@replyke/ui-core-react-js 4.0.0

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 (133) hide show
  1. package/dist/cjs/components/EmojiSuggestions.d.ts +4 -0
  2. package/dist/cjs/components/EmojiSuggestions.js +42 -0
  3. package/dist/cjs/components/EmojiSuggestions.js.map +1 -0
  4. package/dist/cjs/components/FromNow.d.ts +9 -0
  5. package/dist/cjs/components/FromNow.js +51 -0
  6. package/dist/cjs/components/FromNow.js.map +1 -0
  7. package/dist/cjs/components/GiphyContainer.d.ts +14 -0
  8. package/dist/cjs/components/GiphyContainer.js +132 -0
  9. package/dist/cjs/components/GiphyContainer.js.map +1 -0
  10. package/dist/cjs/components/InfiniteScrollTrigger.d.ts +4 -0
  11. package/dist/cjs/components/InfiniteScrollTrigger.js +31 -0
  12. package/dist/cjs/components/InfiniteScrollTrigger.js.map +1 -0
  13. package/dist/cjs/components/Modal.d.ts +8 -0
  14. package/dist/cjs/components/Modal.js +86 -0
  15. package/dist/cjs/components/Modal.js.map +1 -0
  16. package/dist/cjs/components/Skeleton.d.ts +7 -0
  17. package/dist/cjs/components/Skeleton.js +39 -0
  18. package/dist/cjs/components/Skeleton.js.map +1 -0
  19. package/dist/cjs/components/UserAvatar.d.ts +12 -0
  20. package/dist/cjs/components/UserAvatar.js +26 -0
  21. package/dist/cjs/components/UserAvatar.js.map +1 -0
  22. package/dist/cjs/components/index.d.ts +7 -0
  23. package/dist/cjs/components/index.js +23 -0
  24. package/dist/cjs/components/index.js.map +1 -0
  25. package/dist/cjs/constants/index.d.ts +1 -0
  26. package/dist/cjs/constants/index.js +18 -0
  27. package/dist/cjs/constants/index.js.map +1 -0
  28. package/dist/cjs/constants/reset-styles.d.ts +9 -0
  29. package/dist/cjs/constants/reset-styles.js +54 -0
  30. package/dist/cjs/constants/reset-styles.js.map +1 -0
  31. package/dist/cjs/helpers/index.d.ts +1 -0
  32. package/dist/cjs/helpers/index.js +6 -0
  33. package/dist/cjs/helpers/index.js.map +1 -0
  34. package/dist/cjs/helpers/parseContentWithMentions.d.ts +2 -0
  35. package/dist/cjs/helpers/parseContentWithMentions.js +43 -0
  36. package/dist/cjs/helpers/parseContentWithMentions.js.map +1 -0
  37. package/dist/cjs/hooks/index.d.ts +2 -0
  38. package/dist/cjs/hooks/index.js +11 -0
  39. package/dist/cjs/hooks/index.js.map +1 -0
  40. package/dist/cjs/hooks/useTextareaCursorIndicator.d.ts +8 -0
  41. package/dist/cjs/hooks/useTextareaCursorIndicator.js +32 -0
  42. package/dist/cjs/hooks/useTextareaCursorIndicator.js.map +1 -0
  43. package/dist/cjs/hooks/useWidth.d.ts +2 -0
  44. package/dist/cjs/hooks/useWidth.js +28 -0
  45. package/dist/cjs/hooks/useWidth.js.map +1 -0
  46. package/dist/cjs/icons/EllipsisIcon.d.ts +8 -0
  47. package/dist/cjs/icons/EllipsisIcon.js +6 -0
  48. package/dist/cjs/icons/EllipsisIcon.js.map +1 -0
  49. package/dist/cjs/icons/FlagIcon.d.ts +7 -0
  50. package/dist/cjs/icons/FlagIcon.js +8 -0
  51. package/dist/cjs/icons/FlagIcon.js.map +1 -0
  52. package/dist/cjs/icons/HeartFullIcon.d.ts +7 -0
  53. package/dist/cjs/icons/HeartFullIcon.js +6 -0
  54. package/dist/cjs/icons/HeartFullIcon.js.map +1 -0
  55. package/dist/cjs/icons/HeartIcon.d.ts +7 -0
  56. package/dist/cjs/icons/HeartIcon.js +6 -0
  57. package/dist/cjs/icons/HeartIcon.js.map +1 -0
  58. package/dist/cjs/icons/MagnifyingGlassIcon.d.ts +7 -0
  59. package/dist/cjs/icons/MagnifyingGlassIcon.js +6 -0
  60. package/dist/cjs/icons/MagnifyingGlassIcon.js.map +1 -0
  61. package/dist/cjs/icons/index.d.ts +6 -0
  62. package/dist/cjs/icons/index.js +17 -0
  63. package/dist/cjs/icons/index.js.map +1 -0
  64. package/dist/cjs/index.d.ts +5 -0
  65. package/dist/cjs/index.js +22 -0
  66. package/dist/cjs/index.js.map +1 -0
  67. package/dist/esm/components/EmojiSuggestions.d.ts +4 -0
  68. package/dist/esm/components/EmojiSuggestions.js +40 -0
  69. package/dist/esm/components/EmojiSuggestions.js.map +1 -0
  70. package/dist/esm/components/FromNow.d.ts +9 -0
  71. package/dist/esm/components/FromNow.js +46 -0
  72. package/dist/esm/components/FromNow.js.map +1 -0
  73. package/dist/esm/components/GiphyContainer.d.ts +14 -0
  74. package/dist/esm/components/GiphyContainer.js +130 -0
  75. package/dist/esm/components/GiphyContainer.js.map +1 -0
  76. package/dist/esm/components/InfiniteScrollTrigger.d.ts +4 -0
  77. package/dist/esm/components/InfiniteScrollTrigger.js +29 -0
  78. package/dist/esm/components/InfiniteScrollTrigger.js.map +1 -0
  79. package/dist/esm/components/Modal.d.ts +8 -0
  80. package/dist/esm/components/Modal.js +84 -0
  81. package/dist/esm/components/Modal.js.map +1 -0
  82. package/dist/esm/components/Skeleton.d.ts +7 -0
  83. package/dist/esm/components/Skeleton.js +35 -0
  84. package/dist/esm/components/Skeleton.js.map +1 -0
  85. package/dist/esm/components/UserAvatar.d.ts +12 -0
  86. package/dist/esm/components/UserAvatar.js +24 -0
  87. package/dist/esm/components/UserAvatar.js.map +1 -0
  88. package/dist/esm/components/index.d.ts +7 -0
  89. package/dist/esm/components/index.js +8 -0
  90. package/dist/esm/components/index.js.map +1 -0
  91. package/dist/esm/constants/index.d.ts +1 -0
  92. package/dist/esm/constants/index.js +2 -0
  93. package/dist/esm/constants/index.js.map +1 -0
  94. package/dist/esm/constants/reset-styles.d.ts +9 -0
  95. package/dist/esm/constants/reset-styles.js +51 -0
  96. package/dist/esm/constants/reset-styles.js.map +1 -0
  97. package/dist/esm/helpers/index.d.ts +1 -0
  98. package/dist/esm/helpers/index.js +2 -0
  99. package/dist/esm/helpers/index.js.map +1 -0
  100. package/dist/esm/helpers/parseContentWithMentions.d.ts +2 -0
  101. package/dist/esm/helpers/parseContentWithMentions.js +39 -0
  102. package/dist/esm/helpers/parseContentWithMentions.js.map +1 -0
  103. package/dist/esm/hooks/index.d.ts +2 -0
  104. package/dist/esm/hooks/index.js +3 -0
  105. package/dist/esm/hooks/index.js.map +1 -0
  106. package/dist/esm/hooks/useTextareaCursorIndicator.d.ts +8 -0
  107. package/dist/esm/hooks/useTextareaCursorIndicator.js +30 -0
  108. package/dist/esm/hooks/useTextareaCursorIndicator.js.map +1 -0
  109. package/dist/esm/hooks/useWidth.d.ts +2 -0
  110. package/dist/esm/hooks/useWidth.js +26 -0
  111. package/dist/esm/hooks/useWidth.js.map +1 -0
  112. package/dist/esm/icons/EllipsisIcon.d.ts +8 -0
  113. package/dist/esm/icons/EllipsisIcon.js +4 -0
  114. package/dist/esm/icons/EllipsisIcon.js.map +1 -0
  115. package/dist/esm/icons/FlagIcon.d.ts +7 -0
  116. package/dist/esm/icons/FlagIcon.js +6 -0
  117. package/dist/esm/icons/FlagIcon.js.map +1 -0
  118. package/dist/esm/icons/HeartFullIcon.d.ts +7 -0
  119. package/dist/esm/icons/HeartFullIcon.js +4 -0
  120. package/dist/esm/icons/HeartFullIcon.js.map +1 -0
  121. package/dist/esm/icons/HeartIcon.d.ts +7 -0
  122. package/dist/esm/icons/HeartIcon.js +4 -0
  123. package/dist/esm/icons/HeartIcon.js.map +1 -0
  124. package/dist/esm/icons/MagnifyingGlassIcon.d.ts +7 -0
  125. package/dist/esm/icons/MagnifyingGlassIcon.js +4 -0
  126. package/dist/esm/icons/MagnifyingGlassIcon.js.map +1 -0
  127. package/dist/esm/icons/index.d.ts +6 -0
  128. package/dist/esm/icons/index.js +7 -0
  129. package/dist/esm/icons/index.js.map +1 -0
  130. package/dist/esm/index.d.ts +5 -0
  131. package/dist/esm/index.js +6 -0
  132. package/dist/esm/index.js.map +1 -0
  133. package/package.json +56 -0
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resetIcon = exports.resetImg = exports.resetTextInput = exports.resetP = exports.resetIl = exports.resetUl = exports.resetButton = exports.resetDiv = void 0;
4
+ exports.resetDiv = {
5
+ padding: 0,
6
+ margin: 0,
7
+ };
8
+ exports.resetButton = {
9
+ margin: 0,
10
+ padding: 0,
11
+ borderStyle: "none",
12
+ borderWidth: 0,
13
+ backgroundColor: "transparent",
14
+ outline: "none",
15
+ fontFamily: "inherit",
16
+ cursor: "pointer",
17
+ };
18
+ exports.resetUl = {
19
+ listStyleType: "none",
20
+ padding: 0,
21
+ margin: 0,
22
+ fontFamily: "inherit",
23
+ };
24
+ exports.resetIl = {
25
+ padding: 0,
26
+ margin: 0,
27
+ fontFamily: "inherit",
28
+ };
29
+ exports.resetP = {
30
+ padding: 0,
31
+ margin: 0,
32
+ fontFamily: "inherit",
33
+ cursor: "default",
34
+ };
35
+ exports.resetTextInput = {
36
+ padding: 0,
37
+ margin: 0,
38
+ fontFamily: "inherit",
39
+ resize: "none",
40
+ border: "none",
41
+ outline: "none",
42
+ overflow: "auto",
43
+ boxShadow: "none",
44
+ WebkitBoxShadow: "none",
45
+ };
46
+ exports.resetImg = {
47
+ padding: 0,
48
+ margin: 0,
49
+ };
50
+ exports.resetIcon = {
51
+ padding: 0,
52
+ margin: 0,
53
+ };
54
+ //# sourceMappingURL=reset-styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reset-styles.js","sourceRoot":"","sources":["../../../src/constants/reset-styles.ts"],"names":[],"mappings":";;;AAEa,QAAA,QAAQ,GAAwB;IAC3C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;CACV,CAAC;AAEW,QAAA,WAAW,GAAwB;IAC9C,MAAM,EAAE,CAAC;IACT,OAAO,EAAE,CAAC;IACV,WAAW,EAAE,MAAM;IACnB,WAAW,EAAE,CAAC;IACd,eAAe,EAAE,aAAa;IAC9B,OAAO,EAAE,MAAM;IACf,UAAU,EAAE,SAAS;IACrB,MAAM,EAAE,SAAS;CAClB,CAAC;AAEW,QAAA,OAAO,GAAwB;IAC1C,aAAa,EAAE,MAAM;IACrB,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,SAAS;CACtB,CAAC;AAEW,QAAA,OAAO,GAAwB;IAC1C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,SAAS;CACtB,CAAC;AAEW,QAAA,MAAM,GAAwB;IACzC,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,SAAS;IACrB,MAAM,EAAE,SAAS;CAClB,CAAC;AAEW,QAAA,cAAc,GAAwB;IACjD,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,SAAS;IACrB,MAAM,EAAE,MAAM;IACd,MAAM,EAAE,MAAM;IACd,OAAO,EAAE,MAAM;IACf,QAAQ,EAAE,MAAM;IAChB,SAAS,EAAE,MAAM;IACjB,eAAe,EAAE,MAAM;CACxB,CAAC;AAEW,QAAA,QAAQ,GAAwB;IAC3C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;CACV,CAAC;AAEW,QAAA,SAAS,GAAwB;IAC5C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;CACV,CAAC"}
@@ -0,0 +1 @@
1
+ export { parseContentWithMentions } from "./parseContentWithMentions";
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parseContentWithMentions = void 0;
4
+ var parseContentWithMentions_1 = require("./parseContentWithMentions");
5
+ Object.defineProperty(exports, "parseContentWithMentions", { enumerable: true, get: function () { return parseContentWithMentions_1.parseContentWithMentions; } });
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/helpers/index.ts"],"names":[],"mappings":";;;AAAA,uEAAsE;AAA7D,oIAAA,wBAAwB,OAAA"}
@@ -0,0 +1,2 @@
1
+ import { Mention } from "@replyke/core";
2
+ export declare const parseContentWithMentions: (content: string, mentions: Mention[], currentUserId: string | undefined, currentUserClickCallback: (() => void) | undefined, otherUserClickCallback: ((userId: string) => void) | undefined) => (string | JSX.Element)[];
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parseContentWithMentions = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const parseContentWithMentions = (content, mentions, currentUserId, currentUserClickCallback, otherUserClickCallback) => {
6
+ if (!mentions.length)
7
+ return [content];
8
+ // Create a regex pattern to match all mentions in the array, escaping special characters
9
+ const mentionPattern = new RegExp(mentions
10
+ .map((mention) => `@${mention.username.replace(/[-/\\^$*+?.()|[\]{}]/g, "\\$&")}`)
11
+ .join("|"), "g");
12
+ // Replace mentions with a placeholder and split content based on the regex
13
+ const parts = content.split(mentionPattern);
14
+ // Find all matched mentions in the content
15
+ const matches = Array.from(content.matchAll(mentionPattern));
16
+ // Construct the parsed output
17
+ const parsedContent = [];
18
+ let lastIndex = 0;
19
+ parts.forEach((part, index) => {
20
+ if (part) {
21
+ parsedContent.push(part);
22
+ lastIndex += part.length;
23
+ }
24
+ const match = matches[index];
25
+ if (match) {
26
+ const matchedMention = mentions.find((mention) => `@${mention.username}` === match[0]);
27
+ if (matchedMention) {
28
+ parsedContent.push((0, jsx_runtime_1.jsx)("span", { style: { color: "#1e40af" }, onClick: () => {
29
+ if (matchedMention.id === currentUserId) {
30
+ currentUserClickCallback?.();
31
+ }
32
+ else {
33
+ otherUserClickCallback?.(matchedMention.id);
34
+ }
35
+ }, children: match[0] }, lastIndex));
36
+ lastIndex += match[0].length;
37
+ }
38
+ }
39
+ });
40
+ return parsedContent;
41
+ };
42
+ exports.parseContentWithMentions = parseContentWithMentions;
43
+ //# sourceMappingURL=parseContentWithMentions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseContentWithMentions.js","sourceRoot":"","sources":["../../../src/helpers/parseContentWithMentions.tsx"],"names":[],"mappings":";;;;AAEO,MAAM,wBAAwB,GAAG,CACtC,OAAe,EACf,QAAmB,EACnB,aAAiC,EACjC,wBAAkD,EAClD,sBAA8D,EACpC,EAAE;IAC5B,IAAI,CAAC,QAAQ,CAAC,MAAM;QAAE,OAAO,CAAC,OAAO,CAAC,CAAC;IAEvC,yFAAyF;IACzF,MAAM,cAAc,GAAG,IAAI,MAAM,CAC/B,QAAQ;SACL,GAAG,CACF,CAAC,OAAO,EAAE,EAAE,CACV,IAAI,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,uBAAuB,EAAE,MAAM,CAAC,EAAE,CAClE;SACA,IAAI,CAAC,GAAG,CAAC,EACZ,GAAG,CACJ,CAAC;IAEF,2EAA2E;IAC3E,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;IAE5C,2CAA2C;IAC3C,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC;IAE7D,8BAA8B;IAC9B,MAAM,aAAa,GAA6B,EAAE,CAAC;IACnD,IAAI,SAAS,GAAG,CAAC,CAAC;IAElB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;QAC5B,IAAI,IAAI,EAAE,CAAC;YACT,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACzB,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC;QAC3B,CAAC;QAED,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,cAAc,GAAG,QAAQ,CAAC,IAAI,CAClC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC,QAAQ,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC,CACjD,CAAC;YACF,IAAI,cAAc,EAAE,CAAC;gBACnB,aAAa,CAAC,IAAI,CAChB,iCACE,KAAK,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAC3B,OAAO,EAAE,GAAG,EAAE;wBACZ,IAAI,cAAc,CAAC,EAAE,KAAK,aAAa,EAAE,CAAC;4BACxC,wBAAwB,EAAE,EAAE,CAAC;wBAC/B,CAAC;6BAAM,CAAC;4BACN,sBAAsB,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;wBAC9C,CAAC;oBACH,CAAC,YAGA,KAAK,CAAC,CAAC,CAAC,IAFJ,SAAS,CAGT,CACR,CAAC;gBACF,SAAS,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;YAC/B,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,aAAa,CAAC;AACvB,CAAC,CAAC;AA/DW,QAAA,wBAAwB,4BA+DnC"}
@@ -0,0 +1,2 @@
1
+ export { default as useTextareaCursorIndicator } from "./useTextareaCursorIndicator";
2
+ export { default as useWidth } from "./useWidth";
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.useWidth = exports.useTextareaCursorIndicator = void 0;
7
+ var useTextareaCursorIndicator_1 = require("./useTextareaCursorIndicator");
8
+ Object.defineProperty(exports, "useTextareaCursorIndicator", { enumerable: true, get: function () { return __importDefault(useTextareaCursorIndicator_1).default; } });
9
+ var useWidth_1 = require("./useWidth");
10
+ Object.defineProperty(exports, "useWidth", { enumerable: true, get: function () { return __importDefault(useWidth_1).default; } });
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.ts"],"names":[],"mappings":";;;;;;AAAA,2EAAqF;AAA5E,yJAAA,OAAO,OAA8B;AAC9C,uCAAiD;AAAxC,qHAAA,OAAO,OAAY"}
@@ -0,0 +1,8 @@
1
+ declare function useTextareaCursorIndicator({ textAreaRef, }: {
2
+ textAreaRef: React.RefObject<HTMLTextAreaElement>;
3
+ }): {
4
+ textAreaRef: import("react").RefObject<HTMLTextAreaElement>;
5
+ cursorPosition: number;
6
+ isSelectionActive: boolean;
7
+ };
8
+ export default useTextareaCursorIndicator;
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const react_1 = require("react");
4
+ function useTextareaCursorIndicator({ textAreaRef, }) {
5
+ const [cursorPosition, setCursorPosition] = (0, react_1.useState)(0);
6
+ const [isSelectionActive, setIsSelectionActive] = (0, react_1.useState)(false);
7
+ const updateCursorAndSelection = (0, react_1.useCallback)(() => {
8
+ if (textAreaRef.current) {
9
+ const { selectionStart, selectionEnd } = textAreaRef.current;
10
+ setCursorPosition(selectionStart);
11
+ setIsSelectionActive(selectionStart !== selectionEnd);
12
+ }
13
+ }, [textAreaRef]);
14
+ (0, react_1.useEffect)(() => {
15
+ const textArea = textAreaRef.current;
16
+ if (textArea) {
17
+ textArea.addEventListener("input", updateCursorAndSelection);
18
+ textArea.addEventListener("click", updateCursorAndSelection);
19
+ textArea.addEventListener("keydown", updateCursorAndSelection);
20
+ textArea.addEventListener("keyup", updateCursorAndSelection);
21
+ return () => {
22
+ textArea.removeEventListener("input", updateCursorAndSelection);
23
+ textArea.removeEventListener("click", updateCursorAndSelection);
24
+ textArea.removeEventListener("keydown", updateCursorAndSelection);
25
+ textArea.removeEventListener("keyup", updateCursorAndSelection);
26
+ };
27
+ }
28
+ }, [updateCursorAndSelection, textAreaRef]);
29
+ return { textAreaRef, cursorPosition, isSelectionActive };
30
+ }
31
+ exports.default = useTextareaCursorIndicator;
32
+ //# sourceMappingURL=useTextareaCursorIndicator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTextareaCursorIndicator.js","sourceRoot":"","sources":["../../../src/hooks/useTextareaCursorIndicator.tsx"],"names":[],"mappings":";;AAAA,iCAAyD;AAEzD,SAAS,0BAA0B,CAAC,EAClC,WAAW,GAGZ;IACC,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,IAAA,gBAAQ,EAAS,CAAC,CAAC,CAAC;IAChE,MAAM,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IAE3E,MAAM,wBAAwB,GAAG,IAAA,mBAAW,EAAC,GAAG,EAAE;QAChD,IAAI,WAAW,CAAC,OAAO,EAAE,CAAC;YACxB,MAAM,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,WAAW,CAAC,OAAO,CAAC;YAC7D,iBAAiB,CAAC,cAAc,CAAC,CAAC;YAClC,oBAAoB,CAAC,cAAc,KAAK,YAAY,CAAC,CAAC;QACxD,CAAC;IACH,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;IAElB,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,CAAC;QAErC,IAAI,QAAQ,EAAE,CAAC;YACb,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,wBAAwB,CAAC,CAAC;YAC7D,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,wBAAwB,CAAC,CAAC;YAC7D,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,wBAAwB,CAAC,CAAC;YAC/D,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,wBAAwB,CAAC,CAAC;YAE7D,OAAO,GAAG,EAAE;gBACV,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,wBAAwB,CAAC,CAAC;gBAChE,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,wBAAwB,CAAC,CAAC;gBAChE,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,wBAAwB,CAAC,CAAC;gBAClE,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,wBAAwB,CAAC,CAAC;YAClE,CAAC,CAAC;QACJ,CAAC;IACH,CAAC,EAAE,CAAC,wBAAwB,EAAE,WAAW,CAAC,CAAC,CAAC;IAE5C,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,iBAAiB,EAAE,CAAC;AAC5D,CAAC;AAED,kBAAe,0BAA0B,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare function useWidth(): readonly [number, import("react").MutableRefObject<HTMLDivElement | null>];
2
+ export default useWidth;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ "use client";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ const react_1 = require("react");
5
+ function useWidth() {
6
+ const [width, setWidth] = (0, react_1.useState)(0);
7
+ const ref = (0, react_1.useRef)(null);
8
+ (0, react_1.useEffect)(() => {
9
+ const handleResize = (entries) => {
10
+ if (entries[0].contentRect) {
11
+ setWidth(entries[0].contentRect.width);
12
+ }
13
+ };
14
+ const resizeObserver = new ResizeObserver(handleResize);
15
+ const currentRef = ref.current;
16
+ if (currentRef) {
17
+ resizeObserver.observe(currentRef);
18
+ }
19
+ return () => {
20
+ if (currentRef) {
21
+ resizeObserver.unobserve(currentRef);
22
+ }
23
+ };
24
+ }, []);
25
+ return [width, ref];
26
+ }
27
+ exports.default = useWidth;
28
+ //# sourceMappingURL=useWidth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useWidth.js","sourceRoot":"","sources":["../../../src/hooks/useWidth.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;AAEb,iCAAoD;AAEpD,SAAS,QAAQ;IACf,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAC,CAAC,CAAC,CAAC;IACtC,MAAM,GAAG,GAAG,IAAA,cAAM,EAAwB,IAAI,CAAC,CAAC;IAEhD,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,YAAY,GAAG,CAAC,OAA8B,EAAE,EAAE;YACtD,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBAC3B,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACzC,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,cAAc,GAAG,IAAI,cAAc,CAAC,YAAY,CAAC,CAAC;QACxD,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC;QAC/B,IAAI,UAAU,EAAE,CAAC;YACf,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;QAED,OAAO,GAAG,EAAE;YACV,IAAI,UAAU,EAAE,CAAC;gBACf,cAAc,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;YACvC,CAAC;QACH,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CAAC,KAAK,EAAE,GAAG,CAAU,CAAC;AAC/B,CAAC;AAED,kBAAe,QAAQ,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ interface EllipsisIconProps {
3
+ color?: string;
4
+ width?: number;
5
+ height?: number;
6
+ }
7
+ declare const EllipsisIcon: React.FC<EllipsisIconProps>;
8
+ export default EllipsisIcon;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const EllipsisIcon = ({ color = "#8E8E8E", width = 16, height = 16, }) => ((0, jsx_runtime_1.jsxs)("svg", { xmlns: "http://www.w3.org/2000/svg", width: width, height: height, viewBox: "0 0 24 24", fill: "none", stroke: color, strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [(0, jsx_runtime_1.jsx)("circle", { cx: "12", cy: "12", r: "1" }), (0, jsx_runtime_1.jsx)("circle", { cx: "19", cy: "12", r: "1" }), (0, jsx_runtime_1.jsx)("circle", { cx: "5", cy: "12", r: "1" })] }));
5
+ exports.default = EllipsisIcon;
6
+ //# sourceMappingURL=EllipsisIcon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EllipsisIcon.js","sourceRoot":"","sources":["../../../src/icons/EllipsisIcon.tsx"],"names":[],"mappings":";;;AAQA,MAAM,YAAY,GAAgC,CAAC,EACjD,KAAK,GAAG,SAAS,EACjB,KAAK,GAAG,EAAE,EACV,MAAM,GAAG,EAAE,GACZ,EAAE,EAAE,CAAC,CACJ,iCACE,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,MAAM,EAAE,KAAK,EACb,WAAW,EAAC,GAAG,EACf,aAAa,EAAC,OAAO,EACrB,cAAc,EAAC,OAAO,aAEtB,mCAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,GAAG,EAChC,mCAAQ,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,GAAG,EAChC,mCAAQ,EAAE,EAAC,GAAG,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,GAAG,GAAG,IAC3B,CACP,CAAC;AAEF,kBAAe,YAAY,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ interface IconProps {
3
+ size?: number;
4
+ color?: string;
5
+ }
6
+ declare const FlagIcon: React.FC<IconProps>;
7
+ export default FlagIcon;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const FlagIcon = ({ size = 20, color = "#DC2626" }) => {
5
+ return ((0, jsx_runtime_1.jsx)("svg", { width: size, height: size, viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: (0, jsx_runtime_1.jsx)("path", { d: "M14.27 1.48a1.3 1.3 0 0 0-.65.18 6.32 6.32 0 0 1-3 1.1c-1.66 0-3.65-1-5.65-1a11.41 11.41 0 0 0-3.18.46v-.09a.63.63 0 0 0-1.25 0v11.76a.63.63 0 1 0 1.25 0V11a10.56 10.56 0 0 1 3.18-.46c1.66 0 4.4 1 6.45 1A5.86 5.86 0 0 0 15 10.11a1.17 1.17 0 0 0 .47-.93V2.66a1.21 1.21 0 0 0-1.2-1.18zm0 7.65a4.58 4.58 0 0 1-2.87 1.08 17.73 17.73 0 0 1-3.29-.49 16 16 0 0 0-3.16-.48A12.3 12.3 0 0 0 2 9.57v-6.1A9.85 9.85 0 0 1 4.93 3a11.59 11.59 0 0 1 2.78.48 11.9 11.9 0 0 0 2.87.52 7.5 7.5 0 0 0 3.67-1.27z", fill: color }) }));
6
+ };
7
+ exports.default = FlagIcon;
8
+ //# sourceMappingURL=FlagIcon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FlagIcon.js","sourceRoot":"","sources":["../../../src/icons/FlagIcon.tsx"],"names":[],"mappings":";;;AAOA,MAAM,QAAQ,GAAwB,CAAC,EAAE,IAAI,GAAG,EAAE,EAAE,KAAK,GAAG,SAAS,EAAE,EAAE,EAAE;IACzE,OAAO,CACL,gCACE,KAAK,EAAE,IAAI,EACX,MAAM,EAAE,IAAI,EACZ,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,4BAA4B,YAElC,iCACE,CAAC,EAAC,4eAA4e,EAC9e,IAAI,EAAE,KAAK,GACX,GACE,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,QAAQ,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ interface HeartFullIconProps {
3
+ color?: string;
4
+ size?: number;
5
+ }
6
+ declare const HeartFullIcon: React.FC<HeartFullIconProps>;
7
+ export default HeartFullIcon;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const HeartFullIcon = ({ color = "#DC2626", size = 20, }) => ((0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 512 512", width: size, height: size, fill: color, children: (0, jsx_runtime_1.jsx)("path", { d: "M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9L464.4 300.4c30.4-28.3 47.6-68 47.6-109.5v-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1v5.8c0 41.5 17.2 81.2 47.6 109.5z" }) }));
5
+ exports.default = HeartFullIcon;
6
+ //# sourceMappingURL=HeartFullIcon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeartFullIcon.js","sourceRoot":"","sources":["../../../src/icons/HeartFullIcon.tsx"],"names":[],"mappings":";;;AAOA,MAAM,aAAa,GAAiC,CAAC,EACnD,KAAK,GAAG,SAAS,EACjB,IAAI,GAAG,EAAE,GACV,EAAE,EAAE,CAAC,CACJ,gCACE,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,aAAa,EACrB,KAAK,EAAE,IAAI,EACX,MAAM,EAAE,IAAI,EACZ,IAAI,EAAE,KAAK,YAEX,iCAAM,CAAC,EAAC,kRAAkR,GAAG,GACzR,CACP,CAAC;AAEF,kBAAe,aAAa,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ interface HeartIconProps {
3
+ color?: string;
4
+ size?: number;
5
+ }
6
+ declare const HeartIcon: React.FC<HeartIconProps>;
7
+ export default HeartIcon;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const HeartIcon = ({ color = "#000", size = 20, }) => ((0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 512 512", width: size, height: size, fill: color, children: (0, jsx_runtime_1.jsx)("path", { d: "M225.8 468.2l-2.5-2.3L48.1 303.2C17.4 274.7 0 234.7 0 192.8l0-3.3c0-70.4 50-130.8 119.2-144C158.6 37.9 198.9 47 231 69.6c9 6.4 17.4 13.8 25 22.3c4.2-4.8 8.7-9.2 13.5-13.3c3.7-3.2 7.5-6.2 11.5-9c0 0 0 0 0 0C313.1 47 353.4 37.9 392.8 45.4C462 58.6 512 119.1 512 189.5l0 3.3c0 41.9-17.4 81.9-48.1 110.4L288.7 465.9l-2.5 2.3c-8.2 7.6-19 11.9-30.2 11.9s-22-4.2-30.2-11.9zM239.1 145c-.4-.3-.7-.7-1-1.1l-17.8-20-.1-.1s0 0 0 0c-23.1-25.9-58-37.7-92-31.2C81.6 101.5 48 142.1 48 189.5l0 3.3c0 28.5 11.9 55.8 32.8 75.2L256 430.7 431.2 268c20.9-19.4 32.8-46.7 32.8-75.2l0-3.3c0-47.3-33.6-88-80.1-96.9c-34-6.5-69 5.4-92 31.2c0 0 0 0-.1 .1s0 0-.1 .1l-17.8 20c-.3 .4-.7 .7-1 1.1c-4.5 4.5-10.6 7-16.9 7s-12.4-2.5-16.9-7z" }) }));
5
+ exports.default = HeartIcon;
6
+ //# sourceMappingURL=HeartIcon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeartIcon.js","sourceRoot":"","sources":["../../../src/icons/HeartIcon.tsx"],"names":[],"mappings":";;;AAOA,MAAM,SAAS,GAA6B,CAAC,EAC3C,KAAK,GAAG,MAAM,EACd,IAAI,GAAG,EAAE,GACV,EAAE,EAAE,CAAC,CACJ,gCACE,KAAK,EAAC,4BAA4B,EAClC,OAAO,EAAC,aAAa,EACrB,KAAK,EAAE,IAAI,EACX,MAAM,EAAE,IAAI,EACZ,IAAI,EAAE,KAAK,YAEX,iCAAM,CAAC,EAAC,ksBAAksB,GAAG,GACzsB,CACP,CAAC;AAEF,kBAAe,SAAS,CAAC"}
@@ -0,0 +1,7 @@
1
+ interface MagnifyingGlassIconProps {
2
+ color?: string;
3
+ width?: number;
4
+ height?: number;
5
+ }
6
+ declare const MagnifyingGlassIcon: React.FC<MagnifyingGlassIconProps>;
7
+ export default MagnifyingGlassIcon;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const MagnifyingGlassIcon = ({ color = "#000000", width = 24, height = 24, }) => ((0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", width: width, height: height, viewBox: "0 0 256 256", fill: "none", children: (0, jsx_runtime_1.jsx)("path", { d: "M232.47656,215.51563l-40.67773-40.67774a96.10791,96.10791,0,1,0-16.97168,16.96973l40.67871,40.67871a12.0001,12.0001,0,1,0,16.9707-16.9707ZM43.99707,116a72,72,0,1,1,72,72A72.08124,72.08124,0,0,1,43.99707,116Z", fill: color }) }));
5
+ exports.default = MagnifyingGlassIcon;
6
+ //# sourceMappingURL=MagnifyingGlassIcon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MagnifyingGlassIcon.js","sourceRoot":"","sources":["../../../src/icons/MagnifyingGlassIcon.tsx"],"names":[],"mappings":";;;AAMA,MAAM,mBAAmB,GAAuC,CAAC,EAC/D,KAAK,GAAG,SAAS,EACjB,KAAK,GAAG,EAAE,EACV,MAAM,GAAG,EAAE,GACZ,EAAE,EAAE,CAAC,CACJ,gCACE,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,OAAO,EAAC,aAAa,EACrB,IAAI,EAAC,MAAM,YAEX,iCACE,CAAC,EAAC,iNAAiN,EACnN,IAAI,EAAE,KAAK,GACX,GACE,CACP,CAAC;AAEF,kBAAe,mBAAmB,CAAC"}
@@ -0,0 +1,6 @@
1
+ import EllipsisIcon from "./EllipsisIcon";
2
+ import FlagIcon from "./FlagIcon";
3
+ import HeartFullIcon from "./HeartFullIcon";
4
+ import HeartIcon from "./HeartIcon";
5
+ import MagnifyingGlassIcon from "./MagnifyingGlassIcon";
6
+ export { EllipsisIcon, FlagIcon, HeartFullIcon, HeartIcon, MagnifyingGlassIcon, };
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.MagnifyingGlassIcon = exports.HeartIcon = exports.HeartFullIcon = exports.FlagIcon = exports.EllipsisIcon = void 0;
7
+ const EllipsisIcon_1 = __importDefault(require("./EllipsisIcon"));
8
+ exports.EllipsisIcon = EllipsisIcon_1.default;
9
+ const FlagIcon_1 = __importDefault(require("./FlagIcon"));
10
+ exports.FlagIcon = FlagIcon_1.default;
11
+ const HeartFullIcon_1 = __importDefault(require("./HeartFullIcon"));
12
+ exports.HeartFullIcon = HeartFullIcon_1.default;
13
+ const HeartIcon_1 = __importDefault(require("./HeartIcon"));
14
+ exports.HeartIcon = HeartIcon_1.default;
15
+ const MagnifyingGlassIcon_1 = __importDefault(require("./MagnifyingGlassIcon"));
16
+ exports.MagnifyingGlassIcon = MagnifyingGlassIcon_1.default;
17
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/icons/index.ts"],"names":[],"mappings":";;;;;;AAAA,kEAA0C;AAOxC,uBAPK,sBAAY,CAOL;AANd,0DAAkC;AAOhC,mBAPK,kBAAQ,CAOL;AANV,oEAA4C;AAO1C,wBAPK,uBAAa,CAOL;AANf,4DAAoC;AAOlC,oBAPK,mBAAS,CAOL;AANX,gFAAwD;AAOtD,8BAPK,6BAAmB,CAOL"}
@@ -0,0 +1,5 @@
1
+ export * from "./components";
2
+ export * from "./helpers";
3
+ export * from "./hooks";
4
+ export * from "./icons";
5
+ export * from "./constants";
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./components"), exports);
18
+ __exportStar(require("./helpers"), exports);
19
+ __exportStar(require("./hooks"), exports);
20
+ __exportStar(require("./icons"), exports);
21
+ __exportStar(require("./constants"), exports);
22
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B;AAC7B,4CAA0B;AAC1B,0CAAwB;AACxB,0CAAwB;AACxB,8CAA4B"}
@@ -0,0 +1,4 @@
1
+ declare function EmojiSuggestions({ onEmojiClick, }: {
2
+ onEmojiClick: (emoji: string) => void;
3
+ }): import("react/jsx-runtime").JSX.Element;
4
+ export default EmojiSuggestions;
@@ -0,0 +1,40 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useState } from "react";
3
+ const emojiGroup1 = ["😂", "❤️", "🤣", "😍", "🙏"];
4
+ const emojiGroup2 = ["🥰", "😊", "😭", "👍", "😅"];
5
+ const emojiGroup3 = ["😢", "👏", "💕", "🥺", "😘"];
6
+ const emojiGroup4 = ["🤔", "🤗", "🙌", "😎", "✨"];
7
+ function EmojiSuggestions({ onEmojiClick, }) {
8
+ const [clickedEmoji, setClickedEmoji] = useState(null);
9
+ const [emojiSubset, setEmojiSubset] = useState([]);
10
+ useEffect(() => {
11
+ // Pick 8 random emojis from the array
12
+ const combinedEmojis = [...emojiGroup1, ...emojiGroup2, ...emojiGroup3];
13
+ const shuffled = combinedEmojis.sort(() => 0.5 - Math.random());
14
+ setEmojiSubset(shuffled.slice(0, 8));
15
+ }, []);
16
+ const handleEmojiClick = (emoji) => {
17
+ setClickedEmoji(emoji);
18
+ onEmojiClick(emoji);
19
+ setTimeout(() => setClickedEmoji(null), 150); // Reset after animation
20
+ };
21
+ return (_jsx("div", { style: {
22
+ display: "flex",
23
+ gap: 12,
24
+ padding: 8,
25
+ borderBottom: "1px solid #e6e6e6",
26
+ overflowX: "auto",
27
+ overflowY: "hidden",
28
+ scrollbarWidth: "none",
29
+ msOverflowStyle: "none",
30
+ }, children: emojiSubset.map((emoji) => (_jsx("div", { onClick: () => handleEmojiClick(emoji), style: {
31
+ cursor: "pointer",
32
+ fontSize: 16,
33
+ display: "inline-block",
34
+ userSelect: "none",
35
+ transition: "transform 0.15s",
36
+ transform: clickedEmoji === emoji ? "scale(0.8)" : "scale(1)", // Shrink and grow
37
+ }, children: emoji }, emoji))) }));
38
+ }
39
+ export default EmojiSuggestions;
40
+ //# sourceMappingURL=EmojiSuggestions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EmojiSuggestions.js","sourceRoot":"","sources":["../../../src/components/EmojiSuggestions.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAE5C,MAAM,WAAW,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AACnD,MAAM,WAAW,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AACnD,MAAM,WAAW,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AACnD,MAAM,WAAW,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;AAGlD,SAAS,gBAAgB,CAAC,EACxB,YAAY,GAGb;IACC,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAC;IACtE,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAC;IAE7D,SAAS,CAAC,GAAG,EAAE;QACb,sCAAsC;QACtC,MAAM,cAAc,GAAG,CAAC,GAAG,WAAW,EAAE,GAAG,WAAW,EAAE,GAAG,WAAW,CAAC,CAAC;QAExE,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAChE,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,gBAAgB,GAAG,CAAC,KAAa,EAAE,EAAE;QACzC,eAAe,CAAC,KAAK,CAAC,CAAC;QACvB,YAAY,CAAC,KAAK,CAAC,CAAC;QACpB,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,wBAAwB;IACxE,CAAC,CAAC;IAEF,OAAO,CACL,cACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,GAAG,EAAE,EAAE;YACP,OAAO,EAAE,CAAC;YACV,YAAY,EAAE,mBAAmB;YACjC,SAAS,EAAE,MAAM;YACjB,SAAS,EAAE,QAAQ;YACnB,cAAc,EAAE,MAAM;YACtB,eAAe,EAAE,MAAM;SACxB,YAEA,WAAW,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAC1B,cAEE,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,KAAK,CAAC,EACtC,KAAK,EAAE;gBACL,MAAM,EAAE,SAAS;gBACjB,QAAQ,EAAE,EAAE;gBACZ,OAAO,EAAE,cAAc;gBACvB,UAAU,EAAE,MAAM;gBAClB,UAAU,EAAE,iBAAiB;gBAC7B,SAAS,EAAE,YAAY,KAAK,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,EAAE,kBAAkB;aAClF,YAEA,KAAK,IAXD,KAAK,CAYN,CACP,CAAC,GACE,CACP,CAAC;AACJ,CAAC;AAED,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,9 @@
1
+ declare function FromNow({ time, fontSize, fontWeight, color, lean, justNowText, }: {
2
+ time: Date | string;
3
+ fontSize?: number;
4
+ fontWeight?: number;
5
+ color?: string;
6
+ lean?: boolean;
7
+ justNowText?: string;
8
+ }): import("react/jsx-runtime").JSX.Element;
9
+ export default FromNow;
@@ -0,0 +1,46 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import moment from "moment";
3
+ function formatTime(time, justNowText) {
4
+ const now = new Date();
5
+ const then = new Date(time);
6
+ const seconds = Math.floor((now.getTime() - then.getTime()) / 1000);
7
+ if (seconds < 20) {
8
+ return justNowText;
9
+ }
10
+ else if (seconds < 60) {
11
+ return `${seconds}s`;
12
+ }
13
+ else if (seconds < 3600) {
14
+ return `${Math.floor(seconds / 60)}m`;
15
+ }
16
+ else if (seconds < 86400) {
17
+ return `${Math.floor(seconds / 3600)}h`;
18
+ }
19
+ else if (seconds < 2592000) {
20
+ // 30 days
21
+ return `${Math.floor(seconds / 86400)}d`;
22
+ }
23
+ else if (seconds < 31536000) {
24
+ // 365 days
25
+ return `${Math.floor(seconds / 2592000)}mo`;
26
+ }
27
+ else {
28
+ return `${Math.floor(seconds / 31536000)}y`;
29
+ }
30
+ }
31
+ function FromNow({ time, fontSize = 12, fontWeight = 400, color = "#737373", lean, justNowText = "Just now", }) {
32
+ if (lean) {
33
+ return (_jsx("span", { style: {
34
+ fontSize,
35
+ fontWeight,
36
+ color,
37
+ }, children: formatTime(time, justNowText) }));
38
+ }
39
+ return (_jsx("span", { style: {
40
+ fontSize,
41
+ fontWeight,
42
+ color,
43
+ }, children: moment(new Date(time)).fromNow() }));
44
+ }
45
+ export default FromNow;
46
+ //# sourceMappingURL=FromNow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FromNow.js","sourceRoot":"","sources":["../../../src/components/FromNow.tsx"],"names":[],"mappings":";AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAE5B,SAAS,UAAU,CAAC,IAAmB,EAAE,WAAmB;IAC1D,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;IAEpE,IAAI,OAAO,GAAG,EAAE,EAAE,CAAC;QACjB,OAAO,WAAW,CAAC;IACrB,CAAC;SAAM,IAAI,OAAO,GAAG,EAAE,EAAE,CAAC;QACxB,OAAO,GAAG,OAAO,GAAG,CAAC;IACvB,CAAC;SAAM,IAAI,OAAO,GAAG,IAAI,EAAE,CAAC;QAC1B,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,GAAG,CAAC;IACxC,CAAC;SAAM,IAAI,OAAO,GAAG,KAAK,EAAE,CAAC;QAC3B,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC;IAC1C,CAAC;SAAM,IAAI,OAAO,GAAG,OAAO,EAAE,CAAC;QAC7B,UAAU;QACV,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC;IAC3C,CAAC;SAAM,IAAI,OAAO,GAAG,QAAQ,EAAE,CAAC;QAC9B,WAAW;QACX,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAC9C,CAAC;SAAM,CAAC;QACN,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC;IAC9C,CAAC;AACH,CAAC;AAED,SAAS,OAAO,CAAC,EACf,IAAI,EACJ,QAAQ,GAAG,EAAE,EACb,UAAU,GAAG,GAAG,EAChB,KAAK,GAAG,SAAS,EACjB,IAAI,EACJ,WAAW,GAAG,UAAU,GAQzB;IACC,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,CACL,eACE,KAAK,EAAE;gBACL,QAAQ;gBACR,UAAU;gBACV,KAAK;aACN,YAEA,UAAU,CAAC,IAAI,EAAE,WAAW,CAAC,GACzB,CACR,CAAC;IACJ,CAAC;IACD,OAAO,CACL,eACE,KAAK,EAAE;YACL,QAAQ;YACR,UAAU;YACV,KAAK;SACN,YAEA,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,EAAE,GAC5B,CACR,CAAC;AACJ,CAAC;AAED,eAAe,OAAO,CAAC"}
@@ -0,0 +1,14 @@
1
+ declare function GiphyContainer({ onClickBack, onSelectGif, giphyApiKey, visible, }: {
2
+ onClickBack: () => void;
3
+ onSelectGif: (selectedGif: {
4
+ id: string;
5
+ url: string;
6
+ gifUrl: string;
7
+ gifPreviewUrl: string;
8
+ altText: string | undefined;
9
+ aspectRatio: number;
10
+ }) => void;
11
+ giphyApiKey: string;
12
+ visible: boolean;
13
+ }): import("react/jsx-runtime").JSX.Element;
14
+ export default GiphyContainer;