@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
@@ -67,7 +67,8 @@ export function TableToolOnDrag({
67
67
  theme,
68
68
  dragType,
69
69
  handleToolAction,
70
- hideDelete
70
+ hideDelete,
71
+ translation
71
72
  }) {
72
73
  const classes = Styles(theme);
73
74
  const tools = getTools(dragType, hideDelete);
@@ -81,12 +82,14 @@ export function TableToolOnDrag({
81
82
  btnProps: {
82
83
  onMouseDown: e => e.stopPropagation(),
83
84
  onMouseUp: e => e.stopPropagation()
84
- }
85
+ },
86
+ translation: translation
85
87
  });
86
88
  }
87
89
  function TableTool({
88
90
  theme,
89
- handleToolAction
91
+ handleToolAction,
92
+ translation
90
93
  }) {
91
94
  const classes = Styles(theme);
92
95
  return /*#__PURE__*/_jsx(CustomSelect, {
@@ -95,7 +98,8 @@ function TableTool({
95
98
  options: wholeTableTools,
96
99
  onSend: (value, option) => {
97
100
  handleToolAction(value, option);
98
- }
101
+ },
102
+ translation: translation
99
103
  });
100
104
  }
101
105
  export default TableTool;
@@ -2,7 +2,14 @@ import React, { useEffect, useState } from "react";
2
2
  import { Editor } from "slate";
3
3
  import { useSlate } from "slate-react";
4
4
  import { getNodeText } from "../../utils/helper";
5
+ import { Text } from "slate";
5
6
  import { jsx as _jsx } from "react/jsx-runtime";
7
+ const isEmptyTextNode = node => {
8
+ if (Text.isText(node)) {
9
+ return !node.text.trim();
10
+ }
11
+ return false;
12
+ };
6
13
  const Title = props => {
7
14
  const {
8
15
  attributes,
@@ -11,8 +18,11 @@ const Title = props => {
11
18
  customProps
12
19
  } = props;
13
20
  useDetectExitFromTitle(element, customProps?.getTitleSaveData);
21
+ const isEmpty = !customProps?.readOnly && isEmptyTextNode(element?.children[0]) ? "empty" : "";
14
22
  return /*#__PURE__*/_jsx("div", {
15
23
  ...attributes,
24
+ placeholder: "Title",
25
+ className: `content-editable ${isEmpty}`,
16
26
  style: {
17
27
  fontWeight: "bold",
18
28
  fontSize: "20px"
@@ -13,6 +13,9 @@ const TopBannerButton = props => {
13
13
  customProps
14
14
  } = props;
15
15
  const [open, setOpen] = useState(false);
16
+ const {
17
+ translation
18
+ } = customProps;
16
19
  const onSelectImage = url => {
17
20
  if (url) {
18
21
  insertTopBanner(editor, {
@@ -29,7 +32,7 @@ const TopBannerButton = props => {
29
32
  };
30
33
  return /*#__PURE__*/_jsxs(_Fragment, {
31
34
  children: [/*#__PURE__*/_jsx(ToolbarIcon, {
32
- title: "Top Banner",
35
+ title: translation("Top Banner"),
33
36
  onClick: handleClick,
34
37
  icon: /*#__PURE__*/_jsx(Icon, {
35
38
  icon: "topbanner"
@@ -34,7 +34,8 @@ const VariableButton = props => {
34
34
  PaperProps: {
35
35
  style: {
36
36
  maxHeight: 300,
37
- overflowY: "auto"
37
+ overflowY: "auto",
38
+ transformOrigin: 'top left'
38
39
  },
39
40
  sx: {
40
41
  "&::-webkit-scrollbar-track": {
@@ -44,6 +45,14 @@ const VariableButton = props => {
44
45
  borderRadius: "16px"
45
46
  }
46
47
  }
48
+ },
49
+ anchorOrigin: {
50
+ vertical: 'bottom',
51
+ horizontal: 'right'
52
+ },
53
+ transformOrigin: {
54
+ vertical: 'top',
55
+ horizontal: 'right'
47
56
  }
48
57
  },
49
58
  children: [/*#__PURE__*/_jsx(MenuItem, {
@@ -26,7 +26,8 @@ const MiniEditor = props => {
26
26
  className,
27
27
  otherProps,
28
28
  onSave,
29
- theme
29
+ theme,
30
+ translation
30
31
  } = props;
31
32
  const {
32
33
  CHARACTERS = []
@@ -41,11 +42,15 @@ const MiniEditor = props => {
41
42
  const [value, setValue] = useState(ensureWrappedVariables(updatedContent));
42
43
  const [deboundedValue] = useDebounce(value, 500);
43
44
  const isReadOnly = readOnly === "readonly";
45
+ const {
46
+ translationMock
47
+ } = otherProps;
44
48
  const customProps = {
45
49
  ...(otherProps || {}),
46
50
  readOnly: isReadOnly,
47
51
  editorPlaceholder: miniEditorPlaceholder,
48
- page_id: id
52
+ page_id: id,
53
+ translation: translation || translationMock
49
54
  };
50
55
  const [mentions, setMentions] = useMentions({
51
56
  editor,
@@ -58,7 +63,8 @@ const MiniEditor = props => {
58
63
  } = mentions;
59
64
  const chars = type ? Shorthands[type]({
60
65
  ...mentions,
61
- CHARACTERS
66
+ CHARACTERS,
67
+ translation: translation || translationMock
62
68
  }) : [];
63
69
  useEffect(() => {
64
70
  if (onSave && isInteracted) {
@@ -133,7 +133,7 @@ const editorStyles = ({
133
133
  },
134
134
  "& .accordion-summary-collapse-btn": {
135
135
  padding: "4px",
136
- width: '5px'
136
+ width: "5px"
137
137
  },
138
138
  "& .workflow-icon-btn": {
139
139
  pointerEvents: "none",
@@ -242,7 +242,7 @@ const editorStyles = ({
242
242
  }
243
243
  },
244
244
  "& .section-tw": {
245
- background: 'transparent !important',
245
+ background: "transparent !important",
246
246
  "& button": {
247
247
  padding: "2px",
248
248
  borderRadius: "0px",
@@ -291,8 +291,8 @@ const editorStyles = ({
291
291
  }
292
292
  },
293
293
  "& ::selection": {
294
- background: 'rgba(35, 131, 226, 0.35)!important',
295
- color: 'inherit'
294
+ background: "rgba(35, 131, 226, 0.35)!important",
295
+ color: "inherit"
296
296
  },
297
297
  "&.readOnlyContainer": {
298
298
  "& .max-content": {
@@ -302,7 +302,7 @@ const editorStyles = ({
302
302
  },
303
303
  fullScreenWrapper: {
304
304
  "& .editor-wrapper": {
305
- paddingTop: '20px'
305
+ paddingTop: "20px"
306
306
  },
307
307
  "& .MuiDialog-paper, & .MuiPopover-paper": {
308
308
  background: `${theme?.palette?.editor?.background} !important`
@@ -59,7 +59,8 @@ const BasicToolbar = props => {
59
59
  children: fontStyle?.map((m, i) => {
60
60
  return /*#__PURE__*/_jsx(MarkButton, {
61
61
  editor: editor,
62
- ...m
62
+ ...m,
63
+ customProps: customProps
63
64
  }, `pptool_mark_${i}_${m.id}`);
64
65
  })
65
66
  }), !hideLink && /*#__PURE__*/_jsx(Grid, {
@@ -10,8 +10,12 @@ const BlockButton = props => {
10
10
  const {
11
11
  editor,
12
12
  format,
13
- title
13
+ title,
14
+ customProps
14
15
  } = props;
16
+ const {
17
+ translation
18
+ } = customProps;
15
19
  const isMark = MARK_TYPES?.indexOf(format) >= 0;
16
20
  const isActive = isMark ? isMarkActive(editor, format) : isBlockActive(editor, format);
17
21
  const {
@@ -29,7 +33,7 @@ const BlockButton = props => {
29
33
  toggleBlock(editor, format);
30
34
  }
31
35
  },
32
- title: title,
36
+ title: translation(title),
33
37
  sx: classes.textAlignButtons,
34
38
  style: {
35
39
  color: "#64748B"
@@ -1,8 +1,32 @@
1
1
  import React from "react";
2
2
  import { Select, MenuItem } from "@mui/material";
3
- import { addMarkData, activeMark } from "../../utils/SlateUtilityFunctions.js";
3
+ import { addMarkData, activeMark, getSelectedElementStyle } from "../../utils/SlateUtilityFunctions.js";
4
+ import { toolbarGroups } from "../toolbarGroups.js";
4
5
  import KeyboardArrowDownRoundedIcon from "@mui/icons-material/KeyboardArrowDownRounded";
6
+ import { googleFontList as defaultFonts } from "../../common/FontLoader/FontList.js";
5
7
  import { jsx as _jsx } from "react/jsx-runtime";
8
+ const allTools = toolbarGroups.flat();
9
+ const fontWeight = allTools.find(f => f.format === "fontWeight");
10
+ export const getValue = (editor, format) => {
11
+ switch (format) {
12
+ case "fontFamily":
13
+ {
14
+ const style = getSelectedElementStyle("font-family", editor, format);
15
+ return style || defaultFonts[0];
16
+ }
17
+ case "fontWeight":
18
+ {
19
+ const {
20
+ options
21
+ } = fontWeight || {};
22
+ const fontWeightStyle = getSelectedElementStyle("font-weight", editor, format);
23
+ const selected = options?.find(o => o.value === fontWeightStyle || o.numVal === fontWeightStyle);
24
+ return selected?.value;
25
+ }
26
+ default:
27
+ return activeMark(editor, format);
28
+ }
29
+ };
6
30
  const Dropdown = ({
7
31
  classes,
8
32
  editor,
@@ -10,7 +34,7 @@ const Dropdown = ({
10
34
  options,
11
35
  width
12
36
  }) => {
13
- const value = activeMark(editor, format);
37
+ const value = activeMark(editor, format, true) || getValue(editor, format);
14
38
  const changeMarkData = (event, format) => {
15
39
  event.preventDefault();
16
40
  const value = event.target.value;
@@ -20,7 +44,7 @@ const Dropdown = ({
20
44
  });
21
45
  };
22
46
  return /*#__PURE__*/_jsx(Select, {
23
- value: value,
47
+ value: value || options?.[0]?.value,
24
48
  className: "editor-dd",
25
49
  onChange: e => changeMarkData(e, format),
26
50
  MenuProps: {
@@ -1,9 +1,10 @@
1
1
  import React from "react";
2
2
  import { Autocomplete, TextField } from "@mui/material";
3
- import { activeMark, addMarkData } from "../../utils/SlateUtilityFunctions.js";
3
+ import { addMarkData } from "../../utils/SlateUtilityFunctions.js";
4
4
  import usePopupStyle from "../PopupTool/PopupToolStyle.js";
5
5
  import { useEditorContext } from "../../hooks/useMouseMove.js";
6
- import KeyboardArrowDownRoundedIcon from '@mui/icons-material/KeyboardArrowDownRounded';
6
+ import KeyboardArrowDownRoundedIcon from "@mui/icons-material/KeyboardArrowDownRounded";
7
+ import { getValue } from "./Dropdown.js";
7
8
  import { jsx as _jsx } from "react/jsx-runtime";
8
9
  const FontFamilyAutocomplete = ({
9
10
  editor,
@@ -14,7 +15,7 @@ const FontFamilyAutocomplete = ({
14
15
  val = "",
15
16
  webFont = false
16
17
  }) => {
17
- const markValue = activeMark(editor, format);
18
+ const markValue = getValue(editor, format);
18
19
  const value = !webFont ? markValue : val;
19
20
  const changeMarkData = (event, newValue, format) => {
20
21
  if (!webFont) {
@@ -1,21 +1,25 @@
1
1
  import React from "react";
2
2
  import Icon from "../../common/Icon";
3
3
  import Button from "../../common/Button";
4
- import { toggleMark, isMarkActive } from "../../utils/SlateUtilityFunctions.js";
4
+ import { toggleMark, isMarkBtnActive } from "../../utils/SlateUtilityFunctions.js";
5
5
  import { jsx as _jsx } from "react/jsx-runtime";
6
6
  const MarkButton = ({
7
7
  editor,
8
8
  format,
9
- title
9
+ title,
10
+ customProps
10
11
  }) => {
12
+ const {
13
+ translation
14
+ } = customProps;
11
15
  return /*#__PURE__*/_jsx(Button, {
12
- active: isMarkActive(editor, format),
16
+ active: isMarkBtnActive(editor, format),
13
17
  format: format,
14
18
  onMouseDown: e => {
15
19
  e.preventDefault();
16
20
  toggleMark(editor, format);
17
21
  },
18
- title: title,
22
+ title: translation(title),
19
23
  style: {
20
24
  color: "#64748B"
21
25
  },
@@ -1,8 +1,7 @@
1
1
  import React, { useEffect, useRef, useState } from "react";
2
2
  import { TextField, IconButton } from "@mui/material";
3
- import { addMarkData, activeMark, isBlockActive } from "../../utils/SlateUtilityFunctions.js";
4
- import { headingMap, sizeMap } from "../../utils/font.js";
5
- import { getBreakPointsValue } from "../../helper/theme.js";
3
+ import { addMarkData, activeMark } from "../../utils/SlateUtilityFunctions.js";
4
+ import { getBreakPointsValue, getTextSizeVal } from "../../helper/theme.js";
6
5
  import useWindowResize from "../../hooks/useWindowResize.js";
7
6
  import { BREAKPOINTS_DEVICES } from "../../helper/theme.js";
8
7
  import { TextSizeDownArrow, TextSizeUpArrow } from "../../common/iconListV2.js";
@@ -15,11 +14,12 @@ const TextSize = ({
15
14
  format,
16
15
  fullWidth
17
16
  }) => {
18
- const [size] = useWindowResize();
19
- const val = activeMark(editor, format);
20
- const value = getBreakPointsValue(val, size?.device);
21
17
  const [fontSize, setFontSize] = useState();
22
18
  const timerRef = useRef();
19
+ const [size] = useWindowResize();
20
+ const val = activeMark(editor, format);
21
+ const noFontSize = val === "normal" || typeof val === "object" && !Object.keys(val)?.length;
22
+ const value = noFontSize ? getTextSizeVal(editor) : getBreakPointsValue(val, size?.device);
23
23
  useEffect(() => {
24
24
  setFontSize(getSizeVal());
25
25
  }, [value]);
@@ -55,13 +55,7 @@ const TextSize = ({
55
55
  };
56
56
  const getSizeVal = () => {
57
57
  try {
58
- let size = `${value}`?.indexOf("px") >= 0 ? value : sizeMap[value] || value;
59
- Object.entries(headingMap).forEach(([format, value]) => {
60
- if (isBlockActive(editor, format) && isNaN(parseInt(size))) {
61
- size = value;
62
- }
63
- });
64
- return parseInt(size);
58
+ return parseInt(value);
65
59
  } catch (err) {
66
60
  return "";
67
61
  }
@@ -49,7 +49,8 @@ const MiniToolbar = props => {
49
49
  const open = Boolean(PopupComponent);
50
50
  const DialogComp = !fullScreen ? Popper : Dialog;
51
51
  const {
52
- hideTools
52
+ hideTools,
53
+ translation
53
54
  } = customProps;
54
55
  const boxRef = useRef(null); // Add ref to get the Box element
55
56
  const UPDATED_MENU_OPTIONS = MENU_OPTIONS.filter(f => (hideTools || [])?.indexOf(f.type) === -1);
@@ -67,6 +68,7 @@ const MiniToolbar = props => {
67
68
  if (data) {
68
69
  setToolTip(false);
69
70
  setData(null);
71
+ setPopper(null);
70
72
  }
71
73
  }, [data]);
72
74
  useEffect(() => {
@@ -141,29 +143,31 @@ const MiniToolbar = props => {
141
143
  const isDisabled = popupType === type || type === "undo" ? !canUndo : type === "redo" ? !canRedo : false;
142
144
  const isFocussed = editor?.selection?.anchor?.path;
143
145
  const disableAddElement = type === "addElement" && !isFocussed;
144
- return /*#__PURE__*/_jsx(Tooltip, {
146
+ return /*#__PURE__*/_jsxs(Tooltip, {
145
147
  arrow: true,
146
- title: label,
148
+ title: translation(label),
147
149
  disableHoverListener: toolTip,
148
- children: /*#__PURE__*/_jsx(IconButton, {
150
+ children: [type !== "page-settings" && /*#__PURE__*/_jsx(IconButton, {
149
151
  className: `${type === popper ? "active" : ""} ${type === "undo" && !canUndo || type === "redo" && !canRedo ? "disabled" : ""} ${type === "undo" ? canUndo ? "activeUndo" : "disabledUndo" : type === "redo" ? canRedo ? "activeRedo" : "disabledRedo" : ""} ${disableAddElement ? "disableAddElement" : ""}
150
152
  `,
151
- onClick: handleClick(type),
153
+ onClick: type !== "page-settings" ? handleClick(type) : undefined,
152
154
  disabled: isDisabled || disableAddElement,
153
- children: type === "page-settings" ? /*#__PURE__*/_jsx(PageSettingsButton, {
154
- from: "miniToolBar",
155
- icoBtnType: "mini",
156
- customProps: customProps,
157
- editor: editor,
158
- closePopper: closePopper,
159
- setToolTip: setToolTip
160
- }) : /*#__PURE__*/_jsx(Icon, {
155
+ children: /*#__PURE__*/_jsx(Icon, {
161
156
  from: "miniToolBar",
162
157
  icoBtnType: "mini",
163
158
  customProps: customProps,
164
159
  editor: editor
165
160
  })
166
- })
161
+ }), type === "page-settings" && /*#__PURE__*/_jsx(PageSettingsButton, {
162
+ from: "miniToolBar",
163
+ icoBtnType: "mini",
164
+ customProps: customProps,
165
+ editor: editor,
166
+ closePopper: closePopper,
167
+ setToolTip: setToolTip,
168
+ setPopper: setPopper,
169
+ className: type === popper ? "active" : ""
170
+ })]
167
171
  }, `mini_tool_btn_${type}`);
168
172
  })
169
173
  }), /*#__PURE__*/_jsx(DialogComp, {
@@ -191,7 +195,8 @@ const MiniToolbar = props => {
191
195
  fullScreen: fullScreen,
192
196
  toggleFullscreen: toggleFullscreen,
193
197
  search: search,
194
- onSearch: onSearch
198
+ onSearch: onSearch,
199
+ customProps: customProps
195
200
  }), /*#__PURE__*/_jsx(PopupComponent, {
196
201
  classes: popupStyles,
197
202
  editor: editor,
@@ -135,14 +135,16 @@ const AddTemplates = props => {
135
135
  classes: classes,
136
136
  onSelectTemplate: onSelectTemplate,
137
137
  m: mapData,
138
- fullScreen: fullScreen
138
+ fullScreen: fullScreen,
139
+ customProps: customProps
139
140
  }, `template_Card_${mapData.id}_popup`);
140
141
  case "Buttons":
141
142
  return /*#__PURE__*/_jsx(ButtonTemplateCard, {
142
143
  classes: classes,
143
144
  onSelectTemplate: onSelectTemplate,
144
145
  m: mapData,
145
- fullScreen: fullScreen
146
+ fullScreen: fullScreen,
147
+ customProps: customProps
146
148
  }, `template_Card_${mapData.id}_popup`);
147
149
  case "Banners":
148
150
  case "Tables":
@@ -151,7 +153,8 @@ const AddTemplates = props => {
151
153
  onSelectTemplate: onSelectTemplate,
152
154
  m: mapData,
153
155
  fullScreen: fullScreen,
154
- height: "smallCard"
156
+ height: "smallCard",
157
+ customProps: customProps
155
158
  }, `template_Card_${mapData.id}_popup`);
156
159
  case "404 Page":
157
160
  return /*#__PURE__*/_jsx(FullViewCard, {
@@ -159,14 +162,16 @@ const AddTemplates = props => {
159
162
  onSelectTemplate: onSelectTemplate,
160
163
  m: mapData,
161
164
  fullScreen: fullScreen,
162
- height: "mediumCard"
165
+ height: "mediumCard",
166
+ customProps: customProps
163
167
  }, `template_Card_${mapData.id}_popup`);
164
168
  default:
165
169
  return /*#__PURE__*/_jsx(TemplateCard, {
166
170
  classes: classes,
167
171
  onSelectTemplate: onSelectTemplate,
168
172
  m: mapData,
169
- fullScreen: fullScreen
173
+ fullScreen: fullScreen,
174
+ customProps: customProps
170
175
  }, `template_Card_${mapData.id}_popup`);
171
176
  }
172
177
  };
@@ -6,7 +6,8 @@ const Select = props => {
6
6
  const {
7
7
  classes,
8
8
  data,
9
- onSelectTemplate
9
+ onSelectTemplate,
10
+ translation
10
11
  } = props;
11
12
  return /*#__PURE__*/_jsx(Box, {
12
13
  className: "template-card-action",
@@ -19,7 +20,7 @@ const Select = props => {
19
20
  children: /*#__PURE__*/_jsx(Button, {
20
21
  className: "blueBtn",
21
22
  onClick: onSelectTemplate(data),
22
- children: "Select"
23
+ children: translation("Select")
23
24
  })
24
25
  });
25
26
  };
@@ -27,8 +28,12 @@ const ButtonTemplateCard = props => {
27
28
  const {
28
29
  classes,
29
30
  m,
30
- onSelectTemplate
31
+ onSelectTemplate,
32
+ customProps
31
33
  } = props;
34
+ const {
35
+ translation
36
+ } = customProps;
32
37
  return /*#__PURE__*/_jsx(Grid, {
33
38
  item: true,
34
39
  xs: 3,
@@ -45,7 +50,8 @@ const ButtonTemplateCard = props => {
45
50
  }), /*#__PURE__*/_jsx(Select, {
46
51
  classes: classes,
47
52
  onSelectTemplate: onSelectTemplate,
48
- data: m
53
+ data: m,
54
+ translation: translation
49
55
  })]
50
56
  })
51
57
  })
@@ -6,7 +6,8 @@ const Select = props => {
6
6
  const {
7
7
  classes,
8
8
  data,
9
- onSelectTemplate
9
+ onSelectTemplate,
10
+ translation
10
11
  } = props;
11
12
  return /*#__PURE__*/_jsx(Box, {
12
13
  className: "template-card-action",
@@ -18,7 +19,7 @@ const Select = props => {
18
19
  children: /*#__PURE__*/_jsx(Button, {
19
20
  className: "blueBtn",
20
21
  onClick: onSelectTemplate(data),
21
- children: "Select"
22
+ children: translation("Select")
22
23
  })
23
24
  });
24
25
  };
@@ -27,8 +28,12 @@ const FullViewCard = props => {
27
28
  classes,
28
29
  m,
29
30
  onSelectTemplate,
30
- height = 'smallCard'
31
+ height = 'smallCard',
32
+ customProps
31
33
  } = props;
34
+ const {
35
+ translation
36
+ } = customProps;
32
37
  return /*#__PURE__*/_jsx(Grid, {
33
38
  item: true,
34
39
  xs: 12,
@@ -46,7 +51,8 @@ const FullViewCard = props => {
46
51
  }), /*#__PURE__*/_jsx(Select, {
47
52
  classes: classes,
48
53
  onSelectTemplate: onSelectTemplate,
49
- data: m
54
+ data: m,
55
+ translation: translation
50
56
  })]
51
57
  })
52
58
  })
@@ -11,9 +11,13 @@ function MiniColorPicker(props) {
11
11
  format,
12
12
  classes,
13
13
  id,
14
- editor
14
+ editor,
15
+ customProps
15
16
  } = props;
16
17
  const [openColorTool, setOpenColorTool] = useState(null);
18
+ const {
19
+ translation
20
+ } = customProps;
17
21
  return /*#__PURE__*/_jsxs("div", {
18
22
  children: [/*#__PURE__*/_jsxs(Button, {
19
23
  className: "fontColorBtn",
@@ -29,7 +33,7 @@ function MiniColorPicker(props) {
29
33
  activeMark: activeMark,
30
34
  editor: editor,
31
35
  showHex: false,
32
- title: "Text Color",
36
+ title: translation("Text Color"),
33
37
  id: id,
34
38
  classes: classes,
35
39
  forMiniTool: true,