@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
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { translateOptionItems
|
|
2
|
-
import
|
|
3
|
-
import { fmtHttpParams
|
|
4
|
-
import { eq
|
|
5
|
-
const
|
|
1
|
+
import { translateOptionItems, deepClone } from "../../../../utils/util.js";
|
|
2
|
+
import FormValidators from "../../../../utils/validators.js";
|
|
3
|
+
import { fmtHttpParams } from "../../../../utils/request/fmtHttpParams.js";
|
|
4
|
+
import { eq, isArray } from "lodash-es";
|
|
5
|
+
const fieldMixin = {
|
|
6
6
|
inject: [
|
|
7
7
|
"refList",
|
|
8
8
|
"getFormConfig",
|
|
@@ -17,8 +17,8 @@ const F = {
|
|
|
17
17
|
],
|
|
18
18
|
data() {
|
|
19
19
|
return {
|
|
20
|
-
fieldReadonlyFlag:
|
|
21
|
-
loading:
|
|
20
|
+
fieldReadonlyFlag: false,
|
|
21
|
+
loading: false
|
|
22
22
|
};
|
|
23
23
|
},
|
|
24
24
|
computed: {
|
|
@@ -26,257 +26,493 @@ const F = {
|
|
|
26
26
|
return this.getFormConfig();
|
|
27
27
|
},
|
|
28
28
|
subFormName() {
|
|
29
|
-
return this.getSubFormName ? this.getSubFormName() : "";
|
|
29
|
+
return !!this.getSubFormName ? this.getSubFormName() : "";
|
|
30
30
|
},
|
|
31
31
|
subFormItemFlag() {
|
|
32
|
-
return this.getSubFormFieldFlag ? this.getSubFormFieldFlag() :
|
|
32
|
+
return !!this.getSubFormFieldFlag ? this.getSubFormFieldFlag() : false;
|
|
33
33
|
},
|
|
34
34
|
formModel: {
|
|
35
|
-
cache:
|
|
35
|
+
cache: false,
|
|
36
36
|
get() {
|
|
37
37
|
return this.globalModel.formModel;
|
|
38
38
|
}
|
|
39
39
|
},
|
|
40
40
|
isReadMode() {
|
|
41
|
-
return this.getReadMode() ?
|
|
41
|
+
return !!this.getReadMode() ? true : this.fieldReadonlyFlag;
|
|
42
42
|
},
|
|
43
43
|
optionLabel() {
|
|
44
|
-
if (this.fieldModel === null)
|
|
44
|
+
if (this.fieldModel === null) {
|
|
45
45
|
return "";
|
|
46
|
-
{
|
|
47
|
-
let
|
|
48
|
-
const { valueKey
|
|
49
|
-
|
|
50
|
-
(
|
|
51
|
-
|
|
46
|
+
} else {
|
|
47
|
+
let resultContent = "";
|
|
48
|
+
const { valueKey, labelKey } = this.field.options;
|
|
49
|
+
this.field.options.optionItems.forEach((oItem) => {
|
|
50
|
+
if (oItem[valueKey] === this.fieldModel || this.findInArray(this.fieldModel, oItem[valueKey]) !== -1) {
|
|
51
|
+
resultContent = resultContent === "" ? oItem[labelKey] : resultContent + " " + oItem[labelKey];
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
return resultContent;
|
|
52
55
|
}
|
|
53
56
|
}
|
|
54
57
|
},
|
|
55
58
|
methods: {
|
|
56
59
|
handleHidden() {
|
|
57
|
-
if (this.designState)
|
|
58
|
-
return
|
|
59
|
-
|
|
60
|
-
|
|
60
|
+
if (this.designState) {
|
|
61
|
+
return false;
|
|
62
|
+
}
|
|
63
|
+
const { onHidden, hidden } = this.field.options;
|
|
64
|
+
if (hidden) return true;
|
|
65
|
+
if (onHidden) {
|
|
66
|
+
const onHiddenFn = new Function(onHidden);
|
|
67
|
+
return onHiddenFn.call(this);
|
|
68
|
+
}
|
|
69
|
+
return false;
|
|
61
70
|
},
|
|
62
71
|
handleDisabled() {
|
|
63
|
-
if (this.designState)
|
|
64
|
-
return
|
|
65
|
-
|
|
66
|
-
|
|
72
|
+
if (this.designState) {
|
|
73
|
+
return false;
|
|
74
|
+
}
|
|
75
|
+
const { onDisabled, disabled } = this.field.options;
|
|
76
|
+
if (disabled) return true;
|
|
77
|
+
if (onDisabled) {
|
|
78
|
+
const disabledFn = new Function(onDisabled);
|
|
79
|
+
return disabledFn.call(this);
|
|
80
|
+
}
|
|
81
|
+
return false;
|
|
67
82
|
},
|
|
68
|
-
findInArray(
|
|
69
|
-
if (!Array.isArray(
|
|
83
|
+
findInArray(arrayObject, element) {
|
|
84
|
+
if (!Array.isArray(arrayObject)) {
|
|
70
85
|
return -1;
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
86
|
+
}
|
|
87
|
+
let foundIdx = -1;
|
|
88
|
+
arrayObject.forEach((aItem, aIdx) => {
|
|
89
|
+
if (aItem === element) {
|
|
90
|
+
foundIdx = aIdx;
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
return foundIdx;
|
|
75
94
|
},
|
|
76
95
|
//--------------------- 组件内部方法 begin ------------------//
|
|
77
96
|
getPropName() {
|
|
78
|
-
|
|
97
|
+
if (this.subFormItemFlag && !this.designState) {
|
|
98
|
+
return this.subFormName + "." + this.subFormRowIndex + "." + this.field.options.name;
|
|
99
|
+
} else {
|
|
100
|
+
return this.field.options.name;
|
|
101
|
+
}
|
|
79
102
|
},
|
|
80
103
|
initFieldModel() {
|
|
81
|
-
if (this.field.formItemFlag) {
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
104
|
+
if (!this.field.formItemFlag) {
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
if (!!this.subFormItemFlag && !this.designState) {
|
|
108
|
+
const subFormData = this.formModel[this.subFormName];
|
|
109
|
+
if ((subFormData === void 0 || subFormData[this.subFormRowIndex] === void 0 || subFormData[this.subFormRowIndex][this.field.options.name] === void 0) && this.field.options.defaultValue !== void 0) {
|
|
110
|
+
this.fieldModel = this.field.options.defaultValue;
|
|
111
|
+
subFormData[this.subFormRowIndex][this.field.options.name] = this.field.options.defaultValue;
|
|
112
|
+
} else if (subFormData[this.subFormRowIndex][this.field.options.name] === void 0) {
|
|
113
|
+
this.fieldModel = null;
|
|
114
|
+
subFormData[this.subFormRowIndex][this.field.options.name] = null;
|
|
115
|
+
} else {
|
|
116
|
+
this.fieldModel = subFormData[this.subFormRowIndex][this.field.options.name];
|
|
94
117
|
}
|
|
95
|
-
|
|
118
|
+
setTimeout(() => {
|
|
119
|
+
this.handleOnChangeForSubForm(
|
|
120
|
+
this.fieldModel,
|
|
121
|
+
this.oldFieldValue,
|
|
122
|
+
[],
|
|
123
|
+
subFormData,
|
|
124
|
+
this.subFormRowId
|
|
125
|
+
);
|
|
126
|
+
}, 800);
|
|
127
|
+
this.oldFieldValue = deepClone(this.fieldModel);
|
|
128
|
+
this.initFileList();
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
if (this.formModel[this.field.options.name] === void 0 && this.field.options.defaultValue !== void 0) {
|
|
132
|
+
this.fieldModel = this.field.options.defaultValue;
|
|
133
|
+
} else if (this.formModel[this.field.options.name] === void 0) {
|
|
134
|
+
this.formModel[this.field.options.name] = null;
|
|
135
|
+
} else {
|
|
136
|
+
this.fieldModel = this.formModel[this.field.options.name];
|
|
96
137
|
}
|
|
138
|
+
this.oldFieldValue = deepClone(this.fieldModel);
|
|
139
|
+
this.initFileList();
|
|
97
140
|
},
|
|
98
141
|
initFileList() {
|
|
99
|
-
this.field.type !== "picture-upload" && this.field.type !== "file-upload" || this.designState ===
|
|
142
|
+
if (this.field.type !== "picture-upload" && this.field.type !== "file-upload" || this.designState === true) {
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
if (!!this.fieldModel) {
|
|
146
|
+
if (Array.isArray(this.fieldModel)) {
|
|
147
|
+
this.fileList = deepClone(this.fieldModel);
|
|
148
|
+
} else {
|
|
149
|
+
this.fileList.splice(0, 0, deepClone(this.fieldModel));
|
|
150
|
+
}
|
|
151
|
+
}
|
|
100
152
|
},
|
|
101
153
|
initEventHandler() {
|
|
102
|
-
this.on$("setFormData", (
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
this.
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
154
|
+
this.on$("setFormData", (newFormData) => {
|
|
155
|
+
if (!this.subFormItemFlag) {
|
|
156
|
+
this.setValue(newFormData[this.field.options.name]);
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
this.on$("field-value-changed", (values) => {
|
|
160
|
+
if (!!this.subFormItemFlag) {
|
|
161
|
+
const subFormData = this.formModel[this.subFormName];
|
|
162
|
+
this.handleOnChangeForSubForm(values[0], values[1], subFormData, this.subFormRowId);
|
|
163
|
+
} else {
|
|
164
|
+
this.handleOnChange(values[0], values[1]);
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
this.on$("loadOptionItemsFromDataSet", (dsName) => {
|
|
168
|
+
this.loadOptionItemsFromDataSet(dsName);
|
|
169
|
+
});
|
|
170
|
+
this.on$("reloadOptionItems", (widgetNames) => {
|
|
171
|
+
if (widgetNames.length === 0 || widgetNames.indexOf(this.field.options.name) > -1) {
|
|
172
|
+
this.initOptionItems(true);
|
|
173
|
+
}
|
|
114
174
|
});
|
|
115
175
|
},
|
|
116
176
|
handleOnCreated() {
|
|
117
|
-
|
|
177
|
+
if (!!this.designState) {
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
if (!!this.field.options.onCreated) {
|
|
181
|
+
const customFunc = new Function(this.field.options.onCreated);
|
|
182
|
+
customFunc.call(this);
|
|
183
|
+
}
|
|
118
184
|
},
|
|
119
185
|
handleOnMounted() {
|
|
120
|
-
|
|
186
|
+
if (!!this.designState) {
|
|
187
|
+
return;
|
|
188
|
+
}
|
|
189
|
+
if (!!this.field.options.onMounted) {
|
|
190
|
+
const mountFunc = new Function(this.field.options.onMounted);
|
|
191
|
+
mountFunc.call(this);
|
|
192
|
+
}
|
|
121
193
|
},
|
|
122
|
-
registerToRefList(
|
|
123
|
-
this.refList !== null && this.field.options.name
|
|
194
|
+
registerToRefList(oldRefName) {
|
|
195
|
+
if (this.refList !== null && !!this.field.options.name) {
|
|
196
|
+
if (this.subFormItemFlag && !this.designState) {
|
|
197
|
+
if (!!oldRefName) {
|
|
198
|
+
delete this.refList[oldRefName + "@row" + this.subFormRowId];
|
|
199
|
+
}
|
|
200
|
+
this.refList[this.field.options.name + "@row" + this.subFormRowId] = this;
|
|
201
|
+
} else {
|
|
202
|
+
if (!!oldRefName) {
|
|
203
|
+
delete this.refList[oldRefName];
|
|
204
|
+
}
|
|
205
|
+
this.refList[this.field.options.name] = this;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
124
208
|
},
|
|
125
209
|
unregisterFromRefList() {
|
|
126
|
-
if (this.refList !== null && this.field.options.name) {
|
|
127
|
-
const
|
|
128
|
-
this.subFormItemFlag && !this.designState
|
|
210
|
+
if (this.refList !== null && !!this.field.options.name) {
|
|
211
|
+
const oldRefName = this.field.options.name;
|
|
212
|
+
if (this.subFormItemFlag && !this.designState) {
|
|
213
|
+
delete this.refList[oldRefName + "@row" + this.subFormRowId];
|
|
214
|
+
} else {
|
|
215
|
+
delete this.refList[oldRefName];
|
|
216
|
+
}
|
|
129
217
|
}
|
|
130
218
|
},
|
|
131
219
|
clearOptionItems() {
|
|
132
|
-
|
|
220
|
+
if (!!this.field.options.dsEnabled) {
|
|
221
|
+
this.field.options.optionItems.splice(0, this.field.options.optionItems.length);
|
|
222
|
+
}
|
|
133
223
|
},
|
|
134
|
-
async initOptionItems(
|
|
135
|
-
var
|
|
136
|
-
if (
|
|
137
|
-
|
|
224
|
+
async initOptionItems(keepSelected) {
|
|
225
|
+
var _a;
|
|
226
|
+
if (this.designState) {
|
|
227
|
+
return;
|
|
228
|
+
}
|
|
229
|
+
if (this.loading) return;
|
|
230
|
+
this.loading = true;
|
|
231
|
+
if (["radio", "checkbox", "select", "cascader", "treeSelect"].includes(this.field.type)) {
|
|
232
|
+
if (!!this.field.options.dsEnabled && ((_a = this.field.options.http) == null ? void 0 : _a.url)) {
|
|
138
233
|
try {
|
|
139
|
-
const
|
|
234
|
+
const dsResult = await fmtHttpParams.call(this, this.field.options, {
|
|
140
235
|
fieldCode: this.field.options.name
|
|
141
236
|
});
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
237
|
+
if (isArray(dsResult)) {
|
|
238
|
+
this.loadOptions(dsResult);
|
|
239
|
+
}
|
|
240
|
+
if (isArray(dsResult.list)) {
|
|
241
|
+
if (this.field.options.loadingPage) {
|
|
242
|
+
this.pager.total = dsResult.total || 0;
|
|
243
|
+
this.pager.totalPage = dsResult.totalPage || 0;
|
|
244
|
+
this.loadOptions([...this.getOptionItems(), ...dsResult.list]);
|
|
245
|
+
} else {
|
|
246
|
+
this.loadOptions(dsResult.list);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
} catch (err) {
|
|
250
|
+
console.error("err: ", err);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
const newOptionItems = this.getOptionData();
|
|
254
|
+
if (!!newOptionItems && newOptionItems.hasOwnProperty(this.field.options.name)) {
|
|
255
|
+
if (!!keepSelected) {
|
|
256
|
+
this.reloadOptions(newOptionItems[this.field.options.name]);
|
|
257
|
+
} else {
|
|
258
|
+
this.loadOptions(newOptionItems[this.field.options.name]);
|
|
145
259
|
}
|
|
146
|
-
|
|
147
|
-
|
|
260
|
+
}
|
|
261
|
+
this.loading = false;
|
|
148
262
|
}
|
|
149
263
|
},
|
|
150
|
-
loadOptionItemsFromDataSet(
|
|
151
|
-
if (this.designState
|
|
264
|
+
loadOptionItemsFromDataSet(dsName) {
|
|
265
|
+
if (this.designState) {
|
|
266
|
+
return;
|
|
267
|
+
}
|
|
268
|
+
if (this.field.type !== "radio" && this.field.type !== "checkbox" && this.field.type !== "select" && this.field.type !== "cascader") {
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
271
|
+
if (!this.field.options.dsEnabled || !this.field.options.dsName || !this.field.options.dataSetName || this.field.options.dsName !== dsName) {
|
|
152
272
|
return;
|
|
153
|
-
|
|
154
|
-
|
|
273
|
+
}
|
|
274
|
+
const dataCache = this.getDSResultCache();
|
|
275
|
+
const dSetName = this.field.options.dataSetName;
|
|
276
|
+
if (!!dataCache && !!dataCache[dsName] && !!dataCache[dsName][dSetName]) {
|
|
277
|
+
this.field.options.optionItems.splice(0, this.field.options.optionItems.length);
|
|
278
|
+
this.loadOptions(dataCache[dsName][dSetName]);
|
|
279
|
+
}
|
|
155
280
|
},
|
|
156
281
|
refreshDefaultValue() {
|
|
157
|
-
this.designState ===
|
|
282
|
+
if (this.designState === true && this.field.options.defaultValue !== void 0) {
|
|
283
|
+
this.fieldModel = this.field.options.defaultValue;
|
|
284
|
+
}
|
|
158
285
|
},
|
|
159
286
|
clearFieldRules() {
|
|
160
|
-
this.field.formItemFlag
|
|
287
|
+
if (!this.field.formItemFlag) {
|
|
288
|
+
return;
|
|
289
|
+
}
|
|
290
|
+
this.rules.splice(0, this.rules.length);
|
|
161
291
|
},
|
|
162
292
|
buildFieldRules() {
|
|
163
|
-
if (!
|
|
164
|
-
|
|
165
|
-
|
|
293
|
+
if (!this.field.formItemFlag || this.field.options.hidden) {
|
|
294
|
+
return;
|
|
295
|
+
}
|
|
296
|
+
this.rules.splice(0, this.rules.length);
|
|
297
|
+
if (!!this.field.options.required) {
|
|
298
|
+
this.rules.push({
|
|
299
|
+
required: true,
|
|
166
300
|
//trigger: ['blur', 'change'],
|
|
167
301
|
trigger: [
|
|
168
302
|
"blur"
|
|
169
303
|
],
|
|
170
304
|
message: this.field.options.requiredHint || this.i18nt("render.hint.fieldRequired")
|
|
171
|
-
})
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
305
|
+
});
|
|
306
|
+
}
|
|
307
|
+
if (!!this.field.options.validation) {
|
|
308
|
+
const vldName = this.field.options.validation;
|
|
309
|
+
if (!!FormValidators[vldName]) {
|
|
310
|
+
this.rules.push({
|
|
311
|
+
validator: FormValidators[vldName],
|
|
175
312
|
trigger: ["blur", "change"],
|
|
176
313
|
label: this.field.options.label,
|
|
177
314
|
errorMsg: this.field.options.validationHint
|
|
178
|
-
})
|
|
179
|
-
|
|
315
|
+
});
|
|
316
|
+
} else {
|
|
317
|
+
this.rules.push({
|
|
318
|
+
validator: FormValidators["regExp"],
|
|
180
319
|
trigger: ["blur", "change"],
|
|
181
|
-
regExp:
|
|
320
|
+
regExp: vldName,
|
|
182
321
|
label: this.field.options.label,
|
|
183
322
|
errorMsg: this.field.options.validationHint
|
|
184
323
|
});
|
|
185
324
|
}
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
325
|
+
}
|
|
326
|
+
if (!!this.field.options.onValidate) {
|
|
327
|
+
const customFn = (rule, value) => {
|
|
328
|
+
const tmpFunc = new Function("rule", "value", this.field.options.onValidate);
|
|
329
|
+
return tmpFunc.call(this, rule, value);
|
|
330
|
+
};
|
|
331
|
+
this.rules.push({
|
|
332
|
+
validator: customFn,
|
|
333
|
+
trigger: ["blur"],
|
|
334
|
+
label: this.field.options.label
|
|
335
|
+
});
|
|
194
336
|
}
|
|
195
337
|
},
|
|
196
338
|
/**
|
|
197
339
|
* 禁用字段值变动触发表单校验
|
|
198
340
|
*/
|
|
199
341
|
disableChangeValidate() {
|
|
200
|
-
|
|
201
|
-
|
|
342
|
+
if (!this.rules) {
|
|
343
|
+
return;
|
|
344
|
+
}
|
|
345
|
+
this.rules.forEach((rule) => {
|
|
346
|
+
if (!!rule.trigger) {
|
|
347
|
+
rule.trigger.splice(0, rule.trigger.length);
|
|
348
|
+
}
|
|
202
349
|
});
|
|
203
350
|
},
|
|
204
351
|
/**
|
|
205
352
|
* 启用字段值变动触发表单校验
|
|
206
353
|
*/
|
|
207
354
|
enableChangeValidate() {
|
|
208
|
-
|
|
209
|
-
|
|
355
|
+
if (!this.rules) {
|
|
356
|
+
return;
|
|
357
|
+
}
|
|
358
|
+
this.rules.forEach((rule) => {
|
|
359
|
+
if (!!rule.trigger) {
|
|
360
|
+
rule.trigger.push("blur");
|
|
361
|
+
rule.trigger.push("change");
|
|
362
|
+
}
|
|
210
363
|
});
|
|
211
364
|
},
|
|
212
|
-
disableOptionOfList(
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
365
|
+
disableOptionOfList(optionList, optionValue) {
|
|
366
|
+
if (!!optionList && optionList.length > 0) {
|
|
367
|
+
optionList.forEach((opt) => {
|
|
368
|
+
if (opt.value === optionValue) {
|
|
369
|
+
opt.disabled = true;
|
|
370
|
+
}
|
|
371
|
+
});
|
|
372
|
+
}
|
|
216
373
|
},
|
|
217
|
-
enableOptionOfList(
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
374
|
+
enableOptionOfList(optionList, optionValue) {
|
|
375
|
+
if (!!optionList && optionList.length > 0) {
|
|
376
|
+
optionList.forEach((opt) => {
|
|
377
|
+
if (opt.value === optionValue) {
|
|
378
|
+
opt.disabled = false;
|
|
379
|
+
}
|
|
380
|
+
});
|
|
381
|
+
}
|
|
221
382
|
},
|
|
222
383
|
//--------------------- 组件内部方法 end ------------------//
|
|
223
384
|
//--------------------- 事件处理 begin ------------------//
|
|
224
|
-
emitFieldDataChange(
|
|
225
|
-
|
|
385
|
+
emitFieldDataChange(newValue, oldValue) {
|
|
386
|
+
if (newValue) {
|
|
387
|
+
newValue = newValue.target ? newValue.target.value : newValue;
|
|
388
|
+
}
|
|
389
|
+
this.emit$("field-value-changed", [newValue, oldValue]);
|
|
390
|
+
this.dispatch("VFormRender", "fieldChange", [
|
|
226
391
|
this.field.options.name,
|
|
227
|
-
|
|
228
|
-
|
|
392
|
+
newValue,
|
|
393
|
+
oldValue,
|
|
229
394
|
this.subFormName,
|
|
230
395
|
this.subFormRowIndex
|
|
231
396
|
]);
|
|
232
397
|
},
|
|
233
|
-
syncUpdateFormModel(
|
|
234
|
-
if (
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
}
|
|
239
|
-
|
|
398
|
+
syncUpdateFormModel(value) {
|
|
399
|
+
if (!!this.designState) {
|
|
400
|
+
return;
|
|
401
|
+
}
|
|
402
|
+
if (!!this.subFormItemFlag) {
|
|
403
|
+
const subFormData = this.formModel[this.subFormName] || [{}];
|
|
404
|
+
const subFormDataRow = subFormData[this.subFormRowIndex];
|
|
405
|
+
if (!!subFormDataRow) {
|
|
406
|
+
subFormDataRow[this.field.options.name] = value;
|
|
407
|
+
}
|
|
408
|
+
} else {
|
|
409
|
+
this.formModel[this.field.options.name] = value;
|
|
410
|
+
}
|
|
240
411
|
},
|
|
241
|
-
handleChangeEvent(
|
|
242
|
-
|
|
412
|
+
handleChangeEvent(value) {
|
|
413
|
+
if (value) {
|
|
414
|
+
value = value.target ? value.target.value : value;
|
|
415
|
+
}
|
|
416
|
+
if (!!this.designState) {
|
|
417
|
+
return;
|
|
418
|
+
}
|
|
419
|
+
this.syncUpdateFormModel(value);
|
|
420
|
+
this.emitFieldDataChange(value, this.oldFieldValue);
|
|
421
|
+
this.oldFieldValue = deepClone(value);
|
|
422
|
+
this.dispatch("VFormRender", "fieldValidation", [this.getPropName()]);
|
|
243
423
|
},
|
|
244
|
-
handleFocusCustomEvent(
|
|
245
|
-
|
|
424
|
+
handleFocusCustomEvent(event) {
|
|
425
|
+
if (!!this.designState) {
|
|
426
|
+
return;
|
|
427
|
+
}
|
|
428
|
+
this.oldFieldValue = deepClone(this.fieldModel);
|
|
429
|
+
if (!!this.field.options.onFocus) {
|
|
430
|
+
const customFn = new Function("event", this.field.options.onFocus);
|
|
431
|
+
customFn.call(this, event);
|
|
432
|
+
}
|
|
433
|
+
if (this.field.options.loadingPage) {
|
|
434
|
+
this.initPager();
|
|
435
|
+
this.initOptionItems();
|
|
436
|
+
}
|
|
246
437
|
},
|
|
247
|
-
handleBlurCustomEvent(
|
|
248
|
-
|
|
438
|
+
handleBlurCustomEvent(event) {
|
|
439
|
+
if (!!this.designState) {
|
|
440
|
+
return;
|
|
441
|
+
}
|
|
442
|
+
if (!!this.field.options.onBlur) {
|
|
443
|
+
const customFn = new Function("event", this.field.options.onBlur);
|
|
444
|
+
customFn.call(this, event);
|
|
445
|
+
}
|
|
249
446
|
},
|
|
250
|
-
handleInputCustomEvent(
|
|
251
|
-
|
|
447
|
+
handleInputCustomEvent(value) {
|
|
448
|
+
if (value) {
|
|
449
|
+
value = value.target ? value.target.value : value;
|
|
450
|
+
}
|
|
451
|
+
if (!!this.designState) {
|
|
452
|
+
return;
|
|
453
|
+
}
|
|
454
|
+
this.syncUpdateFormModel(value);
|
|
455
|
+
this.dispatch("VFormRender", "fieldValidation", [this.getPropName()]);
|
|
456
|
+
if (!!this.field.options.onInput) {
|
|
457
|
+
const customFn = new Function("value", this.field.options.onInput);
|
|
458
|
+
customFn.call(this, value);
|
|
459
|
+
}
|
|
252
460
|
},
|
|
253
461
|
emitAppendButtonClick() {
|
|
254
|
-
|
|
462
|
+
if (!!this.designState) {
|
|
463
|
+
return;
|
|
464
|
+
}
|
|
465
|
+
if (!!this.field.options.onAppendButtonClick) {
|
|
466
|
+
const customFn = new Function(this.field.options.onAppendButtonClick);
|
|
467
|
+
customFn.call(this);
|
|
468
|
+
} else {
|
|
469
|
+
this.dispatch("VFormRender", "appendButtonClick", [this]);
|
|
470
|
+
}
|
|
255
471
|
},
|
|
256
|
-
handleOnChange(
|
|
257
|
-
|
|
472
|
+
handleOnChange(val, oldVal, ops = []) {
|
|
473
|
+
if (!!this.designState) {
|
|
474
|
+
return;
|
|
475
|
+
}
|
|
476
|
+
if (!!this.field.options.onChange) {
|
|
477
|
+
const changeFn = new Function("value", "oldValue", "ops", this.field.options.onChange);
|
|
478
|
+
changeFn.call(this, val, oldVal, ops[0]);
|
|
479
|
+
}
|
|
258
480
|
},
|
|
259
|
-
handleOnChangeForSubForm(
|
|
260
|
-
this.designState
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
481
|
+
handleOnChangeForSubForm(val, oldVal, ops = [], subFormData, rowId) {
|
|
482
|
+
if (!!this.designState) {
|
|
483
|
+
return;
|
|
484
|
+
}
|
|
485
|
+
if (!!this.field.options.onChange) {
|
|
486
|
+
const changeFn = new Function(
|
|
487
|
+
"value",
|
|
488
|
+
"oldValue",
|
|
489
|
+
"ops",
|
|
490
|
+
"subFormData",
|
|
491
|
+
"rowId",
|
|
492
|
+
this.field.options.onChange
|
|
493
|
+
);
|
|
494
|
+
changeFn.call(this, val, oldVal, ops[0], subFormData, rowId);
|
|
495
|
+
}
|
|
268
496
|
},
|
|
269
497
|
onClick() {
|
|
270
|
-
if (
|
|
271
|
-
|
|
272
|
-
|
|
498
|
+
if (!!this.designState) {
|
|
499
|
+
return;
|
|
500
|
+
}
|
|
501
|
+
if (!!this.field.options.onClick) {
|
|
502
|
+
const customFn = new Function(this.field.options.onClick);
|
|
503
|
+
return customFn.call(this);
|
|
504
|
+
} else {
|
|
273
505
|
this.dispatch("VFormRender", "buttonClick", [this]);
|
|
274
506
|
}
|
|
275
507
|
},
|
|
276
508
|
handleButtonWidgetClick() {
|
|
277
|
-
if (
|
|
278
|
-
|
|
279
|
-
|
|
509
|
+
if (!!this.designState) {
|
|
510
|
+
return;
|
|
511
|
+
}
|
|
512
|
+
if (!!this.field.options.onClick) {
|
|
513
|
+
const customFn = new Function(this.field.options.onClick);
|
|
514
|
+
return customFn.call(this);
|
|
515
|
+
} else {
|
|
280
516
|
this.dispatch("VFormRender", "buttonClick", [this]);
|
|
281
517
|
}
|
|
282
518
|
},
|
|
@@ -284,7 +520,16 @@ const F = {
|
|
|
284
520
|
* 下拉框右边搜索按钮
|
|
285
521
|
*/
|
|
286
522
|
handleClickIcon() {
|
|
287
|
-
this.designState
|
|
523
|
+
if (!!this.designState) {
|
|
524
|
+
return;
|
|
525
|
+
}
|
|
526
|
+
if (this.handleDisabled()) {
|
|
527
|
+
return;
|
|
528
|
+
}
|
|
529
|
+
if (!!this.field.options.onClickIcon) {
|
|
530
|
+
const onClickIconFn = new Function(this.field.options.onClickIcon);
|
|
531
|
+
onClickIconFn.call(this);
|
|
532
|
+
}
|
|
288
533
|
},
|
|
289
534
|
// remoteQuery(keyword) {
|
|
290
535
|
// if (!!this.designState) {
|
|
@@ -300,86 +545,135 @@ const F = {
|
|
|
300
545
|
//--------------------- 以下为组件支持外部调用的API方法 begin ------------------//
|
|
301
546
|
/* 提示:用户可自行扩充这些方法!!! */
|
|
302
547
|
getFormRef() {
|
|
303
|
-
return this.refList
|
|
548
|
+
return this.refList["v_form_ref"];
|
|
304
549
|
},
|
|
305
|
-
getWidgetRef(
|
|
306
|
-
const
|
|
307
|
-
|
|
550
|
+
getWidgetRef(widgetName, showError) {
|
|
551
|
+
const foundRef = this.refList[widgetName];
|
|
552
|
+
if (!foundRef && !!showError) {
|
|
553
|
+
this.$message.error(this.i18nt("render.hint.refNotFound") + widgetName);
|
|
554
|
+
}
|
|
555
|
+
return foundRef;
|
|
308
556
|
},
|
|
309
557
|
getFieldEditor() {
|
|
310
|
-
return this.$refs
|
|
558
|
+
return this.$refs["fieldEditor"];
|
|
311
559
|
},
|
|
312
|
-
showFileList(
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
560
|
+
showFileList(list) {
|
|
561
|
+
if (!isArray(list)) return [];
|
|
562
|
+
const res = list.map((item, uid) => ({
|
|
563
|
+
...item,
|
|
564
|
+
name: item.fileName,
|
|
565
|
+
uid
|
|
566
|
+
}));
|
|
567
|
+
return res;
|
|
318
568
|
},
|
|
319
569
|
/*
|
|
320
570
|
注意:VFormRender的setFormData方法不会触发子表单内field-widget的setValue方法,
|
|
321
571
|
因为setFormData方法调用后,子表单内所有field-widget组件已被清空,接收不到setFormData事件!!
|
|
322
572
|
*/
|
|
323
|
-
setValue(
|
|
324
|
-
if (
|
|
325
|
-
|
|
326
|
-
|
|
573
|
+
setValue(newValue, disableChangeEvent = false) {
|
|
574
|
+
if (newValue) {
|
|
575
|
+
newValue = newValue.target ? newValue.target.value : newValue;
|
|
576
|
+
}
|
|
577
|
+
if (eq(this.fieldModel, newValue)) return;
|
|
578
|
+
if (!!this.field.formItemFlag) {
|
|
579
|
+
const oldValue = deepClone(this.fieldModel);
|
|
580
|
+
if (this.field.type === "file-upload") {
|
|
581
|
+
newValue = this.showFileList(newValue || []);
|
|
582
|
+
} else if (this.field.type === "code-editor") {
|
|
583
|
+
this.$refs.fieldEditor.setValue(newValue);
|
|
584
|
+
}
|
|
585
|
+
this.fieldModel = newValue;
|
|
586
|
+
this.initFileList();
|
|
587
|
+
this.syncUpdateFormModel(newValue);
|
|
588
|
+
if (!disableChangeEvent) {
|
|
589
|
+
this.emitFieldDataChange(newValue, oldValue);
|
|
590
|
+
}
|
|
327
591
|
}
|
|
328
592
|
},
|
|
329
593
|
getValue() {
|
|
330
|
-
|
|
594
|
+
{
|
|
595
|
+
return this.fieldModel;
|
|
596
|
+
}
|
|
331
597
|
},
|
|
332
598
|
resetField() {
|
|
333
|
-
const
|
|
334
|
-
this.setValue(
|
|
335
|
-
|
|
599
|
+
const defaultValue = this.field.options.defaultValue;
|
|
600
|
+
this.setValue(defaultValue);
|
|
601
|
+
this.$nextTick(() => {
|
|
602
|
+
});
|
|
603
|
+
if (this.field.type === "picture-upload" || this.field.type === "file-upload") {
|
|
604
|
+
this.fileList.splice(0, this.fileList.length);
|
|
605
|
+
this.handleChangeEvent(this.fileList);
|
|
606
|
+
}
|
|
336
607
|
},
|
|
337
|
-
setWidgetOption(
|
|
338
|
-
this.field.options.hasOwnProperty(
|
|
608
|
+
setWidgetOption(optionName, optionValue) {
|
|
609
|
+
if (this.field.options.hasOwnProperty(optionName)) {
|
|
610
|
+
this.field.options[optionName] = optionValue;
|
|
611
|
+
}
|
|
339
612
|
},
|
|
340
|
-
setReadonly(
|
|
341
|
-
this.field.options.readonly =
|
|
613
|
+
setReadonly(flag) {
|
|
614
|
+
this.field.options.readonly = flag;
|
|
342
615
|
},
|
|
343
|
-
setDisabled(
|
|
344
|
-
this.field.options.disabled =
|
|
616
|
+
setDisabled(flag) {
|
|
617
|
+
this.field.options.disabled = flag;
|
|
345
618
|
},
|
|
346
|
-
setAppendButtonVisible(
|
|
347
|
-
this.field.options.appendButton =
|
|
619
|
+
setAppendButtonVisible(flag) {
|
|
620
|
+
this.field.options.appendButton = flag;
|
|
348
621
|
},
|
|
349
|
-
setAppendButtonDisabled(
|
|
350
|
-
this.field.options.appendButtonDisabled =
|
|
622
|
+
setAppendButtonDisabled(flag) {
|
|
623
|
+
this.field.options.appendButtonDisabled = flag;
|
|
351
624
|
},
|
|
352
|
-
setHidden(
|
|
353
|
-
this.field.options.hidden =
|
|
625
|
+
setHidden(flag) {
|
|
626
|
+
this.field.options.hidden = flag;
|
|
627
|
+
if (!!flag) {
|
|
628
|
+
this.clearFieldRules();
|
|
629
|
+
} else {
|
|
630
|
+
this.buildFieldRules();
|
|
631
|
+
}
|
|
354
632
|
},
|
|
355
|
-
setRequired(
|
|
356
|
-
this.field.options.required =
|
|
633
|
+
setRequired(flag) {
|
|
634
|
+
this.field.options.required = flag;
|
|
635
|
+
this.buildFieldRules();
|
|
636
|
+
if (!this.designState && !flag) {
|
|
637
|
+
this.clearValidate();
|
|
638
|
+
}
|
|
357
639
|
},
|
|
358
640
|
/**
|
|
359
641
|
* 清除字段校验提示
|
|
360
642
|
*/
|
|
361
643
|
clearValidate() {
|
|
362
|
-
|
|
644
|
+
if (!!this.designState) {
|
|
645
|
+
return;
|
|
646
|
+
}
|
|
647
|
+
this.getFormRef().getNativeForm().clearValidate(this.getPropName());
|
|
363
648
|
},
|
|
364
649
|
getVfCtx() {
|
|
365
650
|
return this.getFormRef().vfCtx;
|
|
366
651
|
},
|
|
367
|
-
setLabel(
|
|
368
|
-
this.field.options.label =
|
|
652
|
+
setLabel(newLabel) {
|
|
653
|
+
this.field.options.label = newLabel;
|
|
369
654
|
},
|
|
370
655
|
focus() {
|
|
371
|
-
|
|
656
|
+
if (!!this.getFieldEditor() && !!this.getFieldEditor().focus) {
|
|
657
|
+
this.getFieldEditor().focus();
|
|
658
|
+
}
|
|
372
659
|
},
|
|
373
660
|
clearSelectedOptions() {
|
|
374
|
-
this.field.type !== "checkbox" && this.field.type !== "radio" && this.field.type !== "select"
|
|
661
|
+
if (this.field.type !== "checkbox" && this.field.type !== "radio" && this.field.type !== "select") {
|
|
662
|
+
return;
|
|
663
|
+
}
|
|
664
|
+
if (this.field.type === "checkbox" || this.field.type === "select" && this.field.options.multiple) {
|
|
665
|
+
this.fieldModel = [];
|
|
666
|
+
} else {
|
|
667
|
+
this.fieldModel = "";
|
|
668
|
+
}
|
|
375
669
|
},
|
|
376
670
|
/**
|
|
377
671
|
* 加载选项,并清空字段值
|
|
378
672
|
* @param options
|
|
379
673
|
*/
|
|
380
|
-
loadOptions(
|
|
381
|
-
this.field.options.optionItems =
|
|
382
|
-
|
|
674
|
+
loadOptions(options) {
|
|
675
|
+
this.field.options.optionItems = translateOptionItems(
|
|
676
|
+
options,
|
|
383
677
|
this.field.type,
|
|
384
678
|
this.field.options.labelKey || "label",
|
|
385
679
|
this.field.options.valueKey || "value"
|
|
@@ -389,19 +683,19 @@ const F = {
|
|
|
389
683
|
* 重新加载选项,不清空字段值
|
|
390
684
|
* @param options
|
|
391
685
|
*/
|
|
392
|
-
reloadOptions(
|
|
393
|
-
this.field.options.optionItems =
|
|
394
|
-
|
|
686
|
+
reloadOptions(options) {
|
|
687
|
+
this.field.options.optionItems = translateOptionItems(
|
|
688
|
+
options,
|
|
395
689
|
this.field.type,
|
|
396
690
|
this.field.options.labelKey || "label",
|
|
397
691
|
this.field.options.valueKey || "value"
|
|
398
692
|
);
|
|
399
693
|
},
|
|
400
|
-
disableOption(
|
|
401
|
-
this.disableOptionOfList(this.field.options.optionItems,
|
|
694
|
+
disableOption(optionValue) {
|
|
695
|
+
this.disableOptionOfList(this.field.options.optionItems, optionValue);
|
|
402
696
|
},
|
|
403
|
-
enableOption(
|
|
404
|
-
this.enableOptionOfList(this.field.options.optionItems,
|
|
697
|
+
enableOption(optionValue) {
|
|
698
|
+
this.enableOptionOfList(this.field.options.optionItems, optionValue);
|
|
405
699
|
},
|
|
406
700
|
/**
|
|
407
701
|
* 返回选择项
|
|
@@ -410,14 +704,14 @@ const F = {
|
|
|
410
704
|
getOptionItems() {
|
|
411
705
|
return this.field.options.optionItems;
|
|
412
706
|
},
|
|
413
|
-
setUploadHeader(
|
|
414
|
-
this.uploadHeaders[
|
|
707
|
+
setUploadHeader(name, value) {
|
|
708
|
+
this.uploadHeaders[name] = value;
|
|
415
709
|
},
|
|
416
|
-
setUploadData(
|
|
417
|
-
this.uploadData[
|
|
710
|
+
setUploadData(name, value) {
|
|
711
|
+
this.uploadData[name] = value;
|
|
418
712
|
},
|
|
419
|
-
setToolbar(
|
|
420
|
-
this.customToolbar =
|
|
713
|
+
setToolbar(customToolbar) {
|
|
714
|
+
this.customToolbar = customToolbar;
|
|
421
715
|
},
|
|
422
716
|
/**
|
|
423
717
|
* 是否子表单内嵌的字段组件
|
|
@@ -437,31 +731,41 @@ const F = {
|
|
|
437
731
|
* 设置或取消设置字段只读查看模式
|
|
438
732
|
* @param readonlyFlag
|
|
439
733
|
*/
|
|
440
|
-
setReadMode(
|
|
441
|
-
this.fieldReadonlyFlag =
|
|
734
|
+
setReadMode(readonlyFlag = true) {
|
|
735
|
+
this.fieldReadonlyFlag = readonlyFlag;
|
|
442
736
|
},
|
|
443
737
|
/**
|
|
444
738
|
* 动态增加自定义css样式
|
|
445
739
|
* @param className
|
|
446
740
|
*/
|
|
447
|
-
addCssClass(
|
|
448
|
-
|
|
741
|
+
addCssClass(className) {
|
|
742
|
+
if (!this.field.options.customClass) {
|
|
743
|
+
this.field.options.customClass = [className];
|
|
744
|
+
} else {
|
|
745
|
+
this.field.options.customClass.push(className);
|
|
746
|
+
}
|
|
449
747
|
},
|
|
450
748
|
/**
|
|
451
749
|
* 动态移除自定义css样式
|
|
452
750
|
* @param className
|
|
453
751
|
*/
|
|
454
|
-
removeCssClass(
|
|
455
|
-
if (!this.field.options.customClass)
|
|
752
|
+
removeCssClass(className) {
|
|
753
|
+
if (!this.field.options.customClass) {
|
|
456
754
|
return;
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
755
|
+
}
|
|
756
|
+
let foundIdx = -1;
|
|
757
|
+
this.field.options.customClass.map((cc, idx) => {
|
|
758
|
+
if (cc === className) {
|
|
759
|
+
foundIdx = idx;
|
|
760
|
+
}
|
|
761
|
+
});
|
|
762
|
+
if (foundIdx > -1) {
|
|
763
|
+
this.field.options.customClass.splice(foundIdx, 1);
|
|
764
|
+
}
|
|
461
765
|
}
|
|
462
766
|
//--------------------- 以上为组件支持外部调用的API方法 end ------------------//
|
|
463
767
|
}
|
|
464
768
|
};
|
|
465
769
|
export {
|
|
466
|
-
|
|
770
|
+
fieldMixin as default
|
|
467
771
|
};
|