@kp-ui/lowcode 1.0.24 → 1.0.26
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/_virtual/_plugin-vue_export-helper.js +7 -6
- package/_virtual/virtual_svg-icons-register.js +21 -6
- package/designer.js +220 -162
- package/index.js +60 -56
- package/package.json +1 -1
- package/render.js +607 -376
- package/src/api/useFilesystemApi/filesystem/index.js +31 -23
- package/src/components/CustomRender/components/AttachmentRender.vue.js +4 -4
- package/src/components/CustomRender/components/AttachmentRender.vue2.js +77 -55
- package/src/components/CustomRender/index.js +34 -28
- package/src/components/TpfCollapse/TpfCollapseTitle.vue.js +4 -4
- package/src/components/TpfCollapse/TpfCollapseTitle.vue2.js +9 -6
- package/src/components/code-editor/code-modal-editor.vue.js +43 -40
- package/src/components/code-editor/code-modal-editor.vue2.js +16 -13
- package/src/components/code-editor/index.vue.js +83 -44
- package/src/components/form-designer/designer.js +681 -393
- package/src/components/form-designer/form-widget/container-widget/container-wrapper.vue.js +77 -66
- package/src/components/form-designer/form-widget/container-widget/containerMixin.js +51 -26
- package/src/components/form-designer/form-widget/container-widget/data-table-widget.vue.js +76 -67
- package/src/components/form-designer/form-widget/container-widget/data-table-widget.vue2.js +14 -14
- package/src/components/form-designer/form-widget/container-widget/grid-col-widget.vue.js +175 -117
- package/src/components/form-designer/form-widget/container-widget/grid-sub-form-widget.vue.js +56 -49
- package/src/components/form-designer/form-widget/container-widget/grid-widget.vue.js +41 -37
- package/src/components/form-designer/form-widget/container-widget/index.js +21 -20
- package/src/components/form-designer/form-widget/container-widget/sub-form-widget.vue.js +62 -54
- package/src/components/form-designer/form-widget/container-widget/tab-widget.vue.js +115 -92
- package/src/components/form-designer/form-widget/container-widget/table-cell-widget.vue.js +189 -143
- package/src/components/form-designer/form-widget/container-widget/table-widget.vue.js +54 -48
- package/src/components/form-designer/form-widget/container-widget/vf-box-item.vue.js +87 -72
- package/src/components/form-designer/form-widget/container-widget/vf-box-widget.vue.js +100 -76
- package/src/components/form-designer/form-widget/container-widget/vf-collapse-widget.vue.js +99 -91
- package/src/components/form-designer/form-widget/container-widget/vf-collapse-widget.vue2.js +29 -29
- package/src/components/form-designer/form-widget/container-widget/vf-dialog-widget.vue.js +84 -62
- package/src/components/form-designer/form-widget/container-widget/vf-drawer-widget.vue.js +84 -62
- package/src/components/form-designer/form-widget/field-widget/attachment-render-widget.vue.js +48 -36
- package/src/components/form-designer/form-widget/field-widget/bpmn-editor-widget.vue.js +57 -38
- package/src/components/form-designer/form-widget/field-widget/button-widget.vue.js +49 -45
- package/src/components/form-designer/form-widget/field-widget/cascader-widget.vue.js +69 -53
- package/src/components/form-designer/form-widget/field-widget/checkbox-widget.vue.js +59 -49
- package/src/components/form-designer/form-widget/field-widget/code-editor-widget.vue.js +42 -37
- package/src/components/form-designer/form-widget/field-widget/color-widget.vue.js +43 -37
- package/src/components/form-designer/form-widget/field-widget/date-range-widget.vue.js +65 -54
- package/src/components/form-designer/form-widget/field-widget/date-widget.vue.js +69 -55
- package/src/components/form-designer/form-widget/field-widget/divider-widget.vue.js +35 -32
- package/src/components/form-designer/form-widget/field-widget/dropdown-widget.vue.js +69 -58
- package/src/components/form-designer/form-widget/field-widget/fieldMixin.js +521 -217
- package/src/components/form-designer/form-widget/field-widget/file-upload-widget.vue.js +67 -57
- package/src/components/form-designer/form-widget/field-widget/file-upload-widget.vue2.js +140 -97
- package/src/components/form-designer/form-widget/field-widget/form-item-wrapper.vue.js +192 -124
- package/src/components/form-designer/form-widget/field-widget/html-text-widget.vue.js +34 -31
- package/src/components/form-designer/form-widget/field-widget/index.js +36 -35
- package/src/components/form-designer/form-widget/field-widget/input-widget.vue.js +85 -66
- package/src/components/form-designer/form-widget/field-widget/number-widget.vue.js +64 -50
- package/src/components/form-designer/form-widget/field-widget/picture-upload-widget.vue.js +174 -107
- package/src/components/form-designer/form-widget/field-widget/radio-widget.vue.js +84 -64
- package/src/components/form-designer/form-widget/field-widget/rate-widget.vue.js +41 -36
- package/src/components/form-designer/form-widget/field-widget/rich-editor-widget.vue.js +55 -46
- package/src/components/form-designer/form-widget/field-widget/select-widget.vue.js +83 -63
- package/src/components/form-designer/form-widget/field-widget/slider-widget.vue.js +50 -42
- package/src/components/form-designer/form-widget/field-widget/slot-widget.vue.js +47 -33
- package/src/components/form-designer/form-widget/field-widget/static-content-wrapper.vue.js +96 -68
- package/src/components/form-designer/form-widget/field-widget/static-text-widget.vue.js +30 -28
- package/src/components/form-designer/form-widget/field-widget/switch-widget.vue.js +45 -37
- package/src/components/form-designer/form-widget/field-widget/textarea-widget.vue.js +68 -54
- package/src/components/form-designer/form-widget/field-widget/time-range-widget.vue.js +68 -51
- package/src/components/form-designer/form-widget/field-widget/time-widget.vue.js +61 -48
- package/src/components/form-designer/form-widget/field-widget/treeSelect-widget.vue.js +71 -56
- package/src/components/form-designer/form-widget/index.vue.js +101 -77
- package/src/components/form-designer/refMixinDesign.js +18 -8
- package/src/components/form-designer/setting-panel/form-crud-setting.vue.js +77 -62
- package/src/components/form-designer/setting-panel/form-setting.vue.js +306 -247
- package/src/components/form-designer/setting-panel/index.vue.js +289 -233
- package/src/components/form-designer/setting-panel/option-items-setting.vue.js +234 -186
- package/src/components/form-designer/setting-panel/property-editor/accept-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/actionColumnPosition-editor.vue.js +24 -22
- package/src/components/form-designer/setting-panel/property-editor/addonAfter-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/addonBefore-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/allowClear-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/appendButton-editor.vue.js +23 -21
- package/src/components/form-designer/setting-panel/property-editor/appendButtonDisabled-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/autoFullWidth-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/border-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/buttonIcon-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/buttonStyle-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/code-editor/code-editor-mode.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/columnWidth-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/customRowEvent/data-table-customRow-editor.vue.js +41 -40
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-colorRow-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-customClass-editor.vue.js +38 -28
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-dsEnabled-editor.vue.js +46 -41
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-pagination-editor.vue.js +103 -89
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-rowKey-editor.vue.js +14 -13
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-selections-editor.vue.js +73 -65
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-showButtonsColumn-editor.vue.js +273 -248
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-showIndex-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-stripe-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-tableColumns-editor.vue.js +196 -171
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-tableHeight-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-tableSize-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-tableWidth-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-data-table/data-table-treeDataEnabled-editor.vue.js +41 -33
- package/src/components/form-designer/setting-panel/property-editor/container-grid/colHeight-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/container-grid/gutter-editor.vue.js +72 -59
- package/src/components/form-designer/setting-panel/property-editor/container-grid-col/grid-col-offset-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-grid-col/grid-col-pull-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-grid-col/grid-col-push-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-grid-col/grid-col-responsive-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-grid-col/grid-col-span-editor.vue.js +43 -42
- package/src/components/form-designer/setting-panel/property-editor/container-sub-form/showBlankRow-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-sub-form/showRowNumber-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-sub-form/sub-form-labelAlign-editor.vue.js +24 -22
- package/src/components/form-designer/setting-panel/property-editor/container-tab/tab-customClass-editor.vue.js +73 -57
- package/src/components/form-designer/setting-panel/property-editor/container-tab/tab-tabBarGutter-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/container-tab/tab-tabPosition-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-tab/tab-type-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-table-cell/cellHeight-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-table-cell/cellWidth-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/bodyStyle-editor.vue.js +51 -45
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/cancelButtonHidden-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/cancelButtonLabel-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/closeOnClickModal-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/closeOnPressEscape-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/collapseIcon-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/disabledMode-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/formCode-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/fullscreen-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/height-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/isCollapse-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/okButtonHidden-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/okButtonLabel-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/readMode-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/showClose-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/title-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/unCollapseIcon-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/container-vf-dialog/width-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/container-vf-drawer/vf-drawer-direction-editor.vue.js +30 -28
- package/src/components/form-designer/setting-panel/property-editor/container-vf-drawer/vf-drawer-size-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/customClass-editor.vue.js +21 -19
- package/src/components/form-designer/setting-panel/property-editor/defaultValue-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/disabled-editor.vue.js +26 -23
- package/src/components/form-designer/setting-panel/property-editor/displayStyle-editor.vue.js +24 -22
- package/src/components/form-designer/setting-panel/property-editor/editable-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/endPlaceholder-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/event-handler/eventMixin.js +6 -6
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onAppendButtonClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onBeforeUpload-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onBlur-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCancelButtonClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCellClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCellDoubleClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onChange-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onClickIcon-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCreated-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onCurrentPageChange-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDialogBeforeClose-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDialogOpened-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDisableOperationButton-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDrawerBeforeClose-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onDrawerOpened-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onFileRemove.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onFocus-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetOperationButtonLabel-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetRowClassName-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onGetSpanMethod-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onHeaderClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onHideOperationButton-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onInput-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onMenuClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onMounted-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onOkButtonClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onOperationButtonClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onPageSizeChange-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRemoteQuery-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRowClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onRowDoubleClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSelectionChange-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowAdd-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowChange-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowDelete-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onSubFormRowInsert-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onTabClick-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onTableChange-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onUploadError-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onUploadSuccess-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onValidate-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/event-handler/onVformAdd-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/field-button/circle-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-button/danger-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/field-button/ghost-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/field-button/icon-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-button/plain-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-button/round-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-button/shape-editor.vue.js +27 -25
- package/src/components/form-designer/setting-panel/property-editor/field-button/type-editor.vue.js +37 -35
- package/src/components/form-designer/setting-panel/property-editor/field-cascader/cascader-defaultValue-editor.vue.js +9 -8
- package/src/components/form-designer/setting-panel/property-editor/field-cascader/cascader-multiple-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/field-checkbox/checkbox-defaultValue-editor.vue.js +9 -8
- package/src/components/form-designer/setting-panel/property-editor/field-color/color-defaultValue-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/field-date/date-defaultValue-editor.vue.js +22 -21
- package/src/components/form-designer/setting-panel/property-editor/field-date/date-format-editor.vue.js +30 -28
- package/src/components/form-designer/setting-panel/property-editor/field-date/date-type-editor.vue.js +33 -31
- package/src/components/form-designer/setting-panel/property-editor/field-date/date-valueFormat-editor.vue.js +30 -28
- package/src/components/form-designer/setting-panel/property-editor/field-date-range/date-range-defaultValue-editor.vue.js +22 -21
- package/src/components/form-designer/setting-panel/property-editor/field-date-range/date-range-format-editor.vue.js +33 -31
- package/src/components/form-designer/setting-panel/property-editor/field-date-range/date-range-type-editor.vue.js +27 -25
- package/src/components/form-designer/setting-panel/property-editor/field-date-range/date-range-valueFormat-editor.vue.js +30 -28
- package/src/components/form-designer/setting-panel/property-editor/field-divider/contentPosition-editor.vue.js +27 -25
- package/src/components/form-designer/setting-panel/property-editor/field-divider/divider-direction-editor.vue.js +24 -22
- package/src/components/form-designer/setting-panel/property-editor/field-dropdown/dropdown-menuList-editor.vue.js +30 -27
- package/src/components/form-designer/setting-panel/property-editor/field-file-upload/file-upload-fileTypes-editor.vue.js +28 -25
- package/src/components/form-designer/setting-panel/property-editor/field-html-text/htmlContent-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/field-number/controlsPosition-editor.vue.js +24 -22
- package/src/components/form-designer/setting-panel/property-editor/field-number/number-defaultValue-editor.vue.js +20 -19
- package/src/components/form-designer/setting-panel/property-editor/field-picture-upload/picture-upload-fileTypes-editor.vue.js +28 -25
- package/src/components/form-designer/setting-panel/property-editor/field-radio/radio-defaultValue-editor.vue.js +9 -8
- package/src/components/form-designer/setting-panel/property-editor/field-rate/allowHalf-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-rate/highThreshold-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/field-rate/lowThreshold-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/field-rate/rate-count-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/field-rate/rate-defaultValue-editor.vue.js +20 -19
- package/src/components/form-designer/setting-panel/property-editor/field-rate/showScore-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-rate/showText-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-rich-editor/rich-editor-contentHeight-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/field-select/mode-editor.vue.js +23 -18
- package/src/components/form-designer/setting-panel/property-editor/field-select/select-defaultValue-editor.vue.js +9 -8
- package/src/components/form-designer/setting-panel/property-editor/field-slider/range-editor.vue.js +28 -20
- package/src/components/form-designer/setting-panel/property-editor/field-slider/vertical-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-static-text/textContent-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-switch/activeColor-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/field-switch/checkedValue-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-switch/inactiveColor-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/field-switch/switch-defaultValue-editor.vue.js +20 -19
- package/src/components/form-designer/setting-panel/property-editor/field-switch/switchWidth-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/field-switch/unCheckedValue-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/field-time/time-defaultValue-editor.vue.js +20 -19
- package/src/components/form-designer/setting-panel/property-editor/field-time/time-format-editor.vue.js +24 -22
- package/src/components/form-designer/setting-panel/property-editor/field-time-range/time-range-defaultValue-editor.vue.js +20 -19
- package/src/components/form-designer/setting-panel/property-editor/field-time-range/time-range-format-editor.vue.js +24 -22
- package/src/components/form-designer/setting-panel/property-editor/field-treeSelect/treeSelect-treeDefaultExpandAll-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/hidden-editor.vue.js +36 -33
- package/src/components/form-designer/setting-panel/property-editor/index.js +216 -214
- package/src/components/form-designer/setting-panel/property-editor/label-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/labelAlign-editor.vue.js +25 -23
- package/src/components/form-designer/setting-panel/property-editor/labelHidden-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/labelIconClass-editor.vue.js +23 -21
- package/src/components/form-designer/setting-panel/property-editor/labelIconPosition-editor.vue.js +30 -26
- package/src/components/form-designer/setting-panel/property-editor/labelTooltip-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/labelWidth-editor.vue.js +19 -18
- package/src/components/form-designer/setting-panel/property-editor/limit-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/loadingPage-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/max-editor.vue.js +24 -19
- package/src/components/form-designer/setting-panel/property-editor/maxLength-editor.vue.js +26 -21
- package/src/components/form-designer/setting-panel/property-editor/maxSize-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/min-editor.vue.js +24 -19
- package/src/components/form-designer/setting-panel/property-editor/minLength-editor.vue.js +26 -21
- package/src/components/form-designer/setting-panel/property-editor/multiple-editor.vue.js +27 -19
- package/src/components/form-designer/setting-panel/property-editor/multipleSelect-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/name-editor.vue.js +87 -64
- package/src/components/form-designer/setting-panel/property-editor/optionItems-editor.vue.js +87 -70
- package/src/components/form-designer/setting-panel/property-editor/placeholder-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/placement-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/precision-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/propertyMixin.js +36 -17
- package/src/components/form-designer/setting-panel/property-editor/readonly-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/required-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/requiredHint-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/rightSlotCss-editor.vue.js +20 -18
- package/src/components/form-designer/setting-panel/property-editor/rows-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/showCount-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/showFileList-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/showPassword-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/showSearch-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/showTime-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/size-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/slot-compontent-editor.vue.js +33 -0
- package/src/components/form-designer/setting-panel/property-editor/startPlaceholder-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/step-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/type-editor.vue.js +25 -23
- package/src/components/form-designer/setting-panel/property-editor/uploadListType-editor.vue.js +17 -16
- package/src/components/form-designer/setting-panel/property-editor/uploadTip-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/uploadURL-editor.vue.js +23 -21
- package/src/components/form-designer/setting-panel/property-editor/useModel-editor.vue.js +15 -14
- package/src/components/form-designer/setting-panel/property-editor/validation-editor.vue.js +18 -17
- package/src/components/form-designer/setting-panel/property-editor/validationHint-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor/withCredentials-editor.vue.js +16 -15
- package/src/components/form-designer/setting-panel/property-editor-factory.js +126 -108
- package/src/components/form-designer/setting-panel/propertyRegister.js +35 -29
- package/src/components/form-designer/toolbar-panel/index.vue.js +639 -555
- package/src/components/form-designer/widget-panel/advanced/attachment-render.js +27 -0
- package/src/components/form-designer/widget-panel/advanced/bpmn-editor.js +29 -0
- package/src/components/form-designer/widget-panel/advanced/cascader.js +67 -0
- package/src/components/form-designer/widget-panel/advanced/code-editor.js +43 -0
- package/src/components/form-designer/widget-panel/advanced/file-upload.js +40 -0
- package/src/components/form-designer/widget-panel/advanced/rich-editor.js +37 -0
- package/src/components/form-designer/widget-panel/advanced/slot.js +22 -0
- package/src/components/form-designer/widget-panel/advanced/tree-select.js +68 -0
- package/src/components/form-designer/widget-panel/advancedFieldsEnums.js +18 -314
- package/src/components/form-designer/widget-panel/basicFields/button.js +35 -0
- package/src/components/form-designer/widget-panel/basicFields/checkbox.js +63 -0
- package/src/components/form-designer/widget-panel/basicFields/color.js +42 -0
- package/src/components/form-designer/widget-panel/basicFields/date.js +54 -0
- package/src/components/form-designer/widget-panel/basicFields/dateRange.js +54 -0
- package/src/components/form-designer/widget-panel/basicFields/divider.js +29 -0
- package/src/components/form-designer/widget-panel/basicFields/dropdown.js +40 -0
- package/src/components/form-designer/widget-panel/basicFields/htmlText.js +27 -0
- package/src/components/form-designer/widget-panel/basicFields/input.js +53 -0
- package/src/components/form-designer/widget-panel/basicFields/number.js +49 -0
- package/src/components/form-designer/widget-panel/basicFields/radio.js +70 -0
- package/src/components/form-designer/widget-panel/basicFields/rate.js +44 -0
- package/src/components/form-designer/widget-panel/basicFields/select.js +76 -0
- package/src/components/form-designer/widget-panel/basicFields/slider.js +46 -0
- package/src/components/form-designer/widget-panel/basicFields/staticText.js +27 -0
- package/src/components/form-designer/widget-panel/basicFields/switch.js +40 -0
- package/src/components/form-designer/widget-panel/basicFields/textarea.js +52 -0
- package/src/components/form-designer/widget-panel/basicFields/time.js +50 -0
- package/src/components/form-designer/widget-panel/basicFields/timeRange.js +51 -0
- package/src/components/form-designer/widget-panel/basicFieldsEnums.js +40 -813
- package/src/components/form-designer/widget-panel/business/department-select.js +78 -0
- package/src/components/form-designer/widget-panel/business/index.js +16 -0
- package/src/components/form-designer/widget-panel/business/material-select.js +80 -0
- package/src/components/form-designer/widget-panel/business/operation-select.js +80 -0
- package/src/components/form-designer/widget-panel/business/post-select.js +77 -0
- package/src/components/form-designer/widget-panel/business/project-group-select.js +80 -0
- package/src/components/form-designer/widget-panel/business/project-select.js +76 -0
- package/src/components/form-designer/widget-panel/business/user-select.js +81 -0
- package/src/components/form-designer/widget-panel/containers/data-table.js +104 -0
- package/src/components/form-designer/widget-panel/containers/grid-col.js +28 -0
- package/src/components/form-designer/widget-panel/containers/grid-sub-form.js +43 -0
- package/src/components/form-designer/widget-panel/containers/grid.js +22 -0
- package/src/components/form-designer/widget-panel/containers/index.js +22 -0
- package/src/components/form-designer/widget-panel/containers/tab.js +26 -0
- package/src/components/form-designer/widget-panel/containers/vf-box.js +20 -0
- package/src/components/form-designer/widget-panel/containers/vf-collapse.js +28 -0
- package/src/components/form-designer/widget-panel/containers/vf-dialog.js +35 -0
- package/src/components/form-designer/widget-panel/index.vue.js +230 -182
- package/src/components/form-designer/widget-panel/templatesConfig.js +2 -2
- package/src/components/form-designer/widget-panel/widgetsConfig.js +26 -22
- package/src/components/form-render/container-item/container-item-wrapper.vue.js +11 -11
- package/src/components/form-render/container-item/containerItemMixin.js +184 -97
- package/src/components/form-render/container-item/data-table-item.vue.js +93 -76
- package/src/components/form-render/container-item/grid-col-item.vue.js +97 -71
- package/src/components/form-render/container-item/grid-item.vue.js +49 -43
- package/src/components/form-render/container-item/grid-sub-form-item.vue.js +256 -182
- package/src/components/form-render/container-item/index.js +19 -18
- package/src/components/form-render/container-item/sub-form-item.vue.js +370 -285
- package/src/components/form-render/container-item/tab-item.vue.js +120 -87
- package/src/components/form-render/container-item/table-cell-item.vue.js +63 -56
- package/src/components/form-render/container-item/table-item.vue2.js +56 -49
- package/src/components/form-render/container-item/vf-collapse-item.vue.js +153 -127
- package/src/components/form-render/container-item/vf-dialog-item.vue.js +7 -7
- package/src/components/form-render/container-item/vf-drawer-item.vue.js +7 -7
- package/src/components/form-render/dynamic-dialog.vue.js +129 -79
- package/src/components/form-render/dynamic-drawer.vue.js +102 -62
- package/src/components/form-render/refMixin.js +23 -9
- package/src/components/http-editor/index.vue.js +290 -273
- package/src/components/http-editor/index.vue2.js +71 -45
- package/src/components/svg-icon/FileIcon.js +18 -15
- package/src/components/svg-icon/index.vue.js +20 -14
- package/src/hooks/TpfConfirm.js +20 -19
- package/src/hooks/useFilePreview.js +56 -40
- package/src/lang/en-US.js +2 -2
- package/src/lang/en-US_extension.js +2 -2
- package/src/lang/en-US_render.js +2 -2
- package/src/lang/zh-CN.js +7 -3
- package/src/lang/zh-CN_extension.js +2 -2
- package/src/lang/zh-CN_render.js +2 -2
- package/src/lib/vuedraggable/src/core/componentBuilderHelper.js +27 -23
- package/src/lib/vuedraggable/src/core/componentStructure.js +46 -29
- package/src/lib/vuedraggable/src/core/renderHelper.js +36 -26
- package/src/lib/vuedraggable/src/core/sortableEvents.js +12 -8
- package/src/lib/vuedraggable/src/util/console.js +7 -4
- package/src/lib/vuedraggable/src/util/htmlHelper.js +9 -7
- package/src/lib/vuedraggable/src/util/string.js +8 -6
- package/src/lib/vuedraggable/src/util/tags.js +10 -10
- package/src/lib/vuedraggable/src/vuedraggable.js +165 -126
- package/src/mixins/useDataTableMixin.js +184 -94
- package/src/mixins/useSelectMixin.js +33 -19
- package/src/utils/code-generator.js +11 -7
- package/src/utils/config.js +4 -3
- package/src/utils/el-icons.js +21 -6
- package/src/utils/emitter.js +54 -31
- package/src/utils/event-bus.js +7 -6
- package/src/utils/format.js +46 -24
- package/src/utils/i18n.js +56 -39
- package/src/utils/request/fmtHttpParams.js +28 -16
- package/src/utils/request/handleAxiosError.js +20 -19
- package/src/utils/request/http.js +70 -27
- package/src/utils/request/useGetUseInfo.js +7 -3
- package/src/utils/sfc-generator.js +5 -4
- package/src/utils/smart-vue-i18n/index.js +15 -14
- package/src/utils/smart-vue-i18n/utils.js +11 -10
- package/src/utils/util.js +336 -175
- package/src/utils/validators.js +44 -38
- package/stats.html +1 -1
- package/styles/style.css +1 -1
- package/types/src/components/CustomRender/index.d.ts.map +1 -1
- package/types/src/components/form-designer/setting-panel/index.d.ts +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/attachment-render.d.ts +21 -0
- package/types/src/components/form-designer/widget-panel/advanced/attachment-render.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/bpmn-editor.d.ts +23 -0
- package/types/src/components/form-designer/widget-panel/advanced/bpmn-editor.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/cascader.d.ts +62 -0
- package/types/src/components/form-designer/widget-panel/advanced/cascader.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/code-editor.d.ts +33 -0
- package/types/src/components/form-designer/widget-panel/advanced/code-editor.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/file-upload.d.ts +35 -0
- package/types/src/components/form-designer/widget-panel/advanced/file-upload.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/index.d.ts +8 -0
- package/types/src/components/form-designer/widget-panel/advanced/index.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/rich-editor.d.ts +32 -0
- package/types/src/components/form-designer/widget-panel/advanced/rich-editor.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/slot.d.ts +16 -0
- package/types/src/components/form-designer/widget-panel/advanced/slot.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/advanced/tree-select.d.ts +63 -0
- package/types/src/components/form-designer/widget-panel/advanced/tree-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/button.d.ts +26 -0
- package/types/src/components/form-designer/widget-panel/basicFields/button.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/checkbox.d.ts +47 -0
- package/types/src/components/form-designer/widget-panel/basicFields/checkbox.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/color.d.ts +33 -0
- package/types/src/components/form-designer/widget-panel/basicFields/color.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/date.d.ts +43 -0
- package/types/src/components/form-designer/widget-panel/basicFields/date.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/dateRange.d.ts +43 -0
- package/types/src/components/form-designer/widget-panel/basicFields/dateRange.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/divider.d.ts +20 -0
- package/types/src/components/form-designer/widget-panel/basicFields/divider.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/dropdown.d.ts +31 -0
- package/types/src/components/form-designer/widget-panel/basicFields/dropdown.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/htmlText.d.ts +18 -0
- package/types/src/components/form-designer/widget-panel/basicFields/htmlText.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/input.d.ts +44 -0
- package/types/src/components/form-designer/widget-panel/basicFields/input.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/number.d.ts +40 -0
- package/types/src/components/form-designer/widget-panel/basicFields/number.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/radio.d.ts +51 -0
- package/types/src/components/form-designer/widget-panel/basicFields/radio.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/rate.d.ts +35 -0
- package/types/src/components/form-designer/widget-panel/basicFields/rate.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/select.d.ts +58 -0
- package/types/src/components/form-designer/widget-panel/basicFields/select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/slider.d.ts +37 -0
- package/types/src/components/form-designer/widget-panel/basicFields/slider.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/staticText.d.ts +18 -0
- package/types/src/components/form-designer/widget-panel/basicFields/staticText.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/switch.d.ts +31 -0
- package/types/src/components/form-designer/widget-panel/basicFields/switch.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/textarea.d.ts +42 -0
- package/types/src/components/form-designer/widget-panel/basicFields/textarea.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/time.d.ts +40 -0
- package/types/src/components/form-designer/widget-panel/basicFields/time.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/basicFields/timeRange.d.ts +41 -0
- package/types/src/components/form-designer/widget-panel/basicFields/timeRange.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/department-select.d.ts +59 -0
- package/types/src/components/form-designer/widget-panel/business/department-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/index.d.ts +8 -0
- package/types/src/components/form-designer/widget-panel/business/index.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/material-select.d.ts +59 -0
- package/types/src/components/form-designer/widget-panel/business/material-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/operation-select.d.ts +59 -0
- package/types/src/components/form-designer/widget-panel/business/operation-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/post-select.d.ts +61 -0
- package/types/src/components/form-designer/widget-panel/business/post-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/project-group-select.d.ts +59 -0
- package/types/src/components/form-designer/widget-panel/business/project-group-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/project-select.d.ts +59 -0
- package/types/src/components/form-designer/widget-panel/business/project-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/business/user-select.d.ts +62 -0
- package/types/src/components/form-designer/widget-panel/business/user-select.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/data-table.d.ts +97 -0
- package/types/src/components/form-designer/widget-panel/containers/data-table.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/grid-col.d.ts +22 -0
- package/types/src/components/form-designer/widget-panel/containers/grid-col.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/grid-sub-form.d.ts +34 -0
- package/types/src/components/form-designer/widget-panel/containers/grid-sub-form.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/grid.d.ts +16 -0
- package/types/src/components/form-designer/widget-panel/containers/grid.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/index.d.ts +10 -0
- package/types/src/components/form-designer/widget-panel/containers/index.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/tab-pane.d.ts +17 -0
- package/types/src/components/form-designer/widget-panel/containers/tab-pane.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/tab.d.ts +36 -0
- package/types/src/components/form-designer/widget-panel/containers/tab.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/vf-box.d.ts +14 -0
- package/types/src/components/form-designer/widget-panel/containers/vf-box.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/vf-collapse.d.ts +22 -0
- package/types/src/components/form-designer/widget-panel/containers/vf-collapse.d.ts.map +1 -0
- package/types/src/components/form-designer/widget-panel/containers/vf-dialog.d.ts +29 -0
- package/types/src/components/form-designer/widget-panel/containers/vf-dialog.d.ts.map +1 -0
- package/_virtual/_commonjsHelpers.js +0 -6
- package/_virtual/collection.js +0 -4
- package/_virtual/ext-language_tools.js +0 -4
- package/_virtual/index.js +0 -4
- package/_virtual/mode-css.js +0 -4
- package/_virtual/mode-javascript.js +0 -4
- package/_virtual/mode-json.js +0 -4
- package/_virtual/theme-sqlserver.js +0 -4
- package/src/components/form-designer/widget-panel/businessFieldsEnums.js +0 -558
- package/src/components/form-designer/widget-panel/containersEnums.js +0 -315
package/render.js
CHANGED
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
import { createVNode
|
|
2
|
-
import
|
|
3
|
-
import
|
|
1
|
+
import { createVNode, render, resolveComponent, createBlock, openBlock, withCtx, withModifiers, normalizeClass, createElementBlock, Fragment, renderList, resolveDynamicComponent, createSlots, renderSlot, normalizeProps, guardReactiveProps } from "vue";
|
|
2
|
+
import emitter from "./src/utils/emitter.js";
|
|
3
|
+
import _export_sfc from "./_virtual/_plugin-vue_export-helper.js";
|
|
4
4
|
/* empty css */
|
|
5
5
|
import "./src/components/form-render/container-item/grid-col-item.vue.js";
|
|
6
|
-
import
|
|
7
|
-
import { buildDefaultFormJson
|
|
6
|
+
import i18n, { changeLocale } from "./src/utils/i18n.js";
|
|
7
|
+
import { buildDefaultFormJson, getContainerWidgetByName, cloneFormConfigWithoutEventHandler, deepClone, getDSByName, overwriteObj, runDataSourceRequest, getAllContainerWidgets, getAllFieldWidgets, getDefaultFormConfig, traverseFieldWidgets, getFieldWidgetByName, traverseFieldWidgetsOfContainer, insertCustomCssToHead, insertGlobalFunctionsToHtml, generateId } from "./src/utils/util.js";
|
|
8
8
|
import "./src/components/form-render/container-item/grid-sub-form-item.vue.js";
|
|
9
9
|
import "./src/components/form-render/container-item/sub-form-item.vue.js";
|
|
10
10
|
import "./src/components/form-render/container-item/tab-item.vue.js";
|
|
11
11
|
import "./src/components/form-render/container-item/table-cell-item.vue.js";
|
|
12
12
|
/* empty css */
|
|
13
13
|
import "./src/components/form-render/container-item/vf-collapse-item.vue.js";
|
|
14
|
-
import
|
|
15
|
-
import
|
|
16
|
-
import
|
|
17
|
-
import { fmtHttpParams
|
|
14
|
+
import comps from "./src/components/form-designer/form-widget/field-widget/index.js";
|
|
15
|
+
import DynamicDialog from "./src/components/form-render/dynamic-dialog.vue.js";
|
|
16
|
+
import DynamicDrawer from "./src/components/form-render/dynamic-drawer.vue.js";
|
|
17
|
+
import { fmtHttpParams } from "./src/utils/request/fmtHttpParams.js";
|
|
18
18
|
/* empty css */
|
|
19
|
-
const
|
|
19
|
+
const _sfc_main = {
|
|
20
20
|
name: "VFormRender",
|
|
21
21
|
componentName: "VFormRender",
|
|
22
|
-
mixins: [
|
|
22
|
+
mixins: [emitter, i18n],
|
|
23
23
|
components: {
|
|
24
|
-
...
|
|
24
|
+
...comps
|
|
25
25
|
},
|
|
26
26
|
props: {
|
|
27
27
|
vfCtx: {
|
|
@@ -31,7 +31,7 @@ const Z = {
|
|
|
31
31
|
formJson: {
|
|
32
32
|
//prop传入的表单JSON配置
|
|
33
33
|
type: Object,
|
|
34
|
-
default: () =>
|
|
34
|
+
default: () => buildDefaultFormJson()
|
|
35
35
|
},
|
|
36
36
|
formData: {
|
|
37
37
|
//prop传入的表单数据
|
|
@@ -46,20 +46,22 @@ const Z = {
|
|
|
46
46
|
previewState: {
|
|
47
47
|
//是否表单预览状态
|
|
48
48
|
type: Boolean,
|
|
49
|
-
default:
|
|
49
|
+
default: false
|
|
50
50
|
},
|
|
51
51
|
disabledMode: {
|
|
52
52
|
//表单禁止编辑模式
|
|
53
53
|
type: Boolean,
|
|
54
|
-
default:
|
|
54
|
+
default: false
|
|
55
55
|
},
|
|
56
56
|
renderConfig: {
|
|
57
57
|
//渲染配置对象
|
|
58
58
|
type: Object,
|
|
59
|
-
default: () =>
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
59
|
+
default: () => {
|
|
60
|
+
return {
|
|
61
|
+
languageName: "zh-CN"
|
|
62
|
+
//界面语言,默认显示中文
|
|
63
|
+
};
|
|
64
|
+
}
|
|
63
65
|
},
|
|
64
66
|
globalDsv: {
|
|
65
67
|
// 全局数据源变量
|
|
@@ -73,7 +75,7 @@ const Z = {
|
|
|
73
75
|
dynamicCreation: {
|
|
74
76
|
//是否弹窗、抽屉动态创建的VFormRender
|
|
75
77
|
type: Boolean,
|
|
76
|
-
default:
|
|
78
|
+
default: false
|
|
77
79
|
}
|
|
78
80
|
},
|
|
79
81
|
provide() {
|
|
@@ -91,7 +93,7 @@ const Z = {
|
|
|
91
93
|
},
|
|
92
94
|
previewState: this.previewState,
|
|
93
95
|
getReadMode: () => this.readModeFlag,
|
|
94
|
-
getSubFormFieldFlag: () =>
|
|
96
|
+
getSubFormFieldFlag: () => false,
|
|
95
97
|
getSubFormName: () => "",
|
|
96
98
|
getDSResultCache: () => this.dsResultCache
|
|
97
99
|
};
|
|
@@ -108,7 +110,7 @@ const Z = {
|
|
|
108
110
|
//表单唯一Id,用于区分页面上的多个v-form-render组件!!
|
|
109
111
|
externalComponents: {},
|
|
110
112
|
//外部组件实例集合
|
|
111
|
-
readModeFlag:
|
|
113
|
+
readModeFlag: false,
|
|
112
114
|
//是否只读查看模式
|
|
113
115
|
dialogOrDrawerRef: null,
|
|
114
116
|
//保存子级VFormRender的包裹弹窗组件或抽屉组件的ref
|
|
@@ -126,254 +128,369 @@ const Z = {
|
|
|
126
128
|
return this.formJsonObj.widgetList;
|
|
127
129
|
},
|
|
128
130
|
labelPosition() {
|
|
129
|
-
|
|
131
|
+
if (!!this.formConfig && !!this.formConfig.labelPosition) {
|
|
132
|
+
return this.formConfig.labelPosition;
|
|
133
|
+
}
|
|
134
|
+
return "horizontal";
|
|
130
135
|
},
|
|
131
136
|
labelWidth() {
|
|
132
|
-
|
|
137
|
+
if (!!this.formConfig && !!this.formConfig.labelWidth) {
|
|
138
|
+
return this.formConfig.labelWidth + "px";
|
|
139
|
+
}
|
|
140
|
+
return "80px";
|
|
133
141
|
},
|
|
134
142
|
size() {
|
|
135
|
-
|
|
143
|
+
if (!!this.formConfig && !!this.formConfig.size) {
|
|
144
|
+
return this.formConfig.size;
|
|
145
|
+
}
|
|
146
|
+
return "default";
|
|
136
147
|
},
|
|
137
148
|
customClass() {
|
|
138
|
-
return this.formConfig && this.formConfig.customClass ? this.formConfig.customClass : "";
|
|
149
|
+
return !!this.formConfig && !!this.formConfig.customClass ? this.formConfig.customClass : "";
|
|
139
150
|
}
|
|
140
151
|
},
|
|
141
152
|
watch: {
|
|
142
153
|
//
|
|
143
154
|
},
|
|
144
155
|
created() {
|
|
145
|
-
this.buildFormModel(this.formJsonObj ? this.formJsonObj.widgetList
|
|
156
|
+
this.buildFormModel(!this.formJsonObj ? null : this.formJsonObj.widgetList);
|
|
157
|
+
this.initFormObject();
|
|
146
158
|
},
|
|
147
159
|
mounted() {
|
|
148
|
-
this.initLocale()
|
|
160
|
+
this.initLocale();
|
|
161
|
+
this.initDataSetRequest();
|
|
149
162
|
},
|
|
150
163
|
methods: {
|
|
151
164
|
async onFormDetail() {
|
|
152
|
-
var
|
|
153
|
-
const
|
|
154
|
-
if ((
|
|
155
|
-
const
|
|
156
|
-
|
|
165
|
+
var _a;
|
|
166
|
+
const serveList = this.formConfig.serveList;
|
|
167
|
+
if ((_a = serveList.vformDetail.http) == null ? void 0 : _a.url) {
|
|
168
|
+
const res = await fmtHttpParams.call(this, serveList.vformDetail, { vfCtx: this.vfCtx });
|
|
169
|
+
console.log("res: ", res);
|
|
170
|
+
return res;
|
|
157
171
|
}
|
|
158
172
|
},
|
|
159
173
|
async onFormUpdate() {
|
|
160
|
-
var
|
|
161
|
-
const
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
174
|
+
var _a;
|
|
175
|
+
const modelForm = await this.getFormData();
|
|
176
|
+
const serveList = this.formConfig.serveList;
|
|
177
|
+
if ((_a = serveList.vformDetail.http) == null ? void 0 : _a.url) {
|
|
178
|
+
const res = await fmtHttpParams.call(this, serveList.vformUpdate, {
|
|
179
|
+
data: modelForm,
|
|
165
180
|
vfCtx: this.vfCtx
|
|
166
181
|
});
|
|
167
|
-
|
|
182
|
+
console.log("res: ", res);
|
|
183
|
+
return res;
|
|
168
184
|
}
|
|
169
185
|
},
|
|
170
|
-
initFormObject(
|
|
171
|
-
this.formId = "vfRender" +
|
|
172
|
-
|
|
173
|
-
|
|
186
|
+
initFormObject(insertHtmlCodeFlag = true) {
|
|
187
|
+
this.formId = "vfRender" + generateId();
|
|
188
|
+
if (!!insertHtmlCodeFlag && !this.dynamicCreation) {
|
|
189
|
+
this.insertCustomStyleAndScriptNode();
|
|
190
|
+
}
|
|
191
|
+
this.addFieldChangeEventHandler();
|
|
192
|
+
this.addFieldValidateEventHandler();
|
|
193
|
+
this.registerFormToRefList();
|
|
194
|
+
this.handleOnCreated();
|
|
195
|
+
if (!!this.disabledMode) {
|
|
196
|
+
this.$nextTick(() => {
|
|
197
|
+
this.disableForm();
|
|
198
|
+
});
|
|
199
|
+
}
|
|
174
200
|
},
|
|
175
|
-
getContainerWidgetName(
|
|
176
|
-
|
|
201
|
+
getContainerWidgetName(widget) {
|
|
202
|
+
if (widget.type === "grid") {
|
|
203
|
+
return "vf-grid-item";
|
|
204
|
+
}
|
|
205
|
+
return widget.type + "-item";
|
|
177
206
|
},
|
|
178
|
-
getWidgetName(
|
|
179
|
-
return
|
|
207
|
+
getWidgetName(widget) {
|
|
208
|
+
return widget.type + "-widget";
|
|
180
209
|
},
|
|
181
210
|
initLocale() {
|
|
182
|
-
const
|
|
183
|
-
this.changeLanguage(
|
|
211
|
+
const curLocale = localStorage.getItem("v_form_locale") || "zh-CN";
|
|
212
|
+
this.changeLanguage(curLocale);
|
|
184
213
|
},
|
|
185
214
|
insertCustomStyleAndScriptNode() {
|
|
186
|
-
|
|
187
|
-
this.formConfig.
|
|
188
|
-
|
|
189
|
-
)
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
}
|
|
215
|
+
if (!!this.formConfig && !!this.formConfig.cssCode) {
|
|
216
|
+
insertCustomCssToHead(this.formConfig.cssCode, !!this.previewState ? "" : this.formId);
|
|
217
|
+
}
|
|
218
|
+
if (!!this.formConfig && !!this.formConfig.functions) {
|
|
219
|
+
insertGlobalFunctionsToHtml(
|
|
220
|
+
this.formConfig.functions,
|
|
221
|
+
!!this.previewState ? "" : this.formId
|
|
222
|
+
);
|
|
223
|
+
}
|
|
195
224
|
},
|
|
196
|
-
|
|
197
|
-
if (
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
225
|
+
buildFormModel(widgetList) {
|
|
226
|
+
if (!!widgetList && widgetList.length > 0) {
|
|
227
|
+
widgetList.forEach((wItem) => {
|
|
228
|
+
this.buildDataFromWidget(wItem);
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
},
|
|
232
|
+
buildDataFromWidget(wItem) {
|
|
233
|
+
if (wItem.category === "container") {
|
|
234
|
+
if (wItem.type === "vf-dialog" || wItem.type === "vf-drawer") ;
|
|
235
|
+
else if (wItem.type === "grid") {
|
|
236
|
+
if (!!wItem.cols && wItem.cols.length > 0) {
|
|
237
|
+
wItem.cols.forEach((childItem) => {
|
|
238
|
+
this.buildDataFromWidget(childItem);
|
|
206
239
|
});
|
|
207
|
-
}
|
|
208
|
-
else if (
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
240
|
+
}
|
|
241
|
+
} else if (wItem.type === "table") {
|
|
242
|
+
if (!!wItem.rows && wItem.rows.length > 0) {
|
|
243
|
+
wItem.rows.forEach((rowItem) => {
|
|
244
|
+
if (!!rowItem.cols && rowItem.cols.length > 0) {
|
|
245
|
+
rowItem.cols.forEach((colItem) => {
|
|
246
|
+
this.buildDataFromWidget(colItem);
|
|
247
|
+
});
|
|
248
|
+
}
|
|
212
249
|
});
|
|
213
|
-
}
|
|
214
|
-
else if (
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
250
|
+
}
|
|
251
|
+
} else if (wItem.type === "tab") {
|
|
252
|
+
if (!!wItem.tabs && wItem.tabs.length > 0) {
|
|
253
|
+
wItem.tabs.forEach((tabItem) => {
|
|
254
|
+
if (!!tabItem.widgetList && tabItem.widgetList.length > 0) {
|
|
255
|
+
tabItem.widgetList.forEach((childItem) => {
|
|
256
|
+
this.buildDataFromWidget(childItem);
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
} else if (wItem.type === "sub-form") {
|
|
262
|
+
const subFormName = wItem.options.name;
|
|
263
|
+
if (!this.formData.hasOwnProperty(subFormName)) {
|
|
264
|
+
const subFormDataRow = {};
|
|
265
|
+
if (wItem.options.showBlankRow) {
|
|
266
|
+
wItem.widgetList.forEach((subFormItem) => {
|
|
267
|
+
if (!!subFormItem.formItemFlag) {
|
|
268
|
+
subFormDataRow[subFormItem.options.name] = subFormItem.options.defaultValue;
|
|
269
|
+
}
|
|
270
|
+
});
|
|
271
|
+
this.formDataModel[subFormName] = [subFormDataRow];
|
|
272
|
+
} else {
|
|
273
|
+
this.formDataModel[subFormName] = [];
|
|
274
|
+
}
|
|
219
275
|
} else {
|
|
220
|
-
const
|
|
221
|
-
|
|
222
|
-
o.formItemFlag && (i[o.options.name] = o.options.defaultValue);
|
|
223
|
-
}), this.formDataModel[e] = [i]) : this.formDataModel[e] = [];
|
|
276
|
+
const initialValue = this.formData[subFormName];
|
|
277
|
+
this.formDataModel[subFormName] = deepClone(initialValue);
|
|
224
278
|
}
|
|
225
|
-
} else if (
|
|
226
|
-
const
|
|
227
|
-
if (this.formData.hasOwnProperty(
|
|
228
|
-
const
|
|
229
|
-
|
|
279
|
+
} else if (wItem.type === "grid-sub-form") {
|
|
280
|
+
const gridSubFormName = wItem.options.name;
|
|
281
|
+
if (!this.formData.hasOwnProperty(gridSubFormName)) {
|
|
282
|
+
const gsfFWList = [];
|
|
283
|
+
const fieldListFn = (fw) => {
|
|
284
|
+
gsfFWList.push(fw);
|
|
285
|
+
};
|
|
286
|
+
traverseFieldWidgetsOfContainer(wItem, fieldListFn);
|
|
287
|
+
const gridSubFormDataRow = {};
|
|
288
|
+
if (wItem.options.showBlankRow) {
|
|
289
|
+
gsfFWList.forEach((gridSubFormItem) => {
|
|
290
|
+
gridSubFormDataRow[gridSubFormItem.options.name] = gridSubFormItem.options.defaultValue;
|
|
291
|
+
});
|
|
292
|
+
this.formDataModel[gridSubFormName] = [gridSubFormDataRow];
|
|
293
|
+
} else {
|
|
294
|
+
this.formDataModel[gridSubFormName] = [];
|
|
295
|
+
}
|
|
230
296
|
} else {
|
|
231
|
-
const
|
|
232
|
-
|
|
233
|
-
|
|
297
|
+
const initialValue = this.formData[gridSubFormName];
|
|
298
|
+
this.formDataModel[gridSubFormName] = deepClone(initialValue);
|
|
299
|
+
}
|
|
300
|
+
} else if (wItem.type === "grid-col" || wItem.type === "table-cell") {
|
|
301
|
+
if (!!wItem.widgetList && wItem.widgetList.length > 0) {
|
|
302
|
+
wItem.widgetList.forEach((childItem) => {
|
|
303
|
+
this.buildDataFromWidget(childItem);
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
} else {
|
|
307
|
+
if (!!wItem.widgetList && wItem.widgetList.length > 0) {
|
|
308
|
+
wItem.widgetList.forEach((childItem) => {
|
|
309
|
+
this.buildDataFromWidget(childItem);
|
|
234
310
|
});
|
|
235
|
-
const s = {};
|
|
236
|
-
t.options.showBlankRow ? (i.forEach((r) => {
|
|
237
|
-
s[r.options.name] = r.options.defaultValue;
|
|
238
|
-
}), this.formDataModel[e] = [s]) : this.formDataModel[e] = [];
|
|
239
311
|
}
|
|
240
|
-
} else t.type === "grid-col" || t.type === "table-cell" ? t.widgetList && t.widgetList.length > 0 && t.widgetList.forEach((e) => {
|
|
241
|
-
this.buildDataFromWidget(e);
|
|
242
|
-
}) : t.widgetList && t.widgetList.length > 0 && t.widgetList.forEach((e) => {
|
|
243
|
-
this.buildDataFromWidget(e);
|
|
244
|
-
});
|
|
245
|
-
} else if (t.formItemFlag)
|
|
246
|
-
if (!this.formData.hasOwnProperty(t.options.name))
|
|
247
|
-
this.formDataModel[t.options.name] = t.options.defaultValue;
|
|
248
|
-
else {
|
|
249
|
-
const e = this.formData[t.options.name];
|
|
250
|
-
this.formDataModel[t.options.name] = d(e);
|
|
251
312
|
}
|
|
313
|
+
} else if (!!wItem.formItemFlag) {
|
|
314
|
+
if (!this.formData.hasOwnProperty(wItem.options.name)) {
|
|
315
|
+
this.formDataModel[wItem.options.name] = wItem.options.defaultValue;
|
|
316
|
+
} else {
|
|
317
|
+
const initialValue = this.formData[wItem.options.name];
|
|
318
|
+
this.formDataModel[wItem.options.name] = deepClone(initialValue);
|
|
319
|
+
}
|
|
320
|
+
}
|
|
252
321
|
},
|
|
253
322
|
addFieldChangeEventHandler() {
|
|
254
|
-
this.off$("fieldChange")
|
|
255
|
-
|
|
323
|
+
this.off$("fieldChange");
|
|
324
|
+
this.on$("fieldChange", (fieldName, newValue, oldValue, subFormName, subFormRowIndex) => {
|
|
325
|
+
this.handleFieldDataChange(fieldName, newValue, oldValue, subFormName, subFormRowIndex);
|
|
326
|
+
this.$emit(
|
|
256
327
|
"formChange",
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
328
|
+
fieldName,
|
|
329
|
+
newValue,
|
|
330
|
+
oldValue,
|
|
260
331
|
this.formDataModel,
|
|
261
|
-
|
|
262
|
-
|
|
332
|
+
subFormName,
|
|
333
|
+
subFormRowIndex
|
|
263
334
|
);
|
|
264
335
|
});
|
|
265
336
|
},
|
|
266
337
|
addFieldValidateEventHandler() {
|
|
267
|
-
this.off$("fieldValidation")
|
|
268
|
-
|
|
338
|
+
this.off$("fieldValidation");
|
|
339
|
+
this.on$("fieldValidation", (fieldName) => {
|
|
340
|
+
if (!!this.$refs.renderForm) {
|
|
341
|
+
this.$refs.renderForm.validateFields(fieldName);
|
|
342
|
+
}
|
|
269
343
|
});
|
|
270
344
|
},
|
|
271
345
|
registerFormToRefList() {
|
|
272
|
-
this.widgetRefList
|
|
273
|
-
},
|
|
274
|
-
handleFieldDataChange(
|
|
275
|
-
this.formConfig && this.formConfig.onFormDataChange
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
346
|
+
this.widgetRefList["v_form_ref"] = this;
|
|
347
|
+
},
|
|
348
|
+
handleFieldDataChange(fieldName, newValue, oldValue, subFormName, subFormRowIndex) {
|
|
349
|
+
if (!!this.formConfig && !!this.formConfig.onFormDataChange) {
|
|
350
|
+
const customFunc = new Function(
|
|
351
|
+
"fieldName",
|
|
352
|
+
"newValue",
|
|
353
|
+
"oldValue",
|
|
354
|
+
"formModel",
|
|
355
|
+
"subFormName",
|
|
356
|
+
"subFormRowIndex",
|
|
357
|
+
this.formConfig.onFormDataChange
|
|
358
|
+
);
|
|
359
|
+
customFunc.call(
|
|
360
|
+
this,
|
|
361
|
+
fieldName,
|
|
362
|
+
newValue,
|
|
363
|
+
oldValue,
|
|
364
|
+
this.formDataModel,
|
|
365
|
+
subFormName,
|
|
366
|
+
subFormRowIndex
|
|
367
|
+
);
|
|
368
|
+
}
|
|
292
369
|
},
|
|
293
370
|
handleOnCreated() {
|
|
294
|
-
|
|
371
|
+
if (!!this.formConfig && !!this.formConfig.onFormCreated) {
|
|
372
|
+
const customFunc = new Function(this.formConfig.onFormCreated);
|
|
373
|
+
customFunc.call(this);
|
|
374
|
+
}
|
|
295
375
|
},
|
|
296
376
|
handleOnMounted() {
|
|
297
|
-
|
|
377
|
+
if (!!this.formConfig && !!this.formConfig.onFormMounted) {
|
|
378
|
+
const customFunc = new Function(this.formConfig.onFormMounted);
|
|
379
|
+
customFunc.call(this);
|
|
380
|
+
}
|
|
298
381
|
},
|
|
299
|
-
findWidgetAndSetDisabled(
|
|
300
|
-
const
|
|
301
|
-
|
|
382
|
+
findWidgetAndSetDisabled(widgetName, disabledFlag) {
|
|
383
|
+
const foundW = this.getWidgetRef(widgetName);
|
|
384
|
+
if (!!foundW && !!foundW.setDisabled) {
|
|
385
|
+
foundW.setDisabled(disabledFlag);
|
|
386
|
+
} else {
|
|
387
|
+
this.findWidgetOfSubFormAndSetDisabled(widgetName, disabledFlag);
|
|
388
|
+
}
|
|
302
389
|
},
|
|
303
|
-
findWidgetOfSubFormAndSetDisabled(
|
|
304
|
-
const
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
390
|
+
findWidgetOfSubFormAndSetDisabled(widgetName, disabledFlag) {
|
|
391
|
+
const widgetSchema = getFieldWidgetByName(this.formJsonObj.widgetList, widgetName, true);
|
|
392
|
+
if (!!widgetSchema && !!widgetSchema.options && widgetSchema.options.hasOwnProperty("disabled")) {
|
|
393
|
+
widgetSchema.options.disabled = disabledFlag;
|
|
394
|
+
}
|
|
395
|
+
this.findWidgetNameInSubForm(widgetName).forEach((wn) => {
|
|
396
|
+
const sw = this.getWidgetRef(wn);
|
|
397
|
+
if (!!sw && !!sw.setDisabled) {
|
|
398
|
+
sw.setDisabled(disabledFlag);
|
|
399
|
+
}
|
|
308
400
|
});
|
|
309
401
|
},
|
|
310
|
-
findWidgetAndSetHidden(
|
|
311
|
-
const
|
|
312
|
-
|
|
402
|
+
findWidgetAndSetHidden(widgetName, hiddenFlag) {
|
|
403
|
+
const foundW = this.getWidgetRef(widgetName);
|
|
404
|
+
if (!!foundW && !!foundW.setDisabled) {
|
|
405
|
+
foundW.setHidden(hiddenFlag);
|
|
406
|
+
} else {
|
|
407
|
+
this.findWidgetOfSubFormAndSetHidden(widgetName, hiddenFlag);
|
|
408
|
+
}
|
|
313
409
|
},
|
|
314
|
-
findWidgetOfSubFormAndSetHidden(
|
|
315
|
-
const
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
410
|
+
findWidgetOfSubFormAndSetHidden(widgetName, hiddenFlag) {
|
|
411
|
+
const widgetSchema = getFieldWidgetByName(this.formJsonObj.widgetList, widgetName, true);
|
|
412
|
+
if (!!widgetSchema && !!widgetSchema.options && widgetSchema.options.hasOwnProperty("hidden")) {
|
|
413
|
+
widgetSchema.options.hidden = hiddenFlag;
|
|
414
|
+
}
|
|
415
|
+
this.findWidgetNameInSubForm(widgetName).forEach((wn) => {
|
|
416
|
+
const sw = this.getWidgetRef(wn);
|
|
417
|
+
if (!!sw && !!sw.setDisabled) {
|
|
418
|
+
sw.setHidden(hiddenFlag);
|
|
419
|
+
}
|
|
319
420
|
});
|
|
320
421
|
},
|
|
321
|
-
findWidgetNameInSubForm(
|
|
322
|
-
const
|
|
323
|
-
let
|
|
324
|
-
const
|
|
325
|
-
|
|
422
|
+
findWidgetNameInSubForm(widgetName) {
|
|
423
|
+
const result = [];
|
|
424
|
+
let subFormName = null;
|
|
425
|
+
const handlerFn = (field, parent) => {
|
|
426
|
+
if (!!field.options && field.options.name === widgetName) {
|
|
427
|
+
subFormName = parent.options.name;
|
|
428
|
+
}
|
|
326
429
|
};
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
430
|
+
traverseFieldWidgets(this.widgetList, handlerFn);
|
|
431
|
+
if (!!subFormName) {
|
|
432
|
+
const subFormRef = this.getWidgetRef(subFormName);
|
|
433
|
+
if (!!subFormRef) {
|
|
434
|
+
const rowIds = subFormRef.getRowIdData();
|
|
435
|
+
if (!!rowIds && rowIds.length > 0) {
|
|
436
|
+
rowIds.forEach((rid) => {
|
|
437
|
+
result.push(widgetName + "@row" + rid);
|
|
438
|
+
});
|
|
439
|
+
}
|
|
334
440
|
}
|
|
335
441
|
}
|
|
336
|
-
return
|
|
442
|
+
return result;
|
|
337
443
|
},
|
|
338
444
|
initDataSetRequest() {
|
|
339
|
-
const
|
|
340
|
-
this.getFieldWidgets().forEach((
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
const i = E(this.formConfig, e);
|
|
344
|
-
if (i) {
|
|
345
|
-
const o = new Object({});
|
|
346
|
-
g(o, this.globalDsv || {});
|
|
347
|
-
let s = null;
|
|
348
|
-
try {
|
|
349
|
-
s = await A(i, o, this, !1, this.$message), this.dsResultCache[e] = s, this.broadcast("FieldWidget", "loadOptionItemsFromDataSet", e);
|
|
350
|
-
} catch (r) {
|
|
351
|
-
this.$message.error(r.message);
|
|
352
|
-
}
|
|
445
|
+
const dsNameSet = /* @__PURE__ */ new Set();
|
|
446
|
+
this.getFieldWidgets().forEach((fw) => {
|
|
447
|
+
if (!!fw.field.options.dsEnabled && !!fw.field.options.dsName && !!fw.field.options.dataSetName) {
|
|
448
|
+
dsNameSet.add(fw.field.options.dsName);
|
|
353
449
|
}
|
|
354
450
|
});
|
|
451
|
+
if (dsNameSet.size > 0) {
|
|
452
|
+
dsNameSet.forEach(async (dsName) => {
|
|
453
|
+
const curDS = getDSByName(this.formConfig, dsName);
|
|
454
|
+
if (!!curDS) {
|
|
455
|
+
const localDsv = new Object({});
|
|
456
|
+
overwriteObj(localDsv, this.globalDsv || {});
|
|
457
|
+
let dsResult = null;
|
|
458
|
+
try {
|
|
459
|
+
dsResult = await runDataSourceRequest(curDS, localDsv, this, false, this.$message);
|
|
460
|
+
this.dsResultCache[dsName] = dsResult;
|
|
461
|
+
this.broadcast("FieldWidget", "loadOptionItemsFromDataSet", dsName);
|
|
462
|
+
} catch (err) {
|
|
463
|
+
this.$message.error(err.message);
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
});
|
|
467
|
+
}
|
|
355
468
|
},
|
|
356
469
|
//--------------------- 以下为组件支持外部调用的API方法 begin ------------------//
|
|
357
470
|
/* 提示:用户可自行扩充这些方法!!! */
|
|
358
|
-
changeLanguage(
|
|
359
|
-
|
|
471
|
+
changeLanguage(langName) {
|
|
472
|
+
changeLocale(langName);
|
|
360
473
|
},
|
|
361
474
|
getLanguageName() {
|
|
362
475
|
return localStorage.getItem("v_form_locale") || "zh-CN";
|
|
363
476
|
},
|
|
364
477
|
getNativeForm() {
|
|
365
|
-
return this.$refs
|
|
478
|
+
return this.$refs["renderForm"];
|
|
366
479
|
},
|
|
367
480
|
getFormRef() {
|
|
368
481
|
return this;
|
|
369
482
|
},
|
|
370
|
-
getWidgetRef(
|
|
371
|
-
const
|
|
372
|
-
|
|
483
|
+
getWidgetRef(widgetName, showError = false) {
|
|
484
|
+
const foundRef = this.widgetRefList[widgetName];
|
|
485
|
+
if (!foundRef && !!showError) {
|
|
486
|
+
this.$message.error(this.i18nt("render.hint.refNotFound") + widgetName);
|
|
487
|
+
}
|
|
488
|
+
return foundRef;
|
|
373
489
|
},
|
|
374
490
|
clearFormDataModel() {
|
|
375
|
-
for (const
|
|
376
|
-
delete this.formDataModel[
|
|
491
|
+
for (const pkey in this.formDataModel) {
|
|
492
|
+
delete this.formDataModel[pkey];
|
|
493
|
+
}
|
|
377
494
|
},
|
|
378
495
|
getFormJson() {
|
|
379
496
|
return this.formJsonObj;
|
|
@@ -382,174 +499,262 @@ const Z = {
|
|
|
382
499
|
* 动态加载表单JSON
|
|
383
500
|
* @param newFormJson
|
|
384
501
|
*/
|
|
385
|
-
setFormJson(
|
|
386
|
-
if (
|
|
387
|
-
if (typeof
|
|
388
|
-
let
|
|
389
|
-
if (typeof
|
|
502
|
+
setFormJson(newFormJson) {
|
|
503
|
+
if (!!newFormJson) {
|
|
504
|
+
if (typeof newFormJson === "string" || newFormJson.constructor === Object) {
|
|
505
|
+
let newFormJsonObj = null;
|
|
506
|
+
if (typeof newFormJson === "string") {
|
|
507
|
+
newFormJsonObj = JSON.parse(newFormJson);
|
|
508
|
+
} else {
|
|
509
|
+
newFormJsonObj = newFormJson;
|
|
510
|
+
}
|
|
511
|
+
if (!newFormJsonObj.formConfig || !newFormJsonObj.widgetList) {
|
|
390
512
|
this.$message.error("Invalid format of form json.");
|
|
391
513
|
return;
|
|
392
514
|
}
|
|
393
|
-
this.clearFormDataModel()
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
515
|
+
this.clearFormDataModel();
|
|
516
|
+
this.buildFormModel(newFormJsonObj.widgetList);
|
|
517
|
+
const defaultFormConfig = deepClone(getDefaultFormConfig());
|
|
518
|
+
overwriteObj(defaultFormConfig, newFormJsonObj.formConfig);
|
|
519
|
+
this.formJsonObj["formConfig"] = defaultFormConfig;
|
|
520
|
+
this.formJsonObj["widgetList"] = newFormJsonObj.widgetList;
|
|
521
|
+
this.insertCustomStyleAndScriptNode();
|
|
522
|
+
this.$nextTick(() => {
|
|
523
|
+
this.initFormObject(false);
|
|
524
|
+
this.initDataSetRequest();
|
|
525
|
+
this.handleOnMounted();
|
|
397
526
|
});
|
|
398
|
-
} else
|
|
527
|
+
} else {
|
|
399
528
|
this.$message.error("Set form json failed.");
|
|
529
|
+
}
|
|
530
|
+
}
|
|
400
531
|
},
|
|
401
532
|
/**
|
|
402
533
|
* 重新加载选项数据
|
|
403
534
|
* @param widgetNames 指定重新加载的组件名称或组件名数组,不传则重新加载所有选项字段
|
|
404
535
|
*/
|
|
405
|
-
reloadOptionData(
|
|
406
|
-
let
|
|
407
|
-
|
|
536
|
+
reloadOptionData(widgetNames) {
|
|
537
|
+
let eventParams = [];
|
|
538
|
+
if (!!widgetNames && typeof widgetNames === "string") {
|
|
539
|
+
eventParams = [widgetNames];
|
|
540
|
+
} else if (!!widgetNames && Array.isArray(widgetNames)) {
|
|
541
|
+
eventParams = [...widgetNames];
|
|
542
|
+
}
|
|
543
|
+
this.broadcast("FieldWidget", "reloadOptionItems", eventParams);
|
|
408
544
|
},
|
|
409
|
-
getFormData(
|
|
410
|
-
if (!
|
|
545
|
+
getFormData(needValidation = true) {
|
|
546
|
+
if (!needValidation) {
|
|
411
547
|
return this.formDataModel;
|
|
412
|
-
|
|
548
|
+
}
|
|
549
|
+
let callback = function nullFunc() {
|
|
413
550
|
};
|
|
414
|
-
const
|
|
415
|
-
|
|
416
|
-
|
|
551
|
+
const promise = new window.Promise(function(resolve, reject) {
|
|
552
|
+
callback = function(formData, error) {
|
|
553
|
+
!error ? resolve(formData) : reject(error);
|
|
417
554
|
};
|
|
418
555
|
});
|
|
419
|
-
|
|
420
|
-
|
|
556
|
+
this.$refs["renderForm"].validate().then((res) => {
|
|
557
|
+
callback(this.formDataModel);
|
|
421
558
|
}).catch(() => {
|
|
422
|
-
|
|
423
|
-
}), i;
|
|
424
|
-
},
|
|
425
|
-
setFormData(t) {
|
|
426
|
-
console.log("setFormData: ", t), Object.keys(this.formDataModel).forEach((e) => {
|
|
427
|
-
t && t.hasOwnProperty(e) && (this.formDataModel[e] = d(t[e]));
|
|
428
|
-
}), this.broadcast("ContainerItem", "setFormData", this.formDataModel), this.broadcast("FieldWidget", "setFormData", this.formDataModel);
|
|
429
|
-
},
|
|
430
|
-
getFieldValue(t) {
|
|
431
|
-
const e = this.getWidgetRef(t);
|
|
432
|
-
if (e && e.getValue)
|
|
433
|
-
return e.getValue();
|
|
434
|
-
if (!e) {
|
|
435
|
-
const i = [];
|
|
436
|
-
return this.findWidgetNameInSubForm(t).forEach((o) => {
|
|
437
|
-
const s = this.getWidgetRef(o);
|
|
438
|
-
s && s.getValue && i.push(s.getValue());
|
|
439
|
-
}), i;
|
|
440
|
-
}
|
|
441
|
-
},
|
|
442
|
-
setFieldValue(t, e, i = !1) {
|
|
443
|
-
const o = this.getWidgetRef(t);
|
|
444
|
-
o && o.setValue && o.setValue(e, i), o || this.findWidgetNameInSubForm(t).forEach((s) => {
|
|
445
|
-
const r = this.getWidgetRef(s);
|
|
446
|
-
r && r.setValue && r.setValue(e, i);
|
|
559
|
+
callback(this.formDataModel, this.i18nt("render.hint.validationFailed"));
|
|
447
560
|
});
|
|
561
|
+
return promise;
|
|
448
562
|
},
|
|
449
|
-
|
|
450
|
-
|
|
563
|
+
setFormData(formData) {
|
|
564
|
+
console.log("setFormData: ", formData);
|
|
565
|
+
Object.keys(this.formDataModel).forEach((propName) => {
|
|
566
|
+
if (!!formData && formData.hasOwnProperty(propName)) {
|
|
567
|
+
this.formDataModel[propName] = deepClone(formData[propName]);
|
|
568
|
+
}
|
|
569
|
+
});
|
|
570
|
+
this.broadcast("ContainerItem", "setFormData", this.formDataModel);
|
|
571
|
+
this.broadcast("FieldWidget", "setFormData", this.formDataModel);
|
|
572
|
+
},
|
|
573
|
+
getFieldValue(fieldName) {
|
|
574
|
+
const fieldRef = this.getWidgetRef(fieldName);
|
|
575
|
+
if (!!fieldRef && !!fieldRef.getValue) {
|
|
576
|
+
return fieldRef.getValue();
|
|
577
|
+
}
|
|
578
|
+
if (!fieldRef) {
|
|
579
|
+
const result = [];
|
|
580
|
+
this.findWidgetNameInSubForm(fieldName).forEach((wn) => {
|
|
581
|
+
const sw = this.getWidgetRef(wn);
|
|
582
|
+
if (!!sw && !!sw.getValue) {
|
|
583
|
+
result.push(sw.getValue());
|
|
584
|
+
}
|
|
585
|
+
});
|
|
586
|
+
return result;
|
|
587
|
+
}
|
|
588
|
+
},
|
|
589
|
+
setFieldValue(fieldName, fieldValue, disableChangeEvent = false) {
|
|
590
|
+
const fieldRef = this.getWidgetRef(fieldName);
|
|
591
|
+
if (!!fieldRef && !!fieldRef.setValue) {
|
|
592
|
+
fieldRef.setValue(fieldValue, disableChangeEvent);
|
|
593
|
+
}
|
|
594
|
+
if (!fieldRef) {
|
|
595
|
+
this.findWidgetNameInSubForm(fieldName).forEach((wn) => {
|
|
596
|
+
const sw = this.getWidgetRef(wn);
|
|
597
|
+
if (!!sw && !!sw.setValue) {
|
|
598
|
+
sw.setValue(fieldValue, disableChangeEvent);
|
|
599
|
+
}
|
|
600
|
+
});
|
|
601
|
+
}
|
|
602
|
+
},
|
|
603
|
+
getSubFormValues(subFormName, needValidation = true) {
|
|
604
|
+
const foundSFRef = this.subFormRefList[subFormName];
|
|
605
|
+
return foundSFRef.getSubFormValues(needValidation);
|
|
451
606
|
},
|
|
452
607
|
disableForm() {
|
|
453
|
-
Object.keys(this.widgetRefList)
|
|
454
|
-
|
|
455
|
-
|
|
608
|
+
const wNameList = Object.keys(this.widgetRefList);
|
|
609
|
+
wNameList.forEach((wName) => {
|
|
610
|
+
const foundW = this.getWidgetRef(wName);
|
|
611
|
+
if (!!foundW) {
|
|
612
|
+
if (!!foundW.widget && foundW.widget.type === "sub-form") {
|
|
613
|
+
foundW.disableSubForm();
|
|
614
|
+
} else if (!!foundW.widget && foundW.widget.type === "grid-sub-form") {
|
|
615
|
+
foundW.disableGridSubForm();
|
|
616
|
+
} else {
|
|
617
|
+
!!foundW.setDisabled && foundW.setDisabled(true);
|
|
618
|
+
}
|
|
619
|
+
}
|
|
456
620
|
});
|
|
457
621
|
},
|
|
458
622
|
enableForm() {
|
|
459
|
-
Object.keys(this.widgetRefList)
|
|
460
|
-
|
|
461
|
-
|
|
623
|
+
const wNameList = Object.keys(this.widgetRefList);
|
|
624
|
+
wNameList.forEach((wName) => {
|
|
625
|
+
const foundW = this.getWidgetRef(wName);
|
|
626
|
+
if (!!foundW) {
|
|
627
|
+
if (!!foundW.widget && foundW.widget.type === "sub-form") {
|
|
628
|
+
foundW.enableSubForm();
|
|
629
|
+
} else if (!!foundW.widget && foundW.widget.type === "grid-sub-form") {
|
|
630
|
+
foundW.enableGridSubForm();
|
|
631
|
+
} else {
|
|
632
|
+
!!foundW.setDisabled && foundW.setDisabled(false);
|
|
633
|
+
}
|
|
634
|
+
}
|
|
462
635
|
});
|
|
463
636
|
},
|
|
464
637
|
resetForm() {
|
|
465
|
-
Object.keys(this.subFormRefList)
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
})
|
|
638
|
+
const subFormNames = Object.keys(this.subFormRefList);
|
|
639
|
+
subFormNames.forEach((sfName) => {
|
|
640
|
+
if (!!this.subFormRefList[sfName].resetSubForm) {
|
|
641
|
+
this.subFormRefList[sfName].resetSubForm();
|
|
642
|
+
}
|
|
643
|
+
});
|
|
644
|
+
const wNameList = Object.keys(this.widgetRefList);
|
|
645
|
+
wNameList.forEach((wName) => {
|
|
646
|
+
const foundW = this.getWidgetRef(wName);
|
|
647
|
+
if (!!foundW && !foundW.subFormItemFlag && !!foundW.resetField) {
|
|
648
|
+
foundW.resetField();
|
|
649
|
+
}
|
|
650
|
+
});
|
|
651
|
+
this.$nextTick(() => {
|
|
471
652
|
this.clearValidate();
|
|
472
653
|
});
|
|
473
654
|
},
|
|
474
|
-
clearValidate(
|
|
475
|
-
this.$refs.renderForm.clearValidate(
|
|
655
|
+
clearValidate(props) {
|
|
656
|
+
this.$refs.renderForm.clearValidate(props);
|
|
476
657
|
},
|
|
477
658
|
/**
|
|
478
659
|
* 校验表单
|
|
479
660
|
* @param callback 回调函数
|
|
480
661
|
*/
|
|
481
|
-
validateForm(
|
|
482
|
-
this.$refs
|
|
483
|
-
|
|
662
|
+
validateForm(callback) {
|
|
663
|
+
this.$refs["renderForm"].validate((valid) => {
|
|
664
|
+
callback(valid);
|
|
484
665
|
});
|
|
485
666
|
},
|
|
486
667
|
validateFields() {
|
|
487
668
|
},
|
|
488
|
-
disableWidgets(
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
669
|
+
disableWidgets(widgetNames) {
|
|
670
|
+
if (!!widgetNames) {
|
|
671
|
+
if (typeof widgetNames === "string") {
|
|
672
|
+
this.findWidgetAndSetDisabled(widgetNames, true);
|
|
673
|
+
} else if (Array.isArray(widgetNames)) {
|
|
674
|
+
widgetNames.forEach((wn) => {
|
|
675
|
+
this.findWidgetAndSetDisabled(wn, true);
|
|
676
|
+
});
|
|
677
|
+
}
|
|
678
|
+
}
|
|
492
679
|
},
|
|
493
|
-
enableWidgets(
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
680
|
+
enableWidgets(widgetNames) {
|
|
681
|
+
if (!!widgetNames) {
|
|
682
|
+
if (typeof widgetNames === "string") {
|
|
683
|
+
this.findWidgetAndSetDisabled(widgetNames, false);
|
|
684
|
+
} else if (Array.isArray(widgetNames)) {
|
|
685
|
+
widgetNames.forEach((wn) => {
|
|
686
|
+
this.findWidgetAndSetDisabled(wn, false);
|
|
687
|
+
});
|
|
688
|
+
}
|
|
689
|
+
}
|
|
497
690
|
},
|
|
498
|
-
hideWidgets(
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
691
|
+
hideWidgets(widgetNames) {
|
|
692
|
+
if (!!widgetNames) {
|
|
693
|
+
if (typeof widgetNames === "string") {
|
|
694
|
+
this.findWidgetAndSetHidden(widgetNames, true);
|
|
695
|
+
} else if (Array.isArray(widgetNames)) {
|
|
696
|
+
widgetNames.forEach((wn) => {
|
|
697
|
+
this.findWidgetAndSetHidden(wn, true);
|
|
698
|
+
});
|
|
699
|
+
}
|
|
700
|
+
}
|
|
502
701
|
},
|
|
503
|
-
showWidgets(
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
702
|
+
showWidgets(widgetNames) {
|
|
703
|
+
if (!!widgetNames) {
|
|
704
|
+
if (typeof widgetNames === "string") {
|
|
705
|
+
this.findWidgetAndSetHidden(widgetNames, false);
|
|
706
|
+
} else if (Array.isArray(widgetNames)) {
|
|
707
|
+
widgetNames.forEach((wn) => {
|
|
708
|
+
this.findWidgetAndSetHidden(wn, false);
|
|
709
|
+
});
|
|
710
|
+
}
|
|
711
|
+
}
|
|
507
712
|
},
|
|
508
713
|
/**
|
|
509
714
|
* 获取所有字段组件
|
|
510
715
|
* @param staticWidgetsIncluded 是否包含按钮等静态组件,默认不包含
|
|
511
716
|
* @returns {*[]}
|
|
512
717
|
*/
|
|
513
|
-
getFieldWidgets(
|
|
514
|
-
return
|
|
718
|
+
getFieldWidgets(staticWidgetsIncluded = false) {
|
|
719
|
+
return getAllFieldWidgets(this.formJsonObj.widgetList, staticWidgetsIncluded);
|
|
515
720
|
},
|
|
516
721
|
/**
|
|
517
722
|
* 获取所有容器组件
|
|
518
723
|
* @returns {*[]}
|
|
519
724
|
*/
|
|
520
725
|
getContainerWidgets() {
|
|
521
|
-
return
|
|
726
|
+
return getAllContainerWidgets(this.formJsonObj.widgetList);
|
|
522
727
|
},
|
|
523
728
|
/**
|
|
524
729
|
* 增加外部组件引用,可通过getEC()方法获取外部组件,以便在VForm内部调用外部组件方法
|
|
525
730
|
* @param componentName 外部组件名称
|
|
526
731
|
* @param externalComponent 外部组件实例
|
|
527
732
|
*/
|
|
528
|
-
addEC(
|
|
529
|
-
this.externalComponents[
|
|
733
|
+
addEC(componentName, externalComponent) {
|
|
734
|
+
this.externalComponents[componentName] = externalComponent;
|
|
530
735
|
},
|
|
531
736
|
/**
|
|
532
737
|
* 判断外部组件是否可获取
|
|
533
738
|
* @param componentName 外部组件名称
|
|
534
739
|
* @returns {boolean}
|
|
535
740
|
*/
|
|
536
|
-
hasEC(
|
|
537
|
-
return this.externalComponents.hasOwnProperty(
|
|
741
|
+
hasEC(componentName) {
|
|
742
|
+
return this.externalComponents.hasOwnProperty(componentName);
|
|
538
743
|
},
|
|
539
744
|
/**
|
|
540
745
|
* 获取外部组件实例
|
|
541
746
|
* @param componentName
|
|
542
747
|
* @returns {*}
|
|
543
748
|
*/
|
|
544
|
-
getEC(
|
|
545
|
-
return this.externalComponents[
|
|
749
|
+
getEC(componentName) {
|
|
750
|
+
return this.externalComponents[componentName];
|
|
546
751
|
},
|
|
547
752
|
/**
|
|
548
753
|
* 设置或取消设置表单为只读查看模式
|
|
549
754
|
* @param readonlyFlag
|
|
550
755
|
*/
|
|
551
|
-
setReadMode(
|
|
552
|
-
this.readModeFlag =
|
|
756
|
+
setReadMode(readonlyFlag = true) {
|
|
757
|
+
this.readModeFlag = readonlyFlag;
|
|
553
758
|
},
|
|
554
759
|
/**
|
|
555
760
|
* 获取表单当前是否只读查看模式
|
|
@@ -570,9 +775,12 @@ const Z = {
|
|
|
570
775
|
* @param dsName
|
|
571
776
|
* @param localDsv
|
|
572
777
|
*/
|
|
573
|
-
async executeDataSource(
|
|
574
|
-
const
|
|
575
|
-
|
|
778
|
+
async executeDataSource(dsName, localDsv) {
|
|
779
|
+
const ds = getDSByName(this.formJsonObj.formConfig, dsName);
|
|
780
|
+
const newDsv = new Object({});
|
|
781
|
+
overwriteObj(newDsv, this.globalDsv);
|
|
782
|
+
overwriteObj(newDsv, localDsv);
|
|
783
|
+
return await runDataSourceRequest(ds, newDsv, this, false, this.$message);
|
|
576
784
|
},
|
|
577
785
|
/**
|
|
578
786
|
* 获取父级VFormRender组件实例
|
|
@@ -586,15 +794,17 @@ const Z = {
|
|
|
586
794
|
* @returns {object}
|
|
587
795
|
*/
|
|
588
796
|
getTopFormRef() {
|
|
589
|
-
if (!this.parentForm)
|
|
797
|
+
if (!this.parentForm) {
|
|
590
798
|
return this;
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
799
|
+
}
|
|
800
|
+
let topFormRef = this.parentForm;
|
|
801
|
+
while (topFormRef.parentForm) {
|
|
802
|
+
topFormRef = topFormRef.parentForm;
|
|
803
|
+
}
|
|
804
|
+
return topFormRef;
|
|
595
805
|
},
|
|
596
|
-
setChildFormRef(
|
|
597
|
-
this.childFormRef =
|
|
806
|
+
setChildFormRef(childFormRef) {
|
|
807
|
+
this.childFormRef = childFormRef;
|
|
598
808
|
},
|
|
599
809
|
getChildFormRef() {
|
|
600
810
|
return this.childFormRef;
|
|
@@ -606,8 +816,8 @@ const Z = {
|
|
|
606
816
|
isDynamicCreation() {
|
|
607
817
|
return this.dynamicCreation;
|
|
608
818
|
},
|
|
609
|
-
setDialogOrDrawerRef(
|
|
610
|
-
this.dialogOrDrawerRef =
|
|
819
|
+
setDialogOrDrawerRef(ddRef) {
|
|
820
|
+
this.dialogOrDrawerRef = ddRef;
|
|
611
821
|
},
|
|
612
822
|
/**
|
|
613
823
|
* 获取子级VFormRender的包裹弹窗组件或抽屉组件实例ref
|
|
@@ -622,52 +832,66 @@ const Z = {
|
|
|
622
832
|
* @param formData
|
|
623
833
|
* @param extraData
|
|
624
834
|
*/
|
|
625
|
-
showDialog(
|
|
626
|
-
const
|
|
627
|
-
|
|
628
|
-
|
|
835
|
+
showDialog(dialogName, formData = {}, extraData = {}) {
|
|
836
|
+
const topFormRef = this.getTopFormRef();
|
|
837
|
+
const dialogCon = getContainerWidgetByName(topFormRef.widgetList, dialogName);
|
|
838
|
+
if (!dialogName || dialogCon.type !== "vf-dialog") {
|
|
839
|
+
this.$message.error(this.i18nt("render.hint.refNotFound") + dialogName);
|
|
629
840
|
return;
|
|
630
841
|
}
|
|
631
|
-
const
|
|
632
|
-
widgetList:
|
|
633
|
-
formConfig:
|
|
634
|
-
}
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
842
|
+
const dFormJson = {
|
|
843
|
+
widgetList: deepClone(dialogCon.widgetList),
|
|
844
|
+
formConfig: cloneFormConfigWithoutEventHandler(topFormRef.formConfig)
|
|
845
|
+
};
|
|
846
|
+
const wrapperDivId = generateId() + "";
|
|
847
|
+
const dialogInstance = createVNode(DynamicDialog, {
|
|
848
|
+
options: dialogCon.options,
|
|
849
|
+
formJson: dFormJson,
|
|
850
|
+
formData: { ...formData },
|
|
851
|
+
optionData: topFormRef.optionData,
|
|
852
|
+
globalDsv: topFormRef.globalDsv,
|
|
640
853
|
parentFormRef: this,
|
|
641
|
-
extraData
|
|
642
|
-
wrapperId:
|
|
643
|
-
vfCtx: { ...
|
|
854
|
+
extraData,
|
|
855
|
+
wrapperId: wrapperDivId,
|
|
856
|
+
vfCtx: { ...formData }
|
|
644
857
|
});
|
|
645
|
-
|
|
646
|
-
const
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
858
|
+
dialogInstance.appContext = this.$root.$.appContext;
|
|
859
|
+
const wrapperDiv = document.createElement("div");
|
|
860
|
+
wrapperDiv.id = "vf-dynamic-dialog-wrapper" + wrapperDivId;
|
|
861
|
+
document.body.appendChild(wrapperDiv);
|
|
862
|
+
render(dialogInstance, wrapperDiv);
|
|
863
|
+
document.body.appendChild(dialogInstance.el);
|
|
864
|
+
dialogInstance.component.ctx.show();
|
|
865
|
+
},
|
|
866
|
+
showDrawer(drawerName, formData = {}, extraData = {}) {
|
|
867
|
+
const topFormRef = this.getTopFormRef();
|
|
868
|
+
const drawerCon = getContainerWidgetByName(topFormRef.widgetList, drawerName);
|
|
869
|
+
if (!drawerCon || drawerCon.type !== "vf-drawer") {
|
|
870
|
+
this.$message.error(this.i18nt("render.hint.refNotFound") + drawerName);
|
|
653
871
|
return;
|
|
654
872
|
}
|
|
655
|
-
const
|
|
656
|
-
widgetList:
|
|
657
|
-
formConfig:
|
|
658
|
-
}
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
873
|
+
const dFormJson = {
|
|
874
|
+
widgetList: deepClone(drawerCon.widgetList),
|
|
875
|
+
formConfig: cloneFormConfigWithoutEventHandler(topFormRef.formConfig)
|
|
876
|
+
};
|
|
877
|
+
const wrapperDivId = generateId() + "";
|
|
878
|
+
const drawerInstance = createVNode(DynamicDrawer, {
|
|
879
|
+
options: drawerCon.options,
|
|
880
|
+
formJson: dFormJson,
|
|
881
|
+
formData: formData || {},
|
|
882
|
+
optionData: topFormRef.optionData,
|
|
883
|
+
globalDsv: topFormRef.globalDsv,
|
|
664
884
|
parentFormRef: this,
|
|
665
|
-
extraData
|
|
666
|
-
wrapperId:
|
|
885
|
+
extraData,
|
|
886
|
+
wrapperId: wrapperDivId
|
|
667
887
|
});
|
|
668
|
-
|
|
669
|
-
const
|
|
670
|
-
|
|
888
|
+
drawerInstance.appContext = this.$root.$.appContext;
|
|
889
|
+
const wrapperDiv = document.createElement("div");
|
|
890
|
+
wrapperDiv.id = "vf-dynamic-drawer-wrapper" + wrapperDivId;
|
|
891
|
+
document.body.appendChild(wrapperDiv);
|
|
892
|
+
render(drawerInstance, wrapperDiv);
|
|
893
|
+
document.body.appendChild(drawerInstance.el);
|
|
894
|
+
drawerInstance.component.ctx.show();
|
|
671
895
|
},
|
|
672
896
|
/**
|
|
673
897
|
* 判断表单是否处于设计器预览状态
|
|
@@ -679,55 +903,62 @@ const Z = {
|
|
|
679
903
|
//--------------------- 以上为组件支持外部调用的API方法 end ------------------//
|
|
680
904
|
}
|
|
681
905
|
};
|
|
682
|
-
function
|
|
683
|
-
const
|
|
684
|
-
|
|
685
|
-
|
|
906
|
+
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
907
|
+
const _component_a_form = resolveComponent("a-form");
|
|
908
|
+
const _component_a_config_provider = resolveComponent("a-config-provider");
|
|
909
|
+
return openBlock(), createBlock(_component_a_config_provider, {
|
|
910
|
+
"component-size": $options.size,
|
|
686
911
|
input: { autocomplete: "off" }
|
|
687
912
|
}, {
|
|
688
|
-
default:
|
|
689
|
-
|
|
690
|
-
layout:
|
|
691
|
-
class:
|
|
692
|
-
"label-width":
|
|
693
|
-
"validate-on-rule-change":
|
|
694
|
-
model:
|
|
913
|
+
default: withCtx(() => [
|
|
914
|
+
createVNode(_component_a_form, {
|
|
915
|
+
layout: $options.labelPosition,
|
|
916
|
+
class: normalizeClass([[$options.customClass, $data.readModeFlag ? "readonly-mode-form" : ""], "render-form tpf-form"]),
|
|
917
|
+
"label-width": $options.labelWidth,
|
|
918
|
+
"validate-on-rule-change": false,
|
|
919
|
+
model: $data.formDataModel,
|
|
695
920
|
ref: "renderForm",
|
|
696
|
-
onSubmit:
|
|
921
|
+
onSubmit: _cache[0] || (_cache[0] = withModifiers(() => {
|
|
697
922
|
}, ["prevent"]))
|
|
698
923
|
}, {
|
|
699
|
-
default:
|
|
700
|
-
(
|
|
701
|
-
|
|
702
|
-
widget
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
924
|
+
default: withCtx(() => [
|
|
925
|
+
(openBlock(true), createElementBlock(Fragment, null, renderList($options.widgetList, (widget, index) => {
|
|
926
|
+
return openBlock(), createElementBlock(Fragment, null, [
|
|
927
|
+
"container" === widget.category ? (openBlock(), createBlock(resolveDynamicComponent($options.getContainerWidgetName(widget)), {
|
|
928
|
+
widget,
|
|
929
|
+
key: widget.id,
|
|
930
|
+
"parent-list": $options.widgetList,
|
|
931
|
+
"index-of-parent-list": index,
|
|
932
|
+
"parent-widget": null
|
|
933
|
+
}, createSlots({ _: 2 }, [
|
|
934
|
+
renderList(Object.keys(_ctx.$slots), (slot) => {
|
|
935
|
+
return {
|
|
936
|
+
name: slot,
|
|
937
|
+
fn: withCtx((scope) => [
|
|
938
|
+
renderSlot(_ctx.$slots, slot, normalizeProps(guardReactiveProps(scope)), void 0, true)
|
|
939
|
+
])
|
|
940
|
+
};
|
|
941
|
+
})
|
|
942
|
+
]), 1032, ["widget", "parent-list", "index-of-parent-list"])) : (openBlock(), createBlock(resolveDynamicComponent($options.getWidgetName(widget)), {
|
|
943
|
+
field: widget,
|
|
944
|
+
"form-model": $data.formDataModel,
|
|
945
|
+
designer: null,
|
|
946
|
+
key: widget.id,
|
|
947
|
+
"parent-list": $options.widgetList,
|
|
948
|
+
"index-of-parent-list": index,
|
|
949
|
+
"parent-widget": null
|
|
950
|
+
}, createSlots({ _: 2 }, [
|
|
951
|
+
renderList(Object.keys(_ctx.$slots), (slot) => {
|
|
952
|
+
return {
|
|
953
|
+
name: slot,
|
|
954
|
+
fn: withCtx((scope) => [
|
|
955
|
+
renderSlot(_ctx.$slots, slot, normalizeProps(guardReactiveProps(scope)), void 0, true)
|
|
956
|
+
])
|
|
957
|
+
};
|
|
958
|
+
})
|
|
959
|
+
]), 1032, ["field", "form-model", "parent-list", "index-of-parent-list"]))
|
|
960
|
+
], 64);
|
|
961
|
+
}), 256))
|
|
731
962
|
]),
|
|
732
963
|
_: 3
|
|
733
964
|
}, 8, ["layout", "class", "label-width", "model"])
|
|
@@ -735,7 +966,7 @@ function I(t, e, i, o, s, r) {
|
|
|
735
966
|
_: 3
|
|
736
967
|
}, 8, ["component-size"]);
|
|
737
968
|
}
|
|
738
|
-
const
|
|
969
|
+
const VFormRender = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-ab2b030a"]]);
|
|
739
970
|
export {
|
|
740
|
-
|
|
971
|
+
VFormRender as default
|
|
741
972
|
};
|