@flozy/editor 1.6.0 → 1.6.2
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/Editor/CommonEditor.js +131 -104
- package/dist/Editor/DialogWrapper.js +3 -0
- package/dist/Editor/Editor.css +27 -36
- package/dist/Editor/Elements/Accordion/AccordionButton.js +13 -12
- package/dist/Editor/Elements/AppHeader/AppHeader.js +2 -2
- package/dist/Editor/Elements/Button/ButtonToolIcon.js +10 -9
- package/dist/Editor/Elements/Button/EditorButton.js +4 -20
- package/dist/Editor/Elements/Carousel/Carousel.js +47 -28
- package/dist/Editor/Elements/Carousel/CarouselButton.js +7 -8
- package/dist/Editor/Elements/Color Picker/ColorButtons.js +133 -0
- package/dist/Editor/Elements/Color Picker/ColorPicker.js +39 -19
- package/dist/Editor/Elements/Color Picker/Styles.js +51 -0
- package/dist/Editor/Elements/Color Picker/defaultColors.js +1 -1
- package/dist/Editor/Elements/Embed/Embed.js +33 -126
- package/dist/Editor/Elements/Embed/Image.js +15 -7
- package/dist/Editor/Elements/Embed/Video.js +12 -5
- package/dist/Editor/Elements/Emoji/EmojiButton.js +73 -0
- package/dist/Editor/Elements/Emoji/EmojiPicker.js +0 -0
- package/dist/Editor/Elements/Form/Form.js +24 -12
- package/dist/Editor/Elements/Form/FormButton.js +11 -9
- package/dist/Editor/Elements/Form/FormElements/FormText.js +1 -0
- package/dist/Editor/Elements/Form/FormField.js +7 -1
- package/dist/Editor/Elements/Grid/Grid.js +15 -4
- package/dist/Editor/Elements/Grid/GridButton.js +52 -29
- package/dist/Editor/Elements/Grid/GridItem.js +30 -19
- package/dist/Editor/Elements/Grid/Styles.js +11 -0
- package/dist/Editor/Elements/List/CheckList.js +57 -0
- package/dist/Editor/Elements/List/CheckListButton.js +24 -0
- package/dist/Editor/Elements/NewLine/NewLineButton.js +14 -14
- package/dist/Editor/Elements/PageSettings/PageSettingsButton.js +17 -60
- package/dist/Editor/Elements/Signature/Signature.js +9 -3
- package/dist/Editor/Elements/Signature/SignatureButton.js +10 -9
- package/dist/Editor/Elements/Signature/SignaturePopup.js +50 -7
- package/dist/Editor/Elements/SimpleText.js +62 -0
- package/dist/Editor/Elements/Table/Styles.js +66 -0
- package/dist/Editor/Elements/Table/Table.js +33 -16
- package/dist/Editor/Elements/Table/TableCell.js +54 -24
- package/dist/Editor/Elements/Table/TableSelector.js +13 -15
- package/dist/Editor/Elements/Table/table.css +0 -10
- package/dist/Editor/Elements/TopBanner/Styles.js +33 -0
- package/dist/Editor/Elements/TopBanner/TopBanner.js +106 -0
- package/dist/Editor/Elements/TopBanner/TopBannerButton.js +47 -0
- package/dist/Editor/Styles/EditorStyles.js +50 -0
- package/dist/Editor/Toolbar/FormatTools/Dropdown.js +8 -3
- package/dist/Editor/Toolbar/FormatTools/FontFamilyDropdown.js +16 -16
- package/dist/Editor/Toolbar/FormatTools/FontSize.js +17 -17
- package/dist/Editor/Toolbar/FormatTools/TextSize.js +13 -3
- package/dist/Editor/Toolbar/FormatTools/index.js +3 -2
- package/dist/Editor/Toolbar/Mini/MiniToolbar.js +101 -0
- package/dist/Editor/Toolbar/Mini/Options/Options.js +17 -0
- package/dist/Editor/Toolbar/Mini/Styles.js +30 -0
- package/dist/Editor/Toolbar/PopupTool/AddElements.js +32 -0
- package/dist/Editor/Toolbar/PopupTool/AddTemplates.js +115 -0
- package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +65 -0
- package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +160 -6
- package/dist/Editor/Toolbar/PopupTool/TextFormat.js +263 -80
- package/dist/Editor/Toolbar/PopupTool/index.js +33 -44
- package/dist/Editor/Toolbar/Toolbar.js +178 -134
- package/dist/Editor/Toolbar/styles.css +1 -1
- package/dist/Editor/Toolbar/toolbarGroups.js +83 -34
- package/dist/Editor/assets/svg/AddElementIcon.js +29 -0
- package/dist/Editor/assets/svg/AddTemplateIcon.js +29 -0
- package/dist/Editor/assets/svg/TextIcon.js +29 -0
- package/dist/Editor/common/Icon.js +48 -5
- package/dist/Editor/common/ImageList.js +10 -4
- package/dist/Editor/common/ImageSelector/ImageSelector.js +117 -0
- package/dist/Editor/common/ImageSelector/Options/AddLink.js +44 -0
- package/dist/Editor/common/ImageSelector/Options/ChooseAssets.js +39 -0
- package/dist/Editor/common/ImageSelector/Options/Upload.js +30 -0
- package/dist/Editor/common/ImageSelector/Styles.js +41 -0
- package/dist/Editor/common/ImageUploader.js +19 -8
- package/dist/Editor/common/MentionsPopup/ElementsListCard.js +66 -0
- package/dist/Editor/common/MentionsPopup/MentionsListCard.js +70 -0
- package/dist/Editor/common/MentionsPopup/Styles.js +68 -0
- package/dist/Editor/common/MentionsPopup/index.js +129 -0
- package/dist/Editor/common/Shorthands/elements.js +191 -0
- package/dist/Editor/common/Shorthands/index.js +7 -0
- package/dist/Editor/common/Shorthands/mentions.js +8 -0
- package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +21 -73
- package/dist/Editor/common/StyleBuilder/fieldTypes/buttonLink.js +3 -20
- package/dist/Editor/common/StyleBuilder/index.js +0 -1
- package/dist/Editor/common/StyleBuilder/tableStyle.js +9 -5
- package/dist/Editor/common/ToolbarIcon.js +43 -0
- package/dist/Editor/common/Uploader.js +10 -7
- package/dist/Editor/common/iconslist.js +46 -1
- package/dist/Editor/hooks/useMentions.js +104 -17
- package/dist/Editor/hooks/useMouseMove.js +53 -0
- package/dist/Editor/hooks/useScroll.js +26 -0
- package/dist/Editor/plugins/withEmbeds.js +12 -0
- package/dist/Editor/service/fileupload.js +2 -2
- package/dist/Editor/utils/SlateUtilityFunctions.js +61 -10
- package/dist/Editor/utils/carousel.js +5 -2
- package/dist/Editor/utils/carouselItem.js +2 -2
- package/dist/Editor/utils/customHooks/useResize.js +2 -3
- package/dist/Editor/utils/customHooks/useTableResize.js +2 -1
- package/dist/Editor/utils/embed.js +19 -5
- package/dist/Editor/utils/emoji.js +8 -0
- package/dist/Editor/utils/events.js +49 -12
- package/dist/Editor/utils/form.js +3 -9
- package/dist/Editor/utils/formfield.js +2 -1
- package/dist/Editor/utils/grid.js +44 -8
- package/dist/Editor/utils/gridItem.js +4 -3
- package/dist/Editor/utils/insertNewLine.js +12 -0
- package/dist/Editor/utils/mentions.js +14 -10
- package/dist/Editor/utils/pageSettings.js +67 -0
- package/dist/Editor/utils/signature.js +6 -8
- package/dist/Editor/utils/table.js +79 -18
- package/dist/Editor/utils/topBanner.js +58 -0
- package/package.json +4 -1
- package/dist/Editor/common/MentionsPopup.js +0 -56
@@ -1,34 +1,33 @@
|
|
1
1
|
import React, { useState, useEffect } from "react";
|
2
2
|
import { Editor, Element } from "slate";
|
3
|
-
import {
|
4
|
-
import
|
5
|
-
import { useSelected, useSlateStatic, ReactEditor } from "slate-react";
|
3
|
+
import { Box } from "@mui/material";
|
4
|
+
import { useSlateStatic, ReactEditor } from "slate-react";
|
6
5
|
import useTableResize from "../../utils/customHooks/useTableResize";
|
7
6
|
import { TableUtil } from "../../utils/table";
|
7
|
+
import TableStyles from "./Styles";
|
8
8
|
import { jsx as _jsx } from "react/jsx-runtime";
|
9
9
|
import { Fragment as _Fragment } from "react/jsx-runtime";
|
10
10
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
11
11
|
const Resizer = ({
|
12
|
-
|
12
|
+
classes,
|
13
|
+
onMouseDown,
|
14
|
+
height
|
13
15
|
}) => {
|
14
16
|
return /*#__PURE__*/_jsx(_Fragment, {
|
15
|
-
children: /*#__PURE__*/_jsx(
|
17
|
+
children: /*#__PURE__*/_jsx(Box, {
|
18
|
+
component: "div",
|
16
19
|
className: "cell-resizer",
|
17
20
|
contentEditable: false,
|
18
21
|
onPointerDown: onMouseDown,
|
22
|
+
sx: classes.cellResizer,
|
19
23
|
style: {
|
20
|
-
|
21
|
-
|
22
|
-
top: 0,
|
23
|
-
background: "none",
|
24
|
-
width: "15px",
|
25
|
-
height: "100%"
|
26
|
-
},
|
27
|
-
children: /*#__PURE__*/_jsx(AspectRatioIcon, {})
|
24
|
+
height: `${height}px`
|
25
|
+
}
|
28
26
|
})
|
29
27
|
});
|
30
28
|
};
|
31
29
|
const TableCell = props => {
|
30
|
+
const classes = TableStyles();
|
32
31
|
const {
|
33
32
|
element,
|
34
33
|
attributes,
|
@@ -40,17 +39,18 @@ const TableCell = props => {
|
|
40
39
|
} = customProps;
|
41
40
|
const {
|
42
41
|
bgColor,
|
43
|
-
borderColor
|
42
|
+
borderColor,
|
43
|
+
entireBgColor
|
44
44
|
} = element;
|
45
45
|
const [parentDOM, setParentDOM] = useState(null);
|
46
46
|
const editor = useSlateStatic();
|
47
|
-
const selected = useSelected();
|
48
47
|
const path = ReactEditor.findPath(editor, element);
|
49
48
|
const isHeader = path.length >= 2 ? path[path.length - 2] === 0 : false;
|
50
49
|
const [size, onMouseDown, resizing, onLoad] = useTableResize({
|
51
50
|
parentDOM,
|
52
51
|
size: element?.size
|
53
52
|
});
|
53
|
+
const [tableSize, setTableSize] = useState({});
|
54
54
|
const table = new TableUtil(editor);
|
55
55
|
const tableProps = table.getTableProps();
|
56
56
|
const [tableNode] = Editor.nodes(editor, {
|
@@ -63,16 +63,40 @@ const TableCell = props => {
|
|
63
63
|
});
|
64
64
|
const [parentProps] = tableNode || [{}];
|
65
65
|
const [rowProps] = rowNode || [{}];
|
66
|
+
const tableDOM = table.getDOMNode(path, true);
|
67
|
+
const isCellSelected = table.isCellSelected(editor.selection);
|
68
|
+
const hasSelected = (isCellSelected || [])?.findIndex(f => f.join(",") === path.join(",")) > -1;
|
66
69
|
useEffect(() => {
|
67
|
-
if (
|
70
|
+
if (tableDOM) {
|
71
|
+
const {
|
72
|
+
width,
|
73
|
+
height
|
74
|
+
} = tableDOM.getBoundingClientRect();
|
75
|
+
const {
|
76
|
+
width: parentWidth
|
77
|
+
} = tableDOM?.parentNode?.parentNode?.getBoundingClientRect();
|
78
|
+
const {
|
79
|
+
styleProps
|
80
|
+
} = tableProps || {};
|
81
|
+
const columns = styleProps ? styleProps["table.columns"] : 2;
|
82
|
+
setTableSize({
|
83
|
+
width,
|
84
|
+
height,
|
85
|
+
parentWidth,
|
86
|
+
cellWidth: parentWidth / columns
|
87
|
+
});
|
88
|
+
}
|
89
|
+
}, [tableDOM]);
|
90
|
+
useEffect(() => {
|
91
|
+
if (editor && element && tableSize) {
|
68
92
|
const dom = ReactEditor.toDOMNode(editor, element);
|
69
93
|
setParentDOM(dom);
|
70
94
|
onLoad(element?.size || {
|
71
|
-
width:
|
95
|
+
width: tableSize?.cellWidth,
|
72
96
|
height: 100
|
73
97
|
});
|
74
98
|
}
|
75
|
-
}, []);
|
99
|
+
}, [tableSize]);
|
76
100
|
useEffect(() => {
|
77
101
|
if (!resizing && tableProps) {
|
78
102
|
table.updateTableStyle({
|
@@ -81,20 +105,26 @@ const TableCell = props => {
|
|
81
105
|
}
|
82
106
|
}, [resizing]);
|
83
107
|
const sizeProps = isHeader ? {
|
84
|
-
width: size?.width ||
|
108
|
+
width: size?.width || tableSize?.cellWidth
|
85
109
|
} : {};
|
110
|
+
const cellBorderColor = borderColor || rowProps?.borderColor || parentProps?.borderColor;
|
86
111
|
return /*#__PURE__*/_jsxs("td", {
|
87
112
|
...element.attr,
|
88
113
|
...attributes,
|
89
|
-
className:
|
114
|
+
className: `editor-table-cell ${hasSelected ? "selection" : ""}`,
|
90
115
|
style: {
|
91
116
|
position: "relative",
|
92
|
-
backgroundColor: bgColor,
|
93
|
-
border: `3px solid ${
|
117
|
+
backgroundColor: bgColor || entireBgColor,
|
118
|
+
border: `3px solid ${cellBorderColor}`,
|
94
119
|
...(sizeProps || {})
|
95
120
|
},
|
96
|
-
children: [children,
|
97
|
-
|
121
|
+
children: [children, isHeader && !readOnly && tableSize?.height ? /*#__PURE__*/_jsx(Resizer, {
|
122
|
+
classes: classes,
|
123
|
+
onMouseDown: onMouseDown,
|
124
|
+
height: tableSize?.height
|
125
|
+
}) : null, hasSelected ? /*#__PURE__*/_jsx("div", {
|
126
|
+
className: "selection-area-tc",
|
127
|
+
contentEditable: false
|
98
128
|
}) : null]
|
99
129
|
});
|
100
130
|
};
|
@@ -1,16 +1,16 @@
|
|
1
1
|
import React, { useRef, useState } from "react";
|
2
|
-
import { Grid, Button, Dialog, DialogActions, DialogContent, DialogTitle, IconButton, TextField, Typography
|
2
|
+
import { Grid, Button, Dialog, DialogActions, DialogContent, DialogTitle, IconButton, TextField, Typography } from "@mui/material";
|
3
3
|
import Icon from "../../common/Icon";
|
4
4
|
import { Transforms } from "slate";
|
5
5
|
import { TableUtil } from "../../utils/table.js";
|
6
6
|
import "./TableSelector.css";
|
7
7
|
import CloseIcon from "@mui/icons-material/Close";
|
8
|
-
|
9
|
-
// import styled from "@emotion/styled";
|
8
|
+
import ToolbarIcon from "../../common/ToolbarIcon";
|
10
9
|
import { jsx as _jsx } from "react/jsx-runtime";
|
11
10
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
12
11
|
const TableSelector = ({
|
13
|
-
editor
|
12
|
+
editor,
|
13
|
+
icoBtnType
|
14
14
|
}) => {
|
15
15
|
const tableOptionsRef = useRef();
|
16
16
|
const [selection, setSelection] = useState();
|
@@ -41,18 +41,16 @@ const TableSelector = ({
|
|
41
41
|
return /*#__PURE__*/_jsxs("div", {
|
42
42
|
ref: tableOptionsRef,
|
43
43
|
className: "popup-wrapper1 ",
|
44
|
-
children: [/*#__PURE__*/_jsx(
|
44
|
+
children: [/*#__PURE__*/_jsx(ToolbarIcon, {
|
45
45
|
title: "Table",
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
})
|
55
|
-
})
|
46
|
+
style: {
|
47
|
+
border: showOptions ? "1px solid lightgray" : "none"
|
48
|
+
},
|
49
|
+
onClick: handleButtonClick,
|
50
|
+
icon: /*#__PURE__*/_jsx(Icon, {
|
51
|
+
icon: "table"
|
52
|
+
}),
|
53
|
+
icoBtnType: icoBtnType
|
56
54
|
}), showOptions ? /*#__PURE__*/_jsx(Dialog, {
|
57
55
|
open: showOptions,
|
58
56
|
className: `dialogComp tablePopup`,
|
@@ -0,0 +1,33 @@
|
|
1
|
+
const TopBannerStyles = () => ({
|
2
|
+
root: {
|
3
|
+
"&:hover": {
|
4
|
+
"& .tb-toolbar": {
|
5
|
+
display: "block"
|
6
|
+
}
|
7
|
+
}
|
8
|
+
},
|
9
|
+
toolbar: {
|
10
|
+
position: "absolute",
|
11
|
+
width: "auto",
|
12
|
+
bottom: "8px",
|
13
|
+
left: 0,
|
14
|
+
right: 0,
|
15
|
+
margin: "auto",
|
16
|
+
display: "none",
|
17
|
+
"& button": {
|
18
|
+
background: "#FFF",
|
19
|
+
border: "1px solid #ccc",
|
20
|
+
borderRadius: "6px",
|
21
|
+
color: "#373232",
|
22
|
+
marginRight: "8px",
|
23
|
+
padding: "4px 8px",
|
24
|
+
textTransform: "capitalize",
|
25
|
+
fontSize: "14px",
|
26
|
+
"&:hover": {
|
27
|
+
background: "#ccc",
|
28
|
+
color: "#373232"
|
29
|
+
}
|
30
|
+
}
|
31
|
+
}
|
32
|
+
});
|
33
|
+
export default TopBannerStyles;
|
@@ -0,0 +1,106 @@
|
|
1
|
+
import React, { useState } from "react";
|
2
|
+
import { Box, Button } from "@mui/material";
|
3
|
+
import { updateTopBanner, removeTopBanner } from "../../utils/topBanner";
|
4
|
+
import ImageSelector from "../../common/ImageSelector/ImageSelector";
|
5
|
+
import TopBannerStyles from "./Styles";
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
7
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
8
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
9
|
+
export const TopBannerToolbar = props => {
|
10
|
+
const {
|
11
|
+
classes,
|
12
|
+
customProps,
|
13
|
+
editor
|
14
|
+
} = props;
|
15
|
+
const [open, setOpen] = useState(false);
|
16
|
+
const handleClick = type => () => {
|
17
|
+
switch (type) {
|
18
|
+
case "change":
|
19
|
+
setOpen(true);
|
20
|
+
break;
|
21
|
+
case "remove":
|
22
|
+
removeTopBanner(editor);
|
23
|
+
break;
|
24
|
+
default:
|
25
|
+
return;
|
26
|
+
}
|
27
|
+
};
|
28
|
+
const onSelectImage = img => {
|
29
|
+
updateTopBanner(editor, {
|
30
|
+
url: img
|
31
|
+
});
|
32
|
+
handleClose();
|
33
|
+
};
|
34
|
+
const handleClose = () => {
|
35
|
+
setOpen(false);
|
36
|
+
};
|
37
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
38
|
+
children: [/*#__PURE__*/_jsxs(Box, {
|
39
|
+
component: "div",
|
40
|
+
className: "tb-toolbar",
|
41
|
+
sx: classes.toolbar,
|
42
|
+
children: [/*#__PURE__*/_jsx(Button, {
|
43
|
+
onClick: handleClick("change"),
|
44
|
+
children: "Change Image"
|
45
|
+
}), /*#__PURE__*/_jsx(Button, {
|
46
|
+
onClick: handleClick("remove"),
|
47
|
+
children: "Remove"
|
48
|
+
})]
|
49
|
+
}), /*#__PURE__*/_jsx(ImageSelector, {
|
50
|
+
open: open,
|
51
|
+
onClose: handleClose,
|
52
|
+
customProps: customProps,
|
53
|
+
onSelectImage: onSelectImage
|
54
|
+
})]
|
55
|
+
});
|
56
|
+
};
|
57
|
+
const TopBanner = props => {
|
58
|
+
const {
|
59
|
+
attributes,
|
60
|
+
element,
|
61
|
+
children,
|
62
|
+
customProps
|
63
|
+
} = props;
|
64
|
+
const {
|
65
|
+
readOnly
|
66
|
+
} = customProps;
|
67
|
+
const {
|
68
|
+
url
|
69
|
+
} = element;
|
70
|
+
const classes = TopBannerStyles();
|
71
|
+
return /*#__PURE__*/_jsxs(Box, {
|
72
|
+
component: "div",
|
73
|
+
...attributes,
|
74
|
+
style: {
|
75
|
+
position: "relative",
|
76
|
+
height: "320px",
|
77
|
+
textAlign: "center"
|
78
|
+
},
|
79
|
+
contentEditable: false,
|
80
|
+
sx: classes.root,
|
81
|
+
children: [/*#__PURE__*/_jsx("img", {
|
82
|
+
src: url,
|
83
|
+
alt: "Top Banner",
|
84
|
+
style: {
|
85
|
+
width: "90%",
|
86
|
+
height: "320px",
|
87
|
+
objectFit: "cover",
|
88
|
+
borderRadius: "12px",
|
89
|
+
margin: "0px 0px"
|
90
|
+
}
|
91
|
+
}), !readOnly ? /*#__PURE__*/_jsx(TopBannerToolbar, {
|
92
|
+
...props,
|
93
|
+
classes: classes
|
94
|
+
}) : null, /*#__PURE__*/_jsx("span", {
|
95
|
+
style: {
|
96
|
+
display: "none"
|
97
|
+
},
|
98
|
+
children: children
|
99
|
+
})]
|
100
|
+
});
|
101
|
+
};
|
102
|
+
TopBanner.defaultProps = {
|
103
|
+
attributes: {},
|
104
|
+
children: []
|
105
|
+
};
|
106
|
+
export default TopBanner;
|
@@ -0,0 +1,47 @@
|
|
1
|
+
import React, { useState } from "react";
|
2
|
+
import ToolbarIcon from "../../common/ToolbarIcon";
|
3
|
+
import Icon from "../../common/Icon";
|
4
|
+
import { insertTopBanner } from "../../utils/topBanner";
|
5
|
+
import ImageSelector from "../../common/ImageSelector/ImageSelector";
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
7
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
8
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
9
|
+
const TopBannerButton = props => {
|
10
|
+
const {
|
11
|
+
editor,
|
12
|
+
icoBtnType,
|
13
|
+
customProps
|
14
|
+
} = props;
|
15
|
+
const [open, setOpen] = useState(false);
|
16
|
+
const onSelectImage = url => {
|
17
|
+
console.log(url);
|
18
|
+
if (url) {
|
19
|
+
insertTopBanner(editor, {
|
20
|
+
url
|
21
|
+
});
|
22
|
+
}
|
23
|
+
setOpen(false);
|
24
|
+
};
|
25
|
+
const handleClick = () => {
|
26
|
+
setOpen(true);
|
27
|
+
};
|
28
|
+
const handleClose = () => {
|
29
|
+
setOpen(false);
|
30
|
+
};
|
31
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
32
|
+
children: [/*#__PURE__*/_jsx(ToolbarIcon, {
|
33
|
+
title: "Top Banner",
|
34
|
+
onClick: handleClick,
|
35
|
+
icon: /*#__PURE__*/_jsx(Icon, {
|
36
|
+
icon: "topbanner"
|
37
|
+
}),
|
38
|
+
icoBtnType: icoBtnType
|
39
|
+
}), /*#__PURE__*/_jsx(ImageSelector, {
|
40
|
+
open: open,
|
41
|
+
onClose: handleClose,
|
42
|
+
customProps: customProps,
|
43
|
+
onSelectImage: onSelectImage
|
44
|
+
})]
|
45
|
+
});
|
46
|
+
};
|
47
|
+
export default TopBannerButton;
|
@@ -0,0 +1,50 @@
|
|
1
|
+
const editorStyles = ({
|
2
|
+
padHeight
|
3
|
+
}) => ({
|
4
|
+
root: {
|
5
|
+
display: "flex",
|
6
|
+
flexDirection: "column",
|
7
|
+
position: "relative",
|
8
|
+
padding: "0 8px"
|
9
|
+
},
|
10
|
+
slateWrapper: {
|
11
|
+
height: `${window.innerHeight - padHeight}px`,
|
12
|
+
overflow: "auto",
|
13
|
+
display: "flex",
|
14
|
+
flexDirection: "column",
|
15
|
+
backgroundColor: "#cccccc2b",
|
16
|
+
"& .scroll-area": {
|
17
|
+
display: "flex",
|
18
|
+
justifyContent: "center",
|
19
|
+
// minHeight: "100vh",
|
20
|
+
flex: 1
|
21
|
+
},
|
22
|
+
"& .editor-wrapper": {
|
23
|
+
maxWidth: "90%",
|
24
|
+
height: "100%",
|
25
|
+
backgroundColor: "#FFF",
|
26
|
+
overflow: "visible"
|
27
|
+
},
|
28
|
+
"& .el-toolbar": {
|
29
|
+
position: "absolute",
|
30
|
+
left: 0,
|
31
|
+
top: 0,
|
32
|
+
width: "fit-content",
|
33
|
+
"& button": {
|
34
|
+
border: "1px solid rgba(37, 99, 235, 0.32)",
|
35
|
+
borderRadius: "10px",
|
36
|
+
boxShadow: "0px 0px 10px 0px rgba(0, 0, 0, 0.16)",
|
37
|
+
background: "#fff",
|
38
|
+
width: "36px",
|
39
|
+
height: "36px",
|
40
|
+
"&.mr": {
|
41
|
+
marginRight: "2px"
|
42
|
+
},
|
43
|
+
"& svg": {
|
44
|
+
stroke: "rgb(100, 116, 139);"
|
45
|
+
}
|
46
|
+
}
|
47
|
+
}
|
48
|
+
}
|
49
|
+
});
|
50
|
+
export default editorStyles;
|
@@ -6,7 +6,8 @@ import { jsx as _jsx } from "react/jsx-runtime";
|
|
6
6
|
const Dropdown = ({
|
7
7
|
editor,
|
8
8
|
format,
|
9
|
-
options
|
9
|
+
options,
|
10
|
+
width
|
10
11
|
}) => {
|
11
12
|
const value = activeMark(editor, format);
|
12
13
|
const changeMarkData = (event, format) => {
|
@@ -23,10 +24,11 @@ const Dropdown = ({
|
|
23
24
|
onChange: e => changeMarkData(e, format),
|
24
25
|
style: {
|
25
26
|
fontFamily: fontFamilyMap[value],
|
26
|
-
width: "100%",
|
27
|
+
width: width || "100%",
|
27
28
|
height: "36px",
|
28
29
|
overflow: "hidden",
|
29
|
-
borderRadius: "10px"
|
30
|
+
borderRadius: "10px",
|
31
|
+
fontSize: "14px"
|
30
32
|
},
|
31
33
|
children: options.map((item, index) => /*#__PURE__*/_jsx(MenuItem, {
|
32
34
|
style: {
|
@@ -37,4 +39,7 @@ const Dropdown = ({
|
|
37
39
|
}, index))
|
38
40
|
});
|
39
41
|
};
|
42
|
+
Dropdown.defaultProps = {
|
43
|
+
icon: null
|
44
|
+
};
|
40
45
|
export default Dropdown;
|
@@ -4,6 +4,7 @@ import { addMarkData } from "../../utils/SlateUtilityFunctions.js";
|
|
4
4
|
import { fontFamilyMap } from "../../utils/font";
|
5
5
|
import Icon from "../../common/Icon";
|
6
6
|
import { jsx as _jsx } from "react/jsx-runtime";
|
7
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
7
8
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
8
9
|
const FontFamilyDropdown = ({
|
9
10
|
editor,
|
@@ -18,26 +19,25 @@ const FontFamilyDropdown = ({
|
|
18
19
|
const handleClose = () => {
|
19
20
|
setAnchorEl(null);
|
20
21
|
};
|
21
|
-
return /*#__PURE__*/_jsxs(
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
icon: format
|
22
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
23
|
+
children: [/*#__PURE__*/_jsx(Tooltip, {
|
24
|
+
title: "Font Family",
|
25
|
+
arrow: true,
|
26
|
+
children: /*#__PURE__*/_jsx(IconButton, {
|
27
|
+
"aria-label": "more",
|
28
|
+
id: "long-button",
|
29
|
+
"aria-controls": open ? "long-menu" : undefined,
|
30
|
+
"aria-expanded": open ? "true" : undefined,
|
31
|
+
"aria-haspopup": "true",
|
32
|
+
onClick: handleClick,
|
33
|
+
children: /*#__PURE__*/_jsx(Icon, {
|
34
|
+
icon: format
|
35
|
+
})
|
36
36
|
})
|
37
37
|
}), /*#__PURE__*/_jsx(Menu, {
|
38
38
|
id: "long-menu",
|
39
39
|
MenuListProps: {
|
40
|
-
|
40
|
+
"aria-labelledby": "long-button"
|
41
41
|
},
|
42
42
|
anchorEl: anchorEl,
|
43
43
|
open: open,
|
@@ -1,9 +1,9 @@
|
|
1
|
-
import React, { useEffect, useRef, useState } from
|
2
|
-
import Button from
|
3
|
-
import Icon from
|
4
|
-
import { activeMark, addMarkData, isBlockActive } from
|
5
|
-
import usePopup from
|
6
|
-
import { sizeMap } from
|
1
|
+
import React, { useEffect, useRef, useState } from "react";
|
2
|
+
import Button from "../../common/Button";
|
3
|
+
import Icon from "../../common/Icon";
|
4
|
+
import { activeMark, addMarkData, isBlockActive } from "../../utils/SlateUtilityFunctions";
|
5
|
+
import usePopup from "../../utils/customHooks/usePopup";
|
6
|
+
import { sizeMap } from "../../utils/font";
|
7
7
|
import { jsx as _jsx } from "react/jsx-runtime";
|
8
8
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
9
9
|
const FontSize = ({
|
@@ -16,7 +16,7 @@ const FontSize = ({
|
|
16
16
|
const [fontSize, setFontSize] = useState(16);
|
17
17
|
const [showInput, setShowInput] = usePopup(urlInputRef);
|
18
18
|
useEffect(() => {
|
19
|
-
setFontSize(activeValue ===
|
19
|
+
setFontSize(activeValue === "normal" ? 16 : getSizeVal(activeValue));
|
20
20
|
}, [activeValue]);
|
21
21
|
const getSizeVal = value => {
|
22
22
|
try {
|
@@ -61,8 +61,8 @@ const FontSize = ({
|
|
61
61
|
className: `${isBlockActive(editor, format) && "btnActive"}`,
|
62
62
|
active: isBlockActive(editor, format),
|
63
63
|
style: {
|
64
|
-
border: showInput ?
|
65
|
-
borderBottom:
|
64
|
+
border: showInput ? "1px solid lightgray" : "",
|
65
|
+
borderBottom: "none"
|
66
66
|
},
|
67
67
|
format: format,
|
68
68
|
onClick: handleButtonClick,
|
@@ -73,9 +73,9 @@ const FontSize = ({
|
|
73
73
|
}), showInput && /*#__PURE__*/_jsxs("div", {
|
74
74
|
className: "fontSizeWrapper popup imagePopup",
|
75
75
|
style: {
|
76
|
-
display:
|
77
|
-
justifyContent:
|
78
|
-
maxWidth:
|
76
|
+
display: "flex",
|
77
|
+
justifyContent: "center",
|
78
|
+
maxWidth: "120px"
|
79
79
|
},
|
80
80
|
children: [/*#__PURE__*/_jsx("span", {
|
81
81
|
className: "controls",
|
@@ -89,11 +89,11 @@ const FontSize = ({
|
|
89
89
|
value: fontSize,
|
90
90
|
type: "text",
|
91
91
|
style: {
|
92
|
-
border:
|
93
|
-
outline:
|
94
|
-
marginBottom:
|
95
|
-
maxWidth:
|
96
|
-
overflow:
|
92
|
+
border: "unset",
|
93
|
+
outline: "unset",
|
94
|
+
marginBottom: "unset",
|
95
|
+
maxWidth: "36px",
|
96
|
+
overflow: "hidden"
|
97
97
|
},
|
98
98
|
onChange: onInputChange,
|
99
99
|
disabled: !activeValue && activeValue !== 0
|
@@ -8,7 +8,8 @@ import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
8
|
import { Fragment as _Fragment } from "react/jsx-runtime";
|
9
9
|
const TextSize = ({
|
10
10
|
editor,
|
11
|
-
format
|
11
|
+
format,
|
12
|
+
fullWidth
|
12
13
|
}) => {
|
13
14
|
const value = activeMark(editor, format);
|
14
15
|
const onChangeSize = e => {
|
@@ -49,11 +50,17 @@ const TextSize = ({
|
|
49
50
|
size: "small",
|
50
51
|
inputProps: {
|
51
52
|
style: {
|
52
|
-
width: "30px",
|
53
|
-
textAlign: "center"
|
53
|
+
width: fullWidth ? "100%" : "30px",
|
54
|
+
textAlign: "center",
|
55
|
+
height: "19px",
|
56
|
+
fontSize: "14px"
|
54
57
|
}
|
55
58
|
},
|
59
|
+
fullWidth: fullWidth,
|
56
60
|
InputProps: {
|
61
|
+
style: {
|
62
|
+
borderRadius: "8px"
|
63
|
+
},
|
57
64
|
endAdornment: /*#__PURE__*/_jsxs("div", {
|
58
65
|
className: "textFontArrows",
|
59
66
|
children: [/*#__PURE__*/_jsx(IconButton, {
|
@@ -70,4 +77,7 @@ const TextSize = ({
|
|
70
77
|
})
|
71
78
|
});
|
72
79
|
};
|
80
|
+
TextSize.defaultProps = {
|
81
|
+
fullWidth: false
|
82
|
+
};
|
73
83
|
export default TextSize;
|
@@ -5,5 +5,6 @@ import Autocomplete from "./Autocomplete";
|
|
5
5
|
import Text from "./Text";
|
6
6
|
import TextSize from "./TextSize";
|
7
7
|
import FontFamilyDropdown from "./FontFamilyDropdown";
|
8
|
-
import FontSize from
|
9
|
-
|
8
|
+
import FontSize from "./FontSize";
|
9
|
+
import AccordionButton from "../../Elements/Accordion/AccordionButton";
|
10
|
+
export { BlockButton, Dropdown, MarkButton, Autocomplete, Text, TextSize, FontFamilyDropdown, FontSize, AccordionButton };
|