@btst/stack 1.5.2 → 1.6.0

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 (201) hide show
  1. package/dist/node_modules/.pnpm/@dnd-kit_accessibility@3.1.1_react@19.2.0/node_modules/@dnd-kit/accessibility/dist/accessibility.esm.cjs +68 -0
  2. package/dist/node_modules/.pnpm/@dnd-kit_accessibility@3.1.1_react@19.2.0/node_modules/@dnd-kit/accessibility/dist/accessibility.esm.mjs +60 -0
  3. package/dist/node_modules/.pnpm/@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@dnd-kit/core/dist/core.esm.cjs +3937 -0
  4. package/dist/node_modules/.pnpm/@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@dnd-kit/core/dist/core.esm.mjs +3907 -0
  5. package/dist/node_modules/.pnpm/@dnd-kit_modifiers@9.0.0_@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0__react@19.2.0/node_modules/@dnd-kit/modifiers/dist/modifiers.esm.cjs +30 -0
  6. package/dist/node_modules/.pnpm/@dnd-kit_modifiers@9.0.0_@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0__react@19.2.0/node_modules/@dnd-kit/modifiers/dist/modifiers.esm.mjs +28 -0
  7. package/dist/node_modules/.pnpm/@dnd-kit_sortable@10.0.0_@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0__react@19.2.0/node_modules/@dnd-kit/sortable/dist/sortable.esm.cjs +675 -0
  8. package/dist/node_modules/.pnpm/@dnd-kit_sortable@10.0.0_@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0__react@19.2.0/node_modules/@dnd-kit/sortable/dist/sortable.esm.mjs +661 -0
  9. package/dist/node_modules/.pnpm/@dnd-kit_utilities@3.2.2_react@19.2.0/node_modules/@dnd-kit/utilities/dist/utilities.esm.cjs +358 -0
  10. package/dist/node_modules/.pnpm/@dnd-kit_utilities@3.2.2_react@19.2.0/node_modules/@dnd-kit/utilities/dist/utilities.esm.mjs +332 -0
  11. package/dist/node_modules/.pnpm/@radix-ui_react-tabs@1.1.13_@types_react-dom@19.2.3_@types_react@19.2.6__@types_react@1_865f042350eb43f3338b0fffb33f6246/node_modules/@radix-ui/react-tabs/dist/index.cjs +211 -0
  12. package/dist/node_modules/.pnpm/@radix-ui_react-tabs@1.1.13_@types_react-dom@19.2.3_@types_react@19.2.6__@types_react@1_865f042350eb43f3338b0fffb33f6246/node_modules/@radix-ui/react-tabs/dist/index.mjs +188 -0
  13. package/dist/packages/better-stack/src/plugins/cms/api/plugin.cjs +3 -2
  14. package/dist/packages/better-stack/src/plugins/cms/api/plugin.mjs +3 -2
  15. package/dist/packages/better-stack/src/plugins/cms/client/components/forms/content-form.cjs +15 -15
  16. package/dist/packages/better-stack/src/plugins/cms/client/components/forms/content-form.mjs +16 -16
  17. package/dist/packages/better-stack/src/plugins/form-builder/api/plugin.cjs +588 -0
  18. package/dist/packages/better-stack/src/plugins/form-builder/api/plugin.mjs +586 -0
  19. package/dist/packages/better-stack/src/plugins/form-builder/client/components/forms/form-renderer.cjs +131 -0
  20. package/dist/packages/better-stack/src/plugins/form-builder/client/components/forms/form-renderer.mjs +129 -0
  21. package/dist/packages/better-stack/src/plugins/form-builder/client/components/loading/form-builder-skeleton.cjs +32 -0
  22. package/dist/packages/better-stack/src/plugins/form-builder/client/components/loading/form-builder-skeleton.mjs +30 -0
  23. package/dist/packages/better-stack/src/plugins/form-builder/client/components/loading/form-list-skeleton.cjs +21 -0
  24. package/dist/packages/better-stack/src/plugins/form-builder/client/components/loading/form-list-skeleton.mjs +19 -0
  25. package/dist/packages/better-stack/src/plugins/form-builder/client/components/loading/submissions-skeleton.cjs +34 -0
  26. package/dist/packages/better-stack/src/plugins/form-builder/client/components/loading/submissions-skeleton.mjs +32 -0
  27. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/404-page.cjs +20 -0
  28. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/404-page.mjs +18 -0
  29. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-builder-page.cjs +19 -0
  30. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-builder-page.internal.cjs +186 -0
  31. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-builder-page.internal.mjs +184 -0
  32. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-builder-page.mjs +17 -0
  33. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-list-page.cjs +19 -0
  34. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-list-page.internal.cjs +165 -0
  35. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-list-page.internal.mjs +163 -0
  36. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/form-list-page.mjs +17 -0
  37. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/submissions-page.cjs +19 -0
  38. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/submissions-page.internal.cjs +177 -0
  39. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/submissions-page.internal.mjs +175 -0
  40. package/dist/packages/better-stack/src/plugins/form-builder/client/components/pages/submissions-page.mjs +17 -0
  41. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/default-error.cjs +17 -0
  42. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/default-error.mjs +15 -0
  43. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/empty-state.cjs +16 -0
  44. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/empty-state.mjs +14 -0
  45. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/page-wrapper.cjs +27 -0
  46. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/page-wrapper.mjs +25 -0
  47. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/pagination.cjs +39 -0
  48. package/dist/packages/better-stack/src/plugins/form-builder/client/components/shared/pagination.mjs +37 -0
  49. package/dist/packages/better-stack/src/plugins/form-builder/client/hooks/form-builder-hooks.cjs +551 -0
  50. package/dist/packages/better-stack/src/plugins/form-builder/client/hooks/form-builder-hooks.mjs +537 -0
  51. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-common.cjs +36 -0
  52. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-common.mjs +34 -0
  53. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-editor.cjs +19 -0
  54. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-editor.mjs +17 -0
  55. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-list.cjs +21 -0
  56. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-list.mjs +19 -0
  57. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-submissions.cjs +19 -0
  58. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-submissions.mjs +17 -0
  59. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-toasts.cjs +14 -0
  60. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/form-builder-toasts.mjs +12 -0
  61. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/index.cjs +17 -0
  62. package/dist/packages/better-stack/src/plugins/form-builder/client/localization/index.mjs +15 -0
  63. package/dist/packages/better-stack/src/plugins/form-builder/client/plugin.cjs +278 -0
  64. package/dist/packages/better-stack/src/plugins/form-builder/client/plugin.mjs +276 -0
  65. package/dist/packages/better-stack/src/plugins/form-builder/db.cjs +99 -0
  66. package/dist/packages/better-stack/src/plugins/form-builder/db.mjs +97 -0
  67. package/dist/packages/better-stack/src/plugins/form-builder/schemas.cjs +82 -0
  68. package/dist/packages/better-stack/src/plugins/form-builder/schemas.mjs +74 -0
  69. package/dist/packages/better-stack/src/plugins/form-builder/utils.cjs +37 -0
  70. package/dist/packages/better-stack/src/plugins/form-builder/utils.mjs +29 -0
  71. package/dist/packages/ui/src/components/auto-form/index.cjs +2 -12
  72. package/dist/packages/ui/src/components/auto-form/index.mjs +2 -9
  73. package/dist/packages/ui/src/components/auto-form/stepped-auto-form.cjs +377 -0
  74. package/dist/packages/ui/src/components/auto-form/stepped-auto-form.mjs +368 -0
  75. package/dist/packages/ui/src/components/auto-form/utils.cjs +1 -56
  76. package/dist/packages/ui/src/components/auto-form/utils.mjs +2 -56
  77. package/dist/packages/ui/src/components/form-builder/canvas.cjs +111 -0
  78. package/dist/packages/ui/src/components/form-builder/canvas.mjs +109 -0
  79. package/dist/packages/ui/src/components/form-builder/components/index.cjs +570 -0
  80. package/dist/packages/ui/src/components/form-builder/components/index.mjs +553 -0
  81. package/dist/packages/ui/src/components/form-builder/edit-field-dialog.cjs +131 -0
  82. package/dist/packages/ui/src/components/form-builder/edit-field-dialog.mjs +129 -0
  83. package/dist/packages/ui/src/components/form-builder/form-preview.cjs +73 -0
  84. package/dist/packages/ui/src/components/form-builder/form-preview.mjs +71 -0
  85. package/dist/packages/ui/src/components/form-builder/index.cjs +353 -0
  86. package/dist/packages/ui/src/components/form-builder/index.mjs +344 -0
  87. package/dist/packages/ui/src/components/form-builder/nested-field-editor-dialog.cjs +263 -0
  88. package/dist/packages/ui/src/components/form-builder/nested-field-editor-dialog.mjs +261 -0
  89. package/dist/packages/ui/src/components/form-builder/palette.cjs +52 -0
  90. package/dist/packages/ui/src/components/form-builder/palette.mjs +49 -0
  91. package/dist/packages/ui/src/components/form-builder/schema-utils.cjs +120 -0
  92. package/dist/packages/ui/src/components/form-builder/schema-utils.mjs +114 -0
  93. package/dist/packages/ui/src/components/form-builder/sortable-field.cjs +151 -0
  94. package/dist/packages/ui/src/components/form-builder/sortable-field.mjs +148 -0
  95. package/dist/packages/ui/src/components/form-builder/step-tabs.cjs +180 -0
  96. package/dist/packages/ui/src/components/form-builder/step-tabs.mjs +178 -0
  97. package/dist/packages/ui/src/components/form-builder/types.cjs +7 -0
  98. package/dist/packages/ui/src/components/form-builder/types.mjs +5 -0
  99. package/dist/packages/ui/src/components/form-builder/validation-schemas.cjs +67 -0
  100. package/dist/packages/ui/src/components/form-builder/validation-schemas.mjs +56 -0
  101. package/dist/packages/ui/src/components/tabs.cjs +70 -0
  102. package/dist/packages/ui/src/components/tabs.mjs +65 -0
  103. package/dist/packages/ui/src/lib/schema-converter.cjs +130 -0
  104. package/dist/packages/ui/src/lib/schema-converter.mjs +124 -0
  105. package/dist/plugins/blog/api/index.d.cts +1 -1
  106. package/dist/plugins/blog/api/index.d.mts +1 -1
  107. package/dist/plugins/blog/api/index.d.ts +1 -1
  108. package/dist/plugins/blog/client/hooks/index.d.cts +2 -2
  109. package/dist/plugins/blog/client/hooks/index.d.mts +2 -2
  110. package/dist/plugins/blog/client/hooks/index.d.ts +2 -2
  111. package/dist/plugins/blog/client/index.d.cts +1 -1
  112. package/dist/plugins/blog/client/index.d.mts +1 -1
  113. package/dist/plugins/blog/client/index.d.ts +1 -1
  114. package/dist/plugins/blog/query-keys.d.cts +2 -2
  115. package/dist/plugins/blog/query-keys.d.mts +2 -2
  116. package/dist/plugins/blog/query-keys.d.ts +2 -2
  117. package/dist/plugins/cms/client/index.cjs +6 -0
  118. package/dist/plugins/cms/client/index.d.cts +6 -113
  119. package/dist/plugins/cms/client/index.d.mts +6 -113
  120. package/dist/plugins/cms/client/index.d.ts +6 -113
  121. package/dist/plugins/cms/client/index.mjs +1 -0
  122. package/dist/plugins/form-builder/api/index.cjs +7 -0
  123. package/dist/plugins/form-builder/api/index.d.cts +141 -0
  124. package/dist/plugins/form-builder/api/index.d.mts +141 -0
  125. package/dist/plugins/form-builder/api/index.d.ts +141 -0
  126. package/dist/plugins/form-builder/api/index.mjs +1 -0
  127. package/dist/plugins/form-builder/client/components/index.cjs +29 -0
  128. package/dist/plugins/form-builder/client/components/index.d.cts +93 -0
  129. package/dist/plugins/form-builder/client/components/index.d.mts +93 -0
  130. package/dist/plugins/form-builder/client/components/index.d.ts +93 -0
  131. package/dist/plugins/form-builder/client/components/index.mjs +18 -0
  132. package/dist/plugins/form-builder/client/hooks/index.cjs +19 -0
  133. package/dist/plugins/form-builder/client/hooks/index.d.cts +154 -0
  134. package/dist/plugins/form-builder/client/hooks/index.d.mts +154 -0
  135. package/dist/plugins/form-builder/client/hooks/index.d.ts +154 -0
  136. package/dist/plugins/form-builder/client/hooks/index.mjs +1 -0
  137. package/dist/plugins/form-builder/client/index.cjs +13 -0
  138. package/dist/plugins/form-builder/client/index.d.cts +381 -0
  139. package/dist/plugins/form-builder/client/index.d.mts +381 -0
  140. package/dist/plugins/form-builder/client/index.d.ts +381 -0
  141. package/dist/plugins/form-builder/client/index.mjs +2 -0
  142. package/dist/plugins/form-builder/client.css +3 -0
  143. package/dist/plugins/form-builder/query-keys.cjs +143 -0
  144. package/dist/plugins/form-builder/query-keys.d.cts +74 -0
  145. package/dist/plugins/form-builder/query-keys.d.mts +74 -0
  146. package/dist/plugins/form-builder/query-keys.d.ts +74 -0
  147. package/dist/plugins/form-builder/query-keys.mjs +141 -0
  148. package/dist/plugins/form-builder/style.css +19 -0
  149. package/dist/shared/stack.AX5nZ6A3.d.cts +86 -0
  150. package/dist/shared/stack.AX5nZ6A3.d.mts +86 -0
  151. package/dist/shared/stack.AX5nZ6A3.d.ts +86 -0
  152. package/dist/shared/stack.BIh2AXaW.d.cts +123 -0
  153. package/dist/shared/stack.BIh2AXaW.d.mts +123 -0
  154. package/dist/shared/stack.BIh2AXaW.d.ts +123 -0
  155. package/dist/shared/stack.DzH_wcvr.d.cts +195 -0
  156. package/dist/shared/stack.DzH_wcvr.d.mts +195 -0
  157. package/dist/shared/stack.DzH_wcvr.d.ts +195 -0
  158. package/package.json +54 -1
  159. package/src/plugins/cms/api/plugin.ts +9 -4
  160. package/src/plugins/cms/client/components/forms/content-form.tsx +23 -25
  161. package/src/plugins/cms/client/index.ts +11 -0
  162. package/src/plugins/form-builder/api/index.ts +1 -0
  163. package/src/plugins/form-builder/api/plugin.ts +776 -0
  164. package/src/plugins/form-builder/client/components/forms/form-renderer.tsx +253 -0
  165. package/src/plugins/form-builder/client/components/index.tsx +24 -0
  166. package/src/plugins/form-builder/client/components/loading/form-builder-skeleton.tsx +42 -0
  167. package/src/plugins/form-builder/client/components/loading/form-list-skeleton.tsx +25 -0
  168. package/src/plugins/form-builder/client/components/loading/index.tsx +3 -0
  169. package/src/plugins/form-builder/client/components/loading/submissions-skeleton.tsx +40 -0
  170. package/src/plugins/form-builder/client/components/pages/404-page.tsx +28 -0
  171. package/src/plugins/form-builder/client/components/pages/form-builder-page.internal.tsx +253 -0
  172. package/src/plugins/form-builder/client/components/pages/form-builder-page.tsx +26 -0
  173. package/src/plugins/form-builder/client/components/pages/form-list-page.internal.tsx +231 -0
  174. package/src/plugins/form-builder/client/components/pages/form-list-page.tsx +22 -0
  175. package/src/plugins/form-builder/client/components/pages/submissions-page.internal.tsx +268 -0
  176. package/src/plugins/form-builder/client/components/pages/submissions-page.tsx +26 -0
  177. package/src/plugins/form-builder/client/components/shared/default-error.tsx +30 -0
  178. package/src/plugins/form-builder/client/components/shared/empty-state.tsx +26 -0
  179. package/src/plugins/form-builder/client/components/shared/page-wrapper.tsx +32 -0
  180. package/src/plugins/form-builder/client/components/shared/pagination.tsx +52 -0
  181. package/src/plugins/form-builder/client/hooks/form-builder-hooks.tsx +799 -0
  182. package/src/plugins/form-builder/client/hooks/index.tsx +1 -0
  183. package/src/plugins/form-builder/client/index.ts +22 -0
  184. package/src/plugins/form-builder/client/localization/form-builder-common.ts +36 -0
  185. package/src/plugins/form-builder/client/localization/form-builder-editor.ts +18 -0
  186. package/src/plugins/form-builder/client/localization/form-builder-list.ts +17 -0
  187. package/src/plugins/form-builder/client/localization/form-builder-submissions.ts +17 -0
  188. package/src/plugins/form-builder/client/localization/form-builder-toasts.ts +10 -0
  189. package/src/plugins/form-builder/client/localization/index.ts +15 -0
  190. package/src/plugins/form-builder/client/overrides.ts +146 -0
  191. package/src/plugins/form-builder/client/plugin.tsx +488 -0
  192. package/src/plugins/form-builder/client.css +3 -0
  193. package/src/plugins/form-builder/db.ts +99 -0
  194. package/src/plugins/form-builder/query-keys.ts +198 -0
  195. package/src/plugins/form-builder/schemas.ts +122 -0
  196. package/src/plugins/form-builder/style.css +19 -0
  197. package/src/plugins/form-builder/types.ts +317 -0
  198. package/src/plugins/form-builder/utils.ts +63 -0
  199. package/dist/shared/{stack.DLhzx1-D.d.cts → stack.CcI4sYJP.d.cts} +1 -1
  200. package/dist/shared/{stack.DLhzx1-D.d.mts → stack.CcI4sYJP.d.mts} +1 -1
  201. package/dist/shared/{stack.DLhzx1-D.d.ts → stack.CcI4sYJP.d.ts} +1 -1
@@ -0,0 +1,109 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { useMemo } from 'react';
4
+ import { useDroppable } from '../../../../../node_modules/.pnpm/@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0/node_modules/@dnd-kit/core/dist/core.esm.mjs';
5
+ import { SortableContext, verticalListSortingStrategy } from '../../../../../node_modules/.pnpm/@dnd-kit_sortable@10.0.0_@dnd-kit_core@6.3.1_react-dom@19.2.0_react@19.2.0__react@19.2.0__react@19.2.0/node_modules/@dnd-kit/sortable/dist/sortable.esm.mjs';
6
+ import { cn } from '../../lib/utils.mjs';
7
+ import { SortableField } from './sortable-field.mjs';
8
+ import { StepTabs } from './step-tabs.mjs';
9
+
10
+ function DropZone({ id, isDraggingFromPalette }) {
11
+ const { setNodeRef, isOver } = useDroppable({
12
+ id
13
+ });
14
+ if (!isDraggingFromPalette) {
15
+ return null;
16
+ }
17
+ return /* @__PURE__ */ jsx(
18
+ "div",
19
+ {
20
+ ref: setNodeRef,
21
+ className: cn(
22
+ "h-2 rounded-full transition-all duration-200",
23
+ isOver ? "h-3 bg-primary animate-pulse" : "bg-muted-foreground/20"
24
+ )
25
+ }
26
+ );
27
+ }
28
+ function Canvas({
29
+ fields,
30
+ components,
31
+ onEditField,
32
+ onDeleteField,
33
+ onConfigureNested,
34
+ isDraggingFromPalette,
35
+ className,
36
+ steps,
37
+ activeStepIndex,
38
+ onActiveStepChange,
39
+ onAddStep,
40
+ onDeleteStep,
41
+ onRenameStep,
42
+ hideStepControls
43
+ }) {
44
+ const { setNodeRef, isOver } = useDroppable({
45
+ id: "canvas"
46
+ });
47
+ const getComponent = (type) => components.find((c) => c.type === type);
48
+ const visibleFields = useMemo(() => {
49
+ if (steps.length <= 1) {
50
+ return fields;
51
+ }
52
+ return fields.filter((f) => (f.stepGroup ?? 0) === activeStepIndex);
53
+ }, [fields, steps.length, activeStepIndex]);
54
+ const sortableItems = useMemo(() => visibleFields.map((f) => f.id), [visibleFields]);
55
+ return /* @__PURE__ */ jsxs("div", { className: cn("flex flex-col h-full", className), children: [
56
+ /* @__PURE__ */ jsx(
57
+ StepTabs,
58
+ {
59
+ steps,
60
+ activeStepIndex,
61
+ onActiveStepChange,
62
+ onAddStep,
63
+ onDeleteStep,
64
+ onRenameStep,
65
+ hideStepControls
66
+ }
67
+ ),
68
+ /* @__PURE__ */ jsx(
69
+ "div",
70
+ {
71
+ ref: setNodeRef,
72
+ "data-testid": "form-builder-canvas",
73
+ className: cn(
74
+ "flex-1 p-4 rounded-lg border-2 border-dashed min-h-[400px] transition-colors",
75
+ isOver && isDraggingFromPalette ? "border-primary bg-primary/5" : "border-muted-foreground/20"
76
+ ),
77
+ children: visibleFields.length === 0 ? /* @__PURE__ */ jsxs("div", { className: "flex flex-col items-center justify-center h-full text-muted-foreground", "data-testid": "canvas-drop-zone", children: [
78
+ /* @__PURE__ */ jsx("p", { className: "text-lg font-medium", children: "Drop components here" }),
79
+ /* @__PURE__ */ jsx("p", { className: "text-sm", children: steps.length > 1 ? `Drag components from the palette to add to ${steps[activeStepIndex]?.title || "this step"}` : "Drag components from the palette to build your form" })
80
+ ] }) : /* @__PURE__ */ jsx(
81
+ SortableContext,
82
+ {
83
+ items: sortableItems,
84
+ strategy: verticalListSortingStrategy,
85
+ children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-2", children: [
86
+ /* @__PURE__ */ jsx(DropZone, { id: "drop-zone-start", isDraggingFromPalette }),
87
+ visibleFields.map((field, index) => /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-2", children: [
88
+ /* @__PURE__ */ jsx(
89
+ SortableField,
90
+ {
91
+ field,
92
+ index,
93
+ component: getComponent(field.type),
94
+ onEdit: () => onEditField(field.id),
95
+ onDelete: () => onDeleteField(field.id),
96
+ onConfigureNested: onConfigureNested ? () => onConfigureNested(field.id) : void 0
97
+ }
98
+ ),
99
+ /* @__PURE__ */ jsx(DropZone, { id: `drop-zone-${field.id}`, isDraggingFromPalette })
100
+ ] }, field.id))
101
+ ] })
102
+ }
103
+ )
104
+ }
105
+ )
106
+ ] });
107
+ }
108
+
109
+ export { Canvas };
@@ -0,0 +1,570 @@
1
+ 'use strict';
2
+
3
+ const lucideReact = require('lucide-react');
4
+ const z = require('zod');
5
+ const types = require('../types.cjs');
6
+ const validationSchemas = require('../validation-schemas.cjs');
7
+
8
+ function toNumber(value) {
9
+ if (value == null || value === "") return void 0;
10
+ const num = Number(value);
11
+ return isNaN(num) ? void 0 : num;
12
+ }
13
+ function buildInputProps(placeholder, inputType) {
14
+ const props = {};
15
+ if (placeholder) props.placeholder = placeholder;
16
+ if (inputType) props.type = inputType;
17
+ return Object.keys(props).length > 0 ? props : void 0;
18
+ }
19
+ function getPlaceholder(prop) {
20
+ return prop.inputProps?.placeholder || prop.placeholder;
21
+ }
22
+ function getLabel(prop, key) {
23
+ return prop.label || prop.title || key;
24
+ }
25
+ const textFieldDefinition = types.defineComponent({
26
+ type: "text",
27
+ backingType: "string",
28
+ label: "Text Input",
29
+ icon: lucideReact.Type,
30
+ defaultProps: {
31
+ label: "Text Field",
32
+ placeholder: "",
33
+ required: false
34
+ },
35
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(validationSchemas.stringValidationSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.string })),
36
+ toJSONSchema: (props) => ({
37
+ type: "string",
38
+ label: props.label,
39
+ description: props.description,
40
+ inputProps: buildInputProps(props.placeholder),
41
+ default: props.defaultValue,
42
+ minLength: toNumber(props.minLength),
43
+ maxLength: toNumber(props.maxLength)
44
+ }),
45
+ fromJSONSchema: (prop, key, isRequired) => {
46
+ if (prop.type !== "string" || prop.enum || prop.fieldType || prop.inputType || prop.format || prop.inputProps?.type) {
47
+ return null;
48
+ }
49
+ return {
50
+ id: key,
51
+ type: "text",
52
+ props: {
53
+ label: getLabel(prop, key),
54
+ placeholder: getPlaceholder(prop),
55
+ description: prop.description,
56
+ required: isRequired,
57
+ defaultValue: prop.default,
58
+ minLength: prop.minLength,
59
+ maxLength: prop.maxLength
60
+ }
61
+ };
62
+ }
63
+ });
64
+ const emailFieldDefinition = types.defineComponent({
65
+ type: "email",
66
+ backingType: "string",
67
+ label: "Email",
68
+ icon: lucideReact.Mail,
69
+ defaultProps: {
70
+ label: "Email",
71
+ placeholder: "email@example.com",
72
+ required: false
73
+ },
74
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.string })),
75
+ toJSONSchema: (props) => ({
76
+ type: "string",
77
+ label: props.label,
78
+ description: props.description,
79
+ inputProps: buildInputProps(props.placeholder, "email"),
80
+ default: props.defaultValue,
81
+ format: "email"
82
+ }),
83
+ fromJSONSchema: (prop, key, isRequired) => {
84
+ if (prop.type !== "string" || prop.format !== "email" && prop.inputType !== "email" && prop.inputProps?.type !== "email") {
85
+ return null;
86
+ }
87
+ return {
88
+ id: key,
89
+ type: "email",
90
+ props: {
91
+ label: getLabel(prop, key),
92
+ placeholder: getPlaceholder(prop),
93
+ description: prop.description,
94
+ required: isRequired,
95
+ defaultValue: prop.default
96
+ }
97
+ };
98
+ }
99
+ });
100
+ const numberFieldDefinition = types.defineComponent({
101
+ type: "number",
102
+ backingType: "number",
103
+ label: "Number",
104
+ icon: lucideReact.Hash,
105
+ defaultProps: {
106
+ label: "Number",
107
+ required: false
108
+ },
109
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(validationSchemas.numberValidationSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.number })),
110
+ toJSONSchema: (props) => ({
111
+ type: "number",
112
+ label: props.label,
113
+ description: props.description,
114
+ inputProps: buildInputProps(props.placeholder),
115
+ default: props.defaultValue,
116
+ // toNumber handles form input which may come as strings
117
+ minimum: toNumber(props.min),
118
+ maximum: toNumber(props.max)
119
+ }),
120
+ fromJSONSchema: (prop, key, isRequired) => {
121
+ if (prop.type !== "number" && prop.type !== "integer") {
122
+ return null;
123
+ }
124
+ return {
125
+ id: key,
126
+ type: "number",
127
+ props: {
128
+ label: getLabel(prop, key),
129
+ placeholder: getPlaceholder(prop),
130
+ description: prop.description,
131
+ required: isRequired,
132
+ defaultValue: prop.default,
133
+ min: prop.minimum,
134
+ max: prop.maximum
135
+ }
136
+ };
137
+ }
138
+ });
139
+ const textareaFieldDefinition = types.defineComponent({
140
+ type: "textarea",
141
+ backingType: "string",
142
+ label: "Text Area",
143
+ icon: lucideReact.AlignLeft,
144
+ defaultProps: {
145
+ label: "Text Area",
146
+ placeholder: "",
147
+ required: false
148
+ },
149
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(validationSchemas.stringValidationSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.string })),
150
+ toJSONSchema: (props) => ({
151
+ type: "string",
152
+ label: props.label,
153
+ description: props.description,
154
+ fieldType: "textarea",
155
+ inputProps: buildInputProps(props.placeholder),
156
+ default: props.defaultValue,
157
+ minLength: toNumber(props.minLength),
158
+ maxLength: toNumber(props.maxLength)
159
+ }),
160
+ fromJSONSchema: (prop, key, isRequired) => {
161
+ if (prop.type !== "string" || prop.fieldType !== "textarea") {
162
+ return null;
163
+ }
164
+ return {
165
+ id: key,
166
+ type: "textarea",
167
+ props: {
168
+ label: getLabel(prop, key),
169
+ placeholder: getPlaceholder(prop),
170
+ description: prop.description,
171
+ required: isRequired,
172
+ defaultValue: prop.default,
173
+ minLength: prop.minLength,
174
+ maxLength: prop.maxLength
175
+ }
176
+ };
177
+ }
178
+ });
179
+ const checkboxFieldDefinition = types.defineComponent({
180
+ type: "checkbox",
181
+ backingType: "boolean",
182
+ label: "Checkbox",
183
+ icon: lucideReact.CheckSquare,
184
+ defaultProps: {
185
+ label: "Checkbox",
186
+ required: false
187
+ },
188
+ propertiesSchema: validationSchemas.baseMetaSchema.merge(validationSchemas.booleanValidationSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.boolean })),
189
+ toJSONSchema: (props) => ({
190
+ type: "boolean",
191
+ label: props.label,
192
+ description: props.description,
193
+ default: props.defaultValue
194
+ }),
195
+ fromJSONSchema: (prop, key, isRequired) => {
196
+ if (prop.type !== "boolean" || prop.fieldType === "switch") {
197
+ return null;
198
+ }
199
+ return {
200
+ id: key,
201
+ type: "checkbox",
202
+ props: {
203
+ label: getLabel(prop, key),
204
+ description: prop.description,
205
+ required: isRequired,
206
+ defaultValue: prop.default
207
+ }
208
+ };
209
+ }
210
+ });
211
+ const switchFieldDefinition = types.defineComponent({
212
+ type: "switch",
213
+ backingType: "boolean",
214
+ label: "Switch",
215
+ icon: lucideReact.ToggleLeft,
216
+ defaultProps: {
217
+ label: "Switch",
218
+ required: false
219
+ },
220
+ propertiesSchema: validationSchemas.baseMetaSchema.merge(validationSchemas.booleanValidationSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.boolean })),
221
+ toJSONSchema: (props) => ({
222
+ type: "boolean",
223
+ label: props.label,
224
+ description: props.description,
225
+ fieldType: "switch",
226
+ default: props.defaultValue
227
+ }),
228
+ fromJSONSchema: (prop, key, isRequired) => {
229
+ if (prop.type !== "boolean" || prop.fieldType !== "switch") {
230
+ return null;
231
+ }
232
+ return {
233
+ id: key,
234
+ type: "switch",
235
+ props: {
236
+ label: getLabel(prop, key),
237
+ description: prop.description,
238
+ required: isRequired,
239
+ defaultValue: prop.default
240
+ }
241
+ };
242
+ }
243
+ });
244
+ const selectFieldDefinition = types.defineComponent({
245
+ type: "select",
246
+ backingType: "enum",
247
+ label: "Select",
248
+ icon: lucideReact.ChevronDown,
249
+ defaultProps: {
250
+ label: "Select Field",
251
+ required: false,
252
+ options: ["Option 1", "Option 2", "Option 3"]
253
+ },
254
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(validationSchemas.enumOptionsSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.enum })),
255
+ toJSONSchema: (props) => ({
256
+ type: "string",
257
+ label: props.label,
258
+ description: props.description,
259
+ inputProps: buildInputProps(props.placeholder),
260
+ default: props.defaultValue,
261
+ enum: props.options
262
+ }),
263
+ fromJSONSchema: (prop, key, isRequired) => {
264
+ if (prop.type !== "string" || !prop.enum || prop.fieldType === "radio") {
265
+ return null;
266
+ }
267
+ return {
268
+ id: key,
269
+ type: "select",
270
+ props: {
271
+ label: getLabel(prop, key),
272
+ placeholder: getPlaceholder(prop),
273
+ description: prop.description,
274
+ required: isRequired,
275
+ defaultValue: prop.default,
276
+ options: prop.enum
277
+ }
278
+ };
279
+ }
280
+ });
281
+ const radioFieldDefinition = types.defineComponent({
282
+ type: "radio",
283
+ backingType: "enum",
284
+ label: "Radio Group",
285
+ icon: lucideReact.Circle,
286
+ defaultProps: {
287
+ label: "Radio Group",
288
+ required: false,
289
+ options: ["Option 1", "Option 2", "Option 3"]
290
+ },
291
+ propertiesSchema: validationSchemas.baseMetaSchema.merge(validationSchemas.enumOptionsSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.enum })),
292
+ toJSONSchema: (props) => ({
293
+ type: "string",
294
+ label: props.label,
295
+ description: props.description,
296
+ fieldType: "radio",
297
+ default: props.defaultValue,
298
+ enum: props.options
299
+ }),
300
+ fromJSONSchema: (prop, key, isRequired) => {
301
+ if (prop.type !== "string" || !prop.enum || prop.fieldType !== "radio") {
302
+ return null;
303
+ }
304
+ return {
305
+ id: key,
306
+ type: "radio",
307
+ props: {
308
+ label: getLabel(prop, key),
309
+ description: prop.description,
310
+ required: isRequired,
311
+ defaultValue: prop.default,
312
+ options: prop.enum
313
+ }
314
+ };
315
+ }
316
+ });
317
+ const passwordFieldDefinition = types.defineComponent({
318
+ type: "password",
319
+ backingType: "string",
320
+ label: "Password",
321
+ icon: lucideReact.Lock,
322
+ defaultProps: {
323
+ label: "Password",
324
+ placeholder: "\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022",
325
+ required: false
326
+ },
327
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(validationSchemas.stringValidationSchema).merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.string })),
328
+ toJSONSchema: (props) => ({
329
+ type: "string",
330
+ label: props.label,
331
+ description: props.description,
332
+ inputProps: buildInputProps(props.placeholder, "password"),
333
+ default: props.defaultValue,
334
+ minLength: toNumber(props.minLength),
335
+ maxLength: toNumber(props.maxLength)
336
+ }),
337
+ fromJSONSchema: (prop, key, isRequired) => {
338
+ if (prop.type !== "string" || prop.inputType !== "password" && prop.inputProps?.type !== "password") {
339
+ return null;
340
+ }
341
+ return {
342
+ id: key,
343
+ type: "password",
344
+ props: {
345
+ label: getLabel(prop, key),
346
+ placeholder: getPlaceholder(prop),
347
+ description: prop.description,
348
+ required: isRequired,
349
+ defaultValue: prop.default,
350
+ minLength: prop.minLength,
351
+ maxLength: prop.maxLength
352
+ }
353
+ };
354
+ }
355
+ });
356
+ const urlFieldDefinition = types.defineComponent({
357
+ type: "url",
358
+ backingType: "string",
359
+ label: "Website URL",
360
+ icon: lucideReact.Globe,
361
+ defaultProps: {
362
+ label: "Website",
363
+ placeholder: "https://example.com",
364
+ required: false
365
+ },
366
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.string })),
367
+ toJSONSchema: (props) => ({
368
+ type: "string",
369
+ label: props.label,
370
+ description: props.description,
371
+ inputProps: buildInputProps(props.placeholder),
372
+ default: props.defaultValue,
373
+ format: "uri"
374
+ }),
375
+ fromJSONSchema: (prop, key, isRequired) => {
376
+ if (prop.type !== "string" || prop.format !== "uri") {
377
+ return null;
378
+ }
379
+ return {
380
+ id: key,
381
+ type: "url",
382
+ props: {
383
+ label: getLabel(prop, key),
384
+ placeholder: getPlaceholder(prop),
385
+ description: prop.description,
386
+ required: isRequired,
387
+ defaultValue: prop.default
388
+ }
389
+ };
390
+ }
391
+ });
392
+ const phoneFieldDefinition = types.defineComponent({
393
+ type: "phone",
394
+ backingType: "string",
395
+ label: "Phone Number",
396
+ icon: lucideReact.Phone,
397
+ defaultProps: {
398
+ label: "Phone Number",
399
+ placeholder: "+1 (555) 123-4567",
400
+ required: false
401
+ },
402
+ propertiesSchema: validationSchemas.baseMetaSchemaWithPlaceholder.merge(z.z.object({ defaultValue: validationSchemas.DEFAULT_VALUE_SCHEMAS.string })),
403
+ toJSONSchema: (props) => ({
404
+ type: "string",
405
+ label: props.label,
406
+ description: props.description,
407
+ inputProps: buildInputProps(props.placeholder, "tel"),
408
+ default: props.defaultValue
409
+ }),
410
+ fromJSONSchema: (prop, key, isRequired) => {
411
+ if (prop.type !== "string" || prop.inputType !== "tel" && prop.inputProps?.type !== "tel") {
412
+ return null;
413
+ }
414
+ return {
415
+ id: key,
416
+ type: "phone",
417
+ props: {
418
+ label: getLabel(prop, key),
419
+ placeholder: getPlaceholder(prop),
420
+ description: prop.description,
421
+ required: isRequired,
422
+ defaultValue: prop.default
423
+ }
424
+ };
425
+ }
426
+ });
427
+ const dateFieldDefinition = types.defineComponent({
428
+ type: "date",
429
+ backingType: "date",
430
+ label: "Date Picker",
431
+ icon: lucideReact.Calendar,
432
+ defaultProps: {
433
+ label: "Date",
434
+ required: false
435
+ },
436
+ propertiesSchema: validationSchemas.baseMetaSchema.merge(validationSchemas.dateValidationSchema),
437
+ toJSONSchema: (props) => ({
438
+ type: "string",
439
+ format: "date-time",
440
+ fieldType: "date",
441
+ label: props.label,
442
+ description: props.description
443
+ }),
444
+ fromJSONSchema: (prop, key, isRequired) => {
445
+ if (prop.type !== "string" || prop.format !== "date-time" && prop.fieldType !== "date") {
446
+ return null;
447
+ }
448
+ return {
449
+ id: key,
450
+ type: "date",
451
+ props: {
452
+ label: getLabel(prop, key),
453
+ description: prop.description,
454
+ required: isRequired
455
+ }
456
+ };
457
+ }
458
+ });
459
+ const objectFieldDefinition = {
460
+ type: "object",
461
+ label: "Field Group",
462
+ icon: lucideReact.FolderOpen,
463
+ defaultProps: {
464
+ label: "Field Group",
465
+ required: false
466
+ },
467
+ propertiesSchema: validationSchemas.baseMetaSchema.extend(validationSchemas.objectValidationSchema.shape),
468
+ toJSONSchema: (props) => ({
469
+ type: "object",
470
+ label: props.label,
471
+ description: props.description,
472
+ // properties will be filled in by schema-utils from field.children
473
+ properties: {}
474
+ }),
475
+ fromJSONSchema: (prop, key, isRequired) => {
476
+ if (prop.type !== "object" || !prop.properties) {
477
+ return null;
478
+ }
479
+ return {
480
+ id: key,
481
+ type: "object",
482
+ props: {
483
+ label: getLabel(prop, key),
484
+ description: prop.description,
485
+ required: isRequired
486
+ },
487
+ // children will be filled in by schema-utils
488
+ children: []
489
+ };
490
+ }
491
+ };
492
+ const arrayFieldDefinition = {
493
+ type: "array",
494
+ label: "Repeating Group",
495
+ icon: lucideReact.List,
496
+ defaultProps: {
497
+ label: "Items",
498
+ required: false
499
+ },
500
+ propertiesSchema: validationSchemas.baseMetaSchema.extend(validationSchemas.arrayValidationSchema.shape),
501
+ toJSONSchema: (props) => ({
502
+ type: "array",
503
+ label: props.label,
504
+ description: props.description,
505
+ minItems: props.minItems,
506
+ maxItems: props.maxItems,
507
+ // items will be filled in by schema-utils from field.itemTemplate
508
+ items: {
509
+ type: "object",
510
+ properties: {}
511
+ }
512
+ }),
513
+ fromJSONSchema: (prop, key, isRequired) => {
514
+ if (prop.type !== "array" || !prop.items) {
515
+ return null;
516
+ }
517
+ return {
518
+ id: key,
519
+ type: "array",
520
+ props: {
521
+ label: getLabel(prop, key),
522
+ description: prop.description,
523
+ required: isRequired,
524
+ minItems: prop.minItems,
525
+ maxItems: prop.maxItems
526
+ },
527
+ // itemTemplate will be filled in by schema-utils
528
+ itemTemplate: []
529
+ };
530
+ }
531
+ };
532
+ const defaultComponents = [
533
+ // Container types (must be before primitives to match object/array JSON Schema)
534
+ objectFieldDefinition,
535
+ arrayFieldDefinition,
536
+ // Specific types first
537
+ emailFieldDefinition,
538
+ passwordFieldDefinition,
539
+ urlFieldDefinition,
540
+ phoneFieldDefinition,
541
+ dateFieldDefinition,
542
+ textareaFieldDefinition,
543
+ switchFieldDefinition,
544
+ radioFieldDefinition,
545
+ selectFieldDefinition,
546
+ checkboxFieldDefinition,
547
+ numberFieldDefinition,
548
+ // Generic fallback last
549
+ textFieldDefinition
550
+ ];
551
+ function getComponentByType(type, components = defaultComponents) {
552
+ return components.find((c) => c.type === type);
553
+ }
554
+
555
+ exports.arrayFieldDefinition = arrayFieldDefinition;
556
+ exports.checkboxFieldDefinition = checkboxFieldDefinition;
557
+ exports.dateFieldDefinition = dateFieldDefinition;
558
+ exports.defaultComponents = defaultComponents;
559
+ exports.emailFieldDefinition = emailFieldDefinition;
560
+ exports.getComponentByType = getComponentByType;
561
+ exports.numberFieldDefinition = numberFieldDefinition;
562
+ exports.objectFieldDefinition = objectFieldDefinition;
563
+ exports.passwordFieldDefinition = passwordFieldDefinition;
564
+ exports.phoneFieldDefinition = phoneFieldDefinition;
565
+ exports.radioFieldDefinition = radioFieldDefinition;
566
+ exports.selectFieldDefinition = selectFieldDefinition;
567
+ exports.switchFieldDefinition = switchFieldDefinition;
568
+ exports.textFieldDefinition = textFieldDefinition;
569
+ exports.textareaFieldDefinition = textareaFieldDefinition;
570
+ exports.urlFieldDefinition = urlFieldDefinition;