@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,133 @@
|
|
|
1
|
+
.pcformbuilderv2-canvas-card {
|
|
2
|
+
position: relative;
|
|
3
|
+
padding: var(--g-spacing-3) var(--g-spacing-3);
|
|
4
|
+
border: 1px solid transparent;
|
|
5
|
+
border-radius: var(--g-border-radius-l);
|
|
6
|
+
cursor: pointer;
|
|
7
|
+
transition: background-color 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
|
|
8
|
+
}
|
|
9
|
+
.pcformbuilderv2-canvas-card:hover {
|
|
10
|
+
background-color: var(--g-color-base-simple-hover);
|
|
11
|
+
}
|
|
12
|
+
.pcformbuilderv2-canvas-card:hover > .pcformbuilderv2-canvas-card__controls {
|
|
13
|
+
opacity: 1;
|
|
14
|
+
}
|
|
15
|
+
.pcformbuilderv2-canvas-card_selected {
|
|
16
|
+
border-color: var(--g-color-line-brand);
|
|
17
|
+
background-color: var(--g-color-base-selection);
|
|
18
|
+
}
|
|
19
|
+
.pcformbuilderv2-canvas-card_selected .pcformbuilderv2-canvas-card__controls {
|
|
20
|
+
opacity: 1;
|
|
21
|
+
}
|
|
22
|
+
.pcformbuilderv2-canvas-card_dragging {
|
|
23
|
+
opacity: 0.4;
|
|
24
|
+
}
|
|
25
|
+
.pcformbuilderv2-canvas-card_drop-target, .pcformbuilderv2-canvas-card_drop-target-after {
|
|
26
|
+
position: relative;
|
|
27
|
+
}
|
|
28
|
+
.pcformbuilderv2-canvas-card_drop-target::before, .pcformbuilderv2-canvas-card_drop-target-after::before {
|
|
29
|
+
content: "";
|
|
30
|
+
position: absolute;
|
|
31
|
+
left: 0;
|
|
32
|
+
right: 0;
|
|
33
|
+
height: 3px;
|
|
34
|
+
background: var(--g-color-line-brand);
|
|
35
|
+
border-radius: 2px;
|
|
36
|
+
opacity: 0.45;
|
|
37
|
+
pointer-events: none;
|
|
38
|
+
}
|
|
39
|
+
.pcformbuilderv2-canvas-card_drop-target::before {
|
|
40
|
+
top: calc((var(--g-spacing-3) + 3px) / -2 - 1px);
|
|
41
|
+
}
|
|
42
|
+
.pcformbuilderv2-canvas-card_drop-target-after::before {
|
|
43
|
+
bottom: calc((var(--g-spacing-3) + 3px) / -2 - 1px);
|
|
44
|
+
}
|
|
45
|
+
.pcformbuilderv2-canvas-card__visibility-badge {
|
|
46
|
+
margin-bottom: var(--g-spacing-1);
|
|
47
|
+
}
|
|
48
|
+
.pcformbuilderv2-canvas-card__controls {
|
|
49
|
+
position: absolute;
|
|
50
|
+
top: var(--g-spacing-1);
|
|
51
|
+
right: var(--g-spacing-2);
|
|
52
|
+
display: flex;
|
|
53
|
+
align-items: center;
|
|
54
|
+
gap: var(--g-spacing-half);
|
|
55
|
+
opacity: 0;
|
|
56
|
+
transition: opacity 0.15s ease;
|
|
57
|
+
}
|
|
58
|
+
.pcformbuilderv2-canvas-card__control {
|
|
59
|
+
display: inline-flex;
|
|
60
|
+
align-items: center;
|
|
61
|
+
justify-content: center;
|
|
62
|
+
width: var(--g-spacing-5);
|
|
63
|
+
height: var(--g-spacing-5);
|
|
64
|
+
padding: 0;
|
|
65
|
+
border: none;
|
|
66
|
+
background: transparent;
|
|
67
|
+
color: var(--g-color-text-secondary);
|
|
68
|
+
cursor: grab;
|
|
69
|
+
border-radius: var(--g-border-radius-s);
|
|
70
|
+
}
|
|
71
|
+
.pcformbuilderv2-canvas-card__control:hover {
|
|
72
|
+
background-color: var(--g-color-base-simple-hover-solid);
|
|
73
|
+
color: var(--g-color-text-primary);
|
|
74
|
+
}
|
|
75
|
+
.pcformbuilderv2-canvas-card__control:active {
|
|
76
|
+
cursor: grabbing;
|
|
77
|
+
}
|
|
78
|
+
.pcformbuilderv2-canvas-card__labeled {
|
|
79
|
+
display: flex;
|
|
80
|
+
flex-direction: column;
|
|
81
|
+
gap: var(--g-spacing-1);
|
|
82
|
+
}
|
|
83
|
+
.pcformbuilderv2-canvas-card__labeled-title {
|
|
84
|
+
display: flex;
|
|
85
|
+
align-items: baseline;
|
|
86
|
+
gap: var(--g-spacing-2);
|
|
87
|
+
}
|
|
88
|
+
.pcformbuilderv2-canvas-card__section-header {
|
|
89
|
+
display: flex;
|
|
90
|
+
align-items: center;
|
|
91
|
+
gap: var(--g-spacing-2);
|
|
92
|
+
padding-bottom: var(--g-spacing-1);
|
|
93
|
+
border-bottom: 1px solid var(--g-color-line-generic);
|
|
94
|
+
}
|
|
95
|
+
.pcformbuilderv2-canvas-card__children {
|
|
96
|
+
margin-top: var(--g-spacing-2);
|
|
97
|
+
padding-left: var(--g-spacing-3);
|
|
98
|
+
border-left: 2px solid var(--g-color-line-generic);
|
|
99
|
+
display: flex;
|
|
100
|
+
flex-direction: column;
|
|
101
|
+
gap: var(--g-spacing-2);
|
|
102
|
+
border-radius: 0 var(--g-border-radius-m) var(--g-border-radius-m) 0;
|
|
103
|
+
transition: border-color 0.12s ease, background-color 0.12s ease;
|
|
104
|
+
}
|
|
105
|
+
.pcformbuilderv2-canvas-card__children_drop-target {
|
|
106
|
+
border-left-color: var(--g-color-line-brand);
|
|
107
|
+
background-color: var(--g-color-base-selection);
|
|
108
|
+
}
|
|
109
|
+
.pcformbuilderv2-canvas-card__children .pcformbuilderv2-canvas-card_drop-target::before {
|
|
110
|
+
top: calc((var(--g-spacing-2) + 3px) / -2 - 1px);
|
|
111
|
+
}
|
|
112
|
+
.pcformbuilderv2-canvas-card__children .pcformbuilderv2-canvas-card_drop-target-after::before {
|
|
113
|
+
bottom: calc((var(--g-spacing-2) + 3px) / -2 - 1px);
|
|
114
|
+
}
|
|
115
|
+
.pcformbuilderv2-canvas-card__static-text {
|
|
116
|
+
padding: var(--g-spacing-2) 10px;
|
|
117
|
+
border-radius: var(--g-border-radius-s);
|
|
118
|
+
}
|
|
119
|
+
.pcformbuilderv2-canvas-card__color-swatch {
|
|
120
|
+
display: flex;
|
|
121
|
+
align-items: center;
|
|
122
|
+
gap: var(--g-spacing-2);
|
|
123
|
+
}
|
|
124
|
+
.pcformbuilderv2-canvas-card__color-swatch-chip {
|
|
125
|
+
width: var(--g-spacing-6);
|
|
126
|
+
height: var(--g-spacing-6);
|
|
127
|
+
border: 1px solid var(--g-color-line-generic);
|
|
128
|
+
border-radius: var(--g-border-radius-s);
|
|
129
|
+
}
|
|
130
|
+
.pcformbuilderv2-canvas-card__color-swatch-value {
|
|
131
|
+
font-size: var(--g-text-body-1-font-size);
|
|
132
|
+
color: var(--g-color-text-secondary);
|
|
133
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { FormField } from "../../types.js";
|
|
2
|
+
import { SectionDropData } from "./components/SectionChildrenDropZone.js";
|
|
3
|
+
import './CanvasCard.css';
|
|
4
|
+
export type { SectionDropData };
|
|
5
|
+
interface CanvasCardProps {
|
|
6
|
+
field: FormField;
|
|
7
|
+
index: number;
|
|
8
|
+
group: string;
|
|
9
|
+
}
|
|
10
|
+
export declare const CanvasCard: ({ field, index, group }: CanvasCardProps) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { CollisionPriority } from '@dnd-kit/abstract';
|
|
4
|
+
import { SortableKeyboardPlugin, isSortable } from '@dnd-kit/dom/sortable';
|
|
5
|
+
import { useSortable } from '@dnd-kit/react/sortable';
|
|
6
|
+
import { Copy, Grip, TrashBin } from '@gravity-ui/icons';
|
|
7
|
+
import { Button, Icon, Label } from '@gravity-ui/uikit';
|
|
8
|
+
import { useFormContext } from "../../hooks/FormContext.js";
|
|
9
|
+
import { formBuilderV2Cn } from "../../utils/cn.js";
|
|
10
|
+
import { isDropAfter, isPaletteData } from "../../utils/dragData.js";
|
|
11
|
+
import { FieldPreview } from "./components/FieldPreview.js";
|
|
12
|
+
import { SectionChildrenDropZone } from "./components/SectionChildrenDropZone.js";
|
|
13
|
+
import './CanvasCard.css';
|
|
14
|
+
const b = formBuilderV2Cn('canvas-card');
|
|
15
|
+
export const CanvasCard = ({ field, index, group }) => {
|
|
16
|
+
const { selectedFieldId, selectField, removeField, duplicateField } = useFormContext();
|
|
17
|
+
const isSelected = selectedFieldId === field.id;
|
|
18
|
+
const hasWhen = 'when' in field && Array.isArray(field.when) && field.when.length > 0;
|
|
19
|
+
const cardData = React.useMemo(() => ({ kind: 'card', group }), [group]);
|
|
20
|
+
const { ref, handleRef, isDragSource, isDropTarget, sortable } = useSortable({
|
|
21
|
+
id: field.id,
|
|
22
|
+
index,
|
|
23
|
+
group,
|
|
24
|
+
data: cardData,
|
|
25
|
+
transition: null,
|
|
26
|
+
plugins: [SortableKeyboardPlugin],
|
|
27
|
+
collisionPriority: field.type === 'section' ? CollisionPriority.Low : undefined,
|
|
28
|
+
alignment: {
|
|
29
|
+
x: 'start',
|
|
30
|
+
y: 'center',
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
const dragOp = sortable.manager?.dragOperation;
|
|
34
|
+
const source = dragOp?.source;
|
|
35
|
+
const isPaletteSource = isPaletteData(source?.data);
|
|
36
|
+
const sourceIndex = source && isSortable(source) ? source.index : undefined;
|
|
37
|
+
const pointerY = dragOp?.position?.current?.y;
|
|
38
|
+
const targetCenterY = sortable.droppable?.shape?.center?.y;
|
|
39
|
+
const dropAfter = isDropTarget &&
|
|
40
|
+
!isDragSource &&
|
|
41
|
+
(isPaletteSource
|
|
42
|
+
? isDropAfter(pointerY, targetCenterY)
|
|
43
|
+
: sourceIndex !== undefined && sourceIndex < index);
|
|
44
|
+
const handleClick = (event) => {
|
|
45
|
+
event.stopPropagation();
|
|
46
|
+
selectField(field.id);
|
|
47
|
+
};
|
|
48
|
+
const handleKeyDown = (event) => {
|
|
49
|
+
if (event.key === 'Enter' || event.key === ' ') {
|
|
50
|
+
event.preventDefault();
|
|
51
|
+
event.stopPropagation();
|
|
52
|
+
selectField(field.id);
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
return (_jsxs("div", { ref: ref, className: b({
|
|
56
|
+
selected: isSelected,
|
|
57
|
+
dragging: isDragSource,
|
|
58
|
+
'drop-target': isDropTarget && !isDragSource && !dropAfter,
|
|
59
|
+
'drop-target-after': dropAfter,
|
|
60
|
+
}), onClick: handleClick, onKeyDown: handleKeyDown, role: "button", tabIndex: 0, "aria-pressed": isSelected, children: [hasWhen && (_jsx("div", { className: b('visibility-badge'), children: _jsx(Label, { theme: "info", size: "s", children: "Visibility by condition" }) })), _jsx(FieldPreview, { field: field }), _jsxs("div", { className: b('controls'), children: [_jsx(Button, { ref: handleRef, view: "flat", size: "xs", className: b('control'), "aria-label": "Drag to reorder", title: "Drag to reorder", onClick: (event) => event.stopPropagation(), children: _jsx(Icon, { data: Grip, size: 12 }) }), _jsx(Button, { view: "flat", size: "xs", onClick: (event) => {
|
|
61
|
+
event.stopPropagation();
|
|
62
|
+
duplicateField(field.id);
|
|
63
|
+
}, title: "Duplicate", children: _jsx(Icon, { data: Copy, size: 12 }) }), _jsx(Button, { view: "flat-danger", size: "xs", onClick: (event) => {
|
|
64
|
+
event.stopPropagation();
|
|
65
|
+
removeField(field.id);
|
|
66
|
+
}, title: "Remove", children: _jsx(Icon, { data: TrashBin, size: 12 }) })] }), field.type === 'section' && (_jsx(SectionChildrenDropZone, { sectionId: field.id, fields: field.fields }))] }));
|
|
67
|
+
};
|
|
68
|
+
//# sourceMappingURL=CanvasCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CanvasCard.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/CanvasCard/CanvasCard.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {CollisionPriority} from '@dnd-kit/abstract';\nimport {SortableKeyboardPlugin, isSortable} from '@dnd-kit/dom/sortable';\nimport {useSortable} from '@dnd-kit/react/sortable';\nimport {Copy, Grip, TrashBin} from '@gravity-ui/icons';\nimport {Button, Icon, Label} from '@gravity-ui/uikit';\n\nimport {useFormContext} from '../../hooks/FormContext';\nimport {FormField} from '../../types';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport type {CardDragData} from '../../utils/dragData';\nimport {isDropAfter, isPaletteData} from '../../utils/dragData';\n\nimport {FieldPreview} from './components/FieldPreview';\nimport {SectionChildrenDropZone, SectionDropData} from './components/SectionChildrenDropZone';\n\nimport './CanvasCard.scss';\n\nexport type {SectionDropData};\n\nconst b = formBuilderV2Cn('canvas-card');\n\ninterface CanvasCardProps {\n field: FormField;\n index: number;\n group: string;\n}\n\nexport const CanvasCard = ({field, index, group}: CanvasCardProps) => {\n const {selectedFieldId, selectField, removeField, duplicateField} = useFormContext();\n\n const isSelected = selectedFieldId === field.id;\n const hasWhen = 'when' in field && Array.isArray(field.when) && field.when.length > 0;\n\n const cardData: CardDragData = React.useMemo(() => ({kind: 'card', group}), [group]);\n\n const {ref, handleRef, isDragSource, isDropTarget, sortable} = useSortable({\n id: field.id,\n index,\n group,\n data: cardData,\n transition: null,\n plugins: [SortableKeyboardPlugin],\n collisionPriority: field.type === 'section' ? CollisionPriority.Low : undefined,\n alignment: {\n x: 'start',\n y: 'center',\n },\n });\n\n const dragOp = sortable.manager?.dragOperation;\n const source = dragOp?.source;\n const isPaletteSource = isPaletteData(source?.data);\n const sourceIndex = source && isSortable(source) ? source.index : undefined;\n const pointerY = dragOp?.position?.current?.y;\n const targetCenterY = sortable.droppable?.shape?.center?.y;\n\n const dropAfter =\n isDropTarget &&\n !isDragSource &&\n (isPaletteSource\n ? isDropAfter(pointerY, targetCenterY)\n : sourceIndex !== undefined && sourceIndex < index);\n\n const handleClick = (event: React.MouseEvent) => {\n event.stopPropagation();\n selectField(field.id);\n };\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n event.stopPropagation();\n selectField(field.id);\n }\n };\n\n return (\n <div\n ref={ref}\n className={b({\n selected: isSelected,\n dragging: isDragSource,\n 'drop-target': isDropTarget && !isDragSource && !dropAfter,\n 'drop-target-after': dropAfter,\n })}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n role=\"button\"\n tabIndex={0}\n aria-pressed={isSelected}\n >\n {hasWhen && (\n <div className={b('visibility-badge')}>\n <Label theme=\"info\" size=\"s\">\n Visibility by condition\n </Label>\n </div>\n )}\n <FieldPreview field={field} />\n\n <div className={b('controls')}>\n <Button\n ref={handleRef}\n view=\"flat\"\n size=\"xs\"\n className={b('control')}\n aria-label=\"Drag to reorder\"\n title=\"Drag to reorder\"\n onClick={(event) => event.stopPropagation()}\n >\n <Icon data={Grip} size={12} />\n </Button>\n <Button\n view=\"flat\"\n size=\"xs\"\n onClick={(event) => {\n event.stopPropagation();\n duplicateField(field.id);\n }}\n title=\"Duplicate\"\n >\n <Icon data={Copy} size={12} />\n </Button>\n <Button\n view=\"flat-danger\"\n size=\"xs\"\n onClick={(event) => {\n event.stopPropagation();\n removeField(field.id);\n }}\n title=\"Remove\"\n >\n <Icon data={TrashBin} size={12} />\n </Button>\n </div>\n\n {field.type === 'section' && (\n <SectionChildrenDropZone sectionId={field.id} fields={field.fields} />\n )}\n </div>\n );\n};\n"]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { Label, Text } from '@gravity-ui/uikit';
|
|
4
|
+
import { cloneDeep, set, unset } from 'lodash';
|
|
5
|
+
import { componentMap } from "../../../../form-generator-v2/components/constants.js";
|
|
6
|
+
import { useCanvasContent } from "../../../CanvasContentContext.js";
|
|
7
|
+
import { formBuilderV2Cn } from "../../../utils/cn.js";
|
|
8
|
+
const b = formBuilderV2Cn('canvas-card');
|
|
9
|
+
const isTemplateField = (field) => 'name' in field && typeof field.name === 'string' && field.name.includes('{{index}}');
|
|
10
|
+
const makeOnUpdate = (setContent) => (key, value, options) => {
|
|
11
|
+
setContent((prev) => {
|
|
12
|
+
const next = cloneDeep(prev);
|
|
13
|
+
if (options?.unset) {
|
|
14
|
+
unset(next, key);
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
set(next, key, value);
|
|
18
|
+
}
|
|
19
|
+
return next;
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
export const FieldPreview = ({ field }) => {
|
|
23
|
+
const { content, setContent, templateContent, setTemplateContent } = useCanvasContent();
|
|
24
|
+
const onUpdateForContent = React.useMemo(() => makeOnUpdate(setContent), [setContent]);
|
|
25
|
+
const onUpdateForTemplate = React.useMemo(() => makeOnUpdate(setTemplateContent), [setTemplateContent]);
|
|
26
|
+
if (field.type === 'section') {
|
|
27
|
+
return (_jsxs("div", { className: b('section-header'), children: [_jsx(Text, { variant: "subheader-2", children: field.title || 'Section' }), field.index ? (_jsxs(Label, { theme: "info", size: "s", children: ["Array \u00B7 ", field.itemTitle ?? 'Item {{index}}'] })) : (_jsx(Label, { theme: "unknown", size: "s", children: "Group" }))] }));
|
|
28
|
+
}
|
|
29
|
+
const Component = componentMap[field.type];
|
|
30
|
+
if (!Component) {
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
const { when: _when, id: _id, ...fieldProps } = field;
|
|
34
|
+
const useTemplate = isTemplateField(field);
|
|
35
|
+
const widgetContent = useTemplate ? templateContent : content;
|
|
36
|
+
const onUpdate = useTemplate ? onUpdateForTemplate : onUpdateForContent;
|
|
37
|
+
return (_jsx(Component, { ...fieldProps, content: widgetContent, onUpdate: onUpdate }));
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=FieldPreview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldPreview.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/CanvasCard/components/FieldPreview.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {Label, Text} from '@gravity-ui/uikit';\nimport {cloneDeep, set, unset} from 'lodash';\n\nimport {componentMap} from '../../../../form-generator-v2/components/constants';\nimport type {Content, OnUpdate} from '../../../../form-generator-v2/types';\nimport {useCanvasContent} from '../../../CanvasContentContext';\nimport {FormField} from '../../../types';\nimport {formBuilderV2Cn} from '../../../utils/cn';\n\nconst b = formBuilderV2Cn('canvas-card');\n\nconst isTemplateField = (field: FormField): boolean =>\n 'name' in field && typeof field.name === 'string' && field.name.includes('{{index}}');\n\nconst makeOnUpdate =\n (setContent: React.Dispatch<React.SetStateAction<Content>>): OnUpdate =>\n (key, value, options) => {\n setContent((prev) => {\n const next = cloneDeep(prev);\n if (options?.unset) {\n unset(next, key);\n } else {\n set(next, key, value);\n }\n return next;\n });\n };\n\ninterface FieldPreviewProps {\n field: FormField;\n}\n\nexport const FieldPreview = ({field}: FieldPreviewProps) => {\n const {content, setContent, templateContent, setTemplateContent} = useCanvasContent();\n\n const onUpdateForContent = React.useMemo<OnUpdate>(\n () => makeOnUpdate(setContent),\n [setContent],\n );\n const onUpdateForTemplate = React.useMemo<OnUpdate>(\n () => makeOnUpdate(setTemplateContent),\n [setTemplateContent],\n );\n\n if (field.type === 'section') {\n return (\n <div className={b('section-header')}>\n <Text variant=\"subheader-2\">{field.title || 'Section'}</Text>\n {field.index ? (\n <Label theme=\"info\" size=\"s\">\n Array · {field.itemTitle ?? 'Item {{index}}'}\n </Label>\n ) : (\n <Label theme=\"unknown\" size=\"s\">\n Group\n </Label>\n )}\n </div>\n );\n }\n\n const Component = componentMap[field.type] as\n | React.ComponentType<Record<string, unknown>>\n | undefined;\n if (!Component) {\n return null;\n }\n\n const {when: _when, id: _id, ...fieldProps} = field;\n\n const useTemplate = isTemplateField(field);\n const widgetContent = useTemplate ? templateContent : content;\n const onUpdate = useTemplate ? onUpdateForTemplate : onUpdateForContent;\n\n return (\n <Component\n {...(fieldProps as Record<string, unknown>)}\n content={widgetContent}\n onUpdate={onUpdate}\n />\n );\n};\n"]}
|
package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { FormField } from "../../../types.js";
|
|
2
|
+
import type { SectionDropData } from "../../../utils/dragData.js";
|
|
3
|
+
export declare const SECTION_DROP_PREFIX = "section-drop:";
|
|
4
|
+
export type { SectionDropData };
|
|
5
|
+
interface SectionChildrenDropZoneProps {
|
|
6
|
+
sectionId: string;
|
|
7
|
+
fields: FormField[];
|
|
8
|
+
}
|
|
9
|
+
export declare const SectionChildrenDropZone: ({ sectionId, fields }: SectionChildrenDropZoneProps) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useDroppable } from '@dnd-kit/react';
|
|
3
|
+
import { Text } from '@gravity-ui/uikit';
|
|
4
|
+
import { formBuilderV2Cn } from "../../../utils/cn.js";
|
|
5
|
+
import { CanvasList } from "../../Canvas/Canvas.js";
|
|
6
|
+
const b = formBuilderV2Cn('canvas-card');
|
|
7
|
+
export const SECTION_DROP_PREFIX = 'section-drop:';
|
|
8
|
+
export const SectionChildrenDropZone = ({ sectionId, fields }) => {
|
|
9
|
+
const { ref, isDropTarget } = useDroppable({
|
|
10
|
+
id: `${SECTION_DROP_PREFIX}${sectionId}`,
|
|
11
|
+
data: { kind: 'section-drop', sectionId },
|
|
12
|
+
});
|
|
13
|
+
const className = b('children');
|
|
14
|
+
return (_jsxs("div", { ref: ref, className: `${className}${isDropTarget ? ` ${className}_drop-target` : ''}`, children: [_jsx(CanvasList, { fields: fields, parentGroup: `section:${sectionId}` }), fields.length === 0 && (_jsx(Text, { variant: "body-2", color: "hint", children: "Empty section. Drag a tile from the palette into this box, or select the section first and click a tile to add it inside." }))] }));
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=SectionChildrenDropZone.js.map
|
package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SectionChildrenDropZone.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAC,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAGvC,OAAO,EAAC,eAAe,EAAC,6BAA0B;AAElD,OAAO,EAAC,UAAU,EAAC,+BAA4B;AAE/C,MAAM,CAAC,GAAG,eAAe,CAAC,aAAa,CAAC,CAAC;AAEzC,MAAM,CAAC,MAAM,mBAAmB,GAAG,eAAe,CAAC;AASnD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,EAAC,SAAS,EAAE,MAAM,EAA+B,EAAE,EAAE;IACzF,MAAM,EAAC,GAAG,EAAE,YAAY,EAAC,GAAG,YAAY,CAAC;QACrC,EAAE,EAAE,GAAG,mBAAmB,GAAG,SAAS,EAAE;QACxC,IAAI,EAAE,EAAC,IAAI,EAAE,cAAc,EAAE,SAAS,EAAC;KAC1C,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC;IAEhC,OAAO,CACH,eAAK,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,SAAS,GAAG,YAAY,CAAC,CAAC,CAAC,IAAI,SAAS,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,aACtF,KAAC,UAAU,IAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,SAAS,EAAE,GAAI,EAClE,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,CACpB,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,MAAM,0IAG5B,CACV,IACC,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import {useDroppable} from '@dnd-kit/react';\nimport {Text} from '@gravity-ui/uikit';\n\nimport {FormField} from '../../../types';\nimport {formBuilderV2Cn} from '../../../utils/cn';\nimport type {SectionDropData} from '../../../utils/dragData';\nimport {CanvasList} from '../../Canvas/Canvas';\n\nconst b = formBuilderV2Cn('canvas-card');\n\nexport const SECTION_DROP_PREFIX = 'section-drop:';\n\nexport type {SectionDropData};\n\ninterface SectionChildrenDropZoneProps {\n sectionId: string;\n fields: FormField[];\n}\n\nexport const SectionChildrenDropZone = ({sectionId, fields}: SectionChildrenDropZoneProps) => {\n const {ref, isDropTarget} = useDroppable({\n id: `${SECTION_DROP_PREFIX}${sectionId}`,\n data: {kind: 'section-drop', sectionId},\n });\n\n const className = b('children');\n\n return (\n <div ref={ref} className={`${className}${isDropTarget ? ` ${className}_drop-target` : ''}`}>\n <CanvasList fields={fields} parentGroup={`section:${sectionId}`} />\n {fields.length === 0 && (\n <Text variant=\"body-2\" color=\"hint\">\n Empty section. Drag a tile from the palette into this box, or select the section\n first and click a tile to add it inside.\n </Text>\n )}\n </div>\n );\n};\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
.pcformbuilderv2-content-tab {
|
|
2
|
+
display: grid;
|
|
3
|
+
grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
|
|
4
|
+
gap: var(--g-spacing-4);
|
|
5
|
+
margin-top: var(--g-spacing-4);
|
|
6
|
+
}
|
|
7
|
+
.pcformbuilderv2-content-tab__column {
|
|
8
|
+
padding: var(--g-spacing-4);
|
|
9
|
+
}
|
|
10
|
+
.pcformbuilderv2-content-tab__title {
|
|
11
|
+
display: block;
|
|
12
|
+
margin-bottom: var(--g-spacing-3);
|
|
13
|
+
}
|
|
14
|
+
.pcformbuilderv2-content-tab__json {
|
|
15
|
+
margin: 0;
|
|
16
|
+
padding: var(--g-spacing-3);
|
|
17
|
+
background: var(--g-color-base-generic);
|
|
18
|
+
border-radius: var(--g-border-radius-m);
|
|
19
|
+
font-size: 12px;
|
|
20
|
+
overflow: auto;
|
|
21
|
+
max-height: 70vh;
|
|
22
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { Card, Text } from '@gravity-ui/uikit';
|
|
4
|
+
import FormGenerator from "../../../form-generator-v2/FormGenerator.js";
|
|
5
|
+
import { useCanvasContent } from "../../CanvasContentContext.js";
|
|
6
|
+
import { useFormContext } from "../../hooks/FormContext.js";
|
|
7
|
+
import { formBuilderV2Cn } from "../../utils/cn.js";
|
|
8
|
+
import { stripIds } from "../../utils/stripIds.js";
|
|
9
|
+
import './ContentTab.css';
|
|
10
|
+
const b = formBuilderV2Cn('content-tab');
|
|
11
|
+
export const ContentTab = () => {
|
|
12
|
+
const { formFields } = useFormContext();
|
|
13
|
+
const { content, setContent } = useCanvasContent();
|
|
14
|
+
const schema = React.useMemo(() => stripIds(formFields), [formFields]);
|
|
15
|
+
return (_jsxs("div", { className: b(), children: [_jsxs(Card, { className: b('column'), view: "outlined", children: [_jsx(Text, { variant: "subheader-2", className: b('title'), children: "Live form" }), schema.length > 0 ? (_jsx(FormGenerator, { blockConfig: schema, contentConfig: content, onUpdate: setContent })) : (_jsx(Text, { variant: "body-2", color: "hint", children: "Add fields on the Visual tab to see the form here." }))] }), _jsxs(Card, { className: b('column'), view: "outlined", children: [_jsx(Text, { variant: "subheader-2", className: b('title'), children: "Content JSON" }), _jsx("pre", { className: b('json'), children: JSON.stringify(content, null, 2) })] })] }));
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=ContentTab.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ContentTab.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/ContentTab/ContentTab.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,IAAI,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE7C,OAAO,aAAa,oDAAiD;AACrE,OAAO,EAAC,gBAAgB,EAAC,sCAAmC;AAC5D,OAAO,EAAC,cAAc,EAAC,mCAAgC;AACvD,OAAO,EAAC,eAAe,EAAC,0BAAuB;AAC/C,OAAO,EAAC,QAAQ,EAAC,gCAA6B;AAE9C,OAAO,kBAAkB,CAAC;AAE1B,MAAM,CAAC,GAAG,eAAe,CAAC,aAAa,CAAC,CAAC;AAEzC,MAAM,CAAC,MAAM,UAAU,GAAG,GAAG,EAAE;IAC3B,MAAM,EAAC,UAAU,EAAC,GAAG,cAAc,EAAE,CAAC;IACtC,MAAM,EAAC,OAAO,EAAE,UAAU,EAAC,GAAG,gBAAgB,EAAE,CAAC;IAEjD,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAEvE,OAAO,CACH,eAAK,SAAS,EAAE,CAAC,EAAE,aACf,MAAC,IAAI,IAAC,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAC,UAAU,aACzC,KAAC,IAAI,IAAC,OAAO,EAAC,aAAa,EAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,0BAE1C,EACN,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CACjB,KAAC,aAAa,IACV,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,OAAO,EACtB,QAAQ,EAAE,UAAU,GACtB,CACL,CAAC,CAAC,CAAC,CACA,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,MAAM,mEAE5B,CACV,IACE,EACP,MAAC,IAAI,IAAC,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAC,UAAU,aACzC,KAAC,IAAI,IAAC,OAAO,EAAC,aAAa,EAAC,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,6BAE1C,EACP,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,GAAO,IAChE,IACL,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Card, Text} from '@gravity-ui/uikit';\n\nimport FormGenerator from '../../../form-generator-v2/FormGenerator';\nimport {useCanvasContent} from '../../CanvasContentContext';\nimport {useFormContext} from '../../hooks/FormContext';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport {stripIds} from '../../utils/stripIds';\n\nimport './ContentTab.scss';\n\nconst b = formBuilderV2Cn('content-tab');\n\nexport const ContentTab = () => {\n const {formFields} = useFormContext();\n const {content, setContent} = useCanvasContent();\n\n const schema = React.useMemo(() => stripIds(formFields), [formFields]);\n\n return (\n <div className={b()}>\n <Card className={b('column')} view=\"outlined\">\n <Text variant=\"subheader-2\" className={b('title')}>\n Live form\n </Text>\n {schema.length > 0 ? (\n <FormGenerator\n blockConfig={schema}\n contentConfig={content}\n onUpdate={setContent}\n />\n ) : (\n <Text variant=\"body-2\" color=\"hint\">\n Add fields on the Visual tab to see the form here.\n </Text>\n )}\n </Card>\n <Card className={b('column')} view=\"outlined\">\n <Text variant=\"subheader-2\" className={b('title')}>\n Content JSON\n </Text>\n <pre className={b('json')}>{JSON.stringify(content, null, 2)}</pre>\n </Card>\n </div>\n );\n};\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
.pcformbuilderv2-drag-overlay {
|
|
2
|
+
display: inline-flex;
|
|
3
|
+
align-items: center;
|
|
4
|
+
gap: var(--g-spacing-2);
|
|
5
|
+
padding: var(--g-spacing-2) var(--g-spacing-3);
|
|
6
|
+
color: var(--g-color-text-primary);
|
|
7
|
+
cursor: grabbing;
|
|
8
|
+
}
|
|
9
|
+
.pcformbuilderv2-drag-overlay__text {
|
|
10
|
+
display: flex;
|
|
11
|
+
align-items: center;
|
|
12
|
+
gap: 6px;
|
|
13
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { BuilderFieldType, FormField } from "../../types.js";
|
|
2
|
+
import './DragOverlayPreview.css';
|
|
3
|
+
interface DragOverlayPreviewProps {
|
|
4
|
+
type: BuilderFieldType;
|
|
5
|
+
field?: FormField;
|
|
6
|
+
}
|
|
7
|
+
export declare const DragOverlayPreview: ({ type, field }: DragOverlayPreviewProps) => import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Card, Icon, Label, Text } from '@gravity-ui/uikit';
|
|
3
|
+
import { formBuilderV2Cn } from "../../utils/cn.js";
|
|
4
|
+
import { TYPE_ICONS, TYPE_LABELS } from "../../utils/fieldMeta.js";
|
|
5
|
+
import './DragOverlayPreview.css';
|
|
6
|
+
const b = formBuilderV2Cn('drag-overlay');
|
|
7
|
+
const getFieldTitle = (f) => {
|
|
8
|
+
if (!f)
|
|
9
|
+
return '';
|
|
10
|
+
if ('title' in f)
|
|
11
|
+
return f.title ?? '';
|
|
12
|
+
if ('text' in f)
|
|
13
|
+
return f.text ?? '';
|
|
14
|
+
return '';
|
|
15
|
+
};
|
|
16
|
+
export const DragOverlayPreview = ({ type, field }) => {
|
|
17
|
+
const name = field && 'name' in field ? field.name : '';
|
|
18
|
+
const title = getFieldTitle(field);
|
|
19
|
+
return (_jsxs(Card, { className: b(), view: "raised", children: [_jsx(Icon, { data: TYPE_ICONS[type], size: 14 }), _jsxs("div", { className: b('text'), children: [_jsx(Text, { variant: "body-2", children: TYPE_LABELS[type] }), (name || title) && (_jsx(Label, { theme: "unknown", size: "s", children: name || title }))] })] }));
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=DragOverlayPreview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DragOverlayPreview.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAG1D,OAAO,EAAC,eAAe,EAAC,0BAAuB;AAC/C,OAAO,EAAC,UAAU,EAAE,WAAW,EAAC,iCAA8B;AAE9D,OAAO,0BAA0B,CAAC;AAElC,MAAM,CAAC,GAAG,eAAe,CAAC,cAAc,CAAC,CAAC;AAO1C,MAAM,aAAa,GAAG,CAAC,CAAwB,EAAU,EAAE;IACvD,IAAI,CAAC,CAAC;QAAE,OAAO,EAAE,CAAC;IAClB,IAAI,OAAO,IAAI,CAAC;QAAE,OAAO,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;IACvC,IAAI,MAAM,IAAI,CAAC;QAAE,OAAO,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;IACrC,OAAO,EAAE,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EAAC,IAAI,EAAE,KAAK,EAA0B,EAAE,EAAE;IACzE,MAAM,IAAI,GAAG,KAAK,IAAI,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;IACxD,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;IAEnC,OAAO,CACH,MAAC,IAAI,IAAC,SAAS,EAAE,CAAC,EAAE,EAAE,IAAI,EAAC,QAAQ,aAC/B,KAAC,IAAI,IAAC,IAAI,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,GAAI,EAC1C,eAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,aACrB,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,YAAE,WAAW,CAAC,IAAI,CAAC,GAAQ,EAChD,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAChB,KAAC,KAAK,IAAC,KAAK,EAAC,SAAS,EAAC,IAAI,EAAC,GAAG,YAC1B,IAAI,IAAI,KAAK,GACV,CACX,IACC,IACH,CACV,CAAC;AACN,CAAC,CAAC","sourcesContent":["import {Card, Icon, Label, Text} from '@gravity-ui/uikit';\n\nimport type {BuilderFieldType, FormField} from '../../types';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport {TYPE_ICONS, TYPE_LABELS} from '../../utils/fieldMeta';\n\nimport './DragOverlayPreview.scss';\n\nconst b = formBuilderV2Cn('drag-overlay');\n\ninterface DragOverlayPreviewProps {\n type: BuilderFieldType;\n field?: FormField;\n}\n\nconst getFieldTitle = (f: FormField | undefined): string => {\n if (!f) return '';\n if ('title' in f) return f.title ?? '';\n if ('text' in f) return f.text ?? '';\n return '';\n};\n\nexport const DragOverlayPreview = ({type, field}: DragOverlayPreviewProps) => {\n const name = field && 'name' in field ? field.name : '';\n const title = getFieldTitle(field);\n\n return (\n <Card className={b()} view=\"raised\">\n <Icon data={TYPE_ICONS[type]} size={14} />\n <div className={b('text')}>\n <Text variant=\"body-2\">{TYPE_LABELS[type]}</Text>\n {(name || title) && (\n <Label theme=\"unknown\" size=\"s\">\n {name || title}\n </Label>\n )}\n </div>\n </Card>\n );\n};\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
.pcformbuilderv2-field-settings__row {
|
|
2
|
+
display: grid;
|
|
3
|
+
grid-template-columns: 100px 1fr;
|
|
4
|
+
align-items: start;
|
|
5
|
+
gap: var(--g-spacing-2);
|
|
6
|
+
}
|
|
7
|
+
.pcformbuilderv2-field-settings__row-label {
|
|
8
|
+
padding-top: 6px;
|
|
9
|
+
font-size: var(--g-text-body-1-font-size);
|
|
10
|
+
line-height: 1.4;
|
|
11
|
+
color: var(--g-color-text-secondary);
|
|
12
|
+
}
|
|
13
|
+
.pcformbuilderv2-field-settings__options {
|
|
14
|
+
display: flex;
|
|
15
|
+
flex-direction: column;
|
|
16
|
+
gap: 6px;
|
|
17
|
+
padding: var(--g-spacing-2);
|
|
18
|
+
border: 1px solid var(--g-color-line-generic);
|
|
19
|
+
border-radius: var(--g-border-radius-m);
|
|
20
|
+
}
|
|
21
|
+
.pcformbuilderv2-field-settings__option-row {
|
|
22
|
+
display: grid;
|
|
23
|
+
grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
|
|
24
|
+
gap: 6px;
|
|
25
|
+
align-items: center;
|
|
26
|
+
}
|
|
27
|
+
.pcformbuilderv2-field-settings__add-option {
|
|
28
|
+
align-self: flex-start;
|
|
29
|
+
margin-top: var(--g-spacing-1);
|
|
30
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { TextInput } from '@gravity-ui/uikit';
|
|
4
|
+
import { useFormContext } from "../../hooks/FormContext.js";
|
|
5
|
+
import { collectNames } from "../../utils/fieldNames.js";
|
|
6
|
+
import { WhenEditor } from "../WhenEditor/WhenEditor.js";
|
|
7
|
+
import { ColorInputSettings } from "./fields/ColorInputSettings.js";
|
|
8
|
+
import { OptionsSettings } from "./fields/OptionsSettings.js";
|
|
9
|
+
import { Row } from "./fields/Row.js";
|
|
10
|
+
import { SectionSettings } from "./fields/SectionSettings.js";
|
|
11
|
+
import { SwitchSettings } from "./fields/SwitchSettings.js";
|
|
12
|
+
import { TextFieldSettings } from "./fields/TextFieldSettings.js";
|
|
13
|
+
import { TextSettings } from "./fields/TextSettings.js";
|
|
14
|
+
import './FieldSettings.css';
|
|
15
|
+
export const FieldSettings = ({ field }) => {
|
|
16
|
+
const { updateField, formFields } = useFormContext();
|
|
17
|
+
const availableFields = React.useMemo(() => {
|
|
18
|
+
const all = Array.from(collectNames(formFields));
|
|
19
|
+
if (field.type === 'section' || field.type === 'text')
|
|
20
|
+
return all;
|
|
21
|
+
return all.filter((n) => n !== field.name);
|
|
22
|
+
}, [formFields, field]);
|
|
23
|
+
const whenEditorSection = (_jsx(Row, { label: "Visible when", children: _jsx(WhenEditor, { when: field.when, availableFields: availableFields, onChange: (next) => updateField(field.id, { when: next }) }) }));
|
|
24
|
+
const commonRows = (_jsxs(React.Fragment, { children: [_jsx(Row, { label: "Title", children: _jsx(TextInput, { value: 'title' in field ? (field.title ?? '') : '', onUpdate: (value) => updateField(field.id, { title: value }), placeholder: "Label shown above the field" }) }), _jsx(Row, { label: "Name", children: _jsx(TextInput, { value: 'name' in field ? (field.name ?? '') : '', onUpdate: (value) => updateField(field.id, { name: value }), placeholder: "Path in content object" }) })] }));
|
|
25
|
+
if (field.type === 'section') {
|
|
26
|
+
return (_jsx(SectionSettings, { field: field, updateField: updateField, whenEditorSection: whenEditorSection }));
|
|
27
|
+
}
|
|
28
|
+
if (field.type === 'text') {
|
|
29
|
+
return (_jsx(TextSettings, { field: field, updateField: updateField, whenEditorSection: whenEditorSection }));
|
|
30
|
+
}
|
|
31
|
+
if (field.type === 'textInput' || field.type === 'textArea') {
|
|
32
|
+
return (_jsx(TextFieldSettings, { field: field, updateField: updateField, commonRows: commonRows, whenEditorSection: whenEditorSection }));
|
|
33
|
+
}
|
|
34
|
+
if (field.type === 'switch') {
|
|
35
|
+
return (_jsx(SwitchSettings, { field: field, updateField: updateField, commonRows: commonRows, whenEditorSection: whenEditorSection }));
|
|
36
|
+
}
|
|
37
|
+
if (field.type === 'colorInput') {
|
|
38
|
+
return (_jsx(ColorInputSettings, { field: field, updateField: updateField, commonRows: commonRows, whenEditorSection: whenEditorSection }));
|
|
39
|
+
}
|
|
40
|
+
if (field.type === 'select' || field.type === 'segmentedRadioGroup') {
|
|
41
|
+
return (_jsx(OptionsSettings, { field: field, updateField: updateField, commonRows: commonRows, whenEditorSection: whenEditorSection }));
|
|
42
|
+
}
|
|
43
|
+
return null;
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=FieldSettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FieldSettings.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/FieldSettings/FieldSettings.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {TextInput} from '@gravity-ui/uikit';\n\nimport type {When} from '../../../form-generator-v2/types';\nimport {useFormContext} from '../../hooks/FormContext';\nimport {FormField} from '../../types';\nimport {collectNames} from '../../utils/fieldNames';\nimport {WhenEditor} from '../WhenEditor/WhenEditor';\n\nimport {ColorInputSettings} from './fields/ColorInputSettings';\nimport {OptionsSettings} from './fields/OptionsSettings';\nimport {Row} from './fields/Row';\nimport {SectionSettings} from './fields/SectionSettings';\nimport {SwitchSettings} from './fields/SwitchSettings';\nimport {TextFieldSettings} from './fields/TextFieldSettings';\nimport {TextSettings} from './fields/TextSettings';\n\nimport './FieldSettings.scss';\n\ninterface FieldSettingsProps {\n field: FormField;\n}\n\nexport const FieldSettings = ({field}: FieldSettingsProps) => {\n const {updateField, formFields} = useFormContext();\n\n const availableFields = React.useMemo(() => {\n const all = Array.from(collectNames(formFields));\n if (field.type === 'section' || field.type === 'text') return all;\n return all.filter((n) => n !== field.name);\n }, [formFields, field]);\n\n const whenEditorSection = (\n <Row label=\"Visible when\">\n <WhenEditor\n when={field.when}\n availableFields={availableFields}\n onChange={(next: When | undefined) => updateField(field.id, {when: next})}\n />\n </Row>\n );\n\n const commonRows = (\n <React.Fragment>\n <Row label=\"Title\">\n <TextInput\n value={'title' in field ? (field.title ?? '') : ''}\n onUpdate={(value) => updateField(field.id, {title: value})}\n placeholder=\"Label shown above the field\"\n />\n </Row>\n <Row label=\"Name\">\n <TextInput\n value={'name' in field ? (field.name ?? '') : ''}\n onUpdate={(value) => updateField(field.id, {name: value})}\n placeholder=\"Path in content object\"\n />\n </Row>\n </React.Fragment>\n );\n\n if (field.type === 'section') {\n return (\n <SectionSettings\n field={field}\n updateField={updateField}\n whenEditorSection={whenEditorSection}\n />\n );\n }\n\n if (field.type === 'text') {\n return (\n <TextSettings\n field={field}\n updateField={updateField}\n whenEditorSection={whenEditorSection}\n />\n );\n }\n\n if (field.type === 'textInput' || field.type === 'textArea') {\n return (\n <TextFieldSettings\n field={field}\n updateField={updateField}\n commonRows={commonRows}\n whenEditorSection={whenEditorSection}\n />\n );\n }\n\n if (field.type === 'switch') {\n return (\n <SwitchSettings\n field={field}\n updateField={updateField}\n commonRows={commonRows}\n whenEditorSection={whenEditorSection}\n />\n );\n }\n\n if (field.type === 'colorInput') {\n return (\n <ColorInputSettings\n field={field}\n updateField={updateField}\n commonRows={commonRows}\n whenEditorSection={whenEditorSection}\n />\n );\n }\n\n if (field.type === 'select' || field.type === 'segmentedRadioGroup') {\n return (\n <OptionsSettings\n field={field}\n updateField={updateField}\n commonRows={commonRows}\n whenEditorSection={whenEditorSection}\n />\n );\n }\n\n return null;\n};\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { BuilderLeafField, FieldUpdate } from "../../../types.js";
|
|
3
|
+
interface ColorInputSettingsProps {
|
|
4
|
+
field: BuilderLeafField & {
|
|
5
|
+
type: 'colorInput';
|
|
6
|
+
};
|
|
7
|
+
updateField: (id: string, updates: FieldUpdate) => void;
|
|
8
|
+
commonRows: React.ReactNode;
|
|
9
|
+
whenEditorSection: React.ReactNode;
|
|
10
|
+
}
|
|
11
|
+
export declare const ColorInputSettings: ({ field, updateField, commonRows, whenEditorSection, }: ColorInputSettingsProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { TextInput } from '@gravity-ui/uikit';
|
|
4
|
+
import { Row } from "./Row.js";
|
|
5
|
+
export const ColorInputSettings = ({ field, updateField, commonRows, whenEditorSection, }) => (_jsxs(React.Fragment, { children: [commonRows, _jsx(Row, { label: "Default", children: _jsx(TextInput, { value: field.defaultValue ?? '', onUpdate: (value) => updateField(field.id, { defaultValue: value || undefined }), placeholder: "#000000" }) }), whenEditorSection] }));
|
|
6
|
+
//# sourceMappingURL=ColorInputSettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ColorInputSettings.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/FieldSettings/fields/ColorInputSettings.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,SAAS,EAAC,MAAM,mBAAmB,CAAC;AAI5C,OAAO,EAAC,GAAG,EAAC,iBAAc;AAS1B,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EAC/B,KAAK,EACL,WAAW,EACX,UAAU,EACV,iBAAiB,GACK,EAAE,EAAE,CAAC,CAC3B,MAAC,KAAK,CAAC,QAAQ,eACV,UAAU,EACX,KAAC,GAAG,IAAC,KAAK,EAAC,SAAS,YAChB,KAAC,SAAS,IACN,KAAK,EAAE,KAAK,CAAC,YAAY,IAAI,EAAE,EAC/B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,EAAE,EAAC,YAAY,EAAE,KAAK,IAAI,SAAS,EAAC,CAAC,EAC9E,WAAW,EAAC,SAAS,GACvB,GACA,EACL,iBAAiB,IACL,CACpB,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {TextInput} from '@gravity-ui/uikit';\n\nimport type {BuilderLeafField, FieldUpdate} from '../../../types';\n\nimport {Row} from './Row';\n\ninterface ColorInputSettingsProps {\n field: BuilderLeafField & {type: 'colorInput'};\n updateField: (id: string, updates: FieldUpdate) => void;\n commonRows: React.ReactNode;\n whenEditorSection: React.ReactNode;\n}\n\nexport const ColorInputSettings = ({\n field,\n updateField,\n commonRows,\n whenEditorSection,\n}: ColorInputSettingsProps) => (\n <React.Fragment>\n {commonRows}\n <Row label=\"Default\">\n <TextInput\n value={field.defaultValue ?? ''}\n onUpdate={(value) => updateField(field.id, {defaultValue: value || undefined})}\n placeholder=\"#000000\"\n />\n </Row>\n {whenEditorSection}\n </React.Fragment>\n);\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { BuilderLeafField, FieldUpdate } from "../../../types.js";
|
|
3
|
+
interface OptionsSettingsProps {
|
|
4
|
+
field: BuilderLeafField & {
|
|
5
|
+
type: 'select' | 'segmentedRadioGroup';
|
|
6
|
+
};
|
|
7
|
+
updateField: (id: string, updates: FieldUpdate) => void;
|
|
8
|
+
commonRows: React.ReactNode;
|
|
9
|
+
whenEditorSection: React.ReactNode;
|
|
10
|
+
}
|
|
11
|
+
export declare const OptionsSettings: ({ field, updateField, commonRows, whenEditorSection, }: OptionsSettingsProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|