@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,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OptionsSettings = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const icons_1 = require("@gravity-ui/icons");
|
|
8
|
+
const uikit_1 = require("@gravity-ui/uikit");
|
|
9
|
+
const cn_1 = require("../../../utils/cn.js");
|
|
10
|
+
const Row_1 = require("./Row.js");
|
|
11
|
+
const b = (0, cn_1.formBuilderV2Cn)('field-settings');
|
|
12
|
+
const OptionsSettings = ({ field, updateField, commonRows, whenEditorSection, }) => {
|
|
13
|
+
const options = field.options ?? [];
|
|
14
|
+
const updateOption = (index, key, value) => {
|
|
15
|
+
const next = options.map((opt, i) => (i === index ? { ...opt, [key]: value } : opt));
|
|
16
|
+
updateField(field.id, { options: next });
|
|
17
|
+
};
|
|
18
|
+
const removeOption = (index) => {
|
|
19
|
+
const next = options.filter((_, i) => i !== index);
|
|
20
|
+
updateField(field.id, { options: next });
|
|
21
|
+
};
|
|
22
|
+
const addOption = () => {
|
|
23
|
+
const nextIndex = options.length + 1;
|
|
24
|
+
updateField(field.id, {
|
|
25
|
+
options: [...options, { value: `option${nextIndex}`, content: `Option ${nextIndex}` }],
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
const defaultValueOptions = [
|
|
29
|
+
{ value: '', content: '— none —' },
|
|
30
|
+
...options.map((o) => ({ value: o.value, content: o.content ?? o.value })),
|
|
31
|
+
];
|
|
32
|
+
return ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [commonRows, (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Default", children: (0, jsx_runtime_1.jsx)(uikit_1.Select, { size: "m", value: [field.defaultValue ?? ''], options: defaultValueOptions, onUpdate: (next) => {
|
|
33
|
+
const value = next[0];
|
|
34
|
+
updateField(field.id, { defaultValue: value || undefined });
|
|
35
|
+
} }) }), field.type === 'select' && ((0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Has clear", children: (0, jsx_runtime_1.jsx)(uikit_1.Checkbox, { checked: Boolean(field.hasClear), onUpdate: (value) => updateField(field.id, { hasClear: value }), children: "Allow clearing the selection" }) })), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Options", children: (0, jsx_runtime_1.jsxs)("div", { className: b('options'), children: [options.map((opt, index) => ((0, jsx_runtime_1.jsxs)("div", { className: b('option-row'), children: [(0, jsx_runtime_1.jsx)(uikit_1.TextInput, { size: "s", value: opt.value, onUpdate: (value) => updateOption(index, 'value', value), placeholder: "value" }), (0, jsx_runtime_1.jsx)(uikit_1.TextInput, { size: "s", value: opt.content ?? '', onUpdate: (value) => updateOption(index, 'content', value), placeholder: "label" }), (0, jsx_runtime_1.jsx)(uikit_1.Button, { size: "s", view: "flat-danger", disabled: options.length <= 1, onClick: () => removeOption(index), title: "Remove option", children: (0, jsx_runtime_1.jsx)(uikit_1.Icon, { data: icons_1.TrashBin, size: 12 }) })] }, index))), (0, jsx_runtime_1.jsx)(uikit_1.Button, { className: b('add-option'), size: "s", view: "normal", onClick: addOption, children: "+ Add option" })] }) }), whenEditorSection] }));
|
|
36
|
+
};
|
|
37
|
+
exports.OptionsSettings = OptionsSettings;
|
|
38
|
+
//# sourceMappingURL=OptionsSettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OptionsSettings.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/FieldSettings/fields/OptionsSettings.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {TrashBin} from '@gravity-ui/icons';\nimport {Button, Checkbox, Icon, Select, TextInput} from '@gravity-ui/uikit';\n\nimport type {BuilderLeafField, FieldUpdate} from '../../../types';\nimport {formBuilderV2Cn} from '../../../utils/cn';\n\nimport {Row} from './Row';\n\nconst b = formBuilderV2Cn('field-settings');\n\ninterface OptionsSettingsProps {\n field: BuilderLeafField & {type: 'select' | 'segmentedRadioGroup'};\n updateField: (id: string, updates: FieldUpdate) => void;\n commonRows: React.ReactNode;\n whenEditorSection: React.ReactNode;\n}\n\nexport const OptionsSettings = ({\n field,\n updateField,\n commonRows,\n whenEditorSection,\n}: OptionsSettingsProps) => {\n const options = field.options ?? [];\n\n const updateOption = (index: number, key: 'value' | 'content', value: string) => {\n const next = options.map((opt, i) => (i === index ? {...opt, [key]: value} : opt));\n updateField(field.id, {options: next});\n };\n\n const removeOption = (index: number) => {\n const next = options.filter((_, i) => i !== index);\n updateField(field.id, {options: next});\n };\n\n const addOption = () => {\n const nextIndex = options.length + 1;\n updateField(field.id, {\n options: [...options, {value: `option${nextIndex}`, content: `Option ${nextIndex}`}],\n });\n };\n\n const defaultValueOptions = [\n {value: '', content: '— none —'},\n ...options.map((o) => ({value: o.value, content: o.content ?? o.value})),\n ];\n\n return (\n <React.Fragment>\n {commonRows}\n <Row label=\"Default\">\n <Select\n size=\"m\"\n value={[field.defaultValue ?? '']}\n options={defaultValueOptions}\n onUpdate={(next) => {\n const value = next[0];\n updateField(field.id, {defaultValue: value || undefined});\n }}\n />\n </Row>\n {field.type === 'select' && (\n <Row label=\"Has clear\">\n <Checkbox\n checked={Boolean(field.hasClear)}\n onUpdate={(value) => updateField(field.id, {hasClear: value})}\n >\n Allow clearing the selection\n </Checkbox>\n </Row>\n )}\n <Row label=\"Options\">\n <div className={b('options')}>\n {options.map((opt, index) => (\n <div key={index} className={b('option-row')}>\n <TextInput\n size=\"s\"\n value={opt.value}\n onUpdate={(value) => updateOption(index, 'value', value)}\n placeholder=\"value\"\n />\n <TextInput\n size=\"s\"\n value={opt.content ?? ''}\n onUpdate={(value) => updateOption(index, 'content', value)}\n placeholder=\"label\"\n />\n <Button\n size=\"s\"\n view=\"flat-danger\"\n disabled={options.length <= 1}\n onClick={() => removeOption(index)}\n title=\"Remove option\"\n >\n <Icon data={TrashBin} size={12} />\n </Button>\n </div>\n ))}\n <Button className={b('add-option')} size=\"s\" view=\"normal\" onClick={addOption}>\n + Add option\n </Button>\n </div>\n </Row>\n {whenEditorSection}\n </React.Fragment>\n );\n};\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Row = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const cn_1 = require("../../../utils/cn.js");
|
|
6
|
+
const b = (0, cn_1.formBuilderV2Cn)('field-settings');
|
|
7
|
+
const Row = ({ label, children }) => ((0, jsx_runtime_1.jsxs)("div", { className: b('row'), children: [(0, jsx_runtime_1.jsx)("span", { className: b('row-label'), children: label }), (0, jsx_runtime_1.jsx)("div", { children: children })] }));
|
|
8
|
+
exports.Row = Row;
|
|
9
|
+
//# sourceMappingURL=Row.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Row.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/FieldSettings/fields/Row.tsx"],"names":[],"mappings":";;;;AAEA,6CAAkD;AAElD,MAAM,CAAC,GAAG,IAAA,oBAAe,EAAC,gBAAgB,CAAC,CAAC;AAOrC,MAAM,GAAG,GAAG,CAAC,EAAC,KAAK,EAAE,QAAQ,EAAW,EAAE,EAAE,CAAC,CAChD,iCAAK,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,aACpB,iCAAM,SAAS,EAAE,CAAC,CAAC,WAAW,CAAC,YAAG,KAAK,GAAQ,EAC/C,0CAAM,QAAQ,GAAO,IACnB,CACT,CAAC;AALW,QAAA,GAAG,OAKd","sourcesContent":["import * as React from 'react';\n\nimport {formBuilderV2Cn} from '../../../utils/cn';\n\nconst b = formBuilderV2Cn('field-settings');\n\ninterface RowProps {\n label: string;\n children: React.ReactNode;\n}\n\nexport const Row = ({label, children}: RowProps) => (\n <div className={b('row')}>\n <span className={b('row-label')}>{label}</span>\n <div>{children}</div>\n </div>\n);\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { BuilderSectionField, FieldUpdate } from "../../../types.js";
|
|
3
|
+
interface SectionSettingsProps {
|
|
4
|
+
field: BuilderSectionField;
|
|
5
|
+
updateField: (id: string, updates: FieldUpdate) => void;
|
|
6
|
+
whenEditorSection: React.ReactNode;
|
|
7
|
+
}
|
|
8
|
+
export declare const SectionSettings: ({ field, updateField, whenEditorSection }: SectionSettingsProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SectionSettings = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const uikit_1 = require("@gravity-ui/uikit");
|
|
8
|
+
const fieldNames_1 = require("../../../utils/fieldNames.js");
|
|
9
|
+
const Row_1 = require("./Row.js");
|
|
10
|
+
const SectionSettings = ({ field, updateField, whenEditorSection }) => {
|
|
11
|
+
const isArray = Boolean(field.index);
|
|
12
|
+
const handleArrayModeToggle = (value) => {
|
|
13
|
+
if (value) {
|
|
14
|
+
updateField(field.id, {
|
|
15
|
+
index: 'index',
|
|
16
|
+
withAddButton: true,
|
|
17
|
+
itemTitle: 'Item {{index}}',
|
|
18
|
+
itemView: 'card',
|
|
19
|
+
fields: (0, fieldNames_1.transformChildNames)(field.fields, fieldNames_1.prefixNameForArrayMode),
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
updateField(field.id, {
|
|
24
|
+
index: undefined,
|
|
25
|
+
withAddButton: undefined,
|
|
26
|
+
itemTitle: undefined,
|
|
27
|
+
itemView: undefined,
|
|
28
|
+
fields: (0, fieldNames_1.transformChildNames)(field.fields, fieldNames_1.stripArrayModePrefix),
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
return ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [(0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Title", children: (0, jsx_runtime_1.jsx)(uikit_1.TextInput, { value: field.title ?? '', onUpdate: (value) => updateField(field.id, { title: value }), placeholder: "Section heading" }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Opened", children: (0, jsx_runtime_1.jsx)(uikit_1.Switch, { checked: Boolean(field.opened), onUpdate: (value) => updateField(field.id, { opened: value }), children: "Expanded by default" }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Array mode", children: (0, jsx_runtime_1.jsx)(uikit_1.Switch, { checked: isArray, onUpdate: handleArrayModeToggle, children: "Repeating group (array of items)" }) }), isArray && ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [(0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Hint", children: (0, jsx_runtime_1.jsxs)(uikit_1.Text, { variant: "caption-2", color: "hint", children: ["Child field names must include ", (0, jsx_runtime_1.jsx)("code", { children: '{{index}}' }), " so each row gets its own value. New fields get an ", (0, jsx_runtime_1.jsx)("code", { children: 'items[{{index}}].' }), ' ', "prefix automatically."] }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Index name", children: (0, jsx_runtime_1.jsx)(uikit_1.TextInput, { value: field.index ?? '', onUpdate: (value) => updateField(field.id, { index: value || 'index' }), placeholder: "index" }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Item title", children: (0, jsx_runtime_1.jsx)(uikit_1.TextInput, { value: field.itemTitle ?? '', onUpdate: (value) => updateField(field.id, { itemTitle: value || undefined }), placeholder: "Item {{index}}" }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Item view", children: (0, jsx_runtime_1.jsx)(uikit_1.Select, { size: "m", value: [field.itemView ?? 'clear'], options: [
|
|
33
|
+
{ value: 'clear', content: 'Clear (flat)' },
|
|
34
|
+
{ value: 'card', content: 'Card (bordered)' },
|
|
35
|
+
], onUpdate: (next) => updateField(field.id, {
|
|
36
|
+
itemView: next[0],
|
|
37
|
+
}) }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Add button", children: (0, jsx_runtime_1.jsx)(uikit_1.Checkbox, { checked: Boolean(field.withAddButton), onUpdate: (value) => updateField(field.id, { withAddButton: value }), children: "Show \u201CAdd item\u201D button" }) })] })), whenEditorSection] }));
|
|
38
|
+
};
|
|
39
|
+
exports.SectionSettings = SectionSettings;
|
|
40
|
+
//# sourceMappingURL=SectionSettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SectionSettings.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/FieldSettings/fields/SectionSettings.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {Checkbox, Select, Switch, Text, TextInput} from '@gravity-ui/uikit';\n\nimport type {BuilderSectionField, FieldUpdate} from '../../../types';\nimport {\n prefixNameForArrayMode,\n stripArrayModePrefix,\n transformChildNames,\n} from '../../../utils/fieldNames';\n\nimport {Row} from './Row';\n\ninterface SectionSettingsProps {\n field: BuilderSectionField;\n updateField: (id: string, updates: FieldUpdate) => void;\n whenEditorSection: React.ReactNode;\n}\n\nexport const SectionSettings = ({field, updateField, whenEditorSection}: SectionSettingsProps) => {\n const isArray = Boolean(field.index);\n\n const handleArrayModeToggle = (value: boolean) => {\n if (value) {\n updateField(field.id, {\n index: 'index',\n withAddButton: true,\n itemTitle: 'Item {{index}}',\n itemView: 'card',\n fields: transformChildNames(field.fields, prefixNameForArrayMode),\n });\n } else {\n updateField(field.id, {\n index: undefined,\n withAddButton: undefined,\n itemTitle: undefined,\n itemView: undefined,\n fields: transformChildNames(field.fields, stripArrayModePrefix),\n });\n }\n };\n\n return (\n <React.Fragment>\n <Row label=\"Title\">\n <TextInput\n value={field.title ?? ''}\n onUpdate={(value) => updateField(field.id, {title: value})}\n placeholder=\"Section heading\"\n />\n </Row>\n <Row label=\"Opened\">\n <Switch\n checked={Boolean(field.opened)}\n onUpdate={(value) => updateField(field.id, {opened: value})}\n >\n Expanded by default\n </Switch>\n </Row>\n <Row label=\"Array mode\">\n <Switch checked={isArray} onUpdate={handleArrayModeToggle}>\n Repeating group (array of items)\n </Switch>\n </Row>\n {isArray && (\n <React.Fragment>\n <Row label=\"Hint\">\n <Text variant=\"caption-2\" color=\"hint\">\n Child field names must include <code>{'{{index}}'}</code> so each row\n gets its own value. New fields get an <code>{'items[{{index}}].'}</code>{' '}\n prefix automatically.\n </Text>\n </Row>\n <Row label=\"Index name\">\n <TextInput\n value={field.index ?? ''}\n onUpdate={(value) => updateField(field.id, {index: value || 'index'})}\n placeholder=\"index\"\n />\n </Row>\n <Row label=\"Item title\">\n <TextInput\n value={field.itemTitle ?? ''}\n onUpdate={(value) =>\n updateField(field.id, {itemTitle: value || undefined})\n }\n placeholder=\"Item {{index}}\"\n />\n </Row>\n <Row label=\"Item view\">\n <Select\n size=\"m\"\n value={[field.itemView ?? 'clear']}\n options={[\n {value: 'clear', content: 'Clear (flat)'},\n {value: 'card', content: 'Card (bordered)'},\n ]}\n onUpdate={(next) =>\n updateField(field.id, {\n itemView: next[0] as 'card' | 'clear',\n })\n }\n />\n </Row>\n <Row label=\"Add button\">\n <Checkbox\n checked={Boolean(field.withAddButton)}\n onUpdate={(value) => updateField(field.id, {withAddButton: value})}\n >\n Show “Add item” button\n </Checkbox>\n </Row>\n </React.Fragment>\n )}\n {whenEditorSection}\n </React.Fragment>\n );\n};\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { BuilderLeafField, FieldUpdate } from "../../../types.js";
|
|
3
|
+
interface SwitchSettingsProps {
|
|
4
|
+
field: BuilderLeafField & {
|
|
5
|
+
type: 'switch';
|
|
6
|
+
};
|
|
7
|
+
updateField: (id: string, updates: FieldUpdate) => void;
|
|
8
|
+
commonRows: React.ReactNode;
|
|
9
|
+
whenEditorSection: React.ReactNode;
|
|
10
|
+
}
|
|
11
|
+
export declare const SwitchSettings: ({ field, updateField, commonRows, whenEditorSection, }: SwitchSettingsProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SwitchSettings = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const uikit_1 = require("@gravity-ui/uikit");
|
|
8
|
+
const Row_1 = require("./Row.js");
|
|
9
|
+
const SwitchSettings = ({ field, updateField, commonRows, whenEditorSection, }) => ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [commonRows, (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Default", children: (0, jsx_runtime_1.jsx)(uikit_1.Switch, { checked: Boolean(field.defaultValue), onUpdate: (value) => updateField(field.id, { defaultValue: value }) }) }), whenEditorSection] }));
|
|
10
|
+
exports.SwitchSettings = SwitchSettings;
|
|
11
|
+
//# sourceMappingURL=SwitchSettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SwitchSettings.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/FieldSettings/fields/SwitchSettings.tsx"],"names":[],"mappings":";;;;;AAAA,qDAA+B;AAE/B,6CAAyC;AAIzC,kCAA0B;AASnB,MAAM,cAAc,GAAG,CAAC,EAC3B,KAAK,EACL,WAAW,EACX,UAAU,EACV,iBAAiB,GACC,EAAE,EAAE,CAAC,CACvB,wBAAC,KAAK,CAAC,QAAQ,eACV,UAAU,EACX,uBAAC,SAAG,IAAC,KAAK,EAAC,SAAS,YAChB,uBAAC,cAAM,IACH,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,EACpC,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,EAAE,EAAC,YAAY,EAAE,KAAK,EAAC,CAAC,GACnE,GACA,EACL,iBAAiB,IACL,CACpB,CAAC;AAhBW,QAAA,cAAc,kBAgBzB","sourcesContent":["import * as React from 'react';\n\nimport {Switch} from '@gravity-ui/uikit';\n\nimport type {BuilderLeafField, FieldUpdate} from '../../../types';\n\nimport {Row} from './Row';\n\ninterface SwitchSettingsProps {\n field: BuilderLeafField & {type: 'switch'};\n updateField: (id: string, updates: FieldUpdate) => void;\n commonRows: React.ReactNode;\n whenEditorSection: React.ReactNode;\n}\n\nexport const SwitchSettings = ({\n field,\n updateField,\n commonRows,\n whenEditorSection,\n}: SwitchSettingsProps) => (\n <React.Fragment>\n {commonRows}\n <Row label=\"Default\">\n <Switch\n checked={Boolean(field.defaultValue)}\n onUpdate={(value) => updateField(field.id, {defaultValue: value})}\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 TextFieldSettingsProps {
|
|
4
|
+
field: BuilderLeafField & {
|
|
5
|
+
type: 'textInput' | 'textArea';
|
|
6
|
+
};
|
|
7
|
+
updateField: (id: string, updates: FieldUpdate) => void;
|
|
8
|
+
commonRows: React.ReactNode;
|
|
9
|
+
whenEditorSection: React.ReactNode;
|
|
10
|
+
}
|
|
11
|
+
export declare const TextFieldSettings: ({ field, updateField, commonRows, whenEditorSection, }: TextFieldSettingsProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TextFieldSettings = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const uikit_1 = require("@gravity-ui/uikit");
|
|
8
|
+
const Row_1 = require("./Row.js");
|
|
9
|
+
const TextFieldSettings = ({ field, updateField, commonRows, whenEditorSection, }) => ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [commonRows, (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Default", children: (0, jsx_runtime_1.jsx)(uikit_1.TextInput, { value: field.defaultValue ?? '', onUpdate: (value) => updateField(field.id, { defaultValue: value || undefined }), placeholder: "Default value" }) }), whenEditorSection] }));
|
|
10
|
+
exports.TextFieldSettings = TextFieldSettings;
|
|
11
|
+
//# sourceMappingURL=TextFieldSettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextFieldSettings.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/FieldSettings/fields/TextFieldSettings.tsx"],"names":[],"mappings":";;;;;AAAA,qDAA+B;AAE/B,6CAA4C;AAI5C,kCAA0B;AASnB,MAAM,iBAAiB,GAAG,CAAC,EAC9B,KAAK,EACL,WAAW,EACX,UAAU,EACV,iBAAiB,GACI,EAAE,EAAE,CAAC,CAC1B,wBAAC,KAAK,CAAC,QAAQ,eACV,UAAU,EACX,uBAAC,SAAG,IAAC,KAAK,EAAC,SAAS,YAChB,uBAAC,iBAAS,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,eAAe,GAC7B,GACA,EACL,iBAAiB,IACL,CACpB,CAAC;AAjBW,QAAA,iBAAiB,qBAiB5B","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 TextFieldSettingsProps {\n field: BuilderLeafField & {type: 'textInput' | 'textArea'};\n updateField: (id: string, updates: FieldUpdate) => void;\n commonRows: React.ReactNode;\n whenEditorSection: React.ReactNode;\n}\n\nexport const TextFieldSettings = ({\n field,\n updateField,\n commonRows,\n whenEditorSection,\n}: TextFieldSettingsProps) => (\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=\"Default value\"\n />\n </Row>\n {whenEditorSection}\n </React.Fragment>\n);\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { BuilderLeafField, FieldUpdate } from "../../../types.js";
|
|
3
|
+
interface TextSettingsProps {
|
|
4
|
+
field: BuilderLeafField & {
|
|
5
|
+
type: 'text';
|
|
6
|
+
};
|
|
7
|
+
updateField: (id: string, updates: FieldUpdate) => void;
|
|
8
|
+
whenEditorSection: React.ReactNode;
|
|
9
|
+
}
|
|
10
|
+
export declare const TextSettings: ({ field, updateField, whenEditorSection }: TextSettingsProps) => import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TextSettings = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const uikit_1 = require("@gravity-ui/uikit");
|
|
8
|
+
const Row_1 = require("./Row.js");
|
|
9
|
+
const TEXT_COLOR_OPTIONS = [
|
|
10
|
+
{ value: '', content: 'Default' },
|
|
11
|
+
{ value: 'primary', content: 'Primary' },
|
|
12
|
+
{ value: 'secondary', content: 'Secondary' },
|
|
13
|
+
{ value: 'hint', content: 'Hint' },
|
|
14
|
+
{ value: 'info', content: 'Info' },
|
|
15
|
+
{ value: 'positive', content: 'Positive' },
|
|
16
|
+
{ value: 'warning', content: 'Warning' },
|
|
17
|
+
{ value: 'danger', content: 'Danger' },
|
|
18
|
+
{ value: 'utility', content: 'Utility' },
|
|
19
|
+
{ value: 'misc', content: 'Misc' },
|
|
20
|
+
];
|
|
21
|
+
const TEXT_LEVEL_OPTIONS = [
|
|
22
|
+
{ value: '', content: 'None' },
|
|
23
|
+
{ value: 'info', content: 'Info banner' },
|
|
24
|
+
{ value: 'danger', content: 'Danger banner' },
|
|
25
|
+
];
|
|
26
|
+
const TEXT_COLORS = [
|
|
27
|
+
'primary',
|
|
28
|
+
'secondary',
|
|
29
|
+
'hint',
|
|
30
|
+
'info',
|
|
31
|
+
'positive',
|
|
32
|
+
'warning',
|
|
33
|
+
'danger',
|
|
34
|
+
'utility',
|
|
35
|
+
'misc',
|
|
36
|
+
];
|
|
37
|
+
const isTextColor = (value) => TEXT_COLORS.includes(value);
|
|
38
|
+
const isTextLevel = (value) => value === 'info' || value === 'danger';
|
|
39
|
+
const TextSettings = ({ field, updateField, whenEditorSection }) => {
|
|
40
|
+
const handleLevelUpdate = ([value]) => {
|
|
41
|
+
updateField(field.id, {
|
|
42
|
+
level: isTextLevel(value) ? value : undefined,
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
const handleColorUpdate = ([value]) => {
|
|
46
|
+
updateField(field.id, {
|
|
47
|
+
color: isTextColor(value) ? value : undefined,
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
return ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [(0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Text", children: (0, jsx_runtime_1.jsx)(uikit_1.TextArea, { value: field.text ?? '', onUpdate: (value) => updateField(field.id, { text: value }), minRows: 2, placeholder: "Static hint text" }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Banner", children: (0, jsx_runtime_1.jsx)(uikit_1.Select, { size: "m", value: [field.level ?? ''], options: TEXT_LEVEL_OPTIONS, onUpdate: handleLevelUpdate }) }), (0, jsx_runtime_1.jsx)(Row_1.Row, { label: "Color", children: (0, jsx_runtime_1.jsx)(uikit_1.Select, { size: "m", value: [field.color ?? ''], options: TEXT_COLOR_OPTIONS, onUpdate: handleColorUpdate }) }), whenEditorSection] }));
|
|
51
|
+
};
|
|
52
|
+
exports.TextSettings = TextSettings;
|
|
53
|
+
//# sourceMappingURL=TextSettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextSettings.js","sourceRoot":"../../../../../../src","sources":["form-builder-v2/components/FieldSettings/fields/TextSettings.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {Select, TextArea} from '@gravity-ui/uikit';\n\nimport type {TextColor} from '../../../../form-generator-v2/types';\nimport type {BuilderLeafField, FieldUpdate} from '../../../types';\n\nimport {Row} from './Row';\n\ntype TextLevel = 'info' | 'danger';\n\nconst TEXT_COLOR_OPTIONS = [\n {value: '', content: 'Default'},\n {value: 'primary', content: 'Primary'},\n {value: 'secondary', content: 'Secondary'},\n {value: 'hint', content: 'Hint'},\n {value: 'info', content: 'Info'},\n {value: 'positive', content: 'Positive'},\n {value: 'warning', content: 'Warning'},\n {value: 'danger', content: 'Danger'},\n {value: 'utility', content: 'Utility'},\n {value: 'misc', content: 'Misc'},\n];\n\nconst TEXT_LEVEL_OPTIONS = [\n {value: '', content: 'None'},\n {value: 'info', content: 'Info banner'},\n {value: 'danger', content: 'Danger banner'},\n];\n\nconst TEXT_COLORS: readonly TextColor[] = [\n 'primary',\n 'secondary',\n 'hint',\n 'info',\n 'positive',\n 'warning',\n 'danger',\n 'utility',\n 'misc',\n];\n\nconst isTextColor = (value: string): value is TextColor =>\n (TEXT_COLORS as readonly string[]).includes(value);\n\nconst isTextLevel = (value: string): value is TextLevel => value === 'info' || value === 'danger';\n\ninterface TextSettingsProps {\n field: BuilderLeafField & {type: 'text'};\n updateField: (id: string, updates: FieldUpdate) => void;\n whenEditorSection: React.ReactNode;\n}\n\nexport const TextSettings = ({field, updateField, whenEditorSection}: TextSettingsProps) => {\n const handleLevelUpdate = ([value]: string[]) => {\n updateField(field.id, {\n level: isTextLevel(value) ? value : undefined,\n });\n };\n\n const handleColorUpdate = ([value]: string[]) => {\n updateField(field.id, {\n color: isTextColor(value) ? value : undefined,\n });\n };\n\n return (\n <React.Fragment>\n <Row label=\"Text\">\n <TextArea\n value={field.text ?? ''}\n onUpdate={(value) => updateField(field.id, {text: value})}\n minRows={2}\n placeholder=\"Static hint text\"\n />\n </Row>\n <Row label=\"Banner\">\n <Select\n size=\"m\"\n value={[field.level ?? '']}\n options={TEXT_LEVEL_OPTIONS}\n onUpdate={handleLevelUpdate}\n />\n </Row>\n <Row label=\"Color\">\n <Select\n size=\"m\"\n value={[field.color ?? '']}\n options={TEXT_COLOR_OPTIONS}\n onUpdate={handleColorUpdate}\n />\n </Row>\n {whenEditorSection}\n </React.Fragment>\n );\n};\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
.pcformbuilderv2-inspector {
|
|
2
|
+
padding: 14px;
|
|
3
|
+
}
|
|
4
|
+
.pcformbuilderv2-inspector__header {
|
|
5
|
+
display: flex;
|
|
6
|
+
flex-direction: column;
|
|
7
|
+
gap: var(--g-spacing-half);
|
|
8
|
+
margin-bottom: var(--g-spacing-3);
|
|
9
|
+
padding-bottom: 10px;
|
|
10
|
+
border-bottom: 1px solid var(--g-color-line-generic);
|
|
11
|
+
}
|
|
12
|
+
.pcformbuilderv2-inspector__body {
|
|
13
|
+
display: flex;
|
|
14
|
+
flex-direction: column;
|
|
15
|
+
gap: var(--g-spacing-2);
|
|
16
|
+
}
|
|
17
|
+
.pcformbuilderv2-inspector__empty {
|
|
18
|
+
padding: var(--g-spacing-4) var(--g-spacing-2);
|
|
19
|
+
text-align: center;
|
|
20
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const Inspector: () => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Inspector = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const uikit_1 = require("@gravity-ui/uikit");
|
|
8
|
+
const FieldSettings_1 = require("../FieldSettings/FieldSettings.js");
|
|
9
|
+
const FormContext_1 = require("../../hooks/FormContext.js");
|
|
10
|
+
const cn_1 = require("../../utils/cn.js");
|
|
11
|
+
const fieldMeta_1 = require("../../utils/fieldMeta.js");
|
|
12
|
+
const fieldTree_1 = require("../../utils/fieldTree.js");
|
|
13
|
+
const b = (0, cn_1.formBuilderV2Cn)('inspector');
|
|
14
|
+
const Inspector = () => {
|
|
15
|
+
const { formFields, selectedFieldId } = (0, FormContext_1.useFormContext)();
|
|
16
|
+
const selected = React.useMemo(() => (selectedFieldId ? (0, fieldTree_1.findFieldById)(formFields, selectedFieldId) : null), [formFields, selectedFieldId]);
|
|
17
|
+
return ((0, jsx_runtime_1.jsx)(uikit_1.Card, { className: b(), view: "outlined", children: selected ? ((0, jsx_runtime_1.jsxs)(React.Fragment, { children: [(0, jsx_runtime_1.jsxs)("div", { className: b('header'), children: [(0, jsx_runtime_1.jsx)(uikit_1.Text, { variant: "subheader-2", children: fieldMeta_1.TYPE_LABELS[selected.type] }), 'name' in selected && selected.name ? ((0, jsx_runtime_1.jsx)(uikit_1.Text, { variant: "caption-1", color: "hint", children: selected.name })) : null] }), (0, jsx_runtime_1.jsx)("div", { className: b('body'), children: (0, jsx_runtime_1.jsx)(FieldSettings_1.FieldSettings, { field: selected }) })] })) : ((0, jsx_runtime_1.jsx)("div", { className: b('empty'), children: (0, jsx_runtime_1.jsx)(uikit_1.Text, { variant: "body-2", color: "hint", children: "Select a field on the canvas to edit its settings." }) })) }));
|
|
18
|
+
};
|
|
19
|
+
exports.Inspector = Inspector;
|
|
20
|
+
//# sourceMappingURL=Inspector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Inspector.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/Inspector/Inspector.tsx"],"names":[],"mappings":";;;;;AAAA,qDAA+B;AAE/B,6CAA6C;AAE7C,qEAA2E;AAC3E,4DAAuD;AACvD,0CAA+C;AAC/C,wDAAkD;AAClD,wDAAoD;AAIpD,MAAM,CAAC,GAAG,IAAA,oBAAe,EAAC,WAAW,CAAC,CAAC;AAEhC,MAAM,SAAS,GAAG,GAAG,EAAE;IAC1B,MAAM,EAAC,UAAU,EAAE,eAAe,EAAC,GAAG,IAAA,4BAAc,GAAE,CAAC;IAEvD,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAC1B,GAAG,EAAE,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,IAAA,yBAAa,EAAC,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAC3E,CAAC,UAAU,EAAE,eAAe,CAAC,CAChC,CAAC;IAEF,OAAO,CACH,uBAAC,YAAI,IAAC,SAAS,EAAE,CAAC,EAAE,EAAE,IAAI,EAAC,UAAU,YAChC,QAAQ,CAAC,CAAC,CAAC,CACR,wBAAC,KAAK,CAAC,QAAQ,eACX,iCAAK,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,aACvB,uBAAC,YAAI,IAAC,OAAO,EAAC,aAAa,YAAE,uBAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAQ,EAC9D,MAAM,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CACnC,uBAAC,YAAI,IAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,MAAM,YACjC,QAAQ,CAAC,IAAI,GACX,CACV,CAAC,CAAC,CAAC,IAAI,IACN,EACN,gCAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACrB,uBAAC,6BAAa,IAAC,KAAK,EAAE,QAAQ,GAAI,GAChC,IACO,CACpB,CAAC,CAAC,CAAC,CACA,gCAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YACtB,uBAAC,YAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,MAAM,mEAE5B,GACL,CACT,GACE,CACV,CAAC;AACN,CAAC,CAAC;AAjCW,QAAA,SAAS,aAiCpB","sourcesContent":["import * as React from 'react';\n\nimport {Card, Text} from '@gravity-ui/uikit';\n\nimport {FieldSettings} from '../../components/FieldSettings/FieldSettings';\nimport {useFormContext} from '../../hooks/FormContext';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport {TYPE_LABELS} from '../../utils/fieldMeta';\nimport {findFieldById} from '../../utils/fieldTree';\n\nimport './Inspector.scss';\n\nconst b = formBuilderV2Cn('inspector');\n\nexport const Inspector = () => {\n const {formFields, selectedFieldId} = useFormContext();\n\n const selected = React.useMemo(\n () => (selectedFieldId ? findFieldById(formFields, selectedFieldId) : null),\n [formFields, selectedFieldId],\n );\n\n return (\n <Card className={b()} view=\"outlined\">\n {selected ? (\n <React.Fragment>\n <div className={b('header')}>\n <Text variant=\"subheader-2\">{TYPE_LABELS[selected.type]}</Text>\n {'name' in selected && selected.name ? (\n <Text variant=\"caption-1\" color=\"hint\">\n {selected.name}\n </Text>\n ) : null}\n </div>\n <div className={b('body')}>\n <FieldSettings field={selected} />\n </div>\n </React.Fragment>\n ) : (\n <div className={b('empty')}>\n <Text variant=\"body-2\" color=\"hint\">\n Select a field on the canvas to edit its settings.\n </Text>\n </div>\n )}\n </Card>\n );\n};\n"]}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
.pcformbuilderv2-palette {
|
|
2
|
+
padding: var(--g-spacing-3);
|
|
3
|
+
}
|
|
4
|
+
.pcformbuilderv2-palette__header {
|
|
5
|
+
display: flex;
|
|
6
|
+
flex-direction: column;
|
|
7
|
+
gap: var(--g-spacing-half);
|
|
8
|
+
margin-bottom: 10px;
|
|
9
|
+
}
|
|
10
|
+
.pcformbuilderv2-palette__items {
|
|
11
|
+
display: grid;
|
|
12
|
+
grid-template-columns: 1fr 1fr;
|
|
13
|
+
gap: 6px;
|
|
14
|
+
}
|
|
15
|
+
.pcformbuilderv2-palette__tile {
|
|
16
|
+
display: flex;
|
|
17
|
+
flex-direction: column;
|
|
18
|
+
align-items: center;
|
|
19
|
+
justify-content: center;
|
|
20
|
+
gap: 6px;
|
|
21
|
+
aspect-ratio: 1;
|
|
22
|
+
width: 100%;
|
|
23
|
+
height: auto;
|
|
24
|
+
padding: var(--g-spacing-2);
|
|
25
|
+
border: 1px solid var(--g-color-line-generic);
|
|
26
|
+
border-radius: var(--g-border-radius-m);
|
|
27
|
+
background: transparent;
|
|
28
|
+
color: var(--g-color-text-primary);
|
|
29
|
+
cursor: grab;
|
|
30
|
+
transition: background-color 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
|
|
31
|
+
}
|
|
32
|
+
.pcformbuilderv2-palette__tile .g-button__text {
|
|
33
|
+
display: flex;
|
|
34
|
+
flex-direction: column;
|
|
35
|
+
align-items: center;
|
|
36
|
+
justify-content: center;
|
|
37
|
+
gap: 6px;
|
|
38
|
+
width: 100%;
|
|
39
|
+
}
|
|
40
|
+
.pcformbuilderv2-palette__tile:hover {
|
|
41
|
+
background-color: var(--g-color-base-simple-hover);
|
|
42
|
+
border-color: var(--g-color-line-generic-hover);
|
|
43
|
+
}
|
|
44
|
+
.pcformbuilderv2-palette__tile:active {
|
|
45
|
+
cursor: grabbing;
|
|
46
|
+
background-color: var(--g-color-base-simple-hover-solid);
|
|
47
|
+
}
|
|
48
|
+
.pcformbuilderv2-palette__tile_dragging {
|
|
49
|
+
opacity: 0.5;
|
|
50
|
+
}
|
|
51
|
+
.pcformbuilderv2-palette__tile-label {
|
|
52
|
+
font-size: var(--g-text-caption-2-font-size);
|
|
53
|
+
line-height: 1.2;
|
|
54
|
+
text-align: center;
|
|
55
|
+
color: var(--g-color-text-secondary);
|
|
56
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Palette = exports.PALETTE_DRAGGABLE_PREFIX = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
const React = tslib_1.__importStar(require("react"));
|
|
7
|
+
const dom_1 = require("@dnd-kit/dom");
|
|
8
|
+
const react_1 = require("@dnd-kit/react");
|
|
9
|
+
const uikit_1 = require("@gravity-ui/uikit");
|
|
10
|
+
const FormContext_1 = require("../../hooks/FormContext.js");
|
|
11
|
+
const cn_1 = require("../../utils/cn.js");
|
|
12
|
+
const fieldMeta_1 = require("../../utils/fieldMeta.js");
|
|
13
|
+
const b = (0, cn_1.formBuilderV2Cn)('palette');
|
|
14
|
+
exports.PALETTE_DRAGGABLE_PREFIX = 'palette:';
|
|
15
|
+
const findContainerId = (fields, selectedId, parentSectionId = null) => {
|
|
16
|
+
if (!selectedId)
|
|
17
|
+
return null;
|
|
18
|
+
for (const field of fields) {
|
|
19
|
+
if (field.id === selectedId) {
|
|
20
|
+
return field.type === 'section' ? field.id : parentSectionId;
|
|
21
|
+
}
|
|
22
|
+
if (field.type === 'section') {
|
|
23
|
+
const nested = findContainerId(field.fields, selectedId, field.id);
|
|
24
|
+
if (nested !== undefined)
|
|
25
|
+
return nested;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return undefined;
|
|
29
|
+
};
|
|
30
|
+
const DRAG_DISTANCE = 4;
|
|
31
|
+
const paletteSensors = [
|
|
32
|
+
dom_1.PointerSensor.configure({
|
|
33
|
+
activationConstraints: [new dom_1.PointerActivationConstraints.Distance({ value: DRAG_DISTANCE })],
|
|
34
|
+
}),
|
|
35
|
+
];
|
|
36
|
+
const PaletteTile = ({ type, label, icon, onClick }) => {
|
|
37
|
+
const { ref, handleRef, isDragging } = (0, react_1.useDraggable)({
|
|
38
|
+
id: `${exports.PALETTE_DRAGGABLE_PREFIX}${type}`,
|
|
39
|
+
data: { kind: 'palette', type },
|
|
40
|
+
sensors: paletteSensors,
|
|
41
|
+
});
|
|
42
|
+
const setRefs = React.useCallback((element) => {
|
|
43
|
+
ref(element);
|
|
44
|
+
handleRef(element);
|
|
45
|
+
}, [ref, handleRef]);
|
|
46
|
+
return ((0, jsx_runtime_1.jsx)(uikit_1.Tooltip, { content: label, placement: "right", openDelay: 500, children: (0, jsx_runtime_1.jsxs)(uikit_1.Button, { ref: setRefs, view: "flat", size: "m", className: b('tile', { dragging: isDragging }), onClick: onClick, children: [(0, jsx_runtime_1.jsx)(uikit_1.Icon, { data: icon, size: 18 }), (0, jsx_runtime_1.jsx)("span", { className: b('tile-label'), children: label })] }) }));
|
|
47
|
+
};
|
|
48
|
+
const Palette = () => {
|
|
49
|
+
const { addField, addFieldToSection, formFields, selectedFieldId } = (0, FormContext_1.useFormContext)();
|
|
50
|
+
const containerId = React.useMemo(() => findContainerId(formFields, selectedFieldId), [formFields, selectedFieldId]);
|
|
51
|
+
const handleAdd = (type) => {
|
|
52
|
+
if (containerId) {
|
|
53
|
+
addFieldToSection(containerId, type);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
addField(type);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
return ((0, jsx_runtime_1.jsxs)(uikit_1.Card, { className: b(), view: "outlined", children: [(0, jsx_runtime_1.jsxs)("div", { className: b('header'), children: [(0, jsx_runtime_1.jsx)(uikit_1.Text, { variant: "subheader-2", children: "Add field" }), (0, jsx_runtime_1.jsx)(uikit_1.Text, { variant: "caption-1", color: "hint", children: "Click to add, or drag onto the canvas to drop at a specific position." })] }), (0, jsx_runtime_1.jsx)("div", { className: b('items'), children: fieldMeta_1.FIELD_TYPES.map((type) => ((0, jsx_runtime_1.jsx)(PaletteTile, { type: type, label: fieldMeta_1.PALETTE_LABELS[type], icon: fieldMeta_1.TYPE_ICONS[type], onClick: () => handleAdd(type) }, type))) })] }));
|
|
60
|
+
};
|
|
61
|
+
exports.Palette = Palette;
|
|
62
|
+
//# sourceMappingURL=Palette.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Palette.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/Palette/Palette.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {PointerActivationConstraints, PointerSensor} from '@dnd-kit/dom';\nimport {useDraggable} from '@dnd-kit/react';\nimport {Button, Card, Icon, Text, Tooltip} from '@gravity-ui/uikit';\nimport type {IconData} from '@gravity-ui/uikit';\n\nimport {useFormContext} from '../../hooks/FormContext';\nimport {BuilderFieldType, FormField} from '../../types';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport type {PaletteDragData} from '../../utils/dragData';\nimport {FIELD_TYPES, PALETTE_LABELS, TYPE_ICONS} from '../../utils/fieldMeta';\n\nimport './Palette.scss';\n\nexport type {PaletteDragData};\n\nconst b = formBuilderV2Cn('palette');\n\nexport const PALETTE_DRAGGABLE_PREFIX = 'palette:';\n\nconst findContainerId = (\n fields: FormField[],\n selectedId: string | null,\n parentSectionId: string | null = null,\n): string | null | undefined => {\n if (!selectedId) return null;\n for (const field of fields) {\n if (field.id === selectedId) {\n return field.type === 'section' ? field.id : parentSectionId;\n }\n if (field.type === 'section') {\n const nested = findContainerId(field.fields, selectedId, field.id);\n if (nested !== undefined) return nested;\n }\n }\n return undefined;\n};\n\ninterface PaletteTileProps {\n type: BuilderFieldType;\n label: string;\n icon: IconData;\n onClick: () => void;\n}\n\nconst DRAG_DISTANCE = 4;\n\nconst paletteSensors = [\n PointerSensor.configure({\n activationConstraints: [new PointerActivationConstraints.Distance({value: DRAG_DISTANCE})],\n }),\n];\n\nconst PaletteTile = ({type, label, icon, onClick}: PaletteTileProps) => {\n const {ref, handleRef, isDragging} = useDraggable({\n id: `${PALETTE_DRAGGABLE_PREFIX}${type}`,\n data: {kind: 'palette', type},\n sensors: paletteSensors,\n });\n\n const setRefs = React.useCallback(\n (element: HTMLButtonElement | null) => {\n ref(element);\n handleRef(element);\n },\n [ref, handleRef],\n );\n\n return (\n <Tooltip content={label} placement=\"right\" openDelay={500}>\n <Button\n ref={setRefs}\n view=\"flat\"\n size=\"m\"\n className={b('tile', {dragging: isDragging})}\n onClick={onClick}\n >\n <Icon data={icon} size={18} />\n <span className={b('tile-label')}>{label}</span>\n </Button>\n </Tooltip>\n );\n};\n\nexport const Palette = () => {\n const {addField, addFieldToSection, formFields, selectedFieldId} = useFormContext();\n\n const containerId = React.useMemo(\n () => findContainerId(formFields, selectedFieldId),\n [formFields, selectedFieldId],\n );\n\n const handleAdd = (type: BuilderFieldType) => {\n if (containerId) {\n addFieldToSection(containerId, type);\n } else {\n addField(type);\n }\n };\n\n return (\n <Card className={b()} view=\"outlined\">\n <div className={b('header')}>\n <Text variant=\"subheader-2\">Add field</Text>\n <Text variant=\"caption-1\" color=\"hint\">\n Click to add, or drag onto the canvas to drop at a specific position.\n </Text>\n </div>\n <div className={b('items')}>\n {FIELD_TYPES.map((type) => (\n <PaletteTile\n key={type}\n type={type}\n label={PALETTE_LABELS[type]}\n icon={TYPE_ICONS[type]}\n onClick={() => handleAdd(type)}\n />\n ))}\n </div>\n </Card>\n );\n};\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
.pcformbuilderv2-resize-handle {
|
|
2
|
+
width: var(--g-spacing-2);
|
|
3
|
+
align-self: stretch;
|
|
4
|
+
cursor: col-resize;
|
|
5
|
+
position: relative;
|
|
6
|
+
user-select: none;
|
|
7
|
+
}
|
|
8
|
+
.pcformbuilderv2-resize-handle::after {
|
|
9
|
+
content: "";
|
|
10
|
+
position: absolute;
|
|
11
|
+
top: 50%;
|
|
12
|
+
left: 50%;
|
|
13
|
+
transform: translate(-50%, -50%);
|
|
14
|
+
width: 2px;
|
|
15
|
+
height: 40%;
|
|
16
|
+
background: var(--g-color-line-generic);
|
|
17
|
+
opacity: 0;
|
|
18
|
+
border-radius: 2px;
|
|
19
|
+
transition: opacity 0.12s ease, background-color 0.12s ease, height 0.12s ease;
|
|
20
|
+
}
|
|
21
|
+
.pcformbuilderv2-resize-handle:hover::after {
|
|
22
|
+
opacity: 1;
|
|
23
|
+
height: 60%;
|
|
24
|
+
}
|
|
25
|
+
.pcformbuilderv2-resize-handle_dragging::after {
|
|
26
|
+
opacity: 1;
|
|
27
|
+
height: 100%;
|
|
28
|
+
background: var(--g-color-line-brand);
|
|
29
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
interface ResizeHandleProps {
|
|
2
|
+
value: number;
|
|
3
|
+
min: number;
|
|
4
|
+
max: number;
|
|
5
|
+
direction: 'left' | 'right';
|
|
6
|
+
onChange: (next: number) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare const ResizeHandle: ({ value, min, max, direction, onChange }: ResizeHandleProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export {};
|