@springmicro/forms 0.7.0 → 0.7.2

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 (78) hide show
  1. package/.eslintrc.cjs +22 -22
  2. package/README.md +11 -11
  3. package/dist/index.d.ts +0 -0
  4. package/dist/index.js +4146 -4143
  5. package/dist/index.umd.cjs +37 -37
  6. package/package.json +3 -3
  7. package/src/builder/bottom-drawer.tsx +429 -429
  8. package/src/builder/form-builder.tsx +256 -256
  9. package/src/builder/modal.tsx +39 -39
  10. package/src/builder/nodes/node-base.tsx +94 -94
  11. package/src/builder/nodes/node-child-helpers.tsx +273 -273
  12. package/src/builder/nodes/node-parent.tsx +187 -187
  13. package/src/builder/nodes/node-types/array-node.tsx +134 -134
  14. package/src/builder/nodes/node-types/date-node.tsx +60 -60
  15. package/src/builder/nodes/node-types/file-node.tsx +67 -67
  16. package/src/builder/nodes/node-types/integer-node.tsx +60 -60
  17. package/src/builder/nodes/node-types/object-node.tsx +67 -67
  18. package/src/builder/nodes/node-types/text-node.tsx +66 -66
  19. package/src/fields/ArrayField.tsx +875 -875
  20. package/src/fields/BooleanField.tsx +110 -110
  21. package/src/fields/MultiSchemaField.tsx +236 -236
  22. package/src/fields/NullField.tsx +22 -22
  23. package/src/fields/NumberField.tsx +87 -87
  24. package/src/fields/ObjectField.tsx +338 -338
  25. package/src/fields/SchemaField.tsx +402 -402
  26. package/src/fields/StringField.tsx +67 -67
  27. package/src/fields/index.ts +24 -24
  28. package/src/index.tsx +26 -26
  29. package/src/interfaces/MessagesProps.interface.ts +5 -5
  30. package/src/interfaces/Option.interface.ts +4 -4
  31. package/src/styles/select.styles.ts +28 -28
  32. package/src/templates/ArrayFieldDescriptionTemplate.tsx +42 -42
  33. package/src/templates/ArrayFieldItemTemplate.tsx +78 -78
  34. package/src/templates/ArrayFieldTemplate.tsx +90 -90
  35. package/src/templates/ArrayFieldTitleTemplate.tsx +44 -44
  36. package/src/templates/BaseInputTemplate.tsx +94 -94
  37. package/src/templates/ButtonTemplates/AddButton.tsx +29 -29
  38. package/src/templates/ButtonTemplates/IconButton.tsx +49 -49
  39. package/src/templates/ButtonTemplates/SubmitButton.tsx +29 -29
  40. package/src/templates/ButtonTemplates/index.ts +16 -16
  41. package/src/templates/DescriptionField.tsx +29 -29
  42. package/src/templates/ErrorList.tsx +25 -25
  43. package/src/templates/FieldTemplate/FieldTemplate.tsx +39 -39
  44. package/src/templates/FieldTemplate/Label.tsx +29 -29
  45. package/src/templates/FieldTemplate/WrapIfAdditional.tsx +85 -85
  46. package/src/templates/FieldTemplate/index.ts +3 -3
  47. package/src/templates/ObjectFieldTemplate.tsx +79 -79
  48. package/src/templates/TitleField.tsx +20 -20
  49. package/src/templates/UnsupportedField.tsx +29 -29
  50. package/src/templates/index.ts +32 -32
  51. package/src/types/Message.type.ts +6 -6
  52. package/src/types/RawMessage.type.ts +15 -15
  53. package/src/types/form-builder.ts +135 -135
  54. package/src/types/utils.type.ts +1 -1
  55. package/src/utils/form-builder.ts +424 -424
  56. package/src/utils/processSelectValue.ts +50 -50
  57. package/src/widgets/AltDateTimeWidget.tsx +17 -17
  58. package/src/widgets/AltDateWidget.tsx +216 -216
  59. package/src/widgets/CheckboxWidget.tsx +80 -80
  60. package/src/widgets/CheckboxesWidget.tsx +74 -74
  61. package/src/widgets/ColorWidget.tsx +26 -26
  62. package/src/widgets/DateTimeWidget.tsx +28 -28
  63. package/src/widgets/DateWidget.tsx +36 -36
  64. package/src/widgets/EmailWidget.tsx +19 -19
  65. package/src/widgets/FileWidget.tsx +144 -144
  66. package/src/widgets/HiddenWidget.tsx +22 -22
  67. package/src/widgets/PasswordWidget.tsx +20 -20
  68. package/src/widgets/RadioWidget.tsx +87 -87
  69. package/src/widgets/RangeWidget.tsx +24 -24
  70. package/src/widgets/SelectWidget.tsx +99 -99
  71. package/src/widgets/TextWidget.tsx +19 -19
  72. package/src/widgets/TextareaWidget.tsx +64 -64
  73. package/src/widgets/URLWidget.tsx +19 -19
  74. package/src/widgets/UpDownWidget.tsx +20 -20
  75. package/src/widgets/index.ts +43 -43
  76. package/tsconfig.json +24 -24
  77. package/tsconfig.node.json +10 -10
  78. package/vite.config.ts +25 -25
@@ -1,94 +1,94 @@
1
- import { EditingStateType } from "../../types/form-builder";
2
- import { UseStateType } from "../../types/utils.type";
3
- import { Box, SxProps } from "@mui/material";
4
- import React from "react";
5
- import { Draggable } from "react-beautiful-dnd";
6
-
7
- export type NodeBaseProps = {
8
- children?: React.ReactNode;
9
- sx?: SxProps;
10
- nodeId: string;
11
- index: number;
12
- editingState: UseStateType<EditingStateType>;
13
- icon: React.ComponentType<any>;
14
- };
15
-
16
- export default function NodeBase({
17
- children,
18
- sx,
19
- nodeId,
20
- index,
21
- editingState,
22
- icon: Icon,
23
- }: NodeBaseProps) {
24
- const [editingId, setEditing] = editingState;
25
- const editingThisNode = editingId && editingId === nodeId;
26
-
27
- const edit = () => {
28
- if (editingThisNode) return;
29
- setEditing(nodeId);
30
- };
31
-
32
- return (
33
- <Draggable draggableId={nodeId} index={index}>
34
- {(provided) => (
35
- <div ref={provided.innerRef} {...provided.draggableProps}>
36
- <Box
37
- id={nodeId}
38
- sx={{
39
- display: "flex",
40
- flexDirection: "row",
41
- width: "100%",
42
- backgroundColor: editingThisNode ? "#ececec" : "#e3e3e3",
43
- border: editingThisNode
44
- ? "2px solid #c0c0c0"
45
- : "2px solid #e3e3e3",
46
- borderRadius: 1,
47
- transition: "all 0.2s",
48
- cursor: editingThisNode ? "default" : "pointer",
49
- ...(sx ?? {}), // Can be used for custom styles or overrides.
50
- }}
51
- >
52
- <Handle {...provided.dragHandleProps} />
53
- <Box
54
- sx={{ flexGrow: 1, pr: 2, pb: 2, display: "flex" }}
55
- onClick={edit}
56
- >
57
- <Box sx={{ width: 30, height: "100%", pt: 2 }} onClick={edit}>
58
- <Icon sx={{ color: "#888" }} />
59
- </Box>
60
- {children}
61
- </Box>
62
- </Box>
63
- </div>
64
- )}
65
- </Draggable>
66
- );
67
- }
68
-
69
- // The draggable part of the icon.
70
- function Handle(props: any) {
71
- return (
72
- <Box
73
- sx={{ p: 2, gap: 0.33, display: "flex", flexDirection: "row" }}
74
- {...props}
75
- >
76
- <Box
77
- sx={{
78
- backgroundColor: "#888",
79
- borderRadius: 2,
80
- width: 3,
81
- height: "100%",
82
- }}
83
- />
84
- <Box
85
- sx={{
86
- backgroundColor: "#888",
87
- borderRadius: 2,
88
- width: 3,
89
- height: "100%",
90
- }}
91
- />
92
- </Box>
93
- );
94
- }
1
+ import { EditingStateType } from "../../types/form-builder";
2
+ import { UseStateType } from "../../types/utils.type";
3
+ import { Box, SxProps } from "@mui/material";
4
+ import React from "react";
5
+ import { Draggable } from "react-beautiful-dnd";
6
+
7
+ export type NodeBaseProps = {
8
+ children?: React.ReactNode;
9
+ sx?: SxProps;
10
+ nodeId: string;
11
+ index: number;
12
+ editingState: UseStateType<EditingStateType>;
13
+ icon: React.ComponentType<any>;
14
+ };
15
+
16
+ export default function NodeBase({
17
+ children,
18
+ sx,
19
+ nodeId,
20
+ index,
21
+ editingState,
22
+ icon: Icon,
23
+ }: NodeBaseProps) {
24
+ const [editingId, setEditing] = editingState;
25
+ const editingThisNode = editingId && editingId === nodeId;
26
+
27
+ const edit = () => {
28
+ if (editingThisNode) return;
29
+ setEditing(nodeId);
30
+ };
31
+
32
+ return (
33
+ <Draggable draggableId={nodeId} index={index}>
34
+ {(provided) => (
35
+ <div ref={provided.innerRef} {...provided.draggableProps}>
36
+ <Box
37
+ id={nodeId}
38
+ sx={{
39
+ display: "flex",
40
+ flexDirection: "row",
41
+ width: "100%",
42
+ backgroundColor: editingThisNode ? "#ececec" : "#e3e3e3",
43
+ border: editingThisNode
44
+ ? "2px solid #c0c0c0"
45
+ : "2px solid #e3e3e3",
46
+ borderRadius: 1,
47
+ transition: "all 0.2s",
48
+ cursor: editingThisNode ? "default" : "pointer",
49
+ ...(sx ?? {}), // Can be used for custom styles or overrides.
50
+ }}
51
+ >
52
+ <Handle {...provided.dragHandleProps} />
53
+ <Box
54
+ sx={{ flexGrow: 1, pr: 2, pb: 2, display: "flex" }}
55
+ onClick={edit}
56
+ >
57
+ <Box sx={{ width: 30, height: "100%", pt: 2 }} onClick={edit}>
58
+ <Icon sx={{ color: "#888" }} />
59
+ </Box>
60
+ {children}
61
+ </Box>
62
+ </Box>
63
+ </div>
64
+ )}
65
+ </Draggable>
66
+ );
67
+ }
68
+
69
+ // The draggable part of the icon.
70
+ function Handle(props: any) {
71
+ return (
72
+ <Box
73
+ sx={{ p: 2, gap: 0.33, display: "flex", flexDirection: "row" }}
74
+ {...props}
75
+ >
76
+ <Box
77
+ sx={{
78
+ backgroundColor: "#888",
79
+ borderRadius: 2,
80
+ width: 3,
81
+ height: "100%",
82
+ }}
83
+ />
84
+ <Box
85
+ sx={{
86
+ backgroundColor: "#888",
87
+ borderRadius: 2,
88
+ width: 3,
89
+ height: "100%",
90
+ }}
91
+ />
92
+ </Box>
93
+ );
94
+ }