@atlaskit/reactions 22.2.0 → 22.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (163) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/dist/cjs/MockReactionsClient.js +1 -49
  3. package/dist/cjs/analytics/analytics.js +1 -40
  4. package/dist/cjs/analytics/index.js +0 -7
  5. package/dist/cjs/analytics/ufo.js +8 -20
  6. package/dist/cjs/client/ReactionServiceClient.js +2 -16
  7. package/dist/cjs/client/index.js +0 -1
  8. package/dist/cjs/components/Counter/Counter.js +10 -24
  9. package/dist/cjs/components/Counter/index.js +0 -6
  10. package/dist/cjs/components/Counter/styles.js +1 -3
  11. package/dist/cjs/components/EmojiButton/EmojiButton.js +3 -18
  12. package/dist/cjs/components/EmojiButton/index.js +0 -1
  13. package/dist/cjs/components/EmojiButton/styles.js +1 -2
  14. package/dist/cjs/components/FlashAnimation/FlashAnimation.js +1 -11
  15. package/dist/cjs/components/FlashAnimation/index.js +0 -1
  16. package/dist/cjs/components/FlashAnimation/styles.js +1 -3
  17. package/dist/cjs/components/Reaction/Reaction.js +23 -62
  18. package/dist/cjs/components/Reaction/index.js +0 -1
  19. package/dist/cjs/components/Reaction/styles.js +1 -4
  20. package/dist/cjs/components/ReactionDialog/ReactionView.js +6 -29
  21. package/dist/cjs/components/ReactionDialog/ReactionsDialog.js +19 -48
  22. package/dist/cjs/components/ReactionDialog/ReactionsList.js +18 -34
  23. package/dist/cjs/components/ReactionDialog/index.js +0 -1
  24. package/dist/cjs/components/ReactionDialog/styles.js +3 -13
  25. package/dist/cjs/components/ReactionPicker/ReactionPicker.js +41 -71
  26. package/dist/cjs/components/ReactionPicker/index.js +0 -1
  27. package/dist/cjs/components/ReactionPicker/styles.js +1 -4
  28. package/dist/cjs/components/ReactionTooltip/ReactionTooltip.js +13 -28
  29. package/dist/cjs/components/ReactionTooltip/index.js +0 -1
  30. package/dist/cjs/components/ReactionTooltip/styles.js +1 -3
  31. package/dist/cjs/components/Reactions/Reactions.js +48 -86
  32. package/dist/cjs/components/Reactions/index.js +0 -1
  33. package/dist/cjs/components/Reactions/styles.js +1 -2
  34. package/dist/cjs/components/Selector/Selector.js +12 -34
  35. package/dist/cjs/components/Selector/index.js +0 -6
  36. package/dist/cjs/components/Selector/styles.js +2 -5
  37. package/dist/cjs/components/ShowMore/ShowMore.js +5 -19
  38. package/dist/cjs/components/ShowMore/index.js +0 -1
  39. package/dist/cjs/components/ShowMore/styles.js +1 -4
  40. package/dist/cjs/components/Trigger/Trigger.js +6 -22
  41. package/dist/cjs/components/Trigger/index.js +0 -1
  42. package/dist/cjs/components/Trigger/styles.js +3 -13
  43. package/dist/cjs/components/UfoErrorBoundary/UfoErrorBoundary.js +1 -19
  44. package/dist/cjs/components/UfoErrorBoundary/index.js +0 -1
  45. package/dist/cjs/components/index.js +0 -5
  46. package/dist/cjs/containers/ConnectedReactionPicker/ConnectedReactionPicker.js +2 -17
  47. package/dist/cjs/containers/ConnectedReactionPicker/index.js +0 -1
  48. package/dist/cjs/containers/ConnectedReactionsView/ConnectedReactionsView.js +17 -62
  49. package/dist/cjs/containers/ConnectedReactionsView/index.js +0 -1
  50. package/dist/cjs/containers/index.js +0 -4
  51. package/dist/cjs/hooks/index.js +0 -1
  52. package/dist/cjs/hooks/useClickAway.js +2 -5
  53. package/dist/cjs/i18n/cs.js +0 -1
  54. package/dist/cjs/i18n/da.js +0 -1
  55. package/dist/cjs/i18n/de.js +0 -1
  56. package/dist/cjs/i18n/en.js +0 -1
  57. package/dist/cjs/i18n/en_GB.js +0 -1
  58. package/dist/cjs/i18n/en_ZZ.js +0 -1
  59. package/dist/cjs/i18n/es.js +0 -1
  60. package/dist/cjs/i18n/et.js +0 -1
  61. package/dist/cjs/i18n/fi.js +0 -1
  62. package/dist/cjs/i18n/fr.js +0 -1
  63. package/dist/cjs/i18n/hu.js +0 -1
  64. package/dist/cjs/i18n/index.js +0 -30
  65. package/dist/cjs/i18n/it.js +0 -1
  66. package/dist/cjs/i18n/ja.js +0 -1
  67. package/dist/cjs/i18n/ko.js +0 -1
  68. package/dist/cjs/i18n/nb.js +0 -1
  69. package/dist/cjs/i18n/nl.js +0 -1
  70. package/dist/cjs/i18n/pl.js +0 -1
  71. package/dist/cjs/i18n/pt_BR.js +0 -1
  72. package/dist/cjs/i18n/pt_PT.js +0 -1
  73. package/dist/cjs/i18n/ru.js +0 -1
  74. package/dist/cjs/i18n/sk.js +0 -1
  75. package/dist/cjs/i18n/sv.js +0 -1
  76. package/dist/cjs/i18n/th.js +0 -1
  77. package/dist/cjs/i18n/tr.js +0 -1
  78. package/dist/cjs/i18n/uk.js +0 -1
  79. package/dist/cjs/i18n/vi.js +0 -1
  80. package/dist/cjs/i18n/zh.js +0 -1
  81. package/dist/cjs/i18n/zh_TW.js +0 -1
  82. package/dist/cjs/index.js +0 -6
  83. package/dist/cjs/shared/constants.js +5 -6
  84. package/dist/cjs/shared/i18n.js +0 -2
  85. package/dist/cjs/shared/index.js +0 -9
  86. package/dist/cjs/shared/utils.js +6 -25
  87. package/dist/cjs/store/MemoryReactionsStore.js +21 -74
  88. package/dist/cjs/store/ReactionConsumer.js +0 -28
  89. package/dist/cjs/store/batched.js +0 -6
  90. package/dist/cjs/store/index.js +0 -2
  91. package/dist/cjs/store/utils.js +0 -25
  92. package/dist/cjs/types/index.js +0 -1
  93. package/dist/cjs/types/reaction.js +0 -10
  94. package/dist/cjs/version.json +1 -1
  95. package/dist/es2019/MockReactionsClient.js +7 -21
  96. package/dist/es2019/analytics/analytics.js +3 -9
  97. package/dist/es2019/analytics/ufo.js +11 -13
  98. package/dist/es2019/client/ReactionServiceClient.js +4 -13
  99. package/dist/es2019/components/Counter/Counter.js +5 -7
  100. package/dist/es2019/components/EmojiButton/EmojiButton.js +0 -3
  101. package/dist/es2019/components/FlashAnimation/FlashAnimation.js +1 -2
  102. package/dist/es2019/components/Reaction/Reaction.js +3 -12
  103. package/dist/es2019/components/Reaction/styles.js +1 -1
  104. package/dist/es2019/components/ReactionDialog/ReactionView.js +0 -4
  105. package/dist/es2019/components/ReactionDialog/ReactionsDialog.js +6 -15
  106. package/dist/es2019/components/ReactionDialog/ReactionsList.js +4 -3
  107. package/dist/es2019/components/ReactionDialog/styles.js +2 -5
  108. package/dist/es2019/components/ReactionPicker/ReactionPicker.js +14 -19
  109. package/dist/es2019/components/ReactionTooltip/ReactionTooltip.js +1 -2
  110. package/dist/es2019/components/Reactions/Reactions.js +16 -25
  111. package/dist/es2019/components/Selector/Selector.js +5 -11
  112. package/dist/es2019/components/Selector/styles.js +1 -1
  113. package/dist/es2019/components/ShowMore/ShowMore.js +1 -2
  114. package/dist/es2019/components/Trigger/Trigger.js +1 -5
  115. package/dist/es2019/components/UfoErrorBoundary/UfoErrorBoundary.js +0 -3
  116. package/dist/es2019/containers/ConnectedReactionPicker/ConnectedReactionPicker.js +0 -4
  117. package/dist/es2019/containers/ConnectedReactionsView/ConnectedReactionsView.js +8 -20
  118. package/dist/es2019/hooks/useClickAway.js +3 -4
  119. package/dist/es2019/index.js +2 -1
  120. package/dist/es2019/shared/constants.js +5 -5
  121. package/dist/es2019/shared/utils.js +7 -15
  122. package/dist/es2019/store/MemoryReactionsStore.js +36 -61
  123. package/dist/es2019/store/ReactionConsumer.js +1 -12
  124. package/dist/es2019/store/batched.js +0 -2
  125. package/dist/es2019/store/utils.js +4 -8
  126. package/dist/es2019/types/reaction.js +1 -1
  127. package/dist/es2019/version.json +1 -1
  128. package/dist/esm/MockReactionsClient.js +1 -42
  129. package/dist/esm/analytics/analytics.js +1 -12
  130. package/dist/esm/analytics/ufo.js +11 -13
  131. package/dist/esm/client/ReactionServiceClient.js +2 -14
  132. package/dist/esm/components/Counter/Counter.js +12 -15
  133. package/dist/esm/components/EmojiButton/EmojiButton.js +2 -6
  134. package/dist/esm/components/FlashAnimation/FlashAnimation.js +1 -2
  135. package/dist/esm/components/Reaction/Reaction.js +23 -40
  136. package/dist/esm/components/Reaction/styles.js +1 -1
  137. package/dist/esm/components/ReactionDialog/ReactionView.js +5 -14
  138. package/dist/esm/components/ReactionDialog/ReactionsDialog.js +20 -35
  139. package/dist/esm/components/ReactionDialog/ReactionsList.js +17 -20
  140. package/dist/esm/components/ReactionDialog/styles.js +2 -5
  141. package/dist/esm/components/ReactionPicker/ReactionPicker.js +42 -52
  142. package/dist/esm/components/ReactionTooltip/ReactionTooltip.js +14 -16
  143. package/dist/esm/components/Reactions/Reactions.js +49 -62
  144. package/dist/esm/components/Selector/Selector.js +13 -22
  145. package/dist/esm/components/Selector/styles.js +1 -1
  146. package/dist/esm/components/ShowMore/ShowMore.js +6 -7
  147. package/dist/esm/components/Trigger/Trigger.js +7 -11
  148. package/dist/esm/components/Trigger/styles.js +3 -6
  149. package/dist/esm/components/UfoErrorBoundary/UfoErrorBoundary.js +1 -14
  150. package/dist/esm/containers/ConnectedReactionPicker/ConnectedReactionPicker.js +2 -9
  151. package/dist/esm/containers/ConnectedReactionsView/ConnectedReactionsView.js +17 -43
  152. package/dist/esm/hooks/useClickAway.js +3 -4
  153. package/dist/esm/index.js +2 -1
  154. package/dist/esm/shared/constants.js +5 -5
  155. package/dist/esm/shared/utils.js +7 -17
  156. package/dist/esm/store/MemoryReactionsStore.js +22 -78
  157. package/dist/esm/store/ReactionConsumer.js +0 -23
  158. package/dist/esm/store/batched.js +0 -4
  159. package/dist/esm/store/utils.js +0 -9
  160. package/dist/esm/types/reaction.js +1 -1
  161. package/dist/esm/version.json +1 -1
  162. package/dist/types/components/ReactionDialog/styles.d.ts +1 -2
  163. package/package.json +6 -4
@@ -1,36 +1,22 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports.ReactionsDialog = exports.RENDER_MODAL_TESTID = void 0;
11
-
12
9
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
-
14
10
  var _react = require("react");
15
-
16
11
  var _reactIntlNext = require("react-intl-next");
17
-
18
12
  var _react2 = require("@emotion/react");
19
-
20
13
  var _standardButton = _interopRequireDefault(require("@atlaskit/button/standard-button"));
21
-
22
14
  var _modalDialog = _interopRequireWildcard(require("@atlaskit/modal-dialog"));
23
-
24
15
  var _shared = require("../../shared");
25
-
26
16
  var _ReactionsList = require("./ReactionsList");
27
-
28
17
  var _styles = require("./styles");
29
-
30
18
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
31
-
32
19
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
33
-
34
20
  /** @jsx jsx */
35
21
 
36
22
  /**
@@ -38,7 +24,6 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
38
24
  */
39
25
  var RENDER_MODAL_TESTID = 'render-reactions-modal';
40
26
  exports.RENDER_MODAL_TESTID = RENDER_MODAL_TESTID;
41
-
42
27
  var getDimensions = function getDimensions(container) {
43
28
  return {
44
29
  clientWidth: container === null || container === void 0 ? void 0 : container.clientWidth,
@@ -46,27 +31,23 @@ var getDimensions = function getDimensions(container) {
46
31
  scrollLeft: container === null || container === void 0 ? void 0 : container.scrollLeft
47
32
  };
48
33
  };
49
-
50
34
  var ReactionsDialog = function ReactionsDialog(_ref) {
51
35
  var _ref$reactions = _ref.reactions,
52
- reactions = _ref$reactions === void 0 ? [] : _ref$reactions,
53
- _ref$handleCloseReact = _ref.handleCloseReactionsDialog,
54
- handleCloseReactionsDialog = _ref$handleCloseReact === void 0 ? function () {} : _ref$handleCloseReact,
55
- emojiProvider = _ref.emojiProvider,
56
- selectedEmojiId = _ref.selectedEmojiId,
57
- _ref$handleSelectReac = _ref.handleSelectReaction,
58
- handleSelectReaction = _ref$handleSelectReac === void 0 ? function () {} : _ref$handleSelectReac;
59
-
36
+ reactions = _ref$reactions === void 0 ? [] : _ref$reactions,
37
+ _ref$handleCloseReact = _ref.handleCloseReactionsDialog,
38
+ handleCloseReactionsDialog = _ref$handleCloseReact === void 0 ? function () {} : _ref$handleCloseReact,
39
+ emojiProvider = _ref.emojiProvider,
40
+ selectedEmojiId = _ref.selectedEmojiId,
41
+ _ref$handleSelectReac = _ref.handleSelectReaction,
42
+ handleSelectReaction = _ref$handleSelectReac === void 0 ? function () {} : _ref$handleSelectReac;
60
43
  var _useState = (0, _react.useState)(),
61
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
62
- elementToScroll = _useState2[0],
63
- setElementToScroll = _useState2[1];
64
-
44
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
45
+ elementToScroll = _useState2[0],
46
+ setElementToScroll = _useState2[1];
65
47
  var _useState3 = (0, _react.useState)(null),
66
- _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
67
- reactionsContainerRef = _useState4[0],
68
- setReactionsContainerRef = _useState4[1];
69
-
48
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
49
+ reactionsContainerRef = _useState4[0],
50
+ setReactionsContainerRef = _useState4[1];
70
51
  var reactionElementsRef = (0, _react.useRef)();
71
52
  var observerRef = (0, _react.useRef)();
72
53
  var intl = (0, _reactIntlNext.useIntl)();
@@ -81,25 +62,22 @@ var ReactionsDialog = function ReactionsDialog(_ref) {
81
62
  return (b === null || b === void 0 ? void 0 : b.count) - (a === null || a === void 0 ? void 0 : a.count);
82
63
  });
83
64
  }, [reactions]);
84
- /* set Reactions Border Width , 9 Number of reactions to display*/
85
65
 
66
+ /* set Reactions Border Width , 9 Number of reactions to display*/
86
67
  var reactionsBorderWidth = (0, _react.useMemo)(function () {
87
68
  return Math.ceil(reactions.length / _shared.constants.NUMBER_OF_REACTIONS_TO_DISPLAY) * 100;
88
69
  }, [reactions]);
89
- /* Callback from IntersectionObserver to set/unset classNames based on visibility to toggle styles*/
90
70
 
71
+ /* Callback from IntersectionObserver to set/unset classNames based on visibility to toggle styles*/
91
72
  var handleNavigation = (0, _react.useCallback)(function (entries) {
92
73
  entries.forEach(function (entry, index) {
93
74
  var _dataset;
94
-
95
75
  var element = entry.target;
96
76
  var emojiElement = element === null || element === void 0 ? void 0 : element.querySelector('[data-emoji-id]');
97
77
  var emojiId = emojiElement === null || emojiElement === void 0 ? void 0 : (_dataset = emojiElement.dataset) === null || _dataset === void 0 ? void 0 : _dataset.emojiId;
98
-
99
78
  if (entry.intersectionRatio < 1) {
100
79
  element.classList.add('disabled');
101
80
  /*Check if selectedEmoji (passed as props based on what user selects) is out of viewport */
102
-
103
81
  if (emojiId === selectedEmojiId && !isSelectedEmojiViewed.current) {
104
82
  setElementToScroll(emojiElement !== null && emojiElement !== void 0 ? emojiElement : undefined);
105
83
  }
@@ -107,7 +85,6 @@ var ReactionsDialog = function ReactionsDialog(_ref) {
107
85
  if (emojiId === selectedEmojiId && !isSelectedEmojiViewed.current) {
108
86
  isSelectedEmojiViewed.current = true;
109
87
  }
110
-
111
88
  element.classList.remove('disabled');
112
89
  }
113
90
  });
@@ -117,21 +94,18 @@ var ReactionsDialog = function ReactionsDialog(_ref) {
117
94
  isSelectedEmojiViewed.current = true;
118
95
  var parentElement = elementToScroll.closest('.reaction-elements');
119
96
  var reactionsList = document.querySelector('#reactions-dialog-tabs-list');
120
-
121
97
  var _getDimensions = getDimensions(reactionsList),
122
- clientWidth = _getDimensions.clientWidth;
123
-
98
+ clientWidth = _getDimensions.clientWidth;
124
99
  var offsetLeft = parentElement === null || parentElement === void 0 ? void 0 : parentElement.offsetLeft;
125
100
  /* which means emoji is not in viewport so scroll to it*/
126
-
127
101
  if (reactionsList && offsetLeft > clientWidth) {
128
102
  var scrollBy = Math.trunc(offsetLeft / clientWidth) * clientWidth;
129
103
  reactionsList.scrollLeft += scrollBy;
130
104
  }
131
105
  }
132
106
  }, [elementToScroll, reactionsContainerRef]);
133
- /* Set up InterSectionObserver to observer reaction elements on navigating*/
134
107
 
108
+ /* Set up InterSectionObserver to observer reaction elements on navigating*/
135
109
  (0, _react.useEffect)(function () {
136
110
  if (reactionsContainerRef) {
137
111
  var options = {
@@ -143,11 +117,9 @@ var ReactionsDialog = function ReactionsDialog(_ref) {
143
117
  reactionElementsRef.current = reactionsContainerRef.querySelectorAll('.reaction-elements');
144
118
  reactionElementsRef.current && reactionElementsRef.current.length > 0 && reactionElementsRef.current.forEach(function (child) {
145
119
  var _observerRef$current;
146
-
147
120
  observerRef === null || observerRef === void 0 ? void 0 : (_observerRef$current = observerRef.current) === null || _observerRef$current === void 0 ? void 0 : _observerRef$current.observe(child);
148
121
  });
149
122
  }
150
-
151
123
  return function () {
152
124
  if (observerRef.current) {
153
125
  observerRef.current.disconnect();
@@ -158,8 +130,8 @@ var ReactionsDialog = function ReactionsDialog(_ref) {
158
130
  var setRef = (0, _react.useCallback)(function (node) {
159
131
  if (!reactionsContainerRef) {
160
132
  setReactionsContainerRef(node);
161
- } // eslint-disable-next-line react-hooks/exhaustive-deps
162
-
133
+ }
134
+ // eslint-disable-next-line react-hooks/exhaustive-deps
163
135
  }, []);
164
136
  return (0, _react2.jsx)(_modalDialog.default, {
165
137
  onClose: handleCloseReactionsDialog,
@@ -183,5 +155,4 @@ var ReactionsDialog = function ReactionsDialog(_ref) {
183
155
  autoFocus: true
184
156
  }, intl.formatMessage(_shared.i18n.messages.closeReactionsDialog))));
185
157
  };
186
-
187
158
  exports.ReactionsDialog = ReactionsDialog;
@@ -1,62 +1,47 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports.ReactionsList = void 0;
11
-
12
9
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
-
14
10
  var _react = require("react");
15
-
16
11
  var _react2 = require("@emotion/react");
17
-
18
12
  var _element = require("@atlaskit/emoji/element");
19
-
20
13
  var _tabs = _interopRequireWildcard(require("@atlaskit/tabs"));
21
-
22
14
  var _tokens = require("@atlaskit/tokens");
23
-
24
15
  var _Counter = require("../Counter");
25
-
26
16
  var _styles = require("./styles");
27
-
28
17
  var _ReactionView = require("./ReactionView");
29
-
30
18
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
31
-
32
19
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
33
-
34
20
  /** @jsx jsx */
21
+
35
22
  var ReactionsList = function ReactionsList(_ref) {
36
23
  var reactions = _ref.reactions,
37
- initialEmojiId = _ref.initialEmojiId,
38
- emojiProvider = _ref.emojiProvider,
39
- onReactionChanged = _ref.onReactionChanged;
40
-
24
+ initialEmojiId = _ref.initialEmojiId,
25
+ emojiProvider = _ref.emojiProvider,
26
+ onReactionChanged = _ref.onReactionChanged;
41
27
  var _useState = (0, _react.useState)(function () {
42
- // Calculate this only on initialize the List of Tabs and each Reactions View collection
43
- return {
44
- index: reactions.findIndex(function (reaction) {
45
- return reaction.emojiId === initialEmojiId;
46
- }),
47
- id: initialEmojiId
48
- };
49
- }),
50
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
51
- selectedEmoji = _useState2[0],
52
- setSelectedEmoji = _useState2[1];
53
-
54
- var theme = (0, _tokens.useThemeObserver)();
28
+ // Calculate this only on initialize the List of Tabs and each Reactions View collection
29
+ return {
30
+ index: reactions.findIndex(function (reaction) {
31
+ return reaction.emojiId === initialEmojiId;
32
+ }),
33
+ id: initialEmojiId
34
+ };
35
+ }),
36
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
37
+ selectedEmoji = _useState2[0],
38
+ setSelectedEmoji = _useState2[1];
39
+ var _useThemeObserver = (0, _tokens.useThemeObserver)(),
40
+ colorMode = _useThemeObserver.colorMode;
55
41
  var onTabChange = (0, _react.useCallback)(function (index, analyticsEvent) {
56
42
  if (index === selectedEmoji.index) {
57
43
  return;
58
44
  }
59
-
60
45
  var emojiId = reactions[index].emojiId;
61
46
  setSelectedEmoji({
62
47
  index: index,
@@ -77,7 +62,7 @@ var ReactionsList = function ReactionsList(_ref) {
77
62
  shortName: ''
78
63
  };
79
64
  return (0, _react2.jsx)("div", {
80
- css: (0, _styles.customTabWrapper)((emojiId === null || emojiId === void 0 ? void 0 : emojiId.id) === selectedEmoji.id, selectedEmoji.id, theme),
65
+ css: (0, _styles.customTabWrapper)((emojiId === null || emojiId === void 0 ? void 0 : emojiId.id) === selectedEmoji.id, selectedEmoji.id, colorMode),
81
66
  className: "reaction-elements",
82
67
  key: reaction.emojiId,
83
68
  "data-testid": emojiId === null || emojiId === void 0 ? void 0 : emojiId.id
@@ -100,5 +85,4 @@ var ReactionsList = function ReactionsList(_ref) {
100
85
  });
101
86
  }));
102
87
  };
103
-
104
88
  exports.ReactionsList = ReactionsList;
@@ -9,5 +9,4 @@ Object.defineProperty(exports, "ReactionsDialog", {
9
9
  return _ReactionsDialog.ReactionsDialog;
10
10
  }
11
11
  });
12
-
13
12
  var _ReactionsDialog = require("./ReactionsDialog");
@@ -4,24 +4,20 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.userStyle = exports.userListStyle = exports.titleStyle = exports.reactionViewStyle = exports.navigationContainerStyle = exports.customTabWrapper = exports.customTabListStyles = exports.counterStyle = exports.containerStyle = exports.centerSpinner = void 0;
7
-
8
7
  var _react = require("@emotion/react");
9
-
10
8
  var _colors = require("@atlaskit/theme/colors");
11
-
12
9
  var _shared = require("../../shared");
13
-
14
10
  /** @jsx jsx */
11
+
15
12
  var REACTIONS_CONTAINER_WIDTH = 48;
16
13
  var REACTION_RIGHT_MARGIN = 8;
17
14
  /* we want to display around 9 reactions and show 10th one as faded so removing 2px from REACTIONS_CONTAINER_WIDTH*/
18
-
19
15
  var CONTAINER_WIDTH = _shared.constants.NUMBER_OF_REACTIONS_TO_DISPLAY * (REACTIONS_CONTAINER_WIDTH + REACTION_RIGHT_MARGIN) + REACTIONS_CONTAINER_WIDTH - 2;
20
16
  var REACTION_CONTAINER_HEIGHT = 48;
17
+
21
18
  /*Reactions Container. Using pseudo Element :after to set border since with onClick of Reaction to higlight the
22
19
  border blue below the reaction. Setting Border Width based on number of reactions to make sure it shows up
23
20
  in case the container overflows */
24
-
25
21
  var containerStyle = function containerStyle(reactionsBorderWidth) {
26
22
  return (0, _react.css)({
27
23
  overflow: 'hidden',
@@ -41,7 +37,6 @@ var containerStyle = function containerStyle(reactionsBorderWidth) {
41
37
  }
42
38
  });
43
39
  };
44
-
45
40
  exports.containerStyle = containerStyle;
46
41
  var titleStyle = (0, _react.css)({
47
42
  '& > h1': {
@@ -54,7 +49,6 @@ var containerEdgeAngle = {
54
49
  rightEdge: 270,
55
50
  leftEdge: 90
56
51
  };
57
-
58
52
  var counterStyle = function counterStyle(isSelected) {
59
53
  return (0, _react.css)({
60
54
  display: 'flex',
@@ -72,9 +66,7 @@ var counterStyle = function counterStyle(isSelected) {
72
66
  }
73
67
  });
74
68
  };
75
-
76
69
  exports.counterStyle = counterStyle;
77
-
78
70
  var fadedCss = function fadedCss(edge, theme) {
79
71
  return (0, _react.css)({
80
72
  content: '""',
@@ -84,10 +76,9 @@ var fadedCss = function fadedCss(edge, theme) {
84
76
  width: "".concat(REACTIONS_CONTAINER_WIDTH, "px"),
85
77
  height: "".concat(REACTION_CONTAINER_HEIGHT, "px"),
86
78
  zIndex: 0,
87
- background: theme === 'dark' || theme === 'legacy-dark' ? "linear-gradient(".concat(containerEdgeAngle[edge], "deg, rgba(34, 39, 43, 0.95) 40.23%, rgba(34, 39, 43, 0.55) 58.33%, rgba(34, 39, 43, 0) 77.49%)") : "linear-gradient(".concat(containerEdgeAngle[edge], "deg, rgba(255, 255, 255, 0.95) 40.23%, rgba(255, 255, 255, 0.55) 58.33%, rgba(255, 255, 255, 0) 77.49%)")
79
+ background: theme === 'dark' ? "linear-gradient(".concat(containerEdgeAngle[edge], "deg, rgba(34, 39, 43, 0.95) 40.23%, rgba(34, 39, 43, 0.55) 58.33%, rgba(34, 39, 43, 0) 77.49%)") : "linear-gradient(".concat(containerEdgeAngle[edge], "deg, rgba(255, 255, 255, 0.95) 40.23%, rgba(255, 255, 255, 0.55) 58.33%, rgba(255, 255, 255, 0) 77.49%)")
88
80
  });
89
81
  };
90
-
91
82
  var customTabWrapper = function customTabWrapper(isSelected, selectedEmojiId, theme) {
92
83
  return (0, _react.css)({
93
84
  flexShrink: 0,
@@ -133,7 +124,6 @@ var customTabWrapper = function customTabWrapper(isSelected, selectedEmojiId, th
133
124
  }
134
125
  });
135
126
  };
136
-
137
127
  exports.customTabWrapper = customTabWrapper;
138
128
  var navigationContainerStyle = (0, _react.css)({
139
129
  '> button': {
@@ -1,58 +1,37 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports.ReactionPicker = exports.RENDER_REACTIONPICKER_TESTID = void 0;
11
-
12
9
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
13
-
14
10
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
-
16
11
  var _react = _interopRequireWildcard(require("react"));
17
-
18
12
  var _react2 = require("@emotion/react");
19
-
20
13
  var _reactIntlNext = require("react-intl-next");
21
-
22
14
  var _picker = require("@atlaskit/emoji/picker");
23
-
24
15
  var _popper = require("@atlaskit/popper");
25
-
26
16
  var _constants = require("@atlaskit/theme/constants");
27
-
28
17
  var _Selector = require("../Selector");
29
-
30
18
  var _Trigger = require("../Trigger");
31
-
32
19
  var _analytics = require("../../analytics");
33
-
34
20
  var _shared = require("../../shared");
35
-
36
21
  var _hooks = require("../../hooks");
37
-
38
22
  var styles = _interopRequireWildcard(require("./styles"));
39
-
40
23
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
41
-
42
24
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
43
-
44
25
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
45
-
46
26
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
47
-
48
27
  /**
49
28
  * Test id for wrapper ReactionPicker div
50
29
  */
51
30
  var RENDER_REACTIONPICKER_TESTID = 'reactionPicker-testid';
31
+
52
32
  /**
53
33
  * Emoji Picker Controller Id for Accessibility Labels
54
34
  */
55
-
56
35
  exports.RENDER_REACTIONPICKER_TESTID = RENDER_REACTIONPICKER_TESTID;
57
36
  var PICKER_CONTROL_ID = 'emoji-picker';
58
37
  var popperModifiers = [
@@ -82,72 +61,66 @@ https://popper.js.org/docs/v1/#modifiers..applyStyle
82
61
  name: 'preventOverflow',
83
62
  enabled: true
84
63
  }];
85
-
86
64
  /**
87
65
  * Picker component for adding reactions
88
66
  */
89
67
  var ReactionPicker = /*#__PURE__*/_react.default.memo(function (props) {
90
68
  var miniMode = props.miniMode,
91
- className = props.className,
92
- emojiProvider = props.emojiProvider,
93
- onSelection = props.onSelection,
94
- allowAllEmojis = props.allowAllEmojis,
95
- disabled = props.disabled,
96
- pickerQuickReactionEmojiIds = props.pickerQuickReactionEmojiIds,
97
- _props$onShowMore = props.onShowMore,
98
- onShowMore = _props$onShowMore === void 0 ? function () {} : _props$onShowMore,
99
- _props$onOpen = props.onOpen,
100
- onOpen = _props$onOpen === void 0 ? function () {} : _props$onOpen,
101
- _props$onCancel = props.onCancel,
102
- onCancel = _props$onCancel === void 0 ? function () {} : _props$onCancel,
103
- _props$tooltipContent = props.tooltipContent,
104
- tooltipContent = _props$tooltipContent === void 0 ? (0, _react2.jsx)(_reactIntlNext.FormattedMessage, _shared.i18n.messages.addReaction) : _props$tooltipContent,
105
- emojiPickerSize = props.emojiPickerSize;
69
+ className = props.className,
70
+ emojiProvider = props.emojiProvider,
71
+ onSelection = props.onSelection,
72
+ allowAllEmojis = props.allowAllEmojis,
73
+ disabled = props.disabled,
74
+ pickerQuickReactionEmojiIds = props.pickerQuickReactionEmojiIds,
75
+ _props$onShowMore = props.onShowMore,
76
+ onShowMore = _props$onShowMore === void 0 ? function () {} : _props$onShowMore,
77
+ _props$onOpen = props.onOpen,
78
+ onOpen = _props$onOpen === void 0 ? function () {} : _props$onOpen,
79
+ _props$onCancel = props.onCancel,
80
+ onCancel = _props$onCancel === void 0 ? function () {} : _props$onCancel,
81
+ _props$tooltipContent = props.tooltipContent,
82
+ tooltipContent = _props$tooltipContent === void 0 ? (0, _react2.jsx)(_reactIntlNext.FormattedMessage, _shared.i18n.messages.addReaction) : _props$tooltipContent,
83
+ emojiPickerSize = props.emojiPickerSize;
106
84
  /**
107
85
  * Container <div /> reference (used by custom hook to detect click outside)
108
86
  */
109
-
110
87
  var wrapperRef = (0, _react.useRef)(null);
111
88
  /**
112
89
  * a function you can ask Popper to recompute your tooltip's position. It will directly call the Popper#update method
113
90
  */
114
-
115
91
  var updatePopper = (0, _react.useRef)();
116
-
117
92
  var _useState = (0, _react.useState)({
118
- /**
119
- * Show the picker floating panel
120
- */
121
- isOpen: false,
93
+ /**
94
+ * Show the picker floating panel
95
+ */
96
+ isOpen: false,
97
+ /**
98
+ * Show the full custom emoji list picker or the default list of emojis
99
+ */
100
+ showFullPicker: !!allowAllEmojis && Array.isArray(pickerQuickReactionEmojiIds) && pickerQuickReactionEmojiIds.length === 0
101
+ }),
102
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
103
+ settings = _useState2[0],
104
+ setSettings = _useState2[1];
122
105
 
123
- /**
124
- * Show the full custom emoji list picker or the default list of emojis
125
- */
126
- showFullPicker: !!allowAllEmojis && Array.isArray(pickerQuickReactionEmojiIds) && pickerQuickReactionEmojiIds.length === 0
127
- }),
128
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
129
- settings = _useState2[0],
130
- setSettings = _useState2[1];
131
106
  /**
132
107
  * Custom hook triggers when user clicks outside the reactions picker
133
108
  */
134
-
135
-
136
109
  (0, _hooks.useClickAway)(wrapperRef, function () {
137
110
  onCancel();
138
111
  close();
139
112
  }, 'click', true, settings.isOpen);
113
+
140
114
  /**
141
115
  * Event callback when the picker is closed
142
116
  * @param _id Optional id if an emoji button was selected or undefineed if was clicked outside the picker
143
117
  */
144
-
145
118
  var close = (0, _react.useCallback)(function (_id) {
146
119
  setSettings({
147
120
  isOpen: false,
148
121
  showFullPicker: !!allowAllEmojis && Array.isArray(pickerQuickReactionEmojiIds) && pickerQuickReactionEmojiIds.length === 0
149
- }); // ufo abort reaction experience
150
-
122
+ });
123
+ // ufo abort reaction experience
151
124
  _analytics.UFO.PickerRender.abort({
152
125
  metadata: {
153
126
  emojiId: _id,
@@ -156,11 +129,11 @@ var ReactionPicker = /*#__PURE__*/_react.default.memo(function (props) {
156
129
  }
157
130
  });
158
131
  }, [allowAllEmojis, pickerQuickReactionEmojiIds]);
132
+
159
133
  /**
160
134
  * Event handle rwhen selecting to show the custom emoji icons picker
161
135
  * @param e event param
162
136
  */
163
-
164
137
  var onSelectMoreClick = (0, _react.useCallback)(function (e) {
165
138
  e.preventDefault();
166
139
  setSettings({
@@ -169,41 +142,38 @@ var ReactionPicker = /*#__PURE__*/_react.default.memo(function (props) {
169
142
  });
170
143
  onShowMore();
171
144
  }, [onShowMore]);
145
+
172
146
  /**
173
147
  * Event callback when an emoji icon is selected
174
148
  * @param item selected item
175
149
  */
176
-
177
150
  var onEmojiSelected = (0, _react.useCallback)(function (item) {
178
151
  // no emoji was selected
179
152
  if (!item.id) {
180
153
  return;
181
154
  }
182
-
183
155
  onSelection(item.id, settings.showFullPicker ? 'emojiPicker' : 'quickSelector');
184
156
  close(item.id);
185
157
  }, [close, onSelection, settings.showFullPicker]);
158
+
186
159
  /**
187
160
  * Event handler when the emoji icon to open the custom picker is selected
188
161
  */
189
-
190
162
  var onTriggerClick = function onTriggerClick() {
191
163
  // ufo start reactions picker open experience
192
164
  _analytics.UFO.PickerRender.start();
193
-
194
165
  setSettings({
195
166
  isOpen: !settings.isOpen,
196
167
  showFullPicker: !!allowAllEmojis && Array.isArray(pickerQuickReactionEmojiIds) && pickerQuickReactionEmojiIds.length === 0
197
168
  });
198
- onOpen(); // ufo reactions picker opened success
199
-
169
+ onOpen();
170
+ // ufo reactions picker opened success
200
171
  _analytics.UFO.PickerRender.success();
201
172
  };
173
+
202
174
  /**
203
175
  * When picker is opened, re-calculate the picker position
204
176
  */
205
-
206
-
207
177
  (0, _react.useEffect)(function () {
208
178
  if (settings.isOpen) {
209
179
  if (updatePopper.current) {
@@ -219,7 +189,8 @@ var ReactionPicker = /*#__PURE__*/_react.default.memo(function (props) {
219
189
  ref: wrapperRef
220
190
  }, (0, _react2.jsx)(_popper.Manager, null, (0, _react2.jsx)(_popper.Reference, null, function (_ref) {
221
191
  var popperRef = _ref.ref;
222
- return (// Render a button to open the <Selector /> panel
192
+ return (
193
+ // Render a button to open the <Selector /> panel
223
194
  (0, _react2.jsx)(_Trigger.Trigger, {
224
195
  ariaAttributes: {
225
196
  'aria-expanded': settings.isOpen,
@@ -237,8 +208,8 @@ var ReactionPicker = /*#__PURE__*/_react.default.memo(function (props) {
237
208
  modifiers: popperModifiers
238
209
  }, function (_ref2) {
239
210
  var ref = _ref2.ref,
240
- style = _ref2.style,
241
- update = _ref2.update;
211
+ style = _ref2.style,
212
+ update = _ref2.update;
242
213
  updatePopper.current = update;
243
214
  return (0, _react2.jsx)(_react.Fragment, null, settings.isOpen && (0, _react2.jsx)("div", {
244
215
  id: PICKER_CONTROL_ID,
@@ -263,5 +234,4 @@ var ReactionPicker = /*#__PURE__*/_react.default.memo(function (props) {
263
234
  })))));
264
235
  })));
265
236
  });
266
-
267
237
  exports.ReactionPicker = ReactionPicker;
@@ -15,5 +15,4 @@ Object.defineProperty(exports, "ReactionPicker", {
15
15
  return _ReactionPicker.ReactionPicker;
16
16
  }
17
17
  });
18
-
19
18
  var _ReactionPicker = require("./ReactionPicker");
@@ -4,14 +4,11 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.popupStyle = exports.pickerStyle = exports.contentStyle = void 0;
7
-
8
7
  var _react = require("@emotion/react");
9
-
10
8
  var _constants = require("@atlaskit/theme/constants");
11
-
12
9
  var _colors = require("@atlaskit/theme/colors");
13
-
14
10
  /** @jsx jsx */
11
+
15
12
  var pickerStyle = (0, _react.css)({
16
13
  verticalAlign: 'middle',
17
14
  '&.miniMode': {