@flozy/editor 9.6.7 → 9.6.8

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.
@@ -1282,8 +1282,8 @@ blockquote {
1282
1282
  }
1283
1283
  @media (max-width: 899px) {
1284
1284
  /* Qa validation required */
1285
- /* .MuiPopover-root {
1286
- z-index: 1302 !important;
1285
+ /* .MuiPopover-root {
1286
+ z-index: 1302 !important;
1287
1287
  } */
1288
1288
 
1289
1289
  canvas {
@@ -37,6 +37,7 @@ const EditorButton = props => {
37
37
  const [edit, setEdit] = useState(false);
38
38
  const [openNav, setOpenNav] = useState(false);
39
39
  const [openMoreOptions, setOpenMoreOptions] = useState(false);
40
+ const [, setIconLoaded] = useState(false);
40
41
  const classes = useCommonStyle(appTheme);
41
42
  const {
42
43
  label,
@@ -209,6 +210,15 @@ const EditorButton = props => {
209
210
  e.stopPropagation();
210
211
  setOpenMoreOptions(!openMoreOptions);
211
212
  };
213
+ const muiIconProps = {
214
+ iconName: buttonIcon,
215
+ style: {
216
+ paddingLeft: "4px",
217
+ paddingRight: "4px"
218
+ },
219
+ props: customProps,
220
+ onIconLoad: () => setIconLoaded(true)
221
+ };
212
222
  return /*#__PURE__*/_jsxs("div", {
213
223
  className: `editor-btn-wrapper`,
214
224
  ...attributes,
@@ -283,19 +293,9 @@ const EditorButton = props => {
283
293
  },
284
294
  ...buttonProps,
285
295
  children: [BtnIcon && iconPosition === "start" && /*#__PURE__*/_jsx(MUIIcon, {
286
- iconName: buttonIcon,
287
- style: {
288
- paddingLeft: "4px",
289
- paddingRight: "4px"
290
- },
291
- props: customProps
296
+ ...muiIconProps
292
297
  }), label || "My Button", BtnIcon && iconPosition === "end" && /*#__PURE__*/_jsx(MUIIcon, {
293
- iconName: buttonIcon,
294
- style: {
295
- paddingLeft: "4px",
296
- paddingRight: "4px"
297
- },
298
- props: customProps
298
+ ...muiIconProps
299
299
  })]
300
300
  }), !readOnly && buttonRef?.current && /*#__PURE__*/_jsx(Popper, {
301
301
  anchorEl: buttonRef?.current,
@@ -5,7 +5,7 @@ import AspectRatioIcon from "@mui/icons-material/AspectRatio";
5
5
  import useResize from "../../utils/customHooks/useResize";
6
6
  import EmbedPopup from "./EmbedPopup";
7
7
  import { IconButton, Tooltip, Box, useTheme } from "@mui/material";
8
- import { GridSettingsIcon, LinkIcon } from "../../common/iconslist";
8
+ import { LinkIcon } from "../../common/iconslist";
9
9
  import { useEditorContext } from "../../hooks/useMouseMove";
10
10
  import { getTRBLBreakPoints, getBreakPointsValue, groupByBreakpoint } from "../../helper/theme";
11
11
  import Icon from "../../common/Icon";
@@ -32,7 +32,7 @@ const ToolBar = ({
32
32
  top: "-4px",
33
33
  left: topM ? "35px" : "0px",
34
34
  margin: "0px",
35
- gap: '3px'
35
+ gap: "3px"
36
36
  },
37
37
  children: [/*#__PURE__*/_jsx(Tooltip, {
38
38
  title: "Image Settings",
@@ -2,6 +2,7 @@ import React, { useState } from "react";
2
2
  import { Grid, Radio, RadioGroup, Typography, FormControlLabel, Select, MenuItem, FormControl, TextField, Button, Menu } from "@mui/material";
3
3
  import KeyboardArrowDownIcon from "@mui/icons-material/KeyboardArrowDown";
4
4
  import UserInputs from "./UserInputs";
5
+ import { minutes, hours, days } from "./constant";
5
6
  import { jsx as _jsx } from "react/jsx-runtime";
6
7
  import { jsxs as _jsxs } from "react/jsx-runtime";
7
8
  import { Fragment as _Fragment } from "react/jsx-runtime";
@@ -34,7 +35,9 @@ const FormWorkflow = props => {
34
35
  setBodyData(bodyData);
35
36
  };
36
37
  const handleScheduleInstant = event => {
38
+ const scheduleOn = event.target.value === "minutes" ? minutes[0] : event.target.value === "hours" ? hours[0] : days[0];
37
39
  setScheduleEvery(event.target.value);
40
+ setScheduleOn(scheduleOn);
38
41
  };
39
42
  const onHandleChange = event => {
40
43
  setScheduleOn(event.target.value);
@@ -106,14 +109,14 @@ const FormWorkflow = props => {
106
109
  fullWidth: true,
107
110
  size: "small",
108
111
  children: /*#__PURE__*/_jsx(Select, {
109
- value: scheduleOn,
112
+ value: `${scheduleOn}`,
110
113
  onChange: onHandleChange,
111
114
  sx: classes.select,
112
115
  IconComponent: KeyboardArrowDownIcon,
113
116
  children: currentInstant.map((ele, index) => /*#__PURE__*/_jsx(MenuItem, {
114
117
  sx: classes.selectList,
115
- value: ele,
116
- children: ele
118
+ value: `${ele}`,
119
+ children: `${ele}`
117
120
  }, `${ele}_${index}`))
118
121
  })
119
122
  })
@@ -49,9 +49,13 @@ const Workflow = props => {
49
49
  setWorkflowList(workflow || []);
50
50
  }, [workflow]);
51
51
  useEffect(() => {
52
- setScheduleOn(currentInstant[0]);
52
+ if (scheduleOn === `${currentInstant[0]}`) {
53
+ setScheduleOn(currentInstant[0]);
54
+ }
53
55
  }, [currentInstant]);
54
56
  const handleAddFormWorkflow = () => {
57
+ setScheduleEvery("minutes");
58
+ setScheduleOn("30");
55
59
  setFormData(true);
56
60
  };
57
61
  const onFormBack = () => {
@@ -106,6 +110,8 @@ const Workflow = props => {
106
110
  setBodyData(result.body_data);
107
111
  setSubject(result.subject_data);
108
112
  setSchedule(result.schedule_type);
113
+ setScheduleOn(`${result?.schedule_on}`);
114
+ setScheduleEvery(result?.schedule_every);
109
115
  setFormData(true);
110
116
  setFlowEdited({
111
117
  isEdited: true,
@@ -33,17 +33,14 @@ const TextFormat = props => {
33
33
  const [anchorEl, setAnchorEl] = useState(null);
34
34
  const [type, setType] = useState(null);
35
35
  const open = Boolean(anchorEl);
36
- const {
37
- element: pageSt
38
- } = getPageSettings(editor) || {};
36
+
37
+ // const { element: pageSt } = getPageSettings(editor) || {};
39
38
  // const pageSettingLine = pageSt?.pageProps?.lineHeight;
40
39
  const {
41
40
  fontFamilies,
42
41
  theme
43
42
  } = useEditorContext();
44
- const {
45
- activeBreakPoint
46
- } = useEditorContext();
43
+ // const { activeBreakPoint } = useEditorContext();
47
44
  // const breakpoint = activeBreakPoint === "" ? "lg" : activeBreakPoint;
48
45
  const fontWeight = allTools.find(f => f.format === "fontWeight");
49
46
  const fontStyle = allTools.filter(f => f.type === "mark" && f.format !== "strikethrough" && f.format !== "superscript" && f.format !== "subscript");
@@ -14,7 +14,6 @@ import { jsx as _jsx } from "react/jsx-runtime";
14
14
  const PopupTool = props => {
15
15
  const {
16
16
  theme,
17
- setIsTextSelected,
18
17
  customProps,
19
18
  editorWrapper
20
19
  } = props;
@@ -35,6 +34,9 @@ const PopupTool = props => {
35
34
  const [size] = useWindowResize();
36
35
  const updateAnchorEl = isScroll => {
37
36
  try {
37
+ const {
38
+ selection
39
+ } = editor;
38
40
  const isHavingSelection = selection && !Range.isCollapsed(selection);
39
41
  if (isHavingSelection && event === "end") {
40
42
  const domRange = ReactEditor.toDOMRange(editor, editor.selection);
@@ -74,15 +76,16 @@ const PopupTool = props => {
74
76
  if (!isCarouselEdit) {
75
77
  setOpen(true);
76
78
  setPopupType("textFormat");
77
- setIsTextSelected(true);
79
+ // setIsTextSelected(true);
78
80
  }
79
81
  } else if (!anchorEl) {
80
82
  setOpen(false);
81
83
  setPopupType("");
82
- setIsTextSelected(false);
84
+ // setIsTextSelected(false);
83
85
  }
84
86
  }, [event, anchorEl]);
85
87
  useEffect(() => {
88
+ console.log("Editor useEffect", selection);
86
89
  const {
87
90
  path,
88
91
  enable
@@ -92,17 +95,20 @@ const PopupTool = props => {
92
95
  if (!selection || Range.isCollapsed(selection) || Editor.string(editor, selection) === "" || isFreeGridEnabled) {
93
96
  setAnchorEl(null);
94
97
  } else {
98
+ console.log("Editor updateAnchorEl", selection);
95
99
  updateAnchorEl();
96
100
  hideSlateSelection(); // removes slate selection background, when there is no selection
97
101
  }
98
102
  }, [selection, event, selectedElement?.enable]);
99
103
  const handleClose = () => {
104
+ console.log("Editor closing");
100
105
  // setAnchorEl(null);
101
106
  setOpen(false);
102
107
  setPopupType("");
103
108
  };
104
109
  return open && !openAI ? /*#__PURE__*/_jsx(ClickAwayListener, {
105
110
  onClickAway: e => {
111
+ console.log("ClickAwayListener", e.target, document.body, e.target !== document.body);
106
112
  // close the mini toolbar, if user clicks outside the editor (in Flozy app.)
107
113
  if (e.target !== document.body) {
108
114
  // e.target returns body, if the user clicks material ui select popup inside the tool bar, on that time, we don't need to close
@@ -19,7 +19,7 @@ const Upload = props => {
19
19
  xs: 12,
20
20
  sx: {
21
21
  padding: "10px",
22
- height: '100%'
22
+ height: "100%"
23
23
  },
24
24
  className: "ims-right",
25
25
  children: /*#__PURE__*/_jsx(Uploader, {
@@ -5,8 +5,8 @@ const UploadStyles = theme => ({
5
5
  borderRadius: "11px",
6
6
  boxShadow: "0px 4px 10px rgba(0, 0, 0, 0.16)",
7
7
  background: theme?.palette?.editor?.uploadFileBg,
8
- minHeight: '150px',
9
- height: 'inherit'
8
+ minHeight: "150px",
9
+ height: "inherit"
10
10
  },
11
11
  uploadField: {
12
12
  width: "100%",
@@ -18,21 +18,21 @@ const UploadStyles = theme => ({
18
18
  backgroundColor: theme?.palette?.editor?.uploadFileInnerBg,
19
19
  borderRadius: "9px",
20
20
  border: "1px dashed #2563EB",
21
- minHeight: '150px'
21
+ minHeight: "150px"
22
22
  },
23
23
  uploadIcon: {
24
24
  display: "grid !important",
25
25
  "& svg": {
26
- display: 'flex',
27
- width: '100%',
26
+ display: "flex",
27
+ width: "100%",
28
28
  "& path": {
29
29
  stroke: "#2563EB"
30
30
  }
31
31
  },
32
- '& span': {
33
- display: 'flex',
34
- width: '100%',
35
- marginTop: '5px'
32
+ "& span": {
33
+ display: "flex",
34
+ width: "100%",
35
+ marginTop: "5px"
36
36
  }
37
37
  }
38
38
  });
@@ -27,6 +27,9 @@ const DynamicIcon = ({
27
27
  iconLoader(iconName, props).then(iconHTML => {
28
28
  if (mounted) {
29
29
  setIcon(iconHTML);
30
+ if (props.onIconLoad) {
31
+ props.onIconLoad(iconHTML);
32
+ }
30
33
  }
31
34
  });
32
35
  return () => {
@@ -58,6 +58,7 @@ const useElementSettingsStyle = theme => ({
58
58
  maxHeight: "500px",
59
59
  overflowX: "hidden",
60
60
  overflowY: "auto",
61
+ paddingLeft: "4px",
61
62
  background: theme?.palette?.editor?.background,
62
63
  paddingLeft: "4px",
63
64
  "& .MuiTypography-root, .MuiInputBase-root, input": {
@@ -54,10 +54,10 @@ const useCommonStyle = theme => ({
54
54
  marginTop: "4px"
55
55
  },
56
56
  "& .MuiPaper-root": {
57
- border: 'unset !important',
58
- borderRadius: '0px',
59
- height: 'fit-content',
60
- padding: '2px'
57
+ border: "unset !important",
58
+ borderRadius: "0px",
59
+ height: "fit-content",
60
+ padding: "2px"
61
61
  },
62
62
  "& .muiIconsListParent": {
63
63
  "& svg": {
@@ -73,7 +73,7 @@ const useCommonStyle = theme => ({
73
73
  "& .MuiGrid-root>.MuiGrid-item": {
74
74
  paddingRight: "0px !important",
75
75
  fontFamily: "Inter, sans-serif",
76
- height: 'fit-content'
76
+ height: "fit-content"
77
77
  },
78
78
  "& .MuiInputBase-root": {
79
79
  borderRadius: "10px",
@@ -134,14 +134,14 @@ const useCommonStyle = theme => ({
134
134
  borderRadius: "10px",
135
135
  width: "46px !important",
136
136
  marginLeft: "10px",
137
- height: '36px !important'
137
+ height: "36px !important"
138
138
  },
139
139
  "& .spacingSlider": {
140
140
  width: "calc(100% - 18px)"
141
141
  }
142
142
  },
143
- '& .MuiFormHelperText-root': {
144
- margin: '4px 0px 0px 0px',
143
+ "& .MuiFormHelperText-root": {
144
+ margin: "4px 0px 0px 0px",
145
145
  color: theme?.palette?.editor?.closeButtonSvgStroke,
146
146
  fontFamily: "Inter, sans-serif"
147
147
  }
@@ -397,14 +397,14 @@ const useCommonStyle = theme => ({
397
397
  padding: "8px 12px",
398
398
  fontSize: "12px",
399
399
  color: theme?.palette?.editor?.menuOptionTextColor,
400
- fontWeight: '500',
400
+ fontWeight: "500",
401
401
  fontFamily: "Inter, sans-serif",
402
- minHeight: '36px',
402
+ minHeight: "36px",
403
403
  "&:hover": {
404
404
  backgroundColor: theme?.palette?.editor?.menuOptionHoverBackground
405
405
  }
406
406
  },
407
- '& .Mui-selected': {
407
+ "& .Mui-selected": {
408
408
  background: `${theme?.palette?.editor?.menuOptionSelectedOption} !important`
409
409
  },
410
410
  "& .MuiListSubheader-root": {
@@ -413,16 +413,16 @@ const useCommonStyle = theme => ({
413
413
  fontSize: "12px"
414
414
  },
415
415
  "& .MuiPaper-root": {
416
- borderRadius: '8px',
417
- padding: '0px',
416
+ borderRadius: "8px",
417
+ padding: "0px",
418
418
  background: `${theme?.palette?.editor?.textWeightPopUpBackground} !important`
419
419
  },
420
- '& .MuiButtonBase-root': {
421
- margin: '4px',
422
- borderRadius: '6px'
420
+ "& .MuiButtonBase-root": {
421
+ margin: "4px",
422
+ borderRadius: "6px"
423
423
  },
424
- '& .MuiList-root': {
425
- padding: '0px'
424
+ "& .MuiList-root": {
425
+ padding: "0px"
426
426
  }
427
427
  },
428
428
  datePicker: {
@@ -529,11 +529,11 @@ const useCommonStyle = theme => ({
529
529
  buttonMoreOption: {
530
530
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
531
531
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
532
- padding: '4px !important',
533
- '& svg': {
534
- width: '18px !important',
535
- height: '18px !important',
536
- '& path': {
532
+ padding: "4px !important",
533
+ "& svg": {
534
+ width: "18px !important",
535
+ height: "18px !important",
536
+ "& path": {
537
537
  stroke: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
538
538
  }
539
539
  }
@@ -541,8 +541,8 @@ const useCommonStyle = theme => ({
541
541
  buttonMoreOption2: {
542
542
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
543
543
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
544
- '& svg': {
545
- '& path': {
544
+ "& svg": {
545
+ "& path": {
546
546
  fill: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
547
547
  }
548
548
  }
@@ -550,11 +550,11 @@ const useCommonStyle = theme => ({
550
550
  buttonMoreOption3: {
551
551
  background: `${theme?.palette?.editor?.aiInputBackground} !important`,
552
552
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1} !important`,
553
- padding: '5px !important',
554
- '& svg': {
555
- width: '16px !important',
556
- height: '16px !important',
557
- '& path': {
553
+ padding: "5px !important",
554
+ "& svg": {
555
+ width: "16px !important",
556
+ height: "16px !important",
557
+ "& path": {
558
558
  stroke: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
559
559
  }
560
560
  }
@@ -562,37 +562,37 @@ const useCommonStyle = theme => ({
562
562
  resizeButton: {
563
563
  background: theme?.palette?.editor?.aiInputBackground,
564
564
  border: `1px solid ${theme?.palette?.editor?.buttonBorder1}`,
565
- padding: '5px !important',
566
- borderRadius: '50% !important',
567
- '& svg': {
568
- width: '18px',
569
- height: '18px',
570
- '& path': {
565
+ padding: "5px !important",
566
+ borderRadius: "50% !important",
567
+ "& svg": {
568
+ width: "18px",
569
+ height: "18px",
570
+ "& path": {
571
571
  fill: `${theme?.palette?.editor?.closeButtonSvgStroke}`
572
572
  }
573
573
  },
574
- '&:hover': {
574
+ "&:hover": {
575
575
  background: theme?.palette?.editor?.aiInputBackground
576
576
  }
577
577
  },
578
578
  gradientFillBtn: {
579
579
  background: `linear-gradient(112.61deg, #2C63ED 19.3%, #8360FD 88.14%) !important`,
580
- textTransform: 'math-auto !important',
581
- color: '#FFFFFF !important',
582
- padding: '0px 12px !important',
583
- height: '32px',
584
- borderRadius: '8px',
585
- fontWeight: '500',
586
- fontSize: '14px'
580
+ textTransform: "math-auto !important",
581
+ color: "#FFFFFF !important",
582
+ padding: "0px 12px !important",
583
+ height: "32px",
584
+ borderRadius: "8px",
585
+ fontWeight: "500",
586
+ fontSize: "14px"
587
587
  },
588
588
  emptyThumbBtn: {
589
589
  background: `${theme?.palette?.editor?.sectionSettingIconHover} !important`,
590
590
  color: `${theme?.palette?.editor?.textColor} !important`,
591
- fontSize: '14px !important',
592
- '& svg': {
593
- width: '20px !important',
594
- height: '20px !important',
595
- '& path': {
591
+ fontSize: "14px !important",
592
+ "& svg": {
593
+ width: "20px !important",
594
+ height: "20px !important",
595
+ "& path": {
596
596
  stroke: `${theme?.palette?.editor?.closeButtonSvgStroke} !important`
597
597
  }
598
598
  }
@@ -1,4 +1,4 @@
1
- import { useEffect, useState } from "react";
1
+ import { useCallback, useEffect, useState } from "react";
2
2
  const useDrag = () => {
3
3
  const [event, setEvent] = useState("");
4
4
  useEffect(() => {
@@ -5,6 +5,7 @@ function useEditorScroll(editorWrapper = {
5
5
  useEffect(() => {
6
6
  if (!editorWrapper?.current) return;
7
7
  const handleScroll = () => {
8
+ console.log("Editor debug useEditorScroll ====>", editorWrapper, callback);
8
9
  callback("scroll");
9
10
  };
10
11
  const currentEditorWrapper = editorWrapper.current;
@@ -149,6 +149,7 @@ const getFocusedNode = (editor, nodeType = "") => {
149
149
  console.log(err);
150
150
  }
151
151
  };
152
+ const voidTypes = ["image", "page-settings"];
152
153
  const withHtml = editor => {
153
154
  const {
154
155
  insertData,
@@ -159,7 +160,7 @@ const withHtml = editor => {
159
160
  return element.type === "link" ? true : isInline(element);
160
161
  };
161
162
  editor.isVoid = element => {
162
- return element.type === "image" ? true : isVoid(element);
163
+ return voidTypes.includes(element.type) ? true : isVoid(element);
163
164
  };
164
165
  editor.insertData = data => {
165
166
  const slateHTML = data?.getData("application/x-slate-fragment");
@@ -1,4 +1,4 @@
1
- import { Editor, Transforms, Element as SlateElement, Range, Text, Element } from "slate";
1
+ import { Editor, Transforms, Element as SlateElement, Range } from "slate";
2
2
  import { Box } from "@mui/material";
3
3
  import { sizeMap } from "./font";
4
4
  import Link from "../Elements/Link/Link";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flozy/editor",
3
- "version": "9.6.7",
3
+ "version": "9.6.8",
4
4
  "description": "An Editor for flozy app brain",
5
5
  "files": [
6
6
  "dist"
@@ -61,7 +61,7 @@
61
61
  "scripts": {
62
62
  "prepare": "husky install .husky",
63
63
  "analyze": "source-map-explorer build/static/js/*.js",
64
- "lint": "./node_modules/.bin/eslint --ignore-path .gitignore .",
64
+ "lint": "./node_modules/. bin/eslint --ignore-path .gitignore .",
65
65
  "start": "craco start",
66
66
  "build": "NODE_OPTIONS='--max_old_space_size=4096' craco build",
67
67
  "test": "craco test --passWithNoTests",