@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
@@ -19,10 +19,6 @@ import { removeSign } from "./ElementSettings/OtherSettings";
19
19
  import useDragging from "../../hooks/useDragging";
20
20
  import { dragOverOn } from "../../helper/RnD/focusNode";
21
21
  import { focusSelection, clearSelection, clearSelectionOnly } from "../../helper";
22
- import { reRenderChildNodes } from "./Utils/gridDropItem";
23
- import VirtualTextElement from "./VirtualElement/VirtualTextElement";
24
- import useAutoScroll from "../../hooks/useAutoScroll";
25
- import ForceAutoAlignment from "./VirtualElement/ForceAutoAlignment";
26
22
  import { jsx as _jsx } from "react/jsx-runtime";
27
23
  import { jsxs as _jsxs } from "react/jsx-runtime";
28
24
  import { Fragment as _Fragment } from "react/jsx-runtime";
@@ -68,12 +64,7 @@ const RnD = props => {
68
64
  editor,
69
65
  breakpoint = "",
70
66
  handleContextMenuClick = () => {},
71
- itemData = {},
72
- customProps,
73
- sectionElement,
74
- dataSets,
75
- autoAlign,
76
- setAutoAlign
67
+ itemData = {}
77
68
  } = props;
78
69
  const {
79
70
  isSelectedElement,
@@ -115,13 +106,6 @@ const RnD = props => {
115
106
  y: 0
116
107
  });
117
108
  const parentSectionPath = str_path?.split("|").slice(0, 2).join("_");
118
- const {
119
- translation
120
- } = customProps;
121
- const {
122
- startAutoScroll,
123
- stopAutoScroll
124
- } = useAutoScroll(10, "slate-wrapper-scroll-container");
125
109
  useEffect(() => {
126
110
  if (ITEM_TYPES.includes(type)) {
127
111
  if (enable === 1) {
@@ -363,16 +347,6 @@ const RnD = props => {
363
347
  };
364
348
  const onDrag = e => {
365
349
  e.preventDefault();
366
- const {
367
- clientY
368
- } = e;
369
- if (clientY < 50) {
370
- startAutoScroll("up");
371
- } else if (window.innerHeight - clientY < 50) {
372
- startAutoScroll("down");
373
- } else {
374
- stopAutoScroll();
375
- }
376
350
  const lines = getClosestDraggable(e.clientX, e.clientY, `.freegrid-section_${parentSectionPath} .freegrid-container .freegrid-item.inactive-drag`.replace(/\|/g, "\\|"), ".freegrid-item.active-drag:not(.exclude-virtual)");
377
351
  setAbsPosition({
378
352
  ...absPosition,
@@ -415,7 +389,6 @@ const RnD = props => {
415
389
  const onDragStop = (e, d) => {
416
390
  e.preventDefault();
417
391
  e.stopPropagation();
418
- stopAutoScroll();
419
392
  if (dragging?.isDragging === 2 && dragging?.position?.strXY && dragging?.dragOver) {
420
393
  d.x = e.x;
421
394
  d.y = e.y;
@@ -476,18 +449,13 @@ const RnD = props => {
476
449
  }
477
450
  const updatedSize = {
478
451
  width: delta?.width + d.width,
479
- height: ref.offsetHeight,
452
+ height: delta?.height + d.height,
480
453
  ...updatedPosition
481
454
  };
482
455
  onChange({
483
456
  ...updatedSize
484
457
  });
485
458
  handleResizeEvent("stop");
486
- const parentPath = getParentSectionPath({
487
- ref
488
- }, ".freegrid-container-parent");
489
- const formatParentPath = parentPath?.split("|")?.map(m => parseInt(m));
490
- reRenderChildNodes(editor, formatParentPath);
491
459
  };
492
460
  const onCloseSettings = () => {
493
461
  setSelectedElement({
@@ -502,6 +470,13 @@ const RnD = props => {
502
470
  }
503
471
  e.preventDefault();
504
472
  e.stopPropagation();
473
+ const isMuiBackdrop = e.target.classList.contains("MuiBackdrop-root");
474
+ if (isMuiBackdrop) {
475
+ setContextMenu({
476
+ path: null
477
+ });
478
+ return;
479
+ }
505
480
  onClick({
506
481
  detail: 1
507
482
  });
@@ -555,7 +530,7 @@ const RnD = props => {
555
530
  return /*#__PURE__*/_jsxs(_Fragment, {
556
531
  children: [/*#__PURE__*/_jsxs(Box, {
557
532
  component: Rnd,
558
- placeholder: translation(ItemTypes[childType]) || translation("Item"),
533
+ placeholder: ItemTypes[childType] || "Item",
559
534
  id: eId || "",
560
535
  ref: c => {
561
536
  positionRef.current = c;
@@ -589,7 +564,6 @@ const RnD = props => {
589
564
  ...DISABLE_RESIZING
590
565
  },
591
566
  ...getEventProps(),
592
- ...(dataSets || {}),
593
567
  children: [/*#__PURE__*/_jsx("div", {
594
568
  id: `opt_ref_${str_path}`,
595
569
  style: {
@@ -623,9 +597,7 @@ const RnD = props => {
623
597
  optionsProps: optionsProps,
624
598
  selectedAction: currentAction,
625
599
  path: str_path,
626
- theme: theme,
627
- translation: translation,
628
- customProps: customProps
600
+ theme: theme
629
601
  }) : null, /*#__PURE__*/_jsx(ElementSettings, {
630
602
  open: Boolean(currentAction),
631
603
  currentAction: currentAction,
@@ -659,29 +631,12 @@ const RnD = props => {
659
631
  open: openContextMenu,
660
632
  contextMenu: contextMenu,
661
633
  handleClose: handleClose,
662
- theme: theme,
663
- translation: translation
634
+ theme: theme
664
635
  }), type === "parent" && breakpoint === "lg" && !readOnly ? /*#__PURE__*/_jsx(VirtualElement, {
636
+ parentEle: positionRef?.current?.resizableElement?.current,
665
637
  updated_at: updated_at,
666
638
  path: str_path,
667
- editor: editor,
668
- sectionElement: sectionElement,
669
- sectionCls: `.freegrid-section_${path.join("_")}`,
670
- dataSets: dataSets
671
- }) : null, childType === "text" && breakpoint === "lg" && !readOnly && enable ? /*#__PURE__*/_jsx(VirtualTextElement, {
672
- editor: editor,
673
- dataSets: dataSets,
674
- getCurrentEle: getCurrentEle,
675
- path: path
676
- }) : null, type === "parent" && breakpoint === "xs" && !readOnly && autoAlign ? /*#__PURE__*/_jsx(ForceAutoAlignment, {
677
- updated_at: updated_at,
678
- path: str_path,
679
- editor: editor,
680
- sectionElement: sectionElement,
681
- sectionCls: `.freegrid-section_${path.join("_")}`,
682
- dataSets: dataSets,
683
- autoAlign: autoAlign,
684
- setAutoAlign: setAutoAlign
639
+ editor: editor
685
640
  }) : null]
686
641
  });
687
642
  };
@@ -19,8 +19,7 @@ const Toolbar = ({
19
19
  readOnly,
20
20
  showTool,
21
21
  onSettings,
22
- isSectionFullWidth,
23
- translation
22
+ isSectionFullWidth
24
23
  }) => {
25
24
  return !readOnly && !showTool ? /*#__PURE__*/_jsx(Box, {
26
25
  component: "div",
@@ -34,7 +33,7 @@ const Toolbar = ({
34
33
  }
35
34
  },
36
35
  children: /*#__PURE__*/_jsx(Tooltip, {
37
- title: translation("Section Settings"),
36
+ title: "Section Settings",
38
37
  children: /*#__PURE__*/_jsx(IconButton, {
39
38
  onClick: onSettings,
40
39
  children: /*#__PURE__*/_jsx(SectionSettingIcon, {})
@@ -52,8 +51,7 @@ const Section = props => {
52
51
  customProps
53
52
  } = props;
54
53
  const {
55
- readOnly,
56
- translation
54
+ readOnly
57
55
  } = customProps;
58
56
  const editor = useSlateStatic();
59
57
  // const [isHovering, setIsHovering] = useState(false);
@@ -178,8 +176,7 @@ const Section = props => {
178
176
  isSectionFullWidth: isSectionFullWidth,
179
177
  readOnly: readOnly,
180
178
  showTool: false,
181
- onSettings: onSettings,
182
- translation: translation
179
+ onSettings: onSettings
183
180
  }), children]
184
181
  }), openSetttings ? /*#__PURE__*/_jsx(SectionPopup, {
185
182
  element: {
@@ -44,60 +44,6 @@ const ELEMENTS_LIST = [{
44
44
  icon: "headingThree"
45
45
  }),
46
46
  onInsert: editor => toggleBlock(editor, "headingThree", false)
47
- }, {
48
- name: "Heading 4",
49
- desc: "",
50
- group: "Text",
51
- type: "headingFour",
52
- icon: /*#__PURE__*/_jsx(Icon, {
53
- icon: "headingFour"
54
- }),
55
- onInsert: editor => toggleBlock(editor, "headingFour", false)
56
- }, {
57
- name: "Heading 5",
58
- desc: "",
59
- group: "Text",
60
- type: "headingFive",
61
- icon: /*#__PURE__*/_jsx(Icon, {
62
- icon: "headingFive"
63
- }),
64
- onInsert: editor => toggleBlock(editor, "headingFive", false)
65
- }, {
66
- name: "Heading 6",
67
- desc: "",
68
- group: "Text",
69
- type: "headingSix",
70
- icon: /*#__PURE__*/_jsx(Icon, {
71
- icon: "headingSix"
72
- }),
73
- onInsert: editor => toggleBlock(editor, "headingSix", false)
74
- }, {
75
- name: "Paragraph 1",
76
- desc: "",
77
- group: "Text",
78
- type: "paragraphOne",
79
- icon: /*#__PURE__*/_jsx(Icon, {
80
- icon: "paragraphOne"
81
- }),
82
- onInsert: editor => toggleBlock(editor, "paragraphOne", false)
83
- }, {
84
- name: "Paragraph 2",
85
- desc: "",
86
- group: "Text",
87
- type: "paragraphTwo",
88
- icon: /*#__PURE__*/_jsx(Icon, {
89
- icon: "paragraphTwo"
90
- }),
91
- onInsert: editor => toggleBlock(editor, "paragraphTwo", false)
92
- }, {
93
- name: "Paragraph 3",
94
- desc: "",
95
- group: "Text",
96
- type: "paragraphThree",
97
- icon: /*#__PURE__*/_jsx(Icon, {
98
- icon: "paragraphThree"
99
- }),
100
- onInsert: editor => toggleBlock(editor, "paragraphThree", false)
101
47
  }, {
102
48
  name: "Quote",
103
49
  desc: "",
@@ -218,10 +164,7 @@ const ELEMENTS_LIST = [{
218
164
  type: "emoji",
219
165
  renderComponent: rest => /*#__PURE__*/_jsx(EmojiButton, {
220
166
  ...rest,
221
- icoBtnType: "cmd",
222
- customProps: {
223
- ...rest
224
- }
167
+ icoBtnType: "cmd"
225
168
  })
226
169
  }, {
227
170
  name: "Brain",
@@ -233,10 +176,7 @@ const ELEMENTS_LIST = [{
233
176
  element: {
234
177
  name: "Brain"
235
178
  },
236
- icoBtnType: "cmd",
237
- customProps: {
238
- ...rest
239
- }
179
+ icoBtnType: "cmd"
240
180
  })
241
181
  }, {
242
182
  name: "Divider",
@@ -359,21 +299,10 @@ const elements = props => {
359
299
  const {
360
300
  search,
361
301
  hideTools,
362
- translation,
363
302
  editor
364
303
  } = props;
365
304
  const nodeType = canOpen(editor);
366
- const translatedElements = ELEMENTS_LIST.map(element => ({
367
- ...element,
368
- name: translation(element.name),
369
- renderComponent: element.renderComponent ? rest => {
370
- return element.renderComponent({
371
- ...rest,
372
- translation
373
- });
374
- } : undefined
375
- }));
376
- const filteredElements = translatedElements.filter(f => (hideTools || []).indexOf(f.type) === -1 && (!f?.hideFor || f?.hideFor?.indexOf(nodeType) === -1));
305
+ const filteredElements = ELEMENTS_LIST.filter(f => (hideTools || []).indexOf(f.type) === -1 && (!f?.hideFor || f?.hideFor?.indexOf(nodeType) === -1));
377
306
  return filteredElements.filter(c => c.name.toLowerCase().includes(search?.toLowerCase()));
378
307
  };
379
308
  export default elements;
@@ -15,12 +15,12 @@ const appHeaderStyle = [{
15
15
  options: fontOptions,
16
16
  webFont: true,
17
17
  width: 7,
18
- renderOption: (option, elementProps, translation) => {
18
+ renderOption: option => {
19
19
  return /*#__PURE__*/_jsx("span", {
20
20
  style: {
21
21
  fontFamily: option.value
22
22
  },
23
- children: translation("LOGO")
23
+ children: "LOGO"
24
24
  });
25
25
  }
26
26
  }, {
@@ -58,12 +58,12 @@ const appHeaderStyle = [{
58
58
  webFont: true,
59
59
  width: 7,
60
60
  options: fontOptions,
61
- renderOption: (option, elementProps, translation) => {
61
+ renderOption: option => {
62
62
  return /*#__PURE__*/_jsx("span", {
63
63
  style: {
64
64
  fontFamily: option.value
65
65
  },
66
- children: translation("Home")
66
+ children: "Home"
67
67
  });
68
68
  }
69
69
  }, {
@@ -51,9 +51,9 @@ const boxStyle = [{
51
51
  text: "Dashed",
52
52
  value: "dashed"
53
53
  }],
54
- renderOption: (option, elementProps, translation) => {
54
+ renderOption: option => {
55
55
  return /*#__PURE__*/_jsx("span", {
56
- children: translation(option.text)
56
+ children: option.text
57
57
  });
58
58
  }
59
59
  }]
@@ -21,8 +21,7 @@ const buttonStyle = [{
21
21
  },
22
22
  children: option.text
23
23
  });
24
- },
25
- themeEnabled: true
24
+ }
26
25
  }, {
27
26
  label: "Font Size",
28
27
  key: "textSize",
@@ -46,8 +45,7 @@ const buttonStyle = [{
46
45
  }, {
47
46
  label: "Button Color",
48
47
  key: "bgColor",
49
- type: "color",
50
- themeEnabled: true
48
+ type: "color"
51
49
  }, {
52
50
  label: "Border Color",
53
51
  key: "borderColor",
@@ -106,9 +104,9 @@ const buttonStyle = [{
106
104
  text: "Dashed",
107
105
  value: "dashed"
108
106
  }],
109
- renderOption: (option, elementProps, translation) => {
107
+ renderOption: option => {
110
108
  return /*#__PURE__*/_jsx("span", {
111
- children: translation(option.text)
109
+ children: option.text
112
110
  });
113
111
  }
114
112
  }]
@@ -46,9 +46,9 @@ const dividerStyle = [{
46
46
  text: "Outset",
47
47
  value: "outset"
48
48
  }],
49
- renderOption: (option, lementProps, translation) => {
49
+ renderOption: option => {
50
50
  return /*#__PURE__*/_jsx("span", {
51
- children: translation(option.text)
51
+ children: option.text
52
52
  });
53
53
  }
54
54
  }]
@@ -16,18 +16,18 @@ const embedVideoStyle = [{
16
16
  key: "aspectRatio",
17
17
  type: "textOptions",
18
18
  options: [{
19
- text: "deafultRatio",
19
+ text: "16:9 (Default)",
20
20
  value: "16 / 9"
21
21
  }, {
22
- text: "nineSixteen",
22
+ text: "9:16",
23
23
  value: "9 / 16"
24
24
  }, {
25
25
  text: "Custom",
26
26
  value: "custom"
27
27
  }],
28
- renderOption: (option, elementProps, translation) => {
28
+ renderOption: option => {
29
29
  return /*#__PURE__*/_jsx("span", {
30
- children: translation(option.text)
30
+ children: option.text
31
31
  });
32
32
  }
33
33
  }]
@@ -78,9 +78,9 @@ const embedVideoStyle = [{
78
78
  text: "Dashed",
79
79
  value: "dashed"
80
80
  }],
81
- renderOption: (option, elementProps, translation) => {
81
+ renderOption: option => {
82
82
  return /*#__PURE__*/_jsx("span", {
83
- children: translation(option.text)
83
+ children: option.text
84
84
  });
85
85
  }
86
86
  }]
@@ -57,9 +57,9 @@ const fieldStyle = [{
57
57
  text: "Dashed",
58
58
  value: "dashed"
59
59
  }],
60
- renderOption: (option, elementProps, translation) => {
60
+ renderOption: option => {
61
61
  return /*#__PURE__*/_jsx("span", {
62
- children: translation(option.text)
62
+ children: option.text
63
63
  });
64
64
  }
65
65
  }]
@@ -8,12 +8,8 @@ const Alignment = props => {
8
8
  const {
9
9
  value,
10
10
  data,
11
- onChange,
12
- customProps
11
+ onChange
13
12
  } = props;
14
- const {
15
- translation
16
- } = customProps;
17
13
  const {
18
14
  key
19
15
  } = data;
@@ -40,7 +36,7 @@ const Alignment = props => {
40
36
  fontSize: "14px",
41
37
  fontWeight: 500
42
38
  },
43
- children: translation("Alignment")
39
+ children: "Alignment"
44
40
  })
45
41
  }), /*#__PURE__*/_jsxs("div", {
46
42
  style: {
@@ -57,21 +53,21 @@ const Alignment = props => {
57
53
  display: "flex"
58
54
  },
59
55
  children: [/*#__PURE__*/_jsx(Tooltip, {
60
- title: translation("Align Left"),
56
+ title: "Align Left",
61
57
  children: /*#__PURE__*/_jsx(FormControlLabel, {
62
58
  value: "start",
63
59
  control: /*#__PURE__*/_jsx(Radio, {}),
64
60
  label: /*#__PURE__*/_jsx(JustifyStartIcon, {})
65
61
  })
66
62
  }), /*#__PURE__*/_jsx(Tooltip, {
67
- title: translation("Align Center"),
63
+ title: "Align Center",
68
64
  children: /*#__PURE__*/_jsx(FormControlLabel, {
69
65
  value: "center",
70
66
  control: /*#__PURE__*/_jsx(Radio, {}),
71
67
  label: /*#__PURE__*/_jsx(JustifyCenterIcon, {})
72
68
  })
73
69
  }), /*#__PURE__*/_jsx(Tooltip, {
74
- title: translation("Align Right"),
70
+ title: "Align Right",
75
71
  children: /*#__PURE__*/_jsx(FormControlLabel, {
76
72
  value: "end",
77
73
  control: /*#__PURE__*/_jsx(Radio, {}),
@@ -89,21 +85,21 @@ const Alignment = props => {
89
85
  display: "flex"
90
86
  },
91
87
  children: [/*#__PURE__*/_jsx(Tooltip, {
92
- title: translation("Align Top"),
88
+ title: "Align Top",
93
89
  children: /*#__PURE__*/_jsx(FormControlLabel, {
94
90
  value: "start",
95
91
  control: /*#__PURE__*/_jsx(Radio, {}),
96
92
  label: /*#__PURE__*/_jsx(AlignStartIcon, {})
97
93
  })
98
94
  }), /*#__PURE__*/_jsx(Tooltip, {
99
- title: translation("Align Middle"),
95
+ title: "Align Middle",
100
96
  children: /*#__PURE__*/_jsx(FormControlLabel, {
101
97
  value: "center",
102
98
  control: /*#__PURE__*/_jsx(Radio, {}),
103
99
  label: /*#__PURE__*/_jsx(AlignCenterIcon, {})
104
100
  })
105
101
  }), /*#__PURE__*/_jsx(Tooltip, {
106
- title: translation("Align Bottom"),
102
+ title: "Align Bottom",
107
103
  children: /*#__PURE__*/_jsx(FormControlLabel, {
108
104
  value: "end",
109
105
  control: /*#__PURE__*/_jsx(Radio, {}),
@@ -126,7 +122,7 @@ const Alignment = props => {
126
122
  fontSize: "14px",
127
123
  fontWeight: 500
128
124
  },
129
- children: translation("Direction")
125
+ children: "Direction"
130
126
  })
131
127
  }), /*#__PURE__*/_jsxs(RadioGroup, {
132
128
  row: true,
@@ -13,9 +13,6 @@ const BackgroundImage = props => {
13
13
  customProps,
14
14
  onChange
15
15
  } = props;
16
- const {
17
- translation
18
- } = customProps;
19
16
  const {
20
17
  key
21
18
  } = data;
@@ -55,7 +52,7 @@ const BackgroundImage = props => {
55
52
  fontWeight: "500",
56
53
  marginBottom: "8px"
57
54
  },
58
- children: translation("Upload Image")
55
+ children: "Upload Image"
59
56
  }), /*#__PURE__*/_jsx(Grid, {
60
57
  container: true,
61
58
  sx: classes.uploadContainer,
@@ -73,14 +70,9 @@ const BackgroundImage = props => {
73
70
  children: base64 ? /*#__PURE__*/_jsx(Grid, {
74
71
  className: "removeImageText",
75
72
  onClick: onRemoveBG,
76
- children: translation("REMOVE")
73
+ children: "REMOVE"
77
74
  }) : /*#__PURE__*/_jsx(Grid, {
78
75
  className: "uploadImageText",
79
- sx: {
80
- padding: 0,
81
- background: `${theme?.palette?.editor?.inputFieldBgColor}`,
82
- border: `1px solid ${theme?.palette?.editor?.inputFieldBorder}`
83
- },
84
76
  children: /*#__PURE__*/_jsxs(Button, {
85
77
  component: "label",
86
78
  variant: "text",
@@ -95,7 +87,7 @@ const BackgroundImage = props => {
95
87
  style: {
96
88
  paddingLeft: "8px"
97
89
  },
98
- children: translation("Upload a image")
90
+ children: "Upload a image"
99
91
  })]
100
92
  })
101
93
  })
@@ -3,37 +3,23 @@ import { Checkbox, FormControlLabel, Grid, Slider, Typography, Box, IconButton }
3
3
  import { squreStyle } from "./radiusStyle";
4
4
  import { getBreakPointsValue } from "../../../helper/theme";
5
5
  import useWindowResize from "../../../hooks/useWindowResize";
6
- import { useEditorTheme } from "../../../hooks/useEditorTheme";
7
6
  import { CheckedBoxCheckIcon } from "../../iconListV2";
8
7
  import { jsx as _jsx } from "react/jsx-runtime";
9
8
  import { jsxs as _jsxs } from "react/jsx-runtime";
10
9
  const BANNER_SPACING_KEYS = ["top", "left", "right", "bottom"];
11
10
  const BannerSpacing = props => {
12
11
  const {
12
+ value: val,
13
13
  data,
14
14
  onChange,
15
15
  elementProps,
16
- classes,
17
- customProps
16
+ classes
18
17
  } = props;
19
- const {
20
- translation
21
- } = customProps;
22
18
  const {
23
19
  key
24
20
  } = data;
25
21
  const lockKeyVal = `lock${key}`;
26
- const {
27
- selectedTheme
28
- } = useEditorTheme();
29
- const {
30
- bannerSpacing,
31
- lockbannerSpacing
32
- } = selectedTheme?.elementProps?.button || {};
33
- const isUserValue = Object.keys(props?.value || {})?.length;
34
- const isUserLockedSpacing = typeof elementProps[lockKeyVal] === "boolean";
35
- const val = isUserValue ? props?.value : bannerSpacing;
36
- let lockSpacing = isUserLockedSpacing ? elementProps[lockKeyVal] : lockbannerSpacing;
22
+ let lockSpacing = elementProps[lockKeyVal];
37
23
  if (lockSpacing === undefined) {
38
24
  lockSpacing = true;
39
25
  }
@@ -77,7 +63,7 @@ const BannerSpacing = props => {
77
63
  fontSize: "14px",
78
64
  fontWeight: 500
79
65
  },
80
- children: translation(data?.label)
66
+ children: data?.label
81
67
  }), /*#__PURE__*/_jsxs(Grid, {
82
68
  container: true,
83
69
  wrap: "nowrap",
@@ -140,7 +126,7 @@ const BannerSpacing = props => {
140
126
  sx: {
141
127
  fontSize: "14px"
142
128
  },
143
- children: translation("Customize")
129
+ children: "Customize"
144
130
  })
145
131
  }), !lockSpacing ? /*#__PURE__*/_jsx(Grid, {
146
132
  container: true,
@@ -3,40 +3,28 @@ import { Grid, Typography, Slider, FormControlLabel, Checkbox, Box, IconButton }
3
3
  import { radiusStyle } from "./radiusStyle";
4
4
  import useWindowResize from "../../../hooks/useWindowResize";
5
5
  import { getBreakPointsValue, getCustomizationValue } from "../../../helper/theme";
6
- import { useEditorTheme } from "../../../hooks/useEditorTheme";
7
6
  import { CheckedBoxCheckIcon } from "../../iconListV2";
8
7
  import { jsx as _jsx } from "react/jsx-runtime";
9
8
  import { jsxs as _jsxs } from "react/jsx-runtime";
10
9
  const BORDER_RADIUS_KEYS = ["topLeft", "topRight", "bottomLeft", "bottomRight"];
11
10
  const BorderRadius = props => {
12
11
  const {
12
+ value: val,
13
13
  data,
14
14
  onChange,
15
15
  elementProps,
16
- classes,
17
- customProps
16
+ classes
18
17
  } = props;
19
- const {
20
- translation
21
- } = customProps;
18
+ let {
19
+ lockRadius
20
+ } = elementProps;
21
+ if (lockRadius === undefined) {
22
+ lockRadius = true;
23
+ }
22
24
  const {
23
25
  key
24
26
  } = data;
25
27
  const [size] = useWindowResize();
26
- const {
27
- selectedTheme
28
- } = useEditorTheme();
29
- const {
30
- borderRadius,
31
- lockRadius: themeLockRadius
32
- } = selectedTheme?.elementProps?.button || {};
33
- const isUserValue = Object.keys(props?.value || {})?.length;
34
- const isUserLockedRadius = typeof elementProps?.lockRadius === "boolean";
35
- const val = isUserValue ? props?.value : borderRadius;
36
- let lockRadius = isUserLockedRadius ? elementProps?.lockRadius : themeLockRadius;
37
- if (lockRadius === undefined) {
38
- lockRadius = true;
39
- }
40
28
  const value = getBreakPointsValue(val, size?.device);
41
29
  const handleChange = e => {
42
30
  let changeAll = {};
@@ -72,7 +60,7 @@ const BorderRadius = props => {
72
60
  fontSize: "14px",
73
61
  fontWeight: 500
74
62
  },
75
- children: translation(data?.label)
63
+ children: data?.label
76
64
  }), /*#__PURE__*/_jsxs(Grid, {
77
65
  container: true,
78
66
  wrap: "nowrap",
@@ -125,7 +113,7 @@ const BorderRadius = props => {
125
113
  sx: {
126
114
  fontSize: "14px"
127
115
  },
128
- children: translation("Customize")
116
+ children: "Customize"
129
117
  })
130
118
  }), !lockRadius ? /*#__PURE__*/_jsx(Grid, {
131
119
  container: true,