@flozy/editor 1.4.3 → 1.4.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (27) hide show
  1. package/README.md +3 -0
  2. package/dist/Editor/CommonEditor.js +124 -34
  3. package/dist/Editor/Editor.css +23 -0
  4. package/dist/Editor/Elements/AppHeader/AppHeader.js +146 -99
  5. package/dist/Editor/Elements/AppHeader/useEleveateScroll.js +53 -0
  6. package/dist/Editor/Elements/Embed/Image.js +14 -13
  7. package/dist/Editor/Elements/Grid/Grid.js +136 -12
  8. package/dist/Editor/Elements/Grid/GridItem.js +1 -5
  9. package/dist/Editor/Elements/Signature/SignatureOptions/DrawSignature.js +16 -7
  10. package/dist/Editor/Elements/Signature/SignatureOptions/UploadSignature.js +5 -8
  11. package/dist/Editor/Elements/Signature/SignaturePopup.js +28 -18
  12. package/dist/Editor/Toolbar/FormatTools/Autocomplete.js +4 -4
  13. package/dist/Editor/Toolbar/Toolbar.js +2 -1
  14. package/dist/Editor/common/DroppableOverlay.js +33 -0
  15. package/dist/Editor/common/EditorIcons.js +27 -0
  16. package/dist/Editor/common/StyleBuilder/appHeaderStyle.js +5 -0
  17. package/dist/Editor/common/StyleBuilder/fieldTypes/alignment.js +12 -7
  18. package/dist/Editor/common/StyleBuilder/fieldTypes/selectBox.js +8 -4
  19. package/dist/Editor/common/StyleBuilder/gridItemStyle.js +0 -5
  20. package/dist/Editor/common/StyleBuilder/gridStyle.js +10 -0
  21. package/dist/Editor/common/useDragAndDrop.js +83 -0
  22. package/dist/Editor/helper/index.js +15 -1
  23. package/dist/Editor/hooks/useWindowResize.js +21 -0
  24. package/dist/Editor/utils/customHooks/useResize.js +6 -4
  25. package/dist/Editor/utils/grid.js +3 -3
  26. package/dist/Editor/utils/insertAppHeader.js +1 -1
  27. package/package.json +3 -1
@@ -1,11 +1,16 @@
1
- import React, { useState } from "react";
2
- import { Transforms, Path } from "slate";
1
+ import React, { useState, useEffect } from "react";
2
+ import { Transforms, Path, Node } from "slate";
3
3
  import { useSelected, useSlateStatic, ReactEditor } from "slate-react";
4
4
  import { gridItem } from "../../utils/gridItem";
5
5
  import GridPopup from "./GridPopup";
6
6
  import { IconButton, Tooltip } from "@mui/material";
7
7
  import SettingsIcon from "@mui/icons-material/Settings";
8
8
  import AddIcon from "@mui/icons-material/Add";
9
+ import NoteAddIcon from "@mui/icons-material/NoteAdd";
10
+ import CompressIcon from "@mui/icons-material/Compress";
11
+ import { insertGrid } from "../../utils/grid";
12
+ import useDragAndDrop from "../../common/useDragAndDrop";
13
+ import useResize from "../../utils/customHooks/useResize";
9
14
  import { jsx as _jsx } from "react/jsx-runtime";
10
15
  import { jsxs as _jsxs } from "react/jsx-runtime";
11
16
  const Grid = props => {
@@ -26,7 +31,9 @@ const Grid = props => {
26
31
  bgColor,
27
32
  alignment,
28
33
  backgroundImage,
29
- borderColor
34
+ borderColor,
35
+ size: elSize,
36
+ fgColor
30
37
  } = element;
31
38
  const {
32
39
  left,
@@ -39,9 +46,45 @@ const Grid = props => {
39
46
  horizantal,
40
47
  flexDirection
41
48
  } = alignment || {};
49
+ const {
50
+ height: elHeight
51
+ } = elSize || {};
42
52
  const editor = useSlateStatic();
43
53
  const selected = useSelected();
44
54
  const path = ReactEditor.findPath(editor, element);
55
+ const [parentDOM, setParentDOM] = useState(null);
56
+
57
+ // resize
58
+ const [size, onMouseDown, resizing, onLoad] = useResize({
59
+ parentDOM,
60
+ size: element?.size,
61
+ isGrid: true
62
+ });
63
+ const arr = Array.from(Node.elements(editor));
64
+ const ele = arr.find(([elem]) => element === elem);
65
+ useEffect(() => {
66
+ if (editor && ele[1] !== undefined) {
67
+ const dom = ReactEditor.toDOMNode(editor, Node.get(editor, ele[1]));
68
+ const {
69
+ height
70
+ } = dom?.getBoundingClientRect();
71
+ setParentDOM(dom);
72
+ onLoad(element?.size || {
73
+ height: height
74
+ });
75
+ }
76
+ }, []);
77
+
78
+ // upadate resize data once resize done
79
+ useEffect(() => {
80
+ if (!resizing) {
81
+ Transforms.setNodes(editor, {
82
+ size: size
83
+ }, {
84
+ at: path
85
+ });
86
+ }
87
+ }, [resizing]);
45
88
  const onAddGridItem = () => {
46
89
  const currentPath = editor.selection?.anchor?.path;
47
90
  const ancestorsPath = Path.ancestors(currentPath, {
@@ -85,12 +128,56 @@ const Grid = props => {
85
128
  setOpenSettings(false);
86
129
  };
87
130
  const onDelete = () => {
88
- if (path) {
89
- Transforms.removeNodes(editor, {
90
- at: path
131
+ try {
132
+ if (path) {
133
+ Transforms.removeNodes(editor, {
134
+ at: path
135
+ });
136
+ }
137
+ } catch (err) {
138
+ console.log(err);
139
+ }
140
+ };
141
+ const onAddSection = (defaultGrid = null, next = true) => () => {
142
+ try {
143
+ const insertPath = next ? Path.next(path) : path;
144
+ insertGrid(editor, defaultGrid, insertPath);
145
+ } catch (err) {
146
+ console.log(err);
147
+ }
148
+ };
149
+ const onDrop = dropElement => {
150
+ try {
151
+ Transforms.insertNodes(editor, JSON.parse(dropElement), {
152
+ at: path,
153
+ select: true
91
154
  });
155
+ } catch (err) {
156
+ console.log(err);
92
157
  }
93
158
  };
159
+ const onDragEnd = () => {
160
+ try {
161
+ const currentDelpath = ReactEditor.findPath(editor, element);
162
+ if (currentDelpath) {
163
+ Transforms.removeNodes(editor, {
164
+ at: currentDelpath
165
+ });
166
+ }
167
+ } catch (err) {
168
+ console.log(err);
169
+ }
170
+ };
171
+ const grid_drag_id = `grid_drag_${path.join("_")}`;
172
+ const [dndElements, isDragging, isActiveDrag] = useDragAndDrop({
173
+ editor,
174
+ id: grid_drag_id,
175
+ selected,
176
+ path,
177
+ element,
178
+ onDragEnd,
179
+ onDrop
180
+ });
94
181
  const GridToolBar = () => {
95
182
  return selected ? /*#__PURE__*/_jsxs("div", {
96
183
  className: "grid-container-toolbar",
@@ -109,6 +196,13 @@ const Grid = props => {
109
196
  onClick: onAddGridItem,
110
197
  children: /*#__PURE__*/_jsx(AddIcon, {})
111
198
  })
199
+ }), /*#__PURE__*/_jsx(Tooltip, {
200
+ title: "Add Section",
201
+ arrow: true,
202
+ children: /*#__PURE__*/_jsx(IconButton, {
203
+ onClick: onAddSection(null, true),
204
+ children: /*#__PURE__*/_jsx(NoteAddIcon, {})
205
+ })
112
206
  })]
113
207
  }) : null;
114
208
  };
@@ -116,7 +210,7 @@ const Grid = props => {
116
210
  id
117
211
  } : {};
118
212
  return /*#__PURE__*/_jsxs("div", {
119
- className: `grid-container ${grid} element-root`,
213
+ className: `grid-container ${grid} has-hover element-root ${isDragging ? "dragging" : ""} ${isActiveDrag ? "active_drag" : ""}`,
120
214
  ...attributes,
121
215
  ...sectionId,
122
216
  style: {
@@ -125,7 +219,17 @@ const Grid = props => {
125
219
  backgroundImage: backgroundImage && backgroundImage !== "none" ? `url(${backgroundImage})` : "none",
126
220
  border: `1px solid ${borderColor}`
127
221
  },
128
- children: [!readOnly && /*#__PURE__*/_jsx("div", {
222
+ children: [fgColor && /*#__PURE__*/_jsx("div", {
223
+ style: {
224
+ position: "absolute",
225
+ pointerEvents: "none",
226
+ width: "100%",
227
+ height: "100%",
228
+ background: fgColor,
229
+ backgroundRepeat: "no-repeat",
230
+ backgroundSize: "cover"
231
+ }
232
+ }), dndElements, !readOnly && /*#__PURE__*/_jsx("div", {
129
233
  className: `element-selector ${selected ? "selected" : ""}`,
130
234
  contentEditable: false,
131
235
  children: /*#__PURE__*/_jsx(GridToolBar, {})
@@ -136,18 +240,38 @@ const Grid = props => {
136
240
  onDelete: onDelete,
137
241
  customProps: customProps
138
242
  }) : null, /*#__PURE__*/_jsx("div", {
243
+ className: "grid-c-wrpr",
139
244
  style: {
140
245
  display: "flex",
141
246
  paddingLeft: `${left}px`,
142
247
  paddingRight: `${right}px`,
143
248
  paddingTop: `${top}px`,
144
249
  paddingBottom: `${bottom}px`,
145
- alignItems: horizantal,
146
- justifyContent: horizantal,
147
- flexDirection: flexDirection,
148
- width: "100%"
250
+ alignItems: vertical || "start",
251
+ justifyContent: horizantal || "start",
252
+ flexDirection: flexDirection || "row",
253
+ width: "100%",
254
+ height: resizing ? `${size?.height}px` : elHeight ? `${elHeight}px` : "fit-content"
149
255
  },
150
256
  children: children
257
+ }), selected && !readOnly && /*#__PURE__*/_jsx(IconButton, {
258
+ onPointerDown: onMouseDown,
259
+ style: {
260
+ opacity: 1,
261
+ background: "#FFF",
262
+ position: "absolute",
263
+ left: 0,
264
+ right: 0,
265
+ bottom: "-28px",
266
+ margin: "auto",
267
+ color: "#FFF",
268
+ backgroundColor: "#2684ff",
269
+ width: "42px",
270
+ height: "42px",
271
+ zIndex: 1000
272
+ },
273
+ className: "",
274
+ children: /*#__PURE__*/_jsx(CompressIcon, {})
151
275
  })]
152
276
  });
153
277
  };
@@ -28,7 +28,6 @@ const GridItem = props => {
28
28
  borderWidth,
29
29
  borderColor,
30
30
  margin,
31
- textColorHover,
32
31
  bgColorHover,
33
32
  borderColorHover,
34
33
  textColor
@@ -108,10 +107,7 @@ const GridItem = props => {
108
107
  marginTop: `${margin?.top || 0}px`,
109
108
  marginBottom: `${margin?.bottom || 0}px`,
110
109
  "&:hover": {
111
- background: `${bgColorHover || bgColor || "transparent"}`,
112
- "& *": {
113
- color: textColorHover || textColor || "inherit"
114
- }
110
+ background: `${bgColorHover || bgColor || "transparent"}`
115
111
  }
116
112
  },
117
113
  children: [!readOnly && /*#__PURE__*/_jsx("div", {
@@ -1,23 +1,32 @@
1
- import React, { useRef } from "react";
1
+ import React, { useRef, useState } from "react";
2
2
  import SignatureCanvas from "react-signature-canvas";
3
3
  import { Grid } from "@mui/material";
4
4
  import { jsx as _jsx } from "react/jsx-runtime";
5
+ import { jsxs as _jsxs } from "react/jsx-runtime";
5
6
  const DrawSignature = props => {
6
7
  let canvasRef = useRef();
7
8
  const {
8
9
  onDataChange,
9
10
  customProps: {
10
- brush
11
+ brush,
12
+ services
11
13
  }
12
14
  } = props;
13
- const onSigned = () => {
15
+ const [uploading, setUploading] = useState(false);
16
+ const onSigned = async () => {
17
+ setUploading(true);
18
+ const strImage = canvasRef.toDataURL();
19
+ const result = await services("uploadFile", {
20
+ image: strImage
21
+ });
22
+ setUploading(false);
14
23
  onDataChange({
15
- signature: canvasRef.toDataURL()
24
+ signature: result?.imageURL || strImage
16
25
  });
17
26
  };
18
- return /*#__PURE__*/_jsx(Grid, {
27
+ return /*#__PURE__*/_jsxs(Grid, {
19
28
  container: true,
20
- children: /*#__PURE__*/_jsx(Grid, {
29
+ children: [uploading ? "Uploading..." : "", /*#__PURE__*/_jsx(Grid, {
21
30
  item: true,
22
31
  xs: 12,
23
32
  style: {
@@ -33,7 +42,7 @@ const DrawSignature = props => {
33
42
  maxWidth: brush.size || 2,
34
43
  penColor: brush?.color || "#000"
35
44
  })
36
- })
45
+ })]
37
46
  });
38
47
  };
39
48
  export default DrawSignature;
@@ -1,6 +1,5 @@
1
1
  import React, { useState } from "react";
2
2
  import { convertBase64 } from "../../../utils/helper";
3
- import { uploadFile } from "../../../service/fileupload";
4
3
  import { Grid, Typography } from "@mui/material";
5
4
  import { CloudUpload } from "../../../common/EditorIcons";
6
5
  import { jsx as _jsx } from "react/jsx-runtime";
@@ -20,15 +19,13 @@ const UploadSignature = props => {
20
19
  };
21
20
  const doUpload = async strImage => {
22
21
  setUploading(true);
23
- const result = await uploadFile({
22
+ const result = await customProps?.services("uploadFile", {
24
23
  image: strImage
25
- }, customProps);
24
+ });
26
25
  setUploading(false);
27
- if (result && result?.imageURL) {
28
- onUploadDone({
29
- signature: result?.imageURL
30
- });
31
- }
26
+ onUploadDone({
27
+ signature: result?.imageURL || strImage
28
+ });
32
29
  };
33
30
  return /*#__PURE__*/_jsxs("div", {
34
31
  className: "signature-tab",
@@ -97,24 +97,34 @@ const SignaturePopup = props => {
97
97
  p: 0,
98
98
  pb: 2
99
99
  },
100
- children: /*#__PURE__*/_jsxs("div", {
101
- style: {
102
- display: "flex",
103
- justifyContent: "space-between"
104
- },
105
- children: [/*#__PURE__*/_jsx(Typography, {
106
- variant: "h6",
107
- className: "popupTitle",
108
- color: "primary",
109
- children: "SIGNATURE"
110
- }), /*#__PURE__*/_jsx("div", {
111
- style: {
112
- display: "flex"
113
- },
114
- children: /*#__PURE__*/_jsx(IconButton, {
115
- onClick: handleClose,
116
- className: "close-popupbtn",
117
- children: /*#__PURE__*/_jsx(CloseIcon, {})
100
+ children: /*#__PURE__*/_jsxs(Grid, {
101
+ container: true,
102
+ justifyContent: "space-between",
103
+ children: [/*#__PURE__*/_jsx(Grid, {
104
+ item: true,
105
+ children: /*#__PURE__*/_jsx(Typography, {
106
+ variant: "h6",
107
+ className: "popupTitle",
108
+ color: "primary",
109
+ children: "SIGNATURE"
110
+ })
111
+ }), /*#__PURE__*/_jsx(Grid, {
112
+ item: true,
113
+ children: /*#__PURE__*/_jsxs(Grid, {
114
+ container: true,
115
+ children: [customProps?.customComponents?.signature?.header?.map((elem, index) => /*#__PURE__*/_jsx(Grid, {
116
+ sx: {
117
+ pr: 1
118
+ },
119
+ children: elem
120
+ }, index)), /*#__PURE__*/_jsx(Grid, {
121
+ item: true,
122
+ children: /*#__PURE__*/_jsx(IconButton, {
123
+ onClick: handleClose,
124
+ className: "close-popupbtn",
125
+ children: /*#__PURE__*/_jsx(CloseIcon, {})
126
+ })
127
+ })]
118
128
  })
119
129
  })]
120
130
  })
@@ -1,8 +1,8 @@
1
1
  import React from "react";
2
- import { Autocomplete, TextField } from "@mui/material";
2
+ import { Autocomplete as SelectFreeSolo, TextField } from "@mui/material";
3
3
  import { activeMark } from "../../utils/SlateUtilityFunctions.js";
4
4
  import { jsx as _jsx } from "react/jsx-runtime";
5
- const SelectFreeSolo = ({
5
+ const Autocomplete = ({
6
6
  editor,
7
7
  format,
8
8
  options
@@ -16,7 +16,7 @@ const SelectFreeSolo = ({
16
16
  // addMarkData(editor, { format, value });
17
17
  };
18
18
 
19
- return /*#__PURE__*/_jsx(Autocomplete, {
19
+ return /*#__PURE__*/_jsx(SelectFreeSolo, {
20
20
  size: "small",
21
21
  style: {},
22
22
  value: value?.value,
@@ -30,4 +30,4 @@ const SelectFreeSolo = ({
30
30
  })
31
31
  });
32
32
  };
33
- export default SelectFreeSolo;
33
+ export default Autocomplete;
@@ -132,7 +132,8 @@ const Toolbar = props => {
132
132
  }, element.id);
133
133
  case "page-settings":
134
134
  return /*#__PURE__*/_jsx(PageSettingsButton, {
135
- editor: editor
135
+ editor: editor,
136
+ customProps: customProps
136
137
  }, element.id);
137
138
  case "carousel":
138
139
  return /*#__PURE__*/_jsx(CarouselButton, {
@@ -0,0 +1,33 @@
1
+ import React from "react";
2
+ import { ReactEditor } from "slate-react";
3
+ import { jsx as _jsx } from "react/jsx-runtime";
4
+ const DroppableOverlay = ({
5
+ editor,
6
+ dragData
7
+ }) => {
8
+ const {
9
+ data: {
10
+ current: {
11
+ element
12
+ }
13
+ }
14
+ } = dragData || {
15
+ data: {
16
+ current: {
17
+ element: null
18
+ }
19
+ }
20
+ };
21
+ const dragEle = element ? ReactEditor.toDOMNode(editor, element) : null;
22
+ const {
23
+ width,
24
+ height
25
+ } = dragEle?.getBoundingClientRect() || {};
26
+ return dragEle ? /*#__PURE__*/_jsx("div", {
27
+ style: {
28
+ width: width,
29
+ height: height
30
+ }
31
+ }) : null;
32
+ };
33
+ export default DroppableOverlay;
@@ -78,4 +78,31 @@ export const CloudUpload = props => /*#__PURE__*/_jsx("svg", {
78
78
  fill: "#2563EB",
79
79
  stroke: "#2563EB"
80
80
  })
81
+ });
82
+ export const WorkFlow = () => /*#__PURE__*/_jsxs("svg", {
83
+ width: "20",
84
+ height: "21",
85
+ viewBox: "0 0 20 21",
86
+ fill: "none",
87
+ xmlns: "http://www.w3.org/2000/svg",
88
+ children: [/*#__PURE__*/_jsx("path", {
89
+ d: "M0 20.4H20V0.4H0V20.4Z",
90
+ fill: "url(#pattern0)"
91
+ }), /*#__PURE__*/_jsxs("defs", {
92
+ children: [/*#__PURE__*/_jsx("pattern", {
93
+ id: "pattern0",
94
+ patternContentUnits: "objectBoundingBox",
95
+ width: "1",
96
+ height: "1",
97
+ children: /*#__PURE__*/_jsx("use", {
98
+ href: "#image0_1919_14564",
99
+ transform: "scale(0.00625)"
100
+ })
101
+ }), /*#__PURE__*/_jsx("image", {
102
+ id: "image0_1919_14564",
103
+ width: "160",
104
+ height: "160",
105
+ href: ""
106
+ })]
107
+ })]
81
108
  });
@@ -34,6 +34,11 @@ const appHeaderStyle = [{
34
34
  label: "App Logo",
35
35
  key: "appLogo",
36
36
  type: "backgroundImage"
37
+ }, {
38
+ label: "Move Logo to Right",
39
+ key: "isLogoRight",
40
+ type: "selectBox",
41
+ placeholder: "Move Logo to Right"
37
42
  }]
38
43
  }, {
39
44
  tab: "General",
@@ -19,6 +19,7 @@ const Alignment = props => {
19
19
  }
20
20
  });
21
21
  };
22
+ const flexDirection = value?.flexDirection || "row";
22
23
  return /*#__PURE__*/_jsxs(Grid, {
23
24
  container: true,
24
25
  style: {
@@ -34,7 +35,7 @@ const Alignment = props => {
34
35
  children: /*#__PURE__*/_jsx(Typography, {
35
36
  variant: "body1",
36
37
  color: "primary",
37
- children: "Horizantal Position"
38
+ children: "Align Items"
38
39
  })
39
40
  }), /*#__PURE__*/_jsxs(RadioGroup, {
40
41
  row: true,
@@ -45,7 +46,7 @@ const Alignment = props => {
45
46
  children: [/*#__PURE__*/_jsx(FormControlLabel, {
46
47
  value: "start",
47
48
  control: /*#__PURE__*/_jsx(Radio, {}),
48
- label: "Left"
49
+ label: "Start"
49
50
  }), /*#__PURE__*/_jsx(FormControlLabel, {
50
51
  value: "center",
51
52
  control: /*#__PURE__*/_jsx(Radio, {}),
@@ -53,7 +54,7 @@ const Alignment = props => {
53
54
  }), /*#__PURE__*/_jsx(FormControlLabel, {
54
55
  value: "end",
55
56
  control: /*#__PURE__*/_jsx(Radio, {}),
56
- label: "Right"
57
+ label: "End"
57
58
  })]
58
59
  })]
59
60
  })
@@ -66,7 +67,7 @@ const Alignment = props => {
66
67
  children: /*#__PURE__*/_jsx(Typography, {
67
68
  variant: "body1",
68
69
  color: "primary",
69
- children: "Vertical Position"
70
+ children: "Justify Content"
70
71
  })
71
72
  }), /*#__PURE__*/_jsxs(RadioGroup, {
72
73
  row: true,
@@ -77,7 +78,7 @@ const Alignment = props => {
77
78
  children: [/*#__PURE__*/_jsx(FormControlLabel, {
78
79
  value: "start",
79
80
  control: /*#__PURE__*/_jsx(Radio, {}),
80
- label: "Top"
81
+ label: "Start"
81
82
  }), /*#__PURE__*/_jsx(FormControlLabel, {
82
83
  value: "center",
83
84
  control: /*#__PURE__*/_jsx(Radio, {}),
@@ -85,7 +86,7 @@ const Alignment = props => {
85
86
  }), /*#__PURE__*/_jsx(FormControlLabel, {
86
87
  value: "end",
87
88
  control: /*#__PURE__*/_jsx(Radio, {}),
88
- label: "Bottom"
89
+ label: "End"
89
90
  })]
90
91
  })]
91
92
  })
@@ -104,7 +105,7 @@ const Alignment = props => {
104
105
  row: true,
105
106
  "aria-labelledby": "demo-row-radio-buttons-group-label",
106
107
  name: "flexDirection",
107
- value: value?.flexDirection || "column",
108
+ value: flexDirection,
108
109
  onChange: handleChange,
109
110
  children: [/*#__PURE__*/_jsx(FormControlLabel, {
110
111
  value: "row",
@@ -114,6 +115,10 @@ const Alignment = props => {
114
115
  value: "column",
115
116
  control: /*#__PURE__*/_jsx(Radio, {}),
116
117
  label: "Column"
118
+ }), /*#__PURE__*/_jsx(FormControlLabel, {
119
+ value: "row-reverse",
120
+ control: /*#__PURE__*/_jsx(Radio, {}),
121
+ label: "Row reverse"
117
122
  })]
118
123
  })]
119
124
  })
@@ -1,6 +1,7 @@
1
1
  import React from "react";
2
- import { Grid, Checkbox, FormControlLabel } from "@mui/material";
2
+ import { Grid, Checkbox, FormControlLabel, FormHelperText } from "@mui/material";
3
3
  import { jsx as _jsx } from "react/jsx-runtime";
4
+ import { jsxs as _jsxs } from "react/jsx-runtime";
4
5
  const SelectBox = props => {
5
6
  const {
6
7
  value,
@@ -19,16 +20,19 @@ const SelectBox = props => {
19
20
  return /*#__PURE__*/_jsx(Grid, {
20
21
  container: true,
21
22
  padding: 1,
22
- children: /*#__PURE__*/_jsx(Grid, {
23
+ children: /*#__PURE__*/_jsxs(Grid, {
23
24
  item: true,
24
25
  xs: 12,
25
- children: /*#__PURE__*/_jsx(FormControlLabel, {
26
+ children: [/*#__PURE__*/_jsx(FormControlLabel, {
26
27
  control: /*#__PURE__*/_jsx(Checkbox, {
27
28
  value: value,
29
+ checked: value,
28
30
  onChange: handleChange
29
31
  }),
30
32
  label: placeholder
31
- })
33
+ }), /*#__PURE__*/_jsx(FormHelperText, {
34
+ children: data?.helperText
35
+ })]
32
36
  })
33
37
  });
34
38
  };
@@ -71,11 +71,6 @@ const gridItemStyle = [{
71
71
  tab: "Hover Colors",
72
72
  value: "hoverColors",
73
73
  fields: [{
74
- label: "Text",
75
- key: "textColorHover",
76
- type: "color",
77
- needPreview: true
78
- }, {
79
74
  label: "Background",
80
75
  key: "bgColorHover",
81
76
  type: "color"
@@ -7,6 +7,12 @@ const gridStyle = [{
7
7
  key: "id",
8
8
  type: "text",
9
9
  placeholder: "Id should be unique for the page..."
10
+ }, {
11
+ label: "Copy Grid",
12
+ key: "copyGrid",
13
+ type: "selectBox",
14
+ placeholder: "Copy Grid",
15
+ helperText: "This Grid will get copied when creating a new page from this page."
10
16
  }]
11
17
  }, {
12
18
  tab: "Padding",
@@ -63,6 +69,10 @@ const gridStyle = [{
63
69
  label: "Background",
64
70
  key: "bgColor",
65
71
  type: "color"
72
+ }, {
73
+ label: "Foreground Color",
74
+ key: "fgColor",
75
+ type: "color"
66
76
  }, {
67
77
  label: "Border",
68
78
  key: "borderColor",