@flozy/editor 9.5.9 → 9.6.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 (259) hide show
  1. package/dist/Editor/ChatEditor.js +19 -26
  2. package/dist/Editor/CommonEditor.js +23 -139
  3. package/dist/Editor/DialogWrapper.js +25 -31
  4. package/dist/Editor/Editor.css +9 -13
  5. package/dist/Editor/Elements/AI/AIInput.js +3 -5
  6. package/dist/Editor/Elements/AI/CustomSelect.js +5 -9
  7. package/dist/Editor/Elements/AI/PopoverAIInput.js +2 -4
  8. package/dist/Editor/Elements/Accordion/Accordion.js +3 -4
  9. package/dist/Editor/Elements/Accordion/AccordionBtnPopup.js +1 -4
  10. package/dist/Editor/Elements/Accordion/AccordionButton.js +2 -6
  11. package/dist/Editor/Elements/Accordion/AccordionTitlePopup.js +1 -4
  12. package/dist/Editor/Elements/AppHeader/AppHeader.js +3 -3
  13. package/dist/Editor/Elements/AppHeader/AppHeaderButton.js +2 -6
  14. package/dist/Editor/Elements/AppHeader/AppHeaderPopup.js +1 -4
  15. package/dist/Editor/Elements/Attachments/AttachmentsButton.js +1 -4
  16. package/dist/Editor/Elements/Button/ButtonPopup.js +1 -4
  17. package/dist/Editor/Elements/Button/ButtonToolIcon.js +2 -6
  18. package/dist/Editor/Elements/Button/EditorButton.js +14 -31
  19. package/dist/Editor/Elements/Carousel/Carousel.js +4 -5
  20. package/dist/Editor/Elements/Carousel/CarouselButton.js +2 -6
  21. package/dist/Editor/Elements/Carousel/CarouselItem.js +2 -3
  22. package/dist/Editor/Elements/ChipText/ChipTextPopup.js +1 -4
  23. package/dist/Editor/Elements/CodeToText/CodeToText.js +4 -5
  24. package/dist/Editor/Elements/CodeToText/HtmlContextMenu.js +2 -6
  25. package/dist/Editor/Elements/Color Picker/ColorButtons.js +14 -60
  26. package/dist/Editor/Elements/Color Picker/ColorPicker.css +1 -25
  27. package/dist/Editor/Elements/Color Picker/ColorPicker.js +7 -10
  28. package/dist/Editor/Elements/Color Picker/Styles.js +13 -15
  29. package/dist/Editor/Elements/Colorbox/ColorboxButton.js +2 -6
  30. package/dist/Editor/Elements/DataView/DataView.js +2 -5
  31. package/dist/Editor/Elements/DataView/DataViewButton.js +2 -6
  32. package/dist/Editor/Elements/DataView/Layouts/ColumnView.js +2 -7
  33. package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/Select.js +3 -4
  34. package/dist/Editor/Elements/DataView/Layouts/DataTypes/MultiSelectType.js +5 -25
  35. package/dist/Editor/Elements/DataView/Layouts/DataTypes/TextType.js +2 -7
  36. package/dist/Editor/Elements/DataView/Layouts/FilterSort/SortOptions/ChooseSort.js +12 -13
  37. package/dist/Editor/Elements/DataView/Layouts/FilterSort/SortOptions/index.js +4 -7
  38. package/dist/Editor/Elements/DataView/Layouts/FilterSort/index.js +5 -7
  39. package/dist/Editor/Elements/DataView/Layouts/FilterView.js +7 -9
  40. package/dist/Editor/Elements/DataView/Layouts/Options/AddOptions.js +3 -8
  41. package/dist/Editor/Elements/DataView/Layouts/Options/AddProperty.js +3 -5
  42. package/dist/Editor/Elements/DataView/Layouts/Options/AllProperties.js +5 -6
  43. package/dist/Editor/Elements/DataView/Layouts/Options/ChangeProperty.js +3 -5
  44. package/dist/Editor/Elements/DataView/Layouts/Options/EditOption.js +7 -9
  45. package/dist/Editor/Elements/DataView/Layouts/Options/EditProperty.js +38 -64
  46. package/dist/Editor/Elements/DataView/Layouts/Options/FilterProperty.js +2 -3
  47. package/dist/Editor/Elements/DataView/Layouts/Options/PropertyList.js +2 -3
  48. package/dist/Editor/Elements/DataView/Layouts/Options/index.js +6 -23
  49. package/dist/Editor/Elements/DataView/Layouts/TableStyles.js +1 -4
  50. package/dist/Editor/Elements/DataView/Layouts/TableView.js +4 -6
  51. package/dist/Editor/Elements/DataView/Layouts/ViewData.js +4 -8
  52. package/dist/Editor/Elements/DataView/Layouts/index.js +1 -3
  53. package/dist/Editor/Elements/DataView/Providers/DataViewProvider.js +2 -5
  54. package/dist/Editor/Elements/DataView/styles.js +0 -13
  55. package/dist/Editor/Elements/Divider/Divider.js +3 -5
  56. package/dist/Editor/Elements/Divider/DividerButton.js +2 -6
  57. package/dist/Editor/Elements/Divider/DividerPopup.js +2 -3
  58. package/dist/Editor/Elements/Embed/Embed.js +1 -4
  59. package/dist/Editor/Elements/Embed/EmbedPopup.js +1 -4
  60. package/dist/Editor/Elements/Embed/Image.js +9 -14
  61. package/dist/Editor/Elements/Embed/Video.js +6 -9
  62. package/dist/Editor/Elements/EmbedScript/Code.js +4 -7
  63. package/dist/Editor/Elements/EmbedScript/EmbedScript.js +2 -6
  64. package/dist/Editor/Elements/EmbedScript/EmbedScriptPopup.js +5 -8
  65. package/dist/Editor/Elements/Emoji/EmojiButton.js +2 -6
  66. package/dist/Editor/Elements/Form/FieldPopup.js +1 -4
  67. package/dist/Editor/Elements/Form/Form.js +9 -12
  68. package/dist/Editor/Elements/Form/FormButton.js +2 -6
  69. package/dist/Editor/Elements/Form/FormPopup.js +2 -3
  70. package/dist/Editor/Elements/Form/Workflow/FormWorkflow.js +12 -18
  71. package/dist/Editor/Elements/Form/Workflow/ListWorkflow.js +8 -13
  72. package/dist/Editor/Elements/Form/Workflow/MoreOptions.js +2 -3
  73. package/dist/Editor/Elements/Form/Workflow/Styles.js +22 -24
  74. package/dist/Editor/Elements/Form/Workflow/UserInputs.js +2 -4
  75. package/dist/Editor/Elements/Form/Workflow/index.js +9 -15
  76. package/dist/Editor/Elements/FreeGrid/FreeGrid.js +23 -67
  77. package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +4 -23
  78. package/dist/Editor/Elements/FreeGrid/FreeGridButton.js +2 -6
  79. package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +5 -36
  80. package/dist/Editor/Elements/FreeGrid/Options/AddElement.js +2 -3
  81. package/dist/Editor/Elements/FreeGrid/Options/More.js +4 -10
  82. package/dist/Editor/Elements/FreeGrid/styles.js +0 -3
  83. package/dist/Editor/Elements/Grid/Grid.js +10 -13
  84. package/dist/Editor/Elements/Grid/GridButton.js +5 -9
  85. package/dist/Editor/Elements/Grid/GridItem.js +8 -14
  86. package/dist/Editor/Elements/Grid/GridItemPopup.js +1 -4
  87. package/dist/Editor/Elements/Grid/GridPopup.js +1 -4
  88. package/dist/Editor/Elements/Grid/SectionPopup.js +1 -4
  89. package/dist/Editor/Elements/Link/Link.js +5 -8
  90. package/dist/Editor/Elements/Link/LinkButton.js +1 -4
  91. package/dist/Editor/Elements/List/CheckList.js +9 -14
  92. package/dist/Editor/Elements/NewLine/NewLineButton.js +2 -6
  93. package/dist/Editor/Elements/PageSettings/PageSettingsButton.js +1 -4
  94. package/dist/Editor/Elements/PageSettings/PageSettingsPopup.js +1 -4
  95. package/dist/Editor/Elements/Search/SearchButton.js +3 -6
  96. package/dist/Editor/Elements/Search/SearchList.js +3 -7
  97. package/dist/Editor/Elements/Signature/SignatureButton.js +2 -6
  98. package/dist/Editor/Elements/Signature/SignatureOptions/TypeSignature.js +2 -6
  99. package/dist/Editor/Elements/Signature/SignatureOptions/UploadSignature.js +1 -4
  100. package/dist/Editor/Elements/Signature/SignaturePopup.js +16 -17
  101. package/dist/Editor/Elements/SimpleText/index.js +4 -5
  102. package/dist/Editor/Elements/SimpleText/style.js +2 -2
  103. package/dist/Editor/Elements/Table/DragButton.js +2 -4
  104. package/dist/Editor/Elements/Table/Table.js +11 -23
  105. package/dist/Editor/Elements/Table/TableCell.js +24 -2
  106. package/dist/Editor/Elements/Table/TablePopup.js +1 -4
  107. package/dist/Editor/Elements/Table/TableSelector.js +6 -10
  108. package/dist/Editor/Elements/Table/TableTool.js +4 -8
  109. package/dist/Editor/Elements/Title/title.js +0 -10
  110. package/dist/Editor/Elements/TopBanner/TopBannerButton.js +1 -4
  111. package/dist/Editor/Elements/Variables/VariableButton.js +1 -10
  112. package/dist/Editor/MiniEditor.js +3 -10
  113. package/dist/Editor/Styles/EditorStyles.js +5 -5
  114. package/dist/Editor/Toolbar/Basic/index.js +1 -2
  115. package/dist/Editor/Toolbar/FormatTools/BlockButton.js +2 -6
  116. package/dist/Editor/Toolbar/FormatTools/Dropdown.js +3 -27
  117. package/dist/Editor/Toolbar/FormatTools/FontFamilyAutocomplete.js +3 -4
  118. package/dist/Editor/Toolbar/FormatTools/MarkButton.js +4 -8
  119. package/dist/Editor/Toolbar/FormatTools/TextSize.js +13 -10
  120. package/dist/Editor/Toolbar/Mini/MiniToolbar.js +3 -5
  121. package/dist/Editor/Toolbar/PopupTool/AddTemplates.js +5 -10
  122. package/dist/Editor/Toolbar/PopupTool/ButtonTemplatesCard.js +4 -10
  123. package/dist/Editor/Toolbar/PopupTool/FullViewCard.js +4 -10
  124. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/MiniColorPicker.js +3 -9
  125. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectAlignment.js +35 -42
  126. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectFontSize.js +13 -6
  127. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectList.js +51 -58
  128. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectSuperSubscript.js +22 -29
  129. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectTypography.js +87 -226
  130. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +10 -20
  131. package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +5 -10
  132. package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +11 -71
  133. package/dist/Editor/Toolbar/PopupTool/TemplateCard.js +5 -11
  134. package/dist/Editor/Toolbar/PopupTool/TextFormat.js +45 -128
  135. package/dist/Editor/Toolbar/PopupTool/index.js +17 -21
  136. package/dist/Editor/Toolbar/Toolbar.js +10 -20
  137. package/dist/Editor/Toolbar/toolbarGroups.js +6 -48
  138. package/dist/Editor/common/ColorPickerButton.js +14 -39
  139. package/dist/Editor/common/CustomDialog/index.js +10 -8
  140. package/dist/Editor/common/DnD/DragHandleButton.js +1 -1
  141. package/dist/Editor/common/FontLoader/FontLoader.js +0 -3
  142. package/dist/Editor/common/Icon.js +1 -46
  143. package/dist/Editor/common/ImageSelector/ImageSelector.js +8 -10
  144. package/dist/Editor/common/ImageSelector/Options/AddLink.js +4 -6
  145. package/dist/Editor/common/ImageSelector/Options/Upload.js +1 -1
  146. package/dist/Editor/common/ImageSelector/Styles.js +9 -3
  147. package/dist/Editor/common/ImageSelector/UploadStyles.js +9 -9
  148. package/dist/Editor/common/LinkSettings/NavComponents.js +10 -14
  149. package/dist/Editor/common/LinkSettings/index.js +14 -20
  150. package/dist/Editor/common/LinkSettings/navOptions.js +1 -1
  151. package/dist/Editor/common/MentionsPopup/index.js +2 -6
  152. package/dist/Editor/common/RnD/ContextMenu/CMenus.js +22 -22
  153. package/dist/Editor/common/RnD/ContextMenu/index.js +2 -3
  154. package/dist/Editor/common/RnD/ElementOptions/index.js +2 -7
  155. package/dist/Editor/common/RnD/ElementSettings/OtherSettings/SaveAsTemplate.js +3 -8
  156. package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +3 -7
  157. package/dist/Editor/common/RnD/ElementSettings/Settings/AppHeaderSettings.js +2 -3
  158. package/dist/Editor/common/RnD/ElementSettings/Settings/BoxSettings.js +2 -3
  159. package/dist/Editor/common/RnD/ElementSettings/Settings/ButtonSettings.js +2 -3
  160. package/dist/Editor/common/RnD/ElementSettings/Settings/CodeSettings.js +2 -3
  161. package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +4 -7
  162. package/dist/Editor/common/RnD/ElementSettings/Settings/ImageSettings.js +2 -3
  163. package/dist/Editor/common/RnD/ElementSettings/Settings/TableSettings.js +2 -3
  164. package/dist/Editor/common/RnD/ElementSettings/Settings/TextSettings.js +2 -6
  165. package/dist/Editor/common/RnD/ElementSettings/Settings/VideoSettings.js +2 -3
  166. package/dist/Editor/common/RnD/ElementSettings/styles.js +1 -0
  167. package/dist/Editor/common/RnD/OptionsPopup/index.js +3 -4
  168. package/dist/Editor/common/RnD/SwitchViewport/SwitchViewport.js +4 -11
  169. package/dist/Editor/common/RnD/Theme/ViewportStimulator.js +8 -20
  170. package/dist/Editor/common/RnD/Utils/gridDropItem.js +7 -56
  171. package/dist/Editor/common/RnD/Utils/index.js +0 -3
  172. package/dist/Editor/common/RnD/VirtualElement/index.js +105 -188
  173. package/dist/Editor/common/RnD/VirtualElement/styles.js +7 -123
  174. package/dist/Editor/common/RnD/VirtualElement/updateAutoProps.js +3 -5
  175. package/dist/Editor/common/RnD/index.js +14 -59
  176. package/dist/Editor/common/Section/index.js +4 -7
  177. package/dist/Editor/common/Shorthands/elements.js +3 -74
  178. package/dist/Editor/common/StyleBuilder/appHeaderStyle.js +4 -4
  179. package/dist/Editor/common/StyleBuilder/boxStyle.js +2 -2
  180. package/dist/Editor/common/StyleBuilder/buttonStyle.js +4 -6
  181. package/dist/Editor/common/StyleBuilder/dividerStyles.js +2 -2
  182. package/dist/Editor/common/StyleBuilder/embedVideoStyle.js +6 -6
  183. package/dist/Editor/common/StyleBuilder/fieldStyle.js +2 -2
  184. package/dist/Editor/common/StyleBuilder/fieldTypes/alignment.js +9 -13
  185. package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +3 -11
  186. package/dist/Editor/common/StyleBuilder/fieldTypes/bannerSpacing.js +5 -19
  187. package/dist/Editor/common/StyleBuilder/fieldTypes/borderRadius.js +10 -22
  188. package/dist/Editor/common/StyleBuilder/fieldTypes/buttonLink.js +3 -6
  189. package/dist/Editor/common/StyleBuilder/fieldTypes/card.js +13 -27
  190. package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +14 -43
  191. package/dist/Editor/common/StyleBuilder/fieldTypes/elementSize.js +6 -10
  192. package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +6 -19
  193. package/dist/Editor/common/StyleBuilder/fieldTypes/gridSize.js +2 -6
  194. package/dist/Editor/common/StyleBuilder/fieldTypes/icons.js +2 -5
  195. package/dist/Editor/common/StyleBuilder/fieldTypes/menusArray.js +6 -9
  196. package/dist/Editor/common/StyleBuilder/fieldTypes/metaDataMapping.js +2 -8
  197. package/dist/Editor/common/StyleBuilder/fieldTypes/saveAsTemplate.js +11 -12
  198. package/dist/Editor/common/StyleBuilder/fieldTypes/selectBox.js +2 -6
  199. package/dist/Editor/common/StyleBuilder/fieldTypes/text.js +4 -8
  200. package/dist/Editor/common/StyleBuilder/fieldTypes/textAlign.js +2 -6
  201. package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +12 -21
  202. package/dist/Editor/common/StyleBuilder/formStyle.js +7 -7
  203. package/dist/Editor/common/StyleBuilder/gridItemStyle.js +6 -6
  204. package/dist/Editor/common/StyleBuilder/gridStyle.js +5 -5
  205. package/dist/Editor/common/StyleBuilder/index.js +5 -8
  206. package/dist/Editor/common/StyleBuilder/pageSettingsStyle.js +7 -5
  207. package/dist/Editor/common/Uploader.js +5 -16
  208. package/dist/Editor/commonStyle.js +12 -23
  209. package/dist/Editor/helper/index.js +15 -35
  210. package/dist/Editor/helper/theme.js +2 -202
  211. package/dist/Editor/hooks/useDrag.js +11 -17
  212. package/dist/Editor/hooks/useEditorScroll.js +6 -10
  213. package/dist/Editor/hooks/useMouseMove.js +13 -25
  214. package/dist/Editor/hooks/useTable.js +1 -1
  215. package/dist/Editor/plugins/withEmbeds.js +1 -1
  216. package/dist/Editor/plugins/withHTML.js +9 -11
  217. package/dist/Editor/plugins/withLayout.js +2 -3
  218. package/dist/Editor/plugins/withTable.js +1 -1
  219. package/dist/Editor/theme/ThemeList.js +173 -50
  220. package/dist/Editor/utils/SlateUtilityFunctions.js +49 -168
  221. package/dist/Editor/utils/draftToSlate.js +2 -3
  222. package/dist/Editor/utils/font.js +37 -40
  223. package/dist/Editor/utils/freegrid.js +2 -2
  224. package/dist/Editor/utils/helper.js +19 -90
  225. package/package.json +3 -3
  226. package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/MultiSelect.js +0 -425
  227. package/dist/Editor/Toolbar/PopupTool/ThemeTextFormat.js +0 -436
  228. package/dist/Editor/assets/svg/ClearAllRounded.js +0 -31
  229. package/dist/Editor/assets/svg/ThemeIcons.js +0 -291
  230. package/dist/Editor/common/CustomColorPicker/index.js +0 -131
  231. package/dist/Editor/common/CustomColorPicker/style.js +0 -53
  232. package/dist/Editor/common/CustomDialog2/index.js +0 -94
  233. package/dist/Editor/common/CustomDialog2/style.js +0 -67
  234. package/dist/Editor/common/CustomSelect.js +0 -43
  235. package/dist/Editor/common/RnD/Theme/MainThemeProvider.js +0 -17
  236. package/dist/Editor/common/RnD/VirtualElement/ForceAutoAlignment.js +0 -117
  237. package/dist/Editor/common/RnD/VirtualElement/VirtualTextElement.js +0 -134
  238. package/dist/Editor/common/RnD/VirtualElement/helper.js +0 -281
  239. package/dist/Editor/common/SnackBar/index.js +0 -43
  240. package/dist/Editor/helper/textIndeces.js +0 -58
  241. package/dist/Editor/hooks/useAutoScroll.js +0 -38
  242. package/dist/Editor/hooks/useEditorTheme.js +0 -153
  243. package/dist/Editor/hooks/useThemeValues.js +0 -63
  244. package/dist/Editor/theme/index.js +0 -149
  245. package/dist/Editor/themeSettings/ActiveTheme.js +0 -72
  246. package/dist/Editor/themeSettings/buttons/index.js +0 -290
  247. package/dist/Editor/themeSettings/buttons/style.js +0 -23
  248. package/dist/Editor/themeSettings/colorTheme/index.js +0 -310
  249. package/dist/Editor/themeSettings/colorTheme/style.js +0 -81
  250. package/dist/Editor/themeSettings/fonts/PreviewElement.js +0 -121
  251. package/dist/Editor/themeSettings/fonts/index.js +0 -240
  252. package/dist/Editor/themeSettings/fonts/style.js +0 -61
  253. package/dist/Editor/themeSettings/icons.js +0 -60
  254. package/dist/Editor/themeSettings/index.js +0 -351
  255. package/dist/Editor/themeSettings/style.js +0 -220
  256. package/dist/Editor/themeSettingsAI/icons.js +0 -96
  257. package/dist/Editor/themeSettingsAI/index.js +0 -355
  258. package/dist/Editor/themeSettingsAI/saveTheme.js +0 -205
  259. package/dist/Editor/themeSettingsAI/style.js +0 -259
@@ -1,7 +1,6 @@
1
- import { Transforms, Node, Path, Editor } from "slate";
1
+ import { Transforms, Node, Path } from "slate";
2
2
  import { ReactEditor } from "slate-react";
3
3
  import { handleNegativeInteger } from "../../../utils/helper";
4
- import { handleBoxAlignment } from "../VirtualElement/helper";
5
4
  export const ROW_HEIGHT = 50;
6
5
 
7
6
  // const MARGIN_OF = {
@@ -22,18 +21,9 @@ export function updateRows() {}
22
21
  export function updateCols() {}
23
22
  const handleMoveNode = (editor, path, newPath, {
24
23
  isEmpty
25
- }, autoAlign) => {
24
+ }) => {
26
25
  try {
27
- let replaceNode = Node.get(editor, path);
28
- if (autoAlign) {
29
- // reset node for auto alignment in mobile
30
- replaceNode = {
31
- ...replaceNode,
32
- gridArea_xs: null,
33
- xs_updatedOn: null,
34
- marginTop_xs: null
35
- };
36
- }
26
+ const replaceNode = Node.get(editor, path);
37
27
  if (isEmpty) {
38
28
  const toPath = [...newPath, 0];
39
29
  Transforms.insertNodes(editor, [{
@@ -67,10 +57,9 @@ const handleMoveNode = (editor, path, newPath, {
67
57
  * This method will update prop in child node so it will re-render and update the path
68
58
  * @param {*} path - contains the parent section path
69
59
  */
70
- export const reRenderChildNodes = (editor, path) => {
60
+ const reRenderChildNodes = (editor, path) => {
71
61
  try {
72
62
  const sectionNode = Node.get(editor, path);
73
-
74
63
  // parent node
75
64
  Transforms.setNodes(editor, {
76
65
  updated_at: new Date().getTime()
@@ -138,9 +127,6 @@ function isContainerElement(editor, moveTopath, props, appenBp) {
138
127
  console.log(err);
139
128
  }
140
129
  }
141
- const isInsidePath = (from, moveTo) => {
142
- return Path.isAncestor(from, moveTo);
143
- };
144
130
  export function onDropItem(props, parentClass) {
145
131
  try {
146
132
  const {
@@ -188,17 +174,7 @@ export function onDropItem(props, parentClass) {
188
174
  }, {
189
175
  at: path
190
176
  });
191
- let reRenderSectionPath;
192
- const [sectionData] = Editor.nodes(editor, {
193
- at: moveTo,
194
- match: n => n.type === "freegrid"
195
- });
196
- const [sectionNode, sectionPath] = sectionData || [];
197
- if (needMove && isInsidePath(from, moveTo)) {
198
- reRenderSectionPath = sectionPath;
199
- } else {
200
- reRenderChildNodes(editor, from);
201
- }
177
+ reRenderChildNodes(editor, from);
202
178
 
203
179
  // move the node if section parent changed
204
180
  if (needMove) {
@@ -207,35 +183,10 @@ export function onDropItem(props, parentClass) {
207
183
  if (!isEmpty) {
208
184
  newPath = [...newPath, toSectionNode?.children?.length];
209
185
  }
210
- const moveSectionToSection = from?.length === 2 && moveTo?.length === 2;
211
-
212
- // const autoAlign = breakpoint === "lg" && moveSectionToSection;
213
- const autoAlign = breakpoint === "lg";
214
-
215
- // const boxNode = Node.get(editor, moveTo);
216
-
217
- if (moveTo?.length === 2 && autoAlign) {
218
- // auto align in mobile
219
- Transforms.setNodes(editor, {
220
- xs_updatedOn: null
221
- }, {
222
- at: moveTo
223
- });
224
- } else if (autoAlign) {
225
- Transforms.setNodes(editor, {
226
- autoAlign: true,
227
- xs_updatedOn: new Date().getTime()
228
- }, {
229
- at: moveTo
230
- });
231
- }
232
186
  const rPath = handleMoveNode(editor, path, newPath, {
233
187
  isEmpty
234
- }, autoAlign);
235
- reRenderChildNodes(editor, reRenderSectionPath || moveTo);
236
- if (autoAlign) {
237
- handleBoxAlignment(editor, sectionNode, sectionPath);
238
- }
188
+ });
189
+ reRenderChildNodes(editor, moveTo);
239
190
  return {
240
191
  updated_at: rPath
241
192
  };
@@ -293,7 +293,4 @@ export function getAbsolutePositionY(currentEle) {
293
293
  gridArea,
294
294
  marginTop
295
295
  };
296
- }
297
- export function getPathFromElement(element) {
298
- return element?.dataset.path?.split("|").map(m => parseInt(m));
299
296
  }
@@ -1,235 +1,152 @@
1
- import React, { useEffect, useMemo, useRef, useState } from "react";
1
+ import React, { useEffect, useRef } from "react";
2
2
  import { Box } from "@mui/material";
3
3
  import useVirtualElementStyles from "./styles";
4
4
  import updateAutoProps from "./updateAutoProps";
5
- import { ROW_HEIGHT, calculateGridArea } from "../Utils/gridDropItem";
5
+ import { calculateGridArea } from "../Utils/gridDropItem";
6
6
  import { jsx as _jsx } from "react/jsx-runtime";
7
7
  const ROOT_ITEM_CLASS = ".freegrid-item.path-3";
8
- export function getStartRow(el) {
9
- const gridArea = el.dataset.gridAreaXs;
10
- if (gridArea) {
11
- const [startRow] = gridArea.split("/").map(num => parseInt(num));
12
- return startRow;
13
- }
14
- }
15
- function appendGridOccupied(domItem, startRow, fullHeight, lastRow) {
16
- const endRow = startRow + Math.floor(fullHeight / ROW_HEIGHT) + 1;
17
- lastRow = Math.max(endRow, lastRow);
18
- const gridArea = `${startRow}/1/${endRow}/2`;
19
- domItem.style.setProperty("--gridArea_xs", gridArea);
20
- domItem.dataset.gridAreaXs = gridArea;
21
- domItem.classList.add("exclude-virtual");
22
- return {
23
- domItem,
24
- updatedLastRow: lastRow,
25
- gridArea
26
- };
27
- }
28
8
 
29
9
  // Function to group items by path and calculate heights
30
- // function groupByPathAndCalculateHeight(allData) {
31
- // const data = JSON.parse(JSON.stringify([...allData]));
32
- // const root = {};
33
- // const heightData = {};
34
-
35
- // // Step 1: Group items based on their path
36
- // data.forEach((item) => {
37
- // const segments = item.path.split("|");
38
- // let current = root;
39
-
40
- // segments.forEach((segment, index) => {
41
- // if (!current[segment]) {
42
- // current[segment] = { children: {}, props: { height: 0 } };
43
- // }
44
-
45
- // if (index === segments.length - 1) {
46
- // // Assign the properties of the item including height
47
- // current[segment] = { ...item, children: current[segment].children };
48
- // }
49
-
50
- // current = current[segment].children;
51
- // });
52
- // });
53
-
54
- // // Step 2: Recursively calculate the height of each parent based on children
55
- // const calculateHeight = (node) => {
56
- // if (!node.children || Object.keys(node.children).length === 0) {
57
- // // Base case: If there are no children, return the node's height
58
- // return node.props.height;
59
- // }
60
-
61
- // // Calculate the height by summing the heights of all children
62
- // let totalHeight = 0;
63
- // Object.values(node.children).forEach((child) => {
64
- // totalHeight += calculateHeight(child);
65
- // });
10
+ function groupByPathAndCalculateHeight(data) {
11
+ const root = {};
12
+ const heightData = {};
13
+
14
+ // Step 1: Group items based on their path
15
+ data.forEach(item => {
16
+ const segments = item.path.split("|");
17
+ let current = root;
18
+ segments.forEach((segment, index) => {
19
+ if (!current[segment]) {
20
+ current[segment] = {
21
+ children: {},
22
+ props: {
23
+ height: 0
24
+ }
25
+ };
26
+ }
27
+ if (index === segments.length - 1) {
28
+ // Assign the properties of the item including height
29
+ current[segment] = {
30
+ ...item,
31
+ children: current[segment].children
32
+ };
33
+ }
34
+ current = current[segment].children;
35
+ });
36
+ });
66
37
 
67
- // // Update the parent's height to be the total height of its children
68
- // node.props.height = totalHeight;
69
- // if (node?.path) {
70
- // heightData[node.path] = totalHeight;
71
- // }
72
- // return totalHeight;
73
- // };
38
+ // Step 2: Recursively calculate the height of each parent based on children
39
+ const calculateHeight = node => {
40
+ if (!node.children || Object.keys(node.children).length === 0) {
41
+ // Base case: If there are no children, return the node's height
42
+ return node.props.height;
43
+ }
74
44
 
75
- // // Start calculation from the root
76
- // Object.values(root).forEach((node) => calculateHeight(node));
45
+ // Calculate the height by summing the heights of all children
46
+ let totalHeight = 0;
47
+ Object.values(node.children).forEach(child => {
48
+ totalHeight += calculateHeight(child);
49
+ });
77
50
 
78
- // return { root, heightData };
79
- // }
51
+ // Update the parent's height to be the total height of its children
52
+ node.props.height = totalHeight;
53
+ if (node?.path) {
54
+ heightData[node.path] = totalHeight;
55
+ }
56
+ return totalHeight;
57
+ };
80
58
 
81
- const handleGridItem = (dom, lastRow) => {
82
- const startRow = getStartRow(dom);
83
- const {
84
- marginTopXs,
85
- heightXs
86
- } = dom.dataset;
87
- const marginTop = marginTopXs ? Number(marginTopXs) : 0;
88
- const fullHeight = Number(heightXs) + marginTop;
89
- return appendGridOccupied(dom, startRow, fullHeight, lastRow);
90
- };
91
- const handleNonGridItem = (dom, lastRow) => {
92
- const rect = dom.getBoundingClientRect();
93
- dom.style.setProperty("--height_xs", rect.height + "px"); // assign the auto height that taken
94
- const startRow = lastRow || 1;
95
- const DEFAULT_NEW_ELEMENT_MARGIN_TOP = 12;
96
- let fullHeight = rect.height + DEFAULT_NEW_ELEMENT_MARGIN_TOP;
97
- const gridOccupiedData = appendGridOccupied(dom, startRow, fullHeight, lastRow);
59
+ // Start calculation from the root
60
+ Object.values(root).forEach(node => calculateHeight(node));
98
61
  return {
99
- ...gridOccupiedData,
100
- fullHeight
62
+ root,
63
+ heightData
101
64
  };
102
- };
103
- const appendContainerItems = async (sectionCls, virtualRef, dataSets) => {
104
- const cloneNode = document.querySelector(sectionCls)?.cloneNode(true);
105
- const items = cloneNode?.querySelectorAll(ROOT_ITEM_CLASS) || [];
106
- if (!cloneNode || !items?.length || !virtualRef.current) {
107
- return;
108
- }
109
-
110
- // Remove all existing elements inside virtualRef.current
111
- virtualRef.current.innerHTML = "";
112
- virtualRef.current.style.height = `auto`;
113
- virtualRef.current.style.gridTemplateRows = `unset`;
114
-
115
- // temporary append section items to get the dom styles
116
- virtualRef.current.append(...items);
117
- let itemsHTML = "";
118
- let lastRow = 0;
119
- const gridItems = [];
120
- const nonGridItems = [];
121
- items.forEach(item => {
122
- if (getStartRow(item)) {
123
- gridItems.push(item);
124
- } else {
125
- nonGridItems.push(item);
126
- }
127
- });
128
-
129
- // to find the previously occupied rows
130
- gridItems.forEach(item => {
131
- const {
132
- updatedLastRow,
133
- domItem
134
- } = handleGridItem(item, lastRow);
135
- lastRow = updatedLastRow;
136
- itemsHTML += domItem.outerHTML;
137
- });
138
- let containerHeight = lastRow ? (lastRow - 1) * ROW_HEIGHT : 0;
139
-
140
- //place it on the next rows that are available
141
- nonGridItems.forEach(item => {
142
- const {
143
- domItem,
144
- updatedLastRow,
145
- fullHeight
146
- } = handleNonGridItem(item, lastRow);
147
- lastRow = updatedLastRow;
148
- itemsHTML += domItem.outerHTML;
149
- containerHeight += fullHeight;
150
- });
151
- const oldSectionHeight = dataSets["data-height-xs"];
152
- const newHeight = oldSectionHeight && oldSectionHeight > containerHeight ? oldSectionHeight : containerHeight;
153
- virtualRef.current.style.height = `${newHeight}px`;
154
- virtualRef.current.style.gridTemplateRows = `repeat(${lastRow - 1}, ${ROW_HEIGHT}px)`;
155
- virtualRef.current.innerHTML = itemsHTML;
156
- };
65
+ }
157
66
  const VirtualElement = props => {
158
67
  const classes = useVirtualElementStyles();
159
68
  const {
160
69
  editor,
161
70
  path,
162
- updated_at,
163
- sectionCls,
164
- dataSets
71
+ parentEle,
72
+ updated_at
165
73
  } = props;
74
+ const cloneNode = parentEle?.cloneNode(true);
166
75
  const virtualRef = useRef();
167
- const [toggleUpdate, setToggleUpdate] = useState(false);
168
76
  useEffect(() => {
169
77
  if (virtualRef?.current) {
170
- setTimeout(() => {
78
+ const timeoutId = setTimeout(() => {
171
79
  const allData = calculateProps(path, virtualRef?.current, ROOT_ITEM_CLASS, []);
172
- // const groupData = groupByPathAndCalculateHeight(allData);
173
- // console.log("allData", allData);
80
+ const groupData = groupByPathAndCalculateHeight(allData);
174
81
  // it should trigger by auto alignment or on clicking mobile view change
175
- updateAutoProps(editor, allData, "xs");
82
+ updateAutoProps(editor, allData, "xs", groupData);
176
83
  }, 100);
177
- setToggleUpdate(prev => !prev);
84
+ return () => clearTimeout(timeoutId);
178
85
  }
179
86
  }, [updated_at, virtualRef?.current]);
180
87
  const calculateProps = (curPath, dom, domClass, allData) => {
181
88
  const rect = dom?.getBoundingClientRect();
182
-
183
- // const sectionRect = virtualRef?.current?.getBoundingClientRect();
184
-
185
- const bufferHeight = 12; // for spacing
186
-
89
+ const sectionRect = virtualRef?.current?.getBoundingClientRect();
187
90
  const sectionProps = {
188
91
  path: curPath,
189
92
  props: {
190
- height: rect?.height + bufferHeight
93
+ height: rect?.height
191
94
  }
192
95
  };
193
96
  const itemsData = [];
194
- const items = dom ? dom.querySelectorAll(domClass) : [];
97
+ const items = dom.querySelectorAll(domClass);
98
+ const nextItemPathLength = curPath?.split("|").length + 2;
99
+ let sectionHeight = 12;
195
100
  for (let i = 0; i < items.length; i++) {
196
- const item = items[i];
197
- const itemRect = item?.getBoundingClientRect();
198
- const {
199
- path
200
- } = item?.dataset;
201
- const y = Math.abs(rect.top - itemRect?.top);
202
- itemsData.push({
203
- path,
204
- props: {
205
- top: y,
206
- left: 24,
207
- marginTop: 12,
208
- width: itemRect?.width,
209
- height: itemRect?.height,
210
- gridArea: calculateGridArea(y)
211
- }
212
- });
101
+ const itemRect = items[i]?.getBoundingClientRect();
102
+ if (items[i]?.classList.contains("type_box")) {
103
+ allData = calculateProps(items[i]?.dataset.path, items[i], `.freegrid-item.path-${nextItemPathLength}`, allData);
104
+ } else {
105
+ const y = Math.abs(rect.top - itemRect?.top);
106
+ itemsData.push({
107
+ path: items[i]?.dataset.path,
108
+ props: {
109
+ top: y,
110
+ left: 24,
111
+ marginTop: 12,
112
+ width: itemRect?.width,
113
+ height: itemRect?.height,
114
+ gridArea: calculateGridArea(y)
115
+ }
116
+ });
117
+ sectionHeight += itemRect?.height;
118
+ }
119
+ }
120
+ if (dom?.classList.contains("type_box")) {
121
+ const y = Math.abs(sectionRect.top - rect?.top);
122
+ sectionProps.props.gridArea = calculateGridArea(y);
123
+ }
124
+ if (sectionHeight > sectionProps?.props?.height) {
125
+ sectionProps.props.height = sectionHeight;
213
126
  }
214
127
  allData = [sectionProps, [...allData, ...itemsData]]?.flat();
215
128
  return allData;
216
129
  };
217
- useMemo(() => {
218
- return appendContainerItems(sectionCls, virtualRef, dataSets);
219
- }, [toggleUpdate]);
130
+ const getItems = () => {
131
+ const items = cloneNode?.querySelectorAll(ROOT_ITEM_CLASS) || [];
132
+ let itemsHTML = "";
133
+ for (let i = 0; i < items?.length; i++) {
134
+ items[i].classList.add("exclude-virtual");
135
+ itemsHTML += items[i].outerHTML;
136
+ }
137
+ return itemsHTML;
138
+ };
220
139
  return /*#__PURE__*/_jsx(Box, {
221
140
  className: "mobile-virtual-mode",
222
141
  ref: virtualRef,
223
- sx: {
224
- display: "grid",
225
- gridTemplateColumns: "100%",
226
- visibility: "hidden",
227
- // height: `${containerHeight}px !important`,
228
- // gridTemplateRows: `repeat(${lastRow - 1}, ${ROW_HEIGHT}px)`,
229
- ...classes.root
142
+ sx: classes.root,
143
+ dangerouslySetInnerHTML: {
144
+ __html: getItems()
145
+ },
146
+ style: {
147
+ visibility: "hidden"
230
148
  },
231
- "aria-hidden": "true",
232
- contentEditable: false
149
+ "aria-hidden": "true"
233
150
  });
234
151
  };
235
152
  export default VirtualElement;
@@ -2,137 +2,20 @@ const useVirtualElementStyles = () => ({
2
2
  root: {
3
3
  width: "320px",
4
4
  position: "fixed",
5
- // backgroundColor: "red",
6
- // height: "fit-content",
5
+ backgroundColor: "red",
6
+ height: "auto",
7
7
  overflow: "visible",
8
8
  pointerEvents: "none",
9
- opacity: 1,
9
+ opacity: 0,
10
10
  right: 0,
11
11
  top: 0,
12
- "& .leaf-item": {
13
- fontSize: "var(--fontSize_xs) !important",
14
- "& span": {
15
- fontSize: "var(--fontSize_xs) !important"
16
- }
17
- },
18
- "& .editor-blocker": {
19
- display: "none"
20
- },
21
12
  "& .freegrid-item": {
22
13
  position: "relative !important",
23
- top: "0 !important",
24
- gridArea: "var(--gridArea_xs) !important",
25
- width: "calc(100% - 48px) !important",
26
- height: "var(--height_xs) !important",
27
- left: "24px !important",
28
- marginTop: "var(--marginTop_xs) !important",
29
- outline: "1px solid gray !important",
30
- "&.type_text": {
31
- height: "auto !important"
32
- },
33
- // "&.type_box": {
34
- // // display: "grid !important",
35
- // // gridTemplateRows: "repeat(auto-fill, 50px) !important",
36
- // // height: "min-content !important",
37
- // },
38
-
39
- "& .debug-info, & .editor-blocker": {
40
- display: "none"
41
- },
42
- "& .embed": {
43
- minHeight: "300px"
44
- }
45
- }
46
- }
47
- });
48
- export default useVirtualElementStyles;
49
- export const useAutoAlignStyles = () => ({
50
- root: {
51
- width: "320px",
52
- position: "fixed",
53
- overflow: "visible",
54
- opacity: 1,
55
- right: 0,
56
- top: 0,
57
- height: "auto !important",
58
- pointerEvents: "none",
59
- "& .leaf-item": {
60
- fontSize: "var(--fontSize_xs) !important",
61
- "& span": {
62
- fontSize: "var(--fontSize_xs) !important"
63
- }
64
- },
65
- "& .editor-blocker": {
66
- display: "none"
67
- },
68
- "& .freegrid-item": {
69
- position: "relative !important",
70
- top: "0 !important",
71
14
  gridArea: "none !important",
72
15
  width: "calc(100% - 48px) !important",
73
- height: "var(--height_xs) !important",
16
+ height: "auto !important",
74
17
  left: "24px !important",
75
- marginTop: "12px !important",
76
- minHeight: "auto",
77
- display: "inherit !important",
78
- "&.type_box": {
79
- height: "auto !important"
80
- },
81
- "&.type_image": {
82
- width: "var(--width_xs) !important",
83
- height: "var(--height_xs) !important"
84
- },
85
- "&.type_text": {
86
- height: "auto !important"
87
- },
88
- // start - default signature classes on free-grid
89
- "& .fgi_type_signature": {
90
- height: "100%",
91
- "& .signature-container": {
92
- height: "100%",
93
- LineHeight: 1.43,
94
- "& .signature-btn-container": {
95
- height: "100%",
96
- display: "flex",
97
- flexDirection: "column",
98
- "& .sign-placeholder": {
99
- display: "flex",
100
- // remove hidden sign placeholder
101
- width: "100%",
102
- flexGrow: 1
103
- },
104
- "& button": {
105
- margin: "6px 0px"
106
- }
107
- }
108
- }
109
- },
110
- "& .fgi_type_sign": {
111
- width: "100%",
112
- height: "100%",
113
- "& .signature-signed-wrapper": {
114
- width: "100%",
115
- height: "100%",
116
- "& .signature-signed-span": {
117
- width: "100%",
118
- height: "100%",
119
- "& .signed-btn": {
120
- width: "100%",
121
- height: "100%",
122
- display: "flex",
123
- flexDirection: "column",
124
- "& img": {
125
- width: "100% !important",
126
- maxWidth: "none !important",
127
- height: "70% !important",
128
- flexGrow: 1
129
- }
130
- }
131
- }
132
- }
133
- },
134
- // end - default signature classes on free-grid
135
-
18
+ marginTop: "24px !important",
136
19
  "& .debug-info, & .editor-blocker": {
137
20
  display: "none"
138
21
  },
@@ -141,4 +24,5 @@ export const useAutoAlignStyles = () => ({
141
24
  }
142
25
  }
143
26
  }
144
- });
27
+ });
28
+ export default useVirtualElementStyles;
@@ -1,5 +1,5 @@
1
1
  import { Node, Transforms } from "slate";
2
- const updateAutoProps = (editor, datas = [], breakpoint = "", updateAll) => {
2
+ const updateAutoProps = (editor, datas = [], breakpoint = "", groupData) => {
3
3
  try {
4
4
  // const { heightData } = groupData;
5
5
  for (let i = 0; i < datas.length; i++) {
@@ -14,11 +14,9 @@ const updateAutoProps = (editor, datas = [], breakpoint = "", updateAll) => {
14
14
  return a;
15
15
  }, {});
16
16
  const oldProps = Node.get(editor, int_path);
17
- const updateNode = !oldProps?.xs_updatedOn || updateAll;
18
- if (updateNode) {
17
+ if (!oldProps?.xs_updatedOn) {
19
18
  Transforms.setNodes(editor, {
20
- ...updatedProps,
21
- xs_updatedOn: new Date().getTime()
19
+ ...updatedProps
22
20
  }, {
23
21
  at: int_path
24
22
  });