@flozy/editor 5.6.2 → 5.6.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.
Files changed (37) hide show
  1. package/dist/Editor/CommonEditor.js +10 -5
  2. package/dist/Editor/Editor.css +13 -14
  3. package/dist/Editor/Elements/Button/EditorButton.js +3 -1
  4. package/dist/Editor/Elements/Form/Form.js +1 -0
  5. package/dist/Editor/Elements/FreeGrid/styles.js +1 -0
  6. package/dist/Editor/Elements/List/CheckList.js +2 -1
  7. package/dist/Editor/Elements/Search/SearchAttachment.js +3 -2
  8. package/dist/Editor/Elements/SimpleText/index.js +8 -1
  9. package/dist/Editor/Elements/SimpleText/style.js +5 -1
  10. package/dist/Editor/Elements/Table/TableCell.js +28 -24
  11. package/dist/Editor/Elements/Title/title.js +13 -1
  12. package/dist/Editor/Styles/EditorStyles.js +0 -3
  13. package/dist/Editor/Toolbar/PopupTool/AddTemplates.js +13 -3
  14. package/dist/Editor/Toolbar/PopupTool/PopupToolStyle.js +10 -0
  15. package/dist/Editor/Toolbar/PopupTool/TemplateCard.js +1 -1
  16. package/dist/Editor/Toolbar/PopupTool/TextFormat.js +45 -0
  17. package/dist/Editor/common/FontLoader/FontLoader.js +4 -4
  18. package/dist/Editor/common/MentionsPopup/Styles.js +1 -0
  19. package/dist/Editor/common/RnD/ElementSettings/Settings/FormSettings.js +1 -0
  20. package/dist/Editor/common/RnD/SwitchViewport/SwitchViewport.js +14 -2
  21. package/dist/Editor/common/RnD/Utils/gridDropItem.js +26 -7
  22. package/dist/Editor/common/StyleBuilder/fieldTypes/backgroundImage.js +5 -0
  23. package/dist/Editor/common/StyleBuilder/fieldTypes/card.js +10 -2
  24. package/dist/Editor/common/StyleBuilder/fieldTypes/index.js +3 -1
  25. package/dist/Editor/common/StyleBuilder/fieldTypes/lineSpacing.js +79 -0
  26. package/dist/Editor/common/StyleBuilder/pageSettingsStyle.js +4 -0
  27. package/dist/Editor/common/Uploader.js +8 -0
  28. package/dist/Editor/commonStyle.js +4 -4
  29. package/dist/Editor/helper/index.js +2 -2
  30. package/dist/Editor/helper/theme.js +24 -1
  31. package/dist/Editor/hooks/useMouseMove.js +5 -2
  32. package/dist/Editor/utils/SlateUtilityFunctions.js +8 -1
  33. package/dist/Editor/utils/button.js +4 -4
  34. package/dist/Editor/utils/draftToSlate.js +3 -2
  35. package/dist/Editor/utils/helper.js +19 -16
  36. package/dist/Editor/utils/pageSettings.js +14 -2
  37. package/package.json +1 -1
@@ -26,7 +26,7 @@ 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 { getTRBLBreakPoints } from "./helper/theme";
29
+ import { getBreakpointLineSpacing, getTRBLBreakPoints } from "./helper/theme";
30
30
  import { getInitialValue, handleInsertLastElement, isFreeGrid, isFreeGridFragment, isPageSettings, outsideEditorClickLabel } from "./utils/helper";
31
31
  import useWindowResize from "./hooks/useWindowResize";
32
32
  import PopoverAIInput from "./Elements/AI/PopoverAIInput";
@@ -96,7 +96,8 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
96
96
  const editorWrapper = useRef();
97
97
  const mentionsRef = useRef();
98
98
  const convertedContent = draftToSlate({
99
- data: content
99
+ data: content,
100
+ needLayout: otherProps?.needLayout
100
101
  });
101
102
  const [value, setValue] = useState(convertedContent);
102
103
  const [isInteracted, setIsInteracted] = useState(false);
@@ -139,7 +140,8 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
139
140
  pageColor,
140
141
  color: pageTextColor,
141
142
  pageWidth,
142
- maxWidth: pageMaxWidth
143
+ maxWidth: pageMaxWidth,
144
+ lineHeight
143
145
  } = pageSt?.pageProps || {
144
146
  bannerSpacing: {
145
147
  left: 0,
@@ -166,11 +168,11 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
166
168
  const debounced = useDebouncedCallback(
167
169
  // function
168
170
  value => {
171
+ debouncedValue.current = value;
169
172
  const {
170
173
  value: strVal,
171
174
  ...restVal
172
175
  } = getOnSaveData(value);
173
- debouncedValue.current = value;
174
176
  onSave(strVal, restVal);
175
177
  },
176
178
  // delay in ms
@@ -332,6 +334,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
332
334
  onDrawerOpen: onDrawerOpen,
333
335
  ICON_API: "https://assets.agenciflow.com"
334
336
  };
337
+ const lineH = getBreakpointLineSpacing(lineHeight, breakpoint);
335
338
  const renderElement = useCallback(props => {
336
339
  return /*#__PURE__*/_jsx(Element, {
337
340
  ...props,
@@ -534,6 +537,7 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
534
537
  padding: {
535
538
  ...getTRBLBreakPoints(bannerSpacing)
536
539
  },
540
+ lineHeight: lineH,
537
541
  width: !pageWidth || pageWidth === "fixed" ? fixedWidth : fullWidth,
538
542
  height: viewport.h ? `${viewport.h}px` : `100%`,
539
543
  alignSelf: "center",
@@ -594,8 +598,9 @@ const CommonEditor = /*#__PURE__*/forwardRef((props, ref) => {
594
598
  setIsTextSelected: setIsTextSelected,
595
599
  customProps: customProps,
596
600
  editorWrapper: editorWrapper
597
- }) : null, !readOnly && showViewport ? /*#__PURE__*/_jsx(SwitchViewport, {
601
+ }) : null, !readOnly ? /*#__PURE__*/_jsx(SwitchViewport, {
598
602
  breakpoint: breakpoint,
603
+ show: showViewport,
599
604
  onChange: b => onSwitchBreakpoint(b)
600
605
  }) : null]
601
606
  })
@@ -1257,6 +1257,19 @@ blockquote {
1257
1257
  pointer-events: auto;
1258
1258
  }
1259
1259
 
1260
+ @media (max-width: 899px) {
1261
+ .MuiPopover-root {
1262
+ z-index: 1302 !important;
1263
+ }
1264
+ canvas {
1265
+ max-width: 100% !important;
1266
+ }
1267
+ }
1268
+
1269
+ .settingsHeader {
1270
+ font-size: 14px !important;
1271
+ font-weight: 500 !important;
1272
+ }
1260
1273
  .hideScroll {
1261
1274
  overflow-anchor: none;
1262
1275
  }
@@ -1272,20 +1285,6 @@ blockquote {
1272
1285
  .hideScroll::-webkit-scrollbar-thumb:hover {
1273
1286
  background: none !important;
1274
1287
  }
1275
- @media (max-width: 899px) {
1276
- .MuiPopover-root {
1277
- z-index: 1302 !important;
1278
- }
1279
-
1280
- canvas {
1281
- max-width: 100% !important;
1282
- }
1283
- }
1284
-
1285
- .settingsHeader {
1286
- font-size: 14px !important;
1287
- font-weight: 500 !important;
1288
- }
1289
1288
 
1290
1289
  .custom-scroll::-webkit-scrollbar {
1291
1290
  height: .6rem;
@@ -162,6 +162,7 @@ const EditorButton = props => {
162
162
  display: "inline-flex",
163
163
  color: "rgba(0, 0, 0, 0.54)",
164
164
  marginBottom: "0px !important",
165
+ ...classes.buttonMoreOption,
165
166
  ...classes.buttonMoreOption3
166
167
  },
167
168
  ...btnProps,
@@ -264,11 +265,12 @@ const EditorButton = props => {
264
265
  ...btnSp,
265
266
  borderStyle: borderStyle || "solid",
266
267
  color: `${textColor || "#FFFFFF"}`,
267
- fontSize: textSize || "inherit",
268
+ fontSize: textSize || "12px",
268
269
  fontFamily: fontFamily || "PoppinsRegular",
269
270
  display: "inline-flex",
270
271
  alignItems: "center",
271
272
  position: "relative",
273
+ lineHeight: 1.43,
272
274
  "& .element-toolbar": {
273
275
  display: "none"
274
276
  },
@@ -402,6 +402,7 @@ const Form = props => {
402
402
  borderStyle: borderStyle || "solid",
403
403
  background: bgColor || "transparent",
404
404
  position: "relative",
405
+ lineHeight: 1.43,
405
406
  ...formSX
406
407
  },
407
408
  ref: formEle,
@@ -171,6 +171,7 @@ const useFreeGridStyles = ({
171
171
  height: "100%",
172
172
  "& .signature-container": {
173
173
  height: "100%",
174
+ LineHeight: 1.43,
174
175
  "& .signature-btn-container": {
175
176
  height: "100%",
176
177
  display: "flex",
@@ -39,7 +39,8 @@ const CheckList = ({
39
39
  display: "flex",
40
40
  justifyContent: "center",
41
41
  alignItems: "center",
42
- ...(style || {})
42
+ ...(style || {}),
43
+ lineHeight: 1.43
43
44
  },
44
45
  children: [/*#__PURE__*/_jsxs("div", {
45
46
  contentEditable: false,
@@ -44,11 +44,12 @@ const SearchAttachment = props => {
44
44
  maxWidth: '250px',
45
45
  padding: "0px 10px",
46
46
  boxShadow: "none",
47
- border: `1px solid ${theme?.palette?.primary?.slashBrainBorder} !important`,
47
+ border: `1px solid ${theme?.palette?.primary?.slashBrainBorder}`,
48
48
  borderRadius: "7px !important",
49
- background: `${theme?.palette?.containers?.slashBrainCardBg} !important`,
49
+ background: theme?.palette?.containers?.slashBrainCardBg,
50
50
  cursor: 'pointer',
51
51
  margin: '4px 0px',
52
+ lineHeight: 1.43,
52
53
  "&.MuiPaper-root.MuiPaper-rounded": {
53
54
  borderRadius: "7px !important",
54
55
  paddingTop: '0px !important'
@@ -5,6 +5,7 @@ import { getPageSettings } from "../../utils/pageSettings";
5
5
  import { isTextSelected } from "../../utils/helper";
6
6
  import { useEditorContext } from "../../hooks/useMouseMove";
7
7
  import SimpleTextStyle from "./style";
8
+ import { getBreakpointLineSpacing } from "../../helper/theme";
8
9
  import { jsx as _jsx } from "react/jsx-runtime";
9
10
  import { Fragment as _Fragment } from "react/jsx-runtime";
10
11
  import { jsxs as _jsxs } from "react/jsx-runtime";
@@ -33,8 +34,14 @@ const SimpleText = props => {
33
34
  const {
34
35
  pageColor
35
36
  } = pageSt?.pageProps || {};
37
+ const {
38
+ activeBreakPoint
39
+ } = useEditorContext();
40
+ const lineHeight = element?.children[0]?.lineHeight;
41
+ const lineH = getBreakpointLineSpacing(lineHeight, activeBreakPoint);
36
42
  const classes = SimpleTextStyle({
37
- pageColor: pageColor || theme?.palette?.editor?.background || "#FFFFFF"
43
+ pageColor: pageColor || theme?.palette?.editor?.background || "#FFFFFF",
44
+ lineHeight: lineH
38
45
  });
39
46
  const selected = useSelected();
40
47
  const path = ReactEditor.findPath(editor, element);
@@ -1,10 +1,12 @@
1
1
  import { invertColor } from "../../helper";
2
2
  const SimpleTextStyle = ({
3
- pageColor
3
+ pageColor,
4
+ lineHeight
4
5
  }) => ({
5
6
  root: {
6
7
  position: "relative",
7
8
  padding: "0px",
9
+ lineHeight: lineHeight,
8
10
  "&.dataView": {
9
11
  "& .placeholder-simple-text": {
10
12
  opacity: 0
@@ -33,6 +35,8 @@ const SimpleTextStyle = ({
33
35
  height: "24px",
34
36
  overflow: "hidden",
35
37
  fontSize: "14px",
38
+ display: "inline-flex",
39
+ alignItems: "center",
36
40
  "& .bg-pad-sl": {
37
41
  padding: "2px 4px 2px 4px",
38
42
  background: "transparent",
@@ -288,32 +288,36 @@ const TableCell = props => {
288
288
  Transforms.select(editor, selection);
289
289
  };
290
290
  const onRowDrag = () => {
291
- const {
292
- children
293
- } = rowNode[0] || {};
294
- const rowPath = rowNode[1] || [];
295
- const rowStartCell = [...rowPath, 0];
296
- const rowEndCell = [...rowPath, children?.length - 1];
297
- updateTableSelection({
298
- startCellPath: rowStartCell,
299
- endCellPath: rowEndCell,
300
- isDragging: false
301
- });
302
- selectCurrentCell();
291
+ if (rowNode) {
292
+ const {
293
+ children
294
+ } = rowNode[0] || {};
295
+ const rowPath = rowNode[1] || [];
296
+ const rowStartCell = [...rowPath, 0];
297
+ const rowEndCell = [...rowPath, children?.length - 1];
298
+ updateTableSelection({
299
+ startCellPath: rowStartCell,
300
+ endCellPath: rowEndCell,
301
+ isDragging: false
302
+ });
303
+ selectCurrentCell();
304
+ }
303
305
  };
304
306
  const onColDrag = () => {
305
- const [tableData, tablePath] = tableNode;
306
- const {
307
- rows
308
- } = tableData;
309
- const startColCell = [...tablePath, 0, column];
310
- const endColCell = [...tablePath, rows - 1, column];
311
- updateTableSelection({
312
- startCellPath: startColCell,
313
- endCellPath: endColCell,
314
- isDragging: false
315
- });
316
- selectCurrentCell();
307
+ if (tableNode) {
308
+ const [tableData, tablePath] = tableNode;
309
+ const {
310
+ rows
311
+ } = tableData;
312
+ const startColCell = [...tablePath, 0, column];
313
+ const endColCell = [...tablePath, rows - 1, column];
314
+ updateTableSelection({
315
+ startCellPath: startColCell,
316
+ endCellPath: endColCell,
317
+ isDragging: false
318
+ });
319
+ selectCurrentCell();
320
+ }
317
321
  };
318
322
  const handleToolAction = (value, option, dragType) => {
319
323
  const isRowDrag = dragType === "row";
@@ -1,12 +1,24 @@
1
1
  import React from "react";
2
+ import { Text } from "slate";
2
3
  import { jsx as _jsx } from "react/jsx-runtime";
4
+ const isEmptyTextNode = node => {
5
+ if (Text.isText(node)) {
6
+ return !node.text.trim();
7
+ }
8
+ return false;
9
+ };
3
10
  const Title = props => {
4
11
  const {
12
+ element,
5
13
  attributes,
6
- children
14
+ children,
15
+ customProps
7
16
  } = props;
17
+ const isEmpty = !customProps?.readOnly && isEmptyTextNode(element?.children[0]) ? "empty" : "";
8
18
  return /*#__PURE__*/_jsx("div", {
9
19
  ...attributes,
20
+ placeholder: "Title",
21
+ className: `content-editable ${isEmpty}`,
10
22
  style: {
11
23
  fontWeight: "bold",
12
24
  fontSize: "20px"
@@ -301,9 +301,6 @@ const editorStyles = ({
301
301
  "& .editor-wrapper": {
302
302
  paddingTop: '20px'
303
303
  },
304
- "& .MuiDialog-paper, & .MuiPopover-paper": {
305
- background: `${theme?.palette?.editor?.background} !important`
306
- },
307
304
  "& .MuiPaper-root": {
308
305
  borderRadius: "0px !important",
309
306
  "& .MuiDialogTitle-root": {
@@ -98,12 +98,22 @@ const AddTemplates = props => {
98
98
  setCategory(newValue);
99
99
  setFilteredTemplates(templates.filter(f => f.category === newValue));
100
100
  };
101
- const onSelectTemplate = card => () => {
101
+ const onSelectTemplate = card => async () => {
102
102
  try {
103
- editor.insertNode(JSON.parse(card.content));
103
+ const {
104
+ data
105
+ } = await services("templateContent", {
106
+ id: card?.id
107
+ });
108
+ const content = data?.content;
109
+ if (content) {
110
+ editor.insertNode(JSON.parse(content));
111
+ } else {
112
+ console.log("No data found");
113
+ }
104
114
  onClose();
105
115
  } catch (err) {
106
- console.log(err);
116
+ console.log("Error inserting template content into editor:", err);
107
117
  }
108
118
  };
109
119
  const filterByTitle = f => {
@@ -185,6 +185,11 @@ const usePopupStyle = theme => ({
185
185
  justifyContent: "start",
186
186
  borderRadius: "10px !important",
187
187
  transition: "background-color 0.3s ease",
188
+ // "& .colorBoxElementIcon": {
189
+ // "& path": {
190
+ // fill: theme?.palette?.type === "dark" ? "none" : "",
191
+ // },
192
+ // },
188
193
  "& .signatureElementIcon": {
189
194
  "& path": {
190
195
  fill: `${theme?.palette?.editor?.closeButtonSvgStroke}`
@@ -411,6 +416,11 @@ const usePopupStyle = theme => ({
411
416
  "& .MuiOutlinedInput-notchedOutline": {
412
417
  border: `1px solid ${theme?.palette?.editor?.inputFieldBorder} !important`
413
418
  },
419
+ '& .MuiInputBase-root': {
420
+ '& input': {
421
+ border: "none !important"
422
+ }
423
+ },
414
424
  "& svg": {
415
425
  width: "20px",
416
426
  height: "24px"
@@ -47,7 +47,7 @@ const TemplateCard = props => {
47
47
  }), /*#__PURE__*/_jsx(CardMedia, {
48
48
  className: `template-card-media ${fullScreen ? "fullscreen" : ""}`,
49
49
  component: "div",
50
- image: m?.thumbnail,
50
+ image: m?.compressedThum || m?.thumbnail,
51
51
  alt: m?.title,
52
52
  sx: classes.templateCardMedia
53
53
  }), /*#__PURE__*/_jsx(PreviewAndSelect, {
@@ -14,6 +14,8 @@ import SelectSuperSubscript from "./MiniTextFormat/SelectSuperSubscript";
14
14
  import { ColorResetIcon, TextDefaultStyleIcon } from "../../common/iconListV2";
15
15
  import FontFamilyAutocomplete from "../FormatTools/FontFamilyAutocomplete";
16
16
  import { useEditorContext } from "../../hooks/useMouseMove";
17
+ import LineSpacing from "../../common/StyleBuilder/fieldTypes/lineSpacing";
18
+ import { getPageSettings } from "../../utils/pageSettings";
17
19
  import { jsx as _jsx } from "react/jsx-runtime";
18
20
  import { jsxs as _jsxs } from "react/jsx-runtime";
19
21
  const allTools = toolbarGroups.flat();
@@ -31,10 +33,18 @@ const TextFormat = props => {
31
33
  const [anchorEl, setAnchorEl] = useState(null);
32
34
  const [type, setType] = useState(null);
33
35
  const open = Boolean(anchorEl);
36
+ const {
37
+ element: pageSt
38
+ } = getPageSettings(editor) || {};
39
+ const pageSettingLine = pageSt?.pageProps?.lineHeight;
34
40
  const {
35
41
  fontFamilies,
36
42
  theme
37
43
  } = useEditorContext();
44
+ const {
45
+ activeBreakPoint
46
+ } = useEditorContext();
47
+ const breakpoint = activeBreakPoint === "" ? "lg" : activeBreakPoint;
38
48
  const fontWeight = allTools.find(f => f.format === "fontWeight");
39
49
  const fontStyle = allTools.filter(f => f.type === "mark" && f.format !== "strikethrough" && f.format !== "superscript" && f.format !== "subscript");
40
50
  const fontAlign = allTools.filter(f => f.format?.indexOf("align") >= 0);
@@ -51,6 +61,8 @@ const TextFormat = props => {
51
61
  color: "",
52
62
  bgColor: ""
53
63
  };
64
+ let lineSpacingValue = activeMark(editor, 'lineHeight');
65
+ lineSpacingValue = lineSpacingValue?.[breakpoint] !== undefined ? lineSpacingValue : pageSettingLine;
54
66
  const handleColorPicker = type => e => {
55
67
  setType(type);
56
68
  setAnchorEl(e.currentTarget);
@@ -91,6 +103,13 @@ const TextFormat = props => {
91
103
  value
92
104
  });
93
105
  };
106
+ const handleLineSpacing = data => {
107
+ const [[format, value]] = Object.entries(data);
108
+ addMarkData(editor, {
109
+ format,
110
+ value
111
+ });
112
+ };
94
113
  return /*#__PURE__*/_jsxs(Grid, {
95
114
  container: true,
96
115
  sx: classes.textFormatWrapper,
@@ -360,6 +379,32 @@ const TextFormat = props => {
360
379
  xs: 12,
361
380
  sx: classes.dividerGrid,
362
381
  children: /*#__PURE__*/_jsx(Divider, {})
382
+ }), /*#__PURE__*/_jsxs(Grid, {
383
+ item: true,
384
+ xs: 12,
385
+ children: [/*#__PURE__*/_jsx(Typography, {
386
+ variant: "body1",
387
+ color: "primary",
388
+ sx: classes.typoLabel,
389
+ children: "Line Spacing"
390
+ }), /*#__PURE__*/_jsx(Grid, {
391
+ item: true,
392
+ xs: 12,
393
+ className: "typo-icons",
394
+ sx: classes.evenSpace,
395
+ children: /*#__PURE__*/_jsx(LineSpacing, {
396
+ value: lineSpacingValue,
397
+ onChange: handleLineSpacing,
398
+ data: {
399
+ key: 'lineHeight'
400
+ }
401
+ })
402
+ })]
403
+ }), /*#__PURE__*/_jsx(Grid, {
404
+ item: true,
405
+ xs: 12,
406
+ sx: classes.dividerGrid,
407
+ children: /*#__PURE__*/_jsx(Divider, {})
363
408
  }), /*#__PURE__*/_jsx(Grid, {
364
409
  item: true,
365
410
  xs: 12,
@@ -41,9 +41,9 @@ const FontLoader = props => {
41
41
  // Retry loading the same batch
42
42
  loadNextBatch();
43
43
  } else {
44
- console.log(
45
- // `Max retries reached for batch: ${batch}. Moving to the next batch.`
46
- );
44
+ // console.log(
45
+ // `Max retries reached for batch: ${batch}. Moving to the next batch.`
46
+ // );
47
47
  currentIndex += batchSize;
48
48
  retryCount = 0; // Reset retry count for the next batch
49
49
  loadNextBatch();
@@ -67,7 +67,7 @@ const FontLoader = props => {
67
67
  });
68
68
  loadFontsInBatches(families);
69
69
  }).catch(err => {
70
- console.log(err);
70
+ // console.log(err);
71
71
  });
72
72
  } else {
73
73
  function correctFontArray(fontString) {
@@ -3,6 +3,7 @@ const usePopupStyles = theme => ({
3
3
  position: "absolute",
4
4
  zIndex: 1300,
5
5
  borderRadius: "10px",
6
+ // padding: "0px",
6
7
  boxShadow: "0px 4px 10px 0px #00000029",
7
8
  overflow: "hidden",
8
9
  // padding: "8px 0px !important",
@@ -62,6 +62,7 @@ const FormSettings = props => {
62
62
  MuiAccordion: {
63
63
  styleOverrides: {
64
64
  root: {
65
+ background: theme?.palette?.editor?.miniToolBarBackground,
65
66
  "& .MuiAccordionSummary-root": {
66
67
  flexDirection: "row-reverse",
67
68
  "& .MuiSvgIcon-root": {
@@ -3,24 +3,35 @@ import PersonalVideoIcon from "@mui/icons-material/PersonalVideo";
3
3
  import PhoneIphoneIcon from "@mui/icons-material/PhoneIphone";
4
4
  import useSwitchViewport from "./styles";
5
5
  import { useEffect } from "react";
6
+ import { useEditorContext } from "../../../hooks/useMouseMove";
6
7
  import { jsx as _jsx } from "react/jsx-runtime";
7
8
  import { jsxs as _jsxs } from "react/jsx-runtime";
8
9
  const SwitchViewport = props => {
9
10
  const {
10
11
  breakpoint,
11
- onChange
12
+ onChange,
13
+ show
12
14
  } = props;
13
15
  const classes = useSwitchViewport();
16
+ const {
17
+ setSelectedElement,
18
+ setActiveBreakPoint
19
+ } = useEditorContext();
14
20
  useEffect(() => {
15
- console.log(breakpoint);
21
+ // to reset selection on viewport changes - FS-6589
22
+ setSelectedElement({});
16
23
  }, [breakpoint]);
17
24
  return /*#__PURE__*/_jsxs(Box, {
18
25
  sx: classes.root,
26
+ style: {
27
+ display: show ? "block" : "none"
28
+ },
19
29
  children: [/*#__PURE__*/_jsx(Tooltip, {
20
30
  title: "Desktop View",
21
31
  children: /*#__PURE__*/_jsx(IconButton, {
22
32
  className: `${!breakpoint || breakpoint === "lg" ? "active" : ""}`,
23
33
  onClick: () => {
34
+ setActiveBreakPoint("");
24
35
  onChange("");
25
36
  },
26
37
  children: /*#__PURE__*/_jsx(PersonalVideoIcon, {})
@@ -30,6 +41,7 @@ const SwitchViewport = props => {
30
41
  children: /*#__PURE__*/_jsx(IconButton, {
31
42
  className: `${breakpoint === "xs" ? "active" : ""}`,
32
43
  onClick: () => {
44
+ setActiveBreakPoint("xs");
33
45
  onChange("xs");
34
46
  },
35
47
  children: /*#__PURE__*/_jsx(PhoneIphoneIcon, {})
@@ -1,5 +1,6 @@
1
1
  import { Transforms, Node, Path } from "slate";
2
2
  import { ReactEditor } from "slate-react";
3
+ import { handleNegativeInteger } from "../../../utils/helper";
3
4
  export const ROW_HEIGHT = 50;
4
5
  const MARGIN_OF = {
5
6
  xs: 160,
@@ -75,7 +76,7 @@ const reRenderChildNodes = (editor, path) => {
75
76
  console.log(err);
76
77
  }
77
78
  };
78
- function isContainerElement(editor, moveTopath, props) {
79
+ function isContainerElement(editor, moveTopath, props, appenBp) {
79
80
  try {
80
81
  const {
81
82
  path,
@@ -91,21 +92,32 @@ function isContainerElement(editor, moveTopath, props) {
91
92
  parentNode = Node.get(editor, Path.parent(dragItemPath));
92
93
  }
93
94
  const moveToNode = Node.get(editor, moveTopath);
95
+ const leftOfMoveToNode = moveToNode[`left${appenBp}`];
94
96
  if (moveToNode.type === "freegridBox") {
95
97
  if (parentNode.type === "freegridBox") {
96
98
  // same box
97
99
  if (parentPath === dragOver) {
98
100
  return props.calX;
99
101
  } else {
102
+ const moveToDom = ReactEditor.toDOMNode(editor, moveToNode);
103
+ const {
104
+ left
105
+ } = moveToDom?.getBoundingClientRect() || {};
106
+ const borderLeftWidth = getBorderWidth(moveToDom, "borderLeftWidth");
107
+
100
108
  // for different box
101
- return parseInt(props.x - window.innerWidth / 2 + MARGIN_OF[props.breakpoint] - props.diffX - moveToNode.left);
109
+ return parseInt(props.x - props.diffX - left - borderLeftWidth);
102
110
  }
103
111
  } else {
104
- return props.calX - moveToNode?.left;
112
+ return props.calX - leftOfMoveToNode;
105
113
  }
106
114
  } else if (moveToNode.type === "freegrid") {
107
115
  if (parentNode.type === "freegridBox") {
108
- return parseInt(props.x - window.innerWidth / 2 + MARGIN_OF[props.breakpoint] - props.diffX);
116
+ const boundaryLineEle = document.querySelector(".rnd-guideline-lv");
117
+ const {
118
+ left
119
+ } = boundaryLineEle?.getBoundingClientRect() || {};
120
+ return parseInt(props.x - props.diffX - left);
109
121
  } else {
110
122
  return props.calX;
111
123
  }
@@ -133,14 +145,17 @@ export function onDropItem(props, parentClass) {
133
145
  const from = parentPath.split("|").map(m => parseInt(m));
134
146
  let newPath = [];
135
147
  newPath = moveTo;
136
- const cCalx = isContainerElement(editor, moveTo, props);
148
+ const appenBp = breakpoint === "lg" ? "" : `_${breakpoint}`;
149
+ const cCalx = isContainerElement(editor, moveTo, props, appenBp);
150
+
137
151
  // const posX = parseInt(
138
152
  // cx - window.innerWidth / 2 + MARGIN_OF[breakpoint] - diffX
139
153
  // );
140
154
  const toSectionNode = Node.get(editor, newPath);
141
155
  const addToSectionDOM = ReactEditor.toDOMNode(editor, toSectionNode);
156
+ const borderTopWidth = getBorderWidth(addToSectionDOM, "borderTopWidth");
142
157
  const rect = addToSectionDOM.getBoundingClientRect();
143
- const y = endPosition.y - startPosition.diffY - rect.top;
158
+ const y = handleNegativeInteger(endPosition.y - startPosition.diffY - rect.top - borderTopWidth);
144
159
 
145
160
  // Calculate grid position
146
161
  const row = Math.floor(y / ROW_HEIGHT) + 1;
@@ -150,7 +165,6 @@ export function onDropItem(props, parentClass) {
150
165
 
151
166
  // Update grid area
152
167
  const gridArea = `${row} / 1 / ${row + 1} / 2`;
153
- const appenBp = breakpoint === "lg" ? "" : `_${breakpoint}`;
154
168
  Transforms.setNodes(editor, {
155
169
  [`gridArea${appenBp}`]: gridArea,
156
170
  [`left${appenBp}`]: cCalx,
@@ -188,4 +202,9 @@ export function onDropItem(props, parentClass) {
188
202
  export function calculateGridArea(y) {
189
203
  const row = Math.floor(y / ROW_HEIGHT) + 1;
190
204
  return `${row} / 1 / ${row + 1} / 2`;
205
+ }
206
+ export function getBorderWidth(dom, property) {
207
+ const styles = getComputedStyle(dom);
208
+ const borderWidth = parseFloat(styles[property]);
209
+ return borderWidth;
191
210
  }
@@ -73,6 +73,11 @@ const BackgroundImage = props => {
73
73
  children: "REMOVE"
74
74
  }) : /*#__PURE__*/_jsx(Grid, {
75
75
  className: "uploadImageText",
76
+ sx: {
77
+ padding: 0,
78
+ background: `${theme?.palette?.editor?.inputFieldBgColor}`,
79
+ border: `1px solid ${theme?.palette?.editor?.inputFieldBorder}`
80
+ },
76
81
  children: /*#__PURE__*/_jsxs(Button, {
77
82
  component: "label",
78
83
  variant: "text",
@@ -1,6 +1,7 @@
1
1
  import { Box, Card, Checkbox, FormControlLabel, Grid, Tooltip, Typography } from "@mui/material";
2
2
  import React from "react";
3
3
  import Icon from "../../Icon";
4
+ import { useEditorContext } from "../../../hooks/useMouseMove";
4
5
  import { jsx as _jsx } from "react/jsx-runtime";
5
6
  import { Fragment as _Fragment } from "react/jsx-runtime";
6
7
  import { jsxs as _jsxs } from "react/jsx-runtime";
@@ -15,7 +16,10 @@ const RenderCard = ({
15
16
  return /*#__PURE__*/_jsx(Card, {
16
17
  sx: {
17
18
  position: 'relative',
18
- padding: "10px"
19
+ padding: "10px",
20
+ '& .MuiCheckbox-root svg': {
21
+ fill: 'unset !important'
22
+ }
19
23
  },
20
24
  children: /*#__PURE__*/_jsx(FormControlLabel, {
21
25
  control: /*#__PURE__*/_jsx(Checkbox, {
@@ -81,6 +85,9 @@ const CardsMapping = props => {
81
85
  selectedCard,
82
86
  infoIcon
83
87
  } = data;
88
+ const {
89
+ theme
90
+ } = useEditorContext();
84
91
  const activeCard = value === selectedCard;
85
92
  const handleChange = e => {
86
93
  if (selectedCard === data?.value) {
@@ -99,7 +106,8 @@ const CardsMapping = props => {
99
106
  sx: {
100
107
  marginBottom: "12px",
101
108
  "& .MuiPaper-root": {
102
- border: activeCard ? "1px solid #2563EB" : "1px solid #C8D8FA",
109
+ background: theme?.palette?.editor?.miniToolBarBackground,
110
+ border: activeCard ? "1px solid #2563EB" : `1px solid ${theme?.palette?.editor?.inputFieldBorder}`,
103
111
  borderRadius: "8px",
104
112
  boxShadow: activeCard ? "0px 4px 16px 0px #2563EB40" : "unset"
105
113
  }
@@ -18,6 +18,7 @@ import FontSize from "./fontSize";
18
18
  import SelectSwitch from "./selectSwitch";
19
19
  import CardsMapping from "./card";
20
20
  import MetaDataMapping from "./metaDataMapping";
21
+ import LineSpacing from "./lineSpacing";
21
22
  const FieldMap = {
22
23
  text: Text,
23
24
  bannerSpacing: BannerSpacing,
@@ -38,6 +39,7 @@ const FieldMap = {
38
39
  fontSize: FontSize,
39
40
  selectSwitch: SelectSwitch,
40
41
  card: CardsMapping,
41
- metadatamapping: MetaDataMapping
42
+ metadatamapping: MetaDataMapping,
43
+ lineSpacing: LineSpacing
42
44
  };
43
45
  export default FieldMap;
@@ -0,0 +1,79 @@
1
+ import React, { useState } from "react";
2
+ import { Grid, Slider, Typography, Box } from "@mui/material";
3
+ import { getBreakPointsValue } from "../../../helper/theme";
4
+ import useWindowResize from "../../../hooks/useWindowResize";
5
+ import { useEditorContext } from "../../../hooks/useMouseMove";
6
+ import { jsx as _jsx } from "react/jsx-runtime";
7
+ import { jsxs as _jsxs } from "react/jsx-runtime";
8
+ const LineSpacing = props => {
9
+ const {
10
+ value: val,
11
+ data,
12
+ onChange
13
+ } = props;
14
+ const {
15
+ theme
16
+ } = useEditorContext();
17
+ const {
18
+ key
19
+ } = data;
20
+ const [size] = useWindowResize();
21
+ const pro_value = getBreakPointsValue(val, size?.device);
22
+ const [value, setValue] = useState(pro_value);
23
+ let breakpointValue = getBreakPointsValue(val, null);
24
+ breakpointValue = typeof breakpointValue['lg'] === 'object' ? breakpointValue['lg'] : breakpointValue;
25
+ useState(() => {
26
+ setValue(pro_value);
27
+ }, [pro_value]);
28
+ const handleChange = e => {
29
+ onChange({
30
+ [key]: {
31
+ ...breakpointValue,
32
+ [size?.device]: e.target.value
33
+ }
34
+ });
35
+ };
36
+ return /*#__PURE__*/_jsxs(Grid, {
37
+ item: true,
38
+ xs: 12,
39
+ children: [/*#__PURE__*/_jsx(Typography, {
40
+ variant: "body1",
41
+ color: "primary",
42
+ style: {
43
+ fontSize: "14px",
44
+ fontWeight: 500
45
+ },
46
+ children: data?.label
47
+ }), /*#__PURE__*/_jsxs(Grid, {
48
+ container: true,
49
+ wrap: "nowrap",
50
+ className: "sld-wrpr",
51
+ children: [/*#__PURE__*/_jsx(Slider, {
52
+ className: "spacingSlider",
53
+ defaultValue: value || 1.43,
54
+ "aria-label": "Default",
55
+ valueLabelDisplay: "auto",
56
+ min: 0.5,
57
+ max: 3.0,
58
+ step: 0.1,
59
+ name: "lineHeight",
60
+ onChange: handleChange
61
+ }), /*#__PURE__*/_jsx(Box, {
62
+ component: "input",
63
+ sx: {
64
+ background: theme?.palette?.editor?.background,
65
+ color: theme?.palette?.editor?.textColor
66
+ },
67
+ name: "lineHeight",
68
+ value: pro_value,
69
+ className: "sliderInput",
70
+ onChange: handleChange,
71
+ type: "number",
72
+ placeholder: "0",
73
+ disabled: true,
74
+ defaultValue: pro_value || 1.43
75
+ })]
76
+ })]
77
+ });
78
+ };
79
+ export default LineSpacing;
@@ -25,6 +25,10 @@ const pageSettingsStyle = [{
25
25
  label: "Padding",
26
26
  key: "bannerSpacing",
27
27
  type: "bannerSpacing"
28
+ }, {
29
+ label: "Line Spacing",
30
+ key: "lineHeight",
31
+ type: "lineSpacing"
28
32
  }]
29
33
  }, {
30
34
  tab: "Max Width",
@@ -4,6 +4,7 @@ import { convertBase64 } from "../utils/helper";
4
4
  import { uploadFile } from "../service/fileupload";
5
5
  import Icon from "./Icon";
6
6
  import UploadStyles from "../common/ImageSelector/UploadStyles";
7
+ import { useEditorContext } from "../hooks/useMouseMove";
7
8
  import { jsx as _jsx } from "react/jsx-runtime";
8
9
  import { Fragment as _Fragment } from "react/jsx-runtime";
9
10
  import { jsxs as _jsxs } from "react/jsx-runtime";
@@ -18,6 +19,9 @@ const Uploader = props => {
18
19
  const [base64, setBase64] = useState(value?.url);
19
20
  const [fileName, setFileName] = useState("");
20
21
  const [uploading, setUploading] = useState(false);
22
+ const {
23
+ theme
24
+ } = useEditorContext();
21
25
  const handleChange = async e => {
22
26
  const uFile = e.target.files[0];
23
27
  const strImage = await convertBase64(uFile);
@@ -99,6 +103,10 @@ const Uploader = props => {
99
103
  className: "uploadImageSection",
100
104
  children: base64 ? renderThumb() : /*#__PURE__*/_jsx(Grid, {
101
105
  className: "uploadImageText",
106
+ sx: {
107
+ background: `${theme?.palette?.editor?.inputFieldBgColor}`,
108
+ border: `1px solid ${theme?.palette?.editor?.inputFieldBorder}`
109
+ },
102
110
  children: /*#__PURE__*/_jsxs(Button, {
103
111
  component: "label",
104
112
  variant: "text",
@@ -464,10 +464,6 @@ const useCommonStyle = theme => ({
464
464
  }
465
465
  }
466
466
  },
467
- pageSettingPopUpRoot: {
468
- padding: "16px 8px 16px 10px!important",
469
- height: "100%"
470
- },
471
467
  buttonMoreOption: {
472
468
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
473
469
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
@@ -480,6 +476,10 @@ const useCommonStyle = theme => ({
480
476
  }
481
477
  }
482
478
  },
479
+ pageSettingPopUpRoot: {
480
+ padding: "16px 8px 16px 10px!important",
481
+ height: "100%"
482
+ },
483
483
  buttonMoreOption2: {
484
484
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
485
485
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
@@ -337,14 +337,14 @@ export const isCarouselSelected = editor => {
337
337
  return false;
338
338
  }
339
339
  const [nodeEntry] = Editor.nodes(editor, {
340
- match: n => !Editor.isEditor(n) && Element.isElement(n) && n.type === 'carousel'
340
+ match: n => !Editor.isEditor(n) && Element.isElement(n) && n.type === "carousel"
341
341
  });
342
342
  if (!nodeEntry) {
343
343
  return false;
344
344
  }
345
345
  const [node] = nodeEntry;
346
346
  const carouselDom = ReactEditor.toDOMNode(editor, node);
347
- const isEdit = carouselDom.classList.contains('carousel_slider_edit');
347
+ const isEdit = carouselDom.classList.contains("carousel_slider_edit");
348
348
  return !isEdit;
349
349
  } catch (err) {
350
350
  console.log(err);
@@ -161,4 +161,27 @@ export const groupByBreakpoint = (styleProps, theme) => {
161
161
  }
162
162
  };
163
163
  };
164
- export const getCustomizationValue = value => isNaN(parseInt(value)) ? null : parseInt(value);
164
+ export const getCustomizationValue = value => isNaN(parseInt(value)) ? null : parseInt(value);
165
+ export const getBreakpointLineSpacing = (value, breakpoint) => {
166
+ try {
167
+ const values = getBreakPointsValue(value, breakpoint);
168
+ const cssVal = BREAKPOINTS_DEVICES.reduce((a, b) => {
169
+ if (values[b] || values["lg"]) {
170
+ const value = values[b] || values["lg"];
171
+ return {
172
+ ...a,
173
+ [b]: value
174
+ };
175
+ } else {
176
+ return a;
177
+ }
178
+ }, {});
179
+ if (breakpoint) {
180
+ return value[breakpoint] || value["lg"] || value;
181
+ } else {
182
+ return cssVal["lg"];
183
+ }
184
+ } catch (err) {
185
+ // console.log(err);
186
+ }
187
+ };
@@ -35,6 +35,7 @@ export const EditorProvider = ({
35
35
  path: null
36
36
  });
37
37
  const [fontFamilies, setFontFamilies] = useState({});
38
+ const [activeBreakPoint, setActiveBreakPoint] = useState("");
38
39
  useEffect(() => {
39
40
  window.updateSelectedItem = d => {
40
41
  setSelectedElement(d);
@@ -97,8 +98,10 @@ export const EditorProvider = ({
97
98
  setOpenAI,
98
99
  updateDragging,
99
100
  fontFamilies,
100
- setFontFamilies
101
- }), [path, editor?.selection, selectedPath, selectedElement, contextMenu, openAI, popupType, drop]);
101
+ setFontFamilies,
102
+ activeBreakPoint,
103
+ setActiveBreakPoint
104
+ }), [path, editor?.selection, selectedPath, selectedElement, contextMenu, openAI, popupType, drop, activeBreakPoint]);
102
105
  return /*#__PURE__*/_jsx(EditorContext.Provider, {
103
106
  value: otherValues,
104
107
  children: children
@@ -314,7 +314,8 @@ export const getBlock = props => {
314
314
  borderRadius: `${element?.color ? "0px" : "12px"} 12px 12px ${element?.color ? "0px" : "12px"}`,
315
315
  margin: `${element?.bgColor ? "16px" : "0px"} 0px`,
316
316
  width: element?.bgColor ? "calc(100% - 16px)" : "100%",
317
- borderWidth: element?.color ? "0px 0px 0px 3px" : "0px"
317
+ borderWidth: element?.color ? "0px 0px 0px 3px" : "0px",
318
+ lineHeight: 1.43
318
319
  },
319
320
  children: children
320
321
  });
@@ -374,6 +375,9 @@ export const getBlock = props => {
374
375
  });
375
376
  case "orderedList":
376
377
  return /*#__PURE__*/_jsx("ol", {
378
+ style: {
379
+ lineHeight: 1.43
380
+ },
377
381
  className: "listItemMargin",
378
382
  type: "1",
379
383
  ...attributes,
@@ -381,6 +385,9 @@ export const getBlock = props => {
381
385
  });
382
386
  case "unorderedList":
383
387
  return /*#__PURE__*/_jsx("ul", {
388
+ style: {
389
+ lineHeight: 1.43
390
+ },
384
391
  className: "listItemMargin",
385
392
  ...attributes,
386
393
  children: children
@@ -20,10 +20,10 @@ export const insertButton = editor => {
20
20
  bottomRight: 30
21
21
  },
22
22
  bannerSpacing: {
23
- left: 16,
24
- top: 8,
25
- right: 16,
26
- bottom: 8
23
+ left: 24,
24
+ top: 10,
25
+ right: 24,
26
+ bottom: 10
27
27
  },
28
28
  ...(windowVar.lastButtonProps || {})
29
29
  };
@@ -82,7 +82,8 @@ const splitInlineStyleRanges = (text, inlineStyleRanges, data) => {
82
82
  };
83
83
  export const draftToSlate = props => {
84
84
  const {
85
- data
85
+ data,
86
+ needLayout
86
87
  } = props;
87
88
  if (data?.blocks && data?.blocks?.length > 0) {
88
89
  const converted = data?.blocks?.reduce((a, b) => {
@@ -104,7 +105,7 @@ export const draftToSlate = props => {
104
105
  return data;
105
106
  } else {
106
107
  return [{
107
- type: "paragraph",
108
+ type: needLayout ? "title" : "paragraph",
108
109
  children: [{
109
110
  text: ""
110
111
  }]
@@ -624,6 +624,10 @@ export const isPageSettings = (event, editor) => {
624
624
  return isPageSettingsNode;
625
625
  }
626
626
  };
627
+ export function capitalizeFirstLetter(str) {
628
+ if (!str) return str;
629
+ return str.charAt(0).toUpperCase() + str.slice(1);
630
+ }
627
631
  export const insertLineBreakAtEndOfPath = (editor, path) => {
628
632
  try {
629
633
  const [node, nodePath] = Editor.node(editor, path); // Get the node at the specified path
@@ -642,6 +646,13 @@ export const insertLineBreakAtEndOfPath = (editor, path) => {
642
646
  console.log(err);
643
647
  }
644
648
  };
649
+ export function isHavingSelection(editor) {
650
+ try {
651
+ return editor?.selection && !Range.isCollapsed(editor.selection);
652
+ } catch (err) {
653
+ console.log(err);
654
+ }
655
+ }
645
656
  const omitNodes = ["site-settings", "page-settings"];
646
657
  export function getInitialValue(value = [], readOnly) {
647
658
  if (readOnly === "readonly" && value?.length) {
@@ -670,20 +681,17 @@ export function getInitialValue(value = [], readOnly) {
670
681
  }
671
682
  return value;
672
683
  }
673
- export function capitalizeFirstLetter(str) {
674
- if (!str) return str;
675
- return str.charAt(0).toUpperCase() + str.slice(1);
676
- }
677
- export function isHavingSelection(editor) {
678
- try {
679
- return editor?.selection && !Range.isCollapsed(editor.selection);
680
- } catch (err) {
681
- console.log(err);
682
- }
683
- }
684
684
  export function getSelectedCls(defaultCls = "", selected, selectedClsName = "selected") {
685
685
  return `${defaultCls} ${selected ? selectedClsName : ""}`;
686
686
  }
687
+ export function handleNegativeInteger(val) {
688
+ return val < 0 ? 0 : val;
689
+ }
690
+ export const containsSurrogatePair = text => {
691
+ // Match surrogate pairs (high and low surrogate)
692
+ const surrogatePairRegex = /[\uD800-\uDBFF][\uDC00-\uDFFF]/;
693
+ return surrogatePairRegex.test(text);
694
+ };
687
695
  export const getNodeWithType = (editor, nodeType = "", otherOptions) => {
688
696
  try {
689
697
  const options = {
@@ -697,11 +705,6 @@ export const getNodeWithType = (editor, nodeType = "", otherOptions) => {
697
705
  return [];
698
706
  }
699
707
  };
700
- export const containsSurrogatePair = text => {
701
- // Match surrogate pairs (high and low surrogate)
702
- const surrogatePairRegex = /[\uD800-\uDBFF][\uDC00-\uDFFF]/;
703
- return surrogatePairRegex.test(text);
704
- };
705
708
  export const getSlateDom = (editor, range) => {
706
709
  try {
707
710
  const slateDom = ReactEditor.toDOMRange(editor, range);
@@ -9,7 +9,13 @@ export const findPageSettings = editor => {
9
9
  path: null,
10
10
  element: {
11
11
  pageProps: {
12
- pageWidth: "fixed"
12
+ pageWidth: "fixed",
13
+ "lineHeight": {
14
+ "xs": 1.43,
15
+ "sm": 1.43,
16
+ "md": 1.43,
17
+ "lg": 1.43
18
+ }
13
19
  }
14
20
  }
15
21
  };
@@ -34,7 +40,13 @@ export const getPageSettings = editor => {
34
40
  path: null,
35
41
  element: {
36
42
  pageProps: {
37
- pageWidth: "fixed"
43
+ pageWidth: "fixed",
44
+ "lineHeight": {
45
+ "xs": 1.43,
46
+ "sm": 1.43,
47
+ "md": 1.43,
48
+ "lg": 1.43
49
+ }
38
50
  }
39
51
  }
40
52
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flozy/editor",
3
- "version": "5.6.2",
3
+ "version": "5.6.4",
4
4
  "description": "An Editor for flozy app brain",
5
5
  "files": [
6
6
  "dist"