@contentstack/live-preview-utils 3.1.1 → 3.1.3

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 (254) hide show
  1. package/README.md +2 -2
  2. package/dist/legacy/configManager/config.default.cjs +8 -0
  3. package/dist/legacy/configManager/config.default.cjs.map +1 -1
  4. package/dist/legacy/configManager/config.default.js +8 -0
  5. package/dist/legacy/configManager/config.default.js.map +1 -1
  6. package/dist/legacy/configManager/handleUserConfig.cjs +7 -3
  7. package/dist/legacy/configManager/handleUserConfig.cjs.map +1 -1
  8. package/dist/legacy/configManager/handleUserConfig.js +7 -3
  9. package/dist/legacy/configManager/handleUserConfig.js.map +1 -1
  10. package/dist/legacy/livePreview/editButton/editButton.cjs +86 -1
  11. package/dist/legacy/livePreview/editButton/editButton.cjs.map +1 -1
  12. package/dist/legacy/livePreview/editButton/editButton.d.cts +14 -1
  13. package/dist/legacy/livePreview/editButton/editButton.d.ts +14 -1
  14. package/dist/legacy/livePreview/editButton/editButton.js +85 -1
  15. package/dist/legacy/livePreview/editButton/editButton.js.map +1 -1
  16. package/dist/legacy/livePreview/eventManager/postMessageEvent.hooks.cjs +1 -1
  17. package/dist/legacy/livePreview/eventManager/postMessageEvent.hooks.js +1 -1
  18. package/dist/legacy/preview/contentstack-live-preview-HOC.cjs +6 -2
  19. package/dist/legacy/preview/contentstack-live-preview-HOC.cjs.map +1 -1
  20. package/dist/legacy/preview/contentstack-live-preview-HOC.js +6 -2
  21. package/dist/legacy/preview/contentstack-live-preview-HOC.js.map +1 -1
  22. package/dist/legacy/types/types.cjs.map +1 -1
  23. package/dist/legacy/types/types.d.cts +7 -1
  24. package/dist/legacy/types/types.d.ts +7 -1
  25. package/dist/legacy/types/types.js.map +1 -1
  26. package/dist/legacy/visualBuilder/components/FieldToolbar.cjs +28 -22
  27. package/dist/legacy/visualBuilder/components/FieldToolbar.cjs.map +1 -1
  28. package/dist/legacy/visualBuilder/components/FieldToolbar.d.cts +1 -0
  29. package/dist/legacy/visualBuilder/components/FieldToolbar.d.ts +1 -0
  30. package/dist/legacy/visualBuilder/components/FieldToolbar.js +29 -24
  31. package/dist/legacy/visualBuilder/components/FieldToolbar.js.map +1 -1
  32. package/dist/legacy/visualBuilder/components/addInstanceButton.cjs +39 -11
  33. package/dist/legacy/visualBuilder/components/addInstanceButton.cjs.map +1 -1
  34. package/dist/legacy/visualBuilder/components/addInstanceButton.d.cts +5 -0
  35. package/dist/legacy/visualBuilder/components/addInstanceButton.d.ts +5 -0
  36. package/dist/legacy/visualBuilder/components/addInstanceButton.js +39 -11
  37. package/dist/legacy/visualBuilder/components/addInstanceButton.js.map +1 -1
  38. package/dist/legacy/visualBuilder/components/startEditingButton.cjs +38 -11
  39. package/dist/legacy/visualBuilder/components/startEditingButton.cjs.map +1 -1
  40. package/dist/legacy/visualBuilder/components/startEditingButton.d.cts +6 -2
  41. package/dist/legacy/visualBuilder/components/startEditingButton.d.ts +6 -2
  42. package/dist/legacy/visualBuilder/components/startEditingButton.js +34 -11
  43. package/dist/legacy/visualBuilder/components/startEditingButton.js.map +1 -1
  44. package/dist/legacy/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.cjs +59 -4
  45. package/dist/legacy/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.cjs.map +1 -1
  46. package/dist/legacy/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.js +59 -4
  47. package/dist/legacy/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.js.map +1 -1
  48. package/dist/legacy/visualBuilder/generators/generateAddInstanceButtons.cjs +8 -2
  49. package/dist/legacy/visualBuilder/generators/generateAddInstanceButtons.cjs.map +1 -1
  50. package/dist/legacy/visualBuilder/generators/generateAddInstanceButtons.d.cts +9 -3
  51. package/dist/legacy/visualBuilder/generators/generateAddInstanceButtons.d.ts +9 -3
  52. package/dist/legacy/visualBuilder/generators/generateAddInstanceButtons.js +8 -2
  53. package/dist/legacy/visualBuilder/generators/generateAddInstanceButtons.js.map +1 -1
  54. package/dist/legacy/visualBuilder/generators/generateOverlay.cjs +5 -0
  55. package/dist/legacy/visualBuilder/generators/generateOverlay.cjs.map +1 -1
  56. package/dist/legacy/visualBuilder/generators/generateOverlay.js +5 -0
  57. package/dist/legacy/visualBuilder/generators/generateOverlay.js.map +1 -1
  58. package/dist/legacy/visualBuilder/generators/generateToolbar.cjs +13 -5
  59. package/dist/legacy/visualBuilder/generators/generateToolbar.cjs.map +1 -1
  60. package/dist/legacy/visualBuilder/generators/generateToolbar.d.cts +2 -2
  61. package/dist/legacy/visualBuilder/generators/generateToolbar.d.ts +2 -2
  62. package/dist/legacy/visualBuilder/generators/generateToolbar.js +13 -5
  63. package/dist/legacy/visualBuilder/generators/generateToolbar.js.map +1 -1
  64. package/dist/legacy/visualBuilder/index.cjs +4 -2
  65. package/dist/legacy/visualBuilder/index.cjs.map +1 -1
  66. package/dist/legacy/visualBuilder/index.d.cts +1 -0
  67. package/dist/legacy/visualBuilder/index.d.ts +1 -0
  68. package/dist/legacy/visualBuilder/index.js +4 -2
  69. package/dist/legacy/visualBuilder/index.js.map +1 -1
  70. package/dist/legacy/visualBuilder/listeners/mouseClick.cjs +79 -21
  71. package/dist/legacy/visualBuilder/listeners/mouseClick.cjs.map +1 -1
  72. package/dist/legacy/visualBuilder/listeners/mouseClick.d.cts +4 -1
  73. package/dist/legacy/visualBuilder/listeners/mouseClick.d.ts +4 -1
  74. package/dist/legacy/visualBuilder/listeners/mouseClick.js +79 -21
  75. package/dist/legacy/visualBuilder/listeners/mouseClick.js.map +1 -1
  76. package/dist/legacy/visualBuilder/utils/enableInlineEditing.cjs +94 -0
  77. package/dist/legacy/visualBuilder/utils/enableInlineEditing.cjs.map +1 -0
  78. package/dist/legacy/visualBuilder/utils/enableInlineEditing.d.cts +11 -0
  79. package/dist/legacy/visualBuilder/utils/enableInlineEditing.d.ts +11 -0
  80. package/dist/legacy/visualBuilder/utils/enableInlineEditing.js +74 -0
  81. package/dist/legacy/visualBuilder/utils/enableInlineEditing.js.map +1 -0
  82. package/dist/legacy/visualBuilder/utils/getChildrenDirection.cjs +8 -0
  83. package/dist/legacy/visualBuilder/utils/getChildrenDirection.cjs.map +1 -1
  84. package/dist/legacy/visualBuilder/utils/getChildrenDirection.d.cts +3 -1
  85. package/dist/legacy/visualBuilder/utils/getChildrenDirection.d.ts +3 -1
  86. package/dist/legacy/visualBuilder/utils/getChildrenDirection.js +8 -0
  87. package/dist/legacy/visualBuilder/utils/getChildrenDirection.js.map +1 -1
  88. package/dist/legacy/visualBuilder/utils/handleIndividualFields.cjs +24 -112
  89. package/dist/legacy/visualBuilder/utils/handleIndividualFields.cjs.map +1 -1
  90. package/dist/legacy/visualBuilder/utils/handleIndividualFields.d.cts +3 -5
  91. package/dist/legacy/visualBuilder/utils/handleIndividualFields.d.ts +3 -5
  92. package/dist/legacy/visualBuilder/utils/handleIndividualFields.js +22 -116
  93. package/dist/legacy/visualBuilder/utils/handleIndividualFields.js.map +1 -1
  94. package/dist/legacy/visualBuilder/utils/handleInlineEditableField.cjs +81 -0
  95. package/dist/legacy/visualBuilder/utils/handleInlineEditableField.cjs.map +1 -0
  96. package/dist/legacy/visualBuilder/utils/handleInlineEditableField.d.cts +16 -0
  97. package/dist/legacy/visualBuilder/utils/handleInlineEditableField.d.ts +16 -0
  98. package/dist/legacy/visualBuilder/utils/handleInlineEditableField.js +58 -0
  99. package/dist/legacy/visualBuilder/utils/handleInlineEditableField.js.map +1 -0
  100. package/dist/legacy/visualBuilder/utils/isFieldMultiple.cjs +35 -0
  101. package/dist/legacy/visualBuilder/utils/isFieldMultiple.cjs.map +1 -0
  102. package/dist/legacy/visualBuilder/utils/isFieldMultiple.d.cts +6 -0
  103. package/dist/legacy/visualBuilder/utils/isFieldMultiple.d.ts +6 -0
  104. package/dist/legacy/visualBuilder/utils/isFieldMultiple.js +12 -0
  105. package/dist/legacy/visualBuilder/utils/isFieldMultiple.js.map +1 -0
  106. package/dist/legacy/visualBuilder/utils/multipleElementAddButton.cjs +14 -20
  107. package/dist/legacy/visualBuilder/utils/multipleElementAddButton.cjs.map +1 -1
  108. package/dist/legacy/visualBuilder/utils/multipleElementAddButton.d.cts +1 -1
  109. package/dist/legacy/visualBuilder/utils/multipleElementAddButton.d.ts +1 -1
  110. package/dist/legacy/visualBuilder/utils/multipleElementAddButton.js +14 -20
  111. package/dist/legacy/visualBuilder/utils/multipleElementAddButton.js.map +1 -1
  112. package/dist/legacy/visualBuilder/utils/pasteAsPlainText.cjs +44 -0
  113. package/dist/legacy/visualBuilder/utils/pasteAsPlainText.cjs.map +1 -0
  114. package/dist/legacy/visualBuilder/utils/pasteAsPlainText.d.cts +5 -0
  115. package/dist/legacy/visualBuilder/utils/pasteAsPlainText.d.ts +5 -0
  116. package/dist/legacy/visualBuilder/utils/pasteAsPlainText.js +21 -0
  117. package/dist/legacy/visualBuilder/utils/pasteAsPlainText.js.map +1 -0
  118. package/dist/legacy/visualBuilder/utils/types/index.types.cjs.map +1 -1
  119. package/dist/legacy/visualBuilder/utils/types/index.types.d.cts +6 -1
  120. package/dist/legacy/visualBuilder/utils/types/index.types.d.ts +6 -1
  121. package/dist/legacy/visualBuilder/utils/types/index.types.js.map +1 -1
  122. package/dist/legacy/visualBuilder/visualBuilder.style.cjs +27 -5
  123. package/dist/legacy/visualBuilder/visualBuilder.style.cjs.map +1 -1
  124. package/dist/legacy/visualBuilder/visualBuilder.style.d.cts +6 -1
  125. package/dist/legacy/visualBuilder/visualBuilder.style.d.ts +6 -1
  126. package/dist/legacy/visualBuilder/visualBuilder.style.js +27 -5
  127. package/dist/legacy/visualBuilder/visualBuilder.style.js.map +1 -1
  128. package/dist/modern/configManager/config.default.cjs +8 -0
  129. package/dist/modern/configManager/config.default.cjs.map +1 -1
  130. package/dist/modern/configManager/config.default.js +8 -0
  131. package/dist/modern/configManager/config.default.js.map +1 -1
  132. package/dist/modern/configManager/handleUserConfig.cjs +4 -0
  133. package/dist/modern/configManager/handleUserConfig.cjs.map +1 -1
  134. package/dist/modern/configManager/handleUserConfig.js +4 -0
  135. package/dist/modern/configManager/handleUserConfig.js.map +1 -1
  136. package/dist/modern/livePreview/editButton/editButton.cjs +85 -1
  137. package/dist/modern/livePreview/editButton/editButton.cjs.map +1 -1
  138. package/dist/modern/livePreview/editButton/editButton.d.cts +14 -1
  139. package/dist/modern/livePreview/editButton/editButton.d.ts +14 -1
  140. package/dist/modern/livePreview/editButton/editButton.js +84 -1
  141. package/dist/modern/livePreview/editButton/editButton.js.map +1 -1
  142. package/dist/modern/livePreview/eventManager/postMessageEvent.hooks.cjs +1 -1
  143. package/dist/modern/livePreview/eventManager/postMessageEvent.hooks.js +1 -1
  144. package/dist/modern/preview/contentstack-live-preview-HOC.cjs +6 -2
  145. package/dist/modern/preview/contentstack-live-preview-HOC.cjs.map +1 -1
  146. package/dist/modern/preview/contentstack-live-preview-HOC.js +6 -2
  147. package/dist/modern/preview/contentstack-live-preview-HOC.js.map +1 -1
  148. package/dist/modern/types/types.cjs.map +1 -1
  149. package/dist/modern/types/types.d.cts +7 -1
  150. package/dist/modern/types/types.d.ts +7 -1
  151. package/dist/modern/types/types.js.map +1 -1
  152. package/dist/modern/visualBuilder/components/FieldToolbar.cjs +28 -21
  153. package/dist/modern/visualBuilder/components/FieldToolbar.cjs.map +1 -1
  154. package/dist/modern/visualBuilder/components/FieldToolbar.d.cts +1 -0
  155. package/dist/modern/visualBuilder/components/FieldToolbar.d.ts +1 -0
  156. package/dist/modern/visualBuilder/components/FieldToolbar.js +29 -23
  157. package/dist/modern/visualBuilder/components/FieldToolbar.js.map +1 -1
  158. package/dist/modern/visualBuilder/components/addInstanceButton.cjs +38 -11
  159. package/dist/modern/visualBuilder/components/addInstanceButton.cjs.map +1 -1
  160. package/dist/modern/visualBuilder/components/addInstanceButton.d.cts +5 -0
  161. package/dist/modern/visualBuilder/components/addInstanceButton.d.ts +5 -0
  162. package/dist/modern/visualBuilder/components/addInstanceButton.js +38 -11
  163. package/dist/modern/visualBuilder/components/addInstanceButton.js.map +1 -1
  164. package/dist/modern/visualBuilder/components/startEditingButton.cjs +38 -11
  165. package/dist/modern/visualBuilder/components/startEditingButton.cjs.map +1 -1
  166. package/dist/modern/visualBuilder/components/startEditingButton.d.cts +6 -2
  167. package/dist/modern/visualBuilder/components/startEditingButton.d.ts +6 -2
  168. package/dist/modern/visualBuilder/components/startEditingButton.js +34 -11
  169. package/dist/modern/visualBuilder/components/startEditingButton.js.map +1 -1
  170. package/dist/modern/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.cjs +59 -4
  171. package/dist/modern/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.cjs.map +1 -1
  172. package/dist/modern/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.js +59 -4
  173. package/dist/modern/visualBuilder/eventManager/useRecalculateVariantDataCSLPValues.js.map +1 -1
  174. package/dist/modern/visualBuilder/generators/generateAddInstanceButtons.cjs +8 -2
  175. package/dist/modern/visualBuilder/generators/generateAddInstanceButtons.cjs.map +1 -1
  176. package/dist/modern/visualBuilder/generators/generateAddInstanceButtons.d.cts +9 -3
  177. package/dist/modern/visualBuilder/generators/generateAddInstanceButtons.d.ts +9 -3
  178. package/dist/modern/visualBuilder/generators/generateAddInstanceButtons.js +8 -2
  179. package/dist/modern/visualBuilder/generators/generateAddInstanceButtons.js.map +1 -1
  180. package/dist/modern/visualBuilder/generators/generateOverlay.cjs +5 -0
  181. package/dist/modern/visualBuilder/generators/generateOverlay.cjs.map +1 -1
  182. package/dist/modern/visualBuilder/generators/generateOverlay.js +5 -0
  183. package/dist/modern/visualBuilder/generators/generateOverlay.js.map +1 -1
  184. package/dist/modern/visualBuilder/generators/generateToolbar.cjs +13 -5
  185. package/dist/modern/visualBuilder/generators/generateToolbar.cjs.map +1 -1
  186. package/dist/modern/visualBuilder/generators/generateToolbar.d.cts +2 -2
  187. package/dist/modern/visualBuilder/generators/generateToolbar.d.ts +2 -2
  188. package/dist/modern/visualBuilder/generators/generateToolbar.js +13 -5
  189. package/dist/modern/visualBuilder/generators/generateToolbar.js.map +1 -1
  190. package/dist/modern/visualBuilder/index.cjs +4 -2
  191. package/dist/modern/visualBuilder/index.cjs.map +1 -1
  192. package/dist/modern/visualBuilder/index.d.cts +1 -0
  193. package/dist/modern/visualBuilder/index.d.ts +1 -0
  194. package/dist/modern/visualBuilder/index.js +4 -2
  195. package/dist/modern/visualBuilder/index.js.map +1 -1
  196. package/dist/modern/visualBuilder/listeners/mouseClick.cjs +76 -19
  197. package/dist/modern/visualBuilder/listeners/mouseClick.cjs.map +1 -1
  198. package/dist/modern/visualBuilder/listeners/mouseClick.d.cts +4 -1
  199. package/dist/modern/visualBuilder/listeners/mouseClick.d.ts +4 -1
  200. package/dist/modern/visualBuilder/listeners/mouseClick.js +76 -19
  201. package/dist/modern/visualBuilder/listeners/mouseClick.js.map +1 -1
  202. package/dist/modern/visualBuilder/utils/enableInlineEditing.cjs +94 -0
  203. package/dist/modern/visualBuilder/utils/enableInlineEditing.cjs.map +1 -0
  204. package/dist/modern/visualBuilder/utils/enableInlineEditing.d.cts +11 -0
  205. package/dist/modern/visualBuilder/utils/enableInlineEditing.d.ts +11 -0
  206. package/dist/modern/visualBuilder/utils/enableInlineEditing.js +74 -0
  207. package/dist/modern/visualBuilder/utils/enableInlineEditing.js.map +1 -0
  208. package/dist/modern/visualBuilder/utils/getChildrenDirection.cjs +8 -0
  209. package/dist/modern/visualBuilder/utils/getChildrenDirection.cjs.map +1 -1
  210. package/dist/modern/visualBuilder/utils/getChildrenDirection.d.cts +3 -1
  211. package/dist/modern/visualBuilder/utils/getChildrenDirection.d.ts +3 -1
  212. package/dist/modern/visualBuilder/utils/getChildrenDirection.js +8 -0
  213. package/dist/modern/visualBuilder/utils/getChildrenDirection.js.map +1 -1
  214. package/dist/modern/visualBuilder/utils/handleIndividualFields.cjs +23 -111
  215. package/dist/modern/visualBuilder/utils/handleIndividualFields.cjs.map +1 -1
  216. package/dist/modern/visualBuilder/utils/handleIndividualFields.d.cts +3 -5
  217. package/dist/modern/visualBuilder/utils/handleIndividualFields.d.ts +3 -5
  218. package/dist/modern/visualBuilder/utils/handleIndividualFields.js +21 -115
  219. package/dist/modern/visualBuilder/utils/handleIndividualFields.js.map +1 -1
  220. package/dist/modern/visualBuilder/utils/handleInlineEditableField.cjs +81 -0
  221. package/dist/modern/visualBuilder/utils/handleInlineEditableField.cjs.map +1 -0
  222. package/dist/modern/visualBuilder/utils/handleInlineEditableField.d.cts +16 -0
  223. package/dist/modern/visualBuilder/utils/handleInlineEditableField.d.ts +16 -0
  224. package/dist/modern/visualBuilder/utils/handleInlineEditableField.js +58 -0
  225. package/dist/modern/visualBuilder/utils/handleInlineEditableField.js.map +1 -0
  226. package/dist/modern/visualBuilder/utils/isFieldMultiple.cjs +35 -0
  227. package/dist/modern/visualBuilder/utils/isFieldMultiple.cjs.map +1 -0
  228. package/dist/modern/visualBuilder/utils/isFieldMultiple.d.cts +6 -0
  229. package/dist/modern/visualBuilder/utils/isFieldMultiple.d.ts +6 -0
  230. package/dist/modern/visualBuilder/utils/isFieldMultiple.js +12 -0
  231. package/dist/modern/visualBuilder/utils/isFieldMultiple.js.map +1 -0
  232. package/dist/modern/visualBuilder/utils/multipleElementAddButton.cjs +14 -18
  233. package/dist/modern/visualBuilder/utils/multipleElementAddButton.cjs.map +1 -1
  234. package/dist/modern/visualBuilder/utils/multipleElementAddButton.d.cts +1 -1
  235. package/dist/modern/visualBuilder/utils/multipleElementAddButton.d.ts +1 -1
  236. package/dist/modern/visualBuilder/utils/multipleElementAddButton.js +14 -18
  237. package/dist/modern/visualBuilder/utils/multipleElementAddButton.js.map +1 -1
  238. package/dist/modern/visualBuilder/utils/pasteAsPlainText.cjs +44 -0
  239. package/dist/modern/visualBuilder/utils/pasteAsPlainText.cjs.map +1 -0
  240. package/dist/modern/visualBuilder/utils/pasteAsPlainText.d.cts +5 -0
  241. package/dist/modern/visualBuilder/utils/pasteAsPlainText.d.ts +5 -0
  242. package/dist/modern/visualBuilder/utils/pasteAsPlainText.js +21 -0
  243. package/dist/modern/visualBuilder/utils/pasteAsPlainText.js.map +1 -0
  244. package/dist/modern/visualBuilder/utils/types/index.types.cjs.map +1 -1
  245. package/dist/modern/visualBuilder/utils/types/index.types.d.cts +6 -1
  246. package/dist/modern/visualBuilder/utils/types/index.types.d.ts +6 -1
  247. package/dist/modern/visualBuilder/utils/types/index.types.js.map +1 -1
  248. package/dist/modern/visualBuilder/visualBuilder.style.cjs +27 -5
  249. package/dist/modern/visualBuilder/visualBuilder.style.cjs.map +1 -1
  250. package/dist/modern/visualBuilder/visualBuilder.style.d.cts +6 -1
  251. package/dist/modern/visualBuilder/visualBuilder.style.d.ts +6 -1
  252. package/dist/modern/visualBuilder/visualBuilder.style.js +27 -5
  253. package/dist/modern/visualBuilder/visualBuilder.style.js.map +1 -1
  254. package/package.json +3 -2
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/visualBuilder/utils/enableInlineEditing.ts
21
+ var enableInlineEditing_exports = {};
22
+ __export(enableInlineEditing_exports, {
23
+ enableInlineEditing: () => enableInlineEditing
24
+ });
25
+ module.exports = __toCommonJS(enableInlineEditing_exports);
26
+ var import_lodash_es = require("lodash-es");
27
+ var import__ = require("../index.cjs");
28
+ var import_generatePseudoEditableField = require("../generators/generatePseudoEditableField.cjs");
29
+ var import_constants = require("./constants.cjs");
30
+ var import_getMultilinePlaintext = require("./getMultilinePlaintext.cjs");
31
+ var import_handleFieldMouseDown = require("./handleFieldMouseDown.cjs");
32
+ var import_types = require("./types/index.types.cjs");
33
+ var import_updateFocussedState = require("./updateFocussedState.cjs");
34
+ var import_pasteAsPlainText = require("./pasteAsPlainText.cjs");
35
+ function enableInlineEditing({
36
+ expectedFieldData,
37
+ editableElement,
38
+ fieldType,
39
+ elements
40
+ }) {
41
+ const { visualBuilderContainer, resizeObserver } = elements;
42
+ let actualEditableField = editableElement;
43
+ import__.VisualBuilder.VisualBuilderGlobalState.value.focusFieldValue = actualEditableField == null ? void 0 : actualEditableField.innerText;
44
+ const elementComputedDisplay = window.getComputedStyle(actualEditableField).display;
45
+ let textContent = editableElement.innerText || editableElement.textContent || "";
46
+ if (fieldType === import_types.FieldDataType.MULTILINE) {
47
+ textContent = (0, import_getMultilinePlaintext.getMultilinePlaintext)(actualEditableField);
48
+ actualEditableField.addEventListener("paste", import_pasteAsPlainText.pasteAsPlainText);
49
+ }
50
+ const expectedTextContent = expectedFieldData;
51
+ if (expectedTextContent && textContent !== expectedTextContent || (0, import_generatePseudoEditableField.isEllipsisActive)(editableElement)) {
52
+ const pseudoEditableField = (0, import_generatePseudoEditableField.generatePseudoEditableElement)(
53
+ { editableElement },
54
+ { textContent: expectedFieldData }
55
+ );
56
+ editableElement.style.visibility = "hidden";
57
+ pseudoEditableField.setAttribute(
58
+ import_constants.VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,
59
+ fieldType
60
+ );
61
+ visualBuilderContainer.appendChild(pseudoEditableField);
62
+ actualEditableField = pseudoEditableField;
63
+ if (fieldType === import_types.FieldDataType.MULTILINE)
64
+ actualEditableField.addEventListener("paste", import_pasteAsPlainText.pasteAsPlainText);
65
+ elements.resizeObserver.observe(pseudoEditableField);
66
+ } else if (elementComputedDisplay === "inline") {
67
+ const onInlineElementInput = (0, import_lodash_es.throttle)(() => {
68
+ const overlayWrapper = visualBuilderContainer.querySelector(
69
+ ".visual-builder__overlay__wrapper"
70
+ );
71
+ const focusedToolbar = visualBuilderContainer.querySelector(
72
+ ".visual-builder__focused-toolbar"
73
+ );
74
+ (0, import_updateFocussedState.updateFocussedState)({
75
+ editableElement: actualEditableField,
76
+ visualBuilderContainer,
77
+ overlayWrapper,
78
+ focusedToolbar,
79
+ resizeObserver
80
+ });
81
+ }, 200);
82
+ actualEditableField.addEventListener("input", onInlineElementInput);
83
+ }
84
+ actualEditableField.setAttribute("contenteditable", "true");
85
+ actualEditableField.addEventListener("input", import_handleFieldMouseDown.handleFieldInput);
86
+ actualEditableField.addEventListener("keydown", import_handleFieldMouseDown.handleFieldKeyDown);
87
+ actualEditableField.focus();
88
+ return;
89
+ }
90
+ // Annotate the CommonJS export names for ESM import in node:
91
+ 0 && (module.exports = {
92
+ enableInlineEditing
93
+ });
94
+ //# sourceMappingURL=enableInlineEditing.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/visualBuilder/utils/enableInlineEditing.ts"],"sourcesContent":["import { throttle } from \"lodash-es\";\nimport { VisualBuilder } from \"../index\";\nimport {\n isEllipsisActive,\n generatePseudoEditableElement,\n} from \"../generators/generatePseudoEditableField\";\nimport { VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY } from \"./constants\";\nimport { getMultilinePlaintext } from \"./getMultilinePlaintext\";\nimport { handleFieldInput, handleFieldKeyDown } from \"./handleFieldMouseDown\";\nimport { FieldDataType, VisualBuilderEditContext } from \"./types/index.types\";\nimport { updateFocussedState } from \"./updateFocussedState\";\nimport { pasteAsPlainText } from \"./pasteAsPlainText\";\n\nexport function enableInlineEditing({\n expectedFieldData,\n editableElement,\n fieldType,\n elements,\n}: {\n expectedFieldData: any;\n editableElement: HTMLElement;\n fieldType: FieldDataType;\n elements: VisualBuilderEditContext;\n}) {\n const { visualBuilderContainer, resizeObserver } = elements;\n let actualEditableField = editableElement as HTMLElement;\n\n VisualBuilder.VisualBuilderGlobalState.value.focusFieldValue =\n actualEditableField?.innerText;\n\n const elementComputedDisplay =\n window.getComputedStyle(actualEditableField).display;\n\n let textContent =\n (editableElement as HTMLElement).innerText ||\n editableElement.textContent ||\n \"\";\n\n if (fieldType === FieldDataType.MULTILINE) {\n textContent = getMultilinePlaintext(actualEditableField);\n actualEditableField.addEventListener(\"paste\", pasteAsPlainText);\n }\n const expectedTextContent = expectedFieldData;\n if (\n (expectedTextContent && textContent !== expectedTextContent) ||\n isEllipsisActive(editableElement as HTMLElement)\n ) {\n // TODO: Testing will be done in the E2E.\n const pseudoEditableField = generatePseudoEditableElement(\n { editableElement: editableElement as HTMLElement },\n { textContent: expectedFieldData }\n );\n\n (editableElement as HTMLElement).style.visibility = \"hidden\";\n\n // set field type attribute to the pseudo editable field\n // ensures proper keydown handling similar to the actual editable field\n pseudoEditableField.setAttribute(\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,\n fieldType\n );\n visualBuilderContainer.appendChild(pseudoEditableField);\n actualEditableField = pseudoEditableField;\n\n if (fieldType === FieldDataType.MULTILINE)\n actualEditableField.addEventListener(\"paste\", pasteAsPlainText);\n\n // we will unobserve this in hideOverlay\n elements.resizeObserver.observe(pseudoEditableField);\n } else if (elementComputedDisplay === \"inline\") {\n // if the editable field is inline\n const onInlineElementInput = throttle(() => {\n const overlayWrapper = visualBuilderContainer.querySelector(\n \".visual-builder__overlay__wrapper\"\n ) as HTMLDivElement;\n const focusedToolbar = visualBuilderContainer.querySelector(\n \".visual-builder__focused-toolbar\"\n ) as HTMLDivElement;\n updateFocussedState({\n editableElement: actualEditableField,\n visualBuilderContainer,\n overlayWrapper,\n focusedToolbar,\n resizeObserver,\n });\n }, 200);\n actualEditableField.addEventListener(\"input\", onInlineElementInput);\n }\n\n actualEditableField.setAttribute(\"contenteditable\", \"true\");\n actualEditableField.addEventListener(\"input\", handleFieldInput);\n actualEditableField.addEventListener(\"keydown\", handleFieldKeyDown);\n // focus on the contenteditable element to start accepting input\n actualEditableField.focus();\n\n return;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uBAAyB;AACzB,eAA8B;AAC9B,yCAGO;AACP,uBAAwD;AACxD,mCAAsC;AACtC,kCAAqD;AACrD,mBAAwD;AACxD,iCAAoC;AACpC,8BAAiC;AAE1B,SAAS,oBAAoB;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACJ,GAKG;AACC,QAAM,EAAE,wBAAwB,eAAe,IAAI;AACnD,MAAI,sBAAsB;AAE1B,yBAAc,yBAAyB,MAAM,kBACzC,2DAAqB;AAEzB,QAAM,yBACF,OAAO,iBAAiB,mBAAmB,EAAE;AAEjD,MAAI,cACC,gBAAgC,aACjC,gBAAgB,eAChB;AAEJ,MAAI,cAAc,2BAAc,WAAW;AACvC,sBAAc,oDAAsB,mBAAmB;AACvD,wBAAoB,iBAAiB,SAAS,wCAAgB;AAAA,EAClE;AACA,QAAM,sBAAsB;AAC5B,MACK,uBAAuB,gBAAgB,2BACxC,qDAAiB,eAA8B,GACjD;AAEE,UAAM,0BAAsB;AAAA,MACxB,EAAE,gBAAgD;AAAA,MAClD,EAAE,aAAa,kBAAkB;AAAA,IACrC;AAEA,IAAC,gBAAgC,MAAM,aAAa;AAIpD,wBAAoB;AAAA,MAChB;AAAA,MACA;AAAA,IACJ;AACA,2BAAuB,YAAY,mBAAmB;AACtD,0BAAsB;AAEtB,QAAI,cAAc,2BAAc;AAC5B,0BAAoB,iBAAiB,SAAS,wCAAgB;AAGlE,aAAS,eAAe,QAAQ,mBAAmB;AAAA,EACvD,WAAW,2BAA2B,UAAU;AAE5C,UAAM,2BAAuB,2BAAS,MAAM;AACxC,YAAM,iBAAiB,uBAAuB;AAAA,QAC1C;AAAA,MACJ;AACA,YAAM,iBAAiB,uBAAuB;AAAA,QAC1C;AAAA,MACJ;AACA,0DAAoB;AAAA,QAChB,iBAAiB;AAAA,QACjB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACJ,CAAC;AAAA,IACL,GAAG,GAAG;AACN,wBAAoB,iBAAiB,SAAS,oBAAoB;AAAA,EACtE;AAEA,sBAAoB,aAAa,mBAAmB,MAAM;AAC1D,sBAAoB,iBAAiB,SAAS,4CAAgB;AAC9D,sBAAoB,iBAAiB,WAAW,8CAAkB;AAElE,sBAAoB,MAAM;AAE1B;AACJ;","names":[]}
@@ -0,0 +1,11 @@
1
+ import { FieldDataType, VisualBuilderEditContext } from './types/index.types.cjs';
2
+ import '../../cms/types/contentTypeSchema.types.cjs';
3
+
4
+ declare function enableInlineEditing({ expectedFieldData, editableElement, fieldType, elements, }: {
5
+ expectedFieldData: any;
6
+ editableElement: HTMLElement;
7
+ fieldType: FieldDataType;
8
+ elements: VisualBuilderEditContext;
9
+ }): void;
10
+
11
+ export { enableInlineEditing };
@@ -0,0 +1,11 @@
1
+ import { FieldDataType, VisualBuilderEditContext } from './types/index.types.js';
2
+ import '../../cms/types/contentTypeSchema.types.js';
3
+
4
+ declare function enableInlineEditing({ expectedFieldData, editableElement, fieldType, elements, }: {
5
+ expectedFieldData: any;
6
+ editableElement: HTMLElement;
7
+ fieldType: FieldDataType;
8
+ elements: VisualBuilderEditContext;
9
+ }): void;
10
+
11
+ export { enableInlineEditing };
@@ -0,0 +1,74 @@
1
+ import "../../chunk-5WRI5ZAA.js";
2
+
3
+ // src/visualBuilder/utils/enableInlineEditing.ts
4
+ import { throttle } from "lodash-es";
5
+ import { VisualBuilder } from "../index.js";
6
+ import {
7
+ isEllipsisActive,
8
+ generatePseudoEditableElement
9
+ } from "../generators/generatePseudoEditableField.js";
10
+ import { VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY } from "./constants.js";
11
+ import { getMultilinePlaintext } from "./getMultilinePlaintext.js";
12
+ import { handleFieldInput, handleFieldKeyDown } from "./handleFieldMouseDown.js";
13
+ import { FieldDataType } from "./types/index.types.js";
14
+ import { updateFocussedState } from "./updateFocussedState.js";
15
+ import { pasteAsPlainText } from "./pasteAsPlainText.js";
16
+ function enableInlineEditing({
17
+ expectedFieldData,
18
+ editableElement,
19
+ fieldType,
20
+ elements
21
+ }) {
22
+ const { visualBuilderContainer, resizeObserver } = elements;
23
+ let actualEditableField = editableElement;
24
+ VisualBuilder.VisualBuilderGlobalState.value.focusFieldValue = actualEditableField == null ? void 0 : actualEditableField.innerText;
25
+ const elementComputedDisplay = window.getComputedStyle(actualEditableField).display;
26
+ let textContent = editableElement.innerText || editableElement.textContent || "";
27
+ if (fieldType === FieldDataType.MULTILINE) {
28
+ textContent = getMultilinePlaintext(actualEditableField);
29
+ actualEditableField.addEventListener("paste", pasteAsPlainText);
30
+ }
31
+ const expectedTextContent = expectedFieldData;
32
+ if (expectedTextContent && textContent !== expectedTextContent || isEllipsisActive(editableElement)) {
33
+ const pseudoEditableField = generatePseudoEditableElement(
34
+ { editableElement },
35
+ { textContent: expectedFieldData }
36
+ );
37
+ editableElement.style.visibility = "hidden";
38
+ pseudoEditableField.setAttribute(
39
+ VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,
40
+ fieldType
41
+ );
42
+ visualBuilderContainer.appendChild(pseudoEditableField);
43
+ actualEditableField = pseudoEditableField;
44
+ if (fieldType === FieldDataType.MULTILINE)
45
+ actualEditableField.addEventListener("paste", pasteAsPlainText);
46
+ elements.resizeObserver.observe(pseudoEditableField);
47
+ } else if (elementComputedDisplay === "inline") {
48
+ const onInlineElementInput = throttle(() => {
49
+ const overlayWrapper = visualBuilderContainer.querySelector(
50
+ ".visual-builder__overlay__wrapper"
51
+ );
52
+ const focusedToolbar = visualBuilderContainer.querySelector(
53
+ ".visual-builder__focused-toolbar"
54
+ );
55
+ updateFocussedState({
56
+ editableElement: actualEditableField,
57
+ visualBuilderContainer,
58
+ overlayWrapper,
59
+ focusedToolbar,
60
+ resizeObserver
61
+ });
62
+ }, 200);
63
+ actualEditableField.addEventListener("input", onInlineElementInput);
64
+ }
65
+ actualEditableField.setAttribute("contenteditable", "true");
66
+ actualEditableField.addEventListener("input", handleFieldInput);
67
+ actualEditableField.addEventListener("keydown", handleFieldKeyDown);
68
+ actualEditableField.focus();
69
+ return;
70
+ }
71
+ export {
72
+ enableInlineEditing
73
+ };
74
+ //# sourceMappingURL=enableInlineEditing.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/visualBuilder/utils/enableInlineEditing.ts"],"sourcesContent":["import { throttle } from \"lodash-es\";\nimport { VisualBuilder } from \"../index\";\nimport {\n isEllipsisActive,\n generatePseudoEditableElement,\n} from \"../generators/generatePseudoEditableField\";\nimport { VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY } from \"./constants\";\nimport { getMultilinePlaintext } from \"./getMultilinePlaintext\";\nimport { handleFieldInput, handleFieldKeyDown } from \"./handleFieldMouseDown\";\nimport { FieldDataType, VisualBuilderEditContext } from \"./types/index.types\";\nimport { updateFocussedState } from \"./updateFocussedState\";\nimport { pasteAsPlainText } from \"./pasteAsPlainText\";\n\nexport function enableInlineEditing({\n expectedFieldData,\n editableElement,\n fieldType,\n elements,\n}: {\n expectedFieldData: any;\n editableElement: HTMLElement;\n fieldType: FieldDataType;\n elements: VisualBuilderEditContext;\n}) {\n const { visualBuilderContainer, resizeObserver } = elements;\n let actualEditableField = editableElement as HTMLElement;\n\n VisualBuilder.VisualBuilderGlobalState.value.focusFieldValue =\n actualEditableField?.innerText;\n\n const elementComputedDisplay =\n window.getComputedStyle(actualEditableField).display;\n\n let textContent =\n (editableElement as HTMLElement).innerText ||\n editableElement.textContent ||\n \"\";\n\n if (fieldType === FieldDataType.MULTILINE) {\n textContent = getMultilinePlaintext(actualEditableField);\n actualEditableField.addEventListener(\"paste\", pasteAsPlainText);\n }\n const expectedTextContent = expectedFieldData;\n if (\n (expectedTextContent && textContent !== expectedTextContent) ||\n isEllipsisActive(editableElement as HTMLElement)\n ) {\n // TODO: Testing will be done in the E2E.\n const pseudoEditableField = generatePseudoEditableElement(\n { editableElement: editableElement as HTMLElement },\n { textContent: expectedFieldData }\n );\n\n (editableElement as HTMLElement).style.visibility = \"hidden\";\n\n // set field type attribute to the pseudo editable field\n // ensures proper keydown handling similar to the actual editable field\n pseudoEditableField.setAttribute(\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,\n fieldType\n );\n visualBuilderContainer.appendChild(pseudoEditableField);\n actualEditableField = pseudoEditableField;\n\n if (fieldType === FieldDataType.MULTILINE)\n actualEditableField.addEventListener(\"paste\", pasteAsPlainText);\n\n // we will unobserve this in hideOverlay\n elements.resizeObserver.observe(pseudoEditableField);\n } else if (elementComputedDisplay === \"inline\") {\n // if the editable field is inline\n const onInlineElementInput = throttle(() => {\n const overlayWrapper = visualBuilderContainer.querySelector(\n \".visual-builder__overlay__wrapper\"\n ) as HTMLDivElement;\n const focusedToolbar = visualBuilderContainer.querySelector(\n \".visual-builder__focused-toolbar\"\n ) as HTMLDivElement;\n updateFocussedState({\n editableElement: actualEditableField,\n visualBuilderContainer,\n overlayWrapper,\n focusedToolbar,\n resizeObserver,\n });\n }, 200);\n actualEditableField.addEventListener(\"input\", onInlineElementInput);\n }\n\n actualEditableField.setAttribute(\"contenteditable\", \"true\");\n actualEditableField.addEventListener(\"input\", handleFieldInput);\n actualEditableField.addEventListener(\"keydown\", handleFieldKeyDown);\n // focus on the contenteditable element to start accepting input\n actualEditableField.focus();\n\n return;\n}\n"],"mappings":";;;AAAA,SAAS,gBAAgB;AACzB,SAAS,qBAAqB;AAC9B;AAAA,EACI;AAAA,EACA;AAAA,OACG;AACP,SAAS,+CAA+C;AACxD,SAAS,6BAA6B;AACtC,SAAS,kBAAkB,0BAA0B;AACrD,SAAS,qBAA+C;AACxD,SAAS,2BAA2B;AACpC,SAAS,wBAAwB;AAE1B,SAAS,oBAAoB;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACJ,GAKG;AACC,QAAM,EAAE,wBAAwB,eAAe,IAAI;AACnD,MAAI,sBAAsB;AAE1B,gBAAc,yBAAyB,MAAM,kBACzC,2DAAqB;AAEzB,QAAM,yBACF,OAAO,iBAAiB,mBAAmB,EAAE;AAEjD,MAAI,cACC,gBAAgC,aACjC,gBAAgB,eAChB;AAEJ,MAAI,cAAc,cAAc,WAAW;AACvC,kBAAc,sBAAsB,mBAAmB;AACvD,wBAAoB,iBAAiB,SAAS,gBAAgB;AAAA,EAClE;AACA,QAAM,sBAAsB;AAC5B,MACK,uBAAuB,gBAAgB,uBACxC,iBAAiB,eAA8B,GACjD;AAEE,UAAM,sBAAsB;AAAA,MACxB,EAAE,gBAAgD;AAAA,MAClD,EAAE,aAAa,kBAAkB;AAAA,IACrC;AAEA,IAAC,gBAAgC,MAAM,aAAa;AAIpD,wBAAoB;AAAA,MAChB;AAAA,MACA;AAAA,IACJ;AACA,2BAAuB,YAAY,mBAAmB;AACtD,0BAAsB;AAEtB,QAAI,cAAc,cAAc;AAC5B,0BAAoB,iBAAiB,SAAS,gBAAgB;AAGlE,aAAS,eAAe,QAAQ,mBAAmB;AAAA,EACvD,WAAW,2BAA2B,UAAU;AAE5C,UAAM,uBAAuB,SAAS,MAAM;AACxC,YAAM,iBAAiB,uBAAuB;AAAA,QAC1C;AAAA,MACJ;AACA,YAAM,iBAAiB,uBAAuB;AAAA,QAC1C;AAAA,MACJ;AACA,0BAAoB;AAAA,QAChB,iBAAiB;AAAA,QACjB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACJ,CAAC;AAAA,IACL,GAAG,GAAG;AACN,wBAAoB,iBAAiB,SAAS,oBAAoB;AAAA,EACtE;AAEA,sBAAoB,aAAa,mBAAmB,MAAM;AAC1D,sBAAoB,iBAAiB,SAAS,gBAAgB;AAC9D,sBAAoB,iBAAiB,WAAW,kBAAkB;AAElE,sBAAoB,MAAM;AAE1B;AACJ;","names":[]}
@@ -34,6 +34,7 @@ __export(getChildrenDirection_exports, {
34
34
  });
35
35
  module.exports = __toCommonJS(getChildrenDirection_exports);
36
36
  var import_getChildElements = __toESM(require("./getChildElements.cjs"), 1);
37
+ var validPositions = ["vertical", "horizontal", "none"];
37
38
  function getChildrenDirection(editableElement, parentCslpValue) {
38
39
  if (!editableElement) {
39
40
  return "none";
@@ -44,6 +45,13 @@ function getChildrenDirection(editableElement, parentCslpValue) {
44
45
  if (!parentElement) {
45
46
  return "none";
46
47
  }
48
+ const directionFromParentElement = parentElement.getAttribute("data-add-direction");
49
+ const isValidParentDirection = validPositions.includes(
50
+ directionFromParentElement
51
+ );
52
+ if (directionFromParentElement && isValidParentDirection) {
53
+ return directionFromParentElement;
54
+ }
47
55
  const [firstChildElement, secondChildElement, removeClone] = (0, import_getChildElements.default)(parentElement, parentCslpValue);
48
56
  if (!firstChildElement) return "none";
49
57
  const firstChildBounds = firstChildElement.getBoundingClientRect();
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/visualBuilder/utils/getChildrenDirection.ts"],"sourcesContent":["import getChildElements from \"./getChildElements\";\n\nexport default function getChildrenDirection(\n editableElement: Element,\n parentCslpValue: string\n): \"none\" | \"horizontal\" | \"vertical\" {\n if (!editableElement) {\n return \"none\";\n }\n\n const parentElement = editableElement.closest(\n `[data-cslp=\"${parentCslpValue}\"]`\n );\n\n if (!parentElement) {\n return \"none\";\n }\n\n const [firstChildElement, secondChildElement, removeClone] =\n getChildElements(parentElement, parentCslpValue);\n\n if (!firstChildElement) return \"none\";\n\n // get horizontal and vertical position differences\n const firstChildBounds = firstChildElement.getBoundingClientRect();\n const secondChildBounds = secondChildElement.getBoundingClientRect();\n\n const deltaX = Math.abs(firstChildBounds.left - secondChildBounds.left);\n const deltaY = Math.abs(firstChildBounds.top - secondChildBounds.top);\n\n const dir = deltaX > deltaY ? \"horizontal\" : \"vertical\";\n\n // remove the clone that was created in case there was only one child\n removeClone();\n\n return dir;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,8BAA6B;AAEd,SAAR,qBACH,iBACA,iBACkC;AAClC,MAAI,CAAC,iBAAiB;AAClB,WAAO;AAAA,EACX;AAEA,QAAM,gBAAgB,gBAAgB;AAAA,IAClC,eAAe,eAAe;AAAA,EAClC;AAEA,MAAI,CAAC,eAAe;AAChB,WAAO;AAAA,EACX;AAEA,QAAM,CAAC,mBAAmB,oBAAoB,WAAW,QACrD,wBAAAA,SAAiB,eAAe,eAAe;AAEnD,MAAI,CAAC,kBAAmB,QAAO;AAG/B,QAAM,mBAAmB,kBAAkB,sBAAsB;AACjE,QAAM,oBAAoB,mBAAmB,sBAAsB;AAEnE,QAAM,SAAS,KAAK,IAAI,iBAAiB,OAAO,kBAAkB,IAAI;AACtE,QAAM,SAAS,KAAK,IAAI,iBAAiB,MAAM,kBAAkB,GAAG;AAEpE,QAAM,MAAM,SAAS,SAAS,eAAe;AAG7C,cAAY;AAEZ,SAAO;AACX;","names":["getChildElements"]}
1
+ {"version":3,"sources":["../../../../src/visualBuilder/utils/getChildrenDirection.ts"],"sourcesContent":["import getChildElements from \"./getChildElements\";\n\n\nconst validPositions = [\"vertical\", \"horizontal\", \"none\"] as const;\ntype ValidPositions = typeof validPositions[number];\n\nexport default function getChildrenDirection(\n editableElement: Element,\n parentCslpValue: string\n): ValidPositions {\n if (!editableElement) {\n return \"none\";\n }\n\n const parentElement = editableElement.closest(\n `[data-cslp=\"${parentCslpValue}\"]`\n );\n\n if (!parentElement) {\n return \"none\";\n }\n\n const directionFromParentElement =\n parentElement.getAttribute(\"data-add-direction\");\n\n const isValidParentDirection = validPositions.includes(\n directionFromParentElement as ValidPositions\n );\n\n\n if (directionFromParentElement && isValidParentDirection) {\n return directionFromParentElement as ValidPositions;\n }\n const [firstChildElement, secondChildElement, removeClone] =\n getChildElements(parentElement, parentCslpValue);\n\n if (!firstChildElement) return \"none\";\n\n // get horizontal and vertical position differences\n const firstChildBounds = firstChildElement.getBoundingClientRect();\n const secondChildBounds = secondChildElement.getBoundingClientRect();\n\n const deltaX = Math.abs(firstChildBounds.left - secondChildBounds.left);\n const deltaY = Math.abs(firstChildBounds.top - secondChildBounds.top);\n\n const dir = deltaX > deltaY ? \"horizontal\" : \"vertical\";\n\n // remove the clone that was created in case there was only one child\n removeClone();\n\n return dir;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,8BAA6B;AAG7B,IAAM,iBAAiB,CAAC,YAAY,cAAc,MAAM;AAGzC,SAAR,qBACH,iBACA,iBACc;AACd,MAAI,CAAC,iBAAiB;AAClB,WAAO;AAAA,EACX;AAEA,QAAM,gBAAgB,gBAAgB;AAAA,IAClC,eAAe,eAAe;AAAA,EAClC;AAEA,MAAI,CAAC,eAAe;AAChB,WAAO;AAAA,EACX;AAEA,QAAM,6BACF,cAAc,aAAa,oBAAoB;AAEnD,QAAM,yBAAyB,eAAe;AAAA,IAC1C;AAAA,EACJ;AAGA,MAAI,8BAA8B,wBAAwB;AACtD,WAAO;AAAA,EACX;AACA,QAAM,CAAC,mBAAmB,oBAAoB,WAAW,QACrD,wBAAAA,SAAiB,eAAe,eAAe;AAEnD,MAAI,CAAC,kBAAmB,QAAO;AAG/B,QAAM,mBAAmB,kBAAkB,sBAAsB;AACjE,QAAM,oBAAoB,mBAAmB,sBAAsB;AAEnE,QAAM,SAAS,KAAK,IAAI,iBAAiB,OAAO,kBAAkB,IAAI;AACtE,QAAM,SAAS,KAAK,IAAI,iBAAiB,MAAM,kBAAkB,GAAG;AAEpE,QAAM,MAAM,SAAS,SAAS,eAAe;AAG7C,cAAY;AAEZ,SAAO;AACX;","names":["getChildElements"]}
@@ -1,3 +1,5 @@
1
- declare function getChildrenDirection(editableElement: Element, parentCslpValue: string): "none" | "horizontal" | "vertical";
1
+ declare const validPositions: readonly ["vertical", "horizontal", "none"];
2
+ type ValidPositions = typeof validPositions[number];
3
+ declare function getChildrenDirection(editableElement: Element, parentCslpValue: string): ValidPositions;
2
4
 
3
5
  export { getChildrenDirection as default };
@@ -1,3 +1,5 @@
1
- declare function getChildrenDirection(editableElement: Element, parentCslpValue: string): "none" | "horizontal" | "vertical";
1
+ declare const validPositions: readonly ["vertical", "horizontal", "none"];
2
+ type ValidPositions = typeof validPositions[number];
3
+ declare function getChildrenDirection(editableElement: Element, parentCslpValue: string): ValidPositions;
2
4
 
3
5
  export { getChildrenDirection as default };
@@ -2,6 +2,7 @@ import "../../chunk-5WRI5ZAA.js";
2
2
 
3
3
  // src/visualBuilder/utils/getChildrenDirection.ts
4
4
  import getChildElements from "./getChildElements.js";
5
+ var validPositions = ["vertical", "horizontal", "none"];
5
6
  function getChildrenDirection(editableElement, parentCslpValue) {
6
7
  if (!editableElement) {
7
8
  return "none";
@@ -12,6 +13,13 @@ function getChildrenDirection(editableElement, parentCslpValue) {
12
13
  if (!parentElement) {
13
14
  return "none";
14
15
  }
16
+ const directionFromParentElement = parentElement.getAttribute("data-add-direction");
17
+ const isValidParentDirection = validPositions.includes(
18
+ directionFromParentElement
19
+ );
20
+ if (directionFromParentElement && isValidParentDirection) {
21
+ return directionFromParentElement;
22
+ }
15
23
  const [firstChildElement, secondChildElement, removeClone] = getChildElements(parentElement, parentCslpValue);
16
24
  if (!firstChildElement) return "none";
17
25
  const firstChildBounds = firstChildElement.getBoundingClientRect();
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/visualBuilder/utils/getChildrenDirection.ts"],"sourcesContent":["import getChildElements from \"./getChildElements\";\n\nexport default function getChildrenDirection(\n editableElement: Element,\n parentCslpValue: string\n): \"none\" | \"horizontal\" | \"vertical\" {\n if (!editableElement) {\n return \"none\";\n }\n\n const parentElement = editableElement.closest(\n `[data-cslp=\"${parentCslpValue}\"]`\n );\n\n if (!parentElement) {\n return \"none\";\n }\n\n const [firstChildElement, secondChildElement, removeClone] =\n getChildElements(parentElement, parentCslpValue);\n\n if (!firstChildElement) return \"none\";\n\n // get horizontal and vertical position differences\n const firstChildBounds = firstChildElement.getBoundingClientRect();\n const secondChildBounds = secondChildElement.getBoundingClientRect();\n\n const deltaX = Math.abs(firstChildBounds.left - secondChildBounds.left);\n const deltaY = Math.abs(firstChildBounds.top - secondChildBounds.top);\n\n const dir = deltaX > deltaY ? \"horizontal\" : \"vertical\";\n\n // remove the clone that was created in case there was only one child\n removeClone();\n\n return dir;\n}\n"],"mappings":";;;AAAA,OAAO,sBAAsB;AAEd,SAAR,qBACH,iBACA,iBACkC;AAClC,MAAI,CAAC,iBAAiB;AAClB,WAAO;AAAA,EACX;AAEA,QAAM,gBAAgB,gBAAgB;AAAA,IAClC,eAAe,eAAe;AAAA,EAClC;AAEA,MAAI,CAAC,eAAe;AAChB,WAAO;AAAA,EACX;AAEA,QAAM,CAAC,mBAAmB,oBAAoB,WAAW,IACrD,iBAAiB,eAAe,eAAe;AAEnD,MAAI,CAAC,kBAAmB,QAAO;AAG/B,QAAM,mBAAmB,kBAAkB,sBAAsB;AACjE,QAAM,oBAAoB,mBAAmB,sBAAsB;AAEnE,QAAM,SAAS,KAAK,IAAI,iBAAiB,OAAO,kBAAkB,IAAI;AACtE,QAAM,SAAS,KAAK,IAAI,iBAAiB,MAAM,kBAAkB,GAAG;AAEpE,QAAM,MAAM,SAAS,SAAS,eAAe;AAG7C,cAAY;AAEZ,SAAO;AACX;","names":[]}
1
+ {"version":3,"sources":["../../../../src/visualBuilder/utils/getChildrenDirection.ts"],"sourcesContent":["import getChildElements from \"./getChildElements\";\n\n\nconst validPositions = [\"vertical\", \"horizontal\", \"none\"] as const;\ntype ValidPositions = typeof validPositions[number];\n\nexport default function getChildrenDirection(\n editableElement: Element,\n parentCslpValue: string\n): ValidPositions {\n if (!editableElement) {\n return \"none\";\n }\n\n const parentElement = editableElement.closest(\n `[data-cslp=\"${parentCslpValue}\"]`\n );\n\n if (!parentElement) {\n return \"none\";\n }\n\n const directionFromParentElement =\n parentElement.getAttribute(\"data-add-direction\");\n\n const isValidParentDirection = validPositions.includes(\n directionFromParentElement as ValidPositions\n );\n\n\n if (directionFromParentElement && isValidParentDirection) {\n return directionFromParentElement as ValidPositions;\n }\n const [firstChildElement, secondChildElement, removeClone] =\n getChildElements(parentElement, parentCslpValue);\n\n if (!firstChildElement) return \"none\";\n\n // get horizontal and vertical position differences\n const firstChildBounds = firstChildElement.getBoundingClientRect();\n const secondChildBounds = secondChildElement.getBoundingClientRect();\n\n const deltaX = Math.abs(firstChildBounds.left - secondChildBounds.left);\n const deltaY = Math.abs(firstChildBounds.top - secondChildBounds.top);\n\n const dir = deltaX > deltaY ? \"horizontal\" : \"vertical\";\n\n // remove the clone that was created in case there was only one child\n removeClone();\n\n return dir;\n}\n"],"mappings":";;;AAAA,OAAO,sBAAsB;AAG7B,IAAM,iBAAiB,CAAC,YAAY,cAAc,MAAM;AAGzC,SAAR,qBACH,iBACA,iBACc;AACd,MAAI,CAAC,iBAAiB;AAClB,WAAO;AAAA,EACX;AAEA,QAAM,gBAAgB,gBAAgB;AAAA,IAClC,eAAe,eAAe;AAAA,EAClC;AAEA,MAAI,CAAC,eAAe;AAChB,WAAO;AAAA,EACX;AAEA,QAAM,6BACF,cAAc,aAAa,oBAAoB;AAEnD,QAAM,yBAAyB,eAAe;AAAA,IAC1C;AAAA,EACJ;AAGA,MAAI,8BAA8B,wBAAwB;AACtD,WAAO;AAAA,EACX;AACA,QAAM,CAAC,mBAAmB,oBAAoB,WAAW,IACrD,iBAAiB,eAAe,eAAe;AAEnD,MAAI,CAAC,kBAAmB,QAAO;AAG/B,QAAM,mBAAmB,kBAAkB,sBAAsB;AACjE,QAAM,oBAAoB,mBAAmB,sBAAsB;AAEnE,QAAM,SAAS,KAAK,IAAI,iBAAiB,OAAO,kBAAkB,IAAI;AACtE,QAAM,SAAS,KAAK,IAAI,iBAAiB,MAAM,kBAAkB,GAAG;AAEpE,QAAM,MAAM,SAAS,SAAS,eAAe;AAG7C,cAAY;AAEZ,SAAO;AACX;","names":[]}
@@ -34,9 +34,7 @@ __export(handleIndividualFields_exports, {
34
34
  handleIndividualFields: () => handleIndividualFields
35
35
  });
36
36
  module.exports = __toCommonJS(handleIndividualFields_exports);
37
- var import_lodash_es = require("lodash-es");
38
37
  var import__ = require("../index.cjs");
39
- var import_generatePseudoEditableField = require("../generators/generatePseudoEditableField.cjs");
40
38
  var import_constants = require("./constants.cjs");
41
39
  var import_fieldSchemaMap = require("./fieldSchemaMap.cjs");
42
40
  var import_getFieldData = require("./getFieldData.cjs");
@@ -44,11 +42,11 @@ var import_getFieldType = require("./getFieldType.cjs");
44
42
  var import_handleFieldMouseDown = require("./handleFieldMouseDown.cjs");
45
43
  var import_isFieldDisabled = require("./isFieldDisabled.cjs");
46
44
  var import_multipleElementAddButton = require("./multipleElementAddButton.cjs");
47
- var import_updateFocussedState = require("./updateFocussedState.cjs");
48
- var import_types = require("./types/index.types.cjs");
49
- var import_getMultilinePlaintext = require("./getMultilinePlaintext.cjs");
50
45
  var import_postMessage = require("./types/postMessage.types.cjs");
51
46
  var import_visualBuilderPostMessage = __toESM(require("./visualBuilderPostMessage.cjs"), 1);
47
+ var import_isFieldMultiple = require("./isFieldMultiple.cjs");
48
+ var import_handleInlineEditableField = require("./handleInlineEditableField.cjs");
49
+ var import_pasteAsPlainText = require("./pasteAsPlainText.cjs");
52
50
  async function handleIndividualFields(eventDetails, elements) {
53
51
  const { fieldMetadata, editableElement } = eventDetails;
54
52
  const { visualBuilderContainer, lastEditedField, resizeObserver } = elements;
@@ -72,7 +70,7 @@ async function handleIndividualFields(eventDetails, elements) {
72
70
  import_constants.VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,
73
71
  fieldType
74
72
  );
75
- if (isFieldMultiple(fieldSchema)) {
73
+ if ((0, import_isFieldMultiple.isFieldMultiple)(fieldSchema)) {
76
74
  if (lastEditedField !== editableElement) {
77
75
  const addButtonLabel = fieldSchema.data_type === "blocks" ? (
78
76
  // ? `Add ${fieldSchema.display_name ?? "Modular Block"}`
@@ -94,95 +92,17 @@ async function handleIndividualFields(eventDetails, elements) {
94
92
  );
95
93
  }
96
94
  }
97
- !disabled && handleInlineEditing();
98
- function handleInlineEditing() {
99
- if (!import_constants.ALLOWED_INLINE_EDITABLE_FIELD.includes(fieldType)) return;
100
- const index = Number(fieldMetadata.instance.fieldPathWithIndex.split(".").at(-1));
101
- const isInstance = Number.isFinite(index);
102
- if (isFieldMultiple(fieldSchema)) {
103
- let expectedFieldInstanceData = null;
104
- if (Array.isArray(expectedFieldData)) {
105
- if (!isInstance) {
106
- return;
107
- }
108
- if (index >= expectedFieldData.length) {
109
- } else {
110
- expectedFieldInstanceData = expectedFieldData.at(index);
111
- }
112
- } else {
113
- expectedFieldInstanceData = expectedFieldData;
114
- }
115
- enableInlineEditing(expectedFieldInstanceData);
116
- } else {
117
- let expectedFieldInstanceData = null;
118
- if (isInstance) {
119
- if (index !== 0) {
120
- return;
121
- }
122
- expectedFieldInstanceData = Array.isArray(expectedFieldData) ? expectedFieldData.at(0) : expectedFieldData;
123
- }
124
- enableInlineEditing(expectedFieldInstanceData ?? expectedFieldData);
125
- }
126
- function enableInlineEditing(expectedFieldData2) {
127
- let actualEditableField = editableElement;
128
- import__.VisualBuilder.VisualBuilderGlobalState.value.focusFieldValue = actualEditableField == null ? void 0 : actualEditableField.innerText;
129
- const elementComputedDisplay = window.getComputedStyle(actualEditableField).display;
130
- let textContent = editableElement.innerText || editableElement.textContent || "";
131
- if (fieldType === import_types.FieldDataType.MULTILINE) {
132
- textContent = (0, import_getMultilinePlaintext.getMultilinePlaintext)(actualEditableField);
133
- actualEditableField.addEventListener("paste", pasteAsPlainText);
134
- }
135
- const expectedTextContent = expectedFieldData2;
136
- if (expectedTextContent && textContent !== expectedTextContent || (0, import_generatePseudoEditableField.isEllipsisActive)(editableElement)) {
137
- const pseudoEditableField = (0, import_generatePseudoEditableField.generatePseudoEditableElement)(
138
- { editableElement },
139
- { textContent: expectedFieldData2 }
140
- );
141
- editableElement.style.visibility = "hidden";
142
- pseudoEditableField.setAttribute(
143
- import_constants.VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,
144
- fieldType
145
- );
146
- visualBuilderContainer.appendChild(pseudoEditableField);
147
- actualEditableField = pseudoEditableField;
148
- if (fieldType === import_types.FieldDataType.MULTILINE)
149
- actualEditableField.addEventListener(
150
- "paste",
151
- pasteAsPlainText
152
- );
153
- elements.resizeObserver.observe(pseudoEditableField);
154
- } else if (elementComputedDisplay === "inline") {
155
- const onInlineElementInput = (0, import_lodash_es.throttle)(() => {
156
- const overlayWrapper = visualBuilderContainer.querySelector(
157
- ".visual-builder__overlay__wrapper"
158
- );
159
- const focusedToolbar = visualBuilderContainer.querySelector(
160
- ".visual-builder__focused-toolbar"
161
- );
162
- (0, import_updateFocussedState.updateFocussedState)({
163
- editableElement: actualEditableField,
164
- visualBuilderContainer,
165
- overlayWrapper,
166
- focusedToolbar,
167
- resizeObserver
168
- });
169
- }, 200);
170
- actualEditableField.addEventListener(
171
- "input",
172
- onInlineElementInput
173
- );
174
- }
175
- actualEditableField.setAttribute("contenteditable", "true");
176
- actualEditableField.addEventListener("input", import_handleFieldMouseDown.handleFieldInput);
177
- actualEditableField.addEventListener("keydown", import_handleFieldMouseDown.handleFieldKeyDown);
178
- actualEditableField.focus();
179
- return;
180
- }
95
+ if (disabled) {
96
+ return;
181
97
  }
182
- }
183
- function isFieldMultiple(fieldSchema) {
184
- return fieldSchema && (fieldSchema.multiple || fieldSchema.data_type === "reference" && // @ts-ignore
185
- fieldSchema.field_metadata.ref_multiple);
98
+ (0, import_handleInlineEditableField.handleInlineEditableField)({
99
+ fieldType,
100
+ fieldSchema,
101
+ fieldMetadata,
102
+ expectedFieldData,
103
+ editableElement,
104
+ elements
105
+ });
186
106
  }
187
107
  function cleanIndividualFieldResidual(elements) {
188
108
  const { overlayWrapper, visualBuilderContainer, focusedToolbar } = elements;
@@ -210,7 +130,7 @@ function cleanIndividualFieldResidual(elements) {
210
130
  );
211
131
  previousSelectedEditableDOM.removeEventListener(
212
132
  "paste",
213
- pasteAsPlainText
133
+ import_pasteAsPlainText.pasteAsPlainText
214
134
  );
215
135
  elements.resizeObserver.unobserve(previousSelectedEditableDOM);
216
136
  }
@@ -219,7 +139,7 @@ function cleanIndividualFieldResidual(elements) {
219
139
  );
220
140
  if (pseudoEditableElement) {
221
141
  elements.resizeObserver.unobserve(pseudoEditableElement);
222
- pseudoEditableElement.removeEventListener("paste", pasteAsPlainText);
142
+ pseudoEditableElement.removeEventListener("paste", import_pasteAsPlainText.pasteAsPlainText);
223
143
  pseudoEditableElement.remove();
224
144
  if (previousSelectedEditableDOM) {
225
145
  previousSelectedEditableDOM.style.removeProperty(
@@ -229,26 +149,18 @@ function cleanIndividualFieldResidual(elements) {
229
149
  }
230
150
  if (focusedToolbar) {
231
151
  focusedToolbar.innerHTML = "";
232
- const toolbarEvents = [import_postMessage.VisualBuilderPostMessageEvents.DELETE_INSTANCE, import_postMessage.VisualBuilderPostMessageEvents.UPDATE_DISCUSSION_ID];
152
+ const toolbarEvents = [
153
+ import_postMessage.VisualBuilderPostMessageEvents.DELETE_INSTANCE,
154
+ import_postMessage.VisualBuilderPostMessageEvents.UPDATE_DISCUSSION_ID
155
+ ];
233
156
  toolbarEvents.forEach((event) => {
234
- var _a, _b;
235
- (_b = (_a = import_visualBuilderPostMessage.default) == null ? void 0 : _a.unregisterEvent) == null ? void 0 : _b.call(_a, event);
157
+ var _a, _b, _c, _d;
158
+ if ((_b = (_a = import_visualBuilderPostMessage.default) == null ? void 0 : _a.requestMessageHandlers) == null ? void 0 : _b.has(event)) {
159
+ (_d = (_c = import_visualBuilderPostMessage.default) == null ? void 0 : _c.unregisterEvent) == null ? void 0 : _d.call(_c, event);
160
+ }
236
161
  });
237
162
  }
238
163
  }
239
- var pasteAsPlainText = (0, import_lodash_es.debounce)(
240
- (e) => {
241
- e.preventDefault();
242
- const clipboardData = e.clipboardData;
243
- document.execCommand(
244
- "inserttext",
245
- false,
246
- clipboardData == null ? void 0 : clipboardData.getData("text/plain")
247
- );
248
- },
249
- 100,
250
- { leading: true }
251
- );
252
164
  // Annotate the CommonJS export names for ESM import in node:
253
165
  0 && (module.exports = {
254
166
  cleanIndividualFieldResidual,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/visualBuilder/utils/handleIndividualFields.ts"],"sourcesContent":["import { debounce, throttle } from \"lodash-es\";\nimport { VisualBuilder } from \"..\";\nimport {\n generatePseudoEditableElement,\n isEllipsisActive,\n} from \"../generators/generatePseudoEditableField\";\nimport { VisualBuilderCslpEventDetails } from \"../types/visualBuilder.types\";\nimport {\n ALLOWED_INLINE_EDITABLE_FIELD,\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,\n} from \"./constants\";\nimport { FieldSchemaMap } from \"./fieldSchemaMap\";\nimport { getFieldData } from \"./getFieldData\";\nimport { getFieldType } from \"./getFieldType\";\nimport { handleFieldInput, handleFieldKeyDown } from \"./handleFieldMouseDown\";\nimport { isFieldDisabled } from \"./isFieldDisabled\";\nimport {\n handleAddButtonsForMultiple,\n removeAddInstanceButtons,\n} from \"./multipleElementAddButton\";\nimport { updateFocussedState } from \"./updateFocussedState\";\nimport { FieldDataType, ISchemaFieldMap } from \"./types/index.types\";\nimport { getMultilinePlaintext } from \"./getMultilinePlaintext\";\nimport { VisualBuilderPostMessageEvents } from \"./types/postMessage.types\";\nimport visualBuilderPostMessage from \"./visualBuilderPostMessage\";\n\n/**\n * It handles all the fields based on their data type and its \"multiple\" property.\n * @param eventDetails The event details object that contain cslp and field metadata.\n * @param elements The elements object that contain the visual builder wrapper.\n */\nexport async function handleIndividualFields(\n eventDetails: VisualBuilderCslpEventDetails,\n elements: {\n visualBuilderContainer: HTMLDivElement;\n resizeObserver: ResizeObserver;\n lastEditedField: Element | null;\n }\n): Promise<void> {\n const { fieldMetadata, editableElement } = eventDetails;\n const { visualBuilderContainer, lastEditedField, resizeObserver } =\n elements;\n const {\n content_type_uid,\n entry_uid,\n locale,\n fieldPath,\n fieldPathWithIndex,\n } = fieldMetadata;\n\n const [fieldSchema, expectedFieldData] = await Promise.all([\n FieldSchemaMap.getFieldSchema(content_type_uid, fieldPath),\n getFieldData(\n { content_type_uid, entry_uid, locale },\n fieldPathWithIndex\n ),\n ]);\n\n const fieldType = getFieldType(fieldSchema);\n\n const { isDisabled: disabled } = isFieldDisabled(fieldSchema, eventDetails);\n\n editableElement.setAttribute(\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,\n fieldType\n );\n\n if (isFieldMultiple(fieldSchema)) {\n if (lastEditedField !== editableElement) {\n const addButtonLabel =\n fieldSchema.data_type === \"blocks\"\n ? // ? `Add ${fieldSchema.display_name ?? \"Modular Block\"}`\n \"Add Section\"\n : undefined;\n\n handleAddButtonsForMultiple(\n eventDetails,\n {\n editableElement: eventDetails.editableElement,\n visualBuilderContainer: visualBuilderContainer,\n resizeObserver: resizeObserver,\n },\n {\n fieldSchema,\n expectedFieldData,\n disabled,\n label: addButtonLabel,\n }\n );\n }\n } \n\n !disabled && handleInlineEditing();\n\n /**\n * Handles inline editing for supported fields.\n */\n function handleInlineEditing() {\n\n if (!ALLOWED_INLINE_EDITABLE_FIELD.includes(fieldType)) return;\n\n // Instances of ALLOWED_INLINE_EDITABLE_FIELD will always have index at last\n const index = Number(fieldMetadata.instance.fieldPathWithIndex.split('.').at(-1));\n const isInstance = Number.isFinite(index);\n\n // CASE 1: Handle inline editing for multiple field\n if(isFieldMultiple(fieldSchema)) {\n let expectedFieldInstanceData = null;\n if(Array.isArray(expectedFieldData)) {\n // CASE: Selected element is the multiple field itself.\n // Inline Editing not allowed on field, only allowed on instance.\n // (We recieve unreliable `multipleFieldMetadata` in this case)\n if(!isInstance) {\n return;\n }\n\n // CASE: Value does not exist for the provided instance's index\n if(index >= expectedFieldData.length) {\n // TODO: What should be the behavior here?\n }\n else {\n expectedFieldInstanceData = expectedFieldData.at(index);\n }\n }\n // CASE: ContentType's Field changed from single to multiple, while Entry's Field still single.\n else {\n expectedFieldInstanceData = expectedFieldData;\n }\n\n enableInlineEditing(expectedFieldInstanceData); \n }\n // CASE 2: Handle inline editing for a single field\n else {\n let expectedFieldInstanceData = null;\n // CASE: ContentType's Field changed from multiple to single, while Entry's Field still multiple.\n if(isInstance) {\n if(index !== 0) {\n // TODO: Handle this with UX\n // Let user know, CSLP is invalid due to change in Content Type\n return;\n }\n expectedFieldInstanceData = Array.isArray(expectedFieldData) ? expectedFieldData.at(0) : expectedFieldData;\n }\n enableInlineEditing(expectedFieldInstanceData ?? expectedFieldData);\n }\n\n function enableInlineEditing(expectedFieldData: any) {\n\n let actualEditableField = editableElement as HTMLElement;\n\n VisualBuilder.VisualBuilderGlobalState.value.focusFieldValue =\n actualEditableField?.innerText;\n\n const elementComputedDisplay =\n window.getComputedStyle(actualEditableField).display;\n\n let textContent =\n (editableElement as HTMLElement).innerText ||\n editableElement.textContent ||\n \"\";\n\n if (fieldType === FieldDataType.MULTILINE) {\n textContent = getMultilinePlaintext(actualEditableField);\n actualEditableField.addEventListener(\"paste\", pasteAsPlainText);\n }\n const expectedTextContent = expectedFieldData;\n if (\n (expectedTextContent && textContent !== expectedTextContent) ||\n isEllipsisActive(editableElement as HTMLElement)\n ) {\n \n // TODO: Testing will be done in the E2E.\n const pseudoEditableField = generatePseudoEditableElement(\n { editableElement: editableElement as HTMLElement },\n { textContent: expectedFieldData }\n );\n\n (editableElement as HTMLElement).style.visibility = \"hidden\";\n\n // set field type attribute to the pseudo editable field\n // ensures proper keydown handling similar to the actual editable field\n pseudoEditableField.setAttribute(\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,\n fieldType\n );\n visualBuilderContainer.appendChild(pseudoEditableField);\n actualEditableField = pseudoEditableField;\n\n if (fieldType === FieldDataType.MULTILINE)\n actualEditableField.addEventListener(\n \"paste\",\n pasteAsPlainText\n );\n\n // we will unobserve this in hideOverlay\n elements.resizeObserver.observe(pseudoEditableField);\n } else if (elementComputedDisplay === \"inline\") {\n // if the editable field is inline\n const onInlineElementInput = throttle(() => {\n const overlayWrapper = visualBuilderContainer.querySelector(\n \".visual-builder__overlay__wrapper\"\n ) as HTMLDivElement;\n const focusedToolbar = visualBuilderContainer.querySelector(\n \".visual-builder__focused-toolbar\"\n ) as HTMLDivElement;\n updateFocussedState({\n editableElement: actualEditableField,\n visualBuilderContainer,\n overlayWrapper,\n focusedToolbar,\n resizeObserver,\n });\n }, 200);\n actualEditableField.addEventListener(\n \"input\",\n onInlineElementInput\n );\n }\n\n actualEditableField.setAttribute(\"contenteditable\", \"true\");\n actualEditableField.addEventListener(\"input\", handleFieldInput);\n actualEditableField.addEventListener(\"keydown\", handleFieldKeyDown);\n // focus on the contenteditable element to start accepting input\n actualEditableField.focus();\n\n return;\n }\n }\n}\n\nfunction isFieldMultiple(fieldSchema: ISchemaFieldMap): boolean {\n return fieldSchema &&\n (fieldSchema.multiple ||\n (fieldSchema.data_type === \"reference\" &&\n // @ts-ignore\n fieldSchema.field_metadata.ref_multiple));\n}\n\nexport function cleanIndividualFieldResidual(elements: {\n overlayWrapper: HTMLDivElement;\n visualBuilderContainer: HTMLDivElement | null;\n focusedToolbar: HTMLDivElement | null;\n resizeObserver: ResizeObserver;\n}): void {\n const { overlayWrapper, visualBuilderContainer, focusedToolbar } = elements;\n\n removeAddInstanceButtons(\n {\n eventTarget: null,\n visualBuilderContainer: visualBuilderContainer,\n overlayWrapper: overlayWrapper,\n },\n true\n );\n\n const previousSelectedEditableDOM =\n VisualBuilder.VisualBuilderGlobalState.value\n .previousSelectedEditableDOM;\n if (previousSelectedEditableDOM) {\n previousSelectedEditableDOM.removeAttribute(\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY\n );\n previousSelectedEditableDOM.removeAttribute(\"contenteditable\");\n previousSelectedEditableDOM.removeEventListener(\n \"input\",\n handleFieldInput\n );\n previousSelectedEditableDOM.removeEventListener(\n \"keydown\",\n handleFieldKeyDown\n );\n\n previousSelectedEditableDOM.removeEventListener(\n \"paste\",\n pasteAsPlainText\n );\n // Note - this happens in two places, 1. hideOverlay and 2. here\n // TODO maybe see all usages of both functions and try to do it in one place\n elements.resizeObserver.unobserve(previousSelectedEditableDOM);\n }\n\n const pseudoEditableElement = visualBuilderContainer?.querySelector(\n \".visual-builder__pseudo-editable-element\"\n );\n if (pseudoEditableElement) {\n elements.resizeObserver.unobserve(pseudoEditableElement);\n pseudoEditableElement.removeEventListener(\"paste\", pasteAsPlainText);\n pseudoEditableElement.remove();\n if (previousSelectedEditableDOM) {\n (previousSelectedEditableDOM as HTMLElement).style.removeProperty(\n \"visibility\"\n );\n }\n }\n\n if (focusedToolbar) {\n focusedToolbar.innerHTML = \"\";\n const toolbarEvents = [VisualBuilderPostMessageEvents.DELETE_INSTANCE, VisualBuilderPostMessageEvents.UPDATE_DISCUSSION_ID]\n toolbarEvents.forEach((event) => {\n //@ts-expect-error - We are accessing private method here, but it is necessary to clean up the event listeners.\n visualBuilderPostMessage?.unregisterEvent?.(event);\n });\n }\n}\n\nconst pasteAsPlainText = debounce(\n (e: Event) => {\n e.preventDefault();\n const clipboardData = (e as ClipboardEvent).clipboardData;\n document.execCommand(\n \"inserttext\",\n false,\n clipboardData?.getData(\"text/plain\")\n );\n },\n 100,\n { leading: true }\n);\n"],"mappings":"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","names":["expectedFieldData","visualBuilderPostMessage"]}
1
+ {"version":3,"sources":["../../../../src/visualBuilder/utils/handleIndividualFields.ts"],"sourcesContent":["import { VisualBuilder } from \"..\";\nimport { VisualBuilderCslpEventDetails } from \"../types/visualBuilder.types\";\nimport { VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY } from \"./constants\";\nimport { FieldSchemaMap } from \"./fieldSchemaMap\";\nimport { getFieldData } from \"./getFieldData\";\nimport { getFieldType } from \"./getFieldType\";\nimport { handleFieldInput, handleFieldKeyDown } from \"./handleFieldMouseDown\";\nimport { isFieldDisabled } from \"./isFieldDisabled\";\nimport {\n handleAddButtonsForMultiple,\n removeAddInstanceButtons,\n} from \"./multipleElementAddButton\";\nimport { VisualBuilderPostMessageEvents } from \"./types/postMessage.types\";\nimport visualBuilderPostMessage from \"./visualBuilderPostMessage\";\nimport { isFieldMultiple } from \"./isFieldMultiple\";\nimport { handleInlineEditableField } from \"./handleInlineEditableField\";\nimport { VisualBuilderEditContext } from \"./types/index.types\";\nimport { pasteAsPlainText } from \"./pasteAsPlainText\";\n\n/**\n * It handles all the fields based on their data type and its \"multiple\" property.\n * @param eventDetails The event details object that contain cslp and field metadata.\n * @param elements The elements object that contain the visual builder wrapper.\n */\nexport async function handleIndividualFields(\n eventDetails: VisualBuilderCslpEventDetails,\n elements: VisualBuilderEditContext\n): Promise<void> {\n const { fieldMetadata, editableElement } = eventDetails;\n const { visualBuilderContainer, lastEditedField, resizeObserver } =\n elements;\n const {\n content_type_uid,\n entry_uid,\n locale,\n fieldPath,\n fieldPathWithIndex,\n } = fieldMetadata;\n\n const [fieldSchema, expectedFieldData] = await Promise.all([\n FieldSchemaMap.getFieldSchema(content_type_uid, fieldPath),\n getFieldData(\n { content_type_uid, entry_uid, locale },\n fieldPathWithIndex\n ),\n ]);\n\n const fieldType = getFieldType(fieldSchema);\n\n const { isDisabled: disabled } = isFieldDisabled(fieldSchema, eventDetails);\n\n editableElement.setAttribute(\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY,\n fieldType\n );\n\n if (isFieldMultiple(fieldSchema)) {\n if (lastEditedField !== editableElement) {\n const addButtonLabel =\n fieldSchema.data_type === \"blocks\"\n ? // ? `Add ${fieldSchema.display_name ?? \"Modular Block\"}`\n \"Add Section\"\n : undefined;\n\n handleAddButtonsForMultiple(\n eventDetails,\n {\n editableElement: eventDetails.editableElement,\n visualBuilderContainer: visualBuilderContainer,\n resizeObserver: resizeObserver,\n },\n {\n fieldSchema,\n expectedFieldData,\n disabled,\n label: addButtonLabel,\n }\n );\n }\n }\n\n if (disabled) {\n return;\n }\n handleInlineEditableField({\n fieldType,\n fieldSchema,\n fieldMetadata,\n expectedFieldData,\n editableElement: editableElement as HTMLElement,\n elements,\n });\n}\n\nexport function cleanIndividualFieldResidual(elements: {\n overlayWrapper: HTMLDivElement;\n visualBuilderContainer: HTMLDivElement | null;\n focusedToolbar: HTMLDivElement | null;\n resizeObserver: ResizeObserver;\n}): void {\n const { overlayWrapper, visualBuilderContainer, focusedToolbar } = elements;\n\n removeAddInstanceButtons(\n {\n eventTarget: null,\n visualBuilderContainer: visualBuilderContainer,\n overlayWrapper: overlayWrapper,\n },\n true\n );\n\n const previousSelectedEditableDOM =\n VisualBuilder.VisualBuilderGlobalState.value\n .previousSelectedEditableDOM;\n if (previousSelectedEditableDOM) {\n previousSelectedEditableDOM.removeAttribute(\n VISUAL_BUILDER_FIELD_TYPE_ATTRIBUTE_KEY\n );\n previousSelectedEditableDOM.removeAttribute(\"contenteditable\");\n previousSelectedEditableDOM.removeEventListener(\n \"input\",\n handleFieldInput\n );\n previousSelectedEditableDOM.removeEventListener(\n \"keydown\",\n handleFieldKeyDown\n );\n\n previousSelectedEditableDOM.removeEventListener(\n \"paste\",\n pasteAsPlainText\n );\n // Note - this happens in two places, 1. hideOverlay and 2. here\n // TODO maybe see all usages of both functions and try to do it in one place\n elements.resizeObserver.unobserve(previousSelectedEditableDOM);\n }\n\n const pseudoEditableElement = visualBuilderContainer?.querySelector(\n \".visual-builder__pseudo-editable-element\"\n );\n if (pseudoEditableElement) {\n elements.resizeObserver.unobserve(pseudoEditableElement);\n pseudoEditableElement.removeEventListener(\"paste\", pasteAsPlainText);\n pseudoEditableElement.remove();\n if (previousSelectedEditableDOM) {\n (previousSelectedEditableDOM as HTMLElement).style.removeProperty(\n \"visibility\"\n );\n }\n }\n\n if (focusedToolbar) {\n focusedToolbar.innerHTML = \"\";\n const toolbarEvents = [\n VisualBuilderPostMessageEvents.DELETE_INSTANCE,\n VisualBuilderPostMessageEvents.UPDATE_DISCUSSION_ID,\n ];\n toolbarEvents.forEach((event) => {\n //@ts-expect-error - We are accessing private method here, but it is necessary to clean up the event listeners.\n if (visualBuilderPostMessage?.requestMessageHandlers?.has(event)) {\n //@ts-expect-error - We are accessing private method here, but it is necessary to clean up the event listeners.\n visualBuilderPostMessage?.unregisterEvent?.(event);\n }\n });\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,eAA8B;AAE9B,uBAAwD;AACxD,4BAA+B;AAC/B,0BAA6B;AAC7B,0BAA6B;AAC7B,kCAAqD;AACrD,6BAAgC;AAChC,sCAGO;AACP,yBAA+C;AAC/C,sCAAqC;AACrC,6BAAgC;AAChC,uCAA0C;AAE1C,8BAAiC;AAOjC,eAAsB,uBAClB,cACA,UACa;AACb,QAAM,EAAE,eAAe,gBAAgB,IAAI;AAC3C,QAAM,EAAE,wBAAwB,iBAAiB,eAAe,IAC5D;AACJ,QAAM;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACJ,IAAI;AAEJ,QAAM,CAAC,aAAa,iBAAiB,IAAI,MAAM,QAAQ,IAAI;AAAA,IACvD,qCAAe,eAAe,kBAAkB,SAAS;AAAA,QACzD;AAAA,MACI,EAAE,kBAAkB,WAAW,OAAO;AAAA,MACtC;AAAA,IACJ;AAAA,EACJ,CAAC;AAED,QAAM,gBAAY,kCAAa,WAAW;AAE1C,QAAM,EAAE,YAAY,SAAS,QAAI,wCAAgB,aAAa,YAAY;AAE1E,kBAAgB;AAAA,IACZ;AAAA,IACA;AAAA,EACJ;AAEA,UAAI,wCAAgB,WAAW,GAAG;AAC9B,QAAI,oBAAoB,iBAAiB;AACrC,YAAM,iBACF,YAAY,cAAc;AAAA;AAAA,QAEpB;AAAA,UACA;AAEV;AAAA,QACI;AAAA,QACA;AAAA,UACI,iBAAiB,aAAa;AAAA,UAC9B;AAAA,UACA;AAAA,QACJ;AAAA,QACA;AAAA,UACI;AAAA,UACA;AAAA,UACA;AAAA,UACA,OAAO;AAAA,QACX;AAAA,MACJ;AAAA,IACJ;AAAA,EACJ;AAEA,MAAI,UAAU;AACV;AAAA,EACJ;AACA,kEAA0B;AAAA,IACtB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACJ,CAAC;AACL;AAEO,SAAS,6BAA6B,UAKpC;AACL,QAAM,EAAE,gBAAgB,wBAAwB,eAAe,IAAI;AAEnE;AAAA,IACI;AAAA,MACI,aAAa;AAAA,MACb;AAAA,MACA;AAAA,IACJ;AAAA,IACA;AAAA,EACJ;AAEA,QAAM,8BACF,uBAAc,yBAAyB,MAClC;AACT,MAAI,6BAA6B;AAC7B,gCAA4B;AAAA,MACxB;AAAA,IACJ;AACA,gCAA4B,gBAAgB,iBAAiB;AAC7D,gCAA4B;AAAA,MACxB;AAAA,MACA;AAAA,IACJ;AACA,gCAA4B;AAAA,MACxB;AAAA,MACA;AAAA,IACJ;AAEA,gCAA4B;AAAA,MACxB;AAAA,MACA;AAAA,IACJ;AAGA,aAAS,eAAe,UAAU,2BAA2B;AAAA,EACjE;AAEA,QAAM,wBAAwB,iEAAwB;AAAA,IAClD;AAAA;AAEJ,MAAI,uBAAuB;AACvB,aAAS,eAAe,UAAU,qBAAqB;AACvD,0BAAsB,oBAAoB,SAAS,wCAAgB;AACnE,0BAAsB,OAAO;AAC7B,QAAI,6BAA6B;AAC7B,MAAC,4BAA4C,MAAM;AAAA,QAC/C;AAAA,MACJ;AAAA,IACJ;AAAA,EACJ;AAEA,MAAI,gBAAgB;AAChB,mBAAe,YAAY;AAC3B,UAAM,gBAAgB;AAAA,MAClB,kDAA+B;AAAA,MAC/B,kDAA+B;AAAA,IACnC;AACA,kBAAc,QAAQ,CAAC,UAAU;AA7JzC;AA+JY,WAAI,2CAAAA,YAAA,mBAA0B,2BAA1B,mBAAkD,IAAI,QAAQ;AAE9D,oDAAAA,YAAA,mBAA0B,oBAA1B,4BAA4C;AAAA,MAChD;AAAA,IACJ,CAAC;AAAA,EACL;AACJ;","names":["visualBuilderPostMessage"]}
@@ -1,16 +1,14 @@
1
1
  import { VisualBuilderCslpEventDetails } from '../types/visualBuilder.types.cjs';
2
+ import { VisualBuilderEditContext } from './types/index.types.cjs';
2
3
  import '../../cslp/types/cslp.types.cjs';
4
+ import '../../cms/types/contentTypeSchema.types.cjs';
3
5
 
4
6
  /**
5
7
  * It handles all the fields based on their data type and its "multiple" property.
6
8
  * @param eventDetails The event details object that contain cslp and field metadata.
7
9
  * @param elements The elements object that contain the visual builder wrapper.
8
10
  */
9
- declare function handleIndividualFields(eventDetails: VisualBuilderCslpEventDetails, elements: {
10
- visualBuilderContainer: HTMLDivElement;
11
- resizeObserver: ResizeObserver;
12
- lastEditedField: Element | null;
13
- }): Promise<void>;
11
+ declare function handleIndividualFields(eventDetails: VisualBuilderCslpEventDetails, elements: VisualBuilderEditContext): Promise<void>;
14
12
  declare function cleanIndividualFieldResidual(elements: {
15
13
  overlayWrapper: HTMLDivElement;
16
14
  visualBuilderContainer: HTMLDivElement | null;
@@ -1,16 +1,14 @@
1
1
  import { VisualBuilderCslpEventDetails } from '../types/visualBuilder.types.js';
2
+ import { VisualBuilderEditContext } from './types/index.types.js';
2
3
  import '../../cslp/types/cslp.types.js';
4
+ import '../../cms/types/contentTypeSchema.types.js';
3
5
 
4
6
  /**
5
7
  * It handles all the fields based on their data type and its "multiple" property.
6
8
  * @param eventDetails The event details object that contain cslp and field metadata.
7
9
  * @param elements The elements object that contain the visual builder wrapper.
8
10
  */
9
- declare function handleIndividualFields(eventDetails: VisualBuilderCslpEventDetails, elements: {
10
- visualBuilderContainer: HTMLDivElement;
11
- resizeObserver: ResizeObserver;
12
- lastEditedField: Element | null;
13
- }): Promise<void>;
11
+ declare function handleIndividualFields(eventDetails: VisualBuilderCslpEventDetails, elements: VisualBuilderEditContext): Promise<void>;
14
12
  declare function cleanIndividualFieldResidual(elements: {
15
13
  overlayWrapper: HTMLDivElement;
16
14
  visualBuilderContainer: HTMLDivElement | null;