react-intlayer 1.2.0 → 2.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 (184) hide show
  1. package/dist/cjs/IntlayerProvider.cjs +1 -1
  2. package/dist/cjs/IntlayerProvider.cjs.map +1 -1
  3. package/dist/cjs/cli/react-intlayer.cjs +68 -0
  4. package/dist/cjs/cli/react-intlayer.cjs.map +1 -0
  5. package/dist/cjs/cli/react-intlayer.d.ts +1 -0
  6. package/dist/cjs/{ContentEditor/contentRender.cjs → client/ContentEditionLayout.cjs} +9 -14
  7. package/dist/cjs/client/ContentEditionLayout.cjs.map +1 -0
  8. package/dist/cjs/client/ContentEditionLayout.d.ts +6 -0
  9. package/dist/cjs/client/IntlayerClientProvider.cjs +35 -2
  10. package/dist/cjs/client/IntlayerClientProvider.cjs.map +1 -1
  11. package/dist/cjs/client/IntlayerClientProvider.d.ts +2 -1
  12. package/dist/cjs/client/getBrowserLocale.cjs +170 -0
  13. package/dist/cjs/client/getBrowserLocale.cjs.map +1 -0
  14. package/dist/cjs/client/getBrowserLocale.d.ts +26 -0
  15. package/dist/cjs/client/index.cjs +6 -0
  16. package/dist/cjs/client/index.cjs.map +1 -1
  17. package/dist/cjs/client/index.d.ts +2 -0
  18. package/dist/cjs/client/useContent.cjs +2 -2
  19. package/dist/cjs/client/useContent.cjs.map +1 -1
  20. package/dist/cjs/client/useContent.d.ts +1 -2
  21. package/dist/cjs/client/useLocale.cjs +5 -3
  22. package/dist/cjs/client/useLocale.cjs.map +1 -1
  23. package/dist/cjs/client/useLocale.d.ts +1 -0
  24. package/dist/cjs/client/useLocaleBase.cjs +49 -0
  25. package/dist/cjs/client/useLocaleBase.cjs.map +1 -0
  26. package/dist/cjs/client/useLocaleBase.d.ts +14 -0
  27. package/dist/cjs/client/useLocaleCookie.cjs +1 -1
  28. package/dist/cjs/client/useLocaleCookie.cjs.map +1 -1
  29. package/dist/cjs/client/useTraduction.cjs.map +1 -1
  30. package/dist/cjs/client/useTraduction.d.ts +6 -5
  31. package/dist/cjs/craco/craco.config.cjs +32 -0
  32. package/dist/cjs/craco/craco.config.cjs.map +1 -0
  33. package/dist/cjs/craco/craco.config.d.ts +2 -0
  34. package/dist/cjs/craco/intlayerCracoPlugin.cjs +89 -0
  35. package/dist/cjs/craco/intlayerCracoPlugin.cjs.map +1 -0
  36. package/dist/cjs/craco/intlayerCracoPlugin.d.ts +26 -0
  37. package/dist/cjs/getEnumeration.cjs +0 -4
  38. package/dist/cjs/getEnumeration.cjs.map +1 -1
  39. package/dist/cjs/getEnumeration.d.ts +8 -5
  40. package/dist/cjs/getTranslation.cjs +1 -5
  41. package/dist/cjs/getTranslation.cjs.map +1 -1
  42. package/dist/cjs/getTranslation.d.ts +3 -2
  43. package/dist/cjs/index.cjs +4 -0
  44. package/dist/cjs/index.cjs.map +1 -1
  45. package/dist/cjs/index.d.ts +2 -0
  46. package/dist/cjs/processDictionary/{contentDictionary.d.cjs → contentDictionary.cjs} +3 -3
  47. package/dist/cjs/processDictionary/contentDictionary.cjs.map +1 -0
  48. package/dist/cjs/processDictionary/contentDictionary.d.ts +16 -0
  49. package/dist/cjs/processDictionary/index.cjs +118 -21
  50. package/dist/cjs/processDictionary/index.cjs.map +1 -1
  51. package/dist/cjs/processDictionary/index.d.ts +5 -4
  52. package/dist/cjs/server/IntlayerServerProvider.cjs +1 -1
  53. package/dist/cjs/server/IntlayerServerProvider.cjs.map +1 -1
  54. package/dist/cjs/server/getLocaleTranslation.cjs +1 -1
  55. package/dist/cjs/server/getLocaleTranslation.cjs.map +1 -1
  56. package/dist/cjs/server/useTraduction.cjs.map +1 -1
  57. package/dist/cjs/server/useTraduction.d.ts +4 -3
  58. package/dist/cjs/useIntlayerBase.cjs +3 -0
  59. package/dist/cjs/useIntlayerBase.cjs.map +1 -1
  60. package/dist/cjs/vite/intlayerPlugin.cjs +60 -0
  61. package/dist/cjs/vite/intlayerPlugin.cjs.map +1 -0
  62. package/dist/cjs/vite/intlayerPlugin.d.ts +17 -0
  63. package/dist/esm/IntlayerProvider.mjs +3 -2
  64. package/dist/esm/IntlayerProvider.mjs.map +1 -1
  65. package/dist/esm/chunk-ZNCO4QRF.mjs +9 -0
  66. package/dist/esm/cli/react-intlayer.d.mts +1 -0
  67. package/dist/esm/cli/react-intlayer.mjs +45 -0
  68. package/dist/esm/cli/react-intlayer.mjs.map +1 -0
  69. package/dist/esm/client/ContentEditionLayout.d.mts +6 -0
  70. package/dist/esm/client/ContentEditionLayout.mjs +11 -0
  71. package/dist/esm/client/ContentEditionLayout.mjs.map +1 -0
  72. package/dist/esm/client/IntlayerClientProvider.d.mts +2 -1
  73. package/dist/esm/client/IntlayerClientProvider.mjs +42 -7
  74. package/dist/esm/client/IntlayerClientProvider.mjs.map +1 -1
  75. package/dist/esm/client/getBrowserLocale.d.mts +26 -0
  76. package/dist/esm/client/getBrowserLocale.mjs +146 -0
  77. package/dist/esm/client/getBrowserLocale.mjs.map +1 -0
  78. package/dist/esm/client/index.d.mts +2 -0
  79. package/dist/esm/client/index.mjs +5 -0
  80. package/dist/esm/client/index.mjs.map +1 -1
  81. package/dist/esm/client/useContent.d.mts +1 -2
  82. package/dist/esm/client/useContent.mjs +3 -2
  83. package/dist/esm/client/useContent.mjs.map +1 -1
  84. package/dist/esm/client/useIntlayer.mjs +1 -0
  85. package/dist/esm/client/useIntlayer.mjs.map +1 -1
  86. package/dist/esm/client/useLocale.d.mts +1 -0
  87. package/dist/esm/client/useLocale.mjs +7 -4
  88. package/dist/esm/client/useLocale.mjs.map +1 -1
  89. package/dist/esm/client/useLocaleBase.d.mts +14 -0
  90. package/dist/esm/client/useLocaleBase.mjs +26 -0
  91. package/dist/esm/client/useLocaleBase.mjs.map +1 -0
  92. package/dist/esm/client/useLocaleCookie.mjs +3 -4
  93. package/dist/esm/client/useLocaleCookie.mjs.map +1 -1
  94. package/dist/esm/client/useTraduction.d.mts +6 -5
  95. package/dist/esm/client/useTraduction.mjs +1 -0
  96. package/dist/esm/client/useTraduction.mjs.map +1 -1
  97. package/dist/esm/craco/craco.config.d.mts +2 -0
  98. package/dist/esm/craco/craco.config.mjs +17 -0
  99. package/dist/esm/craco/craco.config.mjs.map +1 -0
  100. package/dist/esm/craco/intlayerCracoPlugin.d.mts +26 -0
  101. package/dist/esm/craco/intlayerCracoPlugin.mjs +54 -0
  102. package/dist/esm/craco/intlayerCracoPlugin.mjs.map +1 -0
  103. package/dist/esm/getEnumeration.d.mts +8 -5
  104. package/dist/esm/getEnumeration.mjs +1 -4
  105. package/dist/esm/getEnumeration.mjs.map +1 -1
  106. package/dist/esm/getTranslation.d.mts +3 -2
  107. package/dist/esm/getTranslation.mjs +3 -8
  108. package/dist/esm/getTranslation.mjs.map +1 -1
  109. package/dist/esm/index.d.mts +2 -0
  110. package/dist/esm/index.mjs +6 -1
  111. package/dist/esm/index.mjs.map +1 -1
  112. package/dist/esm/processDictionary/contentDictionary.d.mts +16 -0
  113. package/dist/esm/processDictionary/contentDictionary.mjs +1 -0
  114. package/dist/esm/processDictionary/contentDictionary.mjs.map +1 -0
  115. package/dist/esm/processDictionary/index.d.mts +5 -4
  116. package/dist/esm/processDictionary/index.mjs +122 -25
  117. package/dist/esm/processDictionary/index.mjs.map +1 -1
  118. package/dist/esm/server/IntlayerServerProvider.mjs +3 -4
  119. package/dist/esm/server/IntlayerServerProvider.mjs.map +1 -1
  120. package/dist/esm/server/getLocaleTranslation.mjs +3 -2
  121. package/dist/esm/server/getLocaleTranslation.mjs.map +1 -1
  122. package/dist/esm/server/index.mjs +1 -0
  123. package/dist/esm/server/index.mjs.map +1 -1
  124. package/dist/esm/server/serverContext.mjs +1 -0
  125. package/dist/esm/server/serverContext.mjs.map +1 -1
  126. package/dist/esm/server/useIntlayer.mjs +1 -0
  127. package/dist/esm/server/useIntlayer.mjs.map +1 -1
  128. package/dist/esm/server/useTraduction.d.mts +4 -3
  129. package/dist/esm/server/useTraduction.mjs +1 -0
  130. package/dist/esm/server/useTraduction.mjs.map +1 -1
  131. package/dist/esm/useIntlayerBase.mjs +4 -0
  132. package/dist/esm/useIntlayerBase.mjs.map +1 -1
  133. package/dist/esm/vite/intlayerPlugin.d.mts +17 -0
  134. package/dist/esm/vite/intlayerPlugin.mjs +36 -0
  135. package/dist/esm/vite/intlayerPlugin.mjs.map +1 -0
  136. package/package.json +37 -6
  137. package/src/IntlayerProvider.tsx +2 -2
  138. package/src/cli/react-intlayer.ts +60 -0
  139. package/src/client/ContentEditionLayout.tsx +15 -0
  140. package/src/client/IntlayerClientProvider.tsx +50 -12
  141. package/src/client/getBrowserLocale.tsx +192 -0
  142. package/src/client/index.ts +2 -0
  143. package/src/client/useContent.ts +2 -2
  144. package/src/client/useLocale.ts +5 -4
  145. package/src/client/useLocaleBase.ts +24 -0
  146. package/src/client/useLocaleCookie.ts +2 -5
  147. package/src/client/useTraduction.ts +6 -5
  148. package/src/craco/craco.config.ts +11 -0
  149. package/src/craco/intlayerCracoPlugin.ts +89 -0
  150. package/src/getEnumeration.ts +8 -10
  151. package/src/getTranslation.ts +5 -12
  152. package/src/index.ts +2 -1
  153. package/src/processDictionary/{contentDictionary.d.ts → contentDictionary.ts} +6 -5
  154. package/src/processDictionary/index.ts +159 -25
  155. package/src/server/IntlayerServerProvider.tsx +2 -5
  156. package/src/server/getLocaleTranslation.ts +2 -2
  157. package/src/server/useTraduction.ts +4 -3
  158. package/src/useIntlayerBase.ts +3 -0
  159. package/src/vite/intlayerPlugin.ts +59 -0
  160. package/dist/cjs/ContentEditor/ContentEditor.cjs +0 -110
  161. package/dist/cjs/ContentEditor/ContentEditor.cjs.map +0 -1
  162. package/dist/cjs/ContentEditor/ContentEditor.d.ts +0 -8
  163. package/dist/cjs/ContentEditor/contentRender.cjs.map +0 -1
  164. package/dist/cjs/ContentEditor/contentRender.d.ts +0 -3
  165. package/dist/cjs/ContentEditor/index.cjs +0 -25
  166. package/dist/cjs/ContentEditor/index.cjs.map +0 -1
  167. package/dist/cjs/ContentEditor/index.d.ts +0 -3
  168. package/dist/cjs/processDictionary/contentDictionary.d.cjs.map +0 -1
  169. package/dist/cjs/processDictionary/contentDictionary.d.d.ts +0 -29
  170. package/dist/esm/ContentEditor/ContentEditor.d.mts +0 -8
  171. package/dist/esm/ContentEditor/ContentEditor.mjs +0 -91
  172. package/dist/esm/ContentEditor/ContentEditor.mjs.map +0 -1
  173. package/dist/esm/ContentEditor/contentRender.d.mts +0 -3
  174. package/dist/esm/ContentEditor/contentRender.mjs +0 -13
  175. package/dist/esm/ContentEditor/contentRender.mjs.map +0 -1
  176. package/dist/esm/ContentEditor/index.d.mts +0 -3
  177. package/dist/esm/ContentEditor/index.mjs +0 -3
  178. package/dist/esm/ContentEditor/index.mjs.map +0 -1
  179. package/dist/esm/processDictionary/contentDictionary.d.d.mts +0 -29
  180. package/dist/esm/processDictionary/contentDictionary.d.mjs +0 -1
  181. package/src/ContentEditor/ContentEditor.tsx +0 -116
  182. package/src/ContentEditor/contentRender.tsx +0 -11
  183. package/src/ContentEditor/index.tsx +0 -2
  184. /package/dist/esm/{processDictionary/contentDictionary.d.mjs.map → chunk-ZNCO4QRF.mjs.map} +0 -0
@@ -1,91 +0,0 @@
1
- "use client";
2
- import { jsx } from "react/jsx-runtime";
3
- import {
4
- useEffect,
5
- useState,
6
- useRef,
7
- useCallback
8
- } from "react";
9
- const PRESS_DETECT_DURATION = 500;
10
- const ContentEditor = ({ children }) => {
11
- const divRef = useRef(null);
12
- const [isEditing, setIsEditing] = useState(false);
13
- const pressTimerRef = useRef(null);
14
- const handleOnLongPress = () => {
15
- setIsEditing(true);
16
- };
17
- const startPressTimer = () => {
18
- pressTimerRef.current = setTimeout(() => {
19
- handleOnLongPress();
20
- }, PRESS_DETECT_DURATION);
21
- };
22
- const clearPressTimer = () => {
23
- if (pressTimerRef.current) {
24
- clearTimeout(pressTimerRef.current);
25
- pressTimerRef.current = null;
26
- }
27
- };
28
- const handleMouseDown = () => {
29
- clearPressTimer();
30
- startPressTimer();
31
- };
32
- const handleMouseUp = () => {
33
- clearPressTimer();
34
- };
35
- const handleClickOutside = useCallback(
36
- (event) => {
37
- if (divRef.current && !divRef.current.contains(event.target)) {
38
- setIsEditing(false);
39
- }
40
- },
41
- [divRef]
42
- );
43
- useEffect(() => {
44
- document.addEventListener("mousedown", handleClickOutside);
45
- return () => {
46
- document.removeEventListener("mousedown", handleClickOutside);
47
- clearPressTimer();
48
- };
49
- }, [handleClickOutside]);
50
- const handleOnClick = (e) => {
51
- if (isEditing) {
52
- e.preventDefault();
53
- e.stopPropagation();
54
- }
55
- };
56
- const handleOnBlur = () => {
57
- setIsEditing(false);
58
- };
59
- const onContentChange = (_e) => {
60
- };
61
- return /* @__PURE__ */ jsx(
62
- "div",
63
- {
64
- role: "textbox",
65
- tabIndex: 0,
66
- onKeyUp: () => null,
67
- contentEditable: isEditing,
68
- onInput: onContentChange,
69
- onClick: handleOnClick,
70
- onMouseDown: handleMouseDown,
71
- onMouseUp: handleMouseUp,
72
- onMouseLeave: handleMouseUp,
73
- onTouchStart: handleMouseDown,
74
- onTouchEnd: handleMouseUp,
75
- onTouchCancel: handleMouseUp,
76
- onBlur: handleOnBlur,
77
- suppressContentEditableWarning: true,
78
- style: isEditing ? {
79
- backgroundColor: "transparent",
80
- cursor: "text",
81
- display: "inline"
82
- } : { cursor: "pointer", display: "inline" },
83
- ref: divRef,
84
- children
85
- }
86
- );
87
- };
88
- export {
89
- ContentEditor
90
- };
91
- //# sourceMappingURL=ContentEditor.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/ContentEditor/ContentEditor.tsx"],"sourcesContent":["'use client';\n\nimport {\n useEffect,\n useState,\n useRef,\n useCallback,\n type FC,\n type MouseEventHandler,\n} from 'react';\n\ntype ContentEditorProps = {\n children?: string;\n};\n\nconst PRESS_DETECT_DURATION = 500;\n\nexport const ContentEditor: FC<ContentEditorProps> = ({ children }) => {\n const divRef = useRef<HTMLDivElement>(null);\n const [isEditing, setIsEditing] = useState(false);\n const pressTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n\n const handleOnLongPress = () => {\n setIsEditing(true);\n };\n\n const startPressTimer = () => {\n pressTimerRef.current = setTimeout(() => {\n handleOnLongPress();\n }, PRESS_DETECT_DURATION);\n };\n\n const clearPressTimer = () => {\n if (pressTimerRef.current) {\n clearTimeout(pressTimerRef.current);\n pressTimerRef.current = null;\n }\n };\n\n const handleMouseDown = () => {\n clearPressTimer(); // Ensure any previous timer is cleared\n startPressTimer();\n };\n\n const handleMouseUp = () => {\n clearPressTimer();\n };\n\n // Use useCallback to ensure the function identity remains stable\n const handleClickOutside = useCallback(\n (event: MouseEvent) => {\n if (divRef.current && !divRef.current.contains(event.target as Node)) {\n setIsEditing(false);\n }\n },\n [divRef]\n );\n\n useEffect(() => {\n // Attach click outside listener\n document.addEventListener('mousedown', handleClickOutside);\n\n return () => {\n // Cleanup\n document.removeEventListener('mousedown', handleClickOutside);\n clearPressTimer(); // Ensure to clear the timer when component unmounts\n };\n }, [handleClickOutside]);\n\n const handleOnClick: MouseEventHandler<HTMLDivElement> = (e) => {\n if (isEditing) {\n e.preventDefault();\n e.stopPropagation();\n }\n };\n\n const handleOnBlur = () => {\n // Stop editing when the element loses focus\n setIsEditing(false);\n };\n\n const onContentChange = (_e: React.FormEvent<HTMLDivElement>) => {\n // console.log(e.currentTarget.textContent);\n };\n\n return (\n <div\n role=\"textbox\"\n tabIndex={0}\n onKeyUp={() => null}\n contentEditable={isEditing}\n onInput={onContentChange}\n onClick={handleOnClick}\n onMouseDown={handleMouseDown}\n onMouseUp={handleMouseUp}\n onMouseLeave={handleMouseUp}\n onTouchStart={handleMouseDown}\n onTouchEnd={handleMouseUp}\n onTouchCancel={handleMouseUp}\n onBlur={handleOnBlur}\n suppressContentEditableWarning={true} // To suppress the warning for controlled components\n style={\n isEditing\n ? {\n backgroundColor: 'transparent',\n cursor: 'text',\n display: 'inline',\n }\n : { cursor: 'pointer', display: 'inline' }\n }\n ref={divRef}\n >\n {children}\n </div>\n );\n};\n"],"mappings":";AAsFI;AApFJ;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OAGK;AAMP,MAAM,wBAAwB;AAEvB,MAAM,gBAAwC,CAAC,EAAE,SAAS,MAAM;AACrE,QAAM,SAAS,OAAuB,IAAI;AAC1C,QAAM,CAAC,WAAW,YAAY,IAAI,SAAS,KAAK;AAChD,QAAM,gBAAgB,OAA6C,IAAI;AAEvE,QAAM,oBAAoB,MAAM;AAC9B,iBAAa,IAAI;AAAA,EACnB;AAEA,QAAM,kBAAkB,MAAM;AAC5B,kBAAc,UAAU,WAAW,MAAM;AACvC,wBAAkB;AAAA,IACpB,GAAG,qBAAqB;AAAA,EAC1B;AAEA,QAAM,kBAAkB,MAAM;AAC5B,QAAI,cAAc,SAAS;AACzB,mBAAa,cAAc,OAAO;AAClC,oBAAc,UAAU;AAAA,IAC1B;AAAA,EACF;AAEA,QAAM,kBAAkB,MAAM;AAC5B,oBAAgB;AAChB,oBAAgB;AAAA,EAClB;AAEA,QAAM,gBAAgB,MAAM;AAC1B,oBAAgB;AAAA,EAClB;AAGA,QAAM,qBAAqB;AAAA,IACzB,CAAC,UAAsB;AACrB,UAAI,OAAO,WAAW,CAAC,OAAO,QAAQ,SAAS,MAAM,MAAc,GAAG;AACpE,qBAAa,KAAK;AAAA,MACpB;AAAA,IACF;AAAA,IACA,CAAC,MAAM;AAAA,EACT;AAEA,YAAU,MAAM;AAEd,aAAS,iBAAiB,aAAa,kBAAkB;AAEzD,WAAO,MAAM;AAEX,eAAS,oBAAoB,aAAa,kBAAkB;AAC5D,sBAAgB;AAAA,IAClB;AAAA,EACF,GAAG,CAAC,kBAAkB,CAAC;AAEvB,QAAM,gBAAmD,CAAC,MAAM;AAC9D,QAAI,WAAW;AACb,QAAE,eAAe;AACjB,QAAE,gBAAgB;AAAA,IACpB;AAAA,EACF;AAEA,QAAM,eAAe,MAAM;AAEzB,iBAAa,KAAK;AAAA,EACpB;AAEA,QAAM,kBAAkB,CAAC,OAAwC;AAAA,EAEjE;AAEA,SACE;AAAA,IAAC;AAAA;AAAA,MACC,MAAK;AAAA,MACL,UAAU;AAAA,MACV,SAAS,MAAM;AAAA,MACf,iBAAiB;AAAA,MACjB,SAAS;AAAA,MACT,SAAS;AAAA,MACT,aAAa;AAAA,MACb,WAAW;AAAA,MACX,cAAc;AAAA,MACd,cAAc;AAAA,MACd,YAAY;AAAA,MACZ,eAAe;AAAA,MACf,QAAQ;AAAA,MACR,gCAAgC;AAAA,MAChC,OACE,YACI;AAAA,QACE,iBAAiB;AAAA,QACjB,QAAQ;AAAA,QACR,SAAS;AAAA,MACX,IACA,EAAE,QAAQ,WAAW,SAAS,SAAS;AAAA,MAE7C,KAAK;AAAA,MAEJ;AAAA;AAAA,EACH;AAEJ;","names":[]}
@@ -1,3 +0,0 @@
1
- declare const contentRender: (content: string) => string;
2
-
3
- export { contentRender };
@@ -1,13 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { ContentEditor } from './ContentEditor.mjs';
3
- const contentRender = (content) => {
4
- const isEditable = process.env.NODE_ENV === "development";
5
- if (isEditable && ContentEditor) {
6
- return /* @__PURE__ */ jsx(ContentEditor, { children: content });
7
- }
8
- return content;
9
- };
10
- export {
11
- contentRender
12
- };
13
- //# sourceMappingURL=contentRender.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/ContentEditor/contentRender.tsx"],"sourcesContent":["import { ContentEditor } from './ContentEditor';\n\nexport const contentRender = (content: string) => {\n const isEditable = process.env.NODE_ENV === 'development';\n\n if (isEditable && ContentEditor) {\n return (<ContentEditor>{content}</ContentEditor>) as unknown as string;\n }\n\n return content;\n};\n"],"mappings":"AAMY;AANZ,SAAS,qBAAqB;AAEvB,MAAM,gBAAgB,CAAC,YAAoB;AAChD,QAAM,aAAa,QAAQ,IAAI,aAAa;AAE5C,MAAI,cAAc,eAAe;AAC/B,WAAQ,oBAAC,iBAAe,mBAAQ;AAAA,EAClC;AAEA,SAAO;AACT;","names":[]}
@@ -1,3 +0,0 @@
1
- export { ContentEditor } from './ContentEditor.mjs';
2
- export { contentRender } from './contentRender.mjs';
3
- import 'react';
@@ -1,3 +0,0 @@
1
- export * from './ContentEditor.mjs';
2
- export * from './contentRender.mjs';
3
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/ContentEditor/index.tsx"],"sourcesContent":["export * from './ContentEditor';\nexport * from './contentRender';\n"],"mappings":"AAAA,cAAc;AACd,cAAc;","names":[]}
@@ -1,29 +0,0 @@
1
- import { TranslationContent } from '@intlayer/core';
2
-
3
- type ContentValue =
4
- | string
5
- | {
6
- [key: string]: ContentValue;
7
- }
8
- | TranslationContent<unknown>;
9
-
10
- type Content = Record<string, ContentValue | undefined>;
11
-
12
- type TransformedContentValue =
13
- | string
14
- | {
15
- [key: string]: TransformedContentValue;
16
- }
17
- | undefined
18
- | ((quantity: number) => TransformedContentValue);
19
-
20
- type TransformedContent = Record<
21
- string,
22
- TransformedContentValue | undefined
23
- >;
24
-
25
- type ContentDictionary = Content & {
26
- id: string;
27
- };
28
-
29
- export type { Content, ContentDictionary, ContentValue, TransformedContent, TransformedContentValue };
@@ -1 +0,0 @@
1
- //# sourceMappingURL=contentDictionary.d.mjs.map
@@ -1,116 +0,0 @@
1
- 'use client';
2
-
3
- import {
4
- useEffect,
5
- useState,
6
- useRef,
7
- useCallback,
8
- type FC,
9
- type MouseEventHandler,
10
- } from 'react';
11
-
12
- type ContentEditorProps = {
13
- children?: string;
14
- };
15
-
16
- const PRESS_DETECT_DURATION = 500;
17
-
18
- export const ContentEditor: FC<ContentEditorProps> = ({ children }) => {
19
- const divRef = useRef<HTMLDivElement>(null);
20
- const [isEditing, setIsEditing] = useState(false);
21
- const pressTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);
22
-
23
- const handleOnLongPress = () => {
24
- setIsEditing(true);
25
- };
26
-
27
- const startPressTimer = () => {
28
- pressTimerRef.current = setTimeout(() => {
29
- handleOnLongPress();
30
- }, PRESS_DETECT_DURATION);
31
- };
32
-
33
- const clearPressTimer = () => {
34
- if (pressTimerRef.current) {
35
- clearTimeout(pressTimerRef.current);
36
- pressTimerRef.current = null;
37
- }
38
- };
39
-
40
- const handleMouseDown = () => {
41
- clearPressTimer(); // Ensure any previous timer is cleared
42
- startPressTimer();
43
- };
44
-
45
- const handleMouseUp = () => {
46
- clearPressTimer();
47
- };
48
-
49
- // Use useCallback to ensure the function identity remains stable
50
- const handleClickOutside = useCallback(
51
- (event: MouseEvent) => {
52
- if (divRef.current && !divRef.current.contains(event.target as Node)) {
53
- setIsEditing(false);
54
- }
55
- },
56
- [divRef]
57
- );
58
-
59
- useEffect(() => {
60
- // Attach click outside listener
61
- document.addEventListener('mousedown', handleClickOutside);
62
-
63
- return () => {
64
- // Cleanup
65
- document.removeEventListener('mousedown', handleClickOutside);
66
- clearPressTimer(); // Ensure to clear the timer when component unmounts
67
- };
68
- }, [handleClickOutside]);
69
-
70
- const handleOnClick: MouseEventHandler<HTMLDivElement> = (e) => {
71
- if (isEditing) {
72
- e.preventDefault();
73
- e.stopPropagation();
74
- }
75
- };
76
-
77
- const handleOnBlur = () => {
78
- // Stop editing when the element loses focus
79
- setIsEditing(false);
80
- };
81
-
82
- const onContentChange = (_e: React.FormEvent<HTMLDivElement>) => {
83
- // console.log(e.currentTarget.textContent);
84
- };
85
-
86
- return (
87
- <div
88
- role="textbox"
89
- tabIndex={0}
90
- onKeyUp={() => null}
91
- contentEditable={isEditing}
92
- onInput={onContentChange}
93
- onClick={handleOnClick}
94
- onMouseDown={handleMouseDown}
95
- onMouseUp={handleMouseUp}
96
- onMouseLeave={handleMouseUp}
97
- onTouchStart={handleMouseDown}
98
- onTouchEnd={handleMouseUp}
99
- onTouchCancel={handleMouseUp}
100
- onBlur={handleOnBlur}
101
- suppressContentEditableWarning={true} // To suppress the warning for controlled components
102
- style={
103
- isEditing
104
- ? {
105
- backgroundColor: 'transparent',
106
- cursor: 'text',
107
- display: 'inline',
108
- }
109
- : { cursor: 'pointer', display: 'inline' }
110
- }
111
- ref={divRef}
112
- >
113
- {children}
114
- </div>
115
- );
116
- };
@@ -1,11 +0,0 @@
1
- import { ContentEditor } from './ContentEditor';
2
-
3
- export const contentRender = (content: string) => {
4
- const isEditable = process.env.NODE_ENV === 'development';
5
-
6
- if (isEditable && ContentEditor) {
7
- return (<ContentEditor>{content}</ContentEditor>) as unknown as string;
8
- }
9
-
10
- return content;
11
- };
@@ -1,2 +0,0 @@
1
- export * from './ContentEditor';
2
- export * from './contentRender';