@flozy/editor 11.2.3 → 11.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (145) hide show
  1. package/dist/Editor/ChatEditor.js +7 -7
  2. package/dist/Editor/CommonEditor.js +86 -24
  3. package/dist/Editor/DialogWrapper.js +31 -25
  4. package/dist/Editor/Editor.css +37 -4
  5. package/dist/Editor/Elements/AI/PopoverAIInput.js +11 -3
  6. package/dist/Editor/Elements/AppHeader/AppHeader.js +3 -3
  7. package/dist/Editor/Elements/Attachments/AttachmentStyles.js +16 -0
  8. package/dist/Editor/Elements/Attachments/Attachments.js +239 -11
  9. package/dist/Editor/Elements/Attachments/AttachmentsButton.js +11 -4
  10. package/dist/Editor/Elements/Button/EditorButton.js +32 -44
  11. package/dist/Editor/Elements/Color Picker/ColorButtons.js +61 -14
  12. package/dist/Editor/Elements/Color Picker/ColorPicker.css +25 -1
  13. package/dist/Editor/Elements/Color Picker/ColorPicker.js +10 -7
  14. package/dist/Editor/Elements/Color Picker/Styles.js +15 -13
  15. package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/Select.js +134 -55
  16. package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/SelectV1.js +7 -8
  17. package/dist/Editor/Elements/DataView/Layouts/DataTypes/PersonType.js +8 -3
  18. package/dist/Editor/Elements/DataView/Layouts/Options/EditProperty.js +1 -1
  19. package/dist/Editor/Elements/DataView/Layouts/TableStyles.js +1 -1
  20. package/dist/Editor/Elements/Embed/Embed.js +37 -43
  21. package/dist/Editor/Elements/Embed/Image.js +307 -26
  22. package/dist/Editor/Elements/Embed/Video.js +355 -35
  23. package/dist/Editor/Elements/EmbedScript/EmbedScriptPopup.js +9 -6
  24. package/dist/Editor/Elements/EmbedScript/styles.js +17 -1
  25. package/dist/Editor/Elements/Form/FormField.js +1 -1
  26. package/dist/Editor/Elements/Form/Workflow/Styles.js +25 -22
  27. package/dist/Editor/Elements/Form/Workflow/constant.js +25 -1
  28. package/dist/Editor/Elements/FreeGrid/FreeGrid.js +37 -76
  29. package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +9 -5
  30. package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +3 -1
  31. package/dist/Editor/Elements/FreeGrid/helper.js +194 -0
  32. package/dist/Editor/Elements/FreeGrid/styles.js +15 -0
  33. package/dist/Editor/Elements/Grid/GridItem.js +1 -1
  34. package/dist/Editor/Elements/PageSettings/PageSettingsButton.js +2 -1
  35. package/dist/Editor/Elements/Table/Table.js +2 -1
  36. package/dist/Editor/Elements/Table/TableCell.js +10 -3
  37. package/dist/Editor/Elements/Title/title.js +4 -5
  38. package/dist/Editor/Elements/TopBanner/TopBanner.js +4 -2
  39. package/dist/Editor/Elements/TopBanner/TopBannerButton.js +5 -3
  40. package/dist/Editor/Styles/EditorStyles.js +19 -5
  41. package/dist/Editor/Toolbar/FormatTools/Dropdown.js +27 -3
  42. package/dist/Editor/Toolbar/FormatTools/FontFamilyAutocomplete.js +4 -3
  43. package/dist/Editor/Toolbar/FormatTools/MarkButton.js +2 -2
  44. package/dist/Editor/Toolbar/FormatTools/TextSize.js +33 -29
  45. package/dist/Editor/Toolbar/Mini/MiniToolbar.js +2 -1
  46. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/MiniColorPicker.js +3 -1
  47. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectFontSize.js +25 -23
  48. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectTypography.js +167 -42
  49. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +15 -5
  50. package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +2 -1
  51. package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +65 -7
  52. package/dist/Editor/Toolbar/PopupTool/TextFormat.js +66 -12
  53. package/dist/Editor/Toolbar/PopupTool/ThemeTextFormat.js +439 -0
  54. package/dist/Editor/Toolbar/PopupTool/index.js +6 -4
  55. package/dist/Editor/Toolbar/toolbarGroups.js +48 -6
  56. package/dist/Editor/assets/svg/BackIcon.js +18 -0
  57. package/dist/Editor/assets/svg/ThemeIcons.js +293 -0
  58. package/dist/Editor/common/ColorPickerButton.js +38 -19
  59. package/dist/Editor/common/CustomColorPicker/index.js +130 -0
  60. package/dist/Editor/common/CustomColorPicker/style.js +53 -0
  61. package/dist/Editor/common/CustomDialog2/index.js +94 -0
  62. package/dist/Editor/common/CustomDialog2/style.js +67 -0
  63. package/dist/Editor/common/CustomSelect.js +43 -0
  64. package/dist/Editor/common/DnD/DragHandleButton.js +1 -1
  65. package/dist/Editor/common/FontLoader/FontLoader.js +1 -0
  66. package/dist/Editor/common/Icon.js +28 -0
  67. package/dist/Editor/common/ImageSelector/ImageSelector.js +66 -13
  68. package/dist/Editor/common/ImageSelector/Options/ChooseAssets.js +1 -1
  69. package/dist/Editor/common/ImageSelector/Options/RecentUploads.js +483 -0
  70. package/dist/Editor/common/ImageSelector/Options/Upload.js +26 -11
  71. package/dist/Editor/common/ImageSelector/Styles.js +3 -9
  72. package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +2 -1
  73. package/dist/Editor/common/RnD/ElementSettings/Settings/AppHeaderSettings.js +3 -2
  74. package/dist/Editor/common/RnD/ElementSettings/Settings/BoxSettings.js +3 -2
  75. package/dist/Editor/common/RnD/ElementSettings/Settings/ButtonSettings.js +3 -2
  76. package/dist/Editor/common/RnD/ElementSettings/Settings/CodeSettings.js +3 -2
  77. package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +3 -2
  78. package/dist/Editor/common/RnD/ElementSettings/Settings/ImageSettings.js +20 -7
  79. package/dist/Editor/common/RnD/ElementSettings/Settings/TableSettings.js +3 -2
  80. package/dist/Editor/common/RnD/ElementSettings/Settings/TextSettings.js +2 -0
  81. package/dist/Editor/common/RnD/ElementSettings/Settings/VideoSettings.js +20 -7
  82. package/dist/Editor/common/RnD/GuideLines/styles.js +1 -1
  83. package/dist/Editor/common/RnD/Theme/MainThemeProvider.js +17 -0
  84. package/dist/Editor/common/RnD/Theme/ViewportStimulator.js +6 -3
  85. package/dist/Editor/common/RnD/Utils/gridDropItem.js +28 -11
  86. package/dist/Editor/common/RnD/Utils/index.js +3 -1
  87. package/dist/Editor/common/RnD/VirtualElement/VirtualTextElement.js +52 -63
  88. package/dist/Editor/common/RnD/VirtualElement/helper.js +248 -68
  89. package/dist/Editor/common/RnD/VirtualElement/styles.js +22 -0
  90. package/dist/Editor/common/RnD/index.js +61 -14
  91. package/dist/Editor/common/Shorthands/elements.js +55 -3
  92. package/dist/Editor/common/StyleBuilder/buttonStyle.js +5 -15
  93. package/dist/Editor/common/StyleBuilder/embedVideoStyle.js +4 -0
  94. package/dist/Editor/common/StyleBuilder/fieldStyle.js +1 -0
  95. package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +13 -3
  96. package/dist/Editor/common/StyleBuilder/fieldTypes/bannerSpacing.js +12 -2
  97. package/dist/Editor/common/StyleBuilder/fieldTypes/borderRadius.js +15 -7
  98. package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +36 -10
  99. package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +13 -4
  100. package/dist/Editor/common/StyleBuilder/fieldTypes/menusArray.js +2 -0
  101. package/dist/Editor/common/StyleBuilder/fieldTypes/text.js +16 -4
  102. package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +15 -7
  103. package/dist/Editor/common/StyleBuilder/formStyle.js +19 -13
  104. package/dist/Editor/common/StyleBuilder/index.js +10 -19
  105. package/dist/Editor/common/Uploader.js +118 -17
  106. package/dist/Editor/common/UploaderWithProgress.js +183 -0
  107. package/dist/Editor/common/iconslist.js +21 -0
  108. package/dist/Editor/commonStyle.js +111 -53
  109. package/dist/Editor/helper/index.js +4 -1
  110. package/dist/Editor/helper/theme.js +203 -2
  111. package/dist/Editor/hooks/useEditorTheme.js +153 -0
  112. package/dist/Editor/hooks/useMouseMove.js +12 -3
  113. package/dist/Editor/hooks/useTable.js +62 -1
  114. package/dist/Editor/hooks/useThemeValues.js +63 -0
  115. package/dist/Editor/plugins/withEmbeds.js +1 -1
  116. package/dist/Editor/plugins/withHTML.js +56 -3
  117. package/dist/Editor/plugins/withTable.js +1 -1
  118. package/dist/Editor/service/fileTracking.js +22 -0
  119. package/dist/Editor/service/fileupload.js +77 -0
  120. package/dist/Editor/theme/ThemeList.js +50 -173
  121. package/dist/Editor/theme/index.js +149 -0
  122. package/dist/Editor/themeSettings/ActiveTheme.js +82 -0
  123. package/dist/Editor/themeSettings/buttons/index.js +300 -0
  124. package/dist/Editor/themeSettings/buttons/style.js +23 -0
  125. package/dist/Editor/themeSettings/colorTheme/index.js +310 -0
  126. package/dist/Editor/themeSettings/colorTheme/style.js +81 -0
  127. package/dist/Editor/themeSettings/fonts/PreviewElement.js +121 -0
  128. package/dist/Editor/themeSettings/fonts/index.js +240 -0
  129. package/dist/Editor/themeSettings/fonts/style.js +62 -0
  130. package/dist/Editor/themeSettings/icons.js +60 -0
  131. package/dist/Editor/themeSettings/index.js +380 -0
  132. package/dist/Editor/themeSettings/style.js +299 -0
  133. package/dist/Editor/themeSettingsAI/icons.js +96 -0
  134. package/dist/Editor/themeSettingsAI/index.js +355 -0
  135. package/dist/Editor/themeSettingsAI/saveTheme.js +202 -0
  136. package/dist/Editor/themeSettingsAI/style.js +332 -0
  137. package/dist/Editor/utils/SlateUtilityFunctions.js +165 -40
  138. package/dist/Editor/utils/accordion.js +1 -1
  139. package/dist/Editor/utils/attachments.js +138 -2
  140. package/dist/Editor/utils/button.js +1 -17
  141. package/dist/Editor/utils/font.js +40 -37
  142. package/dist/Editor/utils/formfield.js +2 -2
  143. package/dist/Editor/utils/helper.js +101 -3
  144. package/dist/Editor/utils/insertAppHeader.js +8 -4
  145. package/package.json +1 -1
@@ -7,7 +7,7 @@ import { Node } from "slate";
7
7
  const HIDE_PLACHOLDERS = ["grid", "grid-item", "table"];
8
8
  const TEXT_NODES = ["paragraph", "headingOne", "headingTwo", "headingThree"];
9
9
  const PREVIEW_IMAGE_HIDE_CLASS = ["grid-container-toolbar", "grid-item-toolbar", "element-toolbar", "mini-tool-wrpr-ei", "element-selector", "element-selector-ctrl"];
10
- const RND_ITEMS = ["freegridItem", "freegridBox"];
10
+ export const RND_ITEMS = ["freegridItem", "freegridBox"];
11
11
  export const getThumbnailImage = async (dom, options = {}) => {
12
12
  try {
13
13
  const canvas = await html2canvas(dom, {
@@ -99,6 +99,9 @@ function padZero(str, len) {
99
99
  return (zeros + str).slice(-len);
100
100
  }
101
101
  export function getEmbedURL(element, needType = false) {
102
+ if (typeof element?.href !== "string" && typeof element?.url !== "string") {
103
+ return null;
104
+ }
102
105
  let refUrl = element.href ? element.href : element.url;
103
106
  refUrl = refUrl ? refUrl.includes("http") ? refUrl : `//${refUrl}` : "Link";
104
107
  let embedUrl = refUrl;
@@ -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,197 @@ 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
+ const fontSize = getElementProperty(element, "font-size");
151
+ return fontSize || 16;
152
+ }
153
+ } catch (err) {
154
+ // console.log(err);
155
+ }
156
+ }
157
+ export function getVariableValue(val) {
158
+ const bodyElement = document.body;
159
+ const computedStyle = getComputedStyle(bodyElement);
160
+ const [, variableName] = val?.match(/var\((--[^)]+)\)/) || [];
161
+ const varValue = computedStyle.getPropertyValue(variableName).trim();
162
+ return varValue;
163
+ }
164
+ const MAP_PROPERTY_KEYS = {
165
+ fontFamily: "font-family",
166
+ fontSize: "font-size",
167
+ textSize: "font-size",
168
+ fontWeight: "font-weight",
169
+ color: "color",
170
+ bgColor: "background-color"
171
+ };
172
+ export function getElementProperty(element, styleProperty) {
173
+ if (!element) {
174
+ return "";
175
+ }
176
+ const computedStyle = window.getComputedStyle(element);
177
+ const property = MAP_PROPERTY_KEYS[styleProperty] || styleProperty;
178
+ let style = computedStyle.getPropertyValue(property);
179
+ if (property === "font-family") {
180
+ style = style.replace(/"/g, ""); // remove double quotes if exists e.g: '"Courier New"'
181
+ }
182
+
183
+ return style || "";
184
+ }
185
+ export const textThemeFields = ["fontFamily", "fontSize", "color", "bold", "italic", "fontWeight"
186
+ // "underline",
187
+ // "strikethrough",
188
+ ];
189
+
190
+ const themeElements = ["headingOne", "headingTwo", "headingThree", "headingFour", "headingFive", "headingSix", "paragraphOne", "paragraphTwo", "paragraphThree"];
191
+ export const isTextCustomized = editor => {
192
+ try {
193
+ if (editor.selection) {
194
+ const currentElement = Node.parent(editor, editor?.selection?.anchor?.path);
195
+ if (!currentElement) {
196
+ return false;
197
+ }
198
+ const {
199
+ children,
200
+ type
201
+ } = currentElement;
202
+ if (!themeElements.includes(type)) {
203
+ return false;
204
+ }
205
+ if (!children?.length) {
206
+ return true;
207
+ }
208
+ const customized = textThemeFields.some(field => {
209
+ const element = children.find(child => child.text.trim() !== "") || {};
210
+ const value = element[field];
211
+ if (field === "fontSize") {
212
+ return Object.keys(value || {}).length;
213
+ } else {
214
+ return value;
215
+ }
216
+ });
217
+ return customized;
218
+ } else {
219
+ return null;
220
+ }
221
+ } catch (err) {
222
+ return null;
223
+ }
224
+ };
225
+ const addToTheme = (field, value, element) => {
226
+ switch (field) {
227
+ case "fontFamily":
228
+ return {
229
+ fontFamily: value
230
+ };
231
+ case "fontSize":
232
+ return {
233
+ fontSize: value?.lg
234
+ };
235
+ case "color":
236
+ return {
237
+ color: value
238
+ };
239
+ case "bold":
240
+ return {
241
+ fontWeight: "bold"
242
+ };
243
+ case "italic":
244
+ return {
245
+ fontStyle: "italic"
246
+ };
247
+ // case "underline":
248
+ // case "strikethrough":
249
+ // let textDecoration = "";
250
+
251
+ // if (element.underline) {
252
+ // textDecoration = "underline";
253
+ // }
254
+
255
+ // if (element.strikethrough) {
256
+ // textDecoration += " strikethrough";
257
+ // }
258
+
259
+ // return { textDecoration };
260
+ default:
261
+ return {};
262
+ }
263
+ };
264
+ const MAP_TEXT_THEME_FIELD = {
265
+ headingOne: "h1",
266
+ headingTwo: "h2",
267
+ headingThree: "h3",
268
+ headingFour: "h4",
269
+ headingFive: "h5",
270
+ headingSix: "h6",
271
+ paragraphOne: "para1",
272
+ paragraphTwo: "para2",
273
+ paragraphThree: "para3"
274
+ };
275
+ export const saveToTheme = editor => {
276
+ try {
277
+ if (editor.selection) {
278
+ const currentElement = Node.parent(editor, editor?.selection?.anchor?.path);
279
+ if (!currentElement) {
280
+ return false;
281
+ }
282
+ const {
283
+ children
284
+ } = currentElement;
285
+ if (!children?.length) {
286
+ return true;
287
+ }
288
+ let theme = {};
289
+ textThemeFields.forEach(field => {
290
+ const element = children.find(child => child.text.trim() !== "") || {};
291
+ const value = element[field];
292
+ let style = {};
293
+ let isValueExist = false;
294
+ if (value) {
295
+ isValueExist = true;
296
+ if (field === "fontSize") {
297
+ isValueExist = !!Object.keys(value).length;
298
+ }
299
+ }
300
+ if (isValueExist) {
301
+ style = addToTheme(field, value, element);
302
+ }
303
+ theme = {
304
+ ...theme,
305
+ ...style
306
+ };
307
+ });
308
+ textThemeFields.forEach(field => {
309
+ Editor.removeMark(editor, field);
310
+ });
311
+ return {
312
+ field: MAP_TEXT_THEME_FIELD[currentElement?.type],
313
+ theme
314
+ };
315
+ }
316
+ } catch (err) {
317
+ return;
318
+ }
319
+ };
320
+ export const HEADING_THEME_FIELDS = ["h1", "h2", "h3", "h4", "h5", "h6"];
321
+ export const PARAGRAPH_THEME_FIELDS = ["para1", "para2", "para3"];
121
322
  export const getBRValue = (props, rbr = "lg") => {
122
323
  const {
123
324
  value,
@@ -0,0 +1,153 @@
1
+ import { useSlate } from "slate-react";
2
+ import { defaultTheme } from "../theme";
3
+ import { getPageSettings, updatePageSettings } from "../utils/pageSettings";
4
+ import { HEADING_THEME_FIELDS, PARAGRAPH_THEME_FIELDS } from "../helper/theme";
5
+ import { useEditorContext } from "./useMouseMove";
6
+ const MAP_FIELDS = {
7
+ HEADING: HEADING_THEME_FIELDS,
8
+ PARAGRAPH: PARAGRAPH_THEME_FIELDS
9
+ };
10
+ const MAP_FONT_FIELD_KEYS = {
11
+ HEADING: "headingFontFamily",
12
+ PARAGRAPH: "paragraphFontFamily"
13
+ };
14
+ function getUpdatePayload(prevTheme = {}, update, actionData) {
15
+ const {
16
+ action,
17
+ fieldName
18
+ } = actionData || {};
19
+ const {
20
+ theme: prev
21
+ } = prevTheme;
22
+ let theme = {};
23
+ let themeProps = {};
24
+ switch (action) {
25
+ case "THEME_CHANGE":
26
+ theme = update;
27
+ break;
28
+ case "CSS_VAR_CHANGE":
29
+ const prevCssVars = prev?.cssVars || {};
30
+ const prevValue = prevCssVars[fieldName] || {};
31
+ themeProps = {
32
+ ...(prev || {}),
33
+ cssVars: {
34
+ ...prevCssVars,
35
+ [fieldName]: {
36
+ ...prevValue,
37
+ ...update
38
+ }
39
+ }
40
+ };
41
+ theme = {
42
+ ...prevTheme,
43
+ theme: themeProps
44
+ };
45
+ break;
46
+ case "ELEMENT_PROPS_CHANGE":
47
+ const prevEleProps = prev?.elementProps || {};
48
+ const prevEleValue = prevEleProps[fieldName] || {};
49
+ themeProps = {
50
+ ...(prev || {}),
51
+ elementProps: {
52
+ ...prevEleProps,
53
+ [fieldName]: {
54
+ ...prevEleValue,
55
+ ...update
56
+ }
57
+ }
58
+ };
59
+ theme = {
60
+ ...prevTheme,
61
+ theme: themeProps
62
+ };
63
+ break;
64
+ case "OTHER_PROPS_CHANGE":
65
+ themeProps = {
66
+ ...(prev || {}),
67
+ otherProps: {
68
+ ...(prev.otherProps || {}),
69
+ ...update
70
+ }
71
+ };
72
+ theme = {
73
+ ...prevTheme,
74
+ theme: themeProps
75
+ };
76
+ break;
77
+ case "FONT_CHANGE":
78
+ const {
79
+ elementProps = {},
80
+ otherProps = {}
81
+ } = prev;
82
+ const {
83
+ fieldType
84
+ } = actionData || {};
85
+ const fields = MAP_FIELDS[fieldType];
86
+ const fontFieldsUpdate = {};
87
+ fields?.forEach(field => {
88
+ const prevFieldData = elementProps[field];
89
+ fontFieldsUpdate[field] = {
90
+ ...prevFieldData,
91
+ ...update
92
+ };
93
+ });
94
+ const FONT_KEY_FOR_FIELD = MAP_FONT_FIELD_KEYS[fieldType];
95
+ themeProps = {
96
+ ...(prev || {}),
97
+ elementProps: {
98
+ ...elementProps,
99
+ ...fontFieldsUpdate
100
+ },
101
+ otherProps: {
102
+ ...otherProps,
103
+ [FONT_KEY_FOR_FIELD]: update?.fontFamily
104
+ }
105
+ };
106
+ theme = {
107
+ ...prevTheme,
108
+ theme: themeProps
109
+ };
110
+ break;
111
+ default:
112
+ theme = {
113
+ ...prevTheme,
114
+ ...(update || {})
115
+ };
116
+ break;
117
+ }
118
+ return theme;
119
+ }
120
+ const updateTheme = (editor, pageSt, update, actionData, triggerRender) => {
121
+ const {
122
+ pageProps
123
+ } = pageSt || {};
124
+ const {
125
+ theme
126
+ } = pageProps || {};
127
+ const updatedTheme = getUpdatePayload(theme, update, actionData);
128
+ updatePageSettings(editor, {
129
+ ...(pageProps || {}),
130
+ theme: updatedTheme
131
+ });
132
+ triggerRender();
133
+ };
134
+ export const useEditorTheme = () => {
135
+ const editor = useSlate();
136
+ const {
137
+ triggerRender
138
+ } = useEditorContext();
139
+ const {
140
+ element: pageSt
141
+ } = getPageSettings(editor) || {};
142
+ const {
143
+ pageProps
144
+ } = pageSt || {};
145
+ const {
146
+ theme
147
+ } = pageProps || {};
148
+ return {
149
+ selectedTheme: theme?.theme || defaultTheme()?.theme,
150
+ updateTheme: (update, actionData) => updateTheme(editor, pageSt, update, actionData, triggerRender),
151
+ theme
152
+ };
153
+ };
@@ -21,7 +21,10 @@ export const useEditorSelection = editor => {
21
21
  export const EditorProvider = ({
22
22
  editor,
23
23
  theme,
24
- children
24
+ children,
25
+ openTheme = false,
26
+ setOpenTheme = () => {},
27
+ triggerRender
25
28
  }) => {
26
29
  const [previous, setPrevious] = useState("");
27
30
  const [drop, setDrop] = useState(0);
@@ -36,6 +39,7 @@ export const EditorProvider = ({
36
39
  path: null
37
40
  });
38
41
  const [fontFamilies, setFontFamilies] = useState(defaultFontFamilies);
42
+ const [activeBreakPoint, setActiveBreakPoint] = useState("");
39
43
  useEffect(() => {
40
44
  window.updateSelectedItem = d => {
41
45
  setSelectedElement(d);
@@ -98,8 +102,13 @@ export const EditorProvider = ({
98
102
  setOpenAI,
99
103
  updateDragging,
100
104
  fontFamilies,
101
- setFontFamilies
102
- }), [path, editor?.selection, selectedPath, selectedElement, contextMenu, openAI, popupType, drop]);
105
+ setFontFamilies,
106
+ openTheme,
107
+ setOpenTheme,
108
+ activeBreakPoint,
109
+ setActiveBreakPoint,
110
+ triggerRender
111
+ }), [path, editor?.selection, selectedPath, selectedElement, contextMenu, openAI, popupType, drop, openTheme, activeBreakPoint]);
103
112
  return /*#__PURE__*/_jsx(EditorContext.Provider, {
104
113
  value: otherValues,
105
114
  children: children
@@ -25,6 +25,63 @@ import { createCopiedTableStructure, getRectangleBounds, tableNodeToDom } from "
25
25
  // };
26
26
  import { jsx as _jsx } from "react/jsx-runtime";
27
27
  import { jsxs as _jsxs } from "react/jsx-runtime";
28
+ function moveToAdjacentTableCell(editor, reverse = false, otherProps, tableSelection, updateTableSelection) {
29
+ try {
30
+ const {
31
+ startCellPath,
32
+ endCellPath
33
+ } = tableSelection;
34
+ if (startCellPath && startCellPath.toString() === endCellPath.toString()) {
35
+ const {
36
+ tableNode,
37
+ tablePath
38
+ } = otherProps;
39
+ const cellPath = startCellPath.slice(tablePath.length - 1);
40
+ const rows = tableNode.children;
41
+ const currentRowIndex = cellPath[1];
42
+ const currentColIndex = cellPath[2];
43
+ const numRows = rows.length;
44
+ const numCols = rows[0]?.children?.length || 0;
45
+
46
+ // Calculate new indices
47
+ let newRowIndex = currentRowIndex;
48
+ let newColIndex = currentColIndex;
49
+ if (reverse) {
50
+ // ALT + TAB: Go to previous cell
51
+ if (currentColIndex > 0) {
52
+ newColIndex--;
53
+ } else if (currentRowIndex > 0) {
54
+ newRowIndex--;
55
+ newColIndex = rows[newRowIndex].children.length - 1;
56
+ } else {
57
+ return; // At first cell, do nothing
58
+ }
59
+ } else {
60
+ // TAB: Go to next cell
61
+ if (currentColIndex < numCols - 1) {
62
+ newColIndex++;
63
+ } else if (currentRowIndex < numRows - 1) {
64
+ newRowIndex++;
65
+ newColIndex = 0;
66
+ } else {
67
+ return; // At last cell, do nothing
68
+ }
69
+ }
70
+
71
+ const nextCellPath = [...tablePath, newRowIndex, newColIndex];
72
+
73
+ // Move the selection into the next cell
74
+ Transforms.select(editor, Editor.start(editor, nextCellPath));
75
+ updateTableSelection({
76
+ startCellPath: nextCellPath,
77
+ endCellPath: nextCellPath,
78
+ isDragging: false
79
+ });
80
+ }
81
+ } catch (err) {
82
+ console.log("Error on pressing tab in table", err);
83
+ }
84
+ }
28
85
  const handleDragEnd = (dragData, editor, resetAll) => {
29
86
  const {
30
87
  active,
@@ -127,7 +184,11 @@ export const TableProvider = ({
127
184
  let isTextSelected;
128
185
  const handleKeyDown = event => {
129
186
  const isCutKey = (event.ctrlKey || event.metaKey) && event.key === "x";
130
- if (isCutKey) {
187
+ if (event.key === "Tab") {
188
+ event.preventDefault();
189
+ const isReverse = event.shiftKey;
190
+ moveToAdjacentTableCell(editor, isReverse, otherProps, tableSelection, updateTableSelection);
191
+ } else if (isCutKey) {
131
192
  isTextSelected = isHavingSelection(editor);
132
193
  } else if (event.key === "Backspace") {
133
194
  const selectedCells = getSelectedCells();
@@ -0,0 +1,63 @@
1
+ import { useEffect, useState } from "react";
2
+ import { getElementProperty } from "../helper/theme";
3
+ import { ReactEditor } from "slate-react";
4
+ import { Node } from "slate";
5
+ import { useEditorTheme } from "./useEditorTheme";
6
+ function useThemeValues() {
7
+ return {};
8
+ }
9
+ export default useThemeValues;
10
+ export function useButtonStyle(value, key, element) {
11
+ const [buttonStyle, setButtonStyle] = useState(value);
12
+ const {
13
+ selectedTheme
14
+ } = useEditorTheme();
15
+ const themeBtnProps = selectedTheme?.elementProps?.button || {};
16
+ useEffect(() => {
17
+ const color = getColorValue(value, key, element, themeBtnProps);
18
+ setButtonStyle({
19
+ color
20
+ });
21
+ }, [value, key, element]);
22
+ return {
23
+ buttonStyle
24
+ };
25
+ }
26
+ const DEFAULT_MAP_THEMES = {
27
+ textColor: "color",
28
+ bgColor: "backgroundColor"
29
+ };
30
+ const hoverMap = (theme, format) => {
31
+ const hover = theme?.hover || {};
32
+ const key = DEFAULT_MAP_THEMES[format];
33
+ return hover[key];
34
+ };
35
+ const MAP_THEME_KEYS = {
36
+ ...DEFAULT_MAP_THEMES,
37
+ textColorHover: hoverMap,
38
+ bgColorHover: hoverMap
39
+ };
40
+ const getColorValue = (val, key, elementProps, themeBtnProps) => {
41
+ const themeKey = MAP_THEME_KEYS[key];
42
+ if (elementProps?.type === "button" && !val && themeKey) {
43
+ if (typeof themeKey === "string") {
44
+ return themeBtnProps[themeKey];
45
+ } else {
46
+ return themeKey(themeBtnProps, key);
47
+ }
48
+ }
49
+ return val;
50
+ };
51
+ export function getButtonElementStyle(editor, element, stylePropertyName) {
52
+ try {
53
+ const path = ReactEditor.findPath(editor, element);
54
+ if (path?.length) {
55
+ const currentEle = Node.get(editor, path);
56
+ const dom = ReactEditor.toDOMNode(editor, currentEle);
57
+ const editorBtn = dom?.querySelector(".button.theme-element");
58
+ return getElementProperty(editorBtn, stylePropertyName);
59
+ }
60
+ } catch (err) {
61
+ // console.log(err);
62
+ }
63
+ }
@@ -1,5 +1,5 @@
1
1
  import { Transforms, Path, Node } from "slate";
2
- const AvoidCopying = ["headingOne", "headingTwo", "headingThree", "blockquote"];
2
+ const AvoidCopying = ["headingOne", "headingTwo", "headingThree", "headingFour", "headingFive", "headingSix", "paragraphOne", "paragraphTwo", "paragraphThree", "blockquote"];
3
3
  const BlockTypes = ["grid"];
4
4
  const withEmbeds = editor => {
5
5
  const {
@@ -3,7 +3,7 @@ import deserialize from "../helper/deserialize";
3
3
  import { decodeAndParseBase64 } from "../utils/helper";
4
4
  import convertMDToHTML from "../helper/markdown";
5
5
  const avoidDefaultInsert = ["table", "grid"];
6
- const NON_TEXT_TAGS = ["ol", "ul", "img", "table", "video", "a", "button", "GOOGLE-SHEETS-HTML-ORIGIN"];
6
+ const NON_TEXT_TAGS = ["ol", "ul", "img", "table", "video", "a", "button", "GOOGLE-SHEETS-HTML-ORIGIN", "hr"];
7
7
  const ALLOWED_TEXT_NODES = ["paragraph", "title", "headingOne", "headingTwo", "headingThree", "headingFour", "headingFive", "headingSix"];
8
8
  const parseCopiedHTML = html => {
9
9
  const parsed = new DOMParser().parseFromString(html, "text/html");
@@ -56,7 +56,7 @@ const loopChildren = (children = [], defaultInsert) => {
56
56
  }
57
57
  return defaultInsert;
58
58
  };
59
- const getCurrentElement = editor => {
59
+ export const getCurrentElement = editor => {
60
60
  try {
61
61
  if (editor.selection) {
62
62
  return Node.parent(editor, editor?.selection?.anchor?.path);
@@ -151,6 +151,52 @@ const getFocusedNode = (editor, nodeType = "") => {
151
151
  }
152
152
  };
153
153
  const voidTypes = ["image", "page-settings"];
154
+
155
+ // 🧠 Split the fragment into first text and rest
156
+ const splitFragment = fragment => {
157
+ let found = false;
158
+ let firstText = "";
159
+ const rest = [];
160
+ for (const node of fragment) {
161
+ if (found) {
162
+ rest.push(node);
163
+ continue;
164
+ }
165
+ const textNodeEntry = [...Node.texts(node)].find(([n]) => n.text.trim().length > 0);
166
+ if (textNodeEntry) {
167
+ const [textNode, path] = textNodeEntry;
168
+ firstText = textNode.text;
169
+
170
+ // Remove the first text node from the node
171
+ const cloned = JSON.parse(JSON.stringify(node));
172
+ let pointer = cloned;
173
+ for (let i = 0; i < path.length - 1; i++) {
174
+ pointer = pointer.children[path[i]];
175
+ }
176
+
177
+ // Remove the first text portion or replace with remaining text
178
+ const index = path[path.length - 1];
179
+ // const original = pointer.children[index];
180
+ // const remainingText = original.text.slice(firstText.length);
181
+
182
+ // if (remainingText) {
183
+ // pointer.children[index] = { ...original, text: remainingText };
184
+ // } else {
185
+ // pointer.children.splice(index, 1);
186
+ // }
187
+
188
+ pointer.children.splice(index, 1);
189
+ if (cloned.children.length > 0) {
190
+ rest.push(cloned);
191
+ }
192
+ found = true;
193
+ } else {
194
+ rest.push(node); // fallback
195
+ }
196
+ }
197
+
198
+ return [firstText, rest];
199
+ };
154
200
  const withHtml = editor => {
155
201
  const {
156
202
  insertData,
@@ -278,7 +324,14 @@ const withHtml = editor => {
278
324
  const firstNodePasted = formattedFragment[0];
279
325
  const isAllowedTextNode = ALLOWED_TEXT_NODES.includes(firstNodePasted?.type || "");
280
326
  if (isAllowedTextNode) {
281
- Transforms.insertFragment(editor, formattedFragment);
327
+ const [firstText, remainingFragment] = splitFragment(fragment);
328
+ Transforms.insertFragment(editor, [{
329
+ text: firstText
330
+ }]);
331
+ insertAtNextNode(editor, remainingFragment);
332
+ if (editor.getTitleSaveData) {
333
+ editor.getTitleSaveData(firstText);
334
+ }
282
335
  } else {
283
336
  insertAtNextNode(editor, formattedFragment);
284
337
  }
@@ -1,6 +1,6 @@
1
1
  import { Editor, Range, Point, Element, Transforms, Node } from "slate";
2
2
  import { TableUtil, createTableCell } from "../utils/table";
3
- const NON_DELETABLE_BLOCKS = ["table-cell", "carousel-item"];
3
+ const NON_DELETABLE_BLOCKS = ["table-cell", "carousel-item", "page-settings"];
4
4
  const withTable = editor => {
5
5
  const {
6
6
  deleteBackward,