@gravity-ui/page-constructor 8.5.0-alpha.2 → 8.5.0-alpha.5
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/blocks/ContentLayout/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/ExtendedFeatures/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/FilterBlock/index.d.ts +1 -1
- package/build/cjs/blocks/FilterBlock/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Form/index.d.ts +1 -1
- package/build/cjs/blocks/Form/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/HeaderSlider/index.d.ts +1 -1
- package/build/cjs/blocks/HeaderSlider/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Icons/index.d.ts +1 -1
- package/build/cjs/blocks/Icons/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Info/index.d.ts +1 -1
- package/build/cjs/blocks/Info/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Map/index.d.ts +1 -1
- package/build/cjs/blocks/Map/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Media/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/PromoFeaturesBlock/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Questions/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Share/index.d.ts +1 -1
- package/build/cjs/blocks/Share/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Slider/index.d.ts +1 -1
- package/build/cjs/blocks/Slider/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Table/index.d.ts +1 -1
- package/build/cjs/blocks/Table/index_deprecated.d.ts +1 -1
- package/build/cjs/blocks/Tabs/index.d.ts +1 -1
- package/build/cjs/blocks/Tabs/index_deprecated.d.ts +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/form-generator-v2/components/constants.d.ts +11 -11
- package/build/cjs/form-generator-v2/index.d.ts +2 -0
- package/build/cjs/form-generator-v2/index.js +8 -0
- package/build/cjs/form-generator-v2/index.js.map +1 -0
- package/build/esm/blocks/ContentLayout/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/ExtendedFeatures/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/FilterBlock/index.d.ts +1 -1
- package/build/esm/blocks/FilterBlock/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Form/index.d.ts +1 -1
- package/build/esm/blocks/Form/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/HeaderSlider/index.d.ts +1 -1
- package/build/esm/blocks/HeaderSlider/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Icons/index.d.ts +1 -1
- package/build/esm/blocks/Icons/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Info/index.d.ts +1 -1
- package/build/esm/blocks/Info/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Map/index.d.ts +1 -1
- package/build/esm/blocks/Map/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Media/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/PromoFeaturesBlock/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Questions/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Share/index.d.ts +1 -1
- package/build/esm/blocks/Share/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Slider/index.d.ts +1 -1
- package/build/esm/blocks/Slider/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Table/index.d.ts +1 -1
- package/build/esm/blocks/Table/index_deprecated.d.ts +1 -1
- package/build/esm/blocks/Tabs/index.d.ts +1 -1
- package/build/esm/blocks/Tabs/index_deprecated.d.ts +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/form-generator-v2/components/constants.d.ts +11 -11
- package/build/esm/form-generator-v2/index.d.ts +2 -0
- package/build/esm/form-generator-v2/index.js +3 -0
- package/build/esm/form-generator-v2/index.js.map +1 -0
- package/package.json +21 -1
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { Content } from "../form-generator-v2/types.js";
|
|
3
|
+
interface CanvasContentContextType {
|
|
4
|
+
content: Content;
|
|
5
|
+
setContent: React.Dispatch<React.SetStateAction<Content>>;
|
|
6
|
+
templateContent: Content;
|
|
7
|
+
setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;
|
|
8
|
+
}
|
|
9
|
+
interface CanvasContentProviderProps {
|
|
10
|
+
content: Content;
|
|
11
|
+
setContent: React.Dispatch<React.SetStateAction<Content>>;
|
|
12
|
+
templateContent: Content;
|
|
13
|
+
setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;
|
|
14
|
+
children: React.ReactNode;
|
|
15
|
+
}
|
|
16
|
+
export declare const CanvasContentProvider: ({ content, setContent, templateContent, setTemplateContent, children, }: CanvasContentProviderProps) => import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
export declare const useCanvasContent: () => CanvasContentContextType;
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
const CanvasContentContext = React.createContext(null);
|
|
4
|
+
export const CanvasContentProvider = ({ content, setContent, templateContent, setTemplateContent, children, }) => {
|
|
5
|
+
const value = React.useMemo(() => ({ content, setContent, templateContent, setTemplateContent }), [content, setContent, templateContent, setTemplateContent]);
|
|
6
|
+
return _jsx(CanvasContentContext.Provider, { value: value, children: children });
|
|
7
|
+
};
|
|
8
|
+
export const useCanvasContent = () => {
|
|
9
|
+
const context = React.useContext(CanvasContentContext);
|
|
10
|
+
if (!context) {
|
|
11
|
+
throw new Error('useCanvasContent must be used within a CanvasContentProvider');
|
|
12
|
+
}
|
|
13
|
+
return context;
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=CanvasContentContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CanvasContentContext.js","sourceRoot":"../../../src","sources":["form-builder-v2/CanvasContentContext.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAW/B,MAAM,oBAAoB,GAAG,KAAK,CAAC,aAAa,CAAkC,IAAI,CAAC,CAAC;AAUxF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,EAClC,OAAO,EACP,UAAU,EACV,eAAe,EACf,kBAAkB,EAClB,QAAQ,GACiB,EAAE,EAAE;IAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CACvB,GAAG,EAAE,CAAC,CAAC,EAAC,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,kBAAkB,EAAC,CAAC,EAClE,CAAC,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,kBAAkB,CAAC,CAC7D,CAAC;IACF,OAAO,KAAC,oBAAoB,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,YAAG,QAAQ,GAAiC,CAAC;AACnG,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAA6B,EAAE;IAC3D,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;IACvD,IAAI,CAAC,OAAO,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;IACpF,CAAC;IACD,OAAO,OAAO,CAAC;AACnB,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport type {Content} from '../form-generator-v2/types';\n\ninterface CanvasContentContextType {\n content: Content;\n setContent: React.Dispatch<React.SetStateAction<Content>>;\n templateContent: Content;\n setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;\n}\n\nconst CanvasContentContext = React.createContext<CanvasContentContextType | null>(null);\n\ninterface CanvasContentProviderProps {\n content: Content;\n setContent: React.Dispatch<React.SetStateAction<Content>>;\n templateContent: Content;\n setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;\n children: React.ReactNode;\n}\n\nexport const CanvasContentProvider = ({\n content,\n setContent,\n templateContent,\n setTemplateContent,\n children,\n}: CanvasContentProviderProps) => {\n const value = React.useMemo<CanvasContentContextType>(\n () => ({content, setContent, templateContent, setTemplateContent}),\n [content, setContent, templateContent, setTemplateContent],\n );\n return <CanvasContentContext.Provider value={value}>{children}</CanvasContentContext.Provider>;\n};\n\nexport const useCanvasContent = (): CanvasContentContextType => {\n const context = React.useContext(CanvasContentContext);\n if (!context) {\n throw new Error('useCanvasContent must be used within a CanvasContentProvider');\n }\n return context;\n};\n"]}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
.pcformbuilderv2-main {
|
|
2
|
+
width: 100%;
|
|
3
|
+
min-width: 640px;
|
|
4
|
+
display: flex;
|
|
5
|
+
flex-direction: column;
|
|
6
|
+
min-height: 0;
|
|
7
|
+
}
|
|
8
|
+
.pcformbuilderv2-main__toolbar {
|
|
9
|
+
display: flex;
|
|
10
|
+
justify-content: space-between;
|
|
11
|
+
align-items: center;
|
|
12
|
+
padding: var(--g-spacing-2) 0;
|
|
13
|
+
gap: var(--g-spacing-3);
|
|
14
|
+
}
|
|
15
|
+
.pcformbuilderv2-main__toolbar-option {
|
|
16
|
+
display: inline-flex;
|
|
17
|
+
align-items: center;
|
|
18
|
+
gap: 6px;
|
|
19
|
+
}
|
|
20
|
+
.pcformbuilderv2-main__schema-popup {
|
|
21
|
+
width: min(560px, 90vw);
|
|
22
|
+
padding: var(--g-spacing-4);
|
|
23
|
+
display: flex;
|
|
24
|
+
flex-direction: column;
|
|
25
|
+
gap: 10px;
|
|
26
|
+
}
|
|
27
|
+
.pcformbuilderv2-main__schema-popup-header {
|
|
28
|
+
display: flex;
|
|
29
|
+
flex-direction: column;
|
|
30
|
+
gap: var(--g-spacing-half);
|
|
31
|
+
}
|
|
32
|
+
.pcformbuilderv2-main__schema-popup-json {
|
|
33
|
+
margin: 0;
|
|
34
|
+
padding: var(--g-spacing-3);
|
|
35
|
+
background: var(--g-color-base-generic);
|
|
36
|
+
border-radius: var(--g-border-radius-m);
|
|
37
|
+
font-size: 12px;
|
|
38
|
+
line-height: 1.4;
|
|
39
|
+
max-height: min(480px, 60vh);
|
|
40
|
+
overflow: auto;
|
|
41
|
+
white-space: pre;
|
|
42
|
+
}
|
|
43
|
+
.pcformbuilderv2-main__schema-popup-actions {
|
|
44
|
+
display: flex;
|
|
45
|
+
gap: var(--g-spacing-2);
|
|
46
|
+
justify-content: flex-end;
|
|
47
|
+
}
|
|
48
|
+
.pcformbuilderv2-main__visual {
|
|
49
|
+
display: grid;
|
|
50
|
+
grid-template-columns: var(--fb2-palette-w, 220px) var(--g-spacing-2) minmax(240px, 1fr) var(--g-spacing-2) var(--fb2-inspector-w, 320px);
|
|
51
|
+
padding: var(--g-spacing-4) 0;
|
|
52
|
+
align-items: stretch;
|
|
53
|
+
}
|
|
54
|
+
.pcformbuilderv2-main__palette, .pcformbuilderv2-main__canvas, .pcformbuilderv2-main__inspector {
|
|
55
|
+
min-width: 0;
|
|
56
|
+
}
|
|
57
|
+
.pcformbuilderv2-main__palette, .pcformbuilderv2-main__inspector {
|
|
58
|
+
position: sticky;
|
|
59
|
+
top: var(--g-spacing-4);
|
|
60
|
+
align-self: start;
|
|
61
|
+
max-height: calc(100vh - 80px);
|
|
62
|
+
overflow-y: auto;
|
|
63
|
+
}
|
|
64
|
+
.pcformbuilderv2-main_compact .pcformbuilderv2-main__visual {
|
|
65
|
+
grid-template-columns: 56px minmax(240px, 1fr) var(--g-spacing-2) var(--fb2-inspector-w, 320px);
|
|
66
|
+
}
|
|
67
|
+
.pcformbuilderv2-main_compact .pcformbuilderv2-main__canvas {
|
|
68
|
+
padding-left: var(--g-spacing-2);
|
|
69
|
+
}
|
|
70
|
+
.pcformbuilderv2-main_compact .pcformbuilderv2-palette {
|
|
71
|
+
padding: 6px;
|
|
72
|
+
}
|
|
73
|
+
.pcformbuilderv2-main_compact .pcformbuilderv2-palette__header {
|
|
74
|
+
display: none;
|
|
75
|
+
}
|
|
76
|
+
.pcformbuilderv2-main_compact .pcformbuilderv2-palette__items {
|
|
77
|
+
grid-template-columns: 1fr;
|
|
78
|
+
}
|
|
79
|
+
.pcformbuilderv2-main_compact .pcformbuilderv2-palette__tile {
|
|
80
|
+
padding: var(--g-spacing-1);
|
|
81
|
+
gap: 0;
|
|
82
|
+
}
|
|
83
|
+
.pcformbuilderv2-main_compact .pcformbuilderv2-palette__tile-label {
|
|
84
|
+
position: absolute;
|
|
85
|
+
width: 1px;
|
|
86
|
+
height: 1px;
|
|
87
|
+
padding: 0;
|
|
88
|
+
margin: -1px;
|
|
89
|
+
overflow: hidden;
|
|
90
|
+
clip: rect(0, 0, 0, 0);
|
|
91
|
+
white-space: nowrap;
|
|
92
|
+
border: 0;
|
|
93
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { FormField } from "./types.js";
|
|
2
|
+
import './FormBuilderV2.css';
|
|
3
|
+
export type FormBuilderDensity = 'full' | 'compact';
|
|
4
|
+
interface FormBuilderV2Props {
|
|
5
|
+
className?: string;
|
|
6
|
+
formFields: FormField[];
|
|
7
|
+
onChange?: (fields: FormField[]) => void;
|
|
8
|
+
density?: FormBuilderDensity;
|
|
9
|
+
}
|
|
10
|
+
export declare const FormBuilderV2: ({ className, formFields, onChange, density, }: FormBuilderV2Props) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { move } from '@dnd-kit/helpers';
|
|
5
|
+
import { DragDropProvider, DragOverlay } from '@dnd-kit/react';
|
|
6
|
+
import { Code, Eye, Pencil } from '@gravity-ui/icons';
|
|
7
|
+
import { Button, Icon, SegmentedRadioGroup } from '@gravity-ui/uikit';
|
|
8
|
+
import { CanvasContentProvider } from "./CanvasContentContext.js";
|
|
9
|
+
import { Canvas } from "./components/Canvas/Canvas.js";
|
|
10
|
+
import { ContentTab } from "./components/ContentTab/ContentTab.js";
|
|
11
|
+
import { DragOverlayPreview } from "./components/DragOverlayPreview/DragOverlayPreview.js";
|
|
12
|
+
import { Inspector } from "./components/Inspector/Inspector.js";
|
|
13
|
+
import { PALETTE_DRAGGABLE_PREFIX, Palette } from "./components/Palette/Palette.js";
|
|
14
|
+
import { ResizeHandle } from "./components/ResizeHandle/ResizeHandle.js";
|
|
15
|
+
import { SchemaPopup } from "./components/SchemaPopup/SchemaPopup.js";
|
|
16
|
+
import { FormProvider, useFormContext } from "./hooks/FormContext.js";
|
|
17
|
+
import { formBuilderV2Cn } from "./utils/cn.js";
|
|
18
|
+
import { isDropAfter, isPaletteData, isSectionDropData } from "./utils/dragData.js";
|
|
19
|
+
import { applyGroupsMap, buildGroupsMap } from "./utils/fieldGroups.js";
|
|
20
|
+
import { findFieldById } from "./utils/fieldTree.js";
|
|
21
|
+
import { stripIds } from "./utils/stripIds.js";
|
|
22
|
+
import './FormBuilderV2.css';
|
|
23
|
+
const b = formBuilderV2Cn('main');
|
|
24
|
+
const PALETTE_MIN = 160;
|
|
25
|
+
const PALETTE_MAX = 400;
|
|
26
|
+
const PALETTE_DEFAULT = 220;
|
|
27
|
+
const INSPECTOR_MIN = 270;
|
|
28
|
+
const INSPECTOR_MAX = 560;
|
|
29
|
+
const INSPECTOR_DEFAULT = 320;
|
|
30
|
+
const FormBuilderShell = ({ className, density }) => {
|
|
31
|
+
const [mode, setMode] = React.useState('edit');
|
|
32
|
+
const [canvasContent, setCanvasContent] = React.useState({});
|
|
33
|
+
const [templateContent, setTemplateContent] = React.useState({});
|
|
34
|
+
const [paletteWidth, setPaletteWidth] = React.useState(PALETTE_DEFAULT);
|
|
35
|
+
const [inspectorWidth, setInspectorWidth] = React.useState(INSPECTOR_DEFAULT);
|
|
36
|
+
const [schemaPopupOpen, setSchemaPopupOpen] = React.useState(false);
|
|
37
|
+
const schemaButtonRef = React.useRef(null);
|
|
38
|
+
const isCompact = density === 'compact';
|
|
39
|
+
const { formFields, setAllFields, addField, addFieldToSection, insertFieldBefore, insertFieldAfter, moveFieldToSection, } = useFormContext();
|
|
40
|
+
const schema = React.useMemo(() => stripIds(formFields), [formFields]);
|
|
41
|
+
const handleDragEnd = React.useCallback((event) => {
|
|
42
|
+
if (event.canceled)
|
|
43
|
+
return;
|
|
44
|
+
const { source, target } = event.operation;
|
|
45
|
+
if (!source)
|
|
46
|
+
return;
|
|
47
|
+
const paletteData = isPaletteData(source.data) ? source.data : null;
|
|
48
|
+
const isPaletteDrag = paletteData !== null || String(source.id).startsWith(PALETTE_DRAGGABLE_PREFIX);
|
|
49
|
+
if (isPaletteDrag) {
|
|
50
|
+
const type = paletteData?.type;
|
|
51
|
+
if (!type)
|
|
52
|
+
return;
|
|
53
|
+
if (!target) {
|
|
54
|
+
addField(type);
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
if (isSectionDropData(target.data)) {
|
|
58
|
+
addFieldToSection(target.data.sectionId, type);
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
if (String(target.id) === String(source.id)) {
|
|
62
|
+
addField(type);
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
const dropAfter = isDropAfter(event.operation.position?.current?.y, target.shape?.center?.y);
|
|
66
|
+
if (dropAfter) {
|
|
67
|
+
insertFieldAfter(String(target.id), type);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
insertFieldBefore(String(target.id), type);
|
|
71
|
+
}
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
if (target && isSectionDropData(target.data)) {
|
|
75
|
+
moveFieldToSection(String(source.id), target.data.sectionId);
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
const groups = buildGroupsMap(formFields);
|
|
79
|
+
const nextGroups = move(groups, event);
|
|
80
|
+
const nextFields = applyGroupsMap(nextGroups);
|
|
81
|
+
setAllFields(nextFields);
|
|
82
|
+
}, [
|
|
83
|
+
addField,
|
|
84
|
+
addFieldToSection,
|
|
85
|
+
formFields,
|
|
86
|
+
insertFieldBefore,
|
|
87
|
+
insertFieldAfter,
|
|
88
|
+
moveFieldToSection,
|
|
89
|
+
setAllFields,
|
|
90
|
+
]);
|
|
91
|
+
const gridStyle = {
|
|
92
|
+
'--fb2-palette-w': `${paletteWidth}px`,
|
|
93
|
+
'--fb2-inspector-w': `${inspectorWidth}px`,
|
|
94
|
+
};
|
|
95
|
+
return (_jsx("div", { className: b({ compact: density === 'compact' }, className), children: _jsxs(CanvasContentProvider, { content: canvasContent, setContent: setCanvasContent, templateContent: templateContent, setTemplateContent: setTemplateContent, children: [_jsxs("div", { className: b('toolbar'), children: [_jsx(SegmentedRadioGroup, { size: "m", value: mode, onUpdate: setMode, options: [
|
|
96
|
+
{
|
|
97
|
+
value: 'edit',
|
|
98
|
+
content: (_jsxs("span", { className: b('toolbar-option'), children: [_jsx(Icon, { data: Pencil, size: 14 }), "Edit"] })),
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
value: 'preview',
|
|
102
|
+
content: (_jsxs("span", { className: b('toolbar-option'), children: [_jsx(Icon, { data: Eye, size: 14 }), "Preview"] })),
|
|
103
|
+
},
|
|
104
|
+
] }), _jsxs(Button, { ref: schemaButtonRef, view: "outlined", size: "m", onClick: () => setSchemaPopupOpen((prev) => !prev), children: [_jsx(Icon, { data: Code, size: 14 }), "Schema"] }), _jsx(SchemaPopup, { schema: schema, onApply: setAllFields, open: schemaPopupOpen, onOpenChange: setSchemaPopupOpen, anchorElement: schemaButtonRef.current })] }), mode === 'edit' ? (_jsxs(DragDropProvider, { onDragEnd: handleDragEnd, children: [_jsxs("div", { className: b('visual'), style: gridStyle, children: [_jsx("aside", { className: b('palette'), children: _jsx(Palette, {}) }), !isCompact && (_jsx(ResizeHandle, { value: paletteWidth, min: PALETTE_MIN, max: PALETTE_MAX, direction: "left", onChange: setPaletteWidth })), _jsx("main", { className: b('canvas'), children: _jsx(Canvas, {}) }), _jsx(ResizeHandle, { value: inspectorWidth, min: INSPECTOR_MIN, max: INSPECTOR_MAX, direction: "right", onChange: setInspectorWidth }), _jsx("aside", { className: b('inspector'), children: _jsx(Inspector, {}) })] }), _jsx(DragOverlay, { dropAnimation: null, children: (source) => {
|
|
105
|
+
if (!source)
|
|
106
|
+
return null;
|
|
107
|
+
if (isPaletteData(source.data)) {
|
|
108
|
+
return _jsx(DragOverlayPreview, { type: source.data.type });
|
|
109
|
+
}
|
|
110
|
+
const field = findFieldById(formFields, String(source.id));
|
|
111
|
+
if (!field)
|
|
112
|
+
return null;
|
|
113
|
+
return _jsx(DragOverlayPreview, { type: field.type, field: field });
|
|
114
|
+
} })] })) : (_jsx(ContentTab, {}))] }) }));
|
|
115
|
+
};
|
|
116
|
+
export const FormBuilderV2 = ({ className, formFields, onChange, density = 'full', }) => {
|
|
117
|
+
return (_jsx(FormProvider, { formFields: formFields, onChange: onChange, children: _jsx(FormBuilderShell, { className: className, density: density }) }));
|
|
118
|
+
};
|
|
119
|
+
//# sourceMappingURL=FormBuilderV2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormBuilderV2.js","sourceRoot":"../../../src","sources":["form-builder-v2/FormBuilderV2.tsx"],"names":[],"mappings":"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","sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nimport type {DragDropEvents} from '@dnd-kit/abstract';\nimport type {DragDropManager, Draggable, Droppable} from '@dnd-kit/dom';\nimport {move} from '@dnd-kit/helpers';\nimport {DragDropProvider, DragOverlay} from '@dnd-kit/react';\nimport {Code, Eye, Pencil} from '@gravity-ui/icons';\nimport {Button, Icon, SegmentedRadioGroup} from '@gravity-ui/uikit';\n\nimport type {Content} from '../form-generator-v2/types';\n\nimport {CanvasContentProvider} from './CanvasContentContext';\nimport {Canvas} from './components/Canvas/Canvas';\nimport {ContentTab} from './components/ContentTab/ContentTab';\nimport {DragOverlayPreview} from './components/DragOverlayPreview/DragOverlayPreview';\nimport {Inspector} from './components/Inspector/Inspector';\nimport {PALETTE_DRAGGABLE_PREFIX, Palette} from './components/Palette/Palette';\nimport {ResizeHandle} from './components/ResizeHandle/ResizeHandle';\nimport {SchemaPopup} from './components/SchemaPopup/SchemaPopup';\nimport {FormProvider, useFormContext} from './hooks/FormContext';\nimport {FormField} from './types';\nimport {formBuilderV2Cn} from './utils/cn';\nimport {isDropAfter, isPaletteData, isSectionDropData} from './utils/dragData';\nimport {applyGroupsMap, buildGroupsMap} from './utils/fieldGroups';\nimport {findFieldById} from './utils/fieldTree';\nimport {stripIds} from './utils/stripIds';\n\nimport './FormBuilderV2.scss';\n\nconst b = formBuilderV2Cn('main');\n\ntype DndEvents = DragDropEvents<Draggable, Droppable, DragDropManager>;\ntype DragEndEvent = Parameters<DndEvents['dragend']>[0];\n\ntype Mode = 'edit' | 'preview';\n\nexport type FormBuilderDensity = 'full' | 'compact';\n\nconst PALETTE_MIN = 160;\nconst PALETTE_MAX = 400;\nconst PALETTE_DEFAULT = 220;\nconst INSPECTOR_MIN = 270;\nconst INSPECTOR_MAX = 560;\nconst INSPECTOR_DEFAULT = 320;\n\ninterface FormBuilderV2Props {\n className?: string;\n formFields: FormField[];\n onChange?: (fields: FormField[]) => void;\n\n density?: FormBuilderDensity;\n}\n\ninterface FormBuilderShellProps {\n className?: string;\n density: FormBuilderDensity;\n}\n\nconst FormBuilderShell = ({className, density}: FormBuilderShellProps) => {\n const [mode, setMode] = React.useState<Mode>('edit');\n const [canvasContent, setCanvasContent] = React.useState<Content>({});\n const [templateContent, setTemplateContent] = React.useState<Content>({});\n const [paletteWidth, setPaletteWidth] = React.useState(PALETTE_DEFAULT);\n const [inspectorWidth, setInspectorWidth] = React.useState(INSPECTOR_DEFAULT);\n const [schemaPopupOpen, setSchemaPopupOpen] = React.useState(false);\n const schemaButtonRef = React.useRef<HTMLButtonElement | null>(null);\n\n const isCompact = density === 'compact';\n\n const {\n formFields,\n setAllFields,\n addField,\n addFieldToSection,\n insertFieldBefore,\n insertFieldAfter,\n moveFieldToSection,\n } = useFormContext();\n\n const schema = React.useMemo(() => stripIds(formFields), [formFields]);\n\n const handleDragEnd = React.useCallback(\n (event: DragEndEvent) => {\n if (event.canceled) return;\n const {source, target} = event.operation;\n if (!source) return;\n\n const paletteData = isPaletteData(source.data) ? source.data : null;\n const isPaletteDrag =\n paletteData !== null || String(source.id).startsWith(PALETTE_DRAGGABLE_PREFIX);\n\n if (isPaletteDrag) {\n const type = paletteData?.type;\n if (!type) return;\n if (!target) {\n addField(type);\n return;\n }\n\n if (isSectionDropData(target.data)) {\n addFieldToSection(target.data.sectionId, type);\n return;\n }\n\n if (String(target.id) === String(source.id)) {\n addField(type);\n return;\n }\n\n const dropAfter = isDropAfter(\n event.operation.position?.current?.y,\n target.shape?.center?.y,\n );\n if (dropAfter) {\n insertFieldAfter(String(target.id), type);\n } else {\n insertFieldBefore(String(target.id), type);\n }\n return;\n }\n\n if (target && isSectionDropData(target.data)) {\n moveFieldToSection(String(source.id), target.data.sectionId);\n return;\n }\n\n const groups = buildGroupsMap(formFields);\n const nextGroups = move(groups, event);\n const nextFields = applyGroupsMap(nextGroups);\n setAllFields(nextFields);\n },\n [\n addField,\n addFieldToSection,\n formFields,\n insertFieldBefore,\n insertFieldAfter,\n moveFieldToSection,\n setAllFields,\n ],\n );\n\n const gridStyle = {\n '--fb2-palette-w': `${paletteWidth}px`,\n '--fb2-inspector-w': `${inspectorWidth}px`,\n } as React.CSSProperties;\n\n return (\n <div className={b({compact: density === 'compact'}, className)}>\n <CanvasContentProvider\n content={canvasContent}\n setContent={setCanvasContent}\n templateContent={templateContent}\n setTemplateContent={setTemplateContent}\n >\n <div className={b('toolbar')}>\n <SegmentedRadioGroup<Mode>\n size=\"m\"\n value={mode}\n onUpdate={setMode}\n options={[\n {\n value: 'edit',\n content: (\n <span className={b('toolbar-option')}>\n <Icon data={Pencil} size={14} />\n Edit\n </span>\n ),\n },\n {\n value: 'preview',\n content: (\n <span className={b('toolbar-option')}>\n <Icon data={Eye} size={14} />\n Preview\n </span>\n ),\n },\n ]}\n />\n <Button\n ref={schemaButtonRef}\n view=\"outlined\"\n size=\"m\"\n onClick={() => setSchemaPopupOpen((prev) => !prev)}\n >\n <Icon data={Code} size={14} />\n Schema\n </Button>\n <SchemaPopup\n schema={schema}\n onApply={setAllFields}\n open={schemaPopupOpen}\n onOpenChange={setSchemaPopupOpen}\n anchorElement={schemaButtonRef.current}\n />\n </div>\n\n {mode === 'edit' ? (\n <DragDropProvider onDragEnd={handleDragEnd}>\n <div className={b('visual')} style={gridStyle}>\n <aside className={b('palette')}>\n <Palette />\n </aside>\n {!isCompact && (\n <ResizeHandle\n value={paletteWidth}\n min={PALETTE_MIN}\n max={PALETTE_MAX}\n direction=\"left\"\n onChange={setPaletteWidth}\n />\n )}\n <main className={b('canvas')}>\n <Canvas />\n </main>\n <ResizeHandle\n value={inspectorWidth}\n min={INSPECTOR_MIN}\n max={INSPECTOR_MAX}\n direction=\"right\"\n onChange={setInspectorWidth}\n />\n <aside className={b('inspector')}>\n <Inspector />\n </aside>\n </div>\n <DragOverlay dropAnimation={null}>\n {(source) => {\n if (!source) return null;\n if (isPaletteData(source.data)) {\n return <DragOverlayPreview type={source.data.type} />;\n }\n const field = findFieldById(formFields, String(source.id));\n if (!field) return null;\n return <DragOverlayPreview type={field.type} field={field} />;\n }}\n </DragOverlay>\n </DragDropProvider>\n ) : (\n <ContentTab />\n )}\n </CanvasContentProvider>\n </div>\n );\n};\n\nexport const FormBuilderV2 = ({\n className,\n formFields,\n onChange,\n density = 'full',\n}: FormBuilderV2Props) => {\n return (\n <FormProvider formFields={formFields} onChange={onChange}>\n <FormBuilderShell className={className} density={density} />\n </FormProvider>\n );\n};\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
.pcformbuilderv2-canvas {
|
|
2
|
+
padding: var(--g-spacing-5);
|
|
3
|
+
min-height: 400px;
|
|
4
|
+
}
|
|
5
|
+
.pcformbuilderv2-canvas__list {
|
|
6
|
+
display: flex;
|
|
7
|
+
flex-direction: column;
|
|
8
|
+
gap: var(--g-spacing-3);
|
|
9
|
+
}
|
|
10
|
+
.pcformbuilderv2-canvas__empty {
|
|
11
|
+
padding: var(--g-spacing-10) var(--g-spacing-5);
|
|
12
|
+
text-align: center;
|
|
13
|
+
border: 1px dashed var(--g-color-line-generic);
|
|
14
|
+
border-radius: var(--g-border-radius-l);
|
|
15
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { FormField } from "../../types.js";
|
|
2
|
+
import './Canvas.css';
|
|
3
|
+
interface CanvasListProps {
|
|
4
|
+
fields: FormField[];
|
|
5
|
+
parentGroup: string;
|
|
6
|
+
}
|
|
7
|
+
declare const CanvasList: ({ fields, parentGroup }: CanvasListProps) => import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export declare const Canvas: () => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export { CanvasList };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Card, Text } from '@gravity-ui/uikit';
|
|
3
|
+
import { useFormContext } from "../../hooks/FormContext.js";
|
|
4
|
+
import { formBuilderV2Cn } from "../../utils/cn.js";
|
|
5
|
+
import { CanvasCard } from "../CanvasCard/CanvasCard.js";
|
|
6
|
+
import './Canvas.css';
|
|
7
|
+
const b = formBuilderV2Cn('canvas');
|
|
8
|
+
const CanvasList = ({ fields, parentGroup }) => (_jsx("div", { className: b('list'), children: fields.map((field, index) => (_jsx(CanvasCard, { field: field, index: index, group: parentGroup }, field.id))) }));
|
|
9
|
+
export const Canvas = () => {
|
|
10
|
+
const { formFields, selectField } = useFormContext();
|
|
11
|
+
return (_jsx(Card, { className: b(), view: "outlined", onClick: () => selectField(null), children: formFields.length === 0 ? (_jsx("div", { className: b('empty'), children: _jsx(Text, { variant: "body-2", color: "hint", children: "Canvas is empty. Click a field type on the left to add it." }) })) : (_jsx(CanvasList, { fields: formFields, parentGroup: "root" })) }));
|
|
12
|
+
};
|
|
13
|
+
export { CanvasList };
|
|
14
|
+
//# sourceMappingURL=Canvas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Canvas.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/Canvas/Canvas.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,IAAI,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAC,cAAc,EAAC,mCAAgC;AAEvD,OAAO,EAAC,eAAe,EAAC,0BAAuB;AAC/C,OAAO,EAAC,UAAU,EAAC,oCAAiC;AAEpD,OAAO,cAAc,CAAC;AAEtB,MAAM,CAAC,GAAG,eAAe,CAAC,QAAQ,CAAC,CAAC;AAOpC,MAAM,UAAU,GAAG,CAAC,EAAC,MAAM,EAAE,WAAW,EAAkB,EAAE,EAAE,CAAC,CAC3D,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACpB,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAC1B,KAAC,UAAU,IAAgB,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,IAAxD,KAAK,CAAC,EAAE,CAAoD,CAChF,CAAC,GACA,CACT,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,EAAE;IACvB,MAAM,EAAC,UAAU,EAAE,WAAW,EAAC,GAAG,cAAc,EAAE,CAAC;IAEnD,OAAO,CACH,KAAC,IAAI,IAAC,SAAS,EAAE,CAAC,EAAE,EAAE,IAAI,EAAC,UAAU,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,YACjE,UAAU,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CACvB,cAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YACtB,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,MAAM,2EAE5B,GACL,CACT,CAAC,CAAC,CAAC,CACA,KAAC,UAAU,IAAC,MAAM,EAAE,UAAU,EAAE,WAAW,EAAC,MAAM,GAAG,CACxD,GACE,CACV,CAAC;AACN,CAAC,CAAC;AAEF,OAAO,EAAC,UAAU,EAAC,CAAC","sourcesContent":["import {Card, Text} from '@gravity-ui/uikit';\n\nimport {useFormContext} from '../../hooks/FormContext';\nimport {FormField} from '../../types';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport {CanvasCard} from '../CanvasCard/CanvasCard';\n\nimport './Canvas.scss';\n\nconst b = formBuilderV2Cn('canvas');\n\ninterface CanvasListProps {\n fields: FormField[];\n parentGroup: string;\n}\n\nconst CanvasList = ({fields, parentGroup}: CanvasListProps) => (\n <div className={b('list')}>\n {fields.map((field, index) => (\n <CanvasCard key={field.id} field={field} index={index} group={parentGroup} />\n ))}\n </div>\n);\n\nexport const Canvas = () => {\n const {formFields, selectField} = useFormContext();\n\n return (\n <Card className={b()} view=\"outlined\" onClick={() => selectField(null)}>\n {formFields.length === 0 ? (\n <div className={b('empty')}>\n <Text variant=\"body-2\" color=\"hint\">\n Canvas is empty. Click a field type on the left to add it.\n </Text>\n </div>\n ) : (\n <CanvasList fields={formFields} parentGroup=\"root\" />\n )}\n </Card>\n );\n};\n\nexport {CanvasList};\n"]}
|
|
@@ -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
|