@flozy/editor 10.4.9 → 10.5.1
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 +18 -134
- 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 +10 -26
- 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/ColumnView.js +2 -4
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/MultiSelectType.js +11 -26
- package/dist/Editor/Elements/DataView/Layouts/DataTypes/SelectType.js +9 -28
- package/dist/Editor/Elements/DataView/Layouts/Options/AddOptions.js +6 -17
- package/dist/Editor/Elements/DataView/Layouts/Options/EditOption.js +16 -43
- package/dist/Editor/Elements/DataView/Layouts/Options/index.js +0 -11
- package/dist/Editor/Elements/DataView/Layouts/ViewData.js +4 -8
- package/dist/Editor/Elements/Embed/Image.js +2 -3
- package/dist/Editor/Elements/Embed/Video.js +1 -1
- package/dist/Editor/Elements/EmbedScript/Code.js +2 -14
- package/dist/Editor/Elements/EmbedScript/EmbedScriptPopup.js +28 -57
- package/dist/Editor/Elements/Form/Form.js +171 -184
- package/dist/Editor/Elements/Form/FormElements/FormText.js +6 -23
- package/dist/Editor/Elements/Form/FormElements/FormTextArea.js +2 -2
- package/dist/Editor/Elements/Form/FormField.js +6 -13
- package/dist/Editor/Elements/Form/Workflow/Styles.js +22 -24
- package/dist/Editor/Elements/FreeGrid/FreeGrid.js +35 -41
- 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 +8 -8
- package/dist/Editor/Elements/FreeGrid/styles.js +7 -75
- package/dist/Editor/Elements/Grid/Grid.js +2 -14
- package/dist/Editor/Elements/Grid/GridItem.js +1 -1
- package/dist/Editor/Elements/List/CheckList.js +2 -3
- package/dist/Editor/Elements/Search/SearchAttachment.js +9 -40
- package/dist/Editor/Elements/Search/SearchButton.js +8 -9
- package/dist/Editor/Elements/Search/SearchList.js +7 -9
- 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/index.js +1 -6
- package/dist/Editor/Elements/SimpleText/style.js +2 -2
- package/dist/Editor/Elements/Table/AddRowCol.js +2 -8
- 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 +8 -31
- 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 +27 -100
- package/dist/Editor/Toolbar/PopupTool/index.js +1 -1
- package/dist/Editor/Toolbar/toolbarGroups.js +6 -48
- package/dist/Editor/assets/svg/SettingsIcon.js +0 -1
- 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 +1 -31
- 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 +55 -61
- package/dist/Editor/common/LinkSettings/index.js +80 -82
- package/dist/Editor/common/LinkSettings/navOptions.js +2 -2
- package/dist/Editor/common/LinkSettings/style.js +74 -209
- package/dist/Editor/common/MentionsPopup/index.js +1 -4
- package/dist/Editor/common/RnD/ElementOptions/Actions.js +15 -13
- package/dist/Editor/common/RnD/ElementOptions/Icons/LinkIcon.js +0 -1
- package/dist/Editor/common/RnD/ElementOptions/index.js +2 -2
- package/dist/Editor/common/RnD/ElementOptions/styles.js +1 -28
- package/dist/Editor/common/RnD/ElementSettings/OtherSettings/Settings.js +5 -6
- 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 +12 -146
- package/dist/Editor/common/RnD/OptionsPopup/index.js +5 -8
- package/dist/Editor/common/RnD/OptionsPopup/style.js +19 -120
- package/dist/Editor/common/RnD/SwitchViewport/SwitchViewport.js +5 -8
- 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 +38 -67
- package/dist/Editor/common/Select/index.js +5 -44
- package/dist/Editor/common/Select/styles.js +2 -30
- package/dist/Editor/common/Shorthands/elements.js +11 -65
- 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/lineSpacing.js +6 -7
- package/dist/Editor/common/StyleBuilder/fieldTypes/menusArray.js +6 -13
- package/dist/Editor/common/StyleBuilder/fieldTypes/textOptions.js +7 -15
- package/dist/Editor/common/StyleBuilder/pageSettingsStyle.js +7 -5
- package/dist/Editor/common/SwipeableDrawer/style.js +12 -14
- package/dist/Editor/common/Uploader.js +0 -16
- package/dist/Editor/common/iconListV2.js +6 -177
- package/dist/Editor/common/iconslist.js +0 -24
- package/dist/Editor/commonStyle.js +62 -186
- package/dist/Editor/helper/index.js +1 -5
- package/dist/Editor/helper/theme.js +2 -203
- package/dist/Editor/hooks/useMouseMove.js +5 -8
- 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 +46 -172
- 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/form.js +4 -4
- package/dist/Editor/utils/formfield.js +2 -9
- package/dist/Editor/utils/helper.js +26 -215
- 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/DataView/Layouts/DataTypes/Components/SelectV1.js +0 -510
- package/dist/Editor/Elements/EmbedScript/styles.js +0 -89
- 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/ClearAllRounded.js +0 -31
- package/dist/Editor/assets/svg/ResetIconNew.js +0 -23
- 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/SnackBar/index.js +0 -43
- 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
|
}
|
@@ -379,7 +345,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
379
345
|
const onDrawerOpen = status => {
|
380
346
|
setIsDrawerOpen(status);
|
381
347
|
};
|
382
|
-
const lineH = getBreakpointLineSpacing(lineHeight, breakpoint || (isMobile ? "xs" : ""));
|
383
348
|
const isReadOnly = readOnly === "readonly";
|
384
349
|
const customProps = {
|
385
350
|
...(otherProps || {}),
|
@@ -392,9 +357,9 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
392
357
|
onDrawerOpen: onDrawerOpen,
|
393
358
|
ICON_API: "https://assets.agenciflow.com",
|
394
359
|
translation: translationFn,
|
395
|
-
getTitleSaveData
|
396
|
-
customLineHeight: lineH
|
360
|
+
getTitleSaveData
|
397
361
|
};
|
362
|
+
const lineH = getBreakpointLineSpacing(lineHeight, breakpoint);
|
398
363
|
const renderElement = useCallback(props => {
|
399
364
|
return /*#__PURE__*/_jsx(Element, {
|
400
365
|
...props,
|
@@ -462,10 +427,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
462
427
|
} else if (event.key === "ArrowDown" && otherProps?.tagName !== "Pages") {
|
463
428
|
upDownArrowKeyEvents(event, editor);
|
464
429
|
} else if (event.key === "Backspace") {
|
465
|
-
const isAccordion = handleAccordionOnBackspace(event, editor);
|
466
|
-
if (isAccordion) {
|
467
|
-
return;
|
468
|
-
}
|
469
430
|
const isNodeRestricted = isRestrictedNode(event, editor);
|
470
431
|
if (isNodeRestricted) {
|
471
432
|
return;
|
@@ -541,7 +502,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
541
502
|
}
|
542
503
|
return style;
|
543
504
|
}, [pageBgImage, pageColor, pageTextColor]);
|
544
|
-
const themeProps = getTheme(selectedTheme);
|
545
505
|
|
546
506
|
// const handleContextMenu = (e) => {
|
547
507
|
// if (!readOnly) {
|
@@ -572,80 +532,19 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
572
532
|
console.log("handleCursorScroll", err);
|
573
533
|
}
|
574
534
|
};
|
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
535
|
return /*#__PURE__*/_jsxs(EditorProvider, {
|
620
536
|
theme: theme,
|
621
537
|
editor: editor,
|
622
|
-
openTheme: openTheme,
|
623
|
-
setOpenTheme: setOpenTheme,
|
624
|
-
triggerRender: triggerRender,
|
625
538
|
children: [/*#__PURE__*/_jsx(FontLoader, {
|
626
539
|
otherProps: {
|
627
540
|
services: otherProps?.services
|
628
541
|
},
|
629
542
|
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, {
|
543
|
+
}), /*#__PURE__*/_jsx(DialogWrapper, {
|
644
544
|
classes: classes,
|
645
545
|
...props,
|
646
546
|
fullScreen: fullScreen,
|
647
547
|
footer: footer || "",
|
648
|
-
selectedTheme: selectedTheme,
|
649
548
|
children: /*#__PURE__*/_jsx(Box, {
|
650
549
|
component: "div",
|
651
550
|
className: `et-wrpr stimulate-${breakpoint} ${editorClass || ""} ${isIframe ? "iframe-editor" : ""}`,
|
@@ -680,7 +579,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
680
579
|
children: /*#__PURE__*/_jsxs(Box, {
|
681
580
|
component: "div",
|
682
581
|
className: "max-content",
|
683
|
-
sx: themeProps?.sxProps || {},
|
684
582
|
"data-info": outsideEditorClickLabel,
|
685
583
|
children: [renderTopBanner(), /*#__PURE__*/_jsx("div", {
|
686
584
|
className: "scroll-area",
|
@@ -714,8 +612,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
714
612
|
onSelect: () => handleCursorScroll(editorWrapper.current),
|
715
613
|
scrollSelectionIntoView: () => {
|
716
614
|
// disable the scrollSelectionIntoView, to resolve editor auto scroll on free-grid
|
717
|
-
}
|
718
|
-
onCopy: e => handleCopy(e, editor)
|
615
|
+
}
|
719
616
|
}), !readOnly ? /*#__PURE__*/_jsx(MentionsPopup, {
|
720
617
|
ref: mentionsRef,
|
721
618
|
mentions: mentions,
|
@@ -726,8 +623,8 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
726
623
|
chars: chars,
|
727
624
|
type: type,
|
728
625
|
theme: theme,
|
729
|
-
|
730
|
-
|
626
|
+
otherProps: customProps,
|
627
|
+
customProps: customProps
|
731
628
|
}) : null, /*#__PURE__*/_jsx(RnDCopy, {
|
732
629
|
readOnly: readOnly
|
733
630
|
})]
|
@@ -750,18 +647,6 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
750
647
|
"data-info": outsideEditorClickLabel,
|
751
648
|
onClick: handleFooterClick,
|
752
649
|
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
650
|
})]
|
766
651
|
})
|
767
652
|
}), !readOnly ? /*#__PURE__*/_jsx(PopupTool, {
|
@@ -770,9 +655,8 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
|
|
770
655
|
setIsTextSelected: setIsTextSelected,
|
771
656
|
customProps: customProps,
|
772
657
|
editorWrapper: editorWrapper
|
773
|
-
}) : null, !readOnly ? /*#__PURE__*/_jsx(SwitchViewport, {
|
658
|
+
}) : null, !readOnly && showViewport ? /*#__PURE__*/_jsx(SwitchViewport, {
|
774
659
|
breakpoint: breakpoint,
|
775
|
-
show: showViewport,
|
776
660
|
onChange: b => onSwitchBreakpoint(b),
|
777
661
|
translation: translationFn
|
778
662
|
}) : 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") {
|