@flozy/editor 9.3.2 → 9.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (248) hide show
  1. package/dist/Editor/ChatEditor.js +50 -15
  2. package/dist/Editor/CommonEditor.js +129 -20
  3. package/dist/Editor/DialogWrapper.js +31 -25
  4. package/dist/Editor/Editor.css +17 -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 +4 -2
  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 +31 -14
  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 +4 -4
  28. package/dist/Editor/Elements/Color Picker/Styles.js +3 -3
  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 -1
  33. package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/Select.js +4 -3
  34. package/dist/Editor/Elements/DataView/Layouts/DataTypes/MultiSelectType.js +6 -1
  35. package/dist/Editor/Elements/DataView/Layouts/DataTypes/TextType.js +7 -2
  36. package/dist/Editor/Elements/DataView/Layouts/FilterSort/SortOptions/ChooseSort.js +13 -12
  37. package/dist/Editor/Elements/DataView/Layouts/FilterSort/SortOptions/index.js +7 -4
  38. package/dist/Editor/Elements/DataView/Layouts/FilterSort/index.js +7 -5
  39. package/dist/Editor/Elements/DataView/Layouts/FilterView.js +9 -7
  40. package/dist/Editor/Elements/DataView/Layouts/Options/AddOptions.js +3 -2
  41. package/dist/Editor/Elements/DataView/Layouts/Options/AddProperty.js +5 -3
  42. package/dist/Editor/Elements/DataView/Layouts/Options/AllProperties.js +6 -5
  43. package/dist/Editor/Elements/DataView/Layouts/Options/ChangeProperty.js +5 -3
  44. package/dist/Editor/Elements/DataView/Layouts/Options/EditOption.js +7 -6
  45. package/dist/Editor/Elements/DataView/Layouts/Options/EditProperty.js +64 -38
  46. package/dist/Editor/Elements/DataView/Layouts/Options/FilterProperty.js +3 -2
  47. package/dist/Editor/Elements/DataView/Layouts/Options/PropertyList.js +3 -2
  48. package/dist/Editor/Elements/DataView/Layouts/Options/index.js +12 -6
  49. package/dist/Editor/Elements/DataView/Layouts/TableStyles.js +4 -1
  50. package/dist/Editor/Elements/DataView/Layouts/TableView.js +6 -4
  51. package/dist/Editor/Elements/DataView/Layouts/index.js +3 -1
  52. package/dist/Editor/Elements/DataView/Providers/DataViewProvider.js +5 -2
  53. package/dist/Editor/Elements/Divider/Divider.js +5 -3
  54. package/dist/Editor/Elements/Divider/DividerButton.js +6 -2
  55. package/dist/Editor/Elements/Divider/DividerPopup.js +3 -2
  56. package/dist/Editor/Elements/Embed/Embed.js +4 -1
  57. package/dist/Editor/Elements/Embed/EmbedPopup.js +4 -1
  58. package/dist/Editor/Elements/Embed/Image.js +16 -11
  59. package/dist/Editor/Elements/Embed/Video.js +10 -7
  60. package/dist/Editor/Elements/EmbedScript/Code.js +7 -4
  61. package/dist/Editor/Elements/EmbedScript/EmbedScript.js +6 -2
  62. package/dist/Editor/Elements/EmbedScript/EmbedScriptPopup.js +8 -5
  63. package/dist/Editor/Elements/Emoji/EmojiButton.js +6 -2
  64. package/dist/Editor/Elements/Form/FieldPopup.js +4 -1
  65. package/dist/Editor/Elements/Form/Form.js +12 -9
  66. package/dist/Editor/Elements/Form/FormButton.js +6 -2
  67. package/dist/Editor/Elements/Form/FormPopup.js +3 -2
  68. package/dist/Editor/Elements/Form/Workflow/FormWorkflow.js +18 -12
  69. package/dist/Editor/Elements/Form/Workflow/ListWorkflow.js +13 -8
  70. package/dist/Editor/Elements/Form/Workflow/MoreOptions.js +3 -2
  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 +21 -18
  74. package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +6 -2
  75. package/dist/Editor/Elements/FreeGrid/FreeGridButton.js +6 -2
  76. package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +8 -3
  77. package/dist/Editor/Elements/FreeGrid/Options/AddElement.js +3 -2
  78. package/dist/Editor/Elements/FreeGrid/Options/More.js +4 -3
  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 +14 -7
  87. package/dist/Editor/Elements/Link/LinkButton.js +4 -1
  88. package/dist/Editor/Elements/List/CheckList.js +14 -9
  89. package/dist/Editor/Elements/NewLine/NewLineButton.js +6 -2
  90. package/dist/Editor/Elements/PageSettings/PageSettingsButton.js +16 -5
  91. package/dist/Editor/Elements/PageSettings/PageSettingsPopup.js +4 -1
  92. package/dist/Editor/Elements/Search/SearchButton.js +6 -3
  93. package/dist/Editor/Elements/Search/SearchList.js +7 -3
  94. package/dist/Editor/Elements/Signature/SignatureButton.js +6 -2
  95. package/dist/Editor/Elements/Signature/SignatureOptions/TypeSignature.js +6 -2
  96. package/dist/Editor/Elements/Signature/SignatureOptions/UploadSignature.js +4 -1
  97. package/dist/Editor/Elements/Signature/SignaturePopup.js +17 -16
  98. package/dist/Editor/Elements/SimpleText/index.js +5 -4
  99. package/dist/Editor/Elements/SimpleText/style.js +2 -2
  100. package/dist/Editor/Elements/Table/DragButton.js +4 -2
  101. package/dist/Editor/Elements/Table/Table.js +48 -25
  102. package/dist/Editor/Elements/Table/TableCell.js +6 -27
  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 +10 -0
  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 +9 -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 +7 -13
  117. package/dist/Editor/Toolbar/Mini/MiniToolbar.js +20 -15
  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 +6 -2
  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 +15 -7
  128. package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +8 -4
  129. package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +16 -9
  130. package/dist/Editor/Toolbar/PopupTool/TemplateCard.js +11 -5
  131. package/dist/Editor/Toolbar/PopupTool/TextFormat.js +120 -41
  132. package/dist/Editor/Toolbar/PopupTool/ThemeTextFormat.js +441 -0
  133. package/dist/Editor/Toolbar/PopupTool/index.js +3 -8
  134. package/dist/Editor/Toolbar/Toolbar.js +20 -10
  135. package/dist/Editor/Toolbar/toolbarGroups.js +48 -6
  136. package/dist/Editor/assets/svg/CalenderIconTick.js +1 -0
  137. package/dist/Editor/assets/svg/ThemeIcons.js +291 -0
  138. package/dist/Editor/common/ColorPickerButton.js +45 -10
  139. package/dist/Editor/common/CustomColorPicker/index.js +125 -0
  140. package/dist/Editor/common/CustomColorPicker/style.js +53 -0
  141. package/dist/Editor/common/CustomDialog/index.js +8 -10
  142. package/dist/Editor/common/CustomDialog2/index.js +94 -0
  143. package/dist/Editor/common/CustomDialog2/style.js +67 -0
  144. package/dist/Editor/common/CustomSelect.js +33 -0
  145. package/dist/Editor/common/DnD/DragHandleButton.js +1 -1
  146. package/dist/Editor/common/FontLoader/FontLoader.js +3 -0
  147. package/dist/Editor/common/Icon.js +46 -1
  148. package/dist/Editor/common/ImageSelector/ImageSelector.js +10 -8
  149. package/dist/Editor/common/ImageSelector/Options/AddLink.js +6 -4
  150. package/dist/Editor/common/ImageSelector/Styles.js +3 -9
  151. package/dist/Editor/common/LinkSettings/NavComponents.js +14 -10
  152. package/dist/Editor/common/LinkSettings/index.js +20 -14
  153. package/dist/Editor/common/LinkSettings/navOptions.js +1 -1
  154. package/dist/Editor/common/MentionsPopup/Styles.js +106 -68
  155. package/dist/Editor/common/MentionsPopup/index.js +8 -4
  156. package/dist/Editor/common/RnD/ContextMenu/CMenus.js +22 -22
  157. package/dist/Editor/common/RnD/ContextMenu/index.js +3 -2
  158. package/dist/Editor/common/RnD/ElementOptions/index.js +7 -2
  159. package/dist/Editor/common/RnD/ElementSettings/OtherSettings/SaveAsTemplate.js +8 -3
  160. package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +7 -3
  161. package/dist/Editor/common/RnD/ElementSettings/Settings/AppHeaderSettings.js +3 -2
  162. package/dist/Editor/common/RnD/ElementSettings/Settings/BoxSettings.js +3 -2
  163. package/dist/Editor/common/RnD/ElementSettings/Settings/ButtonSettings.js +3 -2
  164. package/dist/Editor/common/RnD/ElementSettings/Settings/CodeSettings.js +3 -2
  165. package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +7 -4
  166. package/dist/Editor/common/RnD/ElementSettings/Settings/ImageSettings.js +3 -2
  167. package/dist/Editor/common/RnD/ElementSettings/Settings/TableSettings.js +3 -2
  168. package/dist/Editor/common/RnD/ElementSettings/Settings/TextSettings.js +6 -2
  169. package/dist/Editor/common/RnD/ElementSettings/Settings/VideoSettings.js +3 -2
  170. package/dist/Editor/common/RnD/OptionsPopup/index.js +4 -3
  171. package/dist/Editor/common/RnD/SwitchViewport/SwitchViewport.js +11 -4
  172. package/dist/Editor/common/RnD/Theme/MainThemeProvider.js +17 -0
  173. package/dist/Editor/common/RnD/Theme/ViewportStimulator.js +20 -8
  174. package/dist/Editor/common/RnD/Utils/index.js +45 -0
  175. package/dist/Editor/common/RnD/VirtualElement/index.js +1 -2
  176. package/dist/Editor/common/RnD/index.js +34 -7
  177. package/dist/Editor/common/Section/index.js +7 -4
  178. package/dist/Editor/common/Shorthands/elements.js +93 -10
  179. package/dist/Editor/common/StyleBuilder/appHeaderStyle.js +4 -4
  180. package/dist/Editor/common/StyleBuilder/boxStyle.js +2 -2
  181. package/dist/Editor/common/StyleBuilder/buttonStyle.js +6 -4
  182. package/dist/Editor/common/StyleBuilder/dividerStyles.js +2 -2
  183. package/dist/Editor/common/StyleBuilder/embedVideoStyle.js +6 -6
  184. package/dist/Editor/common/StyleBuilder/fieldStyle.js +2 -2
  185. package/dist/Editor/common/StyleBuilder/fieldTypes/alignment.js +13 -9
  186. package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +11 -3
  187. package/dist/Editor/common/StyleBuilder/fieldTypes/bannerSpacing.js +19 -5
  188. package/dist/Editor/common/StyleBuilder/fieldTypes/borderRadius.js +22 -10
  189. package/dist/Editor/common/StyleBuilder/fieldTypes/buttonLink.js +6 -3
  190. package/dist/Editor/common/StyleBuilder/fieldTypes/card.js +27 -13
  191. package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +41 -14
  192. package/dist/Editor/common/StyleBuilder/fieldTypes/elementSize.js +10 -6
  193. package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +19 -6
  194. package/dist/Editor/common/StyleBuilder/fieldTypes/gridSize.js +6 -2
  195. package/dist/Editor/common/StyleBuilder/fieldTypes/icons.js +5 -2
  196. package/dist/Editor/common/StyleBuilder/fieldTypes/menusArray.js +9 -6
  197. package/dist/Editor/common/StyleBuilder/fieldTypes/metaDataMapping.js +8 -2
  198. package/dist/Editor/common/StyleBuilder/fieldTypes/saveAsTemplate.js +12 -11
  199. package/dist/Editor/common/StyleBuilder/fieldTypes/selectBox.js +6 -2
  200. package/dist/Editor/common/StyleBuilder/fieldTypes/text.js +8 -4
  201. package/dist/Editor/common/StyleBuilder/fieldTypes/textAlign.js +6 -2
  202. package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +21 -12
  203. package/dist/Editor/common/StyleBuilder/formStyle.js +7 -7
  204. package/dist/Editor/common/StyleBuilder/gridItemStyle.js +6 -6
  205. package/dist/Editor/common/StyleBuilder/gridStyle.js +5 -5
  206. package/dist/Editor/common/StyleBuilder/index.js +8 -5
  207. package/dist/Editor/common/StyleBuilder/pageSettingsStyle.js +5 -7
  208. package/dist/Editor/common/Uploader.js +16 -5
  209. package/dist/Editor/commonStyle.js +55 -65
  210. package/dist/Editor/helper/index.js +8 -12
  211. package/dist/Editor/helper/textIndeces.js +58 -0
  212. package/dist/Editor/helper/theme.js +200 -2
  213. package/dist/Editor/hooks/useDrag.js +16 -10
  214. package/dist/Editor/hooks/useEditorScroll.js +10 -5
  215. package/dist/Editor/hooks/useEditorTheme.js +153 -0
  216. package/dist/Editor/hooks/useMouseMove.js +25 -13
  217. package/dist/Editor/hooks/useTable.js +1 -1
  218. package/dist/Editor/plugins/withEmbeds.js +1 -1
  219. package/dist/Editor/plugins/withHTML.js +18 -13
  220. package/dist/Editor/plugins/withLayout.js +3 -2
  221. package/dist/Editor/plugins/withTable.js +1 -1
  222. package/dist/Editor/theme/ThemeList.js +50 -173
  223. package/dist/Editor/theme/index.js +144 -0
  224. package/dist/Editor/themeSettings/ActiveTheme.js +72 -0
  225. package/dist/Editor/themeSettings/buttons/index.js +285 -0
  226. package/dist/Editor/themeSettings/buttons/style.js +23 -0
  227. package/dist/Editor/themeSettings/colorTheme/index.js +297 -0
  228. package/dist/Editor/themeSettings/colorTheme/style.js +81 -0
  229. package/dist/Editor/themeSettings/fonts/PreviewElement.js +121 -0
  230. package/dist/Editor/themeSettings/fonts/index.js +222 -0
  231. package/dist/Editor/themeSettings/fonts/style.js +59 -0
  232. package/dist/Editor/themeSettings/icons.js +60 -0
  233. package/dist/Editor/themeSettings/index.js +328 -0
  234. package/dist/Editor/themeSettings/style.js +193 -0
  235. package/dist/Editor/themeSettingsAI/icons.js +96 -0
  236. package/dist/Editor/themeSettingsAI/index.js +355 -0
  237. package/dist/Editor/themeSettingsAI/saveTheme.js +215 -0
  238. package/dist/Editor/themeSettingsAI/style.js +250 -0
  239. package/dist/Editor/utils/SlateUtilityFunctions.js +171 -47
  240. package/dist/Editor/utils/button.js +0 -14
  241. package/dist/Editor/utils/chatEditor/SlateUtilityFunctions.js +23 -0
  242. package/dist/Editor/utils/divider.js +8 -0
  243. package/dist/Editor/utils/draftToSlate.js +3 -2
  244. package/dist/Editor/utils/embed.js +9 -4
  245. package/dist/Editor/utils/font.js +40 -37
  246. package/dist/Editor/utils/helper.js +65 -19
  247. package/dist/Editor/utils/table.js +8 -0
  248. package/package.json +1 -1
@@ -51,40 +51,30 @@ const useCommonStyle = theme => ({
51
51
  },
52
52
  "& .MuiPaper-root": {
53
53
  border: `unset !important`,
54
- borderRadius: '0px',
55
- height: 'fit-content'
54
+ borderRadius: "0px",
55
+ height: "fit-content",
56
+ padding: "2px"
56
57
  },
57
58
  "& p": {
58
59
  marginBottom: "7px",
59
60
  marginTop: "4px"
60
61
  },
61
- "& .MuiPaper-root": {
62
- border: 'unset !important',
63
- borderRadius: '0px',
64
- height: 'fit-content',
65
- padding: '2px'
62
+ "& p": {
63
+ marginBottom: "7px",
64
+ marginTop: "4px"
66
65
  },
67
66
  "& .muiIconsListParent": {
68
67
  "& svg": {
69
68
  color: `${theme?.palette?.editor?.svgTextAlignStrokeColor} !important`
70
69
  },
71
- "&::-webkit-scrollbar-thumb": {
72
- background: `none !important`
73
- },
74
- "&::-webkit-scrollbar-track": {
75
- visibility: "hidden"
76
- },
77
70
  "&::-webkit-scrollbar-thumb": {
78
71
  background: `${theme?.palette?.editor?.brainPopupScroll} !important`
79
- },
80
- "&::-webkit-scrollbar-track": {
81
- visibility: "hidden"
82
72
  }
83
73
  },
84
74
  "& .MuiGrid-root>.MuiGrid-item": {
85
75
  paddingRight: "0px !important",
86
76
  fontFamily: "Inter, sans-serif",
87
- height: 'fit-content'
77
+ height: "fit-content"
88
78
  },
89
79
  "& .MuiInputBase-root": {
90
80
  borderRadius: "10px",
@@ -145,11 +135,11 @@ const useCommonStyle = theme => ({
145
135
  borderRadius: "10px",
146
136
  width: "46px !important",
147
137
  marginLeft: "10px",
148
- height: '36px !important'
138
+ height: "36px !important"
149
139
  }
150
140
  },
151
- '& .MuiFormHelperText-root': {
152
- margin: '4px 0px 0px 0px',
141
+ "& .MuiFormHelperText-root": {
142
+ margin: "4px 0px 0px 0px",
153
143
  color: theme?.palette?.editor?.closeButtonSvgStroke,
154
144
  fontFamily: "Inter, sans-serif"
155
145
  }
@@ -405,14 +395,14 @@ const useCommonStyle = theme => ({
405
395
  padding: "8px 12px",
406
396
  fontSize: "12px",
407
397
  color: theme?.palette?.editor?.menuOptionTextColor,
408
- fontWeight: '500',
398
+ fontWeight: "500",
409
399
  fontFamily: "Inter, sans-serif",
410
- minHeight: '36px',
400
+ minHeight: "36px",
411
401
  "&:hover": {
412
402
  backgroundColor: theme?.palette?.editor?.menuOptionHoverBackground
413
403
  }
414
404
  },
415
- '& .Mui-selected': {
405
+ "& .Mui-selected": {
416
406
  background: `${theme?.palette?.editor?.menuOptionSelectedOption} !important`
417
407
  },
418
408
  "& .MuiListSubheader-root": {
@@ -421,16 +411,16 @@ const useCommonStyle = theme => ({
421
411
  fontSize: "12px"
422
412
  },
423
413
  "& .MuiPaper-root": {
424
- borderRadius: '8px',
425
- padding: '0px',
414
+ borderRadius: "8px",
415
+ padding: "0px",
426
416
  background: `${theme?.palette?.editor?.textWeightPopUpBackground} !important`
427
417
  },
428
- '& .MuiButtonBase-root': {
429
- margin: '4px',
430
- borderRadius: '6px'
418
+ "& .MuiButtonBase-root": {
419
+ margin: "4px",
420
+ borderRadius: "6px"
431
421
  },
432
- '& .MuiList-root': {
433
- padding: '0px'
422
+ "& .MuiList-root": {
423
+ padding: "0px"
434
424
  }
435
425
  },
436
426
  datePicker: {
@@ -530,27 +520,27 @@ const useCommonStyle = theme => ({
530
520
  }
531
521
  }
532
522
  },
533
- pageSettingPopUpRoot: {
534
- padding: "16px 8px 16px 10px!important",
535
- height: "100%"
536
- },
537
523
  buttonMoreOption: {
538
524
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
539
525
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
540
- padding: '4px !important',
541
- '& svg': {
542
- width: '18px !important',
543
- height: '18px !important',
544
- '& path': {
526
+ padding: "4px !important",
527
+ "& svg": {
528
+ width: "18px !important",
529
+ height: "18px !important",
530
+ "& path": {
545
531
  stroke: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
546
532
  }
547
533
  }
548
534
  },
535
+ pageSettingPopUpRoot: {
536
+ padding: "16px 8px 16px 10px!important",
537
+ height: "100%"
538
+ },
549
539
  buttonMoreOption2: {
550
540
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
551
541
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
552
- '& svg': {
553
- '& path': {
542
+ "& svg": {
543
+ "& path": {
554
544
  fill: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
555
545
  }
556
546
  }
@@ -558,11 +548,11 @@ const useCommonStyle = theme => ({
558
548
  buttonMoreOption3: {
559
549
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
560
550
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
561
- padding: '5px !important',
562
- '& svg': {
563
- width: '16px !important',
564
- height: '16px !important',
565
- '& path': {
551
+ padding: "5px !important",
552
+ "& svg": {
553
+ width: "16px !important",
554
+ height: "16px !important",
555
+ "& path": {
566
556
  stroke: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
567
557
  }
568
558
  }
@@ -570,37 +560,37 @@ const useCommonStyle = theme => ({
570
560
  resizeButton: {
571
561
  background: theme?.palette?.editor?.aiInputBackground,
572
562
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1}`,
573
- padding: '5px !important',
574
- borderRadius: '50% !important',
575
- '& svg': {
576
- width: '18px',
577
- height: '18px',
578
- '& path': {
563
+ padding: "5px !important",
564
+ borderRadius: "50% !important",
565
+ "& svg": {
566
+ width: "18px",
567
+ height: "18px",
568
+ "& path": {
579
569
  fill: `${theme?.palette?.editor?.closeButtonSvgStroke}`
580
570
  }
581
571
  },
582
- '&:hover': {
572
+ "&:hover": {
583
573
  background: theme?.palette?.editor?.aiInputBackground
584
574
  }
585
575
  },
586
576
  gradientFillBtn: {
587
577
  background: `linear-gradient(112.61deg, #2C63ED 19.3%, #8360FD 88.14%) !important`,
588
- textTransform: 'math-auto !important',
589
- color: '#FFFFFF !important',
590
- padding: '0px 12px !important',
591
- height: '32px',
592
- borderRadius: '8px',
593
- fontWeight: '500',
594
- fontSize: '14px'
578
+ textTransform: "math-auto !important",
579
+ color: "#FFFFFF !important",
580
+ padding: "0px 12px !important",
581
+ height: "32px",
582
+ borderRadius: "8px",
583
+ fontWeight: "500",
584
+ fontSize: "14px"
595
585
  },
596
586
  emptyThumbBtn: {
597
587
  background: `${theme?.palette?.editor?.sectionSettingIconHover} !important`,
598
588
  color: `${theme?.palette?.editor?.textColor} !important`,
599
- fontSize: '14px !important',
600
- '& svg': {
601
- width: '20px !important',
602
- height: '20px !important',
603
- '& path': {
589
+ fontSize: "14px !important",
590
+ "& svg": {
591
+ width: "20px !important",
592
+ height: "20px !important",
593
+ "& path": {
604
594
  stroke: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
605
595
  }
606
596
  }
@@ -287,22 +287,18 @@ export const bringItemToFB = (editor, {
287
287
  };
288
288
  export const debounce = function (func, wait, immediate) {
289
289
  let timeout;
290
- function debounced(...args) {
291
- const context = this;
292
- const later = function () {
293
- timeout = null;
294
- if (!immediate) func.apply(context, args);
295
- };
296
- const callNow = immediate && !timeout;
290
+ return function () {
291
+ const context = this,
292
+ args = arguments,
293
+ later = function () {
294
+ timeout = null;
295
+ if (!immediate) func.apply(context, args);
296
+ },
297
+ callNow = immediate && !timeout;
297
298
  clearTimeout(timeout);
298
299
  timeout = setTimeout(later, wait);
299
300
  if (callNow) func.apply(context, args);
300
- }
301
- debounced.cancel = function () {
302
- clearTimeout(timeout);
303
- timeout = null;
304
301
  };
305
- return debounced;
306
302
  };
307
303
  export const getTextColor = (color = "") => {
308
304
  return color?.indexOf("gradient") >= 0 ? {
@@ -0,0 +1,58 @@
1
+ export function extractTextWithPath(data, path = []) {
2
+ let result = [];
3
+ data.forEach((item, index) => {
4
+ const currentPath = [...path, index];
5
+ if (item.text) {
6
+ result.push({
7
+ path_id: currentPath.join(","),
8
+ text: item.text
9
+ });
10
+ }
11
+ if (item.children) {
12
+ result = result.concat(extractTextWithPath(item.children, currentPath));
13
+ }
14
+ });
15
+ return result;
16
+ }
17
+ export function replaceTextPath(nestedJson, pathIdJson) {
18
+ // Create a map from path_id JSON for quick lookup
19
+ const pathIdMap = new Map(pathIdJson.map(item => [item.path_id, item.text]));
20
+ console.log(pathIdMap);
21
+ function extractTextWithPath(data, path = []) {
22
+ data.forEach((item, index) => {
23
+ const currentPath = [...path, index];
24
+ if (item.text) {
25
+ if (pathIdMap.has(currentPath?.join(","))) {
26
+ item.text = pathIdMap.get(currentPath?.join(","));
27
+ }
28
+ }
29
+ if (item.children) {
30
+ extractTextWithPath(item.children, currentPath);
31
+ }
32
+ });
33
+ }
34
+ extractTextWithPath(nestedJson, []);
35
+ return nestedJson;
36
+ }
37
+
38
+ // export function replaceTextPath(nestedJson, pathIdJson) {
39
+ // // Create a map from path_id JSON for quick lookup
40
+ // const pathIdMap = new Map(
41
+ // pathIdJson.map((item) => [item.path_id, item.text])
42
+ // );
43
+
44
+ // function traverseAndReplace(node) {
45
+ // if (Array.isArray(node)) {
46
+ // node.forEach(traverseAndReplace);
47
+ // } else if (typeof node === "object" && node !== null) {
48
+ // console.log(node);
49
+ // if (node.text && pathIdMap.has(node.text)) {
50
+ // node.text = pathIdMap.get(node.path_id);
51
+ // }
52
+ // Object.values(node).forEach(traverseAndReplace);
53
+ // }
54
+ // }
55
+
56
+ // traverseAndReplace(nestedJson);
57
+ // return nestedJson;
58
+ // }
@@ -1,4 +1,6 @@
1
+ import { ReactEditor } from "slate-react";
1
2
  import { sizeMap } from "../utils/font";
3
+ import { Editor, Node } from "slate";
2
4
  export const breakpoints = {
3
5
  small: 0,
4
6
  mobile: 600,
@@ -33,7 +35,7 @@ const overrideValues = (value, ot) => {
33
35
  return Object.keys(value).reduce((a, b) => {
34
36
  return {
35
37
  ...a,
36
- [b]: overrides[ot] ? overrides[ot](value[b]) : value
38
+ [b]: overrides[ot] ? overrides[ot](value[b], value) : value
37
39
  };
38
40
  }, {});
39
41
  };
@@ -50,7 +52,15 @@ const overrides = {
50
52
  overrideReSizeH: val => {
51
53
  return val ? `${val?.height}px` : "auto";
52
54
  },
53
- overrideBorderRadius: val => {
55
+ overrideBorderRadius: (val, breakpointValues) => {
56
+ if (!val?.topLeft) {
57
+ Object.values(breakpointValues || {}).forEach(v => {
58
+ if (v) {
59
+ // Applying the values from breakpoints that exist to those that do not have
60
+ val = v;
61
+ }
62
+ });
63
+ }
54
64
  return `${val?.topLeft}px ${val?.topRight}px ${val?.bottomLeft}px ${val?.bottomRight}px`;
55
65
  }
56
66
  };
@@ -118,6 +128,194 @@ export const getTRBLBreakPoints = (value, breakpoint) => {
118
128
  console.log(err);
119
129
  }
120
130
  };
131
+ export function getElementStyle(editor, element, stylePropertyName) {
132
+ try {
133
+ const path = ReactEditor.findPath(editor, element);
134
+ if (path?.length) {
135
+ const currentEle = Node.get(editor, path);
136
+ const dom = ReactEditor.toDOMNode(editor, currentEle);
137
+ const editorBtn = dom?.querySelector(".button.theme-element");
138
+ return getElementProperty(editorBtn, stylePropertyName);
139
+ }
140
+ } catch (err) {
141
+ // console.log(err);
142
+ }
143
+ }
144
+ export function getTextSizeVal(editor) {
145
+ try {
146
+ const currentNode = Node.get(editor, editor.selection.anchor.path);
147
+ const currentElement = ReactEditor.toDOMNode(editor, currentNode);
148
+ if (currentElement) {
149
+ const element = currentElement.querySelector('span[data-slate-string="true"]');
150
+ return getElementProperty(element, "font-size");
151
+ }
152
+ } catch (err) {
153
+ // console.log(err);
154
+ }
155
+ }
156
+ export function getVariableValue(val) {
157
+ const bodyElement = document.body;
158
+ const computedStyle = getComputedStyle(bodyElement);
159
+ const [, variableName] = val?.match(/var\((--[^)]+)\)/) || [];
160
+ const varValue = computedStyle.getPropertyValue(variableName).trim();
161
+ return varValue;
162
+ }
163
+ const MAP_PROPERTY_KEYS = {
164
+ fontFamily: "font-family",
165
+ fontSize: "font-size",
166
+ textSize: "font-size",
167
+ fontWeight: "font-weight"
168
+ };
169
+ export function getElementProperty(element, styleProperty) {
170
+ if (!element) {
171
+ return "";
172
+ }
173
+ const computedStyle = window.getComputedStyle(element);
174
+ const property = MAP_PROPERTY_KEYS[styleProperty] || styleProperty;
175
+ let style = computedStyle.getPropertyValue(property);
176
+ if (property === "font-family") {
177
+ style = style.replace(/"/g, ""); // remove double quotes if exists e.g: '"Courier New"'
178
+ }
179
+
180
+ return style || "";
181
+ }
182
+ export const textThemeFields = ["fontFamily", "fontSize", "color", "bold", "italic"
183
+ // "underline",
184
+ // "strikethrough",
185
+ ];
186
+
187
+ const themeElements = ["headingOne", "headingTwo", "headingThree", "headingFour", "headingFive", "headingSix", "paragraphOne", "paragraphTwo", "paragraphThree"];
188
+ export const isTextCustomized = editor => {
189
+ try {
190
+ if (editor.selection) {
191
+ const currentElement = Node.parent(editor, editor?.selection?.anchor?.path);
192
+ if (!currentElement) {
193
+ return false;
194
+ }
195
+ const {
196
+ children,
197
+ type
198
+ } = currentElement;
199
+ if (!themeElements.includes(type)) {
200
+ return false;
201
+ }
202
+ if (!children?.length) {
203
+ return true;
204
+ }
205
+ const customized = textThemeFields.some(field => {
206
+ const element = children.find(child => child.text.trim() !== "") || {};
207
+ const value = element[field];
208
+ if (field === "fontSize") {
209
+ return Object.keys(value || {}).length;
210
+ } else {
211
+ return value;
212
+ }
213
+ });
214
+ return customized;
215
+ } else {
216
+ return null;
217
+ }
218
+ } catch (err) {
219
+ return null;
220
+ }
221
+ };
222
+ const addToTheme = (field, value, element) => {
223
+ switch (field) {
224
+ case "fontFamily":
225
+ return {
226
+ fontFamily: value
227
+ };
228
+ case "fontSize":
229
+ return {
230
+ fontSize: value?.lg
231
+ };
232
+ case "color":
233
+ return {
234
+ color: value
235
+ };
236
+ case "bold":
237
+ return {
238
+ fontWeight: "bold"
239
+ };
240
+ case "italic":
241
+ return {
242
+ fontStyle: "italic"
243
+ };
244
+ // case "underline":
245
+ // case "strikethrough":
246
+ // let textDecoration = "";
247
+
248
+ // if (element.underline) {
249
+ // textDecoration = "underline";
250
+ // }
251
+
252
+ // if (element.strikethrough) {
253
+ // textDecoration += " strikethrough";
254
+ // }
255
+
256
+ // return { textDecoration };
257
+ default:
258
+ return {};
259
+ }
260
+ };
261
+ const MAP_TEXT_THEME_FIELD = {
262
+ headingOne: "h1",
263
+ headingTwo: "h2",
264
+ headingThree: "h3",
265
+ headingFour: "h4",
266
+ headingFive: "h5",
267
+ headingSix: "h6",
268
+ paragraphOne: "para1",
269
+ paragraphTwo: "para2",
270
+ paragraphThree: "para3"
271
+ };
272
+ export const saveToTheme = editor => {
273
+ try {
274
+ if (editor.selection) {
275
+ const currentElement = Node.parent(editor, editor?.selection?.anchor?.path);
276
+ if (!currentElement) {
277
+ return false;
278
+ }
279
+ const {
280
+ children
281
+ } = currentElement;
282
+ if (!children?.length) {
283
+ return true;
284
+ }
285
+ let theme = {};
286
+ textThemeFields.forEach(field => {
287
+ const element = children.find(child => child.text.trim() !== "") || {};
288
+ const value = element[field];
289
+ let style = {};
290
+ let isValueExist = false;
291
+ if (value) {
292
+ isValueExist = true;
293
+ if (field === "fontSize") {
294
+ isValueExist = !!Object.keys(value).length;
295
+ }
296
+ }
297
+ if (isValueExist) {
298
+ style = addToTheme(field, value, element);
299
+ }
300
+ theme = {
301
+ ...theme,
302
+ ...style
303
+ };
304
+ });
305
+ textThemeFields.forEach(field => {
306
+ Editor.removeMark(editor, field);
307
+ });
308
+ return {
309
+ field: MAP_TEXT_THEME_FIELD[currentElement?.type],
310
+ theme
311
+ };
312
+ }
313
+ } catch (err) {
314
+ return;
315
+ }
316
+ };
317
+ export const HEADING_THEME_FIELDS = ["h1", "h2", "h3", "h4", "h5", "h6"];
318
+ export const PARAGRAPH_THEME_FIELDS = ["para1", "para2", "para3"];
121
319
  export const getBRValue = (props, rbr = "lg") => {
122
320
  const {
123
321
  value,
@@ -2,19 +2,25 @@ import { useEffect, useState } from "react";
2
2
  const useDrag = () => {
3
3
  const [event, setEvent] = useState("");
4
4
  useEffect(() => {
5
- const onMouseDown = () => {
6
- setEvent("start");
7
- };
8
- const onMouseUp = () => {
9
- setEvent("end");
10
- };
11
- document.addEventListener("pointerdown", onMouseDown);
12
- document.addEventListener("pointerup", onMouseUp);
5
+ addListener();
13
6
  return () => {
14
- document.removeEventListener("pointerdown", onMouseDown);
15
- document.removeEventListener("pointerup", onMouseUp);
7
+ removeListener();
16
8
  };
17
9
  }, []);
10
+ const onMouseDown = () => {
11
+ setEvent("start");
12
+ };
13
+ const onMouseUp = () => {
14
+ setEvent("end");
15
+ };
16
+ const addListener = () => {
17
+ document.addEventListener("pointerdown", onMouseDown);
18
+ document.addEventListener("pointerup", onMouseUp);
19
+ };
20
+ const removeListener = () => {
21
+ document.removeEventListener("pointerdown", onMouseDown);
22
+ document.removeEventListener("pointerup", onMouseUp);
23
+ };
18
24
  return [event];
19
25
  };
20
26
  export default useDrag;
@@ -3,17 +3,22 @@ function useEditorScroll(editorWrapper = {
3
3
  current: null
4
4
  }, callback) {
5
5
  useEffect(() => {
6
- if (!editorWrapper?.current) return;
7
6
  const handleScroll = () => {
8
- callback("scroll");
7
+ if (editorWrapper.current) {
8
+ callback("scroll");
9
+ }
9
10
  };
10
11
  const currentEditorWrapper = editorWrapper.current;
11
- currentEditorWrapper.addEventListener("scroll", handleScroll);
12
+ if (currentEditorWrapper) {
13
+ currentEditorWrapper.addEventListener("scroll", handleScroll);
14
+ }
12
15
 
13
16
  // Cleanup the event listener on component unmount
14
17
  return () => {
15
- currentEditorWrapper.removeEventListener("scroll", handleScroll);
18
+ if (currentEditorWrapper) {
19
+ currentEditorWrapper.removeEventListener("scroll", handleScroll);
20
+ }
16
21
  };
17
- }, [editorWrapper, callback]);
22
+ }, [editorWrapper.current, callback]);
18
23
  }
19
24
  export default useEditorScroll;