@flozy/editor 5.5.7 → 5.5.9
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 +34 -25
- package/dist/Editor/CommonEditor.js +13 -26
- package/dist/Editor/Editor.css +19 -102
- package/dist/Editor/Elements/AI/AIInput.js +1 -0
- package/dist/Editor/Elements/AI/CustomSelect.js +10 -17
- package/dist/Editor/Elements/AI/PopoverAIInput.js +53 -59
- package/dist/Editor/Elements/AI/Styles.js +6 -24
- package/dist/Editor/Elements/Accordion/Accordion.js +1 -8
- package/dist/Editor/Elements/AppHeader/AppHeader.js +6 -6
- package/dist/Editor/Elements/Button/EditorButton.js +1 -6
- package/dist/Editor/Elements/Carousel/CarouselItem.js +3 -11
- package/dist/Editor/Elements/Color Picker/ColorButtons.js +5 -7
- package/dist/Editor/Elements/Color Picker/Styles.js +3 -8
- package/dist/Editor/Elements/Color Picker/defaultColors.js +2 -2
- package/dist/Editor/Elements/Divider/Divider.js +20 -36
- package/dist/Editor/Elements/Embed/Image.js +16 -51
- package/dist/Editor/Elements/Embed/Video.js +3 -26
- package/dist/Editor/Elements/Form/Form.js +2 -38
- package/dist/Editor/Elements/Form/FormElements/FormCheckbox.js +1 -7
- package/dist/Editor/Elements/Form/FormElements/FormDate.js +1 -7
- package/dist/Editor/Elements/Form/FormElements/FormEmail.js +1 -7
- package/dist/Editor/Elements/Form/FormElements/FormNumbers.js +1 -7
- package/dist/Editor/Elements/Form/FormElements/FormRadioButton.js +1 -7
- package/dist/Editor/Elements/Form/FormElements/FormText.js +1 -7
- package/dist/Editor/Elements/Form/FormElements/FormTextArea.js +1 -6
- package/dist/Editor/Elements/Form/FormPopup.js +9 -12
- package/dist/Editor/Elements/Form/Workflow/Styles.js +0 -2
- package/dist/Editor/Elements/FreeGrid/FreeGrid.js +1 -1
- package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +2 -4
- package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +1 -20
- package/dist/Editor/Elements/FreeGrid/breakpointConstants.js +4 -4
- package/dist/Editor/Elements/FreeGrid/styles.js +1 -1
- package/dist/Editor/Elements/Grid/GridButton.js +2 -2
- package/dist/Editor/Elements/Grid/GridItem.js +36 -47
- package/dist/Editor/Elements/Grid/Styles.js +0 -50
- package/dist/Editor/Elements/Link/LinkButton.js +1 -1
- package/dist/Editor/Elements/Search/SearchButton.js +0 -1
- package/dist/Editor/Elements/Signature/Signature.css +1 -1
- package/dist/Editor/Elements/Signature/SignatureOptions/TypeSignature.js +2 -2
- package/dist/Editor/Elements/Signature/SignaturePopup.js +52 -17
- package/dist/Editor/Elements/SimpleText/style.js +0 -15
- package/dist/Editor/Elements/Table/Styles.js +78 -88
- package/dist/Editor/Elements/Table/Table.js +140 -263
- package/dist/Editor/Elements/Table/TableCell.js +111 -365
- package/dist/Editor/Elements/Table/TablePopup.js +3 -9
- package/dist/Editor/Elements/Table/TableRow.js +2 -10
- package/dist/Editor/Elements/TopBanner/TopBanner.js +1 -2
- package/dist/Editor/MiniEditor.js +2 -21
- package/dist/Editor/Styles/EditorStyles.js +4 -13
- package/dist/Editor/Toolbar/FormatTools/BlockButton.js +0 -10
- package/dist/Editor/Toolbar/FormatTools/Dropdown.js +12 -7
- package/dist/Editor/Toolbar/FormatTools/FontFamilyAutocomplete.js +4 -26
- package/dist/Editor/Toolbar/FormatTools/MarkButton.js +0 -3
- package/dist/Editor/Toolbar/FormatTools/TextSize.js +5 -5
- package/dist/Editor/Toolbar/Mini/MiniToolbar.js +8 -8
- package/dist/Editor/Toolbar/Mini/Styles.js +1 -9
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/InfinityAITool.js +3 -7
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +4 -6
- package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +15 -19
- package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +58 -547
- package/dist/Editor/Toolbar/PopupTool/TextFormat.js +16 -28
- package/dist/Editor/Toolbar/PopupTool/index.js +5 -3
- package/dist/Editor/Toolbar/Toolbar.js +0 -6
- package/dist/Editor/Toolbar/toolbarGroups.js +0 -4
- package/dist/Editor/assets/svg/BrainIcon.js +2 -2
- package/dist/Editor/assets/svg/SettingsIcon.js +4 -4
- package/dist/Editor/common/ColorPickerButton.js +45 -85
- package/dist/Editor/common/DnD/Draggable.js +1 -2
- package/dist/Editor/common/FontLoader/FontLoader.js +2 -2
- package/dist/Editor/common/Icon.js +21 -54
- package/dist/Editor/common/ImageSelector/Options/Upload.js +1 -2
- package/dist/Editor/common/ImageSelector/Styles.js +6 -47
- package/dist/Editor/common/ImageSelector/UploadStyles.js +6 -18
- package/dist/Editor/common/LinkSettings/NavComponents.js +1 -2
- package/dist/Editor/common/LinkSettings/index.js +1 -2
- package/dist/Editor/common/MentionsPopup/Styles.js +8 -142
- package/dist/Editor/common/MentionsPopup/index.js +1 -1
- package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +12 -107
- package/dist/Editor/common/RnD/GuideLines/styles.js +3 -3
- package/dist/Editor/common/RnD/ShadowElement.js +1 -1
- package/dist/Editor/common/RnD/VirtualElement/index.js +1 -5
- package/dist/Editor/common/RnD/index.js +3 -4
- package/dist/Editor/common/Section/index.js +3 -3
- package/dist/Editor/common/Section/styles.js +1 -5
- package/dist/Editor/common/Shorthands/elements.js +1 -13
- package/dist/Editor/common/StyleBuilder/fieldStyle.js +1 -2
- package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +3 -4
- package/dist/Editor/common/StyleBuilder/fieldTypes/bannerSpacing.js +7 -35
- package/dist/Editor/common/StyleBuilder/fieldTypes/borderRadius.js +2 -15
- package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +1 -2
- package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +1 -1
- package/dist/Editor/common/StyleBuilder/fieldTypes/icons.js +0 -2
- package/dist/Editor/common/StyleBuilder/fieldTypes/radiusStyle.js +11 -11
- package/dist/Editor/common/StyleBuilder/fieldTypes/saveAsTemplate.js +6 -22
- package/dist/Editor/common/StyleBuilder/fieldTypes/selectBox.js +2 -21
- package/dist/Editor/common/StyleBuilder/fieldTypes/text.js +4 -20
- package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +2 -12
- package/dist/Editor/common/StyleBuilder/formStyle.js +149 -268
- package/dist/Editor/common/StyleBuilder/index.js +20 -101
- package/dist/Editor/common/StyleBuilder/tableStyle.js +25 -69
- package/dist/Editor/common/SwipeableDrawer/style.js +4 -15
- package/dist/Editor/common/ToolbarIcon.js +1 -1
- package/dist/Editor/common/Uploader.js +37 -39
- package/dist/Editor/common/iconListV2.js +74 -598
- package/dist/Editor/common/iconslist.js +19 -25
- package/dist/Editor/commonStyle.js +15 -421
- package/dist/Editor/helper/deserialize/index.js +2 -31
- package/dist/Editor/helper/index.js +2 -15
- package/dist/Editor/helper/theme.js +1 -15
- package/dist/Editor/hooks/useBreakpoints.js +1 -1
- package/dist/Editor/plugins/withCustomDeleteBackward.js +3 -34
- package/dist/Editor/plugins/withEmbeds.js +26 -30
- package/dist/Editor/plugins/withHTML.js +12 -100
- package/dist/Editor/plugins/withLayout.js +0 -1
- package/dist/Editor/utils/SlateUtilityFunctions.js +11 -31
- package/dist/Editor/utils/brains.js +1 -1
- package/dist/Editor/utils/chatEditor/SlateUtilityFunctions.js +1 -26
- package/dist/Editor/utils/customHooks/useResize.js +4 -7
- package/dist/Editor/utils/customHooks/useTableResize.js +2 -6
- package/dist/Editor/utils/embed.js +1 -2
- package/dist/Editor/utils/events.js +1 -0
- package/dist/Editor/utils/font.js +4 -11
- package/dist/Editor/utils/formfield.js +4 -8
- package/dist/Editor/utils/helper.js +2 -100
- package/dist/Editor/utils/insertNewLine.js +1 -19
- package/dist/Editor/utils/serializeToText.js +0 -2
- package/dist/Editor/utils/table.js +24 -228
- package/package.json +2 -2
- package/dist/Editor/Elements/DataView/DataView.js +0 -124
- package/dist/Editor/Elements/DataView/DataViewButton.js +0 -23
- package/dist/Editor/Elements/DataView/Layouts/ColumnView.js +0 -83
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/CheckType.js +0 -33
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/Select.js +0 -180
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/SimpleSelect.js +0 -62
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/styles.js +0 -68
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/DateType.js +0 -35
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/MultiSelectType.js +0 -39
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/NumberType.js +0 -30
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/PersonType.js +0 -30
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/SelectType.js +0 -35
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/TextType.js +0 -36
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/index.js +0 -17
- package/dist/Editor/Elements/DataView/Layouts/FilterSort/SortOptions/ChooseField.js +0 -29
- package/dist/Editor/Elements/DataView/Layouts/FilterSort/SortOptions/ChooseSort.js +0 -38
- package/dist/Editor/Elements/DataView/Layouts/FilterSort/SortOptions/index.js +0 -86
- package/dist/Editor/Elements/DataView/Layouts/FilterSort/index.js +0 -71
- package/dist/Editor/Elements/DataView/Layouts/FilterSort/styles.js +0 -138
- package/dist/Editor/Elements/DataView/Layouts/FilterView.js +0 -213
- package/dist/Editor/Elements/DataView/Layouts/Formula.js +0 -29
- package/dist/Editor/Elements/DataView/Layouts/Options/AddOptions.js +0 -113
- package/dist/Editor/Elements/DataView/Layouts/Options/AddProperty.js +0 -44
- package/dist/Editor/Elements/DataView/Layouts/Options/AllProperties.js +0 -146
- package/dist/Editor/Elements/DataView/Layouts/Options/ChangeProperty.js +0 -79
- package/dist/Editor/Elements/DataView/Layouts/Options/ColumnsList.js +0 -57
- package/dist/Editor/Elements/DataView/Layouts/Options/Constants.js +0 -101
- package/dist/Editor/Elements/DataView/Layouts/Options/EditOption.js +0 -174
- package/dist/Editor/Elements/DataView/Layouts/Options/EditProperty.js +0 -241
- package/dist/Editor/Elements/DataView/Layouts/Options/FilterProperty.js +0 -45
- package/dist/Editor/Elements/DataView/Layouts/Options/PropertyList.js +0 -32
- package/dist/Editor/Elements/DataView/Layouts/Options/index.js +0 -110
- package/dist/Editor/Elements/DataView/Layouts/Options/styles.js +0 -217
- package/dist/Editor/Elements/DataView/Layouts/TableStyles.js +0 -131
- package/dist/Editor/Elements/DataView/Layouts/TableView.js +0 -253
- package/dist/Editor/Elements/DataView/Layouts/ViewData.js +0 -85
- package/dist/Editor/Elements/DataView/Layouts/colStyles.js +0 -10
- package/dist/Editor/Elements/DataView/Layouts/index.js +0 -25
- package/dist/Editor/Elements/DataView/Providers/DataViewProvider.js +0 -277
- package/dist/Editor/Elements/DataView/Utils/globalSearch.js +0 -15
- package/dist/Editor/Elements/DataView/Utils/multiSortRows.js +0 -88
- package/dist/Editor/Elements/DataView/styles.js +0 -169
- package/dist/Editor/Elements/Table/AddRowCol.js +0 -77
- package/dist/Editor/Elements/Table/DragButton.js +0 -142
- package/dist/Editor/Elements/Table/DragStyles.js +0 -70
- package/dist/Editor/Elements/Table/Draggable.js +0 -25
- package/dist/Editor/Elements/Table/Droppable.js +0 -53
- package/dist/Editor/Elements/Table/TableTool.js +0 -101
- package/dist/Editor/Elements/Table/tableHelper.js +0 -71
- package/dist/Editor/assets/svg/ArrowDownIcon.js +0 -25
- package/dist/Editor/assets/svg/ArrowUpIcon.js +0 -25
- package/dist/Editor/assets/svg/CalenderIconTick.js +0 -64
- package/dist/Editor/assets/svg/ChervDown.js +0 -18
- package/dist/Editor/assets/svg/ChervUp.js +0 -18
- package/dist/Editor/assets/svg/DataTableIcon.js +0 -50
- package/dist/Editor/assets/svg/DuplicateIcon.js +0 -23
- package/dist/Editor/assets/svg/EyeIcon.js +0 -23
- package/dist/Editor/assets/svg/EyeSlash.js +0 -43
- package/dist/Editor/assets/svg/HashtagIcon.js +0 -33
- package/dist/Editor/assets/svg/PlusIcon.js +0 -23
- package/dist/Editor/assets/svg/SelectRoundedIcon.js +0 -24
- package/dist/Editor/assets/svg/SortByIcon.js +0 -33
- package/dist/Editor/assets/svg/TableIcons.js +0 -220
- package/dist/Editor/assets/svg/TickOutlined.js +0 -23
- package/dist/Editor/assets/svg/TrashCanIcon.js +0 -38
- package/dist/Editor/common/Select/index.js +0 -20
- package/dist/Editor/common/Select/styles.js +0 -17
- package/dist/Editor/helper/enforceDateFormat.js +0 -41
- package/dist/Editor/hooks/useTable.js +0 -210
- package/dist/Editor/utils/dataView.js +0 -43
@@ -1,8 +1,9 @@
|
|
1
1
|
import React, { useCallback, useMemo, useRef, useState, useEffect, useImperativeHandle, forwardRef } from "react";
|
2
2
|
import { Editable, Slate, ReactEditor } from 'slate-react';
|
3
3
|
import { createEditor, Transforms, Editor } from 'slate';
|
4
|
+
import { useDebounce } from "use-debounce";
|
4
5
|
import withCommon from "./hooks/withCommon";
|
5
|
-
import { getBlock, getMarked
|
6
|
+
import { getBlock, getMarked } from "./utils/chatEditor/SlateUtilityFunctions";
|
6
7
|
import MiniTextFormat from "./Toolbar/PopupTool/MiniTextFormat";
|
7
8
|
import { commands, mentionsEvent } from "./utils/events";
|
8
9
|
import { insertEmoji } from "./utils/emoji";
|
@@ -14,7 +15,6 @@ import Shorthands from "./common/Shorthands";
|
|
14
15
|
import usePopupStyle from "./Toolbar/PopupTool/PopupToolStyle";
|
15
16
|
import { EditorProvider } from "./hooks/useMouseMove";
|
16
17
|
import decorators from "./utils/Decorators";
|
17
|
-
import { useDebouncedCallback } from "use-debounce";
|
18
18
|
import { jsx as _jsx } from "react/jsx-runtime";
|
19
19
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
20
20
|
const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
@@ -42,18 +42,8 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
42
42
|
});
|
43
43
|
const [isInteracted, setIsInteracted] = useState(false);
|
44
44
|
const [value, setValue] = useState(convertedContent);
|
45
|
-
const
|
46
|
-
const
|
47
|
-
// function
|
48
|
-
value => {
|
49
|
-
const {
|
50
|
-
value: strVal,
|
51
|
-
...restVal
|
52
|
-
} = getOnSaveData(value);
|
53
|
-
onSave(strVal, restVal);
|
54
|
-
},
|
55
|
-
// delay in ms
|
56
|
-
500);
|
45
|
+
const [loadedValue] = useState(value);
|
46
|
+
const [deboundedValue] = useDebounce(value, 500);
|
57
47
|
const editor = useMemo(() => {
|
58
48
|
return withCommon(createEditor(), {
|
59
49
|
needLayout,
|
@@ -73,7 +63,7 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
73
63
|
const {
|
74
64
|
value: strVal,
|
75
65
|
...restVal
|
76
|
-
} = getOnSaveData(
|
66
|
+
} = getOnSaveData(value);
|
77
67
|
onsubmit(false, {
|
78
68
|
strVal,
|
79
69
|
restVal
|
@@ -109,8 +99,7 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
109
99
|
const newValue = draftToSlate({
|
110
100
|
data: content
|
111
101
|
});
|
112
|
-
|
113
|
-
|
102
|
+
setValue(newValue);
|
114
103
|
// setTimeout(() => {
|
115
104
|
if (editor.children.length === 0) {
|
116
105
|
Transforms.insertNodes(editor, newValue);
|
@@ -123,14 +112,27 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
123
112
|
}
|
124
113
|
}
|
125
114
|
}));
|
115
|
+
|
116
|
+
// useEffect(() => {
|
117
|
+
// setIsExternalUpdate(true);
|
118
|
+
// setValue(draftToSlate({ data: content }));
|
119
|
+
// }, [content]);
|
120
|
+
|
121
|
+
useEffect(() => {
|
122
|
+
if (JSON.stringify(loadedValue) !== JSON.stringify(deboundedValue) && isInteracted && onSave) {
|
123
|
+
const {
|
124
|
+
value: strVal,
|
125
|
+
...restVal
|
126
|
+
} = getOnSaveData(deboundedValue);
|
127
|
+
onSave(strVal, restVal);
|
128
|
+
}
|
129
|
+
}, [deboundedValue]);
|
126
130
|
const getOnSaveData = val => {
|
127
131
|
const text = serializeToText(val);
|
128
|
-
const mentions = serializeMentions(val);
|
129
132
|
const title = val?.find(f => f.type === "title");
|
130
133
|
return {
|
131
134
|
value: JSON.stringify(val),
|
132
135
|
text: text,
|
133
|
-
mentions: mentions,
|
134
136
|
title: serializeToText(title?.children) || "Untitled"
|
135
137
|
};
|
136
138
|
};
|
@@ -178,8 +180,15 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
178
180
|
});
|
179
181
|
};
|
180
182
|
const handleEditorChange = newValue => {
|
181
|
-
|
182
|
-
|
183
|
+
const value_txt = serializeToText(value);
|
184
|
+
if (!value_txt) {
|
185
|
+
const {
|
186
|
+
value: strVal,
|
187
|
+
...restVal
|
188
|
+
} = getOnSaveData(newValue);
|
189
|
+
onSave(strVal, restVal);
|
190
|
+
}
|
191
|
+
setValue(newValue);
|
183
192
|
if (!isInteracted) {
|
184
193
|
setIsInteracted(true);
|
185
194
|
}
|
@@ -219,7 +228,7 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
219
228
|
editor
|
220
229
|
});
|
221
230
|
} else if (event.key === "Enter" && !isMobile) {
|
222
|
-
const isEmpty =
|
231
|
+
const isEmpty = value.length === 1 && value[0].type === 'paragraph' && value[0].children.length === 1 && value[0].children[0].text === '';
|
223
232
|
if (isEmpty) {
|
224
233
|
event.preventDefault();
|
225
234
|
return;
|
@@ -228,7 +237,7 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
228
237
|
const {
|
229
238
|
value: strVal,
|
230
239
|
...restVal
|
231
|
-
} = getOnSaveData(
|
240
|
+
} = getOnSaveData(value);
|
232
241
|
onsubmit(false, {
|
233
242
|
strVal,
|
234
243
|
restVal
|
@@ -242,7 +251,7 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
242
251
|
const {
|
243
252
|
value: strVal,
|
244
253
|
...restVal
|
245
|
-
} = getOnSaveData(
|
254
|
+
} = getOnSaveData(value);
|
246
255
|
onBlur({
|
247
256
|
strVal,
|
248
257
|
restVal
|
@@ -263,7 +272,7 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
263
272
|
editor: editor,
|
264
273
|
children: /*#__PURE__*/_jsxs(Slate, {
|
265
274
|
editor: editor,
|
266
|
-
initialValue:
|
275
|
+
initialValue: value,
|
267
276
|
onChange: handleEditorChange,
|
268
277
|
children: [toolBar && /*#__PURE__*/_jsx(MiniTextFormat, {
|
269
278
|
classes: classes,
|
@@ -27,7 +27,7 @@ import DragAndDrop from "./common/DnD";
|
|
27
27
|
import Section from "./common/Section";
|
28
28
|
import decorators from "./utils/Decorators";
|
29
29
|
import { getTRBLBreakPoints } from "./helper/theme";
|
30
|
-
import {
|
30
|
+
import { handleInsertLastElement, isFreeGrid, isFreeGridFragment, isPageSettings, outsideEditorClickLabel } from "./utils/helper";
|
31
31
|
import useWindowResize from "./hooks/useWindowResize";
|
32
32
|
import PopoverAIInput from "./Elements/AI/PopoverAIInput";
|
33
33
|
import RnDCopy from "./common/RnD/RnDCopy";
|
@@ -72,12 +72,6 @@ const Leaf = ({
|
|
72
72
|
children: children
|
73
73
|
});
|
74
74
|
};
|
75
|
-
const updateTopBanner = (content = [], setTopBanner) => {
|
76
|
-
setTopBanner(() => {
|
77
|
-
const firstNode = content ? content[0] : {};
|
78
|
-
return firstNode?.type === "topbanner" ? firstNode : null;
|
79
|
-
});
|
80
|
-
};
|
81
75
|
const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
82
76
|
const {
|
83
77
|
id,
|
@@ -109,7 +103,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
109
103
|
});
|
110
104
|
const [isTextSelected, setIsTextSelected] = useState(false);
|
111
105
|
const [breakpoint, setBreakpoint] = useState("");
|
112
|
-
const [topBanner, setTopBanner] = useState();
|
113
106
|
const debouncedValue = useRef(value);
|
114
107
|
const [size] = useWindowResize();
|
115
108
|
const {
|
@@ -124,9 +117,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
124
117
|
} = otherProps || {};
|
125
118
|
const editor = useMemo(() => {
|
126
119
|
if (collaborativeEditor) return collaborativeEditor;
|
127
|
-
|
128
|
-
editor.needLayout = needLayout;
|
129
|
-
return withCommon(editor, {
|
120
|
+
return withCommon(createEditor(), {
|
130
121
|
needLayout
|
131
122
|
});
|
132
123
|
}, [collaborativeEditor]);
|
@@ -158,7 +149,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
158
149
|
setValue(draftToSlate({
|
159
150
|
data: content
|
160
151
|
}));
|
161
|
-
updateTopBanner(content, setTopBanner);
|
162
152
|
if (!isMobile && !ReactEditor.isFocused(editor)) {
|
163
153
|
ReactEditor.focus(editor);
|
164
154
|
}
|
@@ -307,13 +297,10 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
307
297
|
hideTools: updatedHideTools || []
|
308
298
|
}) : [];
|
309
299
|
const handleEditorChange = newValue => {
|
310
|
-
if (
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
if (!isInteracted) {
|
315
|
-
setIsInteracted(true);
|
316
|
-
}
|
300
|
+
if (JSON.stringify(newValue) !== JSON.stringify(debouncedValue?.current)) {
|
301
|
+
debounced(newValue);
|
302
|
+
if (!isInteracted) {
|
303
|
+
setIsInteracted(true);
|
317
304
|
}
|
318
305
|
}
|
319
306
|
};
|
@@ -423,7 +410,10 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
423
410
|
editorWrapper?.current?.classList.remove("hideScroll");
|
424
411
|
handleScrollStop();
|
425
412
|
};
|
426
|
-
const hasTopBanner = () =>
|
413
|
+
const hasTopBanner = () => {
|
414
|
+
const tb = editor.children[0];
|
415
|
+
return tb?.type === "topbanner" ? tb : null;
|
416
|
+
};
|
427
417
|
const renderTopBanner = () => {
|
428
418
|
const tb = hasTopBanner();
|
429
419
|
return tb ? /*#__PURE__*/_jsx(TopBanner, {
|
@@ -505,12 +495,12 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
505
495
|
,
|
506
496
|
children: /*#__PURE__*/_jsxs(Slate, {
|
507
497
|
editor: editor,
|
508
|
-
initialValue:
|
498
|
+
initialValue: debouncedValue?.current,
|
509
499
|
onChange: handleEditorChange,
|
510
500
|
children: [/*#__PURE__*/_jsx(DragAndDrop, {
|
511
501
|
children: /*#__PURE__*/_jsxs(Overlay, {
|
512
502
|
children: [/*#__PURE__*/_jsx(Box, {
|
513
|
-
className: `pc-${editorClass || ""} ${hasTopBanner() ? "has-topbanner" : ""} ${!pageColor ? "no-color" : ""} scrollable-content scrollSmooth
|
503
|
+
className: `pc-${editorClass || ""} ${hasTopBanner() ? "has-topbanner" : ""} ${!pageColor ? "no-color" : ""} scrollable-content scrollSmooth`,
|
514
504
|
sx: classes.slateWrapper,
|
515
505
|
id: "slate-wrapper-scroll-container",
|
516
506
|
ref: editorWrapper,
|
@@ -550,10 +540,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
550
540
|
renderLeaf: renderLeaf,
|
551
541
|
decorate: d => decorators(d, editor),
|
552
542
|
onKeyDown: onKeyDown,
|
553
|
-
onSelect: () => handleCursorScroll(editorWrapper.current)
|
554
|
-
scrollSelectionIntoView: () => {
|
555
|
-
// disable the scrollSelectionIntoView, to resolve editor auto scroll on free-grid
|
556
|
-
}
|
543
|
+
onSelect: () => handleCursorScroll(editorWrapper.current)
|
557
544
|
}), !readOnly ? /*#__PURE__*/_jsx(MentionsPopup, {
|
558
545
|
ref: mentionsRef,
|
559
546
|
mentions: mentions,
|
package/dist/Editor/Editor.css
CHANGED
@@ -31,7 +31,7 @@ blockquote {
|
|
31
31
|
border-left: 3px solid transparent;
|
32
32
|
margin-left: 0;
|
33
33
|
margin-right: 0;
|
34
|
-
|
34
|
+
padding-left: 10px;
|
35
35
|
margin: 0px;
|
36
36
|
}
|
37
37
|
|
@@ -42,7 +42,7 @@ blockquote {
|
|
42
42
|
}
|
43
43
|
|
44
44
|
.editor-wrapper table {
|
45
|
-
border-collapse:
|
45
|
+
border-collapse: separate;
|
46
46
|
}
|
47
47
|
|
48
48
|
.editor-wrapper .editor-wrapperbutton {
|
@@ -149,7 +149,7 @@ blockquote {
|
|
149
149
|
.grid-item-toolbar button,
|
150
150
|
.element-toolbar button,
|
151
151
|
.element-toolbar a {
|
152
|
-
border-radius:
|
152
|
+
border-radius: 10px;
|
153
153
|
border: 1px solid rgba(37, 99, 235, 0.32);
|
154
154
|
background: #fff;
|
155
155
|
box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.16);
|
@@ -225,13 +225,9 @@ blockquote {
|
|
225
225
|
background-color: #0052cc;
|
226
226
|
padding: 8px 12px;
|
227
227
|
color: #ffffff;
|
228
|
-
font-weight:
|
229
|
-
font-size: 14px;
|
228
|
+
font-weight: bold;
|
230
229
|
opacity: 1;
|
231
230
|
border-radius: 32px;
|
232
|
-
text-transform: math-auto;
|
233
|
-
height: 36px;
|
234
|
-
padding: 0px 12px;
|
235
231
|
}
|
236
232
|
|
237
233
|
.signature-btn-container button:hover {
|
@@ -355,17 +351,13 @@ blockquote {
|
|
355
351
|
height: 100%;
|
356
352
|
width: 100%;
|
357
353
|
border: 1px solid #2563EB;
|
358
|
-
border-radius:
|
354
|
+
border-radius: 12px;
|
359
355
|
}
|
360
356
|
|
361
357
|
.activeBrush svg {
|
362
358
|
stroke: #2563eb;
|
363
359
|
}
|
364
360
|
|
365
|
-
.brushIcon:hover {
|
366
|
-
background: unset;
|
367
|
-
}
|
368
|
-
|
369
361
|
.react-datepicker__input-container {
|
370
362
|
display: flex !important;
|
371
363
|
align-items: center;
|
@@ -391,7 +383,7 @@ blockquote {
|
|
391
383
|
|
392
384
|
.dialog-actions-si .MuiButtonBase-root {
|
393
385
|
opacity: 1;
|
394
|
-
padding:
|
386
|
+
padding: 6px 5px 0px 3px !important
|
395
387
|
}
|
396
388
|
|
397
389
|
.signature-tab {
|
@@ -405,9 +397,9 @@ blockquote {
|
|
405
397
|
.signature-tab2 {
|
406
398
|
/* display: flex; */
|
407
399
|
align-items: center;
|
408
|
-
border-width:
|
400
|
+
border-width: 0px, 0px, 0px, 0px;
|
409
401
|
border-style: solid;
|
410
|
-
border-color: #
|
402
|
+
border-color: #2563EB;
|
411
403
|
justify-content: center;
|
412
404
|
flex-direction: column;
|
413
405
|
width: 100%;
|
@@ -499,19 +491,11 @@ blockquote {
|
|
499
491
|
text-transform: none;
|
500
492
|
}
|
501
493
|
|
502
|
-
.MuiButton-root.primaryBtn
|
494
|
+
.MuiButton-root.primaryBtn.disabled,
|
495
|
+
.MuiButton-root.secondaryBtn.disabled {
|
503
496
|
background: #eee !important;
|
504
|
-
box-shadow: none !important;
|
505
497
|
color: #ccc !important;
|
506
498
|
border: 1px solid #ccc !important;
|
507
|
-
cursor: not-allowed;
|
508
|
-
}
|
509
|
-
|
510
|
-
.MuiButton-root.primaryBtn.disabled,
|
511
|
-
.MuiButton-root.secondaryBtn.disabled {
|
512
|
-
background: #eee;
|
513
|
-
color: #ccc;
|
514
|
-
border: 1px solid #ccc;
|
515
499
|
}
|
516
500
|
|
517
501
|
.MuiButton-root.secondaryBtn {
|
@@ -532,7 +516,7 @@ blockquote {
|
|
532
516
|
}
|
533
517
|
|
534
518
|
.deleteBtn {
|
535
|
-
background: #
|
519
|
+
background: #ffffff;
|
536
520
|
border: 1px solid #d32f2f !important;
|
537
521
|
box-shadow: 0px 8px 24px rgba(30, 64, 175, 0.08);
|
538
522
|
border-radius: 8px !important;
|
@@ -542,7 +526,6 @@ blockquote {
|
|
542
526
|
margin-right: 15px !important;
|
543
527
|
color: #d32f2f;
|
544
528
|
width: auto !important;
|
545
|
-
text-transform: capitalize !important;
|
546
529
|
}
|
547
530
|
|
548
531
|
@media (max-width: 480px) {
|
@@ -640,7 +623,7 @@ blockquote {
|
|
640
623
|
}
|
641
624
|
|
642
625
|
.MuiIconButton-root.btnActive {
|
643
|
-
color: #
|
626
|
+
background-color: #ccc;
|
644
627
|
}
|
645
628
|
|
646
629
|
.embed .element-toolbar {
|
@@ -680,8 +663,7 @@ blockquote {
|
|
680
663
|
}
|
681
664
|
|
682
665
|
.resize-br.img-resizer {
|
683
|
-
bottom:
|
684
|
-
right: 5px;
|
666
|
+
bottom: 8px;
|
685
667
|
}
|
686
668
|
|
687
669
|
.visible-on-hover {
|
@@ -876,8 +858,8 @@ blockquote {
|
|
876
858
|
|
877
859
|
.dialogComp .MuiInputBase-input {
|
878
860
|
border-radius: 8px;
|
879
|
-
|
880
|
-
font-size:
|
861
|
+
box-shadow: 0px 4px 18px 0px rgba(0, 0, 0, 0.05);
|
862
|
+
font-size: 12px;
|
881
863
|
font-weight: 500;
|
882
864
|
}
|
883
865
|
|
@@ -1041,11 +1023,11 @@ blockquote {
|
|
1041
1023
|
width: 200px;
|
1042
1024
|
cursor: pointer;
|
1043
1025
|
color: #464646;
|
1044
|
-
|
1026
|
+
background-color: #fff;
|
1045
1027
|
padding: 4px 6px;
|
1046
1028
|
border-radius: 12px;
|
1047
1029
|
span {
|
1048
|
-
text-transform:
|
1030
|
+
text-transform: capitalize;
|
1049
1031
|
}
|
1050
1032
|
@media only screen and (max-width: 599px) {
|
1051
1033
|
background-color: unset;
|
@@ -1067,7 +1049,7 @@ blockquote {
|
|
1067
1049
|
}
|
1068
1050
|
|
1069
1051
|
.textFontArrows .MuiIconButton-root {
|
1070
|
-
padding:
|
1052
|
+
padding: 2px;
|
1071
1053
|
}
|
1072
1054
|
|
1073
1055
|
.tools-drawer .MuiTypography-root {
|
@@ -1091,10 +1073,6 @@ blockquote {
|
|
1091
1073
|
font-size: 14px;
|
1092
1074
|
}
|
1093
1075
|
|
1094
|
-
.listItemMargin {
|
1095
|
-
margin: 0px;
|
1096
|
-
}
|
1097
|
-
|
1098
1076
|
.content-editable.empty {
|
1099
1077
|
position: relative;
|
1100
1078
|
}
|
@@ -1248,76 +1226,15 @@ blockquote {
|
|
1248
1226
|
position: absolute;
|
1249
1227
|
}
|
1250
1228
|
|
1251
|
-
.dividerComponent:hover .divider-settings
|
1252
|
-
.dividerComponent:hover .element-selector {
|
1229
|
+
.dividerComponent:hover .divider-settings {
|
1253
1230
|
display: block;
|
1254
|
-
pointer-events: auto;
|
1255
|
-
}
|
1256
|
-
|
1257
|
-
.hideScroll {
|
1258
|
-
overflow-anchor: none;
|
1259
1231
|
}
|
1260
1232
|
|
1261
|
-
.hideScroll::-webkit-scrollbar-track {
|
1262
|
-
background: none !important;
|
1263
|
-
}
|
1264
|
-
|
1265
|
-
.hideScroll::-webkit-scrollbar-thumb {
|
1266
|
-
background: none !important;
|
1267
|
-
}
|
1268
|
-
|
1269
|
-
.hideScroll::-webkit-scrollbar-thumb:hover {
|
1270
|
-
background: none !important;
|
1271
|
-
}
|
1272
1233
|
@media (max-width: 899px) {
|
1273
1234
|
.MuiPopover-root {
|
1274
1235
|
z-index: 1302 !important;
|
1275
1236
|
}
|
1276
|
-
|
1277
1237
|
canvas {
|
1278
1238
|
max-width: 100% !important;
|
1279
1239
|
}
|
1280
1240
|
}
|
1281
|
-
|
1282
|
-
.settingsHeader {
|
1283
|
-
font-size: 14px !important;
|
1284
|
-
font-weight: 500 !important;
|
1285
|
-
}
|
1286
|
-
|
1287
|
-
.custom-scroll::-webkit-scrollbar {
|
1288
|
-
height: .6rem;
|
1289
|
-
}
|
1290
|
-
|
1291
|
-
.custom-scroll::-webkit-scrollbar-thumb {
|
1292
|
-
background: #888;
|
1293
|
-
border-radius: 5px;
|
1294
|
-
cursor: pointer;
|
1295
|
-
}
|
1296
|
-
|
1297
|
-
.custom-scroll::-webkit-scrollbar-track {
|
1298
|
-
background: #f1f1f1;
|
1299
|
-
}
|
1300
|
-
|
1301
|
-
.custom-scroll:hover::-webkit-scrollbar-thumb {
|
1302
|
-
background: #A7AEC1;
|
1303
|
-
}
|
1304
|
-
|
1305
|
-
::selection {
|
1306
|
-
color: inherit;
|
1307
|
-
background: rgba(35, 131, 226, 0.35) !important;
|
1308
|
-
}
|
1309
|
-
|
1310
|
-
::-moz-selection {
|
1311
|
-
background: rgba(35, 131, 226, 0.35) !important;
|
1312
|
-
color: inherit;
|
1313
|
-
}
|
1314
|
-
|
1315
|
-
::-webkit-selection {
|
1316
|
-
background: rgba(35, 131, 226, 0.35) !important;
|
1317
|
-
color: inherit;
|
1318
|
-
}
|
1319
|
-
|
1320
|
-
.gradientFillBtn {
|
1321
|
-
background: linear-gradient(112.61deg, #2C63ED 19.3%, #8360FD 88.14%) !important;
|
1322
|
-
text-transform: math-auto !important;
|
1323
|
-
}
|
@@ -71,6 +71,7 @@ function AIInput({
|
|
71
71
|
}, [openAI]);
|
72
72
|
const isSendBtnDisabled = !inputValue || loading;
|
73
73
|
const props = getProps(openAI, generatedText) || {};
|
74
|
+
const fromToolBar = openAI === "fromToolBar";
|
74
75
|
const handleSendBtnClick = () => {
|
75
76
|
if (isSendBtnDisabled) {
|
76
77
|
return;
|
@@ -8,14 +8,12 @@ function CustomSelect({
|
|
8
8
|
classes,
|
9
9
|
options,
|
10
10
|
onSend,
|
11
|
-
show
|
12
|
-
btnProps = {}
|
11
|
+
show
|
13
12
|
}) {
|
14
13
|
if (show) {
|
15
14
|
return /*#__PURE__*/_jsx(Box, {
|
16
15
|
component: "div",
|
17
16
|
sx: classes.customSelectContainer,
|
18
|
-
className: "customSelectContainer",
|
19
17
|
children: options?.map((groupOption, index) => {
|
20
18
|
const {
|
21
19
|
options,
|
@@ -30,8 +28,7 @@ function CustomSelect({
|
|
30
28
|
return /*#__PURE__*/_jsx(DisplayOption, {
|
31
29
|
option: option,
|
32
30
|
classes: classes,
|
33
|
-
onSend: onSend
|
34
|
-
btnProps: btnProps
|
31
|
+
onSend: onSend
|
35
32
|
}, i);
|
36
33
|
})]
|
37
34
|
}, index);
|
@@ -45,18 +42,15 @@ export default CustomSelect;
|
|
45
42
|
function DisplayOption({
|
46
43
|
option,
|
47
44
|
classes,
|
48
|
-
onSend
|
49
|
-
btnProps = {}
|
45
|
+
onSend
|
50
46
|
}) {
|
51
47
|
const {
|
52
|
-
Icon
|
53
|
-
Component
|
48
|
+
Icon
|
54
49
|
} = option;
|
55
50
|
const [open, setOpen] = useState(false);
|
56
51
|
const optionRef = useRef();
|
57
|
-
const showChild = option.options?.length || Component;
|
58
52
|
const openOptions = e => {
|
59
|
-
if (
|
53
|
+
if (option.options?.length && !open) {
|
60
54
|
setOpen(e.currentTarget);
|
61
55
|
return;
|
62
56
|
}
|
@@ -72,7 +66,7 @@ function DisplayOption({
|
|
72
66
|
e.stopPropagation();
|
73
67
|
|
74
68
|
// is having child options
|
75
|
-
if (
|
69
|
+
if (option.options?.length) {
|
76
70
|
openOptions(e);
|
77
71
|
return;
|
78
72
|
}
|
@@ -81,19 +75,18 @@ function DisplayOption({
|
|
81
75
|
},
|
82
76
|
id: "infinity-select-popover",
|
83
77
|
className: open ? "active" : "",
|
84
|
-
...btnProps,
|
85
78
|
children: [/*#__PURE__*/_jsxs("div", {
|
86
79
|
className: "option-label",
|
87
80
|
id: "infinity-select-popover",
|
88
81
|
children: [Icon && /*#__PURE__*/_jsx(Icon, {}), option.label]
|
89
|
-
}),
|
82
|
+
}), option.options?.length && /*#__PURE__*/_jsx(IconButton, {
|
90
83
|
children: /*#__PURE__*/_jsx(FaChevronRight, {
|
91
84
|
color: "#94A3B8",
|
92
85
|
size: 12
|
93
86
|
})
|
94
|
-
})
|
87
|
+
})]
|
95
88
|
}), /*#__PURE__*/_jsx(Popper, {
|
96
|
-
open: open &&
|
89
|
+
open: open && option.options,
|
97
90
|
anchorEl: open,
|
98
91
|
sx: {
|
99
92
|
zIndex: 9001,
|
@@ -103,7 +96,7 @@ function DisplayOption({
|
|
103
96
|
setOpen(null);
|
104
97
|
},
|
105
98
|
placement: "right-start",
|
106
|
-
children:
|
99
|
+
children: /*#__PURE__*/_jsx(Box, {
|
107
100
|
children: /*#__PURE__*/_jsx(CustomSelect, {
|
108
101
|
options: option.options,
|
109
102
|
onSend: onSend,
|