xkit-editor 2.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/index.d.ts +2 -0
- package/lib/packages/editor/env.d.ts +7 -0
- package/lib/packages/editor/src/component-configs/__tests__/config.test.d.ts +2 -0
- package/lib/packages/editor/src/component-configs/__tests__/config.test.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/__tests__/group.test.d.ts +2 -0
- package/lib/packages/editor/src/component-configs/__tests__/group.test.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/cascader.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/cascader.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/checkbox.d.ts +4 -0
- package/lib/packages/editor/src/component-configs/checkbox.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/common-props.d.ts +16 -0
- package/lib/packages/editor/src/component-configs/common-props.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/date-picker.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/date-picker.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/date-range-picker.d.ts +4 -0
- package/lib/packages/editor/src/component-configs/date-range-picker.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/group.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/group.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/icon-select.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/icon-select.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/input-array.d.ts +4 -0
- package/lib/packages/editor/src/component-configs/input-array.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/input-number-range.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/input-number-range.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/input-number.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/input-number.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/input-table.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/input-table.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/input-upload.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/input-upload.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/input.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/input.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/layout-sections.d.ts +11 -0
- package/lib/packages/editor/src/component-configs/layout-sections.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/options-config.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/options-config.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/radio.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/radio.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/select.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/select.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/switch.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/switch.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/textarea.d.ts +3 -0
- package/lib/packages/editor/src/component-configs/textarea.d.ts.map +1 -0
- package/lib/packages/editor/src/component-configs/types.d.ts +33 -0
- package/lib/packages/editor/src/component-configs/types.d.ts.map +1 -0
- package/lib/packages/editor/src/components/condition-editor.vue.d.ts +19 -0
- package/lib/packages/editor/src/components/condition-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/design-renderers/input-array-design.vue.d.ts +17 -0
- package/lib/packages/editor/src/components/design-renderers/input-array-design.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/design-renderers/input-table-design.vue.d.ts +15 -0
- package/lib/packages/editor/src/components/design-renderers/input-table-design.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/form-item-layout-editor.vue.d.ts +14 -0
- package/lib/packages/editor/src/components/form-item-layout-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/form-item-span-editor.vue.d.ts +18 -0
- package/lib/packages/editor/src/components/form-item-span-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/form-layout-editor.vue.d.ts +21 -0
- package/lib/packages/editor/src/components/form-layout-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/group-title-color-select.vue.d.ts +10 -0
- package/lib/packages/editor/src/components/group-title-color-select.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/group-title-style-picker.vue.d.ts +10 -0
- package/lib/packages/editor/src/components/group-title-style-picker.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/input-number-range-binding-editor.vue.d.ts +25 -0
- package/lib/packages/editor/src/components/input-number-range-binding-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/input-table-default-rows-editor.vue.d.ts +11 -0
- package/lib/packages/editor/src/components/input-table-default-rows-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/input-table-operation-editor.vue.d.ts +11 -0
- package/lib/packages/editor/src/components/input-table-operation-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/json-code-editor.vue.d.ts +18 -0
- package/lib/packages/editor/src/components/json-code-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/object-section-editor.vue.d.ts +23 -0
- package/lib/packages/editor/src/components/object-section-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/options/default-dict-options-panel.vue.d.ts +10 -0
- package/lib/packages/editor/src/components/options/default-dict-options-panel.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/options/options-editor.vue.d.ts +12 -0
- package/lib/packages/editor/src/components/options/options-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/components/validation-rules-editor.vue.d.ts +12 -0
- package/lib/packages/editor/src/components/validation-rules-editor.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/config.d.ts +8 -0
- package/lib/packages/editor/src/config.d.ts.map +1 -0
- package/lib/packages/editor/src/editor-item-wrapper.vue.d.ts +39 -0
- package/lib/packages/editor/src/editor-item-wrapper.vue.d.ts.map +1 -0
- package/lib/packages/editor/src/group-title-styles.d.ts +9 -0
- package/lib/packages/editor/src/group-title-styles.d.ts.map +1 -0
- package/lib/packages/editor/src/index.d.ts +7 -0
- package/lib/packages/editor/src/index.d.ts.map +1 -0
- package/lib/packages/editor/src/option-sources.d.ts +10 -0
- package/lib/packages/editor/src/option-sources.d.ts.map +1 -0
- package/lib/packages/editor/src/root-configs.d.ts +12 -0
- package/lib/packages/editor/src/root-configs.d.ts.map +1 -0
- package/lib/packages/editor/src/shims-vue.d.ts +5 -0
- package/lib/packages/editor/src/utils/__tests__/component-replace.test.d.ts +2 -0
- package/lib/packages/editor/src/utils/__tests__/component-replace.test.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/__tests__/editor-schema.test.d.ts +2 -0
- package/lib/packages/editor/src/utils/__tests__/editor-schema.test.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/__tests__/form-item-width.test.d.ts +2 -0
- package/lib/packages/editor/src/utils/__tests__/form-item-width.test.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/__tests__/group-drag-path.test.d.ts +2 -0
- package/lib/packages/editor/src/utils/__tests__/group-drag-path.test.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/__tests__/record-field.test.d.ts +2 -0
- package/lib/packages/editor/src/utils/__tests__/record-field.test.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/component-replace.d.ts +8 -0
- package/lib/packages/editor/src/utils/component-replace.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/editor-schema.d.ts +28 -0
- package/lib/packages/editor/src/utils/editor-schema.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/form-item-width.d.ts +6 -0
- package/lib/packages/editor/src/utils/form-item-width.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/local-dict-center.d.ts +11 -0
- package/lib/packages/editor/src/utils/local-dict-center.d.ts.map +1 -0
- package/lib/packages/editor/src/utils/record-field.d.ts +7 -0
- package/lib/packages/editor/src/utils/record-field.d.ts.map +1 -0
- package/lib/packages/editor/src/validation-rules.d.ts +10 -0
- package/lib/packages/editor/src/validation-rules.d.ts.map +1 -0
- package/lib/packages/editor/src/x-editor.vue.d.ts +107 -0
- package/lib/packages/editor/src/x-editor.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/assets/icon-add-circle-fill.vue.d.ts +3 -0
- package/lib/packages/ui/src/assets/icon-add-circle-fill.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/assets/icon-close-line.vue.d.ts +3 -0
- package/lib/packages/ui/src/assets/icon-close-line.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/assets/icon-drag.vue.d.ts +3 -0
- package/lib/packages/ui/src/assets/icon-drag.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/assets/icon-minus-circle.vue.d.ts +3 -0
- package/lib/packages/ui/src/assets/icon-minus-circle.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/_public/form-item-cols.vue.d.ts +17 -0
- package/lib/packages/ui/src/components/_public/form-item-cols.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/button/type.d.ts +85 -0
- package/lib/packages/ui/src/components/button/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/cascader/index.vue.d.ts +66 -0
- package/lib/packages/ui/src/components/cascader/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/cascader/type.d.ts +125 -0
- package/lib/packages/ui/src/components/cascader/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/checkbox/index.vue.d.ts +30 -0
- package/lib/packages/ui/src/components/checkbox/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/checkbox/type.d.ts +36 -0
- package/lib/packages/ui/src/components/checkbox/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/checkboxes/index.vue.d.ts +42 -0
- package/lib/packages/ui/src/components/checkboxes/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/checkboxes/type.d.ts +56 -0
- package/lib/packages/ui/src/components/checkboxes/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/component/index.d.ts +7 -0
- package/lib/packages/ui/src/components/component/index.d.ts.map +1 -0
- package/lib/packages/ui/src/components/condition-builder/condition-node.vue.d.ts +32 -0
- package/lib/packages/ui/src/components/condition-builder/condition-node.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/condition-builder/group-bracket.vue.d.ts +19 -0
- package/lib/packages/ui/src/components/condition-builder/group-bracket.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/condition-builder/group-indent.vue.d.ts +19 -0
- package/lib/packages/ui/src/components/condition-builder/group-indent.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/condition-builder/index.vue.d.ts +160 -0
- package/lib/packages/ui/src/components/condition-builder/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/condition-builder/type.d.ts +88 -0
- package/lib/packages/ui/src/components/condition-builder/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/crud/action-type.d.ts +80 -0
- package/lib/packages/ui/src/components/crud/action-type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/crud/index.vue.d.ts +78 -0
- package/lib/packages/ui/src/components/crud/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/crud/multi-action.vue.d.ts +8 -0
- package/lib/packages/ui/src/components/crud/multi-action.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/crud/single-action.vue.d.ts +7 -0
- package/lib/packages/ui/src/components/crud/single-action.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/crud/type.d.ts +171 -0
- package/lib/packages/ui/src/components/crud/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/crud-form/index.vue.d.ts +22 -0
- package/lib/packages/ui/src/components/crud-form/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/crud-form/type.d.ts +65 -0
- package/lib/packages/ui/src/components/crud-form/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/date-picker/index.vue.d.ts +35 -0
- package/lib/packages/ui/src/components/date-picker/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/date-picker/type.d.ts +139 -0
- package/lib/packages/ui/src/components/date-picker/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/date-range-picker/index.vue.d.ts +15 -0
- package/lib/packages/ui/src/components/date-range-picker/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/date-range-picker/type.d.ts +137 -0
- package/lib/packages/ui/src/components/date-range-picker/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/date-range-picker-v2/index.vue.d.ts +22 -0
- package/lib/packages/ui/src/components/date-range-picker-v2/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/date-range-picker-v2/type.d.ts +37 -0
- package/lib/packages/ui/src/components/date-range-picker-v2/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/description/index.vue.d.ts +28 -0
- package/lib/packages/ui/src/components/description/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/description/type.d.ts +120 -0
- package/lib/packages/ui/src/components/description/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/dialog/type.d.ts +100 -0
- package/lib/packages/ui/src/components/dialog/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/dropdown/type.d.ts +62 -0
- package/lib/packages/ui/src/components/dropdown/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/ellipsis/index.vue.d.ts +34 -0
- package/lib/packages/ui/src/components/ellipsis/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/ellipsis/type.d.ts +26 -0
- package/lib/packages/ui/src/components/ellipsis/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/event-menu/index.vue.d.ts +25 -0
- package/lib/packages/ui/src/components/event-menu/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/form/form-item.type.d.ts +304 -0
- package/lib/packages/ui/src/components/form/form-item.type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/form/form-item.vue.d.ts +50 -0
- package/lib/packages/ui/src/components/form/form-item.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/form/form-layout-renderer.vue.d.ts +71 -0
- package/lib/packages/ui/src/components/form/form-layout-renderer.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/form/index.vue.d.ts +220 -0
- package/lib/packages/ui/src/components/form/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/form/query-form.d.ts +4 -0
- package/lib/packages/ui/src/components/form/query-form.d.ts.map +1 -0
- package/lib/packages/ui/src/components/form/type.d.ts +312 -0
- package/lib/packages/ui/src/components/form/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/group/group-item.vue.d.ts +9 -0
- package/lib/packages/ui/src/components/group/group-item.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/group/index.vue.d.ts +24 -0
- package/lib/packages/ui/src/components/group/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/group/type.d.ts +119 -0
- package/lib/packages/ui/src/components/group/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/icon-select/__tests__/icon-sources.test.d.ts +2 -0
- package/lib/packages/ui/src/components/icon-select/__tests__/icon-sources.test.d.ts.map +1 -0
- package/lib/packages/ui/src/components/icon-select/icon-parser.vue.d.ts +41 -0
- package/lib/packages/ui/src/components/icon-select/icon-parser.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/icon-select/icon-sources.d.ts +22 -0
- package/lib/packages/ui/src/components/icon-select/icon-sources.d.ts.map +1 -0
- package/lib/packages/ui/src/components/icon-select/index.vue.d.ts +15 -0
- package/lib/packages/ui/src/components/icon-select/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/icon-select/type.d.ts +24 -0
- package/lib/packages/ui/src/components/icon-select/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/index.d.ts +107 -0
- package/lib/packages/ui/src/components/index.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input/index.vue.d.ts +20 -0
- package/lib/packages/ui/src/components/input/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input/type.d.ts +121 -0
- package/lib/packages/ui/src/components/input/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-array/__tests__/layout.test.d.ts +2 -0
- package/lib/packages/ui/src/components/input-array/__tests__/layout.test.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-array/index.vue.d.ts +28 -0
- package/lib/packages/ui/src/components/input-array/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-array/layout.d.ts +11 -0
- package/lib/packages/ui/src/components/input-array/layout.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-array/type.d.ts +89 -0
- package/lib/packages/ui/src/components/input-array/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-collapse/index.vue.d.ts +7 -0
- package/lib/packages/ui/src/components/input-collapse/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-collapse/type.d.ts +50 -0
- package/lib/packages/ui/src/components/input-collapse/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-linked/index.vue.d.ts +13 -0
- package/lib/packages/ui/src/components/input-linked/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-linked/type.d.ts +32 -0
- package/lib/packages/ui/src/components/input-linked/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-number/index.vue.d.ts +29 -0
- package/lib/packages/ui/src/components/input-number/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-number/type.d.ts +57 -0
- package/lib/packages/ui/src/components/input-number/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-number-range/index.vue.d.ts +28 -0
- package/lib/packages/ui/src/components/input-number-range/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-number-range/type.d.ts +49 -0
- package/lib/packages/ui/src/components/input-number-range/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-table/index.vue.d.ts +25 -0
- package/lib/packages/ui/src/components/input-table/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-table/type.d.ts +37 -0
- package/lib/packages/ui/src/components/input-table/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-upload/index.vue.d.ts +11 -0
- package/lib/packages/ui/src/components/input-upload/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/input-upload/type.d.ts +59 -0
- package/lib/packages/ui/src/components/input-upload/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/json/index.vue.d.ts +10 -0
- package/lib/packages/ui/src/components/json/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/link/index.vue.d.ts +21 -0
- package/lib/packages/ui/src/components/link/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/link/type.d.ts +28 -0
- package/lib/packages/ui/src/components/link/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/radios/index.vue.d.ts +42 -0
- package/lib/packages/ui/src/components/radios/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/radios/type.d.ts +36 -0
- package/lib/packages/ui/src/components/radios/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/search-bar/index.vue.d.ts +37 -0
- package/lib/packages/ui/src/components/search-bar/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/select/index.vue.d.ts +48 -0
- package/lib/packages/ui/src/components/select/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/select/type.d.ts +222 -0
- package/lib/packages/ui/src/components/select/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/static/options-viewer.vue.d.ts +16 -0
- package/lib/packages/ui/src/components/static/options-viewer.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/static/rich-text-viewer.vue.d.ts +8 -0
- package/lib/packages/ui/src/components/static/rich-text-viewer.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/static/textarea-viewer.vue.d.ts +6 -0
- package/lib/packages/ui/src/components/static/textarea-viewer.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/switch/index.vue.d.ts +38 -0
- package/lib/packages/ui/src/components/switch/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/switch/type.d.ts +72 -0
- package/lib/packages/ui/src/components/switch/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/table/index.vue.d.ts +1317 -0
- package/lib/packages/ui/src/components/table/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/table/table-column.vue.d.ts +44 -0
- package/lib/packages/ui/src/components/table/table-column.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/table/type.d.ts +306 -0
- package/lib/packages/ui/src/components/table/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/table-select/const.d.ts +14 -0
- package/lib/packages/ui/src/components/table-select/const.d.ts.map +1 -0
- package/lib/packages/ui/src/components/table-select/index.vue.d.ts +21871 -0
- package/lib/packages/ui/src/components/table-select/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/table-select/table-selector-main.vue.d.ts +4795 -0
- package/lib/packages/ui/src/components/table-select/table-selector-main.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/table-select/type.d.ts +71 -0
- package/lib/packages/ui/src/components/table-select/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tabs/index.vue.d.ts +6 -0
- package/lib/packages/ui/src/components/tabs/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tabs/type.d.ts +23 -0
- package/lib/packages/ui/src/components/tabs/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/text/index.vue.d.ts +7 -0
- package/lib/packages/ui/src/components/text/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/text/type.d.ts +7 -0
- package/lib/packages/ui/src/components/text/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/textarea/type.d.ts +79 -0
- package/lib/packages/ui/src/components/textarea/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/toolbar/index.vue.d.ts +15 -0
- package/lib/packages/ui/src/components/toolbar/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/transitions/TransitionHeight.vue.d.ts +30 -0
- package/lib/packages/ui/src/components/transitions/TransitionHeight.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree/index.vue.d.ts +17 -0
- package/lib/packages/ui/src/components/tree/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree/tree-node.vue.d.ts +8 -0
- package/lib/packages/ui/src/components/tree/tree-node.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree/tree-state.d.ts +35 -0
- package/lib/packages/ui/src/components/tree/tree-state.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree/type.d.ts +50 -0
- package/lib/packages/ui/src/components/tree/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree-select/index.vue.d.ts +94 -0
- package/lib/packages/ui/src/components/tree-select/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree-select/type.d.ts +156 -0
- package/lib/packages/ui/src/components/tree-select/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree-select-crud/index.vue.d.ts +3102 -0
- package/lib/packages/ui/src/components/tree-select-crud/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/components/tree-select-crud/type.d.ts +88 -0
- package/lib/packages/ui/src/components/tree-select-crud/type.d.ts.map +1 -0
- package/lib/packages/ui/src/components/upload/index.vue.d.ts +54 -0
- package/lib/packages/ui/src/components/upload/index.vue.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/__tests__/use-option-static.test.d.ts +2 -0
- package/lib/packages/ui/src/composables/__tests__/use-option-static.test.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/index.d.ts +3 -0
- package/lib/packages/ui/src/composables/index.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-action.d.ts +21 -0
- package/lib/packages/ui/src/composables/use-action.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-component.d.ts +74 -0
- package/lib/packages/ui/src/composables/use-component.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-config.d.ts +76 -0
- package/lib/packages/ui/src/composables/use-config.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-draggable.d.ts +22 -0
- package/lib/packages/ui/src/composables/use-draggable.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-input-array.d.ts +45 -0
- package/lib/packages/ui/src/composables/use-input-array.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-label.d.ts +2 -0
- package/lib/packages/ui/src/composables/use-label.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-loading.d.ts +6 -0
- package/lib/packages/ui/src/composables/use-loading.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-option-static.d.ts +51 -0
- package/lib/packages/ui/src/composables/use-option-static.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-options.d.ts +66 -0
- package/lib/packages/ui/src/composables/use-options.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-paging.d.ts +134 -0
- package/lib/packages/ui/src/composables/use-paging.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-scaffold.d.ts +54 -0
- package/lib/packages/ui/src/composables/use-scaffold.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-toggle.d.ts +11 -0
- package/lib/packages/ui/src/composables/use-toggle.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-tree-static-path.d.ts +45 -0
- package/lib/packages/ui/src/composables/use-tree-static-path.d.ts.map +1 -0
- package/lib/packages/ui/src/composables/use-visible.d.ts +11 -0
- package/lib/packages/ui/src/composables/use-visible.d.ts.map +1 -0
- package/lib/packages/ui/src/config/layout.d.ts +9 -0
- package/lib/packages/ui/src/config/layout.d.ts.map +1 -0
- package/lib/packages/ui/src/constants/injection.d.ts +11 -0
- package/lib/packages/ui/src/constants/injection.d.ts.map +1 -0
- package/lib/packages/ui/src/directives/highlight.d.ts +7 -0
- package/lib/packages/ui/src/directives/highlight.d.ts.map +1 -0
- package/lib/packages/ui/src/directives/index.d.ts +2 -0
- package/lib/packages/ui/src/directives/index.d.ts.map +1 -0
- package/lib/packages/ui/src/index.d.ts +59 -0
- package/lib/packages/ui/src/index.d.ts.map +1 -0
- package/lib/packages/ui/src/types/api.d.ts +8 -0
- package/lib/packages/ui/src/types/api.d.ts.map +1 -0
- package/lib/packages/ui/src/types/base.d.ts +306 -0
- package/lib/packages/ui/src/types/base.d.ts.map +1 -0
- package/lib/packages/ui/src/types/form.d.ts +82 -0
- package/lib/packages/ui/src/types/form.d.ts.map +1 -0
- package/lib/packages/ui/src/types/index.d.ts +6 -0
- package/lib/packages/ui/src/types/index.d.ts.map +1 -0
- package/lib/packages/ui/src/types/option.d.ts +115 -0
- package/lib/packages/ui/src/types/option.d.ts.map +1 -0
- package/lib/packages/ui/src/types/pagination.d.ts +35 -0
- package/lib/packages/ui/src/types/pagination.d.ts.map +1 -0
- package/lib/packages/ui/src/types/table.d.ts +34 -0
- package/lib/packages/ui/src/types/table.d.ts.map +1 -0
- package/lib/packages/ui/src/types/util.d.ts +6 -0
- package/lib/packages/ui/src/types/util.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/__tests__/condition.test.d.ts +2 -0
- package/lib/packages/ui/src/utils/__tests__/condition.test.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/__tests__/editor-container.test.d.ts +2 -0
- package/lib/packages/ui/src/utils/__tests__/editor-container.test.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/__tests__/form.test.d.ts +2 -0
- package/lib/packages/ui/src/utils/__tests__/form.test.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/__tests__/tree.test.d.ts +2 -0
- package/lib/packages/ui/src/utils/__tests__/tree.test.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/common.d.ts +13 -0
- package/lib/packages/ui/src/utils/common.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/computed-state-manager.d.ts +3 -0
- package/lib/packages/ui/src/utils/computed-state-manager.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/condition.d.ts +4 -0
- package/lib/packages/ui/src/utils/condition.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/editor-container.d.ts +25 -0
- package/lib/packages/ui/src/utils/editor-container.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/form-item.d.ts +23 -0
- package/lib/packages/ui/src/utils/form-item.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/form.d.ts +75 -0
- package/lib/packages/ui/src/utils/form.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/id.d.ts +24 -0
- package/lib/packages/ui/src/utils/id.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/options.d.ts +14 -0
- package/lib/packages/ui/src/utils/options.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/reactive.d.ts +13 -0
- package/lib/packages/ui/src/utils/reactive.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/style.d.ts +5 -0
- package/lib/packages/ui/src/utils/style.d.ts.map +1 -0
- package/lib/packages/ui/src/utils/tree.d.ts +51 -0
- package/lib/packages/ui/src/utils/tree.d.ts.map +1 -0
- package/lib/xkit-editor.css +2 -0
- package/lib/xkit-editor.js +78741 -0
- package/lib/xkit-editor.umd.cjs +99 -0
- package/package.json +50 -0
- package/src/component-configs/__tests__/config.test.ts +288 -0
- package/src/component-configs/__tests__/group.test.ts +104 -0
- package/src/component-configs/cascader.ts +20 -0
- package/src/component-configs/checkbox.ts +43 -0
- package/src/component-configs/common-props.ts +130 -0
- package/src/component-configs/date-picker.ts +153 -0
- package/src/component-configs/date-range-picker.ts +185 -0
- package/src/component-configs/group.ts +196 -0
- package/src/component-configs/icon-select.ts +56 -0
- package/src/component-configs/input-array.ts +184 -0
- package/src/component-configs/input-number-range.ts +143 -0
- package/src/component-configs/input-number.ts +111 -0
- package/src/component-configs/input-table.ts +191 -0
- package/src/component-configs/input-upload.ts +123 -0
- package/src/component-configs/input.ts +48 -0
- package/src/component-configs/layout-sections.ts +546 -0
- package/src/component-configs/options-config.ts +12 -0
- package/src/component-configs/radio.ts +26 -0
- package/src/component-configs/select.ts +42 -0
- package/src/component-configs/switch.ts +19 -0
- package/src/component-configs/textarea.ts +84 -0
- package/src/component-configs/types.ts +37 -0
- package/src/components/condition-editor.vue +641 -0
- package/src/components/design-renderers/input-array-design.vue +283 -0
- package/src/components/design-renderers/input-table-design.vue +311 -0
- package/src/components/form-item-layout-editor.vue +291 -0
- package/src/components/form-item-span-editor.vue +328 -0
- package/src/components/form-layout-editor.vue +263 -0
- package/src/components/group-title-color-select.vue +75 -0
- package/src/components/group-title-style-picker.vue +125 -0
- package/src/components/input-number-range-binding-editor.vue +226 -0
- package/src/components/input-table-default-rows-editor.vue +147 -0
- package/src/components/input-table-operation-editor.vue +168 -0
- package/src/components/json-code-editor.vue +219 -0
- package/src/components/object-section-editor.vue +342 -0
- package/src/components/options/default-dict-options-panel.vue +197 -0
- package/src/components/options/options-editor.vue +161 -0
- package/src/components/table-columns-editor.vue +353 -0
- package/src/components/validation-rules-editor.vue +321 -0
- package/src/config.ts +51 -0
- package/src/editor-item-wrapper.vue +254 -0
- package/src/group-title-styles.ts +82 -0
- package/src/index.ts +6 -0
- package/src/option-sources.ts +45 -0
- package/src/root-configs.ts +278 -0
- package/src/shims-vue.d.ts +5 -0
- package/src/utils/__tests__/component-replace.test.ts +129 -0
- package/src/utils/__tests__/editor-schema.test.ts +429 -0
- package/src/utils/__tests__/form-item-width.test.ts +53 -0
- package/src/utils/__tests__/group-drag-path.test.ts +84 -0
- package/src/utils/__tests__/record-field.test.ts +34 -0
- package/src/utils/component-replace.ts +67 -0
- package/src/utils/editor-schema.ts +374 -0
- package/src/utils/form-item-width.ts +40 -0
- package/src/utils/local-dict-center.ts +81 -0
- package/src/utils/record-field.ts +30 -0
- package/src/validation-rules.ts +104 -0
- package/src/x-editor.vue +1300 -0
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="form-layout-editor">
|
|
3
|
+
<div class="form-layout-editor__header">
|
|
4
|
+
<span class="form-layout-editor__title">{{ title || '表单布局' }}</span>
|
|
5
|
+
<el-radio-group :model-value="activeType" size="small" @update:modelValue="handleTypeChange">
|
|
6
|
+
<el-radio-button label="grid">栅格</el-radio-button>
|
|
7
|
+
<el-radio-button label="descriptions">描述表</el-radio-button>
|
|
8
|
+
<el-radio-button label="table">表格</el-radio-button>
|
|
9
|
+
</el-radio-group>
|
|
10
|
+
</div>
|
|
11
|
+
|
|
12
|
+
<ObjectSectionEditor
|
|
13
|
+
:key="activeType"
|
|
14
|
+
:model-value="activeProfile"
|
|
15
|
+
:title="activeProfileTitle"
|
|
16
|
+
:root-key="`layout.${activeType}`"
|
|
17
|
+
:value-mode="activeValueMode"
|
|
18
|
+
section-mode="plain"
|
|
19
|
+
:sections="activeSections"
|
|
20
|
+
@update:modelValue="handleProfileChange"
|
|
21
|
+
/>
|
|
22
|
+
</div>
|
|
23
|
+
</template>
|
|
24
|
+
|
|
25
|
+
<script setup lang="ts">
|
|
26
|
+
import { computed } from 'vue'
|
|
27
|
+
import { ElMessageBox, ElRadioButton, ElRadioGroup } from 'element-plus'
|
|
28
|
+
import ObjectSectionEditor from './object-section-editor.vue'
|
|
29
|
+
import { containerLayoutSections, descriptionsLayoutSections, tableLayoutSections } from '../component-configs/layout-sections'
|
|
30
|
+
|
|
31
|
+
type LayoutType = 'grid' | 'descriptions' | 'table'
|
|
32
|
+
|
|
33
|
+
interface LayoutValue {
|
|
34
|
+
type?: LayoutType
|
|
35
|
+
row?: Record<string, any>
|
|
36
|
+
col?: Record<string, any>
|
|
37
|
+
grid?: Record<string, any>
|
|
38
|
+
descriptions?: Record<string, any>
|
|
39
|
+
table?: Record<string, any>
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
const props = defineProps<{
|
|
43
|
+
modelValue?: LayoutValue
|
|
44
|
+
title?: string
|
|
45
|
+
formSchema?: Record<string, any>
|
|
46
|
+
}>()
|
|
47
|
+
|
|
48
|
+
const emit = defineEmits<(event: 'update:modelValue', value: LayoutValue | undefined) => void>()
|
|
49
|
+
|
|
50
|
+
const layoutTypes: LayoutType[] = ['grid', 'descriptions', 'table']
|
|
51
|
+
|
|
52
|
+
const cleanRecord = (value: any) => {
|
|
53
|
+
if (!value || typeof value !== 'object') return undefined
|
|
54
|
+
const next = Object.entries(value).reduce<Record<string, any>>((result, [key, itemValue]) => {
|
|
55
|
+
if (itemValue !== undefined && itemValue !== null && itemValue !== '') {
|
|
56
|
+
result[key] = itemValue
|
|
57
|
+
}
|
|
58
|
+
return result
|
|
59
|
+
}, {})
|
|
60
|
+
return Object.keys(next).length > 0 ? next : undefined
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const normalizeLegacyLayout = (layout?: LayoutValue): LayoutValue => {
|
|
64
|
+
const current = layout || {}
|
|
65
|
+
const grid = current.grid || cleanRecord({ row: current.row, col: current.col })
|
|
66
|
+
return {
|
|
67
|
+
...current,
|
|
68
|
+
type: current.type || 'grid',
|
|
69
|
+
...(grid ? { grid } : {})
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const activeType = computed<LayoutType>(() => {
|
|
74
|
+
const type = props.modelValue?.type
|
|
75
|
+
return layoutTypes.includes(type as LayoutType) ? (type as LayoutType) : 'grid'
|
|
76
|
+
})
|
|
77
|
+
|
|
78
|
+
const normalizedLayout = computed(() => normalizeLegacyLayout(props.modelValue))
|
|
79
|
+
const activeProfile = computed(() => {
|
|
80
|
+
if (activeType.value === 'grid') {
|
|
81
|
+
return normalizedLayout.value.grid || cleanRecord({ row: normalizedLayout.value.row, col: normalizedLayout.value.col }) || {}
|
|
82
|
+
}
|
|
83
|
+
return normalizedLayout.value[activeType.value] || {}
|
|
84
|
+
})
|
|
85
|
+
const activeSections = computed(() => {
|
|
86
|
+
if (activeType.value === 'descriptions') return descriptionsLayoutSections
|
|
87
|
+
if (activeType.value === 'table') return tableLayoutSections
|
|
88
|
+
return containerLayoutSections
|
|
89
|
+
})
|
|
90
|
+
const activeProfileTitle = computed(() => {
|
|
91
|
+
if (activeType.value === 'descriptions') return '描述表配置'
|
|
92
|
+
if (activeType.value === 'table') return '表格配置'
|
|
93
|
+
return '栅格配置'
|
|
94
|
+
})
|
|
95
|
+
const activeValueMode = computed(() => (activeType.value === 'grid' ? 'nested' : 'flat'))
|
|
96
|
+
const getTableColumns = (layout: LayoutValue) => Math.max(2, Math.floor(Number(layout.table?.columns || 4)))
|
|
97
|
+
const getDefaultFieldColumns = (layout: LayoutValue) => Math.min(2, getTableColumns(layout))
|
|
98
|
+
|
|
99
|
+
const defaultProfile = (type: LayoutType, sourceLayout: LayoutValue) => {
|
|
100
|
+
if (type === 'grid') {
|
|
101
|
+
const sourceItemsPerRow = sourceLayout.table?.columns
|
|
102
|
+
? Math.max(1, Math.floor(getTableColumns(sourceLayout) / getDefaultFieldColumns(sourceLayout)))
|
|
103
|
+
: sourceLayout.descriptions?.column || 3
|
|
104
|
+
return {
|
|
105
|
+
row: sourceLayout.grid?.row,
|
|
106
|
+
col: {
|
|
107
|
+
span: Math.max(1, Math.round(24 / sourceItemsPerRow))
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
if (type === 'descriptions') {
|
|
112
|
+
return {
|
|
113
|
+
column: sourceLayout.table?.columns
|
|
114
|
+
? Math.max(1, Math.floor(getTableColumns(sourceLayout) / getDefaultFieldColumns(sourceLayout)))
|
|
115
|
+
: Math.round(24 / (sourceLayout.grid?.col?.span || 8)) || 3,
|
|
116
|
+
labelWidth: props.formSchema?.labelWidth
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return {
|
|
120
|
+
columns: 4,
|
|
121
|
+
labelWidth: props.formSchema?.labelWidth,
|
|
122
|
+
valueMinWidth: 220
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
const clamp = (value: number, min: number, max: number) => Math.min(Math.max(value, min), max)
|
|
127
|
+
|
|
128
|
+
const getGridSpan = (item: any, layout: LayoutValue) => {
|
|
129
|
+
return item.layoutCfg?.grid?.span ?? item.span ?? layout.grid?.col?.span ?? layout.col?.span ?? 24
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
const getSourceUnits = (item: any, sourceType: LayoutType, layout: LayoutValue) => {
|
|
133
|
+
if (sourceType === 'table') {
|
|
134
|
+
const itemProfile = item.layoutCfg?.table || {}
|
|
135
|
+
const labelColspan = Math.max(1, Math.floor(Number(itemProfile.labelColspan || 1)))
|
|
136
|
+
const valueColspan = Math.max(1, Math.floor(Number(itemProfile.valueColspan || 1)))
|
|
137
|
+
return {
|
|
138
|
+
value: labelColspan + valueColspan,
|
|
139
|
+
total: getTableColumns(layout)
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
if (sourceType === 'descriptions') {
|
|
143
|
+
return {
|
|
144
|
+
value: item.layoutCfg?.descriptions?.span ?? 1,
|
|
145
|
+
total: layout.descriptions?.column ?? 3
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
return {
|
|
149
|
+
value: getGridSpan(item, layout),
|
|
150
|
+
total: 24
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
const ensureLayoutCfg = (item: any) => {
|
|
155
|
+
if (!item.layoutCfg || typeof item.layoutCfg !== 'object') {
|
|
156
|
+
item.layoutCfg = {}
|
|
157
|
+
}
|
|
158
|
+
return item.layoutCfg
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
const migrateItemToLayout = (item: any, sourceType: LayoutType, targetType: LayoutType, layout: LayoutValue) => {
|
|
162
|
+
const cfg = ensureLayoutCfg(item)
|
|
163
|
+
const source = getSourceUnits(item, sourceType, layout)
|
|
164
|
+
if (targetType === 'table') {
|
|
165
|
+
const columns = getTableColumns(layout)
|
|
166
|
+
const fieldColumns = clamp(Math.round((source.value / source.total) * columns), 2, columns)
|
|
167
|
+
cfg.table = {
|
|
168
|
+
...(cfg.table || {}),
|
|
169
|
+
labelColspan: 1,
|
|
170
|
+
valueColspan: fieldColumns - 1
|
|
171
|
+
}
|
|
172
|
+
} else if (targetType === 'descriptions') {
|
|
173
|
+
const column = layout.descriptions?.column ?? defaultProfile('descriptions', layout).column ?? 3
|
|
174
|
+
cfg.descriptions = {
|
|
175
|
+
...(cfg.descriptions || {}),
|
|
176
|
+
span: clamp(Math.round((source.value / source.total) * column), 1, column)
|
|
177
|
+
}
|
|
178
|
+
} else {
|
|
179
|
+
cfg.grid = {
|
|
180
|
+
...(cfg.grid || {}),
|
|
181
|
+
span: clamp(Math.round((source.value / source.total) * 24), 1, 24)
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
if (Array.isArray(item.body)) {
|
|
186
|
+
item.body.forEach((child: any) => migrateItemToLayout(child, sourceType, targetType, layout))
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
const migrateBodyToLayout = (sourceType: LayoutType, targetType: LayoutType, layout: LayoutValue) => {
|
|
191
|
+
const body = props.formSchema?.body
|
|
192
|
+
if (!Array.isArray(body)) return
|
|
193
|
+
body.forEach((item) => migrateItemToLayout(item, sourceType, targetType, layout))
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
const emitLayout = (layout: LayoutValue) => {
|
|
197
|
+
const next = cleanRecord(layout) as LayoutValue | undefined
|
|
198
|
+
emit('update:modelValue', next)
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
const handleProfileChange = (profile: Record<string, any>) => {
|
|
202
|
+
const next = normalizeLegacyLayout(props.modelValue)
|
|
203
|
+
next[activeType.value] = profile
|
|
204
|
+
if (activeType.value === 'grid') {
|
|
205
|
+
delete next.row
|
|
206
|
+
delete next.col
|
|
207
|
+
}
|
|
208
|
+
emitLayout(next)
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
const handleTypeChange = async (nextTypeValue: string | number | boolean) => {
|
|
212
|
+
const nextType = nextTypeValue as LayoutType
|
|
213
|
+
if (nextType === activeType.value || !layoutTypes.includes(nextType)) return
|
|
214
|
+
|
|
215
|
+
const sourceType = activeType.value
|
|
216
|
+
const next = normalizeLegacyLayout(props.modelValue)
|
|
217
|
+
next.type = nextType
|
|
218
|
+
|
|
219
|
+
if (next[nextType]) {
|
|
220
|
+
emitLayout(next)
|
|
221
|
+
return
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
const targetProfile = defaultProfile(nextType, next)
|
|
225
|
+
try {
|
|
226
|
+
await ElMessageBox.confirm('目标布局还没有配置。是否保留当前布局方案,并根据当前字段比例近似生成目标布局配置?', '切换布局', {
|
|
227
|
+
confirmButtonText: '保留并迁移',
|
|
228
|
+
cancelButtonText: '仅切换',
|
|
229
|
+
distinguishCancelAndClose: true,
|
|
230
|
+
type: 'warning'
|
|
231
|
+
})
|
|
232
|
+
next[nextType] = targetProfile
|
|
233
|
+
migrateBodyToLayout(sourceType, nextType, next)
|
|
234
|
+
emitLayout(next)
|
|
235
|
+
} catch (action) {
|
|
236
|
+
if (action === 'cancel') {
|
|
237
|
+
next[nextType] = targetProfile
|
|
238
|
+
emitLayout(next)
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
</script>
|
|
243
|
+
|
|
244
|
+
<style scoped lang="scss">
|
|
245
|
+
.form-layout-editor {
|
|
246
|
+
width: 100%;
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
.form-layout-editor__header {
|
|
250
|
+
display: flex;
|
|
251
|
+
align-items: center;
|
|
252
|
+
justify-content: space-between;
|
|
253
|
+
gap: 8px;
|
|
254
|
+
margin-bottom: 8px;
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
.form-layout-editor__title {
|
|
258
|
+
min-width: 0;
|
|
259
|
+
color: var(--el-text-color-primary);
|
|
260
|
+
font-size: 13px;
|
|
261
|
+
font-weight: 600;
|
|
262
|
+
}
|
|
263
|
+
</style>
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<ElSelect :model-value="currentValue" class="group-title-color-select" @change="handleChange">
|
|
3
|
+
<ElOption v-for="option in colorOptions" :key="option.value" :label="option.label" :value="option.value">
|
|
4
|
+
<span class="group-title-color-select__option">
|
|
5
|
+
<span class="group-title-color-select__swatch" :class="option.swatchClass" />
|
|
6
|
+
<span>{{ option.label }}</span>
|
|
7
|
+
</span>
|
|
8
|
+
</ElOption>
|
|
9
|
+
<template #label="{ label, value }">
|
|
10
|
+
<span class="group-title-color-select__selected">
|
|
11
|
+
<span class="group-title-color-select__swatch" :class="getSwatchClass(value)" />
|
|
12
|
+
<span>{{ label }}</span>
|
|
13
|
+
</span>
|
|
14
|
+
</template>
|
|
15
|
+
</ElSelect>
|
|
16
|
+
</template>
|
|
17
|
+
|
|
18
|
+
<script setup lang="ts">
|
|
19
|
+
import { computed } from 'vue'
|
|
20
|
+
import { ElOption, ElSelect } from 'element-plus'
|
|
21
|
+
|
|
22
|
+
const props = defineProps<{
|
|
23
|
+
modelValue?: string
|
|
24
|
+
}>()
|
|
25
|
+
|
|
26
|
+
const emit = defineEmits<{
|
|
27
|
+
(event: 'update:modelValue', value: string | undefined): void
|
|
28
|
+
}>()
|
|
29
|
+
|
|
30
|
+
const colorOptions = [
|
|
31
|
+
{ label: '主题色', value: 'primary', swatchClass: 'is-primary' },
|
|
32
|
+
{ label: '主文字', value: 'main', swatchClass: 'is-main' },
|
|
33
|
+
{ label: '次文字', value: 'secondary', swatchClass: 'is-secondary' }
|
|
34
|
+
]
|
|
35
|
+
|
|
36
|
+
const currentValue = computed(() => props.modelValue || 'main')
|
|
37
|
+
const getSwatchClass = (value: string) => colorOptions.find((option) => option.value === value)?.swatchClass
|
|
38
|
+
|
|
39
|
+
const handleChange = (value: string) => {
|
|
40
|
+
emit('update:modelValue', value === 'main' ? undefined : value)
|
|
41
|
+
}
|
|
42
|
+
</script>
|
|
43
|
+
|
|
44
|
+
<style scoped>
|
|
45
|
+
.group-title-color-select {
|
|
46
|
+
width: 100%;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.group-title-color-select__option,
|
|
50
|
+
.group-title-color-select__selected {
|
|
51
|
+
display: inline-flex;
|
|
52
|
+
align-items: center;
|
|
53
|
+
gap: 8px;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.group-title-color-select__swatch {
|
|
57
|
+
width: 14px;
|
|
58
|
+
height: 14px;
|
|
59
|
+
border: 1px solid var(--el-border-color);
|
|
60
|
+
border-radius: 3px;
|
|
61
|
+
flex: 0 0 auto;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
.group-title-color-select__swatch.is-primary {
|
|
65
|
+
background: var(--el-color-primary);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
.group-title-color-select__swatch.is-main {
|
|
69
|
+
background: var(--x-group-title-color-main, #333333);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
.group-title-color-select__swatch.is-secondary {
|
|
73
|
+
background: var(--x-group-title-color-secondary, #666666);
|
|
74
|
+
}
|
|
75
|
+
</style>
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="group-title-style-picker">
|
|
3
|
+
<button class="group-title-style-picker__trigger" type="button" @click="dialogVisible = true">
|
|
4
|
+
<span class="group-title-style-picker__trigger-text">{{ currentStyle?.label || '选择标题样式' }}</span>
|
|
5
|
+
<span class="group-title-style-picker__trigger-sample" :class="modelValue">{{ previewTitle }}</span>
|
|
6
|
+
</button>
|
|
7
|
+
|
|
8
|
+
<ElDialog v-model="dialogVisible" title="选择标题样式" width="760px" append-to-body>
|
|
9
|
+
<div class="group-title-style-picker__grid">
|
|
10
|
+
<button
|
|
11
|
+
v-for="style in styles"
|
|
12
|
+
:key="style.key"
|
|
13
|
+
class="group-title-style-picker__card"
|
|
14
|
+
:class="{ 'is-active': style.className === normalizedValue }"
|
|
15
|
+
type="button"
|
|
16
|
+
@click="handleSelect(style.className)"
|
|
17
|
+
>
|
|
18
|
+
<span class="group-title-style-picker__preview" :class="style.className">{{ previewTitle }}</span>
|
|
19
|
+
<span class="group-title-style-picker__name">{{ style.label }}</span>
|
|
20
|
+
<span v-if="style.description" class="group-title-style-picker__description">{{ style.description }}</span>
|
|
21
|
+
</button>
|
|
22
|
+
</div>
|
|
23
|
+
</ElDialog>
|
|
24
|
+
</div>
|
|
25
|
+
</template>
|
|
26
|
+
|
|
27
|
+
<script setup lang="ts">
|
|
28
|
+
import { computed, inject, ref, type ComputedRef } from 'vue'
|
|
29
|
+
import { ElDialog } from 'element-plus'
|
|
30
|
+
import { getEditorGroupTitleStyles } from '../group-title-styles'
|
|
31
|
+
|
|
32
|
+
const props = defineProps<{
|
|
33
|
+
modelValue?: string
|
|
34
|
+
}>()
|
|
35
|
+
|
|
36
|
+
const emit = defineEmits<{
|
|
37
|
+
(event: 'update:modelValue', value: string | undefined): void
|
|
38
|
+
}>()
|
|
39
|
+
|
|
40
|
+
const editorContext = inject<ComputedRef<{ selectedItem?: any }> | null>('x-editor-context', null)
|
|
41
|
+
const dialogVisible = ref(false)
|
|
42
|
+
|
|
43
|
+
const styles = computed(() => getEditorGroupTitleStyles())
|
|
44
|
+
const normalizedValue = computed(() => props.modelValue || '')
|
|
45
|
+
const currentStyle = computed(() => styles.value.find((style) => style.className === normalizedValue.value))
|
|
46
|
+
const previewTitle = computed(() => editorContext?.value?.selectedItem?.title || '分组标题')
|
|
47
|
+
|
|
48
|
+
const handleSelect = (className: string) => {
|
|
49
|
+
emit('update:modelValue', className || undefined)
|
|
50
|
+
dialogVisible.value = false
|
|
51
|
+
}
|
|
52
|
+
</script>
|
|
53
|
+
|
|
54
|
+
<style scoped>
|
|
55
|
+
.group-title-style-picker {
|
|
56
|
+
width: 100%;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
.group-title-style-picker__trigger {
|
|
60
|
+
display: grid;
|
|
61
|
+
width: 100%;
|
|
62
|
+
min-height: 40px;
|
|
63
|
+
padding: 8px 10px;
|
|
64
|
+
color: var(--el-text-color-primary);
|
|
65
|
+
text-align: left;
|
|
66
|
+
cursor: pointer;
|
|
67
|
+
background: var(--el-fill-color-blank);
|
|
68
|
+
border: 1px solid var(--el-border-color);
|
|
69
|
+
border-radius: 4px;
|
|
70
|
+
gap: 8px;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
.group-title-style-picker__trigger:hover {
|
|
74
|
+
border-color: var(--el-color-primary);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
.group-title-style-picker__trigger-text {
|
|
78
|
+
font-size: 12px;
|
|
79
|
+
color: var(--el-text-color-secondary);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
.group-title-style-picker__trigger-sample {
|
|
83
|
+
display: block;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
.group-title-style-picker__grid {
|
|
87
|
+
display: grid;
|
|
88
|
+
grid-template-columns: repeat(2, minmax(0, 1fr));
|
|
89
|
+
gap: 12px;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
.group-title-style-picker__card {
|
|
93
|
+
display: grid;
|
|
94
|
+
min-height: 112px;
|
|
95
|
+
padding: 14px;
|
|
96
|
+
text-align: left;
|
|
97
|
+
cursor: pointer;
|
|
98
|
+
background: var(--el-fill-color-blank);
|
|
99
|
+
border: 1px solid var(--el-border-color);
|
|
100
|
+
border-radius: 6px;
|
|
101
|
+
gap: 8px;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
.group-title-style-picker__card:hover,
|
|
105
|
+
.group-title-style-picker__card.is-active {
|
|
106
|
+
border-color: var(--el-color-primary);
|
|
107
|
+
box-shadow: 0 0 0 1px var(--el-color-primary-light-7);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
.group-title-style-picker__preview {
|
|
111
|
+
display: block;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
.group-title-style-picker__name {
|
|
115
|
+
font-size: 13px;
|
|
116
|
+
font-weight: 600;
|
|
117
|
+
color: var(--el-text-color-primary);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
.group-title-style-picker__description {
|
|
121
|
+
font-size: 12px;
|
|
122
|
+
line-height: 1.4;
|
|
123
|
+
color: var(--el-text-color-secondary);
|
|
124
|
+
}
|
|
125
|
+
</style>
|
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="input-number-range-binding-editor">
|
|
3
|
+
<div class="input-number-range-binding-editor__header">
|
|
4
|
+
<div class="input-number-range-binding-editor__title">字段名</div>
|
|
5
|
+
<div v-if="allowTuple" class="input-number-range-binding-editor__tabs">
|
|
6
|
+
<button
|
|
7
|
+
v-for="option in modeOptions"
|
|
8
|
+
:key="option.value"
|
|
9
|
+
class="input-number-range-binding-editor__tab"
|
|
10
|
+
:class="{ 'is-active': option.value === bindingMode }"
|
|
11
|
+
type="button"
|
|
12
|
+
@click="handleModeChange(option.value)"
|
|
13
|
+
>
|
|
14
|
+
{{ option.label }}
|
|
15
|
+
</button>
|
|
16
|
+
</div>
|
|
17
|
+
</div>
|
|
18
|
+
|
|
19
|
+
<div class="input-number-range-binding-editor__panel">
|
|
20
|
+
<span class="input-number-range-binding-editor__corner" />
|
|
21
|
+
<div class="input-number-range-binding-editor__path">{{ bindingMode === 'tuple' ? 'name' : 'sync' }}</div>
|
|
22
|
+
<div v-if="bindingMode === 'tuple'" class="input-number-range-binding-editor__fields">
|
|
23
|
+
<label class="input-number-range-binding-editor__field">
|
|
24
|
+
<span class="input-number-range-binding-editor__field-label">字段名</span>
|
|
25
|
+
<ElInput :model-value="tupleField" placeholder="字段名" clearable @update:modelValue="handleTupleFieldChange" />
|
|
26
|
+
</label>
|
|
27
|
+
</div>
|
|
28
|
+
<div v-else class="input-number-range-binding-editor__fields">
|
|
29
|
+
<label class="input-number-range-binding-editor__field">
|
|
30
|
+
<span class="input-number-range-binding-editor__field-label">{{ startFieldLabel }}</span>
|
|
31
|
+
<ElInput :model-value="startField" :placeholder="startFieldPlaceholder" clearable @update:modelValue="handleStartFieldChange" />
|
|
32
|
+
</label>
|
|
33
|
+
<label class="input-number-range-binding-editor__field">
|
|
34
|
+
<span class="input-number-range-binding-editor__field-label">{{ endFieldLabel }}</span>
|
|
35
|
+
<ElInput :model-value="endField" :placeholder="endFieldPlaceholder" clearable @update:modelValue="handleEndFieldChange" />
|
|
36
|
+
</label>
|
|
37
|
+
</div>
|
|
38
|
+
</div>
|
|
39
|
+
</div>
|
|
40
|
+
</template>
|
|
41
|
+
|
|
42
|
+
<script setup lang="ts">
|
|
43
|
+
import { computed } from 'vue'
|
|
44
|
+
import { ElInput } from 'element-plus'
|
|
45
|
+
|
|
46
|
+
type BindingMode = 'tuple' | 'separate'
|
|
47
|
+
|
|
48
|
+
interface SyncItem {
|
|
49
|
+
name: string
|
|
50
|
+
syncName: string
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const props = defineProps<{
|
|
54
|
+
modelValue?: SyncItem[]
|
|
55
|
+
name?: string
|
|
56
|
+
allowTuple?: boolean
|
|
57
|
+
defaultBaseName?: string
|
|
58
|
+
startFieldLabel?: string
|
|
59
|
+
endFieldLabel?: string
|
|
60
|
+
startPlaceholder?: string
|
|
61
|
+
endPlaceholder?: string
|
|
62
|
+
startSyncName?: string
|
|
63
|
+
endSyncName?: string
|
|
64
|
+
}>()
|
|
65
|
+
|
|
66
|
+
const emit = defineEmits<{
|
|
67
|
+
(event: 'update:modelValue', value: SyncItem[] | undefined): void
|
|
68
|
+
(event: 'update:name', value: string | undefined): void
|
|
69
|
+
}>()
|
|
70
|
+
|
|
71
|
+
const modeOptions: { label: string; value: BindingMode }[] = [
|
|
72
|
+
{ label: '单字段', value: 'tuple' },
|
|
73
|
+
{ label: '分别字段', value: 'separate' }
|
|
74
|
+
]
|
|
75
|
+
|
|
76
|
+
const allowTuple = computed(() => props.allowTuple !== false)
|
|
77
|
+
const startSyncName = computed(() => props.startSyncName || 'startValue')
|
|
78
|
+
const endSyncName = computed(() => props.endSyncName || 'endValue')
|
|
79
|
+
const startFieldLabel = computed(() => props.startFieldLabel || '开始字段')
|
|
80
|
+
const endFieldLabel = computed(() => props.endFieldLabel || '结束字段')
|
|
81
|
+
const startFieldPlaceholder = computed(() => props.startPlaceholder || startFieldLabel.value)
|
|
82
|
+
const endFieldPlaceholder = computed(() => props.endPlaceholder || endFieldLabel.value)
|
|
83
|
+
const startSync = computed(() => props.modelValue?.find((item) => item.syncName === startSyncName.value))
|
|
84
|
+
const endSync = computed(() => props.modelValue?.find((item) => item.syncName === endSyncName.value))
|
|
85
|
+
const bindingMode = computed<BindingMode>(() => (!allowTuple.value || startSync.value || endSync.value ? 'separate' : 'tuple'))
|
|
86
|
+
const tupleField = computed(() => props.name || '')
|
|
87
|
+
const startField = computed(() => startSync.value?.name || '')
|
|
88
|
+
const endField = computed(() => endSync.value?.name || '')
|
|
89
|
+
|
|
90
|
+
const cleanField = (value: string) => value.trim()
|
|
91
|
+
|
|
92
|
+
const createSeparateSync = (startName: string, endName: string): SyncItem[] | undefined => {
|
|
93
|
+
const start = cleanField(startName)
|
|
94
|
+
const end = cleanField(endName)
|
|
95
|
+
const items: SyncItem[] = []
|
|
96
|
+
if (start) items.push({ name: start, syncName: startSyncName.value })
|
|
97
|
+
if (end) items.push({ name: end, syncName: endSyncName.value })
|
|
98
|
+
return items.length ? items : undefined
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const createFieldName = (suffix: string) => {
|
|
102
|
+
const baseName = cleanField(props.name || props.defaultBaseName || 'range')
|
|
103
|
+
return baseName ? `${baseName}${suffix}` : ''
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
const handleModeChange = (mode: string | number | boolean | undefined) => {
|
|
107
|
+
if (mode === 'separate') {
|
|
108
|
+
emit('update:name', undefined)
|
|
109
|
+
emit('update:modelValue', createSeparateSync(startField.value || createFieldName('Start'), endField.value || createFieldName('End')))
|
|
110
|
+
return
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
if (allowTuple.value) {
|
|
114
|
+
emit('update:modelValue', undefined)
|
|
115
|
+
emit('update:name', cleanField(props.name || startField.value.replace(/Start$/, '') || props.defaultBaseName || 'range') || undefined)
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
const handleTupleFieldChange = (value: string) => {
|
|
120
|
+
emit('update:modelValue', undefined)
|
|
121
|
+
emit('update:name', cleanField(value) || undefined)
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
const handleStartFieldChange = (value: string) => {
|
|
125
|
+
emit('update:name', undefined)
|
|
126
|
+
emit('update:modelValue', createSeparateSync(value, endField.value))
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
const handleEndFieldChange = (value: string) => {
|
|
130
|
+
emit('update:name', undefined)
|
|
131
|
+
emit('update:modelValue', createSeparateSync(startField.value, value))
|
|
132
|
+
}
|
|
133
|
+
</script>
|
|
134
|
+
|
|
135
|
+
<style scoped lang="scss">
|
|
136
|
+
.input-number-range-binding-editor {
|
|
137
|
+
width: 100%;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
.input-number-range-binding-editor__header {
|
|
141
|
+
display: flex;
|
|
142
|
+
align-items: center;
|
|
143
|
+
justify-content: flex-end;
|
|
144
|
+
gap: 8px;
|
|
145
|
+
margin-bottom: 8px;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
.input-number-range-binding-editor__title {
|
|
149
|
+
flex: 1;
|
|
150
|
+
min-width: 0;
|
|
151
|
+
color: var(--el-text-color-primary);
|
|
152
|
+
font-size: 13px;
|
|
153
|
+
font-weight: 600;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
.input-number-range-binding-editor__tabs {
|
|
157
|
+
display: flex;
|
|
158
|
+
flex: none;
|
|
159
|
+
gap: 4px;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
.input-number-range-binding-editor__tab {
|
|
163
|
+
height: 24px;
|
|
164
|
+
padding: 0 10px;
|
|
165
|
+
color: var(--el-text-color-regular);
|
|
166
|
+
font-size: 12px;
|
|
167
|
+
line-height: 22px;
|
|
168
|
+
background: var(--el-fill-color-blank);
|
|
169
|
+
border: 1px solid var(--el-border-color);
|
|
170
|
+
border-radius: 4px;
|
|
171
|
+
cursor: pointer;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
.input-number-range-binding-editor__tab.is-active {
|
|
175
|
+
color: var(--el-color-primary);
|
|
176
|
+
background: var(--el-color-primary-light-9);
|
|
177
|
+
border-color: var(--el-color-primary);
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
.input-number-range-binding-editor__panel {
|
|
181
|
+
position: relative;
|
|
182
|
+
padding: 28px 10px 10px;
|
|
183
|
+
background: var(--el-fill-color-light);
|
|
184
|
+
border: 1px solid var(--el-border-color-lighter);
|
|
185
|
+
border-radius: 6px;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
.input-number-range-binding-editor__corner {
|
|
189
|
+
position: absolute;
|
|
190
|
+
top: 0;
|
|
191
|
+
right: 0;
|
|
192
|
+
width: 0;
|
|
193
|
+
height: 0;
|
|
194
|
+
border-top: 18px solid var(--el-color-primary-light-5);
|
|
195
|
+
border-left: 18px solid transparent;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
.input-number-range-binding-editor__path {
|
|
199
|
+
position: absolute;
|
|
200
|
+
top: 7px;
|
|
201
|
+
right: 22px;
|
|
202
|
+
color: var(--el-text-color-secondary);
|
|
203
|
+
font-size: 11px;
|
|
204
|
+
line-height: 1;
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
.input-number-range-binding-editor__fields {
|
|
208
|
+
display: grid;
|
|
209
|
+
grid-template-columns: minmax(0, 1fr);
|
|
210
|
+
gap: 8px;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
.input-number-range-binding-editor__field {
|
|
214
|
+
display: grid;
|
|
215
|
+
grid-template-columns: 64px minmax(0, 1fr);
|
|
216
|
+
align-items: center;
|
|
217
|
+
gap: 8px;
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
.input-number-range-binding-editor__field-label {
|
|
221
|
+
color: var(--el-text-color-regular);
|
|
222
|
+
font-size: 12px;
|
|
223
|
+
line-height: 24px;
|
|
224
|
+
text-align: right;
|
|
225
|
+
}
|
|
226
|
+
</style>
|