@gravity-ui/page-constructor 8.5.0-alpha.1 → 8.5.0-alpha.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.
- package/build/cjs/containers/PageConstructor/PageConstructor.d.ts +0 -1
- package/build/cjs/containers/PageConstructor/PageConstructor.js +0 -1
- package/build/cjs/containers/PageConstructor/PageConstructor.js.map +1 -1
- package/build/cjs/form-builder-v2/CanvasContentContext.d.ts +18 -0
- package/build/cjs/form-builder-v2/CanvasContentContext.js +21 -0
- package/build/cjs/form-builder-v2/CanvasContentContext.js.map +1 -0
- package/build/cjs/form-builder-v2/FormBuilderV2.css +93 -0
- package/build/cjs/form-builder-v2/FormBuilderV2.d.ts +10 -0
- package/build/cjs/form-builder-v2/FormBuilderV2.js +123 -0
- package/build/cjs/form-builder-v2/FormBuilderV2.js.map +1 -0
- package/build/cjs/form-builder-v2/components/Canvas/Canvas.css +15 -0
- package/build/cjs/form-builder-v2/components/Canvas/Canvas.d.ts +8 -0
- package/build/cjs/form-builder-v2/components/Canvas/Canvas.js +17 -0
- package/build/cjs/form-builder-v2/components/Canvas/Canvas.js.map +1 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.css +133 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.d.ts +9 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.js +72 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.js.map +1 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.d.ts +6 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.js +44 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.js.map +1 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.d.ts +9 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js +20 -0
- package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js.map +1 -0
- package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.css +22 -0
- package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.d.ts +1 -0
- package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.js +21 -0
- package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.js.map +1 -0
- package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.css +13 -0
- package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.d.ts +7 -0
- package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js +24 -0
- package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.css +30 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.d.ts +6 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.js +49 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.d.ts +12 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js +11 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.d.ts +12 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js +38 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.d.ts +7 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.js +9 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.d.ts +9 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.js +40 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.d.ts +12 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js +11 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.d.ts +12 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js +11 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js.map +1 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.d.ts +11 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.js +53 -0
- package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.js.map +1 -0
- package/build/cjs/form-builder-v2/components/Inspector/Inspector.css +20 -0
- package/build/cjs/form-builder-v2/components/Inspector/Inspector.d.ts +1 -0
- package/build/cjs/form-builder-v2/components/Inspector/Inspector.js +20 -0
- package/build/cjs/form-builder-v2/components/Inspector/Inspector.js.map +1 -0
- package/build/cjs/form-builder-v2/components/Palette/Palette.css +56 -0
- package/build/cjs/form-builder-v2/components/Palette/Palette.d.ts +4 -0
- package/build/cjs/form-builder-v2/components/Palette/Palette.js +62 -0
- package/build/cjs/form-builder-v2/components/Palette/Palette.js.map +1 -0
- package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.css +29 -0
- package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.d.ts +9 -0
- package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.js +98 -0
- package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.js.map +1 -0
- package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.css +49 -0
- package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.d.ts +11 -0
- package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.js +82 -0
- package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.js.map +1 -0
- package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.css +24 -0
- package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.d.ts +8 -0
- package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.js +50 -0
- package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.js.map +1 -0
- package/build/cjs/form-builder-v2/components/WhenEditor/utils.d.ts +24 -0
- package/build/cjs/form-builder-v2/components/WhenEditor/utils.js +83 -0
- package/build/cjs/form-builder-v2/components/WhenEditor/utils.js.map +1 -0
- package/build/cjs/form-builder-v2/hooks/FormContext.d.ts +11 -0
- package/build/cjs/form-builder-v2/hooks/FormContext.js +22 -0
- package/build/cjs/form-builder-v2/hooks/FormContext.js.map +1 -0
- package/build/cjs/form-builder-v2/hooks/useFormFields.d.ts +23 -0
- package/build/cjs/form-builder-v2/hooks/useFormFields.js +144 -0
- package/build/cjs/form-builder-v2/hooks/useFormFields.js.map +1 -0
- package/build/cjs/form-builder-v2/index.d.ts +2 -0
- package/build/cjs/form-builder-v2/index.js +6 -0
- package/build/cjs/form-builder-v2/index.js.map +1 -0
- package/build/cjs/form-builder-v2/styles/variables.css +0 -0
- package/build/cjs/form-builder-v2/types.d.ts +32 -0
- package/build/cjs/form-builder-v2/types.js +3 -0
- package/build/cjs/form-builder-v2/types.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/cn.d.ts +2 -0
- package/build/cjs/form-builder-v2/utils/cn.js +7 -0
- package/build/cjs/form-builder-v2/utils/cn.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/dragData.d.ts +18 -0
- package/build/cjs/form-builder-v2/utils/dragData.js +18 -0
- package/build/cjs/form-builder-v2/utils/dragData.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/fieldDefaults.d.ts +2 -0
- package/build/cjs/form-builder-v2/utils/fieldDefaults.js +51 -0
- package/build/cjs/form-builder-v2/utils/fieldDefaults.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/fieldGroups.d.ts +3 -0
- package/build/cjs/form-builder-v2/utils/fieldGroups.js +26 -0
- package/build/cjs/form-builder-v2/utils/fieldGroups.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/fieldMeta.d.ts +6 -0
- package/build/cjs/form-builder-v2/utils/fieldMeta.js +45 -0
- package/build/cjs/form-builder-v2/utils/fieldMeta.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/fieldNames.d.ts +8 -0
- package/build/cjs/form-builder-v2/utils/fieldNames.js +75 -0
- package/build/cjs/form-builder-v2/utils/fieldNames.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/fieldTree.d.ts +2 -0
- package/build/cjs/form-builder-v2/utils/fieldTree.js +7 -0
- package/build/cjs/form-builder-v2/utils/fieldTree.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/fieldTreeOps.d.ts +13 -0
- package/build/cjs/form-builder-v2/utils/fieldTreeOps.js +80 -0
- package/build/cjs/form-builder-v2/utils/fieldTreeOps.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/parseSchema.d.ts +9 -0
- package/build/cjs/form-builder-v2/utils/parseSchema.js +102 -0
- package/build/cjs/form-builder-v2/utils/parseSchema.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/stripIds.d.ts +3 -0
- package/build/cjs/form-builder-v2/utils/stripIds.js +12 -0
- package/build/cjs/form-builder-v2/utils/stripIds.js.map +1 -0
- package/build/cjs/form-builder-v2/utils/treeWalk.d.ts +4 -0
- package/build/cjs/form-builder-v2/utils/treeWalk.js +45 -0
- package/build/cjs/form-builder-v2/utils/treeWalk.js.map +1 -0
- package/build/cjs/hooks/usePCEditorInitializeEvents.js +2 -2
- package/build/cjs/hooks/usePCEditorInitializeEvents.js.map +1 -1
- package/build/esm/containers/PageConstructor/PageConstructor.d.ts +0 -1
- package/build/esm/containers/PageConstructor/PageConstructor.js +0 -1
- package/build/esm/containers/PageConstructor/PageConstructor.js.map +1 -1
- package/build/esm/form-builder-v2/CanvasContentContext.d.ts +18 -0
- package/build/esm/form-builder-v2/CanvasContentContext.js +15 -0
- package/build/esm/form-builder-v2/CanvasContentContext.js.map +1 -0
- package/build/esm/form-builder-v2/FormBuilderV2.css +93 -0
- package/build/esm/form-builder-v2/FormBuilderV2.d.ts +11 -0
- package/build/esm/form-builder-v2/FormBuilderV2.js +119 -0
- package/build/esm/form-builder-v2/FormBuilderV2.js.map +1 -0
- package/build/esm/form-builder-v2/components/Canvas/Canvas.css +15 -0
- package/build/esm/form-builder-v2/components/Canvas/Canvas.d.ts +9 -0
- package/build/esm/form-builder-v2/components/Canvas/Canvas.js +14 -0
- package/build/esm/form-builder-v2/components/Canvas/Canvas.js.map +1 -0
- package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.css +133 -0
- package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.d.ts +10 -0
- package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.js +68 -0
- package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.js.map +1 -0
- package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.d.ts +6 -0
- package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.js +39 -0
- package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.js.map +1 -0
- package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.d.ts +9 -0
- package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js +16 -0
- package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js.map +1 -0
- package/build/esm/form-builder-v2/components/ContentTab/ContentTab.css +22 -0
- package/build/esm/form-builder-v2/components/ContentTab/ContentTab.d.ts +2 -0
- package/build/esm/form-builder-v2/components/ContentTab/ContentTab.js +17 -0
- package/build/esm/form-builder-v2/components/ContentTab/ContentTab.js.map +1 -0
- package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.css +13 -0
- package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.d.ts +8 -0
- package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js +21 -0
- package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.css +30 -0
- package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.d.ts +7 -0
- package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.js +45 -0
- package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.d.ts +12 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js +6 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.d.ts +12 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js +33 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.d.ts +7 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.js +5 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.d.ts +9 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.js +35 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.d.ts +12 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js +6 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.d.ts +12 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js +6 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js.map +1 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.d.ts +11 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.js +48 -0
- package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.js.map +1 -0
- package/build/esm/form-builder-v2/components/Inspector/Inspector.css +20 -0
- package/build/esm/form-builder-v2/components/Inspector/Inspector.d.ts +2 -0
- package/build/esm/form-builder-v2/components/Inspector/Inspector.js +16 -0
- package/build/esm/form-builder-v2/components/Inspector/Inspector.js.map +1 -0
- package/build/esm/form-builder-v2/components/Palette/Palette.css +56 -0
- package/build/esm/form-builder-v2/components/Palette/Palette.d.ts +5 -0
- package/build/esm/form-builder-v2/components/Palette/Palette.js +58 -0
- package/build/esm/form-builder-v2/components/Palette/Palette.js.map +1 -0
- package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.css +29 -0
- package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.d.ts +10 -0
- package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.js +94 -0
- package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.js.map +1 -0
- package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.css +49 -0
- package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.d.ts +12 -0
- package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.js +78 -0
- package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.js.map +1 -0
- package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.css +24 -0
- package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.d.ts +9 -0
- package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.js +46 -0
- package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.js.map +1 -0
- package/build/esm/form-builder-v2/components/WhenEditor/utils.d.ts +24 -0
- package/build/esm/form-builder-v2/components/WhenEditor/utils.js +76 -0
- package/build/esm/form-builder-v2/components/WhenEditor/utils.js.map +1 -0
- package/build/esm/form-builder-v2/hooks/FormContext.d.ts +11 -0
- package/build/esm/form-builder-v2/hooks/FormContext.js +16 -0
- package/build/esm/form-builder-v2/hooks/FormContext.js.map +1 -0
- package/build/esm/form-builder-v2/hooks/useFormFields.d.ts +23 -0
- package/build/esm/form-builder-v2/hooks/useFormFields.js +139 -0
- package/build/esm/form-builder-v2/hooks/useFormFields.js.map +1 -0
- package/build/esm/form-builder-v2/index.d.ts +2 -0
- package/build/esm/form-builder-v2/index.js +3 -0
- package/build/esm/form-builder-v2/index.js.map +1 -0
- package/build/esm/form-builder-v2/styles/variables.css +0 -0
- package/build/esm/form-builder-v2/types.d.ts +32 -0
- package/build/esm/form-builder-v2/types.js +2 -0
- package/build/esm/form-builder-v2/types.js.map +1 -0
- package/build/esm/form-builder-v2/utils/cn.d.ts +2 -0
- package/build/esm/form-builder-v2/utils/cn.js +4 -0
- package/build/esm/form-builder-v2/utils/cn.js.map +1 -0
- package/build/esm/form-builder-v2/utils/dragData.d.ts +18 -0
- package/build/esm/form-builder-v2/utils/dragData.js +11 -0
- package/build/esm/form-builder-v2/utils/dragData.js.map +1 -0
- package/build/esm/form-builder-v2/utils/fieldDefaults.d.ts +2 -0
- package/build/esm/form-builder-v2/utils/fieldDefaults.js +47 -0
- package/build/esm/form-builder-v2/utils/fieldDefaults.js.map +1 -0
- package/build/esm/form-builder-v2/utils/fieldGroups.d.ts +3 -0
- package/build/esm/form-builder-v2/utils/fieldGroups.js +21 -0
- package/build/esm/form-builder-v2/utils/fieldGroups.js.map +1 -0
- package/build/esm/form-builder-v2/utils/fieldMeta.d.ts +6 -0
- package/build/esm/form-builder-v2/utils/fieldMeta.js +42 -0
- package/build/esm/form-builder-v2/utils/fieldMeta.js.map +1 -0
- package/build/esm/form-builder-v2/utils/fieldNames.d.ts +8 -0
- package/build/esm/form-builder-v2/utils/fieldNames.js +66 -0
- package/build/esm/form-builder-v2/utils/fieldNames.js.map +1 -0
- package/build/esm/form-builder-v2/utils/fieldTree.d.ts +2 -0
- package/build/esm/form-builder-v2/utils/fieldTree.js +3 -0
- package/build/esm/form-builder-v2/utils/fieldTree.js.map +1 -0
- package/build/esm/form-builder-v2/utils/fieldTreeOps.d.ts +13 -0
- package/build/esm/form-builder-v2/utils/fieldTreeOps.js +69 -0
- package/build/esm/form-builder-v2/utils/fieldTreeOps.js.map +1 -0
- package/build/esm/form-builder-v2/utils/parseSchema.d.ts +9 -0
- package/build/esm/form-builder-v2/utils/parseSchema.js +98 -0
- package/build/esm/form-builder-v2/utils/parseSchema.js.map +1 -0
- package/build/esm/form-builder-v2/utils/stripIds.d.ts +3 -0
- package/build/esm/form-builder-v2/utils/stripIds.js +8 -0
- package/build/esm/form-builder-v2/utils/stripIds.js.map +1 -0
- package/build/esm/form-builder-v2/utils/treeWalk.d.ts +4 -0
- package/build/esm/form-builder-v2/utils/treeWalk.js +39 -0
- package/build/esm/form-builder-v2/utils/treeWalk.js.map +1 -0
- package/build/esm/hooks/usePCEditorInitializeEvents.js +2 -2
- package/build/esm/hooks/usePCEditorInitializeEvents.js.map +1 -1
- package/package.json +13 -1
- package/widget/index.js +1 -1
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { ColorField, SectionField, SegmentedRadioGroupField, SelectField, SwitchField, Text, TextField } from "../form-generator-v2/types.js";
|
|
2
|
+
type LeafField = TextField | SelectField | SegmentedRadioGroupField | Text | SwitchField | ColorField;
|
|
3
|
+
export type BuilderLeafField = LeafField & {
|
|
4
|
+
id: string;
|
|
5
|
+
};
|
|
6
|
+
export type BuilderSectionField = Omit<SectionField, 'fields'> & {
|
|
7
|
+
id: string;
|
|
8
|
+
fields: FormField[];
|
|
9
|
+
};
|
|
10
|
+
export type FormField = BuilderLeafField | BuilderSectionField;
|
|
11
|
+
export type BuilderFieldType = FormField['type'];
|
|
12
|
+
export type FieldUpdate = Partial<LeafField> | Partial<Omit<BuilderSectionField, 'id'>>;
|
|
13
|
+
export interface FormFieldsActions {
|
|
14
|
+
addField: (type: BuilderFieldType) => void;
|
|
15
|
+
addFieldToSection: (sectionId: string, type: BuilderFieldType) => void;
|
|
16
|
+
insertFieldBefore: (targetId: string, type: BuilderFieldType) => void;
|
|
17
|
+
insertFieldAfter: (targetId: string, type: BuilderFieldType) => void;
|
|
18
|
+
moveFieldToSection: (fieldId: string, sectionId: string) => void;
|
|
19
|
+
removeField: (fieldId: string) => void;
|
|
20
|
+
duplicateField: (fieldId: string) => void;
|
|
21
|
+
updateField: (fieldId: string, updates: FieldUpdate) => void;
|
|
22
|
+
moveFieldUp: (fieldId: string) => void;
|
|
23
|
+
moveFieldDown: (fieldId: string) => void;
|
|
24
|
+
setAllFields: (fields: FormField[]) => void;
|
|
25
|
+
resetForm: () => void;
|
|
26
|
+
selectField: (fieldId: string | null) => void;
|
|
27
|
+
}
|
|
28
|
+
export interface FormContextType extends FormFieldsActions {
|
|
29
|
+
formFields: FormField[];
|
|
30
|
+
selectedFieldId: string | null;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"../../../src","sources":["form-builder-v2/types.ts"],"names":[],"mappings":"","sourcesContent":["import type {\n ColorField,\n SectionField,\n SegmentedRadioGroupField,\n SelectField,\n SwitchField,\n Text,\n TextField,\n} from '../form-generator-v2/types';\n\ntype LeafField =\n | TextField\n | SelectField\n | SegmentedRadioGroupField\n | Text\n | SwitchField\n | ColorField;\n\nexport type BuilderLeafField = LeafField & {id: string};\nexport type BuilderSectionField = Omit<SectionField, 'fields'> & {\n id: string;\n fields: FormField[];\n};\n\nexport type FormField = BuilderLeafField | BuilderSectionField;\n\nexport type BuilderFieldType = FormField['type'];\n\nexport type FieldUpdate = Partial<LeafField> | Partial<Omit<BuilderSectionField, 'id'>>;\n\nexport interface FormFieldsActions {\n addField: (type: BuilderFieldType) => void;\n addFieldToSection: (sectionId: string, type: BuilderFieldType) => void;\n insertFieldBefore: (targetId: string, type: BuilderFieldType) => void;\n insertFieldAfter: (targetId: string, type: BuilderFieldType) => void;\n moveFieldToSection: (fieldId: string, sectionId: string) => void;\n removeField: (fieldId: string) => void;\n duplicateField: (fieldId: string) => void;\n updateField: (fieldId: string, updates: FieldUpdate) => void;\n moveFieldUp: (fieldId: string) => void;\n moveFieldDown: (fieldId: string) => void;\n setAllFields: (fields: FormField[]) => void;\n resetForm: () => void;\n selectField: (fieldId: string | null) => void;\n}\n\nexport interface FormContextType extends FormFieldsActions {\n formFields: FormField[];\n selectedFieldId: string | null;\n}\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.formBuilderV2Cn = exports.FORM_BUILDER_V2_NAMESPACE = void 0;
|
|
4
|
+
const classname_1 = require("@bem-react/classname");
|
|
5
|
+
exports.FORM_BUILDER_V2_NAMESPACE = 'pcformbuilderv2-';
|
|
6
|
+
exports.formBuilderV2Cn = (0, classname_1.withNaming)({ n: exports.FORM_BUILDER_V2_NAMESPACE, e: '__', m: '_' });
|
|
7
|
+
//# sourceMappingURL=cn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cn.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/cn.ts"],"names":[],"mappings":";;;AAAA,oDAAgD;AAEnC,QAAA,yBAAyB,GAAG,kBAAkB,CAAC;AAE/C,QAAA,eAAe,GAAG,IAAA,sBAAU,EAAC,EAAC,CAAC,EAAE,iCAAyB,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,EAAC,CAAC,CAAC","sourcesContent":["import {withNaming} from '@bem-react/classname';\n\nexport const FORM_BUILDER_V2_NAMESPACE = 'pcformbuilderv2-';\n\nexport const formBuilderV2Cn = withNaming({n: FORM_BUILDER_V2_NAMESPACE, e: '__', m: '_'});\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Data } from '@dnd-kit/abstract';
|
|
2
|
+
import type { BuilderFieldType } from "../types.js";
|
|
3
|
+
export interface PaletteDragData extends Data {
|
|
4
|
+
kind: 'palette';
|
|
5
|
+
type: BuilderFieldType;
|
|
6
|
+
}
|
|
7
|
+
export interface CardDragData extends Data {
|
|
8
|
+
kind: 'card';
|
|
9
|
+
group: string;
|
|
10
|
+
}
|
|
11
|
+
export interface SectionDropData extends Data {
|
|
12
|
+
kind: 'section-drop';
|
|
13
|
+
sectionId: string;
|
|
14
|
+
}
|
|
15
|
+
export declare function isPaletteData(data: Data | null | undefined): data is PaletteDragData;
|
|
16
|
+
export declare function isCardData(data: Data | null | undefined): data is CardDragData;
|
|
17
|
+
export declare function isSectionDropData(data: Data | null | undefined): data is SectionDropData;
|
|
18
|
+
export declare const isDropAfter: (pointerY: number | undefined, targetCenterY: number | undefined) => boolean;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isDropAfter = void 0;
|
|
4
|
+
exports.isPaletteData = isPaletteData;
|
|
5
|
+
exports.isCardData = isCardData;
|
|
6
|
+
exports.isSectionDropData = isSectionDropData;
|
|
7
|
+
function isPaletteData(data) {
|
|
8
|
+
return data !== null && data !== undefined && data.kind === 'palette';
|
|
9
|
+
}
|
|
10
|
+
function isCardData(data) {
|
|
11
|
+
return data !== null && data !== undefined && data.kind === 'card';
|
|
12
|
+
}
|
|
13
|
+
function isSectionDropData(data) {
|
|
14
|
+
return data !== null && data !== undefined && data.kind === 'section-drop';
|
|
15
|
+
}
|
|
16
|
+
const isDropAfter = (pointerY, targetCenterY) => pointerY !== undefined && targetCenterY !== undefined && pointerY > targetCenterY;
|
|
17
|
+
exports.isDropAfter = isDropAfter;
|
|
18
|
+
//# sourceMappingURL=dragData.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dragData.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/dragData.ts"],"names":[],"mappings":";;;AAmBA,sCAEC;AAED,gCAEC;AAED,8CAEC;AAVD,SAAgB,aAAa,CAAC,IAA6B;IACvD,OAAO,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,CAAC;AAC1E,CAAC;AAED,SAAgB,UAAU,CAAC,IAA6B;IACpD,OAAO,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,CAAC;AACvE,CAAC;AAED,SAAgB,iBAAiB,CAAC,IAA6B;IAC3D,OAAO,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC;AAC/E,CAAC;AAEM,MAAM,WAAW,GAAG,CACvB,QAA4B,EAC5B,aAAiC,EAC1B,EAAE,CAAC,QAAQ,KAAK,SAAS,IAAI,aAAa,KAAK,SAAS,IAAI,QAAQ,GAAG,aAAa,CAAC;AAHnF,QAAA,WAAW,eAGwE","sourcesContent":["import type {Data} from '@dnd-kit/abstract';\n\nimport type {BuilderFieldType} from '../types';\n\nexport interface PaletteDragData extends Data {\n kind: 'palette';\n type: BuilderFieldType;\n}\n\nexport interface CardDragData extends Data {\n kind: 'card';\n group: string;\n}\n\nexport interface SectionDropData extends Data {\n kind: 'section-drop';\n sectionId: string;\n}\n\nexport function isPaletteData(data: Data | null | undefined): data is PaletteDragData {\n return data !== null && data !== undefined && data.kind === 'palette';\n}\n\nexport function isCardData(data: Data | null | undefined): data is CardDragData {\n return data !== null && data !== undefined && data.kind === 'card';\n}\n\nexport function isSectionDropData(data: Data | null | undefined): data is SectionDropData {\n return data !== null && data !== undefined && data.kind === 'section-drop';\n}\n\nexport const isDropAfter = (\n pointerY: number | undefined,\n targetCenterY: number | undefined,\n): boolean => pointerY !== undefined && targetCenterY !== undefined && pointerY > targetCenterY;\n"]}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createDefaultField = void 0;
|
|
4
|
+
const createDefaultField = (type, name, id) => {
|
|
5
|
+
switch (type) {
|
|
6
|
+
case 'textInput':
|
|
7
|
+
return { type, name, title: 'Text input', id };
|
|
8
|
+
case 'textArea':
|
|
9
|
+
return { type, name, title: 'Text area', id };
|
|
10
|
+
case 'switch':
|
|
11
|
+
return { type, name, title: 'Switch', id };
|
|
12
|
+
case 'colorInput':
|
|
13
|
+
return { type, name, title: 'Color', defaultValue: '#000000', id };
|
|
14
|
+
case 'select':
|
|
15
|
+
return {
|
|
16
|
+
type,
|
|
17
|
+
name,
|
|
18
|
+
title: 'Select',
|
|
19
|
+
options: [
|
|
20
|
+
{ value: 'option1', content: 'Option 1' },
|
|
21
|
+
{ value: 'option2', content: 'Option 2' },
|
|
22
|
+
],
|
|
23
|
+
id,
|
|
24
|
+
};
|
|
25
|
+
case 'segmentedRadioGroup':
|
|
26
|
+
return {
|
|
27
|
+
type,
|
|
28
|
+
name,
|
|
29
|
+
title: 'Segmented radio',
|
|
30
|
+
options: [
|
|
31
|
+
{ value: 'option1', content: 'Option 1' },
|
|
32
|
+
{ value: 'option2', content: 'Option 2' },
|
|
33
|
+
],
|
|
34
|
+
id,
|
|
35
|
+
};
|
|
36
|
+
case 'text':
|
|
37
|
+
return { type, text: 'Static text', id };
|
|
38
|
+
case 'section':
|
|
39
|
+
return {
|
|
40
|
+
type,
|
|
41
|
+
title: 'Section',
|
|
42
|
+
opened: true,
|
|
43
|
+
fields: [],
|
|
44
|
+
id,
|
|
45
|
+
};
|
|
46
|
+
default:
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
exports.createDefaultField = createDefaultField;
|
|
51
|
+
//# sourceMappingURL=fieldDefaults.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fieldDefaults.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/fieldDefaults.ts"],"names":[],"mappings":";;;AAEO,MAAM,kBAAkB,GAAG,CAAC,IAAsB,EAAE,IAAY,EAAE,EAAU,EAAa,EAAE;IAC9F,QAAQ,IAAI,EAAE,CAAC;QACX,KAAK,WAAW;YACZ,OAAO,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE,EAAC,CAAC;QACjD,KAAK,UAAU;YACX,OAAO,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAC,CAAC;QAChD,KAAK,QAAQ;YACT,OAAO,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAC,CAAC;QAC7C,KAAK,YAAY;YACb,OAAO,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE,EAAC,CAAC;QACrE,KAAK,QAAQ;YACT,OAAO;gBACH,IAAI;gBACJ,IAAI;gBACJ,KAAK,EAAE,QAAQ;gBACf,OAAO,EAAE;oBACL,EAAC,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAC;oBACvC,EAAC,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAC;iBAC1C;gBACD,EAAE;aACL,CAAC;QACN,KAAK,qBAAqB;YACtB,OAAO;gBACH,IAAI;gBACJ,IAAI;gBACJ,KAAK,EAAE,iBAAiB;gBACxB,OAAO,EAAE;oBACL,EAAC,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAC;oBACvC,EAAC,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAC;iBAC1C;gBACD,EAAE;aACL,CAAC;QACN,KAAK,MAAM;YACP,OAAO,EAAC,IAAI,EAAE,IAAI,EAAE,aAAa,EAAE,EAAE,EAAC,CAAC;QAC3C,KAAK,SAAS;YACV,OAAO;gBACH,IAAI;gBACJ,KAAK,EAAE,SAAS;gBAChB,MAAM,EAAE,IAAI;gBACZ,MAAM,EAAE,EAAE;gBACV,EAAE;aACL,CAAC;QACN;YACI,OAAO,SAAkB,CAAC;IAClC,CAAC;AACL,CAAC,CAAC;AA7CW,QAAA,kBAAkB,sBA6C7B","sourcesContent":["import {BuilderFieldType, FormField} from '../types';\n\nexport const createDefaultField = (type: BuilderFieldType, name: string, id: string): FormField => {\n switch (type) {\n case 'textInput':\n return {type, name, title: 'Text input', id};\n case 'textArea':\n return {type, name, title: 'Text area', id};\n case 'switch':\n return {type, name, title: 'Switch', id};\n case 'colorInput':\n return {type, name, title: 'Color', defaultValue: '#000000', id};\n case 'select':\n return {\n type,\n name,\n title: 'Select',\n options: [\n {value: 'option1', content: 'Option 1'},\n {value: 'option2', content: 'Option 2'},\n ],\n id,\n };\n case 'segmentedRadioGroup':\n return {\n type,\n name,\n title: 'Segmented radio',\n options: [\n {value: 'option1', content: 'Option 1'},\n {value: 'option2', content: 'Option 2'},\n ],\n id,\n };\n case 'text':\n return {type, text: 'Static text', id};\n case 'section':\n return {\n type,\n title: 'Section',\n opened: true,\n fields: [],\n id,\n };\n default:\n return undefined as never;\n }\n};\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.applyGroupsMap = exports.buildGroupsMap = void 0;
|
|
4
|
+
const treeWalk_1 = require("./treeWalk.js");
|
|
5
|
+
const buildGroupsMap = (fields) => {
|
|
6
|
+
const groups = { root: fields };
|
|
7
|
+
(0, treeWalk_1.walkFields)(fields, (field) => {
|
|
8
|
+
if (field.type === 'section') {
|
|
9
|
+
groups[`section:${field.id}`] = field.fields;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
return groups;
|
|
13
|
+
};
|
|
14
|
+
exports.buildGroupsMap = buildGroupsMap;
|
|
15
|
+
const applyGroupsMap = (groups) => {
|
|
16
|
+
const transform = (fields) => fields.map((field) => {
|
|
17
|
+
if (field.type === 'section') {
|
|
18
|
+
const childGroup = groups[`section:${field.id}`] ?? field.fields;
|
|
19
|
+
return { ...field, fields: transform(childGroup) };
|
|
20
|
+
}
|
|
21
|
+
return field;
|
|
22
|
+
});
|
|
23
|
+
return transform(groups.root ?? []);
|
|
24
|
+
};
|
|
25
|
+
exports.applyGroupsMap = applyGroupsMap;
|
|
26
|
+
//# sourceMappingURL=fieldGroups.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fieldGroups.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/fieldGroups.ts"],"names":[],"mappings":";;;AAEA,4CAAsC;AAE/B,MAAM,cAAc,GAAG,CAAC,MAAmB,EAA+B,EAAE;IAC/E,MAAM,MAAM,GAAgC,EAAC,IAAI,EAAE,MAAM,EAAC,CAAC;IAC3D,IAAA,qBAAU,EAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;QACzB,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC3B,MAAM,CAAC,WAAW,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC;QACjD,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC;AAClB,CAAC,CAAC;AARW,QAAA,cAAc,kBAQzB;AAEK,MAAM,cAAc,GAAG,CAAC,MAAmC,EAAe,EAAE;IAC/E,MAAM,SAAS,GAAG,CAAC,MAAmB,EAAe,EAAE,CACnD,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACjB,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC3B,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW,KAAK,CAAC,EAAE,EAAE,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC;YACjE,OAAO,EAAC,GAAG,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,UAAU,CAAC,EAAC,CAAC;QACrD,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC,CAAC,CAAC;IACP,OAAO,SAAS,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;AACxC,CAAC,CAAC;AAVW,QAAA,cAAc,kBAUzB","sourcesContent":["import {FormField} from '../types';\n\nimport {walkFields} from './treeWalk';\n\nexport const buildGroupsMap = (fields: FormField[]): Record<string, FormField[]> => {\n const groups: Record<string, FormField[]> = {root: fields};\n walkFields(fields, (field) => {\n if (field.type === 'section') {\n groups[`section:${field.id}`] = field.fields;\n }\n });\n return groups;\n};\n\nexport const applyGroupsMap = (groups: Record<string, FormField[]>): FormField[] => {\n const transform = (fields: FormField[]): FormField[] =>\n fields.map((field) => {\n if (field.type === 'section') {\n const childGroup = groups[`section:${field.id}`] ?? field.fields;\n return {...field, fields: transform(childGroup)};\n }\n return field;\n });\n return transform(groups.root ?? []);\n};\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { IconData } from '@gravity-ui/uikit';
|
|
2
|
+
import type { BuilderFieldType } from "../types.js";
|
|
3
|
+
export declare const TYPE_LABELS: Record<BuilderFieldType, string>;
|
|
4
|
+
export declare const PALETTE_LABELS: Record<BuilderFieldType, string>;
|
|
5
|
+
export declare const TYPE_ICONS: Record<BuilderFieldType, IconData>;
|
|
6
|
+
export declare const FIELD_TYPES: BuilderFieldType[];
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FIELD_TYPES = exports.TYPE_ICONS = exports.PALETTE_LABELS = exports.TYPE_LABELS = void 0;
|
|
4
|
+
const icons_1 = require("@gravity-ui/icons");
|
|
5
|
+
exports.TYPE_LABELS = {
|
|
6
|
+
textInput: 'Text input',
|
|
7
|
+
textArea: 'Text area',
|
|
8
|
+
select: 'Select',
|
|
9
|
+
segmentedRadioGroup: 'Segmented radio',
|
|
10
|
+
switch: 'Switch',
|
|
11
|
+
colorInput: 'Color input',
|
|
12
|
+
text: 'Static text',
|
|
13
|
+
section: 'Section',
|
|
14
|
+
};
|
|
15
|
+
exports.PALETTE_LABELS = {
|
|
16
|
+
textInput: 'Text',
|
|
17
|
+
textArea: 'Text area',
|
|
18
|
+
select: 'Select',
|
|
19
|
+
segmentedRadioGroup: 'Radio',
|
|
20
|
+
switch: 'Switch',
|
|
21
|
+
colorInput: 'Color',
|
|
22
|
+
text: 'Hint',
|
|
23
|
+
section: 'Section',
|
|
24
|
+
};
|
|
25
|
+
exports.TYPE_ICONS = {
|
|
26
|
+
textInput: icons_1.FontCursor,
|
|
27
|
+
textArea: icons_1.TextAlignLeft,
|
|
28
|
+
select: icons_1.ChevronsExpandVertical,
|
|
29
|
+
segmentedRadioGroup: icons_1.ListCheck,
|
|
30
|
+
switch: icons_1.ToggleOn,
|
|
31
|
+
colorInput: icons_1.Droplet,
|
|
32
|
+
text: icons_1.CircleInfo,
|
|
33
|
+
section: icons_1.Cubes3,
|
|
34
|
+
};
|
|
35
|
+
exports.FIELD_TYPES = [
|
|
36
|
+
'textInput',
|
|
37
|
+
'textArea',
|
|
38
|
+
'select',
|
|
39
|
+
'segmentedRadioGroup',
|
|
40
|
+
'switch',
|
|
41
|
+
'colorInput',
|
|
42
|
+
'text',
|
|
43
|
+
'section',
|
|
44
|
+
];
|
|
45
|
+
//# sourceMappingURL=fieldMeta.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fieldMeta.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/fieldMeta.ts"],"names":[],"mappings":";;;AAAA,6CAS2B;AAKd,QAAA,WAAW,GAAqC;IACzD,SAAS,EAAE,YAAY;IACvB,QAAQ,EAAE,WAAW;IACrB,MAAM,EAAE,QAAQ;IAChB,mBAAmB,EAAE,iBAAiB;IACtC,MAAM,EAAE,QAAQ;IAChB,UAAU,EAAE,aAAa;IACzB,IAAI,EAAE,aAAa;IACnB,OAAO,EAAE,SAAS;CACrB,CAAC;AAEW,QAAA,cAAc,GAAqC;IAC5D,SAAS,EAAE,MAAM;IACjB,QAAQ,EAAE,WAAW;IACrB,MAAM,EAAE,QAAQ;IAChB,mBAAmB,EAAE,OAAO;IAC5B,MAAM,EAAE,QAAQ;IAChB,UAAU,EAAE,OAAO;IACnB,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,SAAS;CACrB,CAAC;AAEW,QAAA,UAAU,GAAuC;IAC1D,SAAS,EAAE,kBAAU;IACrB,QAAQ,EAAE,qBAAa;IACvB,MAAM,EAAE,8BAAsB;IAC9B,mBAAmB,EAAE,iBAAS;IAC9B,MAAM,EAAE,gBAAQ;IAChB,UAAU,EAAE,eAAO;IACnB,IAAI,EAAE,kBAAU;IAChB,OAAO,EAAE,cAAM;CAClB,CAAC;AAEW,QAAA,WAAW,GAAuB;IAC3C,WAAW;IACX,UAAU;IACV,QAAQ;IACR,qBAAqB;IACrB,QAAQ;IACR,YAAY;IACZ,MAAM;IACN,SAAS;CACZ,CAAC","sourcesContent":["import {\n ChevronsExpandVertical,\n CircleInfo,\n Cubes3,\n Droplet,\n FontCursor,\n ListCheck,\n TextAlignLeft,\n ToggleOn,\n} from '@gravity-ui/icons';\nimport type {IconData} from '@gravity-ui/uikit';\n\nimport type {BuilderFieldType} from '../types';\n\nexport const TYPE_LABELS: Record<BuilderFieldType, string> = {\n textInput: 'Text input',\n textArea: 'Text area',\n select: 'Select',\n segmentedRadioGroup: 'Segmented radio',\n switch: 'Switch',\n colorInput: 'Color input',\n text: 'Static text',\n section: 'Section',\n};\n\nexport const PALETTE_LABELS: Record<BuilderFieldType, string> = {\n textInput: 'Text',\n textArea: 'Text area',\n select: 'Select',\n segmentedRadioGroup: 'Radio',\n switch: 'Switch',\n colorInput: 'Color',\n text: 'Hint',\n section: 'Section',\n};\n\nexport const TYPE_ICONS: Record<BuilderFieldType, IconData> = {\n textInput: FontCursor,\n textArea: TextAlignLeft,\n select: ChevronsExpandVertical,\n segmentedRadioGroup: ListCheck,\n switch: ToggleOn,\n colorInput: Droplet,\n text: CircleInfo,\n section: Cubes3,\n};\n\nexport const FIELD_TYPES: BuilderFieldType[] = [\n 'textInput',\n 'textArea',\n 'select',\n 'segmentedRadioGroup',\n 'switch',\n 'colorInput',\n 'text',\n 'section',\n];\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { FormField } from "../types.js";
|
|
2
|
+
export declare const ARRAY_ITEM_PREFIX = "items[{{index}}].";
|
|
3
|
+
export declare const prefixNameForArrayMode: (name: string) => string;
|
|
4
|
+
export declare const stripArrayModePrefix: (name: string) => string;
|
|
5
|
+
export declare const collectNames: (fields: FormField[]) => Set<string>;
|
|
6
|
+
export declare const cloneFieldWithNewIds: (field: FormField, generateId: () => string, existingNames: Set<string>) => FormField;
|
|
7
|
+
export declare const transformChildNames: (fields: FormField[], transform: (name: string) => string) => FormField[];
|
|
8
|
+
export declare const maxIdNumericSuffix: (fields: FormField[]) => number;
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.maxIdNumericSuffix = exports.transformChildNames = exports.cloneFieldWithNewIds = exports.collectNames = exports.stripArrayModePrefix = exports.prefixNameForArrayMode = exports.ARRAY_ITEM_PREFIX = void 0;
|
|
4
|
+
const treeWalk_1 = require("./treeWalk.js");
|
|
5
|
+
exports.ARRAY_ITEM_PREFIX = 'items[{{index}}].';
|
|
6
|
+
const prefixNameForArrayMode = (name) => name.includes('{{index}}') ? name : `${exports.ARRAY_ITEM_PREFIX}${name}`;
|
|
7
|
+
exports.prefixNameForArrayMode = prefixNameForArrayMode;
|
|
8
|
+
const stripArrayModePrefix = (name) => name.startsWith(exports.ARRAY_ITEM_PREFIX) ? name.slice(exports.ARRAY_ITEM_PREFIX.length) : name;
|
|
9
|
+
exports.stripArrayModePrefix = stripArrayModePrefix;
|
|
10
|
+
const collectNames = (fields) => {
|
|
11
|
+
const names = new Set();
|
|
12
|
+
(0, treeWalk_1.walkFields)(fields, (field) => {
|
|
13
|
+
if (field.type !== 'section' && field.type !== 'text') {
|
|
14
|
+
names.add(field.name);
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
return names;
|
|
18
|
+
};
|
|
19
|
+
exports.collectNames = collectNames;
|
|
20
|
+
const extractBaseName = (name) => {
|
|
21
|
+
const m = name.match(/^(.+?)_copy(?:_\d+)?$/);
|
|
22
|
+
return m ? m[1] : name;
|
|
23
|
+
};
|
|
24
|
+
const findUniqueCopyName = (originalName, existing) => {
|
|
25
|
+
const stem = extractBaseName(originalName);
|
|
26
|
+
let candidate = `${stem}_copy`;
|
|
27
|
+
let n = 2;
|
|
28
|
+
while (existing.has(candidate)) {
|
|
29
|
+
candidate = `${stem}_copy_${n}`;
|
|
30
|
+
n += 1;
|
|
31
|
+
}
|
|
32
|
+
return candidate;
|
|
33
|
+
};
|
|
34
|
+
const cloneFieldWithNewIds = (field, generateId, existingNames) => {
|
|
35
|
+
const newId = generateId();
|
|
36
|
+
if (field.type === 'section') {
|
|
37
|
+
return {
|
|
38
|
+
...field,
|
|
39
|
+
id: newId,
|
|
40
|
+
title: field.title ? `${field.title} (copy)` : 'Section (copy)',
|
|
41
|
+
fields: field.fields.map((child) => (0, exports.cloneFieldWithNewIds)(child, generateId, existingNames)),
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
if (field.type === 'text') {
|
|
45
|
+
return { ...field, id: newId };
|
|
46
|
+
}
|
|
47
|
+
const newName = findUniqueCopyName(field.name, existingNames);
|
|
48
|
+
existingNames.add(newName);
|
|
49
|
+
return { ...field, id: newId, name: newName };
|
|
50
|
+
};
|
|
51
|
+
exports.cloneFieldWithNewIds = cloneFieldWithNewIds;
|
|
52
|
+
const transformChildNames = (fields, transform) => fields.map((field) => {
|
|
53
|
+
if (field.type === 'section') {
|
|
54
|
+
return { ...field, fields: (0, exports.transformChildNames)(field.fields, transform) };
|
|
55
|
+
}
|
|
56
|
+
if (field.type === 'text') {
|
|
57
|
+
return field;
|
|
58
|
+
}
|
|
59
|
+
return { ...field, name: transform(field.name) };
|
|
60
|
+
});
|
|
61
|
+
exports.transformChildNames = transformChildNames;
|
|
62
|
+
const maxIdNumericSuffix = (fields) => {
|
|
63
|
+
let max = 0;
|
|
64
|
+
(0, treeWalk_1.walkFields)(fields, (field) => {
|
|
65
|
+
const match = /^fb2_(\d+)$/.exec(field.id);
|
|
66
|
+
if (match) {
|
|
67
|
+
const n = parseInt(match[1] ?? '0', 10);
|
|
68
|
+
if (n > max)
|
|
69
|
+
max = n;
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
return max;
|
|
73
|
+
};
|
|
74
|
+
exports.maxIdNumericSuffix = maxIdNumericSuffix;
|
|
75
|
+
//# sourceMappingURL=fieldNames.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fieldNames.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/fieldNames.ts"],"names":[],"mappings":"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","sourcesContent":["import {FormField} from '../types';\n\nimport {walkFields} from './treeWalk';\n\nexport const ARRAY_ITEM_PREFIX = 'items[{{index}}].';\n\nexport const prefixNameForArrayMode = (name: string): string =>\n name.includes('{{index}}') ? name : `${ARRAY_ITEM_PREFIX}${name}`;\n\nexport const stripArrayModePrefix = (name: string): string =>\n name.startsWith(ARRAY_ITEM_PREFIX) ? name.slice(ARRAY_ITEM_PREFIX.length) : name;\n\nexport const collectNames = (fields: FormField[]): Set<string> => {\n const names = new Set<string>();\n walkFields(fields, (field) => {\n if (field.type !== 'section' && field.type !== 'text') {\n names.add(field.name);\n }\n });\n return names;\n};\n\nconst extractBaseName = (name: string): string => {\n const m = name.match(/^(.+?)_copy(?:_\\d+)?$/);\n return m ? m[1] : name;\n};\n\nconst findUniqueCopyName = (originalName: string, existing: Set<string>): string => {\n const stem = extractBaseName(originalName);\n let candidate = `${stem}_copy`;\n let n = 2;\n while (existing.has(candidate)) {\n candidate = `${stem}_copy_${n}`;\n n += 1;\n }\n return candidate;\n};\n\nexport const cloneFieldWithNewIds = (\n field: FormField,\n generateId: () => string,\n existingNames: Set<string>,\n): FormField => {\n const newId = generateId();\n if (field.type === 'section') {\n return {\n ...field,\n id: newId,\n title: field.title ? `${field.title} (copy)` : 'Section (copy)',\n fields: field.fields.map((child) =>\n cloneFieldWithNewIds(child, generateId, existingNames),\n ),\n };\n }\n if (field.type === 'text') {\n return {...field, id: newId};\n }\n const newName = findUniqueCopyName(field.name, existingNames);\n existingNames.add(newName);\n return {...field, id: newId, name: newName};\n};\n\nexport const transformChildNames = (\n fields: FormField[],\n transform: (name: string) => string,\n): FormField[] =>\n fields.map((field) => {\n if (field.type === 'section') {\n return {...field, fields: transformChildNames(field.fields, transform)};\n }\n if (field.type === 'text') {\n return field;\n }\n return {...field, name: transform(field.name)};\n });\n\nexport const maxIdNumericSuffix = (fields: FormField[]): number => {\n let max = 0;\n walkFields(fields, (field) => {\n const match = /^fb2_(\\d+)$/.exec(field.id);\n if (match) {\n const n = parseInt(match[1] ?? '0', 10);\n if (n > max) max = n;\n }\n });\n return max;\n};\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.findFieldById = void 0;
|
|
4
|
+
const treeWalk_1 = require("./treeWalk.js");
|
|
5
|
+
const findFieldById = (fields, id) => (0, treeWalk_1.findField)(fields, (field) => field.id === id);
|
|
6
|
+
exports.findFieldById = findFieldById;
|
|
7
|
+
//# sourceMappingURL=fieldTree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fieldTree.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/fieldTree.ts"],"names":[],"mappings":";;;AAEA,4CAAqC;AAE9B,MAAM,aAAa,GAAG,CAAC,MAAmB,EAAE,EAAU,EAAoB,EAAE,CAC/E,IAAA,oBAAS,EAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;AADrC,QAAA,aAAa,iBACwB","sourcesContent":["import type {FormField} from '../types';\n\nimport {findField} from './treeWalk';\n\nexport const findFieldById = (fields: FormField[], id: string): FormField | null =>\n findField(fields, (field) => field.id === id);\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { FieldUpdate, FormField } from "../types.js";
|
|
2
|
+
export declare const updateFieldDeep: (fields: FormField[], fieldId: string, updates: FieldUpdate) => FormField[];
|
|
3
|
+
export declare const removeFieldDeep: (fields: FormField[], fieldId: string) => FormField[];
|
|
4
|
+
export declare const addChildToSectionDeep: (fields: FormField[], sectionId: string, newChild: FormField) => FormField[];
|
|
5
|
+
export declare const containsId: (field: FormField, id: string) => boolean;
|
|
6
|
+
export declare const isArrayModeSection: (fields: FormField[], sectionId: string) => boolean;
|
|
7
|
+
export declare const insertAtTargetDeep: (fields: FormField[], targetId: string, offset: 0 | 1, makeField: (arrayMode: boolean) => FormField) => FormField[] | null;
|
|
8
|
+
export declare const duplicateFieldDeep: (fields: FormField[], fieldId: string, generateId: () => string, existingNames: Set<string>) => FormField[] | null;
|
|
9
|
+
export interface SwapResult {
|
|
10
|
+
fields: FormField[];
|
|
11
|
+
handled: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare const swapInListDeep: (fields: FormField[], fieldId: string, delta: -1 | 1) => SwapResult;
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.swapInListDeep = exports.duplicateFieldDeep = exports.insertAtTargetDeep = exports.isArrayModeSection = exports.containsId = exports.addChildToSectionDeep = exports.removeFieldDeep = exports.updateFieldDeep = void 0;
|
|
4
|
+
const fieldNames_1 = require("./fieldNames.js");
|
|
5
|
+
const treeWalk_1 = require("./treeWalk.js");
|
|
6
|
+
const updateFieldDeep = (fields, fieldId, updates) => {
|
|
7
|
+
return fields.map((field) => {
|
|
8
|
+
if (field.id === fieldId) {
|
|
9
|
+
return {
|
|
10
|
+
...field,
|
|
11
|
+
...updates,
|
|
12
|
+
id: field.id,
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
if (field.type === 'section') {
|
|
16
|
+
return {
|
|
17
|
+
...field,
|
|
18
|
+
fields: (0, exports.updateFieldDeep)(field.fields, fieldId, updates),
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
return field;
|
|
22
|
+
});
|
|
23
|
+
};
|
|
24
|
+
exports.updateFieldDeep = updateFieldDeep;
|
|
25
|
+
const removeFieldDeep = (fields, fieldId) => {
|
|
26
|
+
const filtered = fields.filter((field) => field.id !== fieldId);
|
|
27
|
+
return filtered.map((field) => field.type === 'section'
|
|
28
|
+
? { ...field, fields: (0, exports.removeFieldDeep)(field.fields, fieldId) }
|
|
29
|
+
: field);
|
|
30
|
+
};
|
|
31
|
+
exports.removeFieldDeep = removeFieldDeep;
|
|
32
|
+
const addChildToSectionDeep = (fields, sectionId, newChild) => {
|
|
33
|
+
return fields.map((field) => {
|
|
34
|
+
if (field.id === sectionId && field.type === 'section') {
|
|
35
|
+
return { ...field, fields: [...field.fields, newChild] };
|
|
36
|
+
}
|
|
37
|
+
if (field.type === 'section') {
|
|
38
|
+
return {
|
|
39
|
+
...field,
|
|
40
|
+
fields: (0, exports.addChildToSectionDeep)(field.fields, sectionId, newChild),
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
return field;
|
|
44
|
+
});
|
|
45
|
+
};
|
|
46
|
+
exports.addChildToSectionDeep = addChildToSectionDeep;
|
|
47
|
+
const containsId = (field, id) => (0, treeWalk_1.findField)([field], (f) => f.id === id) !== null;
|
|
48
|
+
exports.containsId = containsId;
|
|
49
|
+
const isArrayModeSection = (fields, sectionId) => {
|
|
50
|
+
const section = (0, treeWalk_1.findField)(fields, (f) => f.id === sectionId);
|
|
51
|
+
return section?.type === 'section' && Boolean(section.index);
|
|
52
|
+
};
|
|
53
|
+
exports.isArrayModeSection = isArrayModeSection;
|
|
54
|
+
const insertAtTargetDeep = (fields, targetId, offset, makeField) => (0, treeWalk_1.transformAtId)(fields, targetId, (siblings, index, parent) => {
|
|
55
|
+
const arrayMode = Boolean(parent?.index);
|
|
56
|
+
const newField = makeField(arrayMode);
|
|
57
|
+
return [...siblings.slice(0, index + offset), newField, ...siblings.slice(index + offset)];
|
|
58
|
+
});
|
|
59
|
+
exports.insertAtTargetDeep = insertAtTargetDeep;
|
|
60
|
+
const duplicateFieldDeep = (fields, fieldId, generateId, existingNames) => (0, treeWalk_1.transformAtId)(fields, fieldId, (siblings, index) => {
|
|
61
|
+
const clone = (0, fieldNames_1.cloneFieldWithNewIds)(siblings[index], generateId, existingNames);
|
|
62
|
+
return [...siblings.slice(0, index + 1), clone, ...siblings.slice(index + 1)];
|
|
63
|
+
});
|
|
64
|
+
exports.duplicateFieldDeep = duplicateFieldDeep;
|
|
65
|
+
const swapInListDeep = (fields, fieldId, delta) => {
|
|
66
|
+
let didSwap = false;
|
|
67
|
+
const result = (0, treeWalk_1.transformAtId)(fields, fieldId, (siblings, index) => {
|
|
68
|
+
const target = index + delta;
|
|
69
|
+
if (target < 0 || target >= siblings.length) {
|
|
70
|
+
return siblings;
|
|
71
|
+
}
|
|
72
|
+
const next = [...siblings];
|
|
73
|
+
[next[index], next[target]] = [next[target], next[index]];
|
|
74
|
+
didSwap = true;
|
|
75
|
+
return next;
|
|
76
|
+
});
|
|
77
|
+
return result === null || !didSwap ? { fields, handled: false } : { fields: result, handled: true };
|
|
78
|
+
};
|
|
79
|
+
exports.swapInListDeep = swapInListDeep;
|
|
80
|
+
//# sourceMappingURL=fieldTreeOps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fieldTreeOps.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/fieldTreeOps.ts"],"names":[],"mappings":"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","sourcesContent":["import {BuilderSectionField, FieldUpdate, FormField} from '../types';\n\nimport {cloneFieldWithNewIds} from './fieldNames';\nimport {findField, transformAtId} from './treeWalk';\n\nexport const updateFieldDeep = (\n fields: FormField[],\n fieldId: string,\n updates: FieldUpdate,\n): FormField[] => {\n return fields.map((field) => {\n if (field.id === fieldId) {\n return {\n ...field,\n ...(updates as Partial<FormField>),\n id: field.id,\n } as FormField;\n }\n if (field.type === 'section') {\n return {\n ...field,\n fields: updateFieldDeep(field.fields, fieldId, updates),\n } as BuilderSectionField;\n }\n return field;\n });\n};\n\nexport const removeFieldDeep = (fields: FormField[], fieldId: string): FormField[] => {\n const filtered = fields.filter((field) => field.id !== fieldId);\n return filtered.map((field) =>\n field.type === 'section'\n ? ({...field, fields: removeFieldDeep(field.fields, fieldId)} as BuilderSectionField)\n : field,\n );\n};\n\nexport const addChildToSectionDeep = (\n fields: FormField[],\n sectionId: string,\n newChild: FormField,\n): FormField[] => {\n return fields.map((field) => {\n if (field.id === sectionId && field.type === 'section') {\n return {...field, fields: [...field.fields, newChild]};\n }\n if (field.type === 'section') {\n return {\n ...field,\n fields: addChildToSectionDeep(field.fields, sectionId, newChild),\n };\n }\n return field;\n });\n};\n\nexport const containsId = (field: FormField, id: string): boolean =>\n findField([field], (f) => f.id === id) !== null;\n\nexport const isArrayModeSection = (fields: FormField[], sectionId: string): boolean => {\n const section = findField(fields, (f) => f.id === sectionId);\n return section?.type === 'section' && Boolean(section.index);\n};\n\nexport const insertAtTargetDeep = (\n fields: FormField[],\n targetId: string,\n offset: 0 | 1,\n makeField: (arrayMode: boolean) => FormField,\n): FormField[] | null =>\n transformAtId(fields, targetId, (siblings, index, parent) => {\n const arrayMode = Boolean(parent?.index);\n const newField = makeField(arrayMode);\n return [...siblings.slice(0, index + offset), newField, ...siblings.slice(index + offset)];\n });\n\nexport const duplicateFieldDeep = (\n fields: FormField[],\n fieldId: string,\n generateId: () => string,\n existingNames: Set<string>,\n): FormField[] | null =>\n transformAtId(fields, fieldId, (siblings, index) => {\n const clone = cloneFieldWithNewIds(siblings[index], generateId, existingNames);\n return [...siblings.slice(0, index + 1), clone, ...siblings.slice(index + 1)];\n });\n\nexport interface SwapResult {\n fields: FormField[];\n handled: boolean;\n}\n\nexport const swapInListDeep = (fields: FormField[], fieldId: string, delta: -1 | 1): SwapResult => {\n let didSwap = false;\n const result = transformAtId(fields, fieldId, (siblings, index) => {\n const target = index + delta;\n if (target < 0 || target >= siblings.length) {\n return siblings;\n }\n const next = [...siblings];\n [next[index], next[target]] = [next[target], next[index]];\n didSwap = true;\n return next;\n });\n return result === null || !didSwap ? {fields, handled: false} : {fields: result, handled: true};\n};\n"]}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.parseSchema = void 0;
|
|
4
|
+
const VALID_TYPES = new Set([
|
|
5
|
+
'textInput',
|
|
6
|
+
'textArea',
|
|
7
|
+
'select',
|
|
8
|
+
'segmentedRadioGroup',
|
|
9
|
+
'switch',
|
|
10
|
+
'colorInput',
|
|
11
|
+
'text',
|
|
12
|
+
'section',
|
|
13
|
+
]);
|
|
14
|
+
const TYPES_REQUIRING_NAME = new Set([
|
|
15
|
+
'textInput',
|
|
16
|
+
'textArea',
|
|
17
|
+
'select',
|
|
18
|
+
'segmentedRadioGroup',
|
|
19
|
+
'switch',
|
|
20
|
+
'colorInput',
|
|
21
|
+
]);
|
|
22
|
+
const TYPES_WITH_OPTIONS = new Set(['select', 'segmentedRadioGroup']);
|
|
23
|
+
const validateField = (obj, here) => {
|
|
24
|
+
const type = obj.type;
|
|
25
|
+
if (TYPES_REQUIRING_NAME.has(type) && typeof obj.name !== 'string') {
|
|
26
|
+
throw new Error(`${here}: field of type "${type}" requires "name"`);
|
|
27
|
+
}
|
|
28
|
+
if (TYPES_WITH_OPTIONS.has(type)) {
|
|
29
|
+
if (!Array.isArray(obj.options) || obj.options.length === 0) {
|
|
30
|
+
throw new Error(`${here}: field of type "${type}" requires non-empty "options" array`);
|
|
31
|
+
}
|
|
32
|
+
obj.options.forEach((opt, i) => {
|
|
33
|
+
if (!opt || typeof opt !== 'object') {
|
|
34
|
+
throw new Error(`${here}.options[${i}]: expected object`);
|
|
35
|
+
}
|
|
36
|
+
const o = opt;
|
|
37
|
+
if (typeof o.value !== 'string' || typeof o.content !== 'string') {
|
|
38
|
+
throw new Error(`${here}.options[${i}]: "value" and "content" must be strings`);
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
if (type === 'text' && typeof obj.text !== 'string') {
|
|
43
|
+
throw new Error(`${here}: field of type "text" requires "text" string`);
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
const validateAndAssignIds = (raw, path, nextId) => {
|
|
47
|
+
const seenNames = new Set();
|
|
48
|
+
return raw.map((item, i) => {
|
|
49
|
+
const here = `${path}[${i}]`;
|
|
50
|
+
if (!item || typeof item !== 'object') {
|
|
51
|
+
throw new Error(`${here}: expected object, got ${typeof item}`);
|
|
52
|
+
}
|
|
53
|
+
const obj = item;
|
|
54
|
+
if (typeof obj.type !== 'string' || !VALID_TYPES.has(obj.type)) {
|
|
55
|
+
throw new Error(`${here}: unknown field type "${String(obj.type)}"`);
|
|
56
|
+
}
|
|
57
|
+
validateField(obj, here);
|
|
58
|
+
if (typeof obj.name === 'string') {
|
|
59
|
+
if (seenNames.has(obj.name)) {
|
|
60
|
+
throw new Error(`${here}: duplicate name "${obj.name}"`);
|
|
61
|
+
}
|
|
62
|
+
seenNames.add(obj.name);
|
|
63
|
+
}
|
|
64
|
+
if (obj.type === 'section') {
|
|
65
|
+
const nested = Array.isArray(obj.fields)
|
|
66
|
+
? validateAndAssignIds(obj.fields, `${here}.fields`, nextId)
|
|
67
|
+
: [];
|
|
68
|
+
return { ...obj, id: nextId(), fields: nested };
|
|
69
|
+
}
|
|
70
|
+
return { ...obj, id: nextId() };
|
|
71
|
+
});
|
|
72
|
+
};
|
|
73
|
+
const parseSchema = (input) => {
|
|
74
|
+
const trimmed = input.trim();
|
|
75
|
+
if (!trimmed) {
|
|
76
|
+
return { ok: false, error: 'Schema is empty' };
|
|
77
|
+
}
|
|
78
|
+
let parsed;
|
|
79
|
+
try {
|
|
80
|
+
parsed = JSON.parse(trimmed);
|
|
81
|
+
}
|
|
82
|
+
catch (e) {
|
|
83
|
+
return { ok: false, error: `JSON parse error: ${e.message}` };
|
|
84
|
+
}
|
|
85
|
+
if (!Array.isArray(parsed)) {
|
|
86
|
+
return { ok: false, error: 'Schema must be a JSON array of fields' };
|
|
87
|
+
}
|
|
88
|
+
let counter = 0;
|
|
89
|
+
const nextId = () => {
|
|
90
|
+
counter += 1;
|
|
91
|
+
return `imp_${counter}`;
|
|
92
|
+
};
|
|
93
|
+
try {
|
|
94
|
+
const fields = validateAndAssignIds(parsed, '', nextId);
|
|
95
|
+
return { ok: true, fields };
|
|
96
|
+
}
|
|
97
|
+
catch (e) {
|
|
98
|
+
return { ok: false, error: e.message };
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
exports.parseSchema = parseSchema;
|
|
102
|
+
//# sourceMappingURL=parseSchema.js.map
|