@flozy/editor 9.8.3 → 9.8.4

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