@flozy/editor 11.1.1 → 11.1.2
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 +6 -6
- package/dist/Editor/CommonEditor.js +82 -21
- package/dist/Editor/DialogWrapper.js +31 -25
- package/dist/Editor/Editor.css +37 -4
- package/dist/Editor/Elements/AI/PopoverAIInput.js +11 -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 +154 -11
- package/dist/Editor/Elements/Attachments/AttachmentsButton.js +8 -3
- package/dist/Editor/Elements/Button/EditorButton.js +22 -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 +37 -43
- package/dist/Editor/Elements/Embed/Image.js +242 -22
- package/dist/Editor/Elements/Embed/Video.js +277 -32
- package/dist/Editor/Elements/Form/Form.js +10 -35
- 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 +34 -75
- package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +9 -5
- package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +3 -1
- package/dist/Editor/Elements/FreeGrid/helper.js +194 -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/Signature/SignatureOptions/TypeSignature.js +2 -3
- package/dist/Editor/Elements/Signature/SignaturePopup.js +2 -13
- package/dist/Editor/Elements/SimpleText/index.js +4 -1
- package/dist/Editor/Elements/Table/Table.js +2 -1
- package/dist/Editor/Elements/Table/TableCell.js +10 -3
- package/dist/Editor/Elements/Title/title.js +4 -5
- package/dist/Editor/Elements/TopBanner/TopBanner.js +4 -2
- package/dist/Editor/Elements/TopBanner/TopBannerButton.js +5 -3
- package/dist/Editor/Styles/EditorStyles.js +16 -5
- 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 +3 -1
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectFontSize.js +25 -23
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectTypography.js +167 -42
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +15 -5
- package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +2 -1
- package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +65 -7
- package/dist/Editor/Toolbar/PopupTool/TextFormat.js +66 -12
- package/dist/Editor/Toolbar/PopupTool/ThemeTextFormat.js +439 -0
- package/dist/Editor/Toolbar/PopupTool/index.js +7 -4
- package/dist/Editor/Toolbar/toolbarGroups.js +48 -6
- 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 -19
- 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 +1 -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/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 +3 -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 +2 -0
- 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/Theme/MainThemeProvider.js +17 -0
- package/dist/Editor/common/RnD/Theme/ViewportStimulator.js +6 -3
- package/dist/Editor/common/RnD/Utils/gridDropItem.js +28 -11
- package/dist/Editor/common/RnD/Utils/index.js +3 -1
- package/dist/Editor/common/RnD/VirtualElement/VirtualTextElement.js +52 -63
- package/dist/Editor/common/RnD/VirtualElement/helper.js +248 -68
- package/dist/Editor/common/RnD/VirtualElement/styles.js +22 -0
- package/dist/Editor/common/RnD/index.js +61 -14
- package/dist/Editor/common/Shorthands/elements.js +54 -0
- 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 +18 -4
- 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/color.js +36 -10
- package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +13 -4
- package/dist/Editor/common/StyleBuilder/fieldTypes/menusArray.js +2 -0
- package/dist/Editor/common/StyleBuilder/fieldTypes/text.js +15 -4
- 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 +118 -17
- package/dist/Editor/common/UploaderWithProgress.js +183 -0
- package/dist/Editor/common/iconslist.js +21 -0
- package/dist/Editor/commonStyle.js +37 -3
- package/dist/Editor/helper/index.js +4 -1
- package/dist/Editor/helper/theme.js +203 -2
- package/dist/Editor/hooks/useEditorTheme.js +153 -0
- package/dist/Editor/hooks/useMouseMove.js +12 -3
- package/dist/Editor/hooks/useTable.js +62 -1
- package/dist/Editor/hooks/useThemeValues.js +63 -0
- package/dist/Editor/plugins/withEmbeds.js +1 -1
- package/dist/Editor/plugins/withHTML.js +56 -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 +162 -38
- package/dist/Editor/utils/accordion.js +1 -1
- package/dist/Editor/utils/button.js +1 -17
- package/dist/Editor/utils/font.js +40 -37
- package/dist/Editor/utils/helper.js +76 -3
- package/dist/Editor/utils/insertAppHeader.js +8 -4
- package/package.json +1 -1
@@ -0,0 +1,183 @@
|
|
1
|
+
import React, { useState } from "react";
|
2
|
+
import { Grid, Button, Typography } from "@mui/material";
|
3
|
+
import { convertBase64 } from "../utils/helper";
|
4
|
+
import Icon from "./Icon";
|
5
|
+
import UploadStyles from "../common/ImageSelector/UploadStyles";
|
6
|
+
import { allowedFormat, maxSizeMap, allowedTypes, extensionMap } from "../Elements/Form/Workflow/constant";
|
7
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
8
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
9
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
10
|
+
const UploaderWithProgress = props => {
|
11
|
+
const {
|
12
|
+
value,
|
13
|
+
onUploaded,
|
14
|
+
customProps,
|
15
|
+
setS3UploadProp,
|
16
|
+
s3UploadProp
|
17
|
+
} = props;
|
18
|
+
const title = props.title || "Image";
|
19
|
+
const classes = UploadStyles();
|
20
|
+
const [base64, setBase64] = useState(value?.url);
|
21
|
+
const [fileName, setFileName] = useState("");
|
22
|
+
const [uploading, setUploading] = useState(false);
|
23
|
+
const [error, setError] = useState("");
|
24
|
+
const handleChange = async e => {
|
25
|
+
setError("");
|
26
|
+
const uFile = e.target.files[0];
|
27
|
+
if (!uFile) return;
|
28
|
+
const maxAllowedSize = maxSizeMap[title] || 5 * 1024 * 1024;
|
29
|
+
|
30
|
+
// ✅ Check file size
|
31
|
+
if (uFile.size > maxAllowedSize) {
|
32
|
+
const sizeInMB = Math.round(maxAllowedSize / (1024 * 1024));
|
33
|
+
setError(`File size exceeds ${sizeInMB}MB for ${title.toLowerCase()}.`);
|
34
|
+
return;
|
35
|
+
}
|
36
|
+
|
37
|
+
// ✅ File type check with fallback to extension
|
38
|
+
const validTypes = allowedTypes[title];
|
39
|
+
const fileType = uFile.type;
|
40
|
+
const fileName = uFile.name.toLowerCase();
|
41
|
+
const fileExtension = fileName.split(".").pop();
|
42
|
+
const isValid = title === "Embed" || validTypes.includes(fileType) || extensionMap[title]?.includes(fileExtension);
|
43
|
+
if (!isValid) {
|
44
|
+
setError(`Invalid file format. Please upload a valid ${title.toLowerCase()}.`);
|
45
|
+
return;
|
46
|
+
}
|
47
|
+
try {
|
48
|
+
const strImage = await convertBase64(uFile);
|
49
|
+
setBase64(strImage);
|
50
|
+
setFileName(uFile?.name);
|
51
|
+
doUpload(strImage, uFile);
|
52
|
+
} catch (err) {
|
53
|
+
setError("Failed to read file.");
|
54
|
+
}
|
55
|
+
};
|
56
|
+
const doUpload = async (strImage, file) => {
|
57
|
+
setUploading(true);
|
58
|
+
setS3UploadProp({
|
59
|
+
...s3UploadProp,
|
60
|
+
file: file,
|
61
|
+
pageId: customProps?.page_id,
|
62
|
+
services: customProps?.services
|
63
|
+
});
|
64
|
+
setUploading(false);
|
65
|
+
};
|
66
|
+
const {
|
67
|
+
translation
|
68
|
+
} = customProps;
|
69
|
+
const onRemoveBG = () => {
|
70
|
+
setBase64(null);
|
71
|
+
onUploaded("");
|
72
|
+
setS3UploadProp({
|
73
|
+
...s3UploadProp,
|
74
|
+
file: null
|
75
|
+
});
|
76
|
+
};
|
77
|
+
const getBackground = () => {
|
78
|
+
switch (title) {
|
79
|
+
case "Document":
|
80
|
+
return {
|
81
|
+
backgroundImage: `url()`
|
82
|
+
};
|
83
|
+
default:
|
84
|
+
return {
|
85
|
+
backgroundImage: base64 ? `url(${base64})` : "none"
|
86
|
+
};
|
87
|
+
}
|
88
|
+
};
|
89
|
+
const renderThumb = () => {
|
90
|
+
switch (title) {
|
91
|
+
case "Video":
|
92
|
+
case "Document":
|
93
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
94
|
+
children: [/*#__PURE__*/_jsx(Typography, {
|
95
|
+
style: {
|
96
|
+
padding: "8px",
|
97
|
+
fontSize: "12px",
|
98
|
+
color: "#2563eb",
|
99
|
+
textAlign: "center"
|
100
|
+
},
|
101
|
+
children: fileName
|
102
|
+
}), /*#__PURE__*/_jsx(Grid, {
|
103
|
+
className: "removeImageText",
|
104
|
+
onClick: onRemoveBG,
|
105
|
+
children: translation("Remove")
|
106
|
+
})]
|
107
|
+
});
|
108
|
+
default:
|
109
|
+
return /*#__PURE__*/_jsx(Grid, {
|
110
|
+
className: "removeImageText",
|
111
|
+
onClick: onRemoveBG,
|
112
|
+
children: translation("Remove")
|
113
|
+
});
|
114
|
+
}
|
115
|
+
};
|
116
|
+
return /*#__PURE__*/_jsx(_Fragment, {
|
117
|
+
children: /*#__PURE__*/_jsxs(Grid, {
|
118
|
+
style: {
|
119
|
+
height: error ? "fit-content" : "inherit"
|
120
|
+
},
|
121
|
+
className: "uploaderRoot",
|
122
|
+
children: [/*#__PURE__*/_jsx(Grid, {
|
123
|
+
item: true,
|
124
|
+
xs: 12,
|
125
|
+
children: error && /*#__PURE__*/_jsx(Typography, {
|
126
|
+
style: {
|
127
|
+
color: "red",
|
128
|
+
marginBottom: "8px"
|
129
|
+
},
|
130
|
+
children: error
|
131
|
+
})
|
132
|
+
}), /*#__PURE__*/_jsx(Grid, {
|
133
|
+
container: true,
|
134
|
+
sx: classes.uploadContainer,
|
135
|
+
style: {
|
136
|
+
minHeight: error ? "250px" : "none"
|
137
|
+
},
|
138
|
+
className: "uploaderDragPlace",
|
139
|
+
children: /*#__PURE__*/_jsx(Grid, {
|
140
|
+
item: true,
|
141
|
+
xs: 12,
|
142
|
+
className: "btn--wrpr",
|
143
|
+
style: {
|
144
|
+
...getBackground()
|
145
|
+
},
|
146
|
+
sx: classes.uploadField,
|
147
|
+
children: !uploading ? /*#__PURE__*/_jsx(Grid, {
|
148
|
+
className: "uploadImageSection",
|
149
|
+
children: base64 ? renderThumb() : /*#__PURE__*/_jsx(Grid, {
|
150
|
+
className: "uploadImageText",
|
151
|
+
children: /*#__PURE__*/_jsxs(Button, {
|
152
|
+
component: "label",
|
153
|
+
variant: "text",
|
154
|
+
style: {
|
155
|
+
background: "none",
|
156
|
+
width: "100%"
|
157
|
+
},
|
158
|
+
sx: classes.uploadIcon,
|
159
|
+
children: [/*#__PURE__*/_jsx("input", {
|
160
|
+
type: "file",
|
161
|
+
accept: allowedFormat[title],
|
162
|
+
style: {
|
163
|
+
opacity: 0,
|
164
|
+
width: "0px"
|
165
|
+
},
|
166
|
+
onChange: handleChange
|
167
|
+
}), /*#__PURE__*/_jsx(Icon, {
|
168
|
+
icon: "fileUpload"
|
169
|
+
}), /*#__PURE__*/_jsx("span", {
|
170
|
+
style: {
|
171
|
+
paddingLeft: "8px"
|
172
|
+
},
|
173
|
+
children: `${translation("upload")} ${translation(title) || translation("image")}`
|
174
|
+
})]
|
175
|
+
})
|
176
|
+
})
|
177
|
+
}) : null
|
178
|
+
})
|
179
|
+
})]
|
180
|
+
})
|
181
|
+
});
|
182
|
+
};
|
183
|
+
export default UploaderWithProgress;
|
@@ -1677,6 +1677,27 @@ export const CloseIcon = props => /*#__PURE__*/_jsxs("svg", {
|
|
1677
1677
|
strokeLinejoin: "round"
|
1678
1678
|
})]
|
1679
1679
|
});
|
1680
|
+
export const CloseIcon2 = props => /*#__PURE__*/_jsxs("svg", {
|
1681
|
+
width: "10",
|
1682
|
+
height: "10",
|
1683
|
+
viewBox: "0 0 10 10",
|
1684
|
+
fill: "none",
|
1685
|
+
xmlns: "http://www.w3.org/2000/svg",
|
1686
|
+
...(props || {}),
|
1687
|
+
children: [/*#__PURE__*/_jsx("path", {
|
1688
|
+
d: "M9.12476 0.875L0.875176 9.12458",
|
1689
|
+
stroke: "#8F9CAE",
|
1690
|
+
strokeWidth: "1.5",
|
1691
|
+
strokeLinecap: "round",
|
1692
|
+
strokeLinejoin: "round"
|
1693
|
+
}), /*#__PURE__*/_jsx("path", {
|
1694
|
+
d: "M0.875183 0.875L9.12476 9.12458",
|
1695
|
+
stroke: "#8F9CAE",
|
1696
|
+
strokeWidth: "1.5",
|
1697
|
+
strokeLinecap: "round",
|
1698
|
+
strokeLinejoin: "round"
|
1699
|
+
})]
|
1700
|
+
});
|
1680
1701
|
export const SearchIcon = () => /*#__PURE__*/_jsxs("svg", {
|
1681
1702
|
width: "18",
|
1682
1703
|
height: "18",
|
@@ -211,16 +211,16 @@ const useCommonStyle = theme => ({
|
|
211
211
|
backgroundColor: theme?.palette?.editor?.miniToolBarBackground
|
212
212
|
},
|
213
213
|
"& .popup_tabs": {
|
214
|
-
backgroundColor: theme?.palette?.editor?.
|
214
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
215
215
|
"@media only screen and (max-width: 899px)": {
|
216
216
|
width: "100% !important"
|
217
217
|
}
|
218
218
|
},
|
219
219
|
"& .popup_tabs-header": {
|
220
|
-
backgroundColor: theme?.palette?.editor?.
|
220
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
221
221
|
"& .popup_tabs-header-label-active": {
|
222
222
|
color: theme?.palette?.editor?.activeColor,
|
223
|
-
backgroundColor: theme?.palette?.editor?.
|
223
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground
|
224
224
|
}
|
225
225
|
},
|
226
226
|
"& .colorpicker": {
|
@@ -249,6 +249,40 @@ const useCommonStyle = theme => ({
|
|
249
249
|
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
250
250
|
color: theme?.palette?.editor?.textColor
|
251
251
|
}
|
252
|
+
},
|
253
|
+
"& .colorPickerActionBtns": {
|
254
|
+
backgroundColor: theme?.palette?.editor?.miniToolBarBackground,
|
255
|
+
display: "flex",
|
256
|
+
justifyContent: "end",
|
257
|
+
padding: "10px",
|
258
|
+
position: "sticky",
|
259
|
+
bottom: 0,
|
260
|
+
right: 0,
|
261
|
+
boxShadow: `0px -3px 12px 0px ${theme?.palette?.editor?.cardShadow}`,
|
262
|
+
gap: "8px",
|
263
|
+
"& button": {
|
264
|
+
fontWeight: 600,
|
265
|
+
fontSize: "14px",
|
266
|
+
opacity: 1,
|
267
|
+
borderRadius: "8px",
|
268
|
+
textTransform: "math-auto",
|
269
|
+
padding: "4px 20px",
|
270
|
+
height: "fit-content",
|
271
|
+
minWidth: "90px",
|
272
|
+
"@media only screen and (max-width: 899px)": {
|
273
|
+
width: "50%"
|
274
|
+
},
|
275
|
+
"&.confirmBtn": {
|
276
|
+
backgroundColor: "#2563EB",
|
277
|
+
color: "#ffffff",
|
278
|
+
border: `1px solid #2563EB`
|
279
|
+
},
|
280
|
+
"&.cancelBtn": {
|
281
|
+
backgroundColor: theme?.palette?.editor?.closeButtonBackground,
|
282
|
+
color: theme?.palette?.editor?.customDialogueCloseBtnColor,
|
283
|
+
border: `1px solid ${theme?.palette?.editor?.customDialogueCloseBtnBorder}`
|
284
|
+
}
|
285
|
+
}
|
252
286
|
}
|
253
287
|
},
|
254
288
|
colorPickerBtnBorder: {
|
@@ -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
|
+
};
|