@flozy/editor 4.6.2 โ 4.6.4
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/Editor/CommonEditor.js +17 -17
- package/dist/Editor/Editor.css +32 -1
- package/dist/Editor/Elements/AI/AIInput.js +4 -5
- package/dist/Editor/Elements/AI/PopoverAIInput.js +40 -29
- package/dist/Editor/Elements/AI/Styles.js +1 -1
- package/dist/Editor/Elements/Button/EditorButton.js +8 -4
- package/dist/Editor/Elements/Divider/Divider.js +115 -8
- package/dist/Editor/Elements/Divider/DividerPopup.js +24 -0
- package/dist/Editor/Elements/Embed/Embed.css +1 -1
- package/dist/Editor/Elements/Embed/Image.js +3 -2
- package/dist/Editor/Elements/Embed/Video.js +7 -4
- package/dist/Editor/Elements/Emoji/EmojiButton.js +1 -23
- package/dist/Editor/Elements/Form/Form.js +0 -1
- package/dist/Editor/Elements/Form/Workflow/FormWorkflow.js +3 -12
- package/dist/Editor/Elements/FreeGrid/FreeGrid.js +56 -3
- package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +2 -0
- package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +7 -3
- package/dist/Editor/Elements/FreeGrid/Options/AddElement.js +16 -2
- package/dist/Editor/Elements/FreeGrid/Options/sectionItemOptions.js +8 -2
- package/dist/Editor/Elements/FreeGrid/styles.js +83 -2
- package/dist/Editor/Elements/Signature/SignaturePopup.js +24 -7
- package/dist/Editor/Elements/Signature/Signed.js +1 -1
- package/dist/Editor/Elements/SimpleText/index.js +7 -8
- package/dist/Editor/Elements/Table/TableRow.js +1 -1
- package/dist/Editor/Styles/EditorStyles.js +2 -2
- package/dist/Editor/Toolbar/Mini/MiniToolbar.js +1 -2
- package/dist/Editor/Toolbar/PopupTool/ButtonTemplatesCard.js +35 -29
- package/dist/Editor/Toolbar/PopupTool/FullViewCard.js +35 -30
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +4 -4
- package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +22 -38
- package/dist/Editor/Toolbar/PopupTool/TextFormat.js +0 -1
- package/dist/Editor/Toolbar/PopupTool/index.js +18 -6
- package/dist/Editor/common/FontLoader/FontLoader.js +6 -6
- package/dist/Editor/common/Icon.js +1 -1
- package/dist/Editor/common/LinkSettings/index.js +3 -3
- package/dist/Editor/common/LinkSettings/navOptions.js +4 -1
- package/dist/Editor/common/RnD/DragOver/index.js +0 -1
- package/dist/Editor/common/RnD/ElementOptions/Actions.js +15 -2
- package/dist/Editor/common/RnD/ElementOptions/styles.js +5 -0
- package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +1 -1
- package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Signature.js +53 -0
- package/dist/Editor/common/RnD/ElementSettings/OtherSettings/index.js +32 -2
- package/dist/Editor/common/RnD/ElementSettings/Settings/DividerSettings.js +49 -0
- package/dist/Editor/common/RnD/ElementSettings/Settings/index.js +3 -1
- package/dist/Editor/common/RnD/ElementSettings/settingsConstants.js +5 -2
- package/dist/Editor/common/RnD/RnDCopy.js +2 -0
- package/dist/Editor/common/RnD/Utils/gridDropItem.js +5 -3
- package/dist/Editor/common/RnD/VirtualElement/index.js +1 -1
- package/dist/Editor/common/RnD/index.js +67 -37
- package/dist/Editor/common/Section/index.js +11 -1
- package/dist/Editor/common/Section/styles.js +16 -0
- package/dist/Editor/common/StyleBuilder/dividerStyles.js +56 -0
- package/dist/Editor/common/StyleBuilder/embedVideoStyle.js +19 -0
- package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +19 -4
- package/dist/Editor/common/SwipeableDrawer/index.js +4 -15
- package/dist/Editor/common/SwipeableDrawer/style.js +3 -11
- package/dist/Editor/common/Uploader.js +2 -1
- package/dist/Editor/common/iconslist.js +23 -0
- package/dist/Editor/helper/RnD/focusNode.js +74 -0
- package/dist/Editor/helper/index.js +5 -2
- package/dist/Editor/helper/theme.js +2 -2
- package/dist/Editor/hooks/useBreakpoints.js +1 -1
- package/dist/Editor/hooks/useDragging.js +51 -0
- package/dist/Editor/hooks/useMouseMove.js +5 -4
- package/dist/Editor/hooks/withCommon.js +1 -0
- package/dist/Editor/hooks/withRestrictedNodes.js +48 -0
- package/dist/Editor/utils/Decorators/highlightSelection.js +16 -0
- package/dist/Editor/utils/Decorators/index.js +3 -2
- package/dist/Editor/utils/RnD/RnDCtrlCmds.js +16 -1
- package/dist/Editor/utils/SlateUtilityFunctions.js +33 -5
- package/dist/Editor/utils/events.js +71 -0
- package/dist/Editor/utils/helper.js +16 -0
- package/package.json +1 -1
@@ -13,7 +13,7 @@ import PopperHeader from "../PopperHeader";
|
|
13
13
|
import MiniColorPicker from "./MiniColorPicker";
|
14
14
|
import SelectAlignment from "./SelectAlignment";
|
15
15
|
import SelectFontSize from "./SelectFontSize";
|
16
|
-
|
16
|
+
import InfinityAITool from "./InfinityAITool";
|
17
17
|
import { jsx as _jsx } from "react/jsx-runtime";
|
18
18
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
19
19
|
const DEFAULT_COLOR = {
|
@@ -27,8 +27,8 @@ const MiniTextFormat = props => {
|
|
27
27
|
const {
|
28
28
|
classes,
|
29
29
|
editor,
|
30
|
-
closeMainPopup
|
31
|
-
|
30
|
+
closeMainPopup,
|
31
|
+
customProps
|
32
32
|
} = props;
|
33
33
|
const [anchorEl, setAnchorEl] = useState(null);
|
34
34
|
const open = Boolean(anchorEl);
|
@@ -50,7 +50,7 @@ const MiniTextFormat = props => {
|
|
50
50
|
xs: 12,
|
51
51
|
children: /*#__PURE__*/_jsxs("div", {
|
52
52
|
className: "toolWrapper",
|
53
|
-
children: [/*#__PURE__*/_jsx(SelectTypography, {
|
53
|
+
children: [customProps?.hideTools?.includes("infinityAI") ? null : /*#__PURE__*/_jsx(InfinityAITool, {}), /*#__PURE__*/_jsx(SelectTypography, {
|
54
54
|
classes: classes,
|
55
55
|
editor: editor,
|
56
56
|
closeMainPopup: closeMainPopup
|
@@ -3,9 +3,10 @@ const usePopupStyle = theme => ({
|
|
3
3
|
boxShadow: "1px 2px 15px 0px #2563EB40",
|
4
4
|
zIndex: 1300,
|
5
5
|
marginBottom: "12px !important",
|
6
|
-
border: "1px solid #D8DDE1",
|
7
6
|
borderRadius: "6px",
|
7
|
+
border: "1px solid #D8DDE1",
|
8
8
|
maxWidth: "100%",
|
9
|
+
// maxHeight: "40px",
|
9
10
|
"&.fullscreen": {
|
10
11
|
marginBottom: "0px !important",
|
11
12
|
"& .papper-wrpr": {
|
@@ -481,10 +482,9 @@ const usePopupStyle = theme => ({
|
|
481
482
|
}
|
482
483
|
},
|
483
484
|
fullViewCardMedia: {
|
484
|
-
margin: "5px 0px",
|
485
485
|
width: "100%",
|
486
486
|
backgroundPosition: "left top",
|
487
|
-
backgroundSize: "100
|
487
|
+
backgroundSize: "100% auto",
|
488
488
|
zIndex: 1,
|
489
489
|
position: "relative",
|
490
490
|
"&.fullscreen": {
|
@@ -499,10 +499,9 @@ const usePopupStyle = theme => ({
|
|
499
499
|
}
|
500
500
|
},
|
501
501
|
buttonCardMedia: {
|
502
|
-
margin: "5px 0px",
|
503
502
|
width: "100%",
|
504
|
-
height: "
|
505
|
-
backgroundPosition: "
|
503
|
+
height: "48px",
|
504
|
+
backgroundPosition: "left top",
|
506
505
|
backgroundSize: "contain",
|
507
506
|
zIndex: 1,
|
508
507
|
position: "relative",
|
@@ -511,25 +510,26 @@ const usePopupStyle = theme => ({
|
|
511
510
|
}
|
512
511
|
},
|
513
512
|
buttonCardMediaWrpr: {
|
514
|
-
padding: "5px",
|
515
513
|
position: "relative",
|
516
514
|
margin: "8px",
|
517
|
-
|
518
|
-
"
|
519
|
-
"
|
520
|
-
|
521
|
-
backgroundColor: "#E9F3FE",
|
522
|
-
border: "1px solid #2563EB40",
|
523
|
-
borderRadius: "5px",
|
524
|
-
// height: "100%",
|
525
|
-
margin: "0px"
|
526
|
-
// "& .template-card-action": {
|
527
|
-
// display: "flex",
|
528
|
-
// },
|
515
|
+
marginBottom: "0px",
|
516
|
+
"&:hover": {
|
517
|
+
"& .template-card-action": {
|
518
|
+
display: "flex"
|
529
519
|
}
|
520
|
+
},
|
521
|
+
"& .img-loader-wrapper": {
|
522
|
+
position: "absolute",
|
523
|
+
width: "12px",
|
524
|
+
height: "12px",
|
525
|
+
left: 0,
|
526
|
+
right: 0,
|
527
|
+
top: 0,
|
528
|
+
bottom: 0,
|
529
|
+
margin: "auto",
|
530
|
+
zIndex: 0
|
530
531
|
}
|
531
532
|
},
|
532
|
-
|
533
533
|
paperOverrides: {
|
534
534
|
"&.MuiPaper-root": {
|
535
535
|
background: "transparent",
|
@@ -587,13 +587,12 @@ const usePopupStyle = theme => ({
|
|
587
587
|
},
|
588
588
|
customSelectPopoverWrapper: {
|
589
589
|
"& .MuiPopover-paper": {
|
590
|
+
maxHeight: "140px",
|
590
591
|
// minWidth: "130px",
|
591
592
|
border: "1px solid #E4E8EB",
|
592
|
-
maxHeight: "140px",
|
593
593
|
background: `${theme?.palette?.editor?.background} !important`,
|
594
|
-
// overflowY: "hidden",
|
595
|
-
padding: "6px 12px 6px 0px",
|
596
594
|
overflowY: "scroll",
|
595
|
+
padding: "6px 12px 6px 0px",
|
597
596
|
"@media only screen and (max-width: 600px)": {
|
598
597
|
marginTop: "-40px"
|
599
598
|
}
|
@@ -643,21 +642,6 @@ const usePopupStyle = theme => ({
|
|
643
642
|
"& fieldset": {
|
644
643
|
border: "none !important"
|
645
644
|
}
|
646
|
-
},
|
647
|
-
fullViewCardMediaWrpr: {
|
648
|
-
padding: "5px",
|
649
|
-
position: "relative",
|
650
|
-
margin: "8px",
|
651
|
-
height: "140px",
|
652
|
-
"& .img-wrapper": {
|
653
|
-
"&:hover": {
|
654
|
-
padding: "0px 2px 0px 2px",
|
655
|
-
backgroundColor: "#E9F3FE",
|
656
|
-
border: "1px solid #2563EB40",
|
657
|
-
borderRadius: "5px",
|
658
|
-
margin: "0px"
|
659
|
-
}
|
660
|
-
}
|
661
645
|
}
|
662
646
|
});
|
663
647
|
export default usePopupStyle;
|
@@ -80,16 +80,16 @@ const PopupTool = props => {
|
|
80
80
|
updateAnchorEl();
|
81
81
|
}
|
82
82
|
}, [selection]);
|
83
|
-
const handleClose = () => {
|
84
|
-
setAnchorEl(null);
|
85
|
-
setOpen(false);
|
86
|
-
setPopupType("");
|
87
|
-
};
|
88
83
|
useEffect(() => {
|
89
84
|
if (selectedElement?.enable === 1) {
|
90
85
|
setAnchorEl(null);
|
91
86
|
}
|
92
87
|
}, [selection, selectedElement?.path, selectedElement?.enable]);
|
88
|
+
const handleClose = () => {
|
89
|
+
setAnchorEl(null);
|
90
|
+
setOpen(false);
|
91
|
+
setPopupType("");
|
92
|
+
};
|
93
93
|
return open && !openAI ? /*#__PURE__*/_jsx(ClickAwayListener, {
|
94
94
|
onClickAway: e => {
|
95
95
|
// close the mini toolbar, if user clicks outside the editor (in Flozy app.)
|
@@ -111,8 +111,20 @@ const PopupTool = props => {
|
|
111
111
|
open: open,
|
112
112
|
anchorEl: anchorEl,
|
113
113
|
transition: true,
|
114
|
-
placement: "auto-end",
|
115
114
|
sx: classes.popupWrapper,
|
115
|
+
placement: "bottom-start" // or "top" depending on the preferred direction
|
116
|
+
,
|
117
|
+
modifiers: [{
|
118
|
+
name: "preventOverflow",
|
119
|
+
options: {
|
120
|
+
boundary: editorWrapper?.current
|
121
|
+
}
|
122
|
+
}, {
|
123
|
+
name: "flip",
|
124
|
+
options: {
|
125
|
+
fallbackPlacements: ["top-start", "bottom-start"]
|
126
|
+
}
|
127
|
+
}],
|
116
128
|
children: ({
|
117
129
|
TransitionProps
|
118
130
|
}) => /*#__PURE__*/_jsx(Fade, {
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { useEffect } from "react";
|
2
2
|
import WebFont from "webfontloader";
|
3
3
|
import { useEditorContext } from "../../hooks/useMouseMove";
|
4
|
-
const defaultFonts = [
|
4
|
+
const defaultFonts = ["PoppinsRegular", "PoppinsBold", "Helvetica", "Georgia", "Times New Roman", "Monaco", "Courier New", "Qwitcher Grypen", "EB Garamond", "Anton", "DM Serif Text", "Libre Baskerville", "Montserrat", "Open Sans", "Public Sans", "Raleway", "Space Mono", "Bulgarian Garamond", "Impact", "Redacted Script", "Great Vibes", "Zeyada", "Allura", "Pinyon Script", "Herr Von Muellerhoff", "Dawning of a New Day", "Coming Soon", "Dancing Script", "Engagement", "Gaegu", "Ingrid Darling", "Kite One", "La Belle Aurore", "Mea Culpa", "Meddon", "Merriweather", "The Girl Next Door"];
|
5
5
|
const FontLoader = props => {
|
6
6
|
const {
|
7
7
|
otherProps,
|
@@ -15,7 +15,7 @@ const FontLoader = props => {
|
|
15
15
|
let retryCount = 0;
|
16
16
|
function loadNextBatch() {
|
17
17
|
if (currentIndex >= families?.length) {
|
18
|
-
console.log(
|
18
|
+
console.log("All fonts have been loaded");
|
19
19
|
return;
|
20
20
|
}
|
21
21
|
const batch = families?.slice(currentIndex, currentIndex + batchSize);
|
@@ -68,13 +68,13 @@ const FontLoader = props => {
|
|
68
68
|
});
|
69
69
|
} else {
|
70
70
|
function correctFontArray(fontString) {
|
71
|
-
let fontsArray = fontString.split(
|
71
|
+
let fontsArray = fontString.split(",");
|
72
72
|
let cleanedFontsArray = [...new Set(fontsArray.map(font => font.trim()))];
|
73
73
|
return cleanedFontsArray;
|
74
74
|
}
|
75
75
|
function sanitizeFontFamily(fontFamily) {
|
76
76
|
const correctedFonts = correctFontArray(fontFamily);
|
77
|
-
return correctedFonts.join(
|
77
|
+
return correctedFonts.join(", ");
|
78
78
|
}
|
79
79
|
const elements = Array.from(document?.querySelectorAll("*"));
|
80
80
|
const fontSet = new Set();
|
@@ -83,8 +83,8 @@ const FontLoader = props => {
|
|
83
83
|
fontSet.add(sanitizeFontFamily(computedStyles?.fontFamily));
|
84
84
|
});
|
85
85
|
let families = Array.from(fontSet);
|
86
|
-
families = correctFontArray(families.join(
|
87
|
-
families = families.map(font => font.replace(/\"/g,
|
86
|
+
families = correctFontArray(families.join(", "));
|
87
|
+
families = families.map(font => font.replace(/\"/g, ""));
|
88
88
|
loadFontsInBatches(families);
|
89
89
|
}
|
90
90
|
}, []);
|
@@ -224,7 +224,6 @@ const iconList = {
|
|
224
224
|
fill: "#64748B"
|
225
225
|
}
|
226
226
|
}),
|
227
|
-
calenderNewIcon: /*#__PURE__*/_jsx(CalendlyIcon, {}),
|
228
227
|
freegrid: /*#__PURE__*/_jsx(CiGrid32, {
|
229
228
|
size: 20,
|
230
229
|
style: {
|
@@ -234,6 +233,7 @@ const iconList = {
|
|
234
233
|
text: /*#__PURE__*/_jsx(Text, {
|
235
234
|
stroke: "#64748B"
|
236
235
|
}),
|
236
|
+
calenderNewIcon: /*#__PURE__*/_jsx(CalendlyIcon, {}),
|
237
237
|
textArea: /*#__PURE__*/_jsx(TextAreaIcon, {}),
|
238
238
|
phone: /*#__PURE__*/_jsx(Phone, {}),
|
239
239
|
briefCase: /*#__PURE__*/_jsx(BriefCase, {}),
|
@@ -41,9 +41,10 @@ export default function LinkSettings(props) {
|
|
41
41
|
navType
|
42
42
|
} = props;
|
43
43
|
const {
|
44
|
-
isMobile
|
44
|
+
isMobile,
|
45
|
+
tagName
|
45
46
|
} = customProps;
|
46
|
-
const navOptions = getNavOptions(customProps.hideTools);
|
47
|
+
const navOptions = getNavOptions(customProps.hideTools, tagName);
|
47
48
|
const classes = LinkSettingsStyles(theme);
|
48
49
|
const [nav, setNav] = useState(getNav(navType, navOptions));
|
49
50
|
const [navValue, setNavValue] = useState(props?.navValue || "");
|
@@ -61,7 +62,6 @@ export default function LinkSettings(props) {
|
|
61
62
|
};
|
62
63
|
if (isMobile) {
|
63
64
|
return /*#__PURE__*/_jsxs(SwipeableDrawer, {
|
64
|
-
open: true,
|
65
65
|
onClose: handleClose,
|
66
66
|
children: [/*#__PURE__*/_jsx(Typography, {
|
67
67
|
variant: "subtitle1",
|
@@ -1,4 +1,4 @@
|
|
1
|
-
export const getNavOptions = (hideTools = []) => {
|
1
|
+
export const getNavOptions = (hideTools = [], tagName = "") => {
|
2
2
|
let navOptions = [{
|
3
3
|
label: "None",
|
4
4
|
value: ""
|
@@ -33,5 +33,8 @@ export const getNavOptions = (hideTools = []) => {
|
|
33
33
|
placeholder: "phone"
|
34
34
|
}];
|
35
35
|
navOptions = navOptions.filter(n => !hideTools.includes(n.value));
|
36
|
+
if (tagName !== "Pages") {
|
37
|
+
navOptions = navOptions.filter(n => n.value !== "page");
|
38
|
+
}
|
36
39
|
return navOptions;
|
37
40
|
};
|
@@ -17,7 +17,6 @@ const DragOver = props => {
|
|
17
17
|
const open = Boolean(anchorEl);
|
18
18
|
const isSectionHover = status && type === "parent";
|
19
19
|
const isContainerHover = hover_on === path && type === "parent-container";
|
20
|
-
console.log(isSectionHover, isContainerHover);
|
21
20
|
useEffect(() => {
|
22
21
|
if (ref?.current) {
|
23
22
|
const getBoundingClientRect = () => ref?.current?.getBoundingClientRect();
|
@@ -12,7 +12,8 @@ import SaveIcon from "@mui/icons-material/Save";
|
|
12
12
|
import LinkIcon from "./Icons/LinkIcon";
|
13
13
|
import CodeIcon from "@mui/icons-material/Code";
|
14
14
|
import FilterFramesIcon from "@mui/icons-material/FilterFrames";
|
15
|
-
import { GridAddSectionIcon, WorkflowIcon } from "../../iconslist";
|
15
|
+
import { GridAddSectionIcon, SignatureIcon, WorkflowIcon } from "../../iconslist";
|
16
|
+
import Delete from "@mui/icons-material/Delete";
|
16
17
|
const Actions = {
|
17
18
|
ai: {
|
18
19
|
type: "ai",
|
@@ -26,7 +27,7 @@ const Actions = {
|
|
26
27
|
Icon: null,
|
27
28
|
title: "Add Section"
|
28
29
|
},
|
29
|
-
|
30
|
+
addElementInSection: {
|
30
31
|
type: "addElement",
|
31
32
|
Button: IconButton,
|
32
33
|
Icon: AddIcon,
|
@@ -45,6 +46,18 @@ const Actions = {
|
|
45
46
|
Icon: LinkIcon,
|
46
47
|
title: "Link"
|
47
48
|
},
|
49
|
+
signatureSettings: {
|
50
|
+
type: "signatureSettings",
|
51
|
+
Button: IconButton,
|
52
|
+
Icon: SignatureIcon,
|
53
|
+
title: "Signature"
|
54
|
+
},
|
55
|
+
removeSign: {
|
56
|
+
type: "removeSign",
|
57
|
+
Button: IconButton,
|
58
|
+
Icon: Delete,
|
59
|
+
title: "Remove Sign"
|
60
|
+
},
|
48
61
|
more: {
|
49
62
|
type: "more",
|
50
63
|
Button: IconButton,
|
@@ -0,0 +1,53 @@
|
|
1
|
+
import SignaturePopup from "../../../../Elements/Signature/SignaturePopup";
|
2
|
+
import { Path, Transforms } from "slate";
|
3
|
+
import { formatDate } from "../../../../utils/helper";
|
4
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
5
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
6
|
+
const Signature = props => {
|
7
|
+
const {
|
8
|
+
onClose,
|
9
|
+
customProps,
|
10
|
+
editor,
|
11
|
+
path
|
12
|
+
} = props;
|
13
|
+
const pPath = path?.split("|")?.map(m => parseInt(m));
|
14
|
+
const element_path = [...pPath, 0];
|
15
|
+
const onSave = (data = {}) => {
|
16
|
+
onClear();
|
17
|
+
Transforms.insertNodes(editor, [{
|
18
|
+
type: "sign",
|
19
|
+
signature: null,
|
20
|
+
fontFamily: "",
|
21
|
+
signedBy: "",
|
22
|
+
signedOn: formatDate(new Date(), "MM/DD/YYYY"),
|
23
|
+
signedText: "",
|
24
|
+
children: [{
|
25
|
+
text: ""
|
26
|
+
}],
|
27
|
+
...data
|
28
|
+
}], {
|
29
|
+
at: element_path
|
30
|
+
});
|
31
|
+
const parentPath = Path.parent(element_path);
|
32
|
+
Transforms.setNodes(editor, {
|
33
|
+
childType: "sign"
|
34
|
+
}, {
|
35
|
+
at: parentPath
|
36
|
+
});
|
37
|
+
};
|
38
|
+
const onClear = () => {
|
39
|
+
Transforms.removeNodes(editor, {
|
40
|
+
at: element_path
|
41
|
+
});
|
42
|
+
};
|
43
|
+
return /*#__PURE__*/_jsx(_Fragment, {
|
44
|
+
children: /*#__PURE__*/_jsx(SignaturePopup, {
|
45
|
+
onSave: onSave,
|
46
|
+
onClear: onClear,
|
47
|
+
handleClose: onClose,
|
48
|
+
customProps: customProps,
|
49
|
+
onlyPopup: true
|
50
|
+
})
|
51
|
+
});
|
52
|
+
};
|
53
|
+
export default Signature;
|
@@ -1,9 +1,39 @@
|
|
1
1
|
import Settings from "./Settings";
|
2
2
|
import Link from "./Link";
|
3
3
|
import SavePopup from "./SaveAsTemplate";
|
4
|
+
import Signature from "./Signature";
|
5
|
+
import { Path, Transforms } from "slate";
|
4
6
|
const OtherSettings = {
|
5
7
|
link: Link,
|
6
8
|
settings: Settings,
|
7
|
-
saveAsTemplate: SavePopup
|
9
|
+
saveAsTemplate: SavePopup,
|
10
|
+
signatureSettings: Signature
|
8
11
|
};
|
9
|
-
export default OtherSettings;
|
12
|
+
export default OtherSettings;
|
13
|
+
export const removeSign = (editor, path = []) => {
|
14
|
+
const pPath = path?.split("|")?.map(m => parseInt(m));
|
15
|
+
const element_path = [...pPath, 0];
|
16
|
+
Transforms.removeNodes(editor, {
|
17
|
+
at: element_path
|
18
|
+
}); // remove signature
|
19
|
+
|
20
|
+
Transforms.insertNodes(editor, [{
|
21
|
+
type: "signature",
|
22
|
+
children: [{
|
23
|
+
text: ""
|
24
|
+
}],
|
25
|
+
data: {
|
26
|
+
name: "",
|
27
|
+
email: "",
|
28
|
+
date: ""
|
29
|
+
}
|
30
|
+
}], {
|
31
|
+
at: element_path
|
32
|
+
});
|
33
|
+
const parentPath = Path.parent(element_path);
|
34
|
+
Transforms.setNodes(editor, {
|
35
|
+
childType: "signature"
|
36
|
+
}, {
|
37
|
+
at: parentPath
|
38
|
+
});
|
39
|
+
};
|
@@ -0,0 +1,49 @@
|
|
1
|
+
import React from "react";
|
2
|
+
import { Transforms, Node } from "slate";
|
3
|
+
import { Box } from "@mui/material";
|
4
|
+
import { StyleContent } from "../../../StyleBuilder";
|
5
|
+
import dividerStyle from "../../../StyleBuilder/dividerStyles";
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
7
|
+
const DividerSettings = props => {
|
8
|
+
const {
|
9
|
+
editor,
|
10
|
+
path,
|
11
|
+
customProps
|
12
|
+
} = props;
|
13
|
+
const item_path = path?.split("|").map(m => parseInt(m));
|
14
|
+
const element_path = [...item_path, 0];
|
15
|
+
const element = Node.get(editor, element_path);
|
16
|
+
const onChange = data => {
|
17
|
+
console.log("๐ ~ onChange ~ data:", data);
|
18
|
+
console.log("๐ ~ onChange ~ element:", element);
|
19
|
+
const updated_props = {
|
20
|
+
...element,
|
21
|
+
...data,
|
22
|
+
field_type: data?.element
|
23
|
+
};
|
24
|
+
delete updated_props.children;
|
25
|
+
Transforms.setNodes(editor, {
|
26
|
+
...updated_props
|
27
|
+
}, {
|
28
|
+
at: element_path
|
29
|
+
});
|
30
|
+
};
|
31
|
+
const handleClose = () => {
|
32
|
+
console.log("close");
|
33
|
+
};
|
34
|
+
return /*#__PURE__*/_jsx(Box, {
|
35
|
+
component: "div",
|
36
|
+
className: "item-w",
|
37
|
+
children: dividerStyle?.map((m, i) => {
|
38
|
+
return /*#__PURE__*/_jsx(StyleContent, {
|
39
|
+
renderTabs: dividerStyle,
|
40
|
+
value: m.value,
|
41
|
+
element: element,
|
42
|
+
onChange: onChange,
|
43
|
+
customProps: customProps,
|
44
|
+
handleClose: handleClose
|
45
|
+
}, `tab_${m.value}_$${i}`);
|
46
|
+
})
|
47
|
+
});
|
48
|
+
};
|
49
|
+
export default DividerSettings;
|
@@ -7,6 +7,7 @@ import AppHeaderSettings from "./AppHeaderSettings";
|
|
7
7
|
import FormSettings from "./FormSettings";
|
8
8
|
import TableSettings from "./TableSettings";
|
9
9
|
import CodeSettings from "./CodeSettings";
|
10
|
+
import DividerSettings from "./DividerSettings";
|
10
11
|
const SettingsComponents = {
|
11
12
|
text: TextSettings,
|
12
13
|
button: ButtonSettings,
|
@@ -16,6 +17,7 @@ const SettingsComponents = {
|
|
16
17
|
appHeader: AppHeaderSettings,
|
17
18
|
form: FormSettings,
|
18
19
|
table: TableSettings,
|
19
|
-
embedScript: CodeSettings
|
20
|
+
embedScript: CodeSettings,
|
21
|
+
divider: DividerSettings
|
20
22
|
};
|
21
23
|
export default SettingsComponents;
|
@@ -7,7 +7,8 @@ export const settingsLabel = {
|
|
7
7
|
appHeader: "App Header Settings",
|
8
8
|
form: "Form Settings",
|
9
9
|
table: "Table Settings",
|
10
|
-
embedScript: "Code Settings"
|
10
|
+
embedScript: "Code Settings",
|
11
|
+
divider: 'Divider Settings'
|
11
12
|
};
|
12
13
|
export const ItemTypes = {
|
13
14
|
text: "Text",
|
@@ -18,5 +19,7 @@ export const ItemTypes = {
|
|
18
19
|
appHeader: "App Header",
|
19
20
|
form: "Form",
|
20
21
|
table: "Table",
|
21
|
-
embedScript: "Code"
|
22
|
+
embedScript: "Code",
|
23
|
+
signature: "Signature",
|
24
|
+
divider: 'Divider'
|
22
25
|
};
|
@@ -12,6 +12,8 @@ const RnDCopy = props => {
|
|
12
12
|
useEffect(() => {
|
13
13
|
if (selectedElement?.path) {
|
14
14
|
window.selectedRnDElement = selectedElement;
|
15
|
+
} else {
|
16
|
+
window.selectedRnDElement = {};
|
15
17
|
}
|
16
18
|
}, [selectedElement?.path, selectedElement?.enable]);
|
17
19
|
return !readOnly ? /*#__PURE__*/_jsx(Box, {
|
@@ -123,8 +123,8 @@ export function onDropItem(props, parentClass) {
|
|
123
123
|
dragOver,
|
124
124
|
parentPath,
|
125
125
|
path,
|
126
|
-
diffX,
|
127
|
-
x: cx,
|
126
|
+
// diffX,
|
127
|
+
// x: cx,
|
128
128
|
breakpoint
|
129
129
|
// calX,
|
130
130
|
} = props;
|
@@ -134,7 +134,9 @@ export function onDropItem(props, parentClass) {
|
|
134
134
|
let newPath = [];
|
135
135
|
newPath = moveTo;
|
136
136
|
const cCalx = isContainerElement(editor, moveTo, props);
|
137
|
-
const posX = parseInt(
|
137
|
+
// const posX = parseInt(
|
138
|
+
// cx - window.innerWidth / 2 + MARGIN_OF[breakpoint] - diffX
|
139
|
+
// );
|
138
140
|
const toSectionNode = Node.get(editor, newPath);
|
139
141
|
const addToSectionDOM = ReactEditor.toDOMNode(editor, toSectionNode);
|
140
142
|
const rect = addToSectionDOM.getBoundingClientRect();
|