@flozy/editor 10.9.6 → 10.9.8
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.
- package/dist/Editor/ChatEditor.js +17 -16
- package/dist/Editor/CommonEditor.js +138 -27
- package/dist/Editor/DialogWrapper.js +31 -25
- package/dist/Editor/Editor.css +39 -11
- package/dist/Editor/Elements/AI/PopoverAIInput.js +11 -3
- package/dist/Editor/Elements/AI/Styles.js +1 -0
- package/dist/Editor/Elements/Accordion/Accordion.js +28 -22
- package/dist/Editor/Elements/Accordion/AccordionButton.js +12 -3
- package/dist/Editor/Elements/AppHeader/AppHeader.js +3 -3
- package/dist/Editor/Elements/Attachments/AttachmentStyles.js +16 -0
- package/dist/Editor/Elements/Attachments/Attachments.js +153 -11
- package/dist/Editor/Elements/Attachments/AttachmentsButton.js +8 -3
- package/dist/Editor/Elements/Button/EditorButton.js +23 -7
- package/dist/Editor/Elements/Color Picker/ColorButtons.js +61 -14
- package/dist/Editor/Elements/Color Picker/ColorPicker.css +25 -1
- package/dist/Editor/Elements/Color Picker/ColorPicker.js +10 -7
- package/dist/Editor/Elements/Color Picker/Styles.js +15 -13
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/Select.js +134 -55
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/SelectV1.js +7 -8
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/PersonType.js +8 -3
- package/dist/Editor/Elements/DataView/Layouts/Options/EditProperty.js +1 -1
- package/dist/Editor/Elements/DataView/Layouts/TableStyles.js +1 -1
- package/dist/Editor/Elements/Embed/Embed.css +5 -0
- package/dist/Editor/Elements/Embed/Embed.js +36 -43
- package/dist/Editor/Elements/Embed/Image.js +236 -23
- package/dist/Editor/Elements/Embed/Video.js +246 -15
- package/dist/Editor/Elements/Form/FormField.js +1 -1
- package/dist/Editor/Elements/Form/Workflow/Styles.js +24 -22
- package/dist/Editor/Elements/Form/Workflow/constant.js +25 -1
- package/dist/Editor/Elements/FreeGrid/FreeGrid.js +39 -33
- package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +7 -4
- package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +1 -0
- package/dist/Editor/Elements/FreeGrid/Options/More.js +7 -7
- package/dist/Editor/Elements/FreeGrid/helper.js +115 -0
- package/dist/Editor/Elements/FreeGrid/styles.js +15 -0
- package/dist/Editor/Elements/Grid/GridItem.js +1 -1
- package/dist/Editor/Elements/PageSettings/PageSettingsButton.js +2 -1
- package/dist/Editor/Elements/SimpleText/index.js +4 -1
- package/dist/Editor/Elements/SimpleText/style.js +2 -2
- package/dist/Editor/Elements/Table/Table.js +5 -4
- package/dist/Editor/Elements/Table/TableCell.js +10 -3
- package/dist/Editor/Elements/Title/title.js +10 -11
- package/dist/Editor/Elements/TopBanner/TopBanner.js +4 -2
- package/dist/Editor/Elements/TopBanner/TopBannerButton.js +5 -3
- package/dist/Editor/Elements/Variables/VariableButton.js +10 -1
- package/dist/Editor/MiniEditor.js +2 -1
- package/dist/Editor/Styles/EditorStyles.js +20 -8
- package/dist/Editor/Toolbar/FormatTools/Dropdown.js +27 -3
- package/dist/Editor/Toolbar/FormatTools/FontFamilyAutocomplete.js +4 -3
- package/dist/Editor/Toolbar/FormatTools/MarkButton.js +2 -2
- package/dist/Editor/Toolbar/FormatTools/TextSize.js +33 -29
- package/dist/Editor/Toolbar/Mini/MiniToolbar.js +2 -1
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/MiniColorPicker.js +4 -2
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectFontSize.js +25 -23
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectList.js +25 -7
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectTypography.js +167 -42
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +24 -8
- package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +2 -1
- package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +70 -10
- package/dist/Editor/Toolbar/PopupTool/TextFormat.js +73 -14
- package/dist/Editor/Toolbar/PopupTool/ThemeTextFormat.js +439 -0
- package/dist/Editor/Toolbar/PopupTool/index.js +7 -4
- package/dist/Editor/Toolbar/toolbarGroups.js +56 -10
- package/dist/Editor/assets/svg/BackIcon.js +18 -0
- package/dist/Editor/assets/svg/ThemeIcons.js +293 -0
- package/dist/Editor/common/ColorPickerButton.js +38 -16
- package/dist/Editor/common/CustomColorPicker/index.js +130 -0
- package/dist/Editor/common/CustomColorPicker/style.js +53 -0
- package/dist/Editor/common/CustomDialog2/index.js +94 -0
- package/dist/Editor/common/CustomDialog2/style.js +67 -0
- package/dist/Editor/common/CustomSelect.js +43 -0
- package/dist/Editor/common/DnD/DragHandleButton.js +1 -1
- package/dist/Editor/common/FontLoader/FontLoader.js +4 -0
- package/dist/Editor/common/Icon.js +28 -0
- package/dist/Editor/common/ImageSelector/ImageSelector.js +45 -7
- package/dist/Editor/common/ImageSelector/Options/Upload.js +26 -11
- package/dist/Editor/common/ImageSelector/Styles.js +3 -9
- package/dist/Editor/common/LinkSettings/NavComponents.js +6 -2
- package/dist/Editor/common/MentionsPopup/index.js +9 -1
- package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +2 -1
- package/dist/Editor/common/RnD/ElementSettings/Settings/AppHeaderSettings.js +3 -2
- package/dist/Editor/common/RnD/ElementSettings/Settings/BoxSettings.js +3 -2
- package/dist/Editor/common/RnD/ElementSettings/Settings/ButtonSettings.js +3 -2
- package/dist/Editor/common/RnD/ElementSettings/Settings/CodeSettings.js +3 -2
- package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +4 -2
- package/dist/Editor/common/RnD/ElementSettings/Settings/ImageSettings.js +20 -7
- package/dist/Editor/common/RnD/ElementSettings/Settings/TableSettings.js +3 -2
- package/dist/Editor/common/RnD/ElementSettings/Settings/TextSettings.js +9 -1
- package/dist/Editor/common/RnD/ElementSettings/Settings/VideoSettings.js +20 -7
- package/dist/Editor/common/RnD/GuideLines/styles.js +1 -1
- package/dist/Editor/common/RnD/SwitchViewport/SwitchViewport.js +11 -2
- package/dist/Editor/common/RnD/Theme/MainThemeProvider.js +17 -0
- package/dist/Editor/common/RnD/Theme/ViewportStimulator.js +6 -3
- package/dist/Editor/common/RnD/Utils/gridDropItem.js +28 -18
- package/dist/Editor/common/RnD/Utils/index.js +3 -1
- package/dist/Editor/common/RnD/VirtualElement/VirtualTextElement.js +45 -58
- package/dist/Editor/common/RnD/VirtualElement/helper.js +320 -130
- package/dist/Editor/common/RnD/VirtualElement/styles.js +22 -0
- package/dist/Editor/common/RnD/index.js +48 -13
- package/dist/Editor/common/Shorthands/elements.js +62 -4
- package/dist/Editor/common/StyleBuilder/buttonStyle.js +4 -2
- package/dist/Editor/common/StyleBuilder/embedVideoStyle.js +4 -0
- package/dist/Editor/common/StyleBuilder/fieldStyle.js +1 -0
- package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +15 -2
- package/dist/Editor/common/StyleBuilder/fieldTypes/bannerSpacing.js +12 -2
- package/dist/Editor/common/StyleBuilder/fieldTypes/borderRadius.js +15 -7
- package/dist/Editor/common/StyleBuilder/fieldTypes/card.js +16 -8
- package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +36 -10
- package/dist/Editor/common/StyleBuilder/fieldTypes/embedUpload.js +115 -0
- package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +16 -7
- package/dist/Editor/common/StyleBuilder/fieldTypes/index.js +3 -1
- package/dist/Editor/common/StyleBuilder/fieldTypes/menusArray.js +2 -0
- package/dist/Editor/common/StyleBuilder/fieldTypes/text.js +0 -1
- package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +15 -7
- package/dist/Editor/common/StyleBuilder/formStyle.js +19 -13
- package/dist/Editor/common/StyleBuilder/index.js +8 -4
- package/dist/Editor/common/Uploader.js +125 -17
- package/dist/Editor/common/UploaderWithProgress.js +183 -0
- package/dist/Editor/common/iconslist.js +21 -0
- package/dist/Editor/commonStyle.js +64 -45
- package/dist/Editor/helper/index.js +10 -2
- package/dist/Editor/helper/textIndeces.js +58 -0
- package/dist/Editor/helper/theme.js +203 -2
- package/dist/Editor/hooks/useEditorTheme.js +153 -0
- package/dist/Editor/hooks/useMouseMove.js +9 -3
- package/dist/Editor/hooks/useTable.js +62 -1
- package/dist/Editor/hooks/useThemeValues.js +63 -0
- package/dist/Editor/plugins/withEmbeds.js +12 -1
- package/dist/Editor/plugins/withHTML.js +58 -3
- package/dist/Editor/plugins/withTable.js +1 -1
- package/dist/Editor/service/fileupload.js +70 -0
- package/dist/Editor/theme/ThemeList.js +50 -173
- package/dist/Editor/theme/index.js +149 -0
- package/dist/Editor/themeSettings/ActiveTheme.js +82 -0
- package/dist/Editor/themeSettings/buttons/index.js +300 -0
- package/dist/Editor/themeSettings/buttons/style.js +23 -0
- package/dist/Editor/themeSettings/colorTheme/index.js +310 -0
- package/dist/Editor/themeSettings/colorTheme/style.js +81 -0
- package/dist/Editor/themeSettings/fonts/PreviewElement.js +121 -0
- package/dist/Editor/themeSettings/fonts/index.js +240 -0
- package/dist/Editor/themeSettings/fonts/style.js +62 -0
- package/dist/Editor/themeSettings/icons.js +60 -0
- package/dist/Editor/themeSettings/index.js +380 -0
- package/dist/Editor/themeSettings/style.js +299 -0
- package/dist/Editor/themeSettingsAI/icons.js +96 -0
- package/dist/Editor/themeSettingsAI/index.js +355 -0
- package/dist/Editor/themeSettingsAI/saveTheme.js +202 -0
- package/dist/Editor/themeSettingsAI/style.js +332 -0
- package/dist/Editor/utils/SlateUtilityFunctions.js +189 -40
- package/dist/Editor/utils/accordion.js +68 -40
- package/dist/Editor/utils/button.js +1 -17
- package/dist/Editor/utils/draftToSlate.js +3 -2
- package/dist/Editor/utils/events.js +94 -89
- package/dist/Editor/utils/font.js +40 -37
- package/dist/Editor/utils/formfield.js +2 -2
- package/dist/Editor/utils/helper.js +98 -22
- package/dist/Editor/utils/insertAppHeader.js +8 -4
- package/package.json +4 -4
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/MultiSelect.js +0 -454
@@ -49,25 +49,22 @@ const useCommonStyle = theme => ({
|
|
49
49
|
fontWeight: "500",
|
50
50
|
fontFamily: "Inter, sans-serif"
|
51
51
|
},
|
52
|
-
"& p": {
|
53
|
-
marginBottom: "7px",
|
54
|
-
marginTop: "4px"
|
55
|
-
},
|
56
52
|
"& .MuiPaper-root": {
|
57
|
-
border:
|
53
|
+
border: `unset !important`,
|
58
54
|
borderRadius: "0px",
|
59
55
|
height: "fit-content",
|
60
56
|
padding: "2px"
|
61
57
|
},
|
58
|
+
"& p": {
|
59
|
+
marginBottom: "7px",
|
60
|
+
marginTop: "4px"
|
61
|
+
},
|
62
62
|
"& .muiIconsListParent": {
|
63
63
|
"& svg": {
|
64
64
|
color: `${theme?.palette?.editor?.svgTextAlignStrokeColor} !important`
|
65
65
|
},
|
66
66
|
"&::-webkit-scrollbar-thumb": {
|
67
67
|
background: `${theme?.palette?.editor?.brainPopupScroll} !important`
|
68
|
-
},
|
69
|
-
"&::-webkit-scrollbar-track": {
|
70
|
-
visibility: "hidden"
|
71
68
|
}
|
72
69
|
},
|
73
70
|
"& .MuiGrid-root>.MuiGrid-item": {
|
@@ -211,16 +208,16 @@ const useCommonStyle = theme => ({
|
|
211
208
|
backgroundColor: theme?.palette?.editor?.miniToolBarBackground
|
212
209
|
},
|
213
210
|
"& .popup_tabs": {
|
214
|
-
backgroundColor: theme?.palette?.editor?.
|
211
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
215
212
|
"@media only screen and (max-width: 899px)": {
|
216
213
|
width: "100% !important"
|
217
214
|
}
|
218
215
|
},
|
219
216
|
"& .popup_tabs-header": {
|
220
|
-
backgroundColor: theme?.palette?.editor?.
|
217
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
221
218
|
"& .popup_tabs-header-label-active": {
|
222
219
|
color: theme?.palette?.editor?.activeColor,
|
223
|
-
backgroundColor: theme?.palette?.editor?.
|
220
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground
|
224
221
|
}
|
225
222
|
},
|
226
223
|
"& .colorpicker": {
|
@@ -249,6 +246,40 @@ const useCommonStyle = theme => ({
|
|
249
246
|
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
250
247
|
color: theme?.palette?.editor?.textColor
|
251
248
|
}
|
249
|
+
},
|
250
|
+
"& .colorPickerActionBtns": {
|
251
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
252
|
+
display: "flex",
|
253
|
+
justifyContent: "end",
|
254
|
+
padding: "10px",
|
255
|
+
position: "sticky",
|
256
|
+
bottom: 0,
|
257
|
+
right: 0,
|
258
|
+
boxShadow: `0px -3px 12px 0px ${theme?.palette?.editor?.cardShadow}`,
|
259
|
+
gap: "8px",
|
260
|
+
"& button": {
|
261
|
+
fontWeight: 600,
|
262
|
+
fontSize: "14px",
|
263
|
+
opacity: 1,
|
264
|
+
borderRadius: "8px",
|
265
|
+
textTransform: "math-auto",
|
266
|
+
padding: "4px 20px",
|
267
|
+
height: "fit-content",
|
268
|
+
minWidth: "90px",
|
269
|
+
"@media only screen and (max-width: 899px)": {
|
270
|
+
width: "50%"
|
271
|
+
},
|
272
|
+
"&.confirmBtn": {
|
273
|
+
backgroundColor: "#2563EB",
|
274
|
+
color: "#ffffff",
|
275
|
+
border: `1px solid #2563EB`
|
276
|
+
},
|
277
|
+
"&.cancelBtn": {
|
278
|
+
backgroundColor: theme?.palette?.editor?.closeButtonBackground,
|
279
|
+
color: theme?.palette?.editor?.customDialogueCloseBtnColor,
|
280
|
+
border: `1px solid ${theme?.palette?.editor?.customDialogueCloseBtnBorder}`
|
281
|
+
}
|
282
|
+
}
|
252
283
|
}
|
253
284
|
},
|
254
285
|
colorPickerBtnBorder: {
|
@@ -528,33 +559,6 @@ const useCommonStyle = theme => ({
|
|
528
559
|
}
|
529
560
|
}
|
530
561
|
},
|
531
|
-
pageSettingPopUpRoot: {
|
532
|
-
padding: "16px 8px 16px 10px!important",
|
533
|
-
height: "100%",
|
534
|
-
"& .text-field-wrapper": {
|
535
|
-
"& input:-webkit-autofill": {
|
536
|
-
WebkitBackgroundClip: "text !important",
|
537
|
-
WebkitBoxShadow: "0 0 0 1000px transparent inset !important",
|
538
|
-
WebkitTextFillColor: `${theme?.palette?.editor?.deletePopUpButtonTextColor} !important`,
|
539
|
-
transition: "background-color 600000s 0s, color 600000s 0s !important"
|
540
|
-
},
|
541
|
-
"& .MuiFilledInput-root": {
|
542
|
-
backgroundColor: "rgba(255, 255, 255, 0.5)",
|
543
|
-
"&:hover": {
|
544
|
-
backgroundColor: "rgba(255, 255, 255, 0.7)"
|
545
|
-
},
|
546
|
-
"&.Mui-focused": {
|
547
|
-
backgroundColor: "rgba(255, 255, 255, 0.9)"
|
548
|
-
}
|
549
|
-
}
|
550
|
-
}
|
551
|
-
},
|
552
|
-
buttonMoreIcon: {
|
553
|
-
position: "absolute",
|
554
|
-
top: "50%",
|
555
|
-
right: -40,
|
556
|
-
transform: "translateY(-50%)"
|
557
|
-
},
|
558
562
|
buttonMoreOption: {
|
559
563
|
background: `${theme?.palette?.editor?.aiInputBackground} !important`,
|
560
564
|
border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
|
@@ -567,6 +571,28 @@ const useCommonStyle = theme => ({
|
|
567
571
|
}
|
568
572
|
}
|
569
573
|
},
|
574
|
+
pageSettingPopUpRoot: {
|
575
|
+
padding: "16px 8px 16px 10px!important",
|
576
|
+
height: "100%"
|
577
|
+
},
|
578
|
+
buttonMoreIcon: {
|
579
|
+
position: "absolute",
|
580
|
+
top: "50%",
|
581
|
+
right: -40,
|
582
|
+
transform: "translateY(-50%)"
|
583
|
+
},
|
584
|
+
// buttonMoreOption: {
|
585
|
+
// background: `${theme?.palette?.editor?.aiInputBackground} !important`,
|
586
|
+
// border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
|
587
|
+
// padding: "4px !important",
|
588
|
+
// "& svg": {
|
589
|
+
// width: "18px !important",
|
590
|
+
// height: "18px !important",
|
591
|
+
// "& path": {
|
592
|
+
// stroke: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`,
|
593
|
+
// },
|
594
|
+
// },
|
595
|
+
// },
|
570
596
|
buttonMoreOption2: {
|
571
597
|
background: `${theme?.palette?.editor?.aiInputBackground} !important`,
|
572
598
|
border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
|
@@ -693,13 +719,6 @@ const useCommonStyle = theme => ({
|
|
693
719
|
stroke: theme?.palette?.editor?.closeButtonSvgStroke
|
694
720
|
}
|
695
721
|
}
|
696
|
-
},
|
697
|
-
"& .element-toolbar": {
|
698
|
-
"& button": {
|
699
|
-
borderRadius: "50%",
|
700
|
-
background: theme?.palette?.editor?.signatureFontBtnBg,
|
701
|
-
border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`
|
702
|
-
}
|
703
722
|
}
|
704
723
|
}
|
705
724
|
});
|
@@ -7,14 +7,14 @@ 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, {
|
14
14
|
windowWidth: 1440,
|
15
15
|
windowHeight: 768,
|
16
16
|
...options,
|
17
|
-
backgroundColor:
|
17
|
+
backgroundColor: 'white',
|
18
18
|
allowTaint: true,
|
19
19
|
useCORS: false,
|
20
20
|
scale: 0.5,
|
@@ -23,6 +23,11 @@ export const getThumbnailImage = async (dom, options = {}) => {
|
|
23
23
|
// hide class
|
24
24
|
const sw = document.getElementById("slate-wrapper-scroll-container");
|
25
25
|
sw.style.minHeight = "2000px";
|
26
|
+
if (options?.fromBrains) {
|
27
|
+
const textbox = document.querySelector(".innert-editor-textbox");
|
28
|
+
textbox.style.padding = "24px";
|
29
|
+
textbox.style.background = options?.pageColor || '#fffff';
|
30
|
+
}
|
26
31
|
const svgFrames = document.querySelectorAll(".image-frame svg");
|
27
32
|
for (let i = 0; i < svgFrames.length; i++) {
|
28
33
|
svgFrames[i].style.width = "100%";
|
@@ -99,6 +104,9 @@ function padZero(str, len) {
|
|
99
104
|
return (zeros + str).slice(-len);
|
100
105
|
}
|
101
106
|
export function getEmbedURL(element, needType = false) {
|
107
|
+
if (typeof element?.href !== "string" && typeof element?.url !== "string") {
|
108
|
+
return null;
|
109
|
+
}
|
102
110
|
let refUrl = element.href ? element.href : element.url;
|
103
111
|
refUrl = refUrl ? refUrl.includes("http") ? refUrl : `//${refUrl}` : "Link";
|
104
112
|
let embedUrl = refUrl;
|
@@ -0,0 +1,58 @@
|
|
1
|
+
export function extractTextWithPath(data, path = []) {
|
2
|
+
let result = [];
|
3
|
+
data.forEach((item, index) => {
|
4
|
+
const currentPath = [...path, index];
|
5
|
+
if (item.text) {
|
6
|
+
result.push({
|
7
|
+
path_id: currentPath.join(","),
|
8
|
+
text: item.text
|
9
|
+
});
|
10
|
+
}
|
11
|
+
if (item.children) {
|
12
|
+
result = result.concat(extractTextWithPath(item.children, currentPath));
|
13
|
+
}
|
14
|
+
});
|
15
|
+
return result;
|
16
|
+
}
|
17
|
+
export function replaceTextPath(nestedJson, pathIdJson) {
|
18
|
+
// Create a map from path_id JSON for quick lookup
|
19
|
+
const pathIdMap = new Map(pathIdJson.map(item => [item.path_id, item.text]));
|
20
|
+
console.log(pathIdMap);
|
21
|
+
function extractTextWithPath(data, path = []) {
|
22
|
+
data.forEach((item, index) => {
|
23
|
+
const currentPath = [...path, index];
|
24
|
+
if (item.text) {
|
25
|
+
if (pathIdMap.has(currentPath?.join(","))) {
|
26
|
+
item.text = pathIdMap.get(currentPath?.join(","));
|
27
|
+
}
|
28
|
+
}
|
29
|
+
if (item.children) {
|
30
|
+
extractTextWithPath(item.children, currentPath);
|
31
|
+
}
|
32
|
+
});
|
33
|
+
}
|
34
|
+
extractTextWithPath(nestedJson, []);
|
35
|
+
return nestedJson;
|
36
|
+
}
|
37
|
+
|
38
|
+
// export function replaceTextPath(nestedJson, pathIdJson) {
|
39
|
+
// // Create a map from path_id JSON for quick lookup
|
40
|
+
// const pathIdMap = new Map(
|
41
|
+
// pathIdJson.map((item) => [item.path_id, item.text])
|
42
|
+
// );
|
43
|
+
|
44
|
+
// function traverseAndReplace(node) {
|
45
|
+
// if (Array.isArray(node)) {
|
46
|
+
// node.forEach(traverseAndReplace);
|
47
|
+
// } else if (typeof node === "object" && node !== null) {
|
48
|
+
// console.log(node);
|
49
|
+
// if (node.text && pathIdMap.has(node.text)) {
|
50
|
+
// node.text = pathIdMap.get(node.path_id);
|
51
|
+
// }
|
52
|
+
// Object.values(node).forEach(traverseAndReplace);
|
53
|
+
// }
|
54
|
+
// }
|
55
|
+
|
56
|
+
// traverseAndReplace(nestedJson);
|
57
|
+
// return nestedJson;
|
58
|
+
// }
|
@@ -1,4 +1,6 @@
|
|
1
|
+
import { ReactEditor } from "slate-react";
|
1
2
|
import { sizeMap } from "../utils/font";
|
3
|
+
import { Editor, Node } from "slate";
|
2
4
|
export const breakpoints = {
|
3
5
|
small: 0,
|
4
6
|
mobile: 600,
|
@@ -33,7 +35,7 @@ const overrideValues = (value, ot) => {
|
|
33
35
|
return Object.keys(value).reduce((a, b) => {
|
34
36
|
return {
|
35
37
|
...a,
|
36
|
-
[b]: overrides[ot] ? overrides[ot](value[b]) : value
|
38
|
+
[b]: overrides[ot] ? overrides[ot](value[b], value) : value
|
37
39
|
};
|
38
40
|
}, {});
|
39
41
|
};
|
@@ -50,7 +52,15 @@ const overrides = {
|
|
50
52
|
overrideReSizeH: val => {
|
51
53
|
return val ? `${val?.height}px` : "auto";
|
52
54
|
},
|
53
|
-
overrideBorderRadius: val => {
|
55
|
+
overrideBorderRadius: (val, breakpointValues) => {
|
56
|
+
if (!val?.topLeft) {
|
57
|
+
Object.values(breakpointValues || {}).forEach(v => {
|
58
|
+
if (v) {
|
59
|
+
// Applying the values from breakpoints that exist to those that do not have
|
60
|
+
val = v;
|
61
|
+
}
|
62
|
+
});
|
63
|
+
}
|
54
64
|
return `${val?.topLeft}px ${val?.topRight}px ${val?.bottomLeft}px ${val?.bottomRight}px`;
|
55
65
|
}
|
56
66
|
};
|
@@ -118,6 +128,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);
|
@@ -98,8 +101,11 @@ export const EditorProvider = ({
|
|
98
101
|
setOpenAI,
|
99
102
|
updateDragging,
|
100
103
|
fontFamilies,
|
101
|
-
setFontFamilies
|
102
|
-
|
104
|
+
setFontFamilies,
|
105
|
+
openTheme,
|
106
|
+
setOpenTheme,
|
107
|
+
triggerRender
|
108
|
+
}), [path, editor?.selection, selectedPath, selectedElement, contextMenu, openAI, popupType, drop, openTheme]);
|
103
109
|
return /*#__PURE__*/_jsx(EditorContext.Provider, {
|
104
110
|
value: otherValues,
|
105
111
|
children: children
|