@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,130 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useRef, useState, useCallback, useMemo } from "react";
3
+ import { Grid } from "@giphy/react-components";
4
+ import { GiphyFetch } from "@giphy/js-fetch-api";
5
+ import { MagnifyingGlassIcon } from "../icons";
6
+ function GiphyContainer({ onClickBack, onSelectGif, giphyApiKey, visible, }) {
7
+ const gridParentRef = useRef(null);
8
+ const [parentWidth, setParentWidth] = useState(0);
9
+ const [query, setQuery] = useState(""); // Current search query
10
+ const [debouncedQuery, setDebouncedQuery] = useState(""); // Debounced query
11
+ const gf = useMemo(() => new GiphyFetch(giphyApiKey), [giphyApiKey]);
12
+ // Debounce effect
13
+ useEffect(() => {
14
+ const handler = setTimeout(() => {
15
+ setDebouncedQuery(query);
16
+ }, 500); // 500ms debounce delay
17
+ return () => {
18
+ clearTimeout(handler);
19
+ };
20
+ }, [query]);
21
+ // Update parent width on mount and resize
22
+ useEffect(() => {
23
+ const updateWidth = () => {
24
+ if (gridParentRef.current) {
25
+ setParentWidth(gridParentRef.current.offsetWidth);
26
+ }
27
+ };
28
+ updateWidth();
29
+ window.addEventListener("resize", updateWidth);
30
+ return () => {
31
+ window.removeEventListener("resize", updateWidth);
32
+ };
33
+ }, []);
34
+ // Conditionally fetch Gifs only when visible
35
+ const fetchGifs = useCallback((offset) => {
36
+ if (!visible) {
37
+ // Return a valid GifsResult object with empty values
38
+ return Promise.resolve({
39
+ data: [],
40
+ pagination: { total_count: 0, count: 0, offset: 0 }, // Provide complete pagination properties
41
+ meta: { status: 200, msg: "OK", response_id: "" },
42
+ });
43
+ }
44
+ // Fetch search results if visible
45
+ if (debouncedQuery.trim().length > 0) {
46
+ return gf.search(debouncedQuery, { offset, limit: 10 });
47
+ }
48
+ // Fetch trending
49
+ return gf.trending({ offset, limit: 10 });
50
+ }, [debouncedQuery, gf, visible]);
51
+ useEffect(() => {
52
+ if (!visible)
53
+ setQuery("");
54
+ }, [visible]);
55
+ // Memoize the Grid component
56
+ const memoizedGrid = useMemo(() => {
57
+ if (parentWidth > 0) {
58
+ return (_jsx(Grid, { width: parentWidth, columns: 2, fetchGifs: fetchGifs, onGifClick: (gifData, e) => {
59
+ e.preventDefault();
60
+ e.stopPropagation();
61
+ const aspectRatio = Number(gifData.images.fixed_width.width) /
62
+ Number(gifData.images.fixed_width.height);
63
+ const selectedGif = {
64
+ id: gifData.id.toString(),
65
+ url: gifData.url,
66
+ gifUrl: gifData.images.fixed_width.url,
67
+ gifPreviewUrl: gifData.images.preview_gif.url,
68
+ altText: gifData.alt_text,
69
+ aspectRatio,
70
+ };
71
+ onSelectGif(selectedGif);
72
+ } }, `${debouncedQuery}-${visible}`));
73
+ }
74
+ return null;
75
+ }, [parentWidth, fetchGifs, debouncedQuery, onSelectGif, visible]);
76
+ return (_jsxs("div", { style: {
77
+ position: "absolute",
78
+ inset: 0,
79
+ opacity: visible ? 1 : 0, // Opacity based on visibility
80
+ backgroundColor: "white",
81
+ height: "100%",
82
+ width: "100%",
83
+ display: "grid",
84
+ gridTemplateRows: "auto 1fr",
85
+ overflow: "hidden",
86
+ padding: "0.25rem",
87
+ gap: "0.25rem",
88
+ zIndex: 1000,
89
+ pointerEvents: visible ? "auto" : "none", // Make it unclickable when not visible
90
+ transition: "opacity 0.1s ease", // Smooth fade effect
91
+ }, children: [_jsxs("div", { style: {
92
+ display: "flex",
93
+ gap: "0.25rem",
94
+ alignItems: "stretch",
95
+ }, children: [_jsx("button", { onClick: onClickBack, style: {
96
+ backgroundColor: "#e5e7eb",
97
+ borderRadius: "0.5rem",
98
+ width: 28,
99
+ display: "flex",
100
+ alignItems: "center",
101
+ justifyContent: "center",
102
+ flexShrink: 0,
103
+ color: "#888",
104
+ }, children: "\u2190" }), _jsxs("div", { style: {
105
+ width: "100%",
106
+ borderRadius: "0.5rem",
107
+ paddingLeft: 8,
108
+ backgroundColor: "#e5e7eb",
109
+ display: "flex",
110
+ alignItems: "center",
111
+ flex: 1,
112
+ }, children: [_jsx("div", { className: "pt-1", children: _jsx(MagnifyingGlassIcon, { width: 14, color: "#888" }) }), _jsx("input", { type: "text", placeholder: "Search GIPHY", value: query, onChange: (e) => setQuery(e.target.value), style: {
113
+ width: "100%",
114
+ padding: "0.5rem",
115
+ boxSizing: "border-box",
116
+ backgroundColor: "transparent",
117
+ fontSize: 13,
118
+ outline: "none", // Removes the default focus outline
119
+ boxShadow: "none", // Removes any focus ring or shadow
120
+ } })] })] }), _jsx("div", { ref: gridParentRef, style: {
121
+ flex: 1,
122
+ height: "100%",
123
+ width: "100%",
124
+ overflowY: "scroll",
125
+ scrollbarWidth: "none",
126
+ msOverflowStyle: "none",
127
+ }, children: memoizedGrid })] }));
128
+ }
129
+ export default GiphyContainer;
130
+ //# sourceMappingURL=GiphyContainer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GiphyContainer.js","sourceRoot":"","sources":["../../../src/components/GiphyContainer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ declare const InfiniteScrollTrigger: ({ onTriggered, }: {
2
+ onTriggered: () => void;
3
+ }) => import("react/jsx-runtime").JSX.Element;
4
+ export default InfiniteScrollTrigger;
@@ -0,0 +1,29 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { useRef, useEffect } from "react";
4
+ const InfiniteScrollTrigger = ({ onTriggered, }) => {
5
+ const commentsEndRef = useRef(null);
6
+ useEffect(() => {
7
+ const currentEndRef = commentsEndRef.current;
8
+ const observer = new IntersectionObserver(([entry]) => {
9
+ if (entry.isIntersecting) {
10
+ onTriggered();
11
+ }
12
+ }, {
13
+ root: null, // Use the document's viewport as the container
14
+ rootMargin: "0px",
15
+ threshold: 0.1, // Trigger when 10% of the target is visible
16
+ });
17
+ if (currentEndRef) {
18
+ observer.observe(currentEndRef);
19
+ }
20
+ return () => {
21
+ if (currentEndRef) {
22
+ observer.unobserve(currentEndRef);
23
+ }
24
+ };
25
+ }, [onTriggered]);
26
+ return _jsx("div", { ref: commentsEndRef, style: { height: 1 } });
27
+ };
28
+ export default InfiniteScrollTrigger;
29
+ //# sourceMappingURL=InfiniteScrollTrigger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InfiniteScrollTrigger.js","sourceRoot":"","sources":["../../../src/components/InfiniteScrollTrigger.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAE1C,MAAM,qBAAqB,GAAG,CAAC,EAC7B,WAAW,GAGZ,EAAE,EAAE;IACH,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;IAEpC,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,aAAa,GAAG,cAAc,CAAC,OAAO,CAAC;QAE7C,MAAM,QAAQ,GAAG,IAAI,oBAAoB,CACvC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE;YACV,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;gBACzB,WAAW,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,EACD;YACE,IAAI,EAAE,IAAI,EAAE,+CAA+C;YAC3D,UAAU,EAAE,KAAK;YACjB,SAAS,EAAE,GAAG,EAAE,4CAA4C;SAC7D,CACF,CAAC;QAEF,IAAI,aAAa,EAAE,CAAC;YAClB,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClC,CAAC;QAED,OAAO,GAAG,EAAE;YACV,IAAI,aAAa,EAAE,CAAC;gBAClB,QAAQ,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;YACpC,CAAC;QACH,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;IAElB,OAAO,cAAK,GAAG,EAAE,cAAc,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,GAAI,CAAC;AAC5D,CAAC,CAAC;AAEF,eAAe,qBAAqB,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React, { ReactNode } from "react";
2
+ interface ModalProps {
3
+ show: boolean;
4
+ onClose?: () => void;
5
+ children: ReactNode;
6
+ }
7
+ declare const Modal: React.FC<ModalProps>;
8
+ export default Modal;
@@ -0,0 +1,84 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { useEffect, useState } from "react";
4
+ const Modal = ({ show, onClose, children }) => {
5
+ const [isVisible, setIsVisible] = useState(show);
6
+ useEffect(() => {
7
+ if (show) {
8
+ setIsVisible(true);
9
+ }
10
+ }, [show]);
11
+ const handleOverlayClick = (e) => {
12
+ e.stopPropagation();
13
+ onClose?.();
14
+ };
15
+ // const handleContentClick = (e: MouseEvent<HTMLDivElement>) => {
16
+ // e.stopPropagation();
17
+ // };
18
+ const handleAnimationEnd = () => {
19
+ if (!show) {
20
+ setIsVisible(false);
21
+ }
22
+ };
23
+ useEffect(() => {
24
+ const styleSheet = document.createElement("style");
25
+ styleSheet.type = "text/css";
26
+ styleSheet.innerText = `
27
+ @keyframes fadeIn {
28
+ from {
29
+ background: rgba(0, 0, 0, 0);
30
+ }
31
+ to {
32
+ background: rgba(0, 0, 0, 0.5);
33
+ }
34
+ }
35
+ @keyframes fadeOut {
36
+ from {
37
+ background: rgba(0, 0, 0, 0.5);
38
+ }
39
+ to {
40
+ background: rgba(0, 0, 0, 0);
41
+ }
42
+ }
43
+ `;
44
+ document.head.appendChild(styleSheet);
45
+ return () => {
46
+ document.head.removeChild(styleSheet);
47
+ };
48
+ }, []);
49
+ if (!isVisible) {
50
+ return null;
51
+ }
52
+ const modalOverlayStyle = {
53
+ position: "fixed",
54
+ top: 0,
55
+ left: 0,
56
+ width: "100%",
57
+ height: "100%",
58
+ background: show ? "rgba(0, 0, 0, 0.5)" : "rgba(0, 0, 0, 0)", // Background based on show state
59
+ display: "flex",
60
+ flexDirection: "column",
61
+ justifyContent: "center",
62
+ alignItems: "stretch",
63
+ zIndex: 1000,
64
+ animation: show ? "fadeIn 0.5s forwards" : "fadeOut 0.5s forwards", // Apply fadeIn or fadeOut
65
+ visibility: show ? "visible" : "hidden",
66
+ };
67
+ // const modalContentStyle: React.CSSProperties = {
68
+ // position: "relative",
69
+ // width: "max-content",
70
+ // backgroundColor:"yellow",
71
+ // };
72
+ // const modalCloseStyle: React.CSSProperties = {
73
+ // position: 'absolute',
74
+ // top: '10px',
75
+ // right: '10px',
76
+ // background: 'none',
77
+ // border: 'none',
78
+ // fontSize: '20px',
79
+ // cursor: 'pointer',
80
+ // };
81
+ return (_jsx("div", { style: modalOverlayStyle, onAnimationEnd: handleAnimationEnd, onClick: handleOverlayClick, children: children }));
82
+ };
83
+ export default Modal;
84
+ //# sourceMappingURL=Modal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Modal.js","sourceRoot":"","sources":["../../../src/components/Modal.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAc,EAAyB,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAQ1E,MAAM,KAAK,GAAyB,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE;IAClE,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAEjD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,IAAI,EAAE,CAAC;YACT,YAAY,CAAC,IAAI,CAAC,CAAC;QACrB,CAAC;IACH,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAEX,MAAM,kBAAkB,GAAG,CAAC,CAA6B,EAAE,EAAE;QAC3D,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,OAAO,EAAE,EAAE,CAAC;IACd,CAAC,CAAC;IAEF,kEAAkE;IAClE,yBAAyB;IACzB,KAAK;IAEL,MAAM,kBAAkB,GAAG,GAAG,EAAE;QAC9B,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,YAAY,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACnD,UAAU,CAAC,IAAI,GAAG,UAAU,CAAC;QAC7B,UAAU,CAAC,SAAS,GAAG;;;;;;;;;;;;;;;;;KAiBtB,CAAC;QACF,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAEtC,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QACxC,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,iBAAiB,GAAwB;QAC7C,QAAQ,EAAE,OAAO;QACjB,GAAG,EAAE,CAAC;QACN,IAAI,EAAE,CAAC;QACP,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;QACd,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,kBAAkB,EAAE,iCAAiC;QAC/F,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,SAAS;QACrB,MAAM,EAAE,IAAI;QACZ,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,uBAAuB,EAAE,0BAA0B;QAC9F,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ;KACxC,CAAC;IAEF,mDAAmD;IACnD,0BAA0B;IAC1B,0BAA0B;IAC1B,8BAA8B;IAC9B,KAAK;IAEL,iDAAiD;IACjD,0BAA0B;IAC1B,iBAAiB;IACjB,mBAAmB;IACnB,wBAAwB;IACxB,oBAAoB;IACpB,sBAAsB;IACtB,uBAAuB;IACvB,KAAK;IAEL,OAAO,CACL,cACE,KAAK,EAAE,iBAAiB,EACxB,cAAc,EAAE,kBAAkB,EAClC,OAAO,EAAE,kBAAkB,YAM1B,QAAQ,GAEL,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ declare function Skeleton({ style }: React.HTMLAttributes<HTMLDivElement>): import("react/jsx-runtime").JSX.Element;
3
+ declare function CommentSkeleton({ extraLeftPadding, }: {
4
+ extraLeftPadding?: number;
5
+ }): import("react/jsx-runtime").JSX.Element;
6
+ declare function UserMentionSkeleton(): import("react/jsx-runtime").JSX.Element;
7
+ export { CommentSkeleton, UserMentionSkeleton, Skeleton };
@@ -0,0 +1,35 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ function Skeleton({ style }) {
3
+ return (_jsxs(_Fragment, { children: [_jsx("style", { children: `
4
+ @keyframes pulse {
5
+ 0% { opacity: 1; }
6
+ 50% { opacity: 0.3; }
7
+ 100% { opacity: 1; }
8
+ }
9
+ ` }), _jsx("div", { style: {
10
+ animation: "pulse 1.5s ease-in-out infinite",
11
+ width: "100%",
12
+ height: 16,
13
+ borderRadius: 8,
14
+ backgroundColor: "#efefef",
15
+ ...style,
16
+ } })] }));
17
+ }
18
+ function CommentSkeleton({ extraLeftPadding = 0, }) {
19
+ return (_jsxs("div", { style: {
20
+ display: "flex",
21
+ gap: "8px",
22
+ width: "100%",
23
+ paddingLeft: 16 + extraLeftPadding,
24
+ }, children: [_jsx(Skeleton, { style: { height: 32, width: 32, borderRadius: "50%" } }), _jsxs("div", { style: { display: "grid", gap: "8px", flex: 1 }, children: [_jsx(Skeleton, { style: { width: "30%", height: 12 } }), _jsx(Skeleton, { style: { height: 12 } }), _jsx(Skeleton, { style: { width: "15%", height: 12 } })] })] }));
25
+ }
26
+ function UserMentionSkeleton() {
27
+ return (_jsxs("div", { style: {
28
+ display: "flex",
29
+ gap: "8px",
30
+ width: "100%",
31
+ alignItems: "center",
32
+ }, children: [_jsx(Skeleton, { style: { height: "35px", width: "35px", borderRadius: "100%" } }), _jsx("div", { style: { flex: 1 }, children: _jsx(Skeleton, {}) })] }));
33
+ }
34
+ export { CommentSkeleton, UserMentionSkeleton, Skeleton };
35
+ //# sourceMappingURL=Skeleton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Skeleton.js","sourceRoot":"","sources":["../../../src/components/Skeleton.tsx"],"names":[],"mappings":";AAEA,SAAS,QAAQ,CAAC,EAAE,KAAK,EAAwC;IAC/D,OAAO,CACL,8BACE,0BACG;;;;;;KAMJ,GACS,EACR,cACE,KAAK,EAAE;oBACL,SAAS,EAAE,iCAAiC;oBAC5C,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,EAAE;oBACV,YAAY,EAAE,CAAC;oBACf,eAAe,EAAE,SAAS;oBAC1B,GAAG,KAAK;iBACT,GACD,IACD,CACJ,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,EACvB,gBAAgB,GAAG,CAAC,GAGrB;IACC,OAAO,CACL,eACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,GAAG,EAAE,KAAK;YACV,KAAK,EAAE,MAAM;YACb,WAAW,EAAE,EAAE,GAAG,gBAAgB;SACnC,aAED,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,GAAI,EACnE,eAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAAE,aAClD,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EACjD,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,EACnC,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,GAAI,IAC7C,IACF,CACP,CAAC;AACJ,CAAC;AAED,SAAS,mBAAmB;IAC1B,OAAO,CACL,eACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,GAAG,EAAE,KAAK;YACV,KAAK,EAAE,MAAM;YACb,UAAU,EAAE,QAAQ;SACrB,aAED,KAAC,QAAQ,IACP,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,GAC9D,EACF,cAAK,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,YACrB,KAAC,QAAQ,KAAG,GACR,IACF,CACP,CAAC;AACJ,CAAC;AAED,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAAE,QAAQ,EAAE,CAAC"}
@@ -0,0 +1,12 @@
1
+ interface UserProps {
2
+ id?: string;
3
+ avatar?: string | null | undefined;
4
+ name?: string | null | undefined;
5
+ username?: string | null | undefined;
6
+ }
7
+ declare function UserAvatar({ user, size, borderRadius, }: {
8
+ user: UserProps | undefined;
9
+ size?: number | undefined;
10
+ borderRadius?: number | undefined;
11
+ }): import("react/jsx-runtime").JSX.Element | null;
12
+ export default UserAvatar;
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { resetImg } from "../constants/reset-styles";
3
+ function UserAvatar({ user, size = 32, borderRadius, }) {
4
+ if (!user)
5
+ return null;
6
+ return (_jsx("div", { style: {
7
+ overflow: "hidden",
8
+ width: size,
9
+ height: size,
10
+ borderRadius: borderRadius || size,
11
+ borderWidth: 1,
12
+ borderColor: "#E6E6E6",
13
+ display: "inline-block",
14
+ flexShrink: 0,
15
+ }, children: _jsx("img", { src: user.avatar ??
16
+ `https://api.dicebear.com/9.x/thumbs/svg?seed=${user.id}`, alt: user.name || user.id, style: {
17
+ ...resetImg,
18
+ width: "100%",
19
+ height: "100%",
20
+ objectFit: "cover",
21
+ } }) }));
22
+ }
23
+ export default UserAvatar;
24
+ //# sourceMappingURL=UserAvatar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserAvatar.js","sourceRoot":"","sources":["../../../src/components/UserAvatar.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AASrD,SAAS,UAAU,CAAC,EAClB,IAAI,EACJ,IAAI,GAAG,EAAE,EACT,YAAY,GAKb;IACC,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAC;IACvB,OAAO,CACL,cACE,KAAK,EAAE;YACL,QAAQ,EAAE,QAAQ;YAClB,KAAK,EAAE,IAAI;YACX,MAAM,EAAE,IAAI;YACZ,YAAY,EAAE,YAAY,IAAI,IAAI;YAClC,WAAW,EAAE,CAAC;YACd,WAAW,EAAE,SAAS;YACtB,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,CAAC;SACd,YAED,cACE,GAAG,EACD,IAAI,CAAC,MAAM;gBACX,gDAAgD,IAAI,CAAC,EAAE,EAAE,EAE3D,GAAG,EAAE,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,EAAE,EACzB,KAAK,EAAE;gBACL,GAAG,QAAQ;gBACX,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,MAAM;gBACd,SAAS,EAAE,OAAO;aACnB,GACD,GACE,CACP,CAAC;AACJ,CAAC;AAED,eAAe,UAAU,CAAC"}
@@ -0,0 +1,7 @@
1
+ export { default as EmojiSuggestions } from "./EmojiSuggestions";
2
+ export { default as FromNow } from "./FromNow";
3
+ export { default as GiphyContainer } from "./GiphyContainer";
4
+ export { default as InfiniteScrollTrigger } from "./InfiniteScrollTrigger";
5
+ export { default as Modal } from "./Modal";
6
+ export { default as UserAvatar } from "./UserAvatar";
7
+ export { Skeleton, CommentSkeleton, UserMentionSkeleton } from "./Skeleton";
@@ -0,0 +1,8 @@
1
+ export { default as EmojiSuggestions } from "./EmojiSuggestions";
2
+ export { default as FromNow } from "./FromNow";
3
+ export { default as GiphyContainer } from "./GiphyContainer";
4
+ export { default as InfiniteScrollTrigger } from "./InfiniteScrollTrigger";
5
+ export { default as Modal } from "./Modal";
6
+ export { default as UserAvatar } from "./UserAvatar";
7
+ export { Skeleton, CommentSkeleton, UserMentionSkeleton } from "./Skeleton";
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC"}
@@ -0,0 +1 @@
1
+ export * from "./reset-styles";
@@ -0,0 +1,2 @@
1
+ export * from "./reset-styles";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/constants/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}
@@ -0,0 +1,9 @@
1
+ import React from "react";
2
+ export declare const resetDiv: React.CSSProperties;
3
+ export declare const resetButton: React.CSSProperties;
4
+ export declare const resetUl: React.CSSProperties;
5
+ export declare const resetIl: React.CSSProperties;
6
+ export declare const resetP: React.CSSProperties;
7
+ export declare const resetTextInput: React.CSSProperties;
8
+ export declare const resetImg: React.CSSProperties;
9
+ export declare const resetIcon: React.CSSProperties;
@@ -0,0 +1,51 @@
1
+ export const resetDiv = {
2
+ padding: 0,
3
+ margin: 0,
4
+ };
5
+ export const resetButton = {
6
+ margin: 0,
7
+ padding: 0,
8
+ borderStyle: "none",
9
+ borderWidth: 0,
10
+ backgroundColor: "transparent",
11
+ outline: "none",
12
+ fontFamily: "inherit",
13
+ cursor: "pointer",
14
+ };
15
+ export const resetUl = {
16
+ listStyleType: "none",
17
+ padding: 0,
18
+ margin: 0,
19
+ fontFamily: "inherit",
20
+ };
21
+ export const resetIl = {
22
+ padding: 0,
23
+ margin: 0,
24
+ fontFamily: "inherit",
25
+ };
26
+ export const resetP = {
27
+ padding: 0,
28
+ margin: 0,
29
+ fontFamily: "inherit",
30
+ cursor: "default",
31
+ };
32
+ export const resetTextInput = {
33
+ padding: 0,
34
+ margin: 0,
35
+ fontFamily: "inherit",
36
+ resize: "none",
37
+ border: "none",
38
+ outline: "none",
39
+ overflow: "auto",
40
+ boxShadow: "none",
41
+ WebkitBoxShadow: "none",
42
+ };
43
+ export const resetImg = {
44
+ padding: 0,
45
+ margin: 0,
46
+ };
47
+ export const resetIcon = {
48
+ padding: 0,
49
+ margin: 0,
50
+ };
51
+ //# 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,MAAM,CAAC,MAAM,QAAQ,GAAwB;IAC3C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;CACV,CAAC;AAEF,MAAM,CAAC,MAAM,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;AAEF,MAAM,CAAC,MAAM,OAAO,GAAwB;IAC1C,aAAa,EAAE,MAAM;IACrB,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,SAAS;CACtB,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAwB;IAC1C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,SAAS;CACtB,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAwB;IACzC,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,SAAS;IACrB,MAAM,EAAE,SAAS;CAClB,CAAC;AAEF,MAAM,CAAC,MAAM,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;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAwB;IAC3C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;CACV,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAwB;IAC5C,OAAO,EAAE,CAAC;IACV,MAAM,EAAE,CAAC;CACV,CAAC"}
@@ -0,0 +1 @@
1
+ export { parseContentWithMentions } from "./parseContentWithMentions";
@@ -0,0 +1,2 @@
1
+ export { parseContentWithMentions } from "./parseContentWithMentions";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/helpers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC"}
@@ -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,39 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ export const parseContentWithMentions = (content, mentions, currentUserId, currentUserClickCallback, otherUserClickCallback) => {
3
+ if (!mentions.length)
4
+ return [content];
5
+ // Create a regex pattern to match all mentions in the array, escaping special characters
6
+ const mentionPattern = new RegExp(mentions
7
+ .map((mention) => `@${mention.username.replace(/[-/\\^$*+?.()|[\]{}]/g, "\\$&")}`)
8
+ .join("|"), "g");
9
+ // Replace mentions with a placeholder and split content based on the regex
10
+ const parts = content.split(mentionPattern);
11
+ // Find all matched mentions in the content
12
+ const matches = Array.from(content.matchAll(mentionPattern));
13
+ // Construct the parsed output
14
+ const parsedContent = [];
15
+ let lastIndex = 0;
16
+ parts.forEach((part, index) => {
17
+ if (part) {
18
+ parsedContent.push(part);
19
+ lastIndex += part.length;
20
+ }
21
+ const match = matches[index];
22
+ if (match) {
23
+ const matchedMention = mentions.find((mention) => `@${mention.username}` === match[0]);
24
+ if (matchedMention) {
25
+ parsedContent.push(_jsx("span", { style: { color: "#1e40af" }, onClick: () => {
26
+ if (matchedMention.id === currentUserId) {
27
+ currentUserClickCallback?.();
28
+ }
29
+ else {
30
+ otherUserClickCallback?.(matchedMention.id);
31
+ }
32
+ }, children: match[0] }, lastIndex));
33
+ lastIndex += match[0].length;
34
+ }
35
+ }
36
+ });
37
+ return parsedContent;
38
+ };
39
+ //# sourceMappingURL=parseContentWithMentions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseContentWithMentions.js","sourceRoot":"","sources":["../../../src/helpers/parseContentWithMentions.tsx"],"names":[],"mappings":";AAEA,MAAM,CAAC,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,eACE,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"}
@@ -0,0 +1,2 @@
1
+ export { default as useTextareaCursorIndicator } from "./useTextareaCursorIndicator";
2
+ export { default as useWidth } from "./useWidth";
@@ -0,0 +1,3 @@
1
+ export { default as useTextareaCursorIndicator } from "./useTextareaCursorIndicator";
2
+ export { default as useWidth } from "./useWidth";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AACrF,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC"}
@@ -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,30 @@
1
+ import { useState, useEffect, useCallback } from "react";
2
+ function useTextareaCursorIndicator({ textAreaRef, }) {
3
+ const [cursorPosition, setCursorPosition] = useState(0);
4
+ const [isSelectionActive, setIsSelectionActive] = useState(false);
5
+ const updateCursorAndSelection = useCallback(() => {
6
+ if (textAreaRef.current) {
7
+ const { selectionStart, selectionEnd } = textAreaRef.current;
8
+ setCursorPosition(selectionStart);
9
+ setIsSelectionActive(selectionStart !== selectionEnd);
10
+ }
11
+ }, [textAreaRef]);
12
+ useEffect(() => {
13
+ const textArea = textAreaRef.current;
14
+ if (textArea) {
15
+ textArea.addEventListener("input", updateCursorAndSelection);
16
+ textArea.addEventListener("click", updateCursorAndSelection);
17
+ textArea.addEventListener("keydown", updateCursorAndSelection);
18
+ textArea.addEventListener("keyup", updateCursorAndSelection);
19
+ return () => {
20
+ textArea.removeEventListener("input", updateCursorAndSelection);
21
+ textArea.removeEventListener("click", updateCursorAndSelection);
22
+ textArea.removeEventListener("keydown", updateCursorAndSelection);
23
+ textArea.removeEventListener("keyup", updateCursorAndSelection);
24
+ };
25
+ }
26
+ }, [updateCursorAndSelection, textAreaRef]);
27
+ return { textAreaRef, cursorPosition, isSelectionActive };
28
+ }
29
+ export default useTextareaCursorIndicator;
30
+ //# sourceMappingURL=useTextareaCursorIndicator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTextareaCursorIndicator.js","sourceRoot":"","sources":["../../../src/hooks/useTextareaCursorIndicator.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAEzD,SAAS,0BAA0B,CAAC,EAClC,WAAW,GAGZ;IACC,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAAS,CAAC,CAAC,CAAC;IAChE,MAAM,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAE3E,MAAM,wBAAwB,GAAG,WAAW,CAAC,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,SAAS,CAAC,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,eAAe,0BAA0B,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare function useWidth(): readonly [number, import("react").MutableRefObject<HTMLDivElement | null>];
2
+ export default useWidth;
@@ -0,0 +1,26 @@
1
+ "use client";
2
+ import { useEffect, useRef, useState } from "react";
3
+ function useWidth() {
4
+ const [width, setWidth] = useState(0);
5
+ const ref = useRef(null);
6
+ useEffect(() => {
7
+ const handleResize = (entries) => {
8
+ if (entries[0].contentRect) {
9
+ setWidth(entries[0].contentRect.width);
10
+ }
11
+ };
12
+ const resizeObserver = new ResizeObserver(handleResize);
13
+ const currentRef = ref.current;
14
+ if (currentRef) {
15
+ resizeObserver.observe(currentRef);
16
+ }
17
+ return () => {
18
+ if (currentRef) {
19
+ resizeObserver.unobserve(currentRef);
20
+ }
21
+ };
22
+ }, []);
23
+ return [width, ref];
24
+ }
25
+ export default useWidth;
26
+ //# 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,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEpD,SAAS,QAAQ;IACf,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IACtC,MAAM,GAAG,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAC;IAEhD,SAAS,CAAC,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,eAAe,QAAQ,CAAC"}