@flozy/editor 10.6.5 → 10.6.6

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 (173) hide show
  1. package/dist/Editor/ChatEditor.js +17 -16
  2. package/dist/Editor/CommonEditor.js +133 -14
  3. package/dist/Editor/DialogWrapper.js +31 -25
  4. package/dist/Editor/Editor.css +57 -11
  5. package/dist/Editor/Elements/AI/PopoverAIInput.js +11 -3
  6. package/dist/Editor/Elements/AI/Styles.js +1 -0
  7. package/dist/Editor/Elements/Accordion/Accordion.js +45 -9
  8. package/dist/Editor/Elements/Accordion/AccordionSummary.js +1 -23
  9. package/dist/Editor/Elements/AppHeader/AppHeader.js +10 -5
  10. package/dist/Editor/Elements/Button/EditorButton.js +26 -10
  11. package/dist/Editor/Elements/Carousel/CarouselItem.js +2 -1
  12. package/dist/Editor/Elements/Color Picker/ColorButtons.js +61 -14
  13. package/dist/Editor/Elements/Color Picker/ColorPicker.css +25 -1
  14. package/dist/Editor/Elements/Color Picker/ColorPicker.js +10 -7
  15. package/dist/Editor/Elements/Color Picker/Styles.js +15 -13
  16. package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/{MultiSelect.js → SelectV1.js} +125 -69
  17. package/dist/Editor/Elements/DataView/Layouts/DataTypes/MultiSelectType.js +10 -10
  18. package/dist/Editor/Elements/DataView/Layouts/DataTypes/SelectType.js +28 -9
  19. package/dist/Editor/Elements/DataView/Layouts/Options/AddOptions.js +12 -5
  20. package/dist/Editor/Elements/DataView/Layouts/Options/EditOption.js +40 -14
  21. package/dist/Editor/Elements/Divider/Divider.js +1 -1
  22. package/dist/Editor/Elements/Embed/Embed.css +4 -0
  23. package/dist/Editor/Elements/Embed/Video.js +1 -1
  24. package/dist/Editor/Elements/Form/Form.js +3 -3
  25. package/dist/Editor/Elements/Form/FormElements/FormTextArea.js +0 -1
  26. package/dist/Editor/Elements/Form/FormField.js +1 -1
  27. package/dist/Editor/Elements/Form/Workflow/Styles.js +24 -22
  28. package/dist/Editor/Elements/FreeGrid/FreeGrid.js +35 -31
  29. package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +7 -4
  30. package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +1 -0
  31. package/dist/Editor/Elements/FreeGrid/Options/More.js +7 -7
  32. package/dist/Editor/Elements/FreeGrid/Options/sectionItemOptions.js +1 -1
  33. package/dist/Editor/Elements/FreeGrid/helper.js +115 -0
  34. package/dist/Editor/Elements/FreeGrid/styles.js +9 -0
  35. package/dist/Editor/Elements/Grid/Grid.js +14 -2
  36. package/dist/Editor/Elements/Grid/GridItem.js +1 -1
  37. package/dist/Editor/Elements/Signature/Signature.css +2 -1
  38. package/dist/Editor/Elements/Signature/SignatureOptions/DrawSignature.js +18 -5
  39. package/dist/Editor/Elements/Signature/SignatureOptions/UploadSignature.js +16 -3
  40. package/dist/Editor/Elements/SimpleText/style.js +2 -2
  41. package/dist/Editor/Elements/Table/AddRowCol.js +8 -2
  42. package/dist/Editor/Elements/Table/DragButton.js +0 -1
  43. package/dist/Editor/Elements/Table/Draggable.js +6 -2
  44. package/dist/Editor/Elements/Table/Styles.js +7 -0
  45. package/dist/Editor/Elements/Table/Table.js +3 -3
  46. package/dist/Editor/Elements/Table/TableCell.js +24 -5
  47. package/dist/Editor/Elements/Title/title.js +8 -11
  48. package/dist/Editor/Elements/Variables/VariableButton.js +10 -1
  49. package/dist/Editor/MiniEditor.js +2 -1
  50. package/dist/Editor/Styles/EditorStyles.js +4 -4
  51. package/dist/Editor/Toolbar/FormatTools/Dropdown.js +27 -3
  52. package/dist/Editor/Toolbar/FormatTools/FontFamilyAutocomplete.js +4 -3
  53. package/dist/Editor/Toolbar/FormatTools/MarkButton.js +2 -2
  54. package/dist/Editor/Toolbar/FormatTools/TextSize.js +10 -13
  55. package/dist/Editor/Toolbar/Mini/MiniToolbar.js +2 -1
  56. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/MiniColorPicker.js +4 -2
  57. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectFontSize.js +6 -13
  58. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectTypography.js +167 -42
  59. package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +7 -4
  60. package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +2 -1
  61. package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +73 -13
  62. package/dist/Editor/Toolbar/PopupTool/TextFormat.js +58 -10
  63. package/dist/Editor/Toolbar/PopupTool/ThemeTextFormat.js +439 -0
  64. package/dist/Editor/Toolbar/PopupTool/index.js +12 -5
  65. package/dist/Editor/Toolbar/toolbarGroups.js +48 -6
  66. package/dist/Editor/assets/svg/BackIcon.js +18 -0
  67. package/dist/Editor/assets/svg/ThemeIcons.js +293 -0
  68. package/dist/Editor/common/Checkbox/index.js +46 -0
  69. package/dist/Editor/common/Checkbox/styles.js +45 -0
  70. package/dist/Editor/common/ColorPickerButton.js +41 -16
  71. package/dist/Editor/common/CustomColorPicker/index.js +130 -0
  72. package/dist/Editor/common/CustomColorPicker/style.js +53 -0
  73. package/dist/Editor/common/CustomDialog2/index.js +94 -0
  74. package/dist/Editor/common/CustomDialog2/style.js +67 -0
  75. package/dist/Editor/common/CustomSelect.js +43 -0
  76. package/dist/Editor/common/DnD/DragHandleButton.js +1 -1
  77. package/dist/Editor/common/FontLoader/FontLoader.js +3 -0
  78. package/dist/Editor/common/Icon.js +28 -0
  79. package/dist/Editor/common/ImageSelector/ImageSelector.js +2 -2
  80. package/dist/Editor/common/ImageSelector/Styles.js +3 -9
  81. package/dist/Editor/common/LinkSettings/NavComponents.js +47 -63
  82. package/dist/Editor/common/LinkSettings/index.js +17 -28
  83. package/dist/Editor/common/LinkSettings/navOptions.js +2 -2
  84. package/dist/Editor/common/LinkSettings/style.js +164 -244
  85. package/dist/Editor/common/RadioGroup/index.js +48 -0
  86. package/dist/Editor/common/RadioGroup/styles.js +29 -0
  87. package/dist/Editor/common/RnD/ElementOptions/Actions.js +4 -5
  88. package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +2 -1
  89. package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Signature.js +4 -3
  90. package/dist/Editor/common/RnD/ElementSettings/Settings/AppHeaderSettings.js +3 -2
  91. package/dist/Editor/common/RnD/ElementSettings/Settings/BoxSettings.js +3 -2
  92. package/dist/Editor/common/RnD/ElementSettings/Settings/ButtonSettings.js +3 -2
  93. package/dist/Editor/common/RnD/ElementSettings/Settings/CodeSettings.js +3 -2
  94. package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +4 -2
  95. package/dist/Editor/common/RnD/ElementSettings/Settings/ImageSettings.js +3 -2
  96. package/dist/Editor/common/RnD/ElementSettings/Settings/TableSettings.js +3 -2
  97. package/dist/Editor/common/RnD/ElementSettings/Settings/TextSettings.js +3 -1
  98. package/dist/Editor/common/RnD/ElementSettings/Settings/VideoSettings.js +3 -2
  99. package/dist/Editor/common/RnD/ElementSettings/styles.js +0 -1
  100. package/dist/Editor/common/RnD/OptionsPopup/style.js +0 -1
  101. package/dist/Editor/common/RnD/SwitchViewport/SwitchViewport.js +11 -2
  102. package/dist/Editor/common/RnD/Theme/MainThemeProvider.js +17 -0
  103. package/dist/Editor/common/RnD/Theme/ViewportStimulator.js +6 -3
  104. package/dist/Editor/common/RnD/Utils/gridDropItem.js +28 -19
  105. package/dist/Editor/common/RnD/Utils/index.js +58 -25
  106. package/dist/Editor/common/RnD/VirtualElement/VirtualTextElement.js +45 -58
  107. package/dist/Editor/common/RnD/VirtualElement/helper.js +323 -132
  108. package/dist/Editor/common/RnD/VirtualElement/styles.js +22 -0
  109. package/dist/Editor/common/RnD/index.js +72 -38
  110. package/dist/Editor/common/Select/index.js +44 -7
  111. package/dist/Editor/common/Select/styles.js +30 -2
  112. package/dist/Editor/common/Shorthands/elements.js +54 -0
  113. package/dist/Editor/common/StyleBuilder/accordionTitleBtnStyle.js +2 -2
  114. package/dist/Editor/common/StyleBuilder/accordionTitleStyle.js +12 -9
  115. package/dist/Editor/common/StyleBuilder/buttonStyle.js +4 -2
  116. package/dist/Editor/common/StyleBuilder/embedVideoStyle.js +4 -0
  117. package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +5 -0
  118. package/dist/Editor/common/StyleBuilder/fieldTypes/bannerSpacing.js +12 -2
  119. package/dist/Editor/common/StyleBuilder/fieldTypes/borderRadius.js +15 -7
  120. package/dist/Editor/common/StyleBuilder/fieldTypes/card.js +16 -8
  121. package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +36 -10
  122. package/dist/Editor/common/StyleBuilder/fieldTypes/embedUpload.js +115 -0
  123. package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +16 -7
  124. package/dist/Editor/common/StyleBuilder/fieldTypes/index.js +3 -1
  125. package/dist/Editor/common/StyleBuilder/fieldTypes/menusArray.js +2 -0
  126. package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +15 -7
  127. package/dist/Editor/common/SwipeableDrawer/style.js +14 -12
  128. package/dist/Editor/common/Uploader.js +16 -0
  129. package/dist/Editor/common/iconListV2.js +76 -0
  130. package/dist/Editor/common/iconslist.js +21 -0
  131. package/dist/Editor/commonStyle.js +116 -61
  132. package/dist/Editor/helper/deserialize/index.js +6 -4
  133. package/dist/Editor/helper/index.js +11 -2
  134. package/dist/Editor/helper/textIndeces.js +58 -0
  135. package/dist/Editor/helper/theme.js +203 -2
  136. package/dist/Editor/hooks/useEditorTheme.js +153 -0
  137. package/dist/Editor/hooks/useMouseMove.js +9 -3
  138. package/dist/Editor/hooks/useTable.js +5 -4
  139. package/dist/Editor/hooks/useThemeValues.js +63 -0
  140. package/dist/Editor/plugins/withCustomDeleteBackward.js +6 -1
  141. package/dist/Editor/plugins/withEmbeds.js +1 -1
  142. package/dist/Editor/plugins/withHTML.js +14 -5
  143. package/dist/Editor/plugins/withTable.js +1 -1
  144. package/dist/Editor/theme/ThemeList.js +50 -173
  145. package/dist/Editor/theme/index.js +149 -0
  146. package/dist/Editor/themeSettings/ActiveTheme.js +82 -0
  147. package/dist/Editor/themeSettings/buttons/index.js +300 -0
  148. package/dist/Editor/themeSettings/buttons/style.js +23 -0
  149. package/dist/Editor/themeSettings/colorTheme/index.js +310 -0
  150. package/dist/Editor/themeSettings/colorTheme/style.js +81 -0
  151. package/dist/Editor/themeSettings/fonts/PreviewElement.js +121 -0
  152. package/dist/Editor/themeSettings/fonts/index.js +240 -0
  153. package/dist/Editor/themeSettings/fonts/style.js +62 -0
  154. package/dist/Editor/themeSettings/icons.js +60 -0
  155. package/dist/Editor/themeSettings/index.js +380 -0
  156. package/dist/Editor/themeSettings/style.js +299 -0
  157. package/dist/Editor/themeSettingsAI/icons.js +96 -0
  158. package/dist/Editor/themeSettingsAI/index.js +355 -0
  159. package/dist/Editor/themeSettingsAI/saveTheme.js +202 -0
  160. package/dist/Editor/themeSettingsAI/style.js +332 -0
  161. package/dist/Editor/utils/SlateUtilityFunctions.js +173 -50
  162. package/dist/Editor/utils/accordion.js +158 -37
  163. package/dist/Editor/utils/button.js +1 -17
  164. package/dist/Editor/utils/customHooks/useTableResize.js +49 -9
  165. package/dist/Editor/utils/draftToSlate.js +3 -2
  166. package/dist/Editor/utils/events.js +18 -6
  167. package/dist/Editor/utils/font.js +40 -37
  168. package/dist/Editor/utils/formfield.js +1 -0
  169. package/dist/Editor/utils/helper.js +149 -30
  170. package/dist/Editor/utils/insertAppHeader.js +9 -5
  171. package/dist/Editor/utils/signature.js +2 -9
  172. package/dist/Editor/utils/updateFormName.js +22 -0
  173. package/package.json +4 -4
@@ -0,0 +1,332 @@
1
+ const style = ({
2
+ appTheme: theme
3
+ }) => ({
4
+ ".fs-12": {
5
+ fontSize: "12px"
6
+ },
7
+ ".fs-14": {
8
+ fontSize: "14px"
9
+ },
10
+ ".fw-500": {
11
+ fontWeight: "500"
12
+ },
13
+ ".fw-600": {
14
+ fontWeight: "600"
15
+ },
16
+ ".pointer": {
17
+ cursor: "pointer"
18
+ },
19
+ ".transformNone": {
20
+ textTransform: "none"
21
+ },
22
+ ".settingsContainer": {
23
+ width: "340px",
24
+ padding: "16px 16px",
25
+ background: "#fff",
26
+ ".header": {
27
+ borderBottom: `1px solid #DCE4EC`,
28
+ paddingBottom: "8px"
29
+ // marginBottom: "16px",
30
+ }
31
+ },
32
+
33
+ ".title": {
34
+ fontWeight: "700",
35
+ fontSize: "14px"
36
+ },
37
+ ".closeBtn": {
38
+ width: "26px",
39
+ height: "26px",
40
+ BorderRadius: "4px",
41
+ flexShrik: "0",
42
+ padding: "4px",
43
+ background: " #F8FAFC",
44
+ borderRadius: "4px"
45
+ },
46
+ ".MuiTabs-scroller": {
47
+ borderBottom: `1px solid #DCE4EC`
48
+ },
49
+ ".themeCardWrapper": {
50
+ borderRadius: "4px",
51
+ ".active": {
52
+ background: "#ECF2FF"
53
+ }
54
+ },
55
+ ".primaryCard, .secondaryCard": {
56
+ width: "44px",
57
+ height: "44px",
58
+ borderRadius: "5px",
59
+ border: `1px solid #929292`
60
+ },
61
+ ".flexAlign": {
62
+ display: "flex",
63
+ alignItems: "center",
64
+ flexWrap: "wrap"
65
+ },
66
+ ".flexItem": {
67
+ maxWidth: "50%",
68
+ flex: "1 1 50%" /* allow shrink and grow but cap at 50% */,
69
+ minWidth: 0 /* important for flex children */
70
+ },
71
+
72
+ ".activeColorBox, .xsColorBox": {
73
+ width: "24px",
74
+ height: "24px",
75
+ borderRadius: "5px",
76
+ border: `1px solid #929292`
77
+ },
78
+ ".themeCard": {
79
+ borderRadius: "7px",
80
+ padding: "16px",
81
+ border: "1px solid #F3F3F3",
82
+ boxShadow: "1px 2px 5px 0px #00000014",
83
+ position: "relative",
84
+ flexWrap: "nowrap",
85
+ ".tickIcon": {
86
+ visibility: "hidden",
87
+ opacity: "0",
88
+ position: "absolute",
89
+ right: "-8px",
90
+ top: "-8px"
91
+ },
92
+ "&.selected": {
93
+ ".tickIcon": {
94
+ visibility: "visible",
95
+ opacity: "1"
96
+ }
97
+ }
98
+ },
99
+ ".otherColors": {
100
+ display: "flex",
101
+ flexWrap: "wrap",
102
+ width: "48px",
103
+ ".smallCard": {
104
+ width: "20px",
105
+ height: "20px",
106
+ borderRadius: "5px",
107
+ border: `1px solid #929292`
108
+ }
109
+ },
110
+ ".imageUpload": {
111
+ background: "#F3F3F3",
112
+ borderRadius: "12px",
113
+ padding: "10px",
114
+ height: "208px",
115
+ position: "relative",
116
+ "& .resetIcon": {
117
+ position: "absolute",
118
+ right: "10px",
119
+ top: "10px"
120
+ },
121
+ ".changeImgText": {
122
+ position: "absolute",
123
+ left: "50%",
124
+ top: "50%",
125
+ transform: "translate(-50%, -50%)",
126
+ zIndex: 1,
127
+ background: "#0000004D",
128
+ color: "#fff",
129
+ padding: "6px",
130
+ borderRadius: "6px",
131
+ fontSize: "12px",
132
+ fontWeight: 600,
133
+ opacity: "0",
134
+ visibility: "hidden"
135
+ },
136
+ "&:hover": {
137
+ ".changeImgText": {
138
+ opacity: "1",
139
+ visibility: "visible"
140
+ }
141
+ }
142
+ },
143
+ ".imgUploadInner": {
144
+ background: "#fff",
145
+ borderRadius: "10px",
146
+ border: "0.79px dashed #8360FD",
147
+ height: "100%"
148
+ },
149
+ ".outlineBtn": {
150
+ color: "#2563EB",
151
+ borderRadius: "10px",
152
+ boxShadow: "0px 4px 10px 0px #00000026",
153
+ border: "1px solid #2563EB",
154
+ background: "#EBF1F9",
155
+ height: "34px",
156
+ textTransform: "unset",
157
+ fontWeight: "bold",
158
+ "&:hover": {
159
+ background: "#EBF1F9"
160
+ }
161
+ },
162
+ ".seondaryOutlineBtn": {
163
+ border: "1px solid #D8DDE1",
164
+ borderRadius: "8px",
165
+ // boxShadow: "0px 4px 10px 0px #00000026",
166
+ height: "34px",
167
+ textTransform: "unset",
168
+ background: "#f5f6f9 !important",
169
+ color: "#64748B !important",
170
+ "&:hover": {
171
+ border: "1px solid #D8DDE1",
172
+ background: "#f5f6f9 !important"
173
+ }
174
+ },
175
+ ".blueBtn": {
176
+ boxShadow: "0px 4px 10px 0px #00000026",
177
+ background: "#2563EB",
178
+ borderRadius: "8px",
179
+ textTransform: "unset",
180
+ height: "34px",
181
+ color: "#fff",
182
+ fontWeight: "bold",
183
+ "&.disabled": {
184
+ background: "#D9D9DD !important",
185
+ color: "#fff !important"
186
+ }
187
+ },
188
+ ".generatedItem": {
189
+ border: "1px solid #E4E6E9",
190
+ borderRadius: "7px",
191
+ padding: "14px",
192
+ display: "flex",
193
+ gap: "16px",
194
+ position: "relative",
195
+ justifyContent: "space-between",
196
+ marginBottom: "12px",
197
+ ".tickIcon": {
198
+ visibility: "hidden",
199
+ opacity: "0",
200
+ position: "absolute",
201
+ right: "-8px",
202
+ top: "-8px"
203
+ },
204
+ "&.selected": {
205
+ border: "1px solid #2563EB",
206
+ boxShadow: " 3px 3px 8px 0px #2563EB40",
207
+ ".tickIcon": {
208
+ visibility: "visible",
209
+ opacity: "1"
210
+ }
211
+ },
212
+ ".colorBox": {
213
+ border: "1px solid #929292",
214
+ height: "28px",
215
+ width: "28px",
216
+ borderRadius: "5px"
217
+ }
218
+ },
219
+ ".textArea": {
220
+ background: "#F3F3F3",
221
+ borderRadius: "12px",
222
+ padding: "10px",
223
+ height: "208px",
224
+ "& textarea": {
225
+ width: "100%",
226
+ height: "100% !important",
227
+ border: "0.79px solid #8360FD",
228
+ background: "#FFFFFF",
229
+ borderRadius: "8px",
230
+ padding: "10px"
231
+ }
232
+ },
233
+ ".imageUrl": {
234
+ height: "auto !important",
235
+ ".MuiOutlinedInput-root": {
236
+ border: "0.79px solid #8360FD",
237
+ background: "#FFFFFF",
238
+ borderRadius: "8px",
239
+ ".tickIcon": {
240
+ width: "18px"
241
+ }
242
+ },
243
+ "&.invalidUrl": {
244
+ ".MuiInputAdornment-root": {
245
+ ".tickIcon": {
246
+ ".fillPath": {
247
+ fill: "#D9D9DD!important"
248
+ }
249
+ }
250
+ }
251
+ }
252
+ },
253
+ ".saveThemeContainer": {
254
+ ".MuiOutlinedInput-root": {
255
+ borderRadius: "8px",
256
+ boxShadow: "0px 4px 16px 0px #0000000D"
257
+ }
258
+ },
259
+ ".uploadedImage": {
260
+ width: "126px",
261
+ height: "126px",
262
+ borderRadius: "126px"
263
+ },
264
+ ".MuiDialog-paper": {
265
+ borderRadius: "10px",
266
+ background: theme?.palette?.editor?.miniToolBarBackground
267
+ },
268
+ "& .MuiInputBase-root": {
269
+ borderRadius: "8px",
270
+ background: theme?.palette?.editor?.inputFieldBgColor,
271
+ border: `none`,
272
+ height: "40px",
273
+ boxShadow: "0px 4px 16px 0px #0000000D",
274
+ fontFamily: "Inter, sans-serif",
275
+ "&:hover .MuiOutlinedInput-notchedOutline": {
276
+ border: `1px solid ${theme?.palette?.editor?.inputFieldBorder}`
277
+ },
278
+ "& input::placeholder": {
279
+ color: "#94A3B8 !important",
280
+ opacity: "unset",
281
+ fontFamily: "Inter, sans-serif"
282
+ },
283
+ "& .colorPickerButton": {
284
+ border: `2px solid ${theme?.palette?.editor?.buttonBorder2} !important`
285
+ }
286
+ },
287
+ "& .MuiInputBase-root:has(.colorPickerButton)": {
288
+ "& .MuiInputBase-input": {
289
+ padding: "8.5px 14px 8.5px 0px",
290
+ fontFamily: "Inter, sans-serif"
291
+ }
292
+ },
293
+ "& .MuiInputBase-input": {
294
+ color: theme?.palette?.editor?.deletePopUpButtonTextColor,
295
+ textTransform: "math-auto",
296
+ fontFamily: "Inter, sans-serif"
297
+ },
298
+ "& .MuiOutlinedInput-notchedOutline": {
299
+ border: `1px solid ${theme?.palette?.editor?.inputFieldBorder}`
300
+ },
301
+ "& fieldset": {
302
+ border: `1px solid transparent`,
303
+ borderRadius: "8px"
304
+ },
305
+ "& .saveThemeActionBtns": {
306
+ "& button": {
307
+ fontWeight: 600,
308
+ fontSize: "14px",
309
+ opacity: 1,
310
+ borderRadius: "8px",
311
+ textTransform: "math-auto",
312
+ padding: "4px 20px",
313
+ height: "fit-content",
314
+ minWidth: "90px",
315
+ lineHeight: "1.75 !important",
316
+ "@media only screen and (max-width: 899px)": {
317
+ width: "50%"
318
+ },
319
+ "&.confirmBtn": {
320
+ backgroundColor: "#2563EB",
321
+ color: "#ffffff",
322
+ border: `1px solid #2563EB`
323
+ },
324
+ "&.cancelBtn": {
325
+ backgroundColor: theme?.palette?.editor?.closeButtonBackground,
326
+ color: theme?.palette?.editor?.customDialogueCloseBtnColor,
327
+ border: `1px solid ${theme?.palette?.editor?.customDialogueCloseBtnBorder}`
328
+ }
329
+ }
330
+ }
331
+ });
332
+ export default style;
@@ -34,12 +34,12 @@ import SimpleText from "../Elements/SimpleText";
34
34
  import CheckList from "../Elements/List/CheckList";
35
35
  import { getTextColor, isEmptyTextNode } from "../helper";
36
36
  import Attachments from "../Elements/Attachments/Attachments";
37
- import { getBreakpointLineSpacing, getBreakPointsValue, getDevice, groupByBreakpoint } from "../helper/theme";
37
+ import { getBreakpointLineSpacing, getBreakPointsValue, getDevice, getElementProperty, textThemeFields } from "../helper/theme";
38
38
  import Variables from "../Elements/Variables/Variable";
39
- import insertNewLine from "./insertNewLine";
40
39
  import Divider from "../Elements/Divider/Divider";
41
40
  import { getBorderColor, getSlateDom } from "./helper";
42
41
  import Code from "../Elements/EmbedScript/Code";
42
+ import { ReactEditor } from "slate-react";
43
43
  import FreeGrid from "../Elements/FreeGrid/FreeGrid";
44
44
  import FreeGridItem from "../Elements/FreeGrid/FreeGridItem";
45
45
  import FreeGridBox from "../Elements/FreeGrid/FreeGridBox";
@@ -47,16 +47,25 @@ import DataView from "../Elements/DataView/DataView";
47
47
  import ViewData from "../Elements/DataView/Layouts/ViewData";
48
48
  import ColumnView from "../Elements/DataView/Layouts/ColumnView";
49
49
  import SearchAttachment from "../Elements/Search/SearchAttachment";
50
- // import { wrapThemeBreakpoints } from "../Elements/FreeGrid/breakpointConstants";
50
+ import { wrapThemeBreakpoints } from "../Elements/FreeGrid/breakpointConstants";
51
51
  import { jsx as _jsx } from "react/jsx-runtime";
52
- import { jsxs as _jsxs } from "react/jsx-runtime";
53
52
  const alignment = ["alignLeft", "alignRight", "alignCenter", "alignJustify"];
54
53
  const list_types = ["orderedList", "unorderedList"];
55
54
  const LIST_FORMAT_TYPE = {
56
55
  orderedList: "list-item",
57
56
  unorderedList: "list-item"
58
57
  };
59
- const NEWLINESAFTER = ["headingOne", "headingTwo", "headingThree", "headingFour", "headingFive", "headingSix"];
58
+
59
+ // const NEWLINESAFTER = [
60
+ // "headingOne",
61
+ // "headingTwo",
62
+ // "headingThree",
63
+ // "headingFour",
64
+ // "headingFive",
65
+ // "headingSix",
66
+ // ];
67
+
68
+ const THEME_BLOCK_FIELDS = ["headingOne", "headingTwo", "headingThree", "headingFour", "headingFive", "headingSix", "paragraphOne", "paragraphTwo", "paragraphThree"];
60
69
  export const toggleBlock = (editor, format, selection = true, attr = {}) => {
61
70
  const isActive = isBlockActive(editor, format);
62
71
  const isList = list_types.includes(format);
@@ -89,8 +98,9 @@ export const toggleBlock = (editor, format, selection = true, attr = {}) => {
89
98
  if (!selection) {
90
99
  Transforms.insertText(editor, "");
91
100
  }
101
+ const forActiveType = THEME_BLOCK_FIELDS.some(f => f === format) ? format : "paragraph";
92
102
  Transforms.setNodes(editor, {
93
- type: isActive ? "paragraph" : isList ? LIST_FORMAT_TYPE[format] : format,
103
+ type: isActive ? forActiveType : isList ? LIST_FORMAT_TYPE[format] : format,
94
104
  ...attr
95
105
  });
96
106
  if (isList && !isActive) {
@@ -99,10 +109,12 @@ export const toggleBlock = (editor, format, selection = true, attr = {}) => {
99
109
  children: []
100
110
  });
101
111
  }
102
- if (NEWLINESAFTER.indexOf(format) > -1) {
103
- insertNewLine(editor);
104
- }
112
+
113
+ // if (NEWLINESAFTER.indexOf(format) > -1) {
114
+ // insertNewLine(editor);
115
+ // }
105
116
  };
117
+
106
118
  export const addMarkData = (editor, data) => {
107
119
  try {
108
120
  Editor.addMark(editor, data.format, data.value);
@@ -111,9 +123,14 @@ export const addMarkData = (editor, data) => {
111
123
  }
112
124
  };
113
125
  export const toggleMark = (editor, format) => {
114
- const isActive = isMarkActive(editor, format);
126
+ const isActive = isMarkBtnActive(editor, format);
115
127
  if (isActive) {
116
- Editor.removeMark(editor, format);
128
+ const isThemeSupportedMark = textThemeFields.some(f => f === format);
129
+ if (isThemeSupportedMark) {
130
+ Editor.addMark(editor, format, false);
131
+ } else {
132
+ Editor.removeMark(editor, format);
133
+ }
117
134
  } else {
118
135
  Editor.addMark(editor, format, true);
119
136
  }
@@ -127,6 +144,58 @@ export const isMarkActive = (editor, format) => {
127
144
  return null;
128
145
  }
129
146
  };
147
+ export const isMarkBtnActive = (editor, format) => {
148
+ switch (format) {
149
+ case "bold":
150
+ {
151
+ const style = getSelectedElementStyle("font-weight", editor);
152
+ return style === "700";
153
+ }
154
+ case "italic":
155
+ {
156
+ const style = getSelectedElementStyle("font-style", editor);
157
+ return style === format;
158
+ }
159
+ // case "underline": {
160
+ // const style = getSelectedElementStyle("text-decoration");
161
+
162
+ // return style?.includes(format);
163
+ // }
164
+ // case "strikethrough": {
165
+ // const style = getSelectedElementStyle("text-decoration");
166
+
167
+ // return style?.includes("line-through");
168
+ // }
169
+ default:
170
+ return isMarkActive(editor, format);
171
+ }
172
+ };
173
+ export const getSelectedElementStyle = (styleProperty, editor, format) => {
174
+ try {
175
+ if (!editor.selection) {
176
+ return "";
177
+ }
178
+ if (Range.isCollapsed(editor.selection)) {
179
+ return "";
180
+ }
181
+ if (format) {
182
+ const value = activeMark(editor, format, true);
183
+ if (value) {
184
+ return value;
185
+ }
186
+ }
187
+ const domRange = ReactEditor.toDOMRange(editor, editor.selection);
188
+ const selectedDomNode = domRange.commonAncestorContainer;
189
+
190
+ // If it's a text node, get its parent element
191
+ const selectedElement = selectedDomNode.nodeType === 3 ? selectedDomNode.parentElement : selectedDomNode;
192
+ if (selectedElement) {
193
+ return getElementProperty(selectedElement, styleProperty);
194
+ }
195
+ } catch (err) {
196
+ console.log(err);
197
+ }
198
+ };
130
199
  export const isBlockActive = (editor, format) => {
131
200
  const [match] = Editor.nodes(editor, {
132
201
  match: n => !Editor.isEditor(n) && SlateElement.isElement(n) && n.type === format
@@ -152,7 +221,7 @@ export const upateBlockActive = (editor, format, attr = {}) => {
152
221
  });
153
222
  }
154
223
  };
155
- export const activeMark = (editor, format) => {
224
+ export const activeMark = (editor, format, noDefaultValue) => {
156
225
  const defaultMarkData = {
157
226
  color: "#000000",
158
227
  bgColor: "#FFFFFF",
@@ -162,7 +231,7 @@ export const activeMark = (editor, format) => {
162
231
  };
163
232
  try {
164
233
  const marks = Editor.marks(editor);
165
- let defaultValue = defaultMarkData[format];
234
+ let defaultValue = noDefaultValue ? "" : defaultMarkData[format];
166
235
  const {
167
236
  selection
168
237
  } = editor || {};
@@ -179,6 +248,31 @@ export const activeMark = (editor, format) => {
179
248
  return null;
180
249
  }
181
250
  };
251
+
252
+ // to avoid the styles, that automatically assign from themes
253
+ const getThemeMarkedLeaf = (leaf, children) => {
254
+ const {
255
+ italic,
256
+ bold
257
+ } = leaf || {};
258
+ const style = {};
259
+ if (italic === false) {
260
+ style.fontStyle = "normal";
261
+ }
262
+ if (bold === false) {
263
+ style.fontWeight = "normal";
264
+ }
265
+ if (Object.keys(style).length) {
266
+ children = /*#__PURE__*/_jsx(Box, {
267
+ component: "span",
268
+ sx: {
269
+ "& span": style
270
+ },
271
+ children: children
272
+ });
273
+ }
274
+ return children;
275
+ };
182
276
  export const getMarked = (leaf, children, theme) => {
183
277
  const className = leaf?.doublequote ? "doublequote" : "";
184
278
  const lineH = leaf?.lineHeight;
@@ -208,6 +302,7 @@ export const getMarked = (leaf, children, theme) => {
208
302
  children: children
209
303
  });
210
304
  }
305
+ children = getThemeMarkedLeaf(leaf, children);
211
306
  if (leaf.strikethrough) {
212
307
  children = /*#__PURE__*/_jsx("span", {
213
308
  style: {
@@ -235,6 +330,15 @@ export const getMarked = (leaf, children, theme) => {
235
330
  if (leaf.color || leaf.bgColor || leaf.fontSize || leaf.fontFamily || leaf.fontWeight || lineHeight || className) {
236
331
  const family = leaf?.fontFamily;
237
332
  const textStyles = getTextColor(leaf?.color);
333
+ const fontSize = {
334
+ lg: sizeMap[leaf.fontSize] || leaf.fontSize,
335
+ ...getBreakPointsValue(leaf.fontSize, null, "overrideText")
336
+ };
337
+ const fontSizesImportant = {};
338
+ Object.entries(fontSize).forEach(([key, value]) => {
339
+ fontSizesImportant[key] = `${value} !important`;
340
+ });
341
+ const fontSizeWithBreakpoints = wrapThemeBreakpoints(fontSizesImportant, "fontSize", theme);
238
342
  children = /*#__PURE__*/_jsx("span", {
239
343
  style: {
240
344
  background: leaf.bgColor
@@ -243,12 +347,13 @@ export const getMarked = (leaf, children, theme) => {
243
347
  className: `${className} leaf-item`,
244
348
  component: "span",
245
349
  sx: {
246
- ...groupByBreakpoint({
247
- fontSize: {
248
- lg: sizeMap[leaf.fontSize] || leaf.fontSize,
249
- ...getBreakPointsValue(leaf.fontSize, null, "overrideText")
250
- }
251
- }, theme),
350
+ "& span": {
351
+ // fontSize: fontSizesImportant,
352
+ // ...groupByBreakpoint(fontSizesImportant, theme),
353
+ background: leaf.bgColor,
354
+ ...fontSizeWithBreakpoints
355
+ },
356
+ ...fontSizeWithBreakpoints,
252
357
  // ...wrapThemeBreakpoints(
253
358
  // {
254
359
  // lg: sizeMap[leaf.fontSize] || leaf.fontSize,
@@ -300,69 +405,85 @@ export const getBlock = props => {
300
405
  const {
301
406
  translation
302
407
  } = customProps;
408
+ const commonHeadingProps = () => ({
409
+ ...attributes,
410
+ ...element.attr,
411
+ className: `edt-headings content-editable ${isEmpty ? "empty" : ""} theme-element`
412
+ });
413
+ const commonParaProps = paraType => ({
414
+ ...attributes,
415
+ ...element.attr,
416
+ className: `edt-paragraphs content-editable ${isEmpty ? "empty" : ""} theme-element ${paraType}`
417
+ });
303
418
  const breakpoint = getDevice(window.innerWidth);
304
419
  const lineH = element?.children[0]?.lineHeight;
305
420
  const selectedLineHeight = getBreakpointLineSpacing(lineH, breakpoint);
306
421
  switch (element.type) {
307
422
  case "headingOne":
308
- return /*#__PURE__*/_jsxs("h1", {
423
+ return /*#__PURE__*/_jsx("h1", {
309
424
  ...attributes,
310
425
  ...element.attr,
311
- className: `edt-headings content-editable ${isEmpty ? "empty" : ""}`,
426
+ className: `edt-headings content-editable ${isEmpty ? "empty" : ""} disablePointerEvent`,
312
427
  placeholder: translation("Heading 1"),
313
- children: [children, /*#__PURE__*/_jsx("span", {
314
- contentEditable: false
315
- })]
428
+ children: children
316
429
  });
317
430
  case "headingTwo":
318
- return /*#__PURE__*/_jsxs("h2", {
431
+ return /*#__PURE__*/_jsx("h2", {
319
432
  ...attributes,
320
433
  ...element.attr,
321
- className: `edt-headings content-editable ${isEmpty ? "empty" : ""}`,
434
+ className: `edt-headings content-editable ${isEmpty ? "empty" : ""} disablePointerEvent`,
322
435
  placeholder: translation("Heading 2"),
323
- children: [children, /*#__PURE__*/_jsx("span", {
324
- contentEditable: false
325
- })]
436
+ children: children
326
437
  });
327
438
  case "headingThree":
328
- return /*#__PURE__*/_jsxs("h3", {
439
+ return /*#__PURE__*/_jsx("h3", {
329
440
  ...attributes,
330
441
  ...element.attr,
331
- className: `edt-headings content-editable ${isEmpty ? "empty" : ""}`,
442
+ className: `edt-headings content-editable ${isEmpty ? "empty" : ""} disablePointerEvent`,
332
443
  placeholder: translation("Heading 3"),
333
- children: [children, /*#__PURE__*/_jsx("span", {
334
- contentEditable: false
335
- })]
444
+ children: children
336
445
  });
337
446
  case "headingFour":
338
- return /*#__PURE__*/_jsxs("h4", {
447
+ return /*#__PURE__*/_jsx("h4", {
339
448
  ...attributes,
340
449
  ...element.attr,
341
- className: `edt-headings content-editable ${isEmpty ? "empty" : ""}`,
450
+ className: `edt-headings content-editable ${isEmpty ? "empty" : ""} disablePointerEvent`,
342
451
  placeholder: translation("Heading 4"),
343
- children: [children, /*#__PURE__*/_jsx("span", {
344
- contentEditable: false
345
- })]
452
+ children: children
346
453
  });
347
454
  case "headingFive":
348
- return /*#__PURE__*/_jsxs("h5", {
455
+ return /*#__PURE__*/_jsx("h5", {
349
456
  ...attributes,
350
457
  ...element.attr,
351
- className: `edt-headings content-editable ${isEmpty ? "empty" : ""}`,
458
+ className: `edt-headings content-editable ${isEmpty ? "empty" : ""} disablePointerEvent`,
352
459
  placeholder: translation("Heading 5"),
353
- children: [children, /*#__PURE__*/_jsx("span", {
354
- contentEditable: false
355
- })]
460
+ children: children
356
461
  });
357
462
  case "headingSix":
358
- return /*#__PURE__*/_jsxs("h6", {
463
+ return /*#__PURE__*/_jsx("h6", {
359
464
  ...attributes,
360
465
  ...element.attr,
361
- className: `edt-headings content-editable ${isEmpty ? "empty" : ""}`,
466
+ className: `edt-headings content-editable ${isEmpty ? "empty" : ""} disablePointerEvent`,
362
467
  placeholder: translation("Heading 6"),
363
- children: [children, /*#__PURE__*/_jsx("span", {
364
- contentEditable: false
365
- })]
468
+ children: children
469
+ });
470
+ case "paragraphOne":
471
+ return /*#__PURE__*/_jsx("p", {
472
+ ...commonParaProps("para1"),
473
+ placeholder: "Paragraph 1",
474
+ children: children
475
+ });
476
+ case "paragraphTwo":
477
+ return /*#__PURE__*/_jsx("p", {
478
+ ...commonParaProps("para2"),
479
+ placeholder: "Paragraph 2",
480
+ children: children
481
+ });
482
+ case "paragraphThree":
483
+ return /*#__PURE__*/_jsx("p", {
484
+ ...commonParaProps("para3"),
485
+ placeholder: "Paragraph 3",
486
+ children: children
366
487
  });
367
488
  case "blockquote":
368
489
  return /*#__PURE__*/_jsx("blockquote", {
@@ -672,8 +793,10 @@ export const getQueryStrings = urlString => {
672
793
  const newUrl = new URL(urlString);
673
794
  var youCode = newUrl.searchParams.get("v");
674
795
  if (!youCode) {
675
- youCode = newUrl.pathname.replace("/", "");
796
+ const parts = newUrl.pathname.split("/");
797
+ youCode = parts[parts.length - 1]; // video ID
676
798
  }
799
+
677
800
  return `https://www.youtube.com/embed/${youCode}`;
678
801
  } else {
679
802
  return urlString;