@flozy/editor 10.4.2 → 10.4.4
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 +16 -17
- package/dist/Editor/CommonEditor.js +16 -131
- package/dist/Editor/DialogWrapper.js +25 -31
- package/dist/Editor/Editor.css +8 -46
- package/dist/Editor/Elements/AI/PopoverAIInput.js +3 -11
- package/dist/Editor/Elements/Accordion/Accordion.js +9 -46
- package/dist/Editor/Elements/Accordion/AccordionSummary.js +23 -1
- package/dist/Editor/Elements/AppHeader/AppHeader.js +5 -10
- package/dist/Editor/Elements/Button/EditorButton.js +9 -27
- package/dist/Editor/Elements/Carousel/CarouselItem.js +1 -2
- package/dist/Editor/Elements/Color Picker/ColorButtons.js +14 -61
- package/dist/Editor/Elements/Color Picker/ColorPicker.css +1 -25
- package/dist/Editor/Elements/Color Picker/ColorPicker.js +7 -10
- package/dist/Editor/Elements/Color Picker/Styles.js +13 -15
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/Components/MultiSelect.js +26 -26
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/MultiSelectType.js +5 -5
- package/dist/Editor/Elements/DataView/Layouts/Options/AddOptions.js +1 -0
- package/dist/Editor/Elements/Embed/Video.js +1 -1
- package/dist/Editor/Elements/Form/Form.js +3 -3
- package/dist/Editor/Elements/Form/FormElements/FormTextArea.js +1 -0
- package/dist/Editor/Elements/Form/FormField.js +2 -3
- package/dist/Editor/Elements/Form/Workflow/Styles.js +22 -24
- package/dist/Editor/Elements/FreeGrid/FreeGrid.js +31 -35
- package/dist/Editor/Elements/FreeGrid/FreeGridBox.js +4 -7
- package/dist/Editor/Elements/FreeGrid/FreeGridItem.js +0 -1
- package/dist/Editor/Elements/FreeGrid/Options/More.js +7 -7
- package/dist/Editor/Elements/FreeGrid/Options/sectionItemOptions.js +1 -1
- package/dist/Editor/Elements/FreeGrid/styles.js +0 -14
- package/dist/Editor/Elements/Grid/Grid.js +2 -14
- package/dist/Editor/Elements/Grid/GridItem.js +1 -1
- package/dist/Editor/Elements/Signature/Signature.css +1 -2
- package/dist/Editor/Elements/Signature/SignatureOptions/DrawSignature.js +5 -18
- package/dist/Editor/Elements/Signature/SignatureOptions/UploadSignature.js +3 -16
- package/dist/Editor/Elements/SimpleText/style.js +2 -2
- package/dist/Editor/Elements/Table/DragButton.js +1 -0
- package/dist/Editor/Elements/Table/Draggable.js +2 -6
- package/dist/Editor/Elements/Table/Styles.js +0 -7
- package/dist/Editor/Elements/Table/Table.js +3 -3
- package/dist/Editor/Elements/Table/TableCell.js +5 -24
- package/dist/Editor/Elements/Title/title.js +6 -6
- package/dist/Editor/Elements/Variables/VariableButton.js +1 -10
- package/dist/Editor/MiniEditor.js +1 -2
- package/dist/Editor/Styles/EditorStyles.js +5 -5
- package/dist/Editor/Toolbar/FormatTools/Dropdown.js +3 -27
- package/dist/Editor/Toolbar/FormatTools/FontFamilyAutocomplete.js +3 -4
- package/dist/Editor/Toolbar/FormatTools/MarkButton.js +2 -2
- package/dist/Editor/Toolbar/FormatTools/TextSize.js +13 -10
- package/dist/Editor/Toolbar/Mini/MiniToolbar.js +1 -2
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/MiniColorPicker.js +2 -4
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectFontSize.js +13 -6
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/SelectTypography.js +42 -167
- package/dist/Editor/Toolbar/PopupTool/MiniTextFormat/index.js +4 -7
- package/dist/Editor/Toolbar/PopupTool/PopperHeader.js +1 -2
- package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +12 -72
- package/dist/Editor/Toolbar/PopupTool/TextFormat.js +10 -58
- package/dist/Editor/Toolbar/PopupTool/index.js +1 -1
- package/dist/Editor/Toolbar/toolbarGroups.js +6 -48
- package/dist/Editor/common/ColorPickerButton.js +16 -41
- package/dist/Editor/common/DnD/DragHandleButton.js +1 -1
- package/dist/Editor/common/FontLoader/FontLoader.js +0 -3
- package/dist/Editor/common/Icon.js +0 -28
- package/dist/Editor/common/ImageSelector/ImageSelector.js +2 -2
- package/dist/Editor/common/ImageSelector/Styles.js +9 -3
- package/dist/Editor/common/LinkSettings/NavComponents.js +65 -45
- package/dist/Editor/common/LinkSettings/index.js +28 -14
- package/dist/Editor/common/LinkSettings/navOptions.js +2 -2
- package/dist/Editor/common/LinkSettings/style.js +244 -164
- package/dist/Editor/common/MentionsPopup/index.js +1 -4
- package/dist/Editor/common/RnD/ElementOptions/Actions.js +5 -4
- package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +1 -2
- package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Signature.js +3 -4
- package/dist/Editor/common/RnD/ElementSettings/Settings/AppHeaderSettings.js +2 -3
- package/dist/Editor/common/RnD/ElementSettings/Settings/BoxSettings.js +2 -3
- package/dist/Editor/common/RnD/ElementSettings/Settings/ButtonSettings.js +2 -3
- package/dist/Editor/common/RnD/ElementSettings/Settings/CodeSettings.js +2 -3
- package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +2 -4
- package/dist/Editor/common/RnD/ElementSettings/Settings/ImageSettings.js +2 -3
- package/dist/Editor/common/RnD/ElementSettings/Settings/TableSettings.js +2 -3
- package/dist/Editor/common/RnD/ElementSettings/Settings/TextSettings.js +1 -3
- package/dist/Editor/common/RnD/ElementSettings/Settings/VideoSettings.js +2 -3
- package/dist/Editor/common/RnD/ElementSettings/styles.js +1 -0
- package/dist/Editor/common/RnD/OptionsPopup/style.js +1 -0
- package/dist/Editor/common/RnD/SwitchViewport/SwitchViewport.js +2 -11
- package/dist/Editor/common/RnD/Theme/ViewportStimulator.js +3 -6
- package/dist/Editor/common/RnD/Utils/gridDropItem.js +19 -28
- package/dist/Editor/common/RnD/Utils/index.js +1 -3
- package/dist/Editor/common/RnD/VirtualElement/VirtualTextElement.js +58 -42
- package/dist/Editor/common/RnD/VirtualElement/helper.js +132 -323
- package/dist/Editor/common/RnD/VirtualElement/styles.js +0 -16
- package/dist/Editor/common/RnD/index.js +39 -68
- package/dist/Editor/common/Select/index.js +7 -44
- package/dist/Editor/common/Select/styles.js +2 -30
- package/dist/Editor/common/Shorthands/elements.js +0 -54
- package/dist/Editor/common/StyleBuilder/accordionTitleBtnStyle.js +2 -2
- package/dist/Editor/common/StyleBuilder/accordionTitleStyle.js +9 -12
- package/dist/Editor/common/StyleBuilder/buttonStyle.js +2 -4
- package/dist/Editor/common/StyleBuilder/embedVideoStyle.js +0 -4
- package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +0 -5
- package/dist/Editor/common/StyleBuilder/fieldTypes/bannerSpacing.js +2 -12
- package/dist/Editor/common/StyleBuilder/fieldTypes/borderRadius.js +7 -15
- package/dist/Editor/common/StyleBuilder/fieldTypes/card.js +8 -16
- package/dist/Editor/common/StyleBuilder/fieldTypes/color.js +10 -36
- package/dist/Editor/common/StyleBuilder/fieldTypes/fontSize.js +7 -16
- package/dist/Editor/common/StyleBuilder/fieldTypes/index.js +1 -3
- package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +7 -15
- package/dist/Editor/common/SwipeableDrawer/style.js +12 -14
- package/dist/Editor/common/Uploader.js +0 -16
- package/dist/Editor/common/iconListV2.js +0 -76
- package/dist/Editor/common/iconslist.js +0 -21
- package/dist/Editor/commonStyle.js +61 -116
- package/dist/Editor/helper/index.js +1 -5
- package/dist/Editor/helper/theme.js +2 -203
- package/dist/Editor/hooks/useMouseMove.js +3 -9
- package/dist/Editor/hooks/useTable.js +4 -5
- package/dist/Editor/plugins/withEmbeds.js +1 -1
- package/dist/Editor/plugins/withHTML.js +1 -3
- package/dist/Editor/plugins/withTable.js +1 -1
- package/dist/Editor/theme/ThemeList.js +173 -50
- package/dist/Editor/utils/SlateUtilityFunctions.js +37 -161
- package/dist/Editor/utils/accordion.js +4 -14
- package/dist/Editor/utils/button.js +17 -1
- package/dist/Editor/utils/customHooks/useTableResize.js +9 -49
- package/dist/Editor/utils/draftToSlate.js +2 -3
- package/dist/Editor/utils/events.js +6 -50
- package/dist/Editor/utils/font.js +37 -40
- package/dist/Editor/utils/formfield.js +0 -1
- package/dist/Editor/utils/helper.js +26 -210
- package/dist/Editor/utils/insertAppHeader.js +1 -1
- package/dist/Editor/utils/signature.js +9 -2
- package/package.json +4 -4
- package/dist/Editor/Elements/FreeGrid/helper.js +0 -115
- package/dist/Editor/Toolbar/PopupTool/ThemeTextFormat.js +0 -439
- package/dist/Editor/assets/svg/BackIcon.js +0 -18
- package/dist/Editor/assets/svg/ThemeIcons.js +0 -293
- package/dist/Editor/common/Checkbox/index.js +0 -46
- package/dist/Editor/common/Checkbox/styles.js +0 -45
- package/dist/Editor/common/CustomColorPicker/index.js +0 -130
- package/dist/Editor/common/CustomColorPicker/style.js +0 -53
- package/dist/Editor/common/CustomDialog2/index.js +0 -94
- package/dist/Editor/common/CustomDialog2/style.js +0 -67
- package/dist/Editor/common/CustomSelect.js +0 -43
- package/dist/Editor/common/RadioGroup/index.js +0 -48
- package/dist/Editor/common/RadioGroup/styles.js +0 -29
- package/dist/Editor/common/RnD/Theme/MainThemeProvider.js +0 -17
- package/dist/Editor/common/StyleBuilder/fieldTypes/embedUpload.js +0 -115
- package/dist/Editor/helper/textIndeces.js +0 -58
- package/dist/Editor/hooks/useEditorTheme.js +0 -153
- package/dist/Editor/hooks/useThemeValues.js +0 -63
- package/dist/Editor/theme/index.js +0 -149
- package/dist/Editor/themeSettings/ActiveTheme.js +0 -82
- package/dist/Editor/themeSettings/buttons/index.js +0 -300
- package/dist/Editor/themeSettings/buttons/style.js +0 -23
- package/dist/Editor/themeSettings/colorTheme/index.js +0 -310
- package/dist/Editor/themeSettings/colorTheme/style.js +0 -81
- package/dist/Editor/themeSettings/fonts/PreviewElement.js +0 -121
- package/dist/Editor/themeSettings/fonts/index.js +0 -240
- package/dist/Editor/themeSettings/fonts/style.js +0 -62
- package/dist/Editor/themeSettings/icons.js +0 -60
- package/dist/Editor/themeSettings/index.js +0 -380
- package/dist/Editor/themeSettings/style.js +0 -299
- package/dist/Editor/themeSettingsAI/icons.js +0 -96
- package/dist/Editor/themeSettingsAI/index.js +0 -355
- package/dist/Editor/themeSettingsAI/saveTheme.js +0 -202
- package/dist/Editor/themeSettingsAI/style.js +0 -332
- package/dist/Editor/utils/updateFormName.js +0 -22
@@ -1,6 +1,6 @@
|
|
1
1
|
import React, { useCallback, useMemo, useRef, useImperativeHandle, forwardRef, useState } from "react";
|
2
|
-
import { Editable, Slate, ReactEditor } from
|
3
|
-
import { createEditor, Transforms, Editor } from
|
2
|
+
import { Editable, Slate, ReactEditor } from 'slate-react';
|
3
|
+
import { createEditor, Transforms, Editor } from 'slate';
|
4
4
|
import withCommon from "./hooks/withCommon";
|
5
5
|
import { getBlock, getMarked, serializeMentions } from "./utils/chatEditor/SlateUtilityFunctions";
|
6
6
|
import MiniTextFormat from "./Toolbar/PopupTool/MiniTextFormat";
|
@@ -33,15 +33,15 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
33
33
|
isMobile = false,
|
34
34
|
debounceTimeOut = 10,
|
35
35
|
isMarkDown = false,
|
36
|
-
markDownContent =
|
36
|
+
markDownContent = '',
|
37
37
|
translation
|
38
38
|
} = props;
|
39
39
|
const classes = usePopupStyle(theme);
|
40
40
|
const convertedContent = draftToSlate({
|
41
41
|
data: content && content?.length > 0 ? content : [{
|
42
|
-
type:
|
42
|
+
type: 'paragraph',
|
43
43
|
children: [{
|
44
|
-
text:
|
44
|
+
text: ''
|
45
45
|
}]
|
46
46
|
}]
|
47
47
|
});
|
@@ -153,6 +153,14 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
153
153
|
// needLayout = true,
|
154
154
|
} = otherProps || {};
|
155
155
|
const mentionsRef = useRef();
|
156
|
+
const customProps = {
|
157
|
+
...(otherProps || {}),
|
158
|
+
hideTools: ["settings", "add_column", "drag", "resize"],
|
159
|
+
readOnly: isReadOnly,
|
160
|
+
editorPlaceholder: "Write Something",
|
161
|
+
page_id: 1,
|
162
|
+
translation: translation || translationMock
|
163
|
+
};
|
156
164
|
const [mentions, setMentions] = useMentions({
|
157
165
|
editor,
|
158
166
|
selection: editor?.selection
|
@@ -214,15 +222,6 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
214
222
|
debounced(newValue);
|
215
223
|
debouncedValue.current = newValue;
|
216
224
|
};
|
217
|
-
const dummyTranslation = () => {};
|
218
|
-
const customProps = {
|
219
|
-
...(otherProps || {}),
|
220
|
-
hideTools: ["settings", "add_column", "drag", "resize"],
|
221
|
-
readOnly: isReadOnly,
|
222
|
-
editorPlaceholder: "Write Something",
|
223
|
-
page_id: 1,
|
224
|
-
translation: translation || translationMock || dummyTranslation
|
225
|
-
};
|
226
225
|
const Element = props => {
|
227
226
|
return getBlock(props);
|
228
227
|
};
|
@@ -258,7 +257,7 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
258
257
|
editor
|
259
258
|
});
|
260
259
|
} else if (event.key === "Enter" && !isMobile) {
|
261
|
-
const isEmpty = debouncedValue?.current.length === 1 && debouncedValue?.current[0].type ===
|
260
|
+
const isEmpty = debouncedValue?.current.length === 1 && debouncedValue?.current[0].type === 'paragraph' && debouncedValue?.current[0].children.length === 1 && debouncedValue?.current[0].children[0].text === '';
|
262
261
|
if (isEmpty) {
|
263
262
|
event.preventDefault();
|
264
263
|
return;
|
@@ -298,10 +297,10 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
298
297
|
}
|
299
298
|
};
|
300
299
|
|
301
|
-
const html = isMarkDown ? convertMDToHTML(markDownContent) : null;
|
302
300
|
const handleFocus = () => {
|
303
301
|
setIsFocused(true);
|
304
302
|
};
|
303
|
+
const html = isMarkDown ? convertMDToHTML(markDownContent) : null;
|
305
304
|
return !isMarkDown ? /*#__PURE__*/_jsx(EditorProvider, {
|
306
305
|
theme: theme,
|
307
306
|
editor: editor,
|
@@ -315,13 +314,13 @@ const ChatEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
315
314
|
closeMainPopup: handleClose,
|
316
315
|
customProps: customProps
|
317
316
|
}), /*#__PURE__*/_jsx(Editable, {
|
317
|
+
onFocus: handleFocus,
|
318
318
|
className: "chatEditorRoot",
|
319
319
|
renderElement: renderElement,
|
320
320
|
renderLeaf: renderLeaf,
|
321
321
|
decorate: decorators,
|
322
322
|
placeholder: "Start typing ...",
|
323
323
|
spellCheck: true,
|
324
|
-
onFocus: handleFocus,
|
325
324
|
onBlur: handleBlur,
|
326
325
|
onKeyDown: onKeyDown,
|
327
326
|
onPaste: handlePaste,
|
@@ -1,7 +1,7 @@
|
|
1
1
|
/* eslint-disable no-unused-vars */
|
2
|
-
import React, { useRef, useCallback, useEffect, useMemo, useState, forwardRef, useImperativeHandle
|
2
|
+
import React, { useRef, useCallback, useEffect, useMemo, useState, forwardRef, useImperativeHandle } from "react";
|
3
3
|
import PropTypes from "prop-types";
|
4
|
-
import { createEditor,
|
4
|
+
import { createEditor, Range, Transforms } from "slate";
|
5
5
|
import { Slate, Editable, ReactEditor } from "slate-react";
|
6
6
|
import { useDebouncedCallback } from "use-debounce";
|
7
7
|
import { getMarked, getBlock } from "./utils/SlateUtilityFunctions";
|
@@ -10,14 +10,14 @@ import { draftToSlate } from "./utils/draftToSlate";
|
|
10
10
|
import useMentions from "./hooks/useMentions";
|
11
11
|
import MentionsPopup from "./common/MentionsPopup";
|
12
12
|
import { RemoteCursorOverlay } from "./RemoteCursorOverlay/Overlay";
|
13
|
-
import { mentionsEvent, commands, indentation, escapeEvent, enterEvent, upDownArrowKeyEvents
|
13
|
+
import { mentionsEvent, commands, indentation, escapeEvent, enterEvent, upDownArrowKeyEvents } from "./utils/events";
|
14
14
|
import withCommon from "./hooks/withCommon";
|
15
15
|
import DialogWrapper from "./DialogWrapper";
|
16
16
|
import { serializeToText } from "./utils/serializeToText";
|
17
17
|
import { getPageSettings } from "./utils/pageSettings";
|
18
18
|
import { getThumbnailImage, invertColor, pageTextStyle } from "./helper";
|
19
19
|
import PopupTool from "./Toolbar/PopupTool";
|
20
|
-
import { Box, Typography, useTheme
|
20
|
+
import { Box, Typography, useTheme } from "@mui/material";
|
21
21
|
import Shorthands from "./common/Shorthands";
|
22
22
|
import MiniToolbar from "./Toolbar/Mini/MiniToolbar";
|
23
23
|
import { EditorProvider } from "./hooks/useMouseMove";
|
@@ -26,12 +26,9 @@ import editorStyles from "./Styles/EditorStyles";
|
|
26
26
|
import DragAndDrop from "./common/DnD";
|
27
27
|
import Section from "./common/Section";
|
28
28
|
import decorators from "./utils/Decorators";
|
29
|
-
import {
|
30
|
-
import { getInitialValue,
|
29
|
+
import { getBreakpointLineSpacing, getTRBLBreakPoints } from "./helper/theme";
|
30
|
+
import { getInitialValue, handleInsertLastElement, isEverythingSelected, isFreeGrid, isFreeGridFragment, isRestrictedNode, outsideEditorClickLabel } from "./utils/helper";
|
31
31
|
import useWindowResize from "./hooks/useWindowResize";
|
32
|
-
import { getTheme } from "./theme";
|
33
|
-
import ThemeSettings from "./themeSettings";
|
34
|
-
import ThemeSettingsAI from "./themeSettingsAI";
|
35
32
|
import PopoverAIInput from "./Elements/AI/PopoverAIInput";
|
36
33
|
import RnDCopy from "./common/RnD/RnDCopy";
|
37
34
|
import SwitchViewport from "./common/RnD/SwitchViewport/SwitchViewport";
|
@@ -40,12 +37,9 @@ import "./font.css";
|
|
40
37
|
import "./Editor.css";
|
41
38
|
import "animate.css";
|
42
39
|
import FontLoader from "./common/FontLoader/FontLoader";
|
43
|
-
import { ThemeAIIcon, ThemePaintIcon } from "./assets/svg/ThemeIcons";
|
44
40
|
import { CustomDialogComponent } from "./common/CustomDialog";
|
45
|
-
import { extractTextWithPath, replaceTextPath } from "./helper/textIndeces.js";
|
46
41
|
import { jsx as _jsx } from "react/jsx-runtime";
|
47
42
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
48
|
-
export const ThemeContext = /*#__PURE__*/createContext(null);
|
49
43
|
const Item = /*#__PURE__*/forwardRef(({
|
50
44
|
children,
|
51
45
|
...props
|
@@ -87,7 +81,6 @@ const updateTopBanner = (content = [], setTopBanner) => {
|
|
87
81
|
return firstNode?.type === "topbanner" ? firstNode : null;
|
88
82
|
});
|
89
83
|
};
|
90
|
-
const dummyTranslation = () => {};
|
91
84
|
const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
92
85
|
const {
|
93
86
|
id,
|
@@ -101,7 +94,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
101
94
|
otherProps,
|
102
95
|
isIframe,
|
103
96
|
theme,
|
104
|
-
showThemeButtons,
|
105
97
|
showViewport = false,
|
106
98
|
overrideWrapperStyles = {},
|
107
99
|
translation
|
@@ -109,8 +101,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
109
101
|
const editorWrapper = useRef();
|
110
102
|
const mentionsRef = useRef();
|
111
103
|
const convertedContent = draftToSlate({
|
112
|
-
data: content
|
113
|
-
needLayout: otherProps?.needLayout
|
104
|
+
data: content
|
114
105
|
});
|
115
106
|
const [value, setValue] = useState(convertedContent);
|
116
107
|
const [isInteracted, setIsInteracted] = useState(false);
|
@@ -154,11 +145,10 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
154
145
|
const {
|
155
146
|
bannerSpacing,
|
156
147
|
pageBgImage,
|
157
|
-
pageColor
|
148
|
+
pageColor,
|
158
149
|
color: pageTextColor,
|
159
150
|
pageWidth,
|
160
151
|
maxWidth: pageMaxWidth,
|
161
|
-
theme: selectedTheme,
|
162
152
|
lineHeight
|
163
153
|
} = pageSt?.pageProps || {
|
164
154
|
bannerSpacing: {
|
@@ -170,17 +160,10 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
170
160
|
};
|
171
161
|
const classes = editorStyles({
|
172
162
|
padHeight: !fullScreen ? otherProps?.padHeight : 20,
|
173
|
-
placeHolderColor: invertColor(pageColor
|
163
|
+
placeHolderColor: invertColor(pageColor || "#FFF"),
|
174
164
|
theme,
|
175
165
|
overrideWrapperStyles
|
176
166
|
});
|
177
|
-
const [openTheme, setOpenTheme] = useState(false);
|
178
|
-
const [openAITheme, setOpenAITheme] = useState(false);
|
179
|
-
const [, setThemeUpdated] = useState(0);
|
180
|
-
const triggerRender = () => {
|
181
|
-
setThemeUpdated(prev => prev + 1); // Incrementing forces a re-render while updating theme
|
182
|
-
};
|
183
|
-
|
184
167
|
const isMobile = window.matchMedia("(max-width: 899px)")?.matches || false;
|
185
168
|
useEffect(() => {
|
186
169
|
setValue(draftToSlate({
|
@@ -191,25 +174,14 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
191
174
|
ReactEditor.focus(editor);
|
192
175
|
}
|
193
176
|
}, [id, content]);
|
194
|
-
useEffect(() => {
|
195
|
-
if (isReadOnly) {
|
196
|
-
const sectionId = window.location.hash.substring(1);
|
197
|
-
const sectionEle = sectionId ? document.getElementById(decodeURIComponent(sectionId)) : null;
|
198
|
-
if (sectionEle) {
|
199
|
-
sectionEle.scrollIntoView({
|
200
|
-
behavior: "smooth"
|
201
|
-
});
|
202
|
-
}
|
203
|
-
}
|
204
|
-
}, []);
|
205
177
|
const debounced = useDebouncedCallback(
|
206
178
|
// function
|
207
179
|
value => {
|
208
|
-
debouncedValue.current = value;
|
209
180
|
const {
|
210
181
|
value: strVal,
|
211
182
|
...restVal
|
212
183
|
} = getOnSaveData(value);
|
184
|
+
debouncedValue.current = value;
|
213
185
|
onSave(strVal, restVal);
|
214
186
|
},
|
215
187
|
// delay in ms
|
@@ -220,7 +192,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
220
192
|
return {
|
221
193
|
value: JSON.stringify(val),
|
222
194
|
text: text,
|
223
|
-
title: serializeToText(title?.children) || ""
|
195
|
+
title: serializeToText(title?.children) || "Untitled"
|
224
196
|
};
|
225
197
|
};
|
226
198
|
const getTitleSaveData = title => {
|
@@ -333,12 +305,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
333
305
|
redo() {
|
334
306
|
editor?.redo();
|
335
307
|
},
|
336
|
-
toggleTheme() {
|
337
|
-
setOpenTheme(!openTheme);
|
338
|
-
},
|
339
|
-
toggleAITheme() {
|
340
|
-
setOpenAITheme(!openAITheme);
|
341
|
-
},
|
342
308
|
getPageSettings: {
|
343
309
|
background: pageBgImage && pageBgImage !== "none" ? `url(${pageBgImage})` : pageColor || ""
|
344
310
|
}
|
@@ -462,10 +428,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
462
428
|
} else if (event.key === "ArrowDown" && otherProps?.tagName !== "Pages") {
|
463
429
|
upDownArrowKeyEvents(event, editor);
|
464
430
|
} else if (event.key === "Backspace") {
|
465
|
-
const isAccordion = handleAccordionOnBackspace(event, editor);
|
466
|
-
if (isAccordion) {
|
467
|
-
return;
|
468
|
-
}
|
469
431
|
const isNodeRestricted = isRestrictedNode(event, editor);
|
470
432
|
if (isNodeRestricted) {
|
471
433
|
return;
|
@@ -541,7 +503,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
541
503
|
}
|
542
504
|
return style;
|
543
505
|
}, [pageBgImage, pageColor, pageTextColor]);
|
544
|
-
const themeProps = getTheme(selectedTheme);
|
545
506
|
|
546
507
|
// const handleContextMenu = (e) => {
|
547
508
|
// if (!readOnly) {
|
@@ -572,80 +533,19 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
572
533
|
console.log("handleCursorScroll", err);
|
573
534
|
}
|
574
535
|
};
|
575
|
-
window.getTextIndeces = () => {
|
576
|
-
try {
|
577
|
-
const textWithPaths = extractTextWithPath(editor.children, []);
|
578
|
-
return textWithPaths;
|
579
|
-
} catch (err) {
|
580
|
-
console.log(err);
|
581
|
-
}
|
582
|
-
};
|
583
|
-
window.replaceTextIndeces = (path_data = []) => {
|
584
|
-
try {
|
585
|
-
const replacedJson = replaceTextPath(JSON.parse(JSON.stringify(editor.children)), path_data);
|
586
|
-
|
587
|
-
// loop delete all
|
588
|
-
editor.children.forEach(() => {
|
589
|
-
Transforms.delete(editor, {
|
590
|
-
at: [0]
|
591
|
-
});
|
592
|
-
});
|
593
|
-
|
594
|
-
// Insert new nodes
|
595
|
-
Transforms.insertNodes(editor, replacedJson, {
|
596
|
-
at: [0]
|
597
|
-
});
|
598
|
-
} catch (err) {
|
599
|
-
console.log(err);
|
600
|
-
}
|
601
|
-
};
|
602
|
-
window.replaceEditorContent = (fragments = []) => {
|
603
|
-
try {
|
604
|
-
// loop delete all
|
605
|
-
editor.children.forEach(() => {
|
606
|
-
Transforms.delete(editor, {
|
607
|
-
at: [0]
|
608
|
-
});
|
609
|
-
});
|
610
|
-
|
611
|
-
// Insert new nodes
|
612
|
-
Transforms.insertNodes(editor, fragments, {
|
613
|
-
at: [0]
|
614
|
-
});
|
615
|
-
} catch (err) {
|
616
|
-
console.log(err);
|
617
|
-
}
|
618
|
-
};
|
619
536
|
return /*#__PURE__*/_jsxs(EditorProvider, {
|
620
537
|
theme: theme,
|
621
538
|
editor: editor,
|
622
|
-
openTheme: openTheme,
|
623
|
-
setOpenTheme: setOpenTheme,
|
624
|
-
triggerRender: triggerRender,
|
625
539
|
children: [/*#__PURE__*/_jsx(FontLoader, {
|
626
540
|
otherProps: {
|
627
541
|
services: otherProps?.services
|
628
542
|
},
|
629
543
|
readOnly: readOnly
|
630
|
-
}),
|
631
|
-
className: "theme-buttons",
|
632
|
-
children: [/*#__PURE__*/_jsx(IconButton, {
|
633
|
-
onClick: () => setOpenTheme(true),
|
634
|
-
className: "themePaintIcon",
|
635
|
-
children: /*#__PURE__*/_jsx(ThemePaintIcon, {})
|
636
|
-
}), /*#__PURE__*/_jsx(IconButton, {
|
637
|
-
onClick: () => setOpenAITheme(true),
|
638
|
-
style: {
|
639
|
-
marginTop: "4px"
|
640
|
-
},
|
641
|
-
children: /*#__PURE__*/_jsx(ThemeAIIcon, {})
|
642
|
-
})]
|
643
|
-
}) : null, /*#__PURE__*/_jsx(DialogWrapper, {
|
544
|
+
}), /*#__PURE__*/_jsx(DialogWrapper, {
|
644
545
|
classes: classes,
|
645
546
|
...props,
|
646
547
|
fullScreen: fullScreen,
|
647
548
|
footer: footer || "",
|
648
|
-
selectedTheme: selectedTheme,
|
649
549
|
children: /*#__PURE__*/_jsx(Box, {
|
650
550
|
component: "div",
|
651
551
|
className: `et-wrpr stimulate-${breakpoint} ${editorClass || ""} ${isIframe ? "iframe-editor" : ""}`,
|
@@ -680,7 +580,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
680
580
|
children: /*#__PURE__*/_jsxs(Box, {
|
681
581
|
component: "div",
|
682
582
|
className: "max-content",
|
683
|
-
sx: themeProps?.sxProps || {},
|
684
583
|
"data-info": outsideEditorClickLabel,
|
685
584
|
children: [renderTopBanner(), /*#__PURE__*/_jsx("div", {
|
686
585
|
className: "scroll-area",
|
@@ -714,8 +613,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
714
613
|
onSelect: () => handleCursorScroll(editorWrapper.current),
|
715
614
|
scrollSelectionIntoView: () => {
|
716
615
|
// disable the scrollSelectionIntoView, to resolve editor auto scroll on free-grid
|
717
|
-
}
|
718
|
-
onCopy: e => handleCopy(e, editor)
|
616
|
+
}
|
719
617
|
}), !readOnly ? /*#__PURE__*/_jsx(MentionsPopup, {
|
720
618
|
ref: mentionsRef,
|
721
619
|
mentions: mentions,
|
@@ -726,8 +624,8 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
726
624
|
chars: chars,
|
727
625
|
type: type,
|
728
626
|
theme: theme,
|
729
|
-
|
730
|
-
|
627
|
+
otherProps: customProps,
|
628
|
+
customProps: customProps
|
731
629
|
}) : null, /*#__PURE__*/_jsx(RnDCopy, {
|
732
630
|
readOnly: readOnly
|
733
631
|
})]
|
@@ -750,18 +648,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
750
648
|
"data-info": outsideEditorClickLabel,
|
751
649
|
onClick: handleFooterClick,
|
752
650
|
children: footer
|
753
|
-
}), openTheme ? /*#__PURE__*/_jsx(ThemeSettings, {
|
754
|
-
open: openTheme,
|
755
|
-
setOpen: setOpenTheme,
|
756
|
-
editor: editor,
|
757
|
-
services: otherProps?.services,
|
758
|
-
appTheme: theme,
|
759
|
-
customProps: customProps
|
760
|
-
}) : null, /*#__PURE__*/_jsx(ThemeSettingsAI, {
|
761
|
-
openAITheme: openAITheme,
|
762
|
-
setOpenAITheme: setOpenAITheme,
|
763
|
-
onSaveTheme: otherProps?.onSaveTheme,
|
764
|
-
theme: theme
|
765
651
|
})]
|
766
652
|
})
|
767
653
|
}), !readOnly ? /*#__PURE__*/_jsx(PopupTool, {
|
@@ -770,9 +656,8 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
770
656
|
setIsTextSelected: setIsTextSelected,
|
771
657
|
customProps: customProps,
|
772
658
|
editorWrapper: editorWrapper
|
773
|
-
}) : null, !readOnly ? /*#__PURE__*/_jsx(SwitchViewport, {
|
659
|
+
}) : null, !readOnly && showViewport ? /*#__PURE__*/_jsx(SwitchViewport, {
|
774
660
|
breakpoint: breakpoint,
|
775
|
-
show: showViewport,
|
776
661
|
onChange: b => onSwitchBreakpoint(b),
|
777
662
|
translation: translationFn
|
778
663
|
}) : null]
|
@@ -2,7 +2,6 @@ import React from "react";
|
|
2
2
|
import { Dialog, DialogTitle, DialogContent, IconButton, Grid } from "@mui/material";
|
3
3
|
import CloseIcon from "@mui/icons-material/Close";
|
4
4
|
import ViewportStimulator from "./common/RnD/Theme/ViewportStimulator";
|
5
|
-
import MainThemeProvider from "./common/RnD/Theme/MainThemeProvider";
|
6
5
|
import { jsx as _jsx } from "react/jsx-runtime";
|
7
6
|
import { jsxs as _jsxs } from "react/jsx-runtime";
|
8
7
|
const DialogWrapper = props => {
|
@@ -10,45 +9,40 @@ const DialogWrapper = props => {
|
|
10
9
|
fullScreen,
|
11
10
|
onClose,
|
12
11
|
children,
|
13
|
-
classes
|
14
|
-
selectedTheme
|
12
|
+
classes
|
15
13
|
} = props;
|
16
|
-
return fullScreen ? /*#__PURE__*/
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
14
|
+
return fullScreen ? /*#__PURE__*/_jsxs(Dialog, {
|
15
|
+
className: `dialogComp`,
|
16
|
+
open: fullScreen,
|
17
|
+
fullScreen: fullScreen,
|
18
|
+
onClose: onClose,
|
19
|
+
style: {
|
20
|
+
zIndex: 1000
|
21
|
+
},
|
22
|
+
sx: classes.fullScreenWrapper,
|
23
|
+
children: [/*#__PURE__*/_jsx(DialogTitle, {
|
23
24
|
style: {
|
24
|
-
|
25
|
+
padding: "6px 8px"
|
25
26
|
},
|
26
|
-
|
27
|
-
children: [/*#__PURE__*/_jsx(DialogTitle, {
|
28
|
-
style: {
|
29
|
-
padding: "6px 8px"
|
30
|
-
},
|
27
|
+
children: /*#__PURE__*/_jsx(Grid, {
|
31
28
|
children: /*#__PURE__*/_jsx(Grid, {
|
32
|
-
|
29
|
+
style: {
|
30
|
+
display: "flex",
|
31
|
+
justifyContent: "end"
|
32
|
+
},
|
33
|
+
children: /*#__PURE__*/_jsx(IconButton, {
|
34
|
+
onClick: onClose,
|
33
35
|
style: {
|
34
|
-
|
35
|
-
justifyContent: "end"
|
36
|
+
background: "rgba(255,255,255,0.5)"
|
36
37
|
},
|
37
|
-
children: /*#__PURE__*/_jsx(
|
38
|
-
onClick: onClose,
|
39
|
-
style: {
|
40
|
-
background: "rgba(255,255,255,0.5)"
|
41
|
-
},
|
42
|
-
children: /*#__PURE__*/_jsx(CloseIcon, {})
|
43
|
-
})
|
38
|
+
children: /*#__PURE__*/_jsx(CloseIcon, {})
|
44
39
|
})
|
45
40
|
})
|
46
|
-
})
|
47
|
-
|
48
|
-
|
49
|
-
})
|
41
|
+
})
|
42
|
+
}), /*#__PURE__*/_jsx(DialogContent, {
|
43
|
+
children: children
|
44
|
+
})]
|
50
45
|
}) : /*#__PURE__*/_jsx(ViewportStimulator, {
|
51
|
-
selectedTheme: selectedTheme,
|
52
46
|
children: children
|
53
47
|
});
|
54
48
|
};
|
package/dist/Editor/Editor.css
CHANGED
@@ -426,32 +426,6 @@ blockquote {
|
|
426
426
|
|
427
427
|
.upload-sign-img-wrapper {
|
428
428
|
text-align: center;
|
429
|
-
position: relative;
|
430
|
-
}
|
431
|
-
|
432
|
-
.upload-sign-img {
|
433
|
-
max-width: 100%;
|
434
|
-
}
|
435
|
-
|
436
|
-
.remove-sign-img-btn {
|
437
|
-
padding: 8px 12px;
|
438
|
-
background-color: #ffffff68;
|
439
|
-
cursor: pointer;
|
440
|
-
width: fit-content;
|
441
|
-
border-radius: 8px;
|
442
|
-
position: absolute;
|
443
|
-
left: 50%;
|
444
|
-
top: 50%;
|
445
|
-
transform: translate(-50%, -50%);
|
446
|
-
display: none;
|
447
|
-
}
|
448
|
-
|
449
|
-
.remove-sign-img-btn:hover {
|
450
|
-
background-color: #ffffffa0;
|
451
|
-
}
|
452
|
-
|
453
|
-
.upload-sign-img-wrapper:hover .remove-sign-img-btn {
|
454
|
-
display: block;
|
455
429
|
}
|
456
430
|
|
457
431
|
.signature-tab img {
|
@@ -1368,33 +1342,21 @@ code.markcode {
|
|
1368
1342
|
background-color: #f3f3f3;
|
1369
1343
|
font-family: 'Source Code Pro' !important;
|
1370
1344
|
}
|
1371
|
-
|
1372
1345
|
/* Hide the popper when the reference is hidden */
|
1373
1346
|
.hide-popper-on-overlap[data-popper-escaped],
|
1374
1347
|
.hide-popper-on-overlap[data-popper-reference-hidden] {
|
1375
1348
|
visibility: hidden;
|
1376
1349
|
pointer-events: none;
|
1377
1350
|
}
|
1378
|
-
|
1379
|
-
|
1380
|
-
|
1381
|
-
|
1382
|
-
|
1383
|
-
|
1384
|
-
|
1385
|
-
top: 60px;
|
1386
|
-
right: 20px;
|
1387
|
-
z-index: 1000;
|
1388
|
-
}
|
1389
|
-
|
1390
|
-
.themePaintIcon:hover .iconBorder {
|
1391
|
-
fill: #2563EB;
|
1392
|
-
}
|
1393
|
-
|
1394
|
-
.themePaintIcon:hover .iconStroke {
|
1395
|
-
stroke: #2563EB;
|
1351
|
+
code.markcode {
|
1352
|
+
border-radius: 4px;
|
1353
|
+
padding: 6px 8px;
|
1354
|
+
margin: 8px 0px;
|
1355
|
+
display: block;
|
1356
|
+
background-color: #f3f3f3;
|
1357
|
+
font-family: 'Source Code Pro' !important;
|
1396
1358
|
}
|
1397
1359
|
|
1398
1360
|
.hyperLink {
|
1399
1361
|
word-break: break-all;
|
1400
|
-
}
|
1362
|
+
}
|
@@ -167,7 +167,6 @@ function PopoverAIInput({
|
|
167
167
|
const [generatedText, setGeneratedText] = useState("");
|
168
168
|
const [inputValue, setInputValue] = useState("");
|
169
169
|
const [selectedOption, setSelectedOption] = useState();
|
170
|
-
const [threadId, setThreadId] = useState("");
|
171
170
|
const selectedEleRef = useRef({});
|
172
171
|
const classes = Styles();
|
173
172
|
const editor = useSlate();
|
@@ -189,7 +188,6 @@ function PopoverAIInput({
|
|
189
188
|
useEffect(() => {
|
190
189
|
if (openAI) {
|
191
190
|
scrollToAIInput(editor);
|
192
|
-
setThreadId("");
|
193
191
|
}
|
194
192
|
}, [openAI]);
|
195
193
|
useEffect(() => {
|
@@ -198,12 +196,8 @@ function PopoverAIInput({
|
|
198
196
|
const framePayload = (type, option) => {
|
199
197
|
let payload = {
|
200
198
|
mode: option.mode || 0,
|
201
|
-
query: option?.inputValue || inputValue
|
202
|
-
useSession: true
|
199
|
+
query: option?.inputValue || inputValue
|
203
200
|
};
|
204
|
-
if (threadId) {
|
205
|
-
payload.threadId = threadId;
|
206
|
-
}
|
207
201
|
if (option.mode === MODES.translate || option.mode === MODES.rephraseTone) {
|
208
202
|
payload.textOptionInput = type;
|
209
203
|
}
|
@@ -263,14 +257,12 @@ function PopoverAIInput({
|
|
263
257
|
setLoading(false);
|
264
258
|
setInputValue("");
|
265
259
|
let {
|
266
|
-
|
267
|
-
|
268
|
-
} = result?.data || {};
|
260
|
+
data: text
|
261
|
+
} = result || {};
|
269
262
|
if (!text) {
|
270
263
|
onClickOutside();
|
271
264
|
return;
|
272
265
|
}
|
273
|
-
setThreadId(threadId || "");
|
274
266
|
|
275
267
|
// if (!option.replace) {
|
276
268
|
if (type === "continue_writing") {
|