@oinone/kunlun-vue-admin-base 6.3.8 → 6.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/oinone-kunlun-vue-admin-base.css +1 -1
- package/dist/oinone-kunlun-vue-admin-base.esm.js +51429 -38937
- package/dist/oinone-kunlun-vue-admin-base.scss +1 -1
- package/dist/types/src/action/client-actions/SaveDraftActionWidget.d.ts +75 -0
- package/dist/types/src/action/client-actions/TableAddOneAction.d.ts +2 -2
- package/dist/types/src/action/client-actions/TableCopyOneAction.d.ts +2 -2
- package/dist/types/src/action/client-actions/TableEditOneAction.d.ts +2 -0
- package/dist/types/src/action/client-actions/index.d.ts +1 -0
- package/dist/types/src/action/component/action/ActionWidget.d.ts +31 -4
- package/dist/types/src/action/component/action/DefaultAction.vue.d.ts +9 -0
- package/dist/types/src/action/component/action/typing.d.ts +8 -0
- package/dist/types/src/action/component/action-bar/ActionBarWidget.d.ts +15 -3
- package/dist/types/src/action/component/action-bar/DefaultActionBar.vue.d.ts +12 -0
- package/dist/types/src/action/component/action-bar/DefaultMoreActionItem.vue.d.ts +54 -0
- package/dist/types/src/action/component/action-bar/RowActionBarWidget.d.ts +4 -0
- package/dist/types/src/action/component/index.d.ts +1 -0
- package/dist/types/src/action/component/typing/action-bar.d.ts +10 -0
- package/dist/types/src/action/component/typing/index.d.ts +1 -0
- package/dist/types/src/action/composition-actions/CompositionAction.vue.d.ts +9 -0
- package/dist/types/src/action/server-actions/ServerActionWidget.d.ts +3 -0
- package/dist/types/src/action/view-actions/ExportActionWidget/ExportActionWidget.vue.d.ts +9 -0
- package/dist/types/src/action/view-actions/ImportActionWidget/ImportActionWidget.vue.d.ts +9 -0
- package/dist/types/src/action/view-actions/biz-audit/BizAuditRecordDetail.vue.d.ts +3 -7
- package/dist/types/src/action/view-actions/biz-audit/BizAuditRecordDetailList.vue.d.ts +8 -1
- package/dist/types/src/action/view-actions/biz-audit/BizAuditRecordDetailListWidget.d.ts +1 -0
- package/dist/types/src/action/view-actions/biz-audit/BizAuditRecordViewAction.d.ts +1 -0
- package/dist/types/src/basic/BaseSearchWidget.d.ts +3 -0
- package/dist/types/src/basic/common/BaseDataWidget.d.ts +1 -1
- package/dist/types/src/basic/common/BaseRuntimePropertiesWidget.d.ts +3 -1
- package/dist/types/src/basic/constant/call-chaining.d.ts +10 -2
- package/dist/types/src/basic/element/BaseElementListViewWidget.d.ts +33 -8
- package/dist/types/src/basic/element/BaseElementObjectViewWidget.d.ts +17 -1
- package/dist/types/src/basic/field/FormFieldWidget.d.ts +8 -1
- package/dist/types/src/basic/field/complex/select/BaseSelectFieldWidget.d.ts +36 -1
- package/dist/types/src/basic/field/complex/select/FormSelectComplexFieldWidget.d.ts +11 -8
- package/dist/types/src/basic/field/complex/select/SelectFieldWidget.d.ts +23 -0
- package/dist/types/src/basic/field/complex/select/SelectModalFieldWidget.d.ts +22 -0
- package/dist/types/src/basic/field/complex/select/SelectTableFieldWidget.d.ts +21 -0
- package/dist/types/src/basic/field/complex/select/index.d.ts +3 -0
- package/dist/types/src/basic/field/complex/subview/FormSubviewListFieldWidget.d.ts +1 -1
- package/dist/types/src/basic/field/complex/table/TableComplexFieldWidget.d.ts +1 -0
- package/dist/types/src/basic/form/BaseFormWidget.d.ts +2 -0
- package/dist/types/src/basic/form/DefaultForm.vue.d.ts +7 -0
- package/dist/types/src/basic/form/index.d.ts +0 -1
- package/dist/types/src/basic/form-item/BaseFormItemWidget.d.ts +3 -0
- package/dist/types/src/basic/form-item/DefaultFormItem.vue.d.ts +7 -0
- package/dist/types/src/basic/gallery-item/DefaultGalleryItem.vue.d.ts +6 -0
- package/dist/types/src/basic/gallery-item/props.d.ts +5 -0
- package/dist/types/src/basic/table/BaseTableWidget.d.ts +130 -27
- package/dist/types/src/basic/table-column/BaseTableColumnWidget.d.ts +42 -6
- package/dist/types/src/basic/table-column/BaseTableFieldWidget.d.ts +26 -3
- package/dist/types/src/basic/table-column/DefaultGroupCell.vue.d.ts +58 -0
- package/dist/types/src/basic/table-column/DefaultQuickOperationColumn.vue.d.ts +25 -0
- package/dist/types/src/basic/table-column/DefaultTableColumn.vue.d.ts +43 -11
- package/dist/types/src/basic/token/BaseActionWidget.d.ts +7 -2
- package/dist/types/src/basic/token/BaseFieldWidget.d.ts +7 -0
- package/dist/types/src/basic/token/BaseView.d.ts +6 -1
- package/dist/types/src/basic/types/typing.d.ts +8 -0
- package/dist/types/src/components/index.d.ts +8 -0
- package/dist/types/src/components/oio-full-screen/OioFullScreen.vue.d.ts +21 -0
- package/dist/types/src/components/oio-full-screen/index.d.ts +1 -0
- package/dist/types/src/components/oio-manage-group/index.d.ts +1 -1
- package/dist/types/src/components/oio-simple-pagination/OioSimplePagination.vue.d.ts +39 -0
- package/dist/types/src/components/oio-simple-pagination/index.d.ts +1 -0
- package/dist/types/src/components/quick-utils/CheckedHelper.d.ts +5 -0
- package/dist/types/src/components/quick-utils/index.d.ts +5 -0
- package/dist/types/src/components/quick-utils/useListChecked.d.ts +25 -0
- package/dist/types/src/components/quick-utils/useListState.d.ts +45 -0
- package/dist/types/src/components/quick-utils/useTreeChecked.d.ts +26 -0
- package/dist/types/src/components/quick-utils/useTreeState.d.ts +52 -0
- package/dist/types/src/components/select/base/BaseSelect.vue.d.ts +223 -0
- package/dist/types/src/components/select/base/DefaultSelect.vue.d.ts +203 -0
- package/dist/types/src/components/select/base/index.d.ts +4 -0
- package/dist/types/src/components/select/base/props.d.ts +174 -0
- package/dist/types/src/components/select/base/typing.d.ts +6 -0
- package/dist/types/src/components/select/company-select/CompanySelect.vue.d.ts +202 -0
- package/dist/types/src/components/select/company-select/index.d.ts +2 -0
- package/dist/types/src/components/select/company-select/render/index.d.ts +1 -0
- package/dist/types/src/components/select/company-select/render/logo.d.ts +4 -0
- package/dist/types/src/components/select/company-select/render/optionRender.d.ts +15 -0
- package/dist/types/src/components/select/company-select/render/style1.d.ts +4 -0
- package/dist/types/src/components/select/company-select/render/style2.d.ts +4 -0
- package/dist/types/src/components/select/department-select/DepartmentModal.vue.d.ts +333 -0
- package/dist/types/src/components/select/department-select/DepartmentSelect.vue.d.ts +232 -0
- package/dist/types/src/components/select/department-select/DepartmentTree.vue.d.ts +103 -0
- package/dist/types/src/components/select/department-select/constant.d.ts +4 -0
- package/dist/types/src/components/select/department-select/index.d.ts +3 -0
- package/dist/types/src/components/select/department-select/init.d.ts +25 -0
- package/dist/types/src/components/select/employee-select/DepartmentEmployeeSelectPanel.vue.d.ts +114 -0
- package/dist/types/src/components/select/employee-select/EmployeeList.vue.d.ts +85 -0
- package/dist/types/src/components/select/employee-select/EmployeeModal.vue.d.ts +345 -0
- package/dist/types/src/components/select/employee-select/EmployeeSelect.vue.d.ts +238 -0
- package/dist/types/src/components/select/employee-select/RoleEmployeeSelectPanel.vue.d.ts +78 -0
- package/dist/types/src/components/select/employee-select/index.d.ts +3 -0
- package/dist/types/src/components/select/employee-select/init.d.ts +24 -0
- package/dist/types/src/components/select/index.d.ts +6 -0
- package/dist/types/src/components/select/organizational-structure-tree/OrganizationalStructureTree.vue.d.ts +119 -0
- package/dist/types/src/components/select/organizational-structure-tree/index.d.ts +1 -0
- package/dist/types/src/components/select/organizational-structure-tree/init.d.ts +25 -0
- package/dist/types/src/components/select/role-select/RoleList.vue.d.ts +99 -0
- package/dist/types/src/components/select/role-select/RoleModal.vue.d.ts +314 -0
- package/dist/types/src/components/select/role-select/RoleSelect.vue.d.ts +214 -0
- package/dist/types/src/components/select/role-select/index.d.ts +3 -0
- package/dist/types/src/components/select/role-select/init.d.ts +23 -0
- package/dist/types/src/components/select-modal/SelectModal.vue.d.ts +322 -0
- package/dist/types/src/components/select-modal/index.d.ts +1 -0
- package/dist/types/src/{field/form/m2m/select/SelectWidget.vue.d.ts → components/select-table/SelectTable.vue.d.ts} +84 -3
- package/dist/types/src/components/select-table/index.d.ts +1 -0
- package/dist/types/src/components/sortable-group/SortableGroup.vue.d.ts +77 -0
- package/dist/types/src/components/sortable-group/index.d.ts +2 -0
- package/dist/types/src/components/sortable-group/typing.d.ts +5 -0
- package/dist/types/src/components/table-line-height/TableLineHeight.vue.d.ts +26 -0
- package/dist/types/src/components/table-line-height/index.d.ts +1 -0
- package/dist/types/src/components/user-prefer/DefaultUserPrefer.vue.d.ts +6 -0
- package/dist/types/src/components/user-prefer/StandardUserPreferSetting.vue.d.ts +9 -0
- package/dist/types/src/container/block/DefaultBlock.vue.d.ts +0 -7
- package/dist/types/src/container/block/DefaultCol.vue.d.ts +0 -7
- package/dist/types/src/container/block/DefaultContainer.vue.d.ts +0 -7
- package/dist/types/src/container/block/DefaultContainerWidget.d.ts +2 -1
- package/dist/types/src/container/block/DefaultContainers.vue.d.ts +0 -7
- package/dist/types/src/container/block/DefaultRow.vue.d.ts +0 -7
- package/dist/types/src/container/collapse/DefaultCollapse.vue.d.ts +0 -7
- package/dist/types/src/container/group/DefaultGroup.vue.d.ts +31 -0
- package/dist/types/src/container/group/DefaultGroupWidget.d.ts +10 -4
- package/dist/types/src/container/media/icon/DefaultIcon.vue.d.ts +3 -1
- package/dist/types/src/container/media/paragraph/DefaultParagraph.vue.d.ts +5 -3
- package/dist/types/src/container/media/picture/DefaultPicture.vue.d.ts +3 -1
- package/dist/types/src/container/tabs/DefaultTabs.vue.d.ts +7 -1
- package/dist/types/src/container/tabs/DefaultTabsWidget.d.ts +1 -0
- package/dist/types/src/field/cascader/FormCascaderFieldWidget.d.ts +2 -1
- package/dist/types/src/field/detail/map/DefaultReadonlyMap.vue.d.ts +18 -0
- package/dist/types/src/field/detail/map/DetailMapFieldWidget.d.ts +1 -0
- package/dist/types/src/field/form/{o2m/select/SelectWidget.vue.d.ts → abstract/select/DefaultMultipleSelect.vue.d.ts} +47 -10
- package/dist/types/src/field/form/{m2o/select/SelectWidget.vue.d.ts → abstract/select/DefaultSingleSelect.vue.d.ts} +52 -14
- package/dist/types/src/field/form/date/FormDateTimeFieldWidget.d.ts +0 -1
- package/dist/types/src/field/form/enum/radio/FormEnumRadioWidget.d.ts +1 -1
- package/dist/types/src/field/form/enum/select/multi/MultiEnumSelect.vue.d.ts +16 -2
- package/dist/types/src/field/form/enum/select/single/EnumSelect.vue.d.ts +11 -1
- package/dist/types/src/field/form/enum/thumbnail/FormEnumThumbnailFieldWidget.d.ts +1 -1
- package/dist/types/src/field/form/float/Plat.vue.d.ts +4 -4
- package/dist/types/src/field/form/index.d.ts +0 -1
- package/dist/types/src/field/form/m2m/company/FormM2MCompanyFieldWidget.d.ts +8 -3
- package/dist/types/src/field/form/m2m/department/FormM2MDepartmentFieldWidget.d.ts +12 -3
- package/dist/types/src/field/form/m2m/employee/FormM2MEmployeeFieldWidget.d.ts +14 -3
- package/dist/types/src/field/form/m2m/index.d.ts +2 -1
- package/dist/types/src/field/form/m2m/role/FormM2MRoleFieldWidget.d.ts +11 -0
- package/dist/types/src/field/form/m2m/select/{FormM2MFieldSelectWidget.d.ts → FormM2MSelectFieldWidget.d.ts} +2 -2
- package/dist/types/src/field/form/m2m/select/FormM2MSelectModalFieldWidget.d.ts +9 -0
- package/dist/types/src/field/form/m2m/select/FormM2MSelectTableFieldWidget.d.ts +8 -0
- package/dist/types/src/field/form/m2m/select/index.d.ts +3 -0
- package/dist/types/src/field/form/m2o/address/FormM2OAddressFieldWidget.d.ts +3 -3
- package/dist/types/src/field/form/m2o/company/FormM2OCompanyFieldWidget.d.ts +6 -3
- package/dist/types/src/field/form/m2o/department/FormM2ODepartmentFieldWidget.d.ts +10 -3
- package/dist/types/src/field/form/m2o/employee/FormM2OEmployeeFieldWidget.d.ts +12 -3
- package/dist/types/src/field/form/m2o/index.d.ts +2 -2
- package/dist/types/src/field/form/m2o/role/FormM2ORoleFieldWidget.d.ts +9 -0
- package/dist/types/src/field/form/m2o/select/FormM2OSelectFieldWidget.d.ts +3 -7
- package/dist/types/src/field/form/m2o/select/FormM2OSelectModalFieldWidget.d.ts +7 -0
- package/dist/types/src/field/form/m2o/select/FormM2OSelectTableFieldWidget.d.ts +7 -0
- package/dist/types/src/field/form/m2o/select/index.d.ts +4 -0
- package/dist/types/src/field/form/o2m/cascader/index.d.ts +1 -0
- package/dist/types/src/field/form/o2m/index.d.ts +2 -2
- package/dist/types/src/field/form/o2m/select/FormO2MSelectFieldWidget.d.ts +1 -5
- package/dist/types/src/field/form/o2m/select/FormO2MSelectModalFieldWidget.d.ts +7 -0
- package/dist/types/src/field/form/o2m/select/FormO2MSelectTableFieldWidget.d.ts +6 -0
- package/dist/types/src/field/form/o2m/select/index.d.ts +3 -0
- package/dist/types/src/field/form/o2m/table/FormO2MTableFieldWidget.d.ts +8 -0
- package/dist/types/src/field/form/o2o/index.d.ts +1 -1
- package/dist/types/src/field/form/o2o/select/FormO2OSelectModalFieldWidget.d.ts +4 -0
- package/dist/types/src/field/form/o2o/select/FormO2OSelectTableFieldWidget.d.ts +4 -0
- package/dist/types/src/field/form/o2o/select/index.d.ts +3 -0
- package/dist/types/src/field/form/string/input/FormStringInputFieldWidget.d.ts +1 -1
- package/dist/types/src/field/form/string/tag/FormStringMultiTagFieldWidget.d.ts +1 -0
- package/dist/types/src/field/form/string/tag/Tag.vue.d.ts +14 -2
- package/dist/types/src/field/gallery/date/range/ReadonlyDateTimeRangePicker.vue.d.ts +6 -0
- package/dist/types/src/field/gallery/string/tag/GalleryStringTagFieldWidget.d.ts +5 -0
- package/dist/types/src/field/gallery/string/tag/GalleryTag.vue.d.ts +8 -1
- package/dist/types/src/field/prop/RelationSelectProps.d.ts +20 -1
- package/dist/types/src/field/range/SearchRangeFieldWidget.d.ts +0 -1
- package/dist/types/src/field/resource/language-badge/FormResourceLangBadge.vue.d.ts +26 -0
- package/dist/types/src/field/search/m2o/SearchM2OMultiSelectFieldWidget.d.ts +2 -2
- package/dist/types/src/field/table/boolean/TableBooleanSwitchFieldWidget.d.ts +4 -0
- package/dist/types/src/field/table/date/range/TableDateTimeRangeFieldWidget.d.ts +6 -0
- package/dist/types/src/field/table/enum/checkbox/TableEditorCheckboxFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/enum/checkbox/index.d.ts +1 -0
- package/dist/types/src/field/table/enum/index.d.ts +4 -0
- package/dist/types/src/field/table/enum/radio/TableEditorRadioFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/enum/radio/index.d.ts +1 -0
- package/dist/types/src/field/table/enum/select/TableEditorEnumFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/enum/select/TableEditorMultiEnumFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/enum/select/index.d.ts +2 -0
- package/dist/types/src/field/table/enum/thumbnail/TableEditorEnumThumbnailFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/enum/thumbnail/index.d.ts +1 -0
- package/dist/types/src/field/table/html/TableEditorHtmlFieldWidget.d.ts +4 -0
- package/dist/types/src/field/table/html/TableHtmlFieldWidget.d.ts +18 -0
- package/dist/types/src/field/table/html/index.d.ts +2 -1
- package/dist/types/src/field/table/index.d.ts +2 -1
- package/dist/types/src/field/table/m2m/company/TableEditorM2MCompanyFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/m2m/company/index.d.ts +1 -0
- package/dist/types/src/field/table/m2m/department/TableEditorM2MDepartmentFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2m/department/index.d.ts +1 -0
- package/dist/types/src/field/table/m2m/employee/TableEditorM2MEmployeeFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2m/employee/index.d.ts +1 -0
- package/dist/types/src/field/table/m2m/index.d.ts +8 -1
- package/dist/types/src/field/table/m2m/role/TableEditorM2MRoleFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2m/role/index.d.ts +1 -0
- package/dist/types/src/field/table/m2m/select/TableEditorM2MFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/m2m/select/index.d.ts +2 -0
- package/dist/types/src/field/table/m2m/select-modal/TableEditorM2MSelectModalFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2m/select-modal/index.d.ts +1 -0
- package/dist/types/src/field/table/m2m/select-table/TableEditorM2MSelectTableFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2m/select-table/index.d.ts +1 -0
- package/dist/types/src/field/table/m2m/upload/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/address/TableM2OAddressFieldWidget.d.ts +2 -2
- package/dist/types/src/field/table/m2o/address/index.d.ts +2 -0
- package/dist/types/src/field/table/m2o/company/TableEditorM2OCompanyFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/m2o/company/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/department/TableEditorM2ODepartmentFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2o/department/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/download/TableM2ODownloadWidget.d.ts +2 -2
- package/dist/types/src/field/table/m2o/download/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/employee/TableEditorM2OEmployeeFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2o/employee/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/index.d.ts +10 -4
- package/dist/types/src/field/table/m2o/role/TableEditorM2ORoleFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2o/role/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/select/TableEditorM2OFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/m2o/select/index.d.ts +2 -0
- package/dist/types/src/field/table/m2o/select-modal/TableEditorM2OSelectModalFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2o/select-modal/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/select-table/TableEditorM2OSelectTableFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/m2o/select-table/index.d.ts +1 -0
- package/dist/types/src/field/table/m2o/upload/index.d.ts +1 -0
- package/dist/types/src/field/table/number/TableEditorMultiNumberFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/number/index.d.ts +1 -0
- package/dist/types/src/field/table/o2m/index.d.ts +3 -0
- package/dist/types/src/field/table/o2m/select/TableEditorO2MFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/o2m/select/index.d.ts +2 -0
- package/dist/types/src/field/table/o2m/select-modal/TableEditorO2MSelectModalFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/o2m/select-modal/index.d.ts +1 -0
- package/dist/types/src/field/table/o2m/select-table/TableEditorO2MSelectTableFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/o2m/select-table/index.d.ts +1 -0
- package/dist/types/src/field/table/o2o/index.d.ts +3 -0
- package/dist/types/src/field/table/o2o/select/TableEditorO2OFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/o2o/select/index.d.ts +2 -0
- package/dist/types/src/field/table/o2o/select-modal/TableEditorO2OSelectModalFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/o2o/select-modal/index.d.ts +1 -0
- package/dist/types/src/field/table/o2o/select-table/TableEditorO2OSelectTableFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table/o2o/select-table/index.d.ts +1 -0
- package/dist/types/src/field/table/string/tag/TableEditorStringTagFieldWidget.d.ts +5 -0
- package/dist/types/src/field/table/string/tag/index.d.ts +1 -0
- package/dist/types/src/field/table/text/TableTextFieldWidget.d.ts +3 -0
- package/dist/types/src/field/table-operation-column/TableOperationColumn.vue.d.ts +9 -0
- package/dist/types/src/field/transfer/FormTransferFieldWidget.d.ts +2 -2
- package/dist/types/src/field/tree/FormTreeFieldWidget.d.ts +1 -1
- package/dist/types/src/field/tree-select/AbstractTreeFieldWidget.d.ts +2 -2
- package/dist/types/src/field/tree-select/FormTreeSelectFieldWidget.d.ts +2 -1
- package/dist/types/src/icon-manage/view/search/IconSearchWidget.d.ts +1 -0
- package/dist/types/src/index.d.ts +1 -1
- package/dist/types/src/permission/permission/field/ActionPermissionWidget.d.ts +1 -1
- package/dist/types/src/permission/role-permission/resource-permission/FormManagementPermissionFieldWidget.d.ts +1 -1
- package/dist/types/src/permission/role-permission/resource-permission/FormResourcePermissionFieldWidget.d.ts +1 -1
- package/dist/types/src/permission/types.d.ts +2 -0
- package/dist/types/src/service/tree/tree-service.d.ts +1 -1
- package/dist/types/src/tags/context/index.d.ts +0 -1
- package/dist/types/src/tags/resolve/helper.d.ts +0 -16
- package/dist/types/src/typing/action.d.ts +0 -5
- package/dist/types/src/typing/card-cascader.d.ts +1 -1
- package/dist/types/src/typing/control-icon.d.ts +7 -0
- package/dist/types/src/typing/event/index.d.ts +1 -0
- package/dist/types/src/typing/event/table.d.ts +38 -0
- package/dist/types/src/typing/index.d.ts +3 -0
- package/dist/types/src/typing/view.d.ts +12 -0
- package/dist/types/src/util/default-tree-definition.d.ts +15 -1
- package/dist/types/src/util/tree-utils.d.ts +1 -1
- package/dist/types/src/view/application-screen/gallery/field/select/AppsModuleUpstreamSelectWidget.d.ts +2 -2
- package/dist/types/src/view/card/CardWidget.d.ts +12 -0
- package/dist/types/src/view/card/DefaultCard.vue.d.ts +32 -0
- package/dist/types/src/view/card/DefaultCardContent.vue.d.ts +8 -0
- package/dist/types/src/view/card/DefaultCardTitle.vue.d.ts +8 -0
- package/dist/types/src/view/card-cascader/AbstractCardCascaderElementWidget.d.ts +1 -2
- package/dist/types/src/view/card-cascader/CardCascaderWidget.d.ts +1 -1
- package/dist/types/src/view/card-cascader/DefaultCardCascader.vue.d.ts +1 -1
- package/dist/types/src/view/card-cascader/TableSearchCardCascaderWidget.d.ts +1 -1
- package/dist/types/src/view/detail/DetailWidget.d.ts +2 -0
- package/dist/types/src/view/gallery/DefaultGallery.vue.d.ts +7 -0
- package/dist/types/src/view/gallery/GalleryWidget.d.ts +18 -0
- package/dist/types/src/view/homepage-setting/components/MultiSelect.vue.d.ts +26 -0
- package/dist/types/src/view/homepage-setting/components/SingleSelect.vue.d.ts +26 -0
- package/dist/types/src/view/index.d.ts +2 -0
- package/dist/types/src/view/popup/PopupWidget.d.ts +33 -3
- package/dist/types/src/view/popup/dialog/DefaultDialog.vue.d.ts +65 -1
- package/dist/types/src/view/popup/dialog/DialogWidget.d.ts +3 -1
- package/dist/types/src/view/popup/dialog/StaticDialogWidget.d.ts +1 -1
- package/dist/types/src/view/popup/drawer/DefaultDrawer.vue.d.ts +66 -2
- package/dist/types/src/view/popup/drawer/DrawerWidget.d.ts +3 -1
- package/dist/types/src/view/popup/drawer/StaticDrawerWidget.d.ts +1 -1
- package/dist/types/src/view/popup/inner/DefaultInnerPopup.vue.d.ts +2 -2
- package/dist/types/src/view/popup/inner/InnerPopupWidget.d.ts +0 -1
- package/dist/types/src/view/quick-fill/Excel.vue.d.ts +30 -0
- package/dist/types/src/view/quick-fill/QuickFill.vue.d.ts +108 -0
- package/dist/types/src/view/quick-fill/QuickFillWidget.d.ts +87 -0
- package/dist/types/src/view/quick-fill/index.d.ts +1 -0
- package/dist/types/src/view/quick-fill/type.d.ts +12 -0
- package/dist/types/src/view/search/DefaultSearch.vue.d.ts +0 -5
- package/dist/types/src/view/search/SearchWidget.d.ts +1 -0
- package/dist/types/src/view/table/DefaultTable.vue.d.ts +139 -10
- package/dist/types/src/view/table/DefaultTableFooterOperator.vue.d.ts +31 -0
- package/dist/types/src/view/table/DefaultTableGroupCollapse.vue.d.ts +41 -0
- package/dist/types/src/view/table/TableUserPrefer.vue.d.ts +6 -0
- package/dist/types/src/view/table/TableUserPreferWidget.d.ts +1 -0
- package/dist/types/src/view/table/TableWidget.d.ts +119 -8
- package/dist/types/src/view/table/index.d.ts +0 -2
- package/dist/types/src/view/tree/AbstractTreeElementWidget.d.ts +1 -2
- package/dist/types/src/view/tree/TableSearchTreeWidget.d.ts +1 -2
- package/dist/types/src/view/tree/TreeWidget.d.ts +3 -1
- package/dist/types/src/view/tree/props.d.ts +1 -1
- package/dist/types/src/view/view/DefaultView.vue.d.ts +10 -8
- package/dist/types/src/view/view/DetailView.d.ts +1 -0
- package/dist/types/src/view/view/FormView.d.ts +1 -0
- package/dist/types/src/view/view/SearchView.d.ts +1 -0
- package/dist/types/src/view/view/TableView.d.ts +3 -3
- package/dist/types/src/view/view-control/DefaultViewControl.vue.d.ts +24 -0
- package/dist/types/src/view/view-control/ViewControlWidget.d.ts +11 -0
- package/dist/types/src/view/view-control/card-col-control/CardColControlWidget.d.ts +14 -0
- package/dist/types/src/view/view-control/card-col-control/DefaultCardColControl.vue.d.ts +28 -0
- package/dist/types/src/view/view-control/full-screen-control/DefaultFullScreenControl.vue.d.ts +5 -0
- package/dist/types/src/view/view-control/full-screen-control/FullScreenControlWidget.d.ts +4 -0
- package/dist/types/src/view/view-control/group-control/DefaultGroupControl.vue.d.ts +45 -0
- package/dist/types/src/view/view-control/group-control/GroupControlWidget.d.ts +26 -0
- package/dist/types/src/view/view-control/index.d.ts +7 -0
- package/dist/types/src/view/view-control/keyboard-shortcut/DefaultKeyboardShortcut.vue.d.ts +30 -0
- package/dist/types/src/view/view-control/keyboard-shortcut/KeyboardShortcutWidget.d.ts +10 -0
- package/dist/types/src/view/view-control/line-height-control/DefaultLineHeightControl.vue.d.ts +18 -0
- package/dist/types/src/view/view-control/line-height-control/LineHeightControlWidget.d.ts +15 -0
- package/dist/types/src/view/view-control/sort-control/DefaultSortControl.vue.d.ts +45 -0
- package/dist/types/src/view/view-control/sort-control/SortControlWidget.d.ts +27 -0
- package/package.json +22 -22
- package/src/action/client-actions/SaveDraftActionWidget.ts +486 -0
- package/src/action/client-actions/TableAddOneAction.ts +10 -15
- package/src/action/client-actions/TableCopyOneAction.ts +13 -27
- package/src/action/client-actions/TableEditOneAction.ts +23 -2
- package/src/action/client-actions/index.ts +1 -0
- package/src/action/component/action/ActionWidget.ts +84 -35
- package/src/action/component/action/DefaultAction.vue +5 -4
- package/src/action/component/action/typing.ts +4 -0
- package/src/action/component/action-bar/ActionBarWidget.ts +130 -3
- package/src/action/component/action-bar/DefaultActionBar.vue +74 -25
- package/src/action/component/action-bar/DefaultMoreActionItem.vue +172 -0
- package/src/action/component/action-bar/RowActionBarWidget.ts +30 -1
- package/src/action/component/action-bar/style/index.scss +7 -48
- package/src/action/component/dropdown/DefaultDropdown.vue +2 -98
- package/src/action/component/dropdown/style/index.scss +99 -0
- package/src/action/component/index.ts +1 -0
- package/src/action/component/typing/action-bar.ts +10 -0
- package/src/action/component/typing/index.ts +1 -0
- package/src/action/index.scss +1 -0
- package/src/action/server-actions/ServerActionWidget.ts +6 -13
- package/src/action/view-actions/biz-audit/BizAuditRecordDetail.vue +18 -19
- package/src/action/view-actions/biz-audit/BizAuditRecordDetailList.vue +69 -30
- package/src/action/view-actions/biz-audit/BizAuditRecordDetailListWidget.ts +5 -0
- package/src/action/view-actions/biz-audit/BizAuditRecordViewAction.ts +7 -0
- package/src/basic/BaseSearchWidget.ts +9 -1
- package/src/basic/common/BaseDataWidget.ts +1 -1
- package/src/basic/common/BaseRuntimePropertiesWidget.ts +31 -2
- package/src/basic/constant/call-chaining.ts +12 -2
- package/src/basic/element/BaseElementListViewWidget.ts +135 -67
- package/src/basic/element/BaseElementObjectViewWidget.ts +33 -13
- package/src/basic/element/utils.ts +1 -1
- package/src/basic/field/FormFieldWidget.ts +13 -3
- package/src/basic/field/complex/select/BaseSelectFieldWidget.ts +253 -24
- package/src/basic/field/complex/select/FormSelectComplexFieldWidget.ts +104 -38
- package/src/basic/field/complex/select/SelectFieldWidget.ts +189 -0
- package/src/basic/field/complex/select/SelectModalFieldWidget.ts +76 -0
- package/src/basic/field/complex/select/SelectTableFieldWidget.ts +143 -0
- package/src/basic/field/complex/select/index.ts +3 -0
- package/src/basic/field/complex/subview/FormSubviewListFieldWidget.ts +2 -2
- package/src/basic/field/complex/table/TableComplexFieldWidget.ts +5 -0
- package/src/basic/form/BaseFormWidget.ts +7 -1
- package/src/basic/form/DefaultForm.vue +18 -8
- package/src/basic/form/index.ts +0 -1
- package/src/basic/form/style/index.scss +1 -0
- package/src/basic/form/style/word-form.scss +287 -0
- package/src/basic/form-item/BaseFormItemWidget.ts +24 -0
- package/src/basic/form-item/DefaultFormItem.vue +9 -2
- package/src/basic/form-item/style/index.scss +1 -1
- package/src/basic/gallery-item/DefaultGalleryItem.vue +5 -1
- package/src/basic/gallery-item/props.ts +6 -0
- package/src/basic/gallery-item/style/index.scss +17 -5
- package/src/basic/mixin/ManualWidget.ts +1 -1
- package/src/basic/table/BaseTableWidget.ts +746 -150
- package/src/basic/table/style/index.scss +2 -11
- package/src/basic/table-column/BaseTableColumnWidget.ts +131 -15
- package/src/basic/table-column/BaseTableFieldWidget.ts +81 -22
- package/src/basic/table-column/BaseTableQuickOperationColumnWidget.ts +3 -0
- package/src/basic/table-column/DefaultGroupCell.vue +431 -0
- package/src/basic/table-column/DefaultQuickOperationColumn.vue +40 -3
- package/src/basic/table-column/DefaultTableColumn.vue +43 -3
- package/src/basic/token/BaseActionWidget.ts +58 -2
- package/src/basic/token/BaseElementWidget.ts +1 -1
- package/src/basic/token/BaseFieldWidget.ts +13 -1
- package/src/basic/token/BaseView.ts +32 -1
- package/src/basic/token/extend/EditorFieldWidget.ts +1 -1
- package/src/basic/types/typing.ts +9 -0
- package/src/basic/view/MetadataView.vue +1 -2
- package/src/components/common/close-icon/CloseIcon.vue +0 -1
- package/src/components/index.ts +8 -0
- package/src/components/oio-full-screen/OioFullScreen.vue +45 -0
- package/src/components/oio-full-screen/index.ts +1 -0
- package/src/components/oio-manage-group/index.ts +1 -1
- package/src/components/oio-simple-pagination/OioSimplePagination.vue +89 -0
- package/src/components/oio-simple-pagination/index.ts +1 -0
- package/src/components/prop/UploadProps.ts +0 -1
- package/src/components/quick-utils/CheckedHelper.ts +77 -0
- package/src/components/quick-utils/index.ts +5 -0
- package/src/components/quick-utils/useListChecked.ts +230 -0
- package/src/components/quick-utils/useListState.ts +227 -0
- package/src/components/quick-utils/useTreeChecked.ts +271 -0
- package/src/components/quick-utils/useTreeState.ts +248 -0
- package/src/components/select/base/BaseSelect.vue +476 -0
- package/src/components/select/base/DefaultSelect.vue +129 -0
- package/src/components/select/base/index.ts +4 -0
- package/src/components/select/base/props.ts +96 -0
- package/src/components/select/base/typing.ts +6 -0
- package/src/components/select/company-select/CompanySelect.vue +159 -0
- package/src/components/select/company-select/index.ts +2 -0
- package/src/components/select/company-select/render/index.ts +1 -0
- package/src/components/select/company-select/render/logo.ts +18 -0
- package/src/components/select/company-select/render/optionRender.ts +55 -0
- package/src/components/select/company-select/render/style1.ts +11 -0
- package/src/components/select/company-select/render/style2.ts +33 -0
- package/src/components/select/department-select/DepartmentModal.vue +433 -0
- package/src/components/select/department-select/DepartmentSelect.vue +168 -0
- package/src/components/select/department-select/DepartmentTree.vue +244 -0
- package/src/components/select/department-select/constant.ts +10 -0
- package/src/components/select/department-select/index.ts +3 -0
- package/src/components/select/department-select/init.ts +22 -0
- package/src/components/select/employee-select/DepartmentEmployeeSelectPanel.vue +287 -0
- package/src/components/select/employee-select/EmployeeList.vue +146 -0
- package/src/components/select/employee-select/EmployeeModal.vue +464 -0
- package/src/components/select/employee-select/EmployeeSelect.vue +163 -0
- package/src/components/select/employee-select/RoleEmployeeSelectPanel.vue +255 -0
- package/src/components/select/employee-select/index.ts +3 -0
- package/src/components/select/employee-select/init.ts +31 -0
- package/src/components/select/index.ts +6 -0
- package/src/components/select/organizational-structure-tree/OrganizationalStructureTree.vue +262 -0
- package/src/components/select/organizational-structure-tree/index.ts +1 -0
- package/src/components/select/organizational-structure-tree/init.ts +30 -0
- package/src/components/select/role-select/RoleList.vue +159 -0
- package/src/components/select/role-select/RoleModal.vue +357 -0
- package/src/components/select/role-select/RoleSelect.vue +146 -0
- package/src/components/select/role-select/index.ts +3 -0
- package/src/components/select/role-select/init.ts +29 -0
- package/src/components/select-modal/SelectModal.vue +335 -0
- package/src/components/select-modal/index.ts +1 -0
- package/src/components/select-table/SelectTable.vue +306 -0
- package/src/components/select-table/index.ts +1 -0
- package/src/components/sortable-group/SortableGroup.vue +346 -0
- package/src/components/sortable-group/index.ts +2 -0
- package/src/components/sortable-group/typing.ts +5 -0
- package/src/components/table-line-height/TableLineHeight.vue +111 -0
- package/src/components/table-line-height/index.ts +1 -0
- package/src/components/user-prefer/DefaultUserPrefer.vue +5 -0
- package/src/components/user-prefer/StandardUserPreferSetting.vue +6 -2
- package/src/container/block/DefaultBlock.vue +2 -10
- package/src/container/block/DefaultCol.vue +3 -11
- package/src/container/block/DefaultContainer.vue +3 -13
- package/src/container/block/DefaultContainerWidget.ts +9 -4
- package/src/container/block/DefaultContainers.vue +3 -13
- package/src/container/block/DefaultRow.vue +4 -13
- package/src/container/collapse/DefaultCollapse.vue +2 -12
- package/src/container/collapse/DefaultCollapsePanelWidget.ts +2 -0
- package/src/container/collapse/DefaultCollapseWidget.ts +1 -1
- package/src/container/group/DefaultGroup.vue +39 -18
- package/src/container/group/DefaultGroupTitleToolbar.vue +1 -1
- package/src/container/group/DefaultGroupWidget.ts +45 -11
- package/src/container/media/icon/DefaultIcon.vue +15 -7
- package/src/container/media/paragraph/DefaultParagraph.vue +13 -4
- package/src/container/media/picture/DefaultPicture.vue +16 -3
- package/src/container/media/text-info/DefaultTextInfo.vue +14 -6
- package/src/container/spin/DefaultSpin.vue +1 -7
- package/src/container/tabs/DefaultTab.vue +5 -1
- package/src/container/tabs/DefaultTabWidget.ts +2 -0
- package/src/container/tabs/DefaultTabs.vue +7 -1
- package/src/container/tabs/DefaultTabsWidget.ts +5 -0
- package/src/field/cascader/DefaultCascader.vue +3 -2
- package/src/field/cascader/FormCascaderFieldWidget.ts +2 -2
- package/src/field/detail/date/range/ReadonlyDateTimeRangePicker.vue +2 -0
- package/src/field/detail/enum/Enum.vue +11 -8
- package/src/field/detail/map/DefaultReadonlyMap.vue +33 -0
- package/src/field/detail/map/DetailMapFieldWidget.ts +8 -1
- package/src/field/detail/o2m/select/Select.vue +7 -8
- package/src/field/detail/string/string-with-copy/String.vue +4 -22
- package/src/field/detail/string/tag/DetailTag.vue +6 -7
- package/src/field/eip/form/work-scope/service.ts +0 -1
- package/src/field/form/{m2m/select/SelectWidget.vue → abstract/select/DefaultMultipleSelect.vue} +44 -19
- package/src/field/form/{m2o/select/SelectWidget.vue → abstract/select/DefaultSingleSelect.vue} +39 -17
- package/src/field/form/date/DefaultDatePicker.vue +3 -4
- package/src/field/form/date/DefaultDateTimePicker.vue +3 -4
- package/src/field/form/date/DefaultTimePicker.vue +2 -3
- package/src/field/form/date/DefaultYearPicker.vue +2 -3
- package/src/field/form/date/FormDateTimeFieldWidget.ts +0 -7
- package/src/field/form/date/range/DefaultDateRangePicker.vue +7 -8
- package/src/field/form/date/range/DefaultDateTimeRangePicker.vue +8 -9
- package/src/field/form/date/range/DefaultTimeRangePicker.vue +7 -8
- package/src/field/form/date/range/DefaultYearRangePicker.vue +7 -8
- package/src/field/form/enum/radio/FormEnumRadioWidget.ts +4 -6
- package/src/field/form/enum/select/multi/MultiEnumSelect.vue +42 -15
- package/src/field/form/enum/select/single/EnumSelect.vue +64 -10
- package/src/field/form/enum/thumbnail/FormEnumThumbnailFieldWidget.ts +2 -6
- package/src/field/form/float/Plat.vue +21 -9
- package/src/field/form/index.ts +0 -1
- package/src/field/form/m2m/company/FormM2MCompanyFieldWidget.ts +33 -6
- package/src/field/form/m2m/department/FormM2MDepartmentFieldWidget.ts +56 -6
- package/src/field/form/m2m/employee/FormM2MEmployeeFieldWidget.ts +62 -6
- package/src/field/form/m2m/index.ts +2 -1
- package/src/field/form/m2m/role/FormM2MRoleFieldWidget.ts +54 -0
- package/src/field/form/m2m/select/FormM2MSelectFieldWidget.ts +37 -0
- package/src/field/form/m2m/select/FormM2MSelectModalFieldWidget.ts +33 -0
- package/src/field/form/m2m/select/FormM2MSelectTableFieldWidget.ts +29 -0
- package/src/field/form/m2m/select/index.ts +3 -0
- package/src/field/form/m2o/address/FormM2OAddressFieldWidget.ts +14 -3
- package/src/field/form/m2o/company/FormM2OCompanyFieldWidget.ts +29 -6
- package/src/field/form/m2o/department/FormM2ODepartmentFieldWidget.ts +52 -6
- package/src/field/form/m2o/employee/FormM2OEmployeeFieldWidget.ts +58 -6
- package/src/field/form/m2o/index.ts +2 -2
- package/src/field/form/m2o/role/FormM2ORoleFieldWidget.ts +50 -0
- package/src/field/form/m2o/select/FormM2OSelectFieldWidget.ts +33 -88
- package/src/field/form/m2o/select/FormM2OSelectModalFieldWidget.ts +39 -0
- package/src/field/form/m2o/select/FormM2OSelectTableFieldWidget.ts +38 -0
- package/src/field/form/m2o/select/index.ts +4 -0
- package/src/field/form/map/DefaultMap.vue +1 -1
- package/src/field/form/map/style/index.scss +5 -0
- package/src/field/form/o2m/cascader/index.ts +1 -0
- package/src/field/form/o2m/index.ts +2 -2
- package/src/field/form/o2m/select/FormO2MSelectFieldWidget.ts +4 -51
- package/src/field/form/o2m/select/FormO2MSelectModalFieldWidget.ts +27 -0
- package/src/field/form/o2m/select/FormO2MSelectTableFieldWidget.ts +23 -0
- package/src/field/form/o2m/select/index.ts +3 -0
- package/src/field/form/o2m/table/FormO2MTableFieldWidget.ts +26 -1
- package/src/field/form/o2o/index.ts +1 -1
- package/src/field/form/o2o/select/FormO2OSelectModalFieldWidget.ts +34 -0
- package/src/field/form/o2o/select/FormO2OSelectTableFieldWidget.ts +35 -0
- package/src/field/form/o2o/select/index.ts +3 -0
- package/src/field/form/string/input/FormStringInputFieldWidget.ts +1 -1
- package/src/field/form/string/tag/FormStringMultiTagFieldWidget.ts +5 -0
- package/src/field/form/string/tag/Tag.vue +95 -28
- package/src/field/form/text/DomainExpGenerator/ExpRight.vue +1 -0
- package/src/field/gallery/common/style/index.scss +18 -0
- package/src/field/gallery/string/default/GalleryString.vue +8 -0
- package/src/field/gallery/string/hyperlinks/GalleryHyperlinks.vue +8 -0
- package/src/field/gallery/string/media-player/GalleryMediaPlayer.vue +15 -19
- package/src/field/gallery/string/tag/GalleryStringTagFieldWidget.ts +32 -1
- package/src/field/gallery/string/tag/GalleryTag.vue +99 -51
- package/src/field/prop/RelationSelectProps.ts +149 -4
- package/src/field/range/SearchRangeFieldWidget.ts +0 -8
- package/src/field/resource/language-badge/FormResourceLangBadge.vue +3 -3
- package/src/field/search/enum/TabSelect.vue +2 -2
- package/src/field/search/enum/TagSelect.vue +2 -2
- package/src/field/search/m2o/SearchM2OMultiSelectFieldWidget.ts +2 -2
- package/src/field/table/boolean/TableBooleanSwitchFieldWidget.ts +22 -2
- package/src/field/table/date/range/TableDateTimeRangeFieldWidget.ts +16 -1
- package/src/field/table/date/range/editor/DefaultEditorDateRangePicker.vue +5 -8
- package/src/field/table/date/range/editor/DefaultEditorDateTimeRangePicker.vue +5 -8
- package/src/field/table/date/range/editor/DefaultEditorTimeRangePicker.vue +5 -8
- package/src/field/table/date/range/editor/DefaultEditorYearRangePicker.vue +5 -8
- package/src/field/table/enum/TableEnum.vue +0 -1
- package/src/field/table/enum/checkbox/TableEditorCheckboxFieldWidget.ts +14 -0
- package/src/field/table/enum/checkbox/index.ts +1 -0
- package/src/field/table/enum/index.ts +4 -0
- package/src/field/table/enum/radio/TableEditorRadioFieldWidget.ts +13 -0
- package/src/field/table/enum/radio/index.ts +1 -0
- package/src/field/table/enum/select/TableEditorEnumFieldWidget.ts +18 -0
- package/src/field/table/enum/select/TableEditorMultiEnumFieldWidget.ts +19 -0
- package/src/field/table/enum/select/index.ts +2 -0
- package/src/field/table/enum/thumbnail/TableEditorEnumThumbnailFieldWidget.ts +13 -0
- package/src/field/table/enum/thumbnail/index.ts +1 -0
- package/src/field/table/html/TableEditorHtmlFieldWidget.ts +23 -0
- package/src/field/table/html/TableHtmlFieldWidget.ts +51 -0
- package/src/field/table/html/{richtext/TableRichText.vue → TableRichText.vue} +1 -1
- package/src/field/table/html/index.ts +2 -1
- package/src/field/table/index.ts +2 -1
- package/src/field/table/m2m/company/TableEditorM2MCompanyFieldWidget.ts +19 -0
- package/src/field/table/m2m/company/index.ts +1 -0
- package/src/field/table/m2m/department/TableEditorM2MDepartmentFieldWidget.ts +13 -0
- package/src/field/table/m2m/department/index.ts +1 -0
- package/src/field/table/m2m/employee/TableEditorM2MEmployeeFieldWidget.ts +13 -0
- package/src/field/table/m2m/employee/index.ts +1 -0
- package/src/field/table/m2m/index.ts +8 -1
- package/src/field/table/m2m/role/TableEditorM2MRoleFieldWidget.ts +13 -0
- package/src/field/table/m2m/role/index.ts +1 -0
- package/src/field/table/m2m/select/TableEditorM2MFieldWidget.ts +18 -0
- package/src/field/table/{relation/m2m → m2m/select}/TableM2MFieldWidget.ts +6 -1
- package/src/field/table/m2m/select/index.ts +2 -0
- package/src/field/table/m2m/select-modal/TableEditorM2MSelectModalFieldWidget.ts +13 -0
- package/src/field/table/m2m/select-modal/index.ts +1 -0
- package/src/field/table/m2m/select-table/TableEditorM2MSelectTableFieldWidget.ts +13 -0
- package/src/field/table/m2m/select-table/index.ts +1 -0
- package/src/field/table/m2m/upload/index.ts +1 -0
- package/src/field/table/m2o/address/TableM2OAddressFieldWidget.ts +2 -3
- package/src/field/table/m2o/address/index.ts +2 -0
- package/src/field/table/m2o/company/TableEditorM2OCompanyFieldWidget.ts +19 -0
- package/src/field/table/m2o/company/index.ts +1 -0
- package/src/field/table/m2o/department/TableEditorM2ODepartmentFieldWidget.ts +13 -0
- package/src/field/table/m2o/department/index.ts +1 -0
- package/src/field/table/m2o/download/TableM2ODownloadWidget.ts +2 -3
- package/src/field/table/m2o/download/index.ts +1 -0
- package/src/field/table/m2o/employee/TableEditorM2OEmployeeFieldWidget.ts +13 -0
- package/src/field/table/m2o/employee/index.ts +1 -0
- package/src/field/table/m2o/index.ts +10 -4
- package/src/field/table/m2o/role/TableEditorM2ORoleFieldWidget.ts +13 -0
- package/src/field/table/m2o/role/index.ts +1 -0
- package/src/field/table/m2o/select/TableEditorM2OFieldWidget.ts +18 -0
- package/src/field/table/{relation/m2o → m2o/select}/TableM2OFieldWidget.ts +6 -1
- package/src/field/table/m2o/select/index.ts +2 -0
- package/src/field/table/m2o/select-modal/TableEditorM2OSelectModalFieldWidget.ts +13 -0
- package/src/field/table/m2o/select-modal/index.ts +1 -0
- package/src/field/table/m2o/select-table/TableEditorM2OSelectTableFieldWidget.ts +13 -0
- package/src/field/table/m2o/select-table/index.ts +1 -0
- package/src/field/table/m2o/upload/index.ts +1 -0
- package/src/field/table/number/TableEditorMultiNumberFieldWidget.ts +19 -0
- package/src/field/table/number/index.ts +1 -0
- package/src/field/table/o2m/index.ts +3 -0
- package/src/field/table/o2m/select/TableEditorO2MFieldWidget.ts +18 -0
- package/src/field/table/{relation/o2m → o2m/select}/TableO2MFieldWidget.ts +6 -1
- package/src/field/table/o2m/select/index.ts +2 -0
- package/src/field/table/o2m/select-modal/TableEditorO2MSelectModalFieldWidget.ts +13 -0
- package/src/field/table/o2m/select-modal/index.ts +1 -0
- package/src/field/table/o2m/select-table/TableEditorO2MSelectTableFieldWidget.ts +13 -0
- package/src/field/table/o2m/select-table/index.ts +1 -0
- package/src/field/table/o2o/index.ts +3 -0
- package/src/field/table/o2o/select/TableEditorO2OFieldWidget.ts +18 -0
- package/src/field/table/{relation/o2o → o2o/select}/TableO2OFieldWidget.ts +6 -1
- package/src/field/table/o2o/select/index.ts +2 -0
- package/src/field/table/o2o/select-modal/TableEditorO2OSelectModalFieldWidget.ts +13 -0
- package/src/field/table/o2o/select-modal/index.ts +1 -0
- package/src/field/table/o2o/select-table/TableEditorO2OSelectTableFieldWidget.ts +13 -0
- package/src/field/table/o2o/select-table/index.ts +1 -0
- package/src/field/table/string/tag/TableEditorStringTagFieldWidget.ts +19 -0
- package/src/field/table/string/tag/index.ts +1 -0
- package/src/field/table/text/TableTextFieldWidget.ts +12 -0
- package/src/field/table-operation-column/TableOperationColumn.vue +12 -2
- package/src/field/transfer/FormTransferFieldWidget.ts +2 -2
- package/src/field/tree/FormTreeFieldWidget.ts +2 -2
- package/src/field/tree-select/AbstractTreeFieldWidget.ts +2 -1
- package/src/field/tree-select/DefaultTreeSelect.vue +3 -3
- package/src/field/tree-select/FormTreeSelectFieldWidget.ts +2 -8
- package/src/field/util.ts +1 -1
- package/src/file/excel/action/ExportWorkbookActionWidget.ts +2 -15
- package/src/icon-manage/view/search/IconSearch.vue +6 -2
- package/src/index.ts +1 -0
- package/src/main-view/DefaultMainView.vue +1 -2
- package/src/main-view/DefaultMainViewWidget.ts +3 -5
- package/src/main-view/DefaultMetadataMainView.vue +1 -2
- package/src/main-view/shared/SharedMainView.vue +1 -1
- package/src/permission/permission/field/ActionPermissionWidget.ts +2 -2
- package/src/permission/role-permission/resource-permission/FormManagementPermissionFieldWidget.ts +1 -1
- package/src/permission/role-permission/resource-permission/FormResourcePermissionFieldWidget.ts +3 -3
- package/src/permission/system-permission/components/data-permission/data-permission-table.vue +0 -1
- package/src/permission/types.ts +2 -0
- package/src/service/tree/tree-service.ts +8 -2
- package/src/style/antdComponents/All.scss +5 -9
- package/src/style/basic.scss +2 -1
- package/src/style/components/implementation/form/select.scss +2 -21
- package/src/style/components/implementation/form/string.scss +18 -0
- package/src/style/components/index.scss +0 -1
- package/src/style/index.scss +1 -0
- package/src/tags/ActionBar.vue +2 -3
- package/src/tags/Row.vue +1 -2
- package/src/tags/View.vue +10 -2
- package/src/tags/context/index.ts +0 -1
- package/src/tags/context/runtime-context-helper.ts +2 -1
- package/src/tags/internal/EditorField.vue +2 -3
- package/src/tags/mixin/BaseWidgetTagMixin.ts +2 -1
- package/src/tags/mixin/use-widget-tag.ts +2 -1
- package/src/tags/resolve/helper.ts +6 -183
- package/src/tags/resolve/internal/widget-resolve.ts +11 -4
- package/src/tags/resolve/widget-resolve.ts +1 -2
- package/src/typing/action.ts +0 -6
- package/src/typing/card-cascader.ts +1 -1
- package/src/typing/control-icon.ts +7 -0
- package/src/typing/event/index.ts +1 -0
- package/src/typing/event/table.ts +44 -0
- package/src/typing/index.ts +3 -0
- package/src/typing/view.ts +14 -0
- package/src/util/default-tree-definition.ts +100 -1
- package/src/util/jumpDesignerPage.ts +11 -3
- package/src/util/tree-utils.ts +1 -2
- package/src/view/application-screen/gallery/Gallery.vue +6 -0
- package/src/view/application-screen/gallery/field/select/AppsModuleUpstreamSelectWidget.ts +2 -2
- package/src/view/card/CardWidget.ts +87 -4
- package/src/view/card/DefaultCard.vue +124 -42
- package/src/view/card/DefaultCardContent.vue +25 -0
- package/src/view/card/DefaultCardTitle.vue +25 -0
- package/src/view/card/DefaultCardTitleToolbar.vue +1 -1
- package/src/view/card/style/index.scss +26 -8
- package/src/view/card-cascader/AbstractCardCascaderElementWidget.ts +1 -2
- package/src/view/card-cascader/CardCascaderWidget.ts +1 -1
- package/src/view/card-cascader/DefaultCardCascader.vue +2 -1
- package/src/view/card-cascader/TableSearchCardCascaderWidget.ts +1 -1
- package/src/view/detail/DetailWidget.ts +7 -0
- package/src/view/detail/style/index.scss +18 -0
- package/src/view/gallery/DefaultGallery.vue +15 -1
- package/src/view/gallery/GalleryWidget.ts +111 -4
- package/src/view/gallery/style/index.scss +1 -0
- package/src/view/homepage-setting/components/MultiSelect.vue +3 -3
- package/src/view/homepage-setting/components/SingleSelect.vue +2 -3
- package/src/view/index.ts +2 -0
- package/src/view/login/LoginWidget.ts +1 -1
- package/src/view/popup/PopupWidget.ts +111 -12
- package/src/view/popup/dialog/DefaultDialog.vue +127 -6
- package/src/view/popup/dialog/DialogWidget.ts +14 -6
- package/src/view/popup/dialog/StaticDialogWidget.ts +2 -2
- package/src/view/popup/dialog/style/index.scss +24 -0
- package/src/view/popup/drawer/DefaultDrawer.vue +146 -7
- package/src/view/popup/drawer/DrawerWidget.ts +15 -8
- package/src/view/popup/drawer/StaticDrawerWidget.ts +2 -2
- package/src/view/popup/drawer/style/index.scss +183 -2
- package/src/view/popup/inner/DefaultInnerPopup.vue +17 -12
- package/src/view/popup/inner/InnerPopupWidget.ts +2 -7
- package/src/view/quick-fill/Excel.vue +951 -0
- package/src/view/quick-fill/QuickFill.vue +358 -0
- package/src/view/quick-fill/QuickFillWidget.ts +704 -0
- package/src/view/quick-fill/index.ts +1 -0
- package/src/view/quick-fill/type.ts +14 -0
- package/src/view/search/DefaultSearch.vue +161 -134
- package/src/view/system-style/SystemStyle.vue +70 -31
- package/src/view/system-style/SystemStyleWidget.ts +4 -3
- package/src/view/table/DefaultTable.vue +335 -51
- package/src/view/table/DefaultTableFooterOperator.vue +58 -0
- package/src/view/table/DefaultTableGroupCollapse.vue +69 -0
- package/src/view/table/TableUserPrefer.vue +4 -0
- package/src/view/table/TableUserPreferWidget.ts +7 -2
- package/src/view/table/TableWidget.ts +676 -22
- package/src/view/table/index.ts +0 -3
- package/src/view/table/style/index.scss +39 -1
- package/src/view/translate/translate-page-util/translate-box/TranslateBoxWidget.vue +9 -3
- package/src/view/tree/AbstractTreeElementWidget.ts +2 -2
- package/src/view/tree/TableSearchTreeWidget.ts +1 -2
- package/src/view/tree/TreeWidget.ts +8 -2
- package/src/view/tree/props.ts +1 -1
- package/src/view/view/DefaultView.vue +38 -13
- package/src/view/view/DetailView.ts +6 -1
- package/src/view/view/FormView.ts +5 -0
- package/src/view/view/SearchView.ts +6 -1
- package/src/view/view/TableView.ts +8 -3
- package/src/view/view/style/index.scss +158 -0
- package/src/view/view-control/DefaultViewControl.vue +132 -0
- package/src/view/view-control/ViewControlWidget.ts +64 -0
- package/src/view/view-control/card-col-control/CardColControlWidget.ts +33 -0
- package/src/view/view-control/card-col-control/DefaultCardColControl.vue +125 -0
- package/src/view/view-control/full-screen-control/DefaultFullScreenControl.vue +28 -0
- package/src/view/view-control/full-screen-control/FullScreenControlWidget.ts +17 -0
- package/src/view/view-control/group-control/DefaultGroupControl.vue +88 -0
- package/src/view/view-control/group-control/GroupControlWidget.ts +87 -0
- package/src/view/view-control/index.ts +7 -0
- package/src/view/view-control/keyboard-shortcut/DefaultKeyboardShortcut.vue +172 -0
- package/src/view/view-control/keyboard-shortcut/KeyboardShortcutWidget.ts +66 -0
- package/src/view/view-control/line-height-control/DefaultLineHeightControl.vue +26 -0
- package/src/view/view-control/line-height-control/LineHeightControlWidget.ts +39 -0
- package/src/view/view-control/sort-control/DefaultSortControl.vue +85 -0
- package/src/view/view-control/sort-control/SortControlWidget.ts +89 -0
- package/src/view/workbench/Workbench.vue +1 -0
- package/src/view/workbench/services.ts +22 -23
- package/dist/types/src/basic/form/context.d.ts +0 -7
- package/dist/types/src/field/form/metadata-area/SelectDefault/SelectActionWidget.d.ts +0 -6
- package/dist/types/src/field/form/metadata-area/SelectDefault/SelectFieldAction.vue.d.ts +0 -105
- package/dist/types/src/field/form/metadata-area/SelectDefault/SelectFieldActionNode.vue.d.ts +0 -76
- package/dist/types/src/field/form/metadata-area/SelectDefault/SelectFieldWidget.d.ts +0 -6
- package/dist/types/src/field/form/metadata-area/SelectFieldActionWidget.d.ts +0 -33
- package/dist/types/src/field/form/metadata-area/index.d.ts +0 -4
- package/dist/types/src/field/form/metadata-area/service.d.ts +0 -2
- package/dist/types/src/field/form/metadata-area/typing.d.ts +0 -73
- package/dist/types/src/field/table/html/richtext/TableHtmlRichTextFieldWidget.d.ts +0 -11
- package/dist/types/src/field/table/html/richtext/index.d.ts +0 -1
- package/dist/types/src/field/table/relation/index.d.ts +0 -4
- package/dist/types/src/field/table/relation/m2m/index.d.ts +0 -1
- package/dist/types/src/field/table/relation/m2o/index.d.ts +0 -1
- package/dist/types/src/field/table/relation/o2m/index.d.ts +0 -1
- package/dist/types/src/field/table/relation/o2o/index.d.ts +0 -1
- package/dist/types/src/tags/context/context.d.ts +0 -41
- package/dist/types/src/tags/resolve/internal/row-col-resolve.d.ts +0 -76
- package/dist/types/src/view/table/config.d.ts +0 -22
- package/dist/types/src/view/table/typing.d.ts +0 -4
- package/src/basic/form/context.ts +0 -51
- package/src/field/form/m2m/select/FormM2MFieldSelectWidget.ts +0 -55
- package/src/field/form/metadata-area/SelectDefault/SelectActionWidget.ts +0 -24
- package/src/field/form/metadata-area/SelectDefault/SelectFieldAction.vue +0 -257
- package/src/field/form/metadata-area/SelectDefault/SelectFieldActionNode.vue +0 -277
- package/src/field/form/metadata-area/SelectDefault/SelectFieldWidget.ts +0 -22
- package/src/field/form/metadata-area/SelectFieldActionWidget.ts +0 -378
- package/src/field/form/metadata-area/index.ts +0 -6
- package/src/field/form/metadata-area/service.ts +0 -46
- package/src/field/form/metadata-area/typing.ts +0 -114
- package/src/field/form/o2m/select/SelectWidget.vue +0 -111
- package/src/field/form/o2o/select/SelectWidget.vue +0 -119
- package/src/field/table/html/richtext/TableHtmlRichTextFieldWidget.ts +0 -30
- package/src/field/table/html/richtext/index.ts +0 -1
- package/src/field/table/relation/index.ts +0 -4
- package/src/field/table/relation/m2m/index.ts +0 -1
- package/src/field/table/relation/m2o/index.ts +0 -1
- package/src/field/table/relation/o2m/index.ts +0 -1
- package/src/field/table/relation/o2o/index.ts +0 -1
- package/src/style/components/drawer.scss +0 -151
- package/src/tags/context/context.ts +0 -57
- package/src/tags/resolve/internal/row-col-resolve.ts +0 -358
- package/src/view/table/config.ts +0 -30
- package/src/view/table/typing.ts +0 -4
- /package/dist/types/src/components/oio-manage-group/{oio-manage-group.vue.d.ts → OioManageGroup.vue.d.ts} +0 -0
- /package/dist/types/src/field/table/html/{richtext/TableRichText.vue.d.ts → TableRichText.vue.d.ts} +0 -0
- /package/dist/types/src/field/table/{relation/m2m → m2m/select}/TableM2MFieldWidget.d.ts +0 -0
- /package/dist/types/src/field/table/{relation/m2o → m2o/select}/TableM2OFieldWidget.d.ts +0 -0
- /package/dist/types/src/field/table/{relation/o2m → o2m/select}/TableO2MFieldWidget.d.ts +0 -0
- /package/dist/types/src/field/table/{relation/o2o → o2o/select}/TableO2OFieldWidget.d.ts +0 -0
- /package/src/components/oio-manage-group/{oio-manage-group.vue → OioManageGroup.vue} +0 -0
|
@@ -0,0 +1,951 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="quick-fill-excel-container">
|
|
3
|
+
<oio-spin :loading="loading" :delay="50">
|
|
4
|
+
<table
|
|
5
|
+
:class="{
|
|
6
|
+
'excel-table': true,
|
|
7
|
+
'excel-table-selecting': isSelecting
|
|
8
|
+
}"
|
|
9
|
+
ref="tableRef"
|
|
10
|
+
@keydown="handleKeydown"
|
|
11
|
+
@copy="handleCopy"
|
|
12
|
+
@cut="handleCut"
|
|
13
|
+
@paste="handlePaste"
|
|
14
|
+
tabindex="0"
|
|
15
|
+
>
|
|
16
|
+
<thead>
|
|
17
|
+
<tr>
|
|
18
|
+
<th class="corner-cell"></th>
|
|
19
|
+
<!-- 生成列标题 -->
|
|
20
|
+
<th
|
|
21
|
+
v-for="(field, index) in fields"
|
|
22
|
+
:key="field.key"
|
|
23
|
+
class="column-header"
|
|
24
|
+
:style="{ width: cellWidth + 'px' }"
|
|
25
|
+
>
|
|
26
|
+
<a-select
|
|
27
|
+
class="oio-select"
|
|
28
|
+
dropdown-class-name="oio-select-dropdown"
|
|
29
|
+
:options="selectOptions"
|
|
30
|
+
:value="getThSelectValue(index)"
|
|
31
|
+
@change="(value, option) => onChangeTableHeader(value, option, index)"
|
|
32
|
+
></a-select>
|
|
33
|
+
</th>
|
|
34
|
+
</tr>
|
|
35
|
+
</thead>
|
|
36
|
+
<tbody>
|
|
37
|
+
<tr v-for="row in rows" :key="row">
|
|
38
|
+
<!-- 行号 -->
|
|
39
|
+
<td class="row-header">{{ row }}</td>
|
|
40
|
+
<!-- 单元格 -->
|
|
41
|
+
<td
|
|
42
|
+
v-for="(col, index) in columns"
|
|
43
|
+
:key="`${row}-${col}`"
|
|
44
|
+
:class="{
|
|
45
|
+
cell: true,
|
|
46
|
+
selected: isSelected(`${row}-${col}`),
|
|
47
|
+
editing: isEditing(`${row}-${col}`),
|
|
48
|
+
'range-selected': isRangeSelected(`${row}-${col}`),
|
|
49
|
+
'cell-disabled': tableHeaderValues[index].readonly
|
|
50
|
+
}"
|
|
51
|
+
:data-cell="`${row}-${col}`"
|
|
52
|
+
@click="handleCellClick($event, `${row}-${col}`, index)"
|
|
53
|
+
@mousedown="handleCellMouseDown(`${row}-${col}`)"
|
|
54
|
+
@dblclick="startEditing(`${row}-${col}`)"
|
|
55
|
+
@focus="focusCell(`${row}-${col}`)"
|
|
56
|
+
tabindex="0"
|
|
57
|
+
:style="{ width: cellWidth + 'px', height: cellHeight + 'px' }"
|
|
58
|
+
>
|
|
59
|
+
<!-- 编辑状态显示输入框 -->
|
|
60
|
+
<input
|
|
61
|
+
ref="inputRef"
|
|
62
|
+
v-if="isEditing(`${row}-${col}`)"
|
|
63
|
+
:value="getCellContent(`${row}-${col}`)"
|
|
64
|
+
@input="updateCellContent(`${row}-${col}`, $event.target.value)"
|
|
65
|
+
@blur="stopEditing"
|
|
66
|
+
@keydown.enter="handleEnter"
|
|
67
|
+
@keydown="handleCellKeydown"
|
|
68
|
+
@compositionstart="isComposing = true"
|
|
69
|
+
@compositionend="isComposing = false"
|
|
70
|
+
@focus="$event.target.select()"
|
|
71
|
+
class="cell-input"
|
|
72
|
+
type="text"
|
|
73
|
+
/>
|
|
74
|
+
<!-- 非编辑状态显示内容 -->
|
|
75
|
+
<span v-else class="cell-content">{{ getCellContent(`${row}-${col}`) }}</span>
|
|
76
|
+
</td>
|
|
77
|
+
</tr>
|
|
78
|
+
<tr v-for="row in disabledRows" :key="row">
|
|
79
|
+
<td class="row-header cell-disabled">{{ row }}</td>
|
|
80
|
+
<td v-for="col in columns" :key="`${row}-${col}`" class="cell cell-disabled"></td>
|
|
81
|
+
</tr>
|
|
82
|
+
</tbody>
|
|
83
|
+
</table>
|
|
84
|
+
</oio-spin>
|
|
85
|
+
</div>
|
|
86
|
+
</template>
|
|
87
|
+
|
|
88
|
+
<script setup lang="ts">
|
|
89
|
+
import { OioSpin } from '@oinone/kunlun-vue-ui-antd';
|
|
90
|
+
import { Select as ASelect } from 'ant-design-vue';
|
|
91
|
+
import { computed, defineExpose, defineProps, nextTick, onMounted, onUnmounted, ref, watch } from 'vue';
|
|
92
|
+
import { NON_CUT, TableFieldOption } from './type';
|
|
93
|
+
|
|
94
|
+
const runFun = window.requestIdleCallback || ((fn) => setTimeout(fn));
|
|
95
|
+
|
|
96
|
+
const timeSlice = (gen: Generator | (() => Generator), done?: () => void) => {
|
|
97
|
+
let generator: Generator = typeof gen === 'function' ? gen() : gen;
|
|
98
|
+
if (!generator || typeof generator.next !== 'function') return;
|
|
99
|
+
return function next() {
|
|
100
|
+
const start: number = performance.now();
|
|
101
|
+
let res: IteratorResult<unknown> | null = null;
|
|
102
|
+
do {
|
|
103
|
+
res = generator.next();
|
|
104
|
+
} while (!res.done && performance.now() - start < 100);
|
|
105
|
+
|
|
106
|
+
if (res.done) return done?.();
|
|
107
|
+
runFun(next);
|
|
108
|
+
};
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
function* gen<T>(list: T[], fn: (item: T, index: number) => void) {
|
|
112
|
+
let current = 0;
|
|
113
|
+
while (current < list.length) {
|
|
114
|
+
fn(list[current], current);
|
|
115
|
+
yield;
|
|
116
|
+
current++;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
const runLongTask = <T>(list: T[], fn: (item: T, index: number) => void, done?: () => void) => {
|
|
121
|
+
const task = timeSlice(gen(list, fn), done);
|
|
122
|
+
if (task) task();
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
interface CellIndices {
|
|
126
|
+
row: number;
|
|
127
|
+
col: number;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
interface ParsedCellId {
|
|
131
|
+
row: number;
|
|
132
|
+
col: number;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
type CellId = string;
|
|
136
|
+
|
|
137
|
+
const props = defineProps<{
|
|
138
|
+
fields: TableFieldOption[];
|
|
139
|
+
rowCount: number; // 行数
|
|
140
|
+
addRowCount: (addNumber: number) => void;
|
|
141
|
+
}>();
|
|
142
|
+
|
|
143
|
+
const cellWidth = 110; // 单元格宽度
|
|
144
|
+
const cellHeight = 30; // 单元格高度
|
|
145
|
+
const colCount = computed(() => props.fields.length || 0); // 列数
|
|
146
|
+
const hasChangeCellValue = ref(false);
|
|
147
|
+
// 表头下拉选中的值
|
|
148
|
+
const tableHeaderValues = ref<TableFieldOption[]>([]);
|
|
149
|
+
|
|
150
|
+
// 表头下拉选项
|
|
151
|
+
const selectOptions = computed(() => {
|
|
152
|
+
const options: TableFieldOption[] = [...props.fields];
|
|
153
|
+
options.unshift({
|
|
154
|
+
label: '不粘贴',
|
|
155
|
+
key: NON_CUT,
|
|
156
|
+
value: NON_CUT,
|
|
157
|
+
readonly: true,
|
|
158
|
+
field: NON_CUT
|
|
159
|
+
});
|
|
160
|
+
return options;
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
// ======== 状态 =========
|
|
164
|
+
const tableRef = ref<HTMLTableElement | null>(null); // 表格引用
|
|
165
|
+
const inputRef = ref<(HTMLInputElement | null)[]>([]); // 输入框引用数组
|
|
166
|
+
const selectedCell = ref<CellId>(''); // 当前活动/起始选中的单元格
|
|
167
|
+
const editingCell = ref<CellId | null>(null); // 当前正在编辑的单元格
|
|
168
|
+
const cells = ref<Record<CellId, string>>({}); // 存储单元格内容的对象
|
|
169
|
+
const isComposing = ref(false); // 输入框是否正在输入汉字
|
|
170
|
+
const loading = ref(false);
|
|
171
|
+
|
|
172
|
+
// ======== 多选状态 =========
|
|
173
|
+
const isSelecting = ref(false); // 是否正在拖拽选择
|
|
174
|
+
const selectionStart = ref<CellId | null>(null); // 框选的起始单元格
|
|
175
|
+
const selectionEnd = ref<CellId | null>(null); // 框选的结束单元格 (即当前鼠标位置)
|
|
176
|
+
const selectionRange = ref<Set<CellId>>(new Set()); // 存储当前选区内的所有单元格 ID
|
|
177
|
+
|
|
178
|
+
const initTableHeaderValues = () => {
|
|
179
|
+
tableHeaderValues.value = props.fields.map((v) => ({ ...v }));
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
watch(
|
|
183
|
+
() => props.fields,
|
|
184
|
+
() => {
|
|
185
|
+
initTableHeaderValues();
|
|
186
|
+
},
|
|
187
|
+
{ immediate: true }
|
|
188
|
+
);
|
|
189
|
+
|
|
190
|
+
const generateColumnName = (index: number) => {
|
|
191
|
+
let columnName = '';
|
|
192
|
+
let tempIndex = index;
|
|
193
|
+
while (tempIndex >= 0) {
|
|
194
|
+
columnName = String.fromCharCode((tempIndex % 26) + 65) + columnName;
|
|
195
|
+
tempIndex = Math.floor(tempIndex / 26) - 1;
|
|
196
|
+
}
|
|
197
|
+
return index + 1;
|
|
198
|
+
};
|
|
199
|
+
|
|
200
|
+
const columns = computed(() => Array.from({ length: colCount.value }, (_, i) => generateColumnName(i)));
|
|
201
|
+
const rows = computed(() => Array.from({ length: props.rowCount }, (_, i) => i + 1));
|
|
202
|
+
const disabledRows = computed(() => {
|
|
203
|
+
const basic = props.rowCount || 0;
|
|
204
|
+
const l = 9 - basic;
|
|
205
|
+
if (l >= 1) {
|
|
206
|
+
return Array.from({ length: l }, (_, i) => basic + i + 1);
|
|
207
|
+
}
|
|
208
|
+
return [];
|
|
209
|
+
});
|
|
210
|
+
|
|
211
|
+
// ======== 方法 =========
|
|
212
|
+
|
|
213
|
+
// 修改表头
|
|
214
|
+
const onChangeTableHeader = (value, option, index) => {
|
|
215
|
+
tableHeaderValues.value[index].value = value;
|
|
216
|
+
tableHeaderValues.value[index].readonly = option.readonly;
|
|
217
|
+
if (value !== NON_CUT) {
|
|
218
|
+
const other = tableHeaderValues.value.find((v, i) => v.value === value && i !== index);
|
|
219
|
+
if (other) {
|
|
220
|
+
other.value = NON_CUT;
|
|
221
|
+
other.readonly = true;
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
};
|
|
225
|
+
|
|
226
|
+
const getThSelectValue = (index) => {
|
|
227
|
+
return tableHeaderValues.value[index].value;
|
|
228
|
+
};
|
|
229
|
+
|
|
230
|
+
// 获取单元格 ID 的行和列
|
|
231
|
+
const parseCellId = (cellId: CellId): ParsedCellId | null => {
|
|
232
|
+
const match = cellId.match(/(\d+)-(.+)/);
|
|
233
|
+
return match ? { row: parseInt(match[1]), col: parseInt(match[2]) } : null;
|
|
234
|
+
};
|
|
235
|
+
|
|
236
|
+
// 获取单元格内容
|
|
237
|
+
const getCellContent = (cellId: CellId): string => {
|
|
238
|
+
const val = cells.value[cellId];
|
|
239
|
+
if (val == null) {
|
|
240
|
+
return '';
|
|
241
|
+
}
|
|
242
|
+
return `${val}`;
|
|
243
|
+
};
|
|
244
|
+
|
|
245
|
+
// 更新单元格内容
|
|
246
|
+
const updateCellContent = (cellId: CellId, value: string): void => {
|
|
247
|
+
hasChangeCellValue.value = true;
|
|
248
|
+
cells.value[cellId] = value;
|
|
249
|
+
};
|
|
250
|
+
|
|
251
|
+
// 检查单元格是否是活动选中 (单个)
|
|
252
|
+
const isSelected = (cellId: CellId): boolean => {
|
|
253
|
+
return selectedCell.value === cellId;
|
|
254
|
+
};
|
|
255
|
+
|
|
256
|
+
// 检查单元格是否在选区范围内
|
|
257
|
+
const isRangeSelected = (cellId: CellId): boolean => {
|
|
258
|
+
return selectionRange.value.has(cellId);
|
|
259
|
+
};
|
|
260
|
+
|
|
261
|
+
// 检查单元格是否正在编辑
|
|
262
|
+
const isEditing = (cellId: CellId): boolean => {
|
|
263
|
+
return editingCell.value === cellId;
|
|
264
|
+
};
|
|
265
|
+
|
|
266
|
+
// 获取单元格的行列索引
|
|
267
|
+
const getCellIndices = (cellId: CellId): CellIndices | null => {
|
|
268
|
+
const parsed = parseCellId(cellId);
|
|
269
|
+
if (!parsed) {
|
|
270
|
+
return null;
|
|
271
|
+
}
|
|
272
|
+
const rowIdx = parsed.row - 1; // 转换为 0-based 索引
|
|
273
|
+
const colIdx = columns.value.indexOf(parsed.col);
|
|
274
|
+
return colIdx >= 0 ? { row: rowIdx, col: colIdx } : null;
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
// 根据行列索引获取单元格 ID
|
|
278
|
+
const getCellId = (rowIdx: number, colIdx: number): CellId | null => {
|
|
279
|
+
if (rowIdx >= 0 && rowIdx < props.rowCount && colIdx >= 0 && colIdx < colCount.value) {
|
|
280
|
+
return `${rowIdx + 1}-${columns.value[colIdx]}`;
|
|
281
|
+
}
|
|
282
|
+
return null;
|
|
283
|
+
};
|
|
284
|
+
|
|
285
|
+
// 计算并更新选区范围
|
|
286
|
+
const updateSelectionRange = (startId: CellId, endId: CellId): void => {
|
|
287
|
+
const startIndices = getCellIndices(startId);
|
|
288
|
+
const endIndices = getCellIndices(endId);
|
|
289
|
+
if (!startIndices || !endIndices) {
|
|
290
|
+
return;
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
const { row: startRow, col: startCol } = startIndices;
|
|
294
|
+
const { row: endRow, col: endCol } = endIndices;
|
|
295
|
+
|
|
296
|
+
// 确定矩形区域的边界
|
|
297
|
+
const minRow = Math.min(startRow, endRow);
|
|
298
|
+
const maxRow = Math.max(startRow, endRow);
|
|
299
|
+
const minCol = Math.min(startCol, endCol);
|
|
300
|
+
const maxCol = Math.max(startCol, endCol);
|
|
301
|
+
|
|
302
|
+
const newRange = new Set<CellId>();
|
|
303
|
+
for (let r = minRow; r <= maxRow; r++) {
|
|
304
|
+
for (let c = minCol; c <= maxCol; c++) {
|
|
305
|
+
const cellId = getCellId(r, c);
|
|
306
|
+
if (cellId) {
|
|
307
|
+
newRange.add(cellId);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
selectionRange.value = newRange;
|
|
312
|
+
// 选区结束点也作为当前活动单元格 (用于粘贴起点)
|
|
313
|
+
selectedCell.value = endId;
|
|
314
|
+
};
|
|
315
|
+
|
|
316
|
+
// 初始化单选
|
|
317
|
+
const initializeSingleSelection = (cellId: CellId): void => {
|
|
318
|
+
selectionStart.value = cellId;
|
|
319
|
+
selectionEnd.value = cellId;
|
|
320
|
+
const newRange = new Set<CellId>();
|
|
321
|
+
newRange.add(cellId);
|
|
322
|
+
selectionRange.value = newRange;
|
|
323
|
+
selectedCell.value = cellId;
|
|
324
|
+
};
|
|
325
|
+
|
|
326
|
+
// 处理单元格点击
|
|
327
|
+
const handleCellClick = (event: MouseEvent, cellId: CellId, index: number): void => {
|
|
328
|
+
// 如果是 不粘贴列/右键/编辑状态 下的点击,不处理多选
|
|
329
|
+
if (getThSelectValue(index) === NON_CUT || event.button !== 0 || editingCell.value) {
|
|
330
|
+
return;
|
|
331
|
+
}
|
|
332
|
+
if (event.shiftKey) {
|
|
333
|
+
// Shift + 点击:扩展选区到点击的单元格
|
|
334
|
+
if (selectionStart.value) {
|
|
335
|
+
updateSelectionRange(selectionStart.value, cellId);
|
|
336
|
+
} else {
|
|
337
|
+
// 如果没有起始点,从当前 selectedCell 开始
|
|
338
|
+
updateSelectionRange(selectedCell.value, cellId);
|
|
339
|
+
}
|
|
340
|
+
} else if (event.ctrlKey || event.metaKey) {
|
|
341
|
+
// Ctrl/Cmd + 点击:待实现 (可选,如添加到选区)
|
|
342
|
+
// 当前简化为单选
|
|
343
|
+
initializeSingleSelection(cellId);
|
|
344
|
+
} else {
|
|
345
|
+
// 普通点击:单选
|
|
346
|
+
initializeSingleSelection(cellId);
|
|
347
|
+
}
|
|
348
|
+
};
|
|
349
|
+
|
|
350
|
+
// 处理单元格 mousedown (用于拖拽选择)
|
|
351
|
+
const handleCellMouseDown = (cellId: CellId): void => {
|
|
352
|
+
if (editingCell.value) {
|
|
353
|
+
return;
|
|
354
|
+
} // 编辑状态下不响应
|
|
355
|
+
isSelecting.value = true;
|
|
356
|
+
selectionStart.value = cellId;
|
|
357
|
+
selectionEnd.value = cellId;
|
|
358
|
+
updateSelectionRange(cellId, cellId);
|
|
359
|
+
// 添加全局 mousemove 和 mouseup 监听器
|
|
360
|
+
document.addEventListener('mousemove', handleGlobalMouseMove);
|
|
361
|
+
document.addEventListener('mouseup', handleGlobalMouseUp);
|
|
362
|
+
};
|
|
363
|
+
|
|
364
|
+
// 全局 mousemove 处理 (拖拽选择)
|
|
365
|
+
const handleGlobalMouseMove = (event: MouseEvent): void => {
|
|
366
|
+
if (!isSelecting.value) {
|
|
367
|
+
return;
|
|
368
|
+
}
|
|
369
|
+
const targetCell = event.target as HTMLElement;
|
|
370
|
+
const tdElement = targetCell.closest('td[data-cell]') as HTMLElement;
|
|
371
|
+
if (tdElement) {
|
|
372
|
+
const cellId = tdElement.dataset.cell;
|
|
373
|
+
if (cellId && cellId !== selectionEnd.value) {
|
|
374
|
+
selectionEnd.value = cellId;
|
|
375
|
+
updateSelectionRange(selectionStart.value!, cellId);
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
};
|
|
379
|
+
|
|
380
|
+
// 全局 mouseup 处理 (结束拖拽)
|
|
381
|
+
const handleGlobalMouseUp = (): void => {
|
|
382
|
+
isSelecting.value = false;
|
|
383
|
+
document.removeEventListener('mousemove', handleGlobalMouseMove);
|
|
384
|
+
document.removeEventListener('mouseup', handleGlobalMouseUp);
|
|
385
|
+
};
|
|
386
|
+
|
|
387
|
+
// 使单元格获得焦点 (主要用于键盘导航)
|
|
388
|
+
const focusCell = (cellId: CellId): void => {
|
|
389
|
+
selectedCell.value = cellId;
|
|
390
|
+
// 如果没有选区,初始化一个单单元格选区
|
|
391
|
+
if (selectionRange.value.size === 0 || !selectionRange.value.has(cellId)) {
|
|
392
|
+
initializeSingleSelection(cellId);
|
|
393
|
+
}
|
|
394
|
+
};
|
|
395
|
+
|
|
396
|
+
// 开始编辑单元格
|
|
397
|
+
const startEditing = (cellId: CellId, initialInput: string | null = null): void => {
|
|
398
|
+
const node = document.querySelector(`[data-cell='${cellId}']`);
|
|
399
|
+
if (node?.classList.contains('cell-disabled')) {
|
|
400
|
+
return;
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
// 编辑时,只编辑活动单元格,不编辑整个选区
|
|
404
|
+
selectedCell.value = cellId;
|
|
405
|
+
editingCell.value = cellId;
|
|
406
|
+
|
|
407
|
+
if (initialInput !== null) {
|
|
408
|
+
updateCellContent(cellId, '');
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
nextTick(() => {
|
|
412
|
+
const inputs = inputRef.value;
|
|
413
|
+
if (Array.isArray(inputs)) {
|
|
414
|
+
const input = inputs.find((inp) => (inp?.parentNode as HTMLElement)?.closest('td')?.dataset?.cell === cellId);
|
|
415
|
+
if (input) {
|
|
416
|
+
input.focus();
|
|
417
|
+
if (initialInput !== null && initialInput !== 'Backspace' && initialInput !== 'Delete') {
|
|
418
|
+
input.value = initialInput;
|
|
419
|
+
const inputEvent = new Event('input', { bubbles: true });
|
|
420
|
+
input.dispatchEvent(inputEvent);
|
|
421
|
+
} else {
|
|
422
|
+
input.select();
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
});
|
|
427
|
+
};
|
|
428
|
+
|
|
429
|
+
// 停止编辑
|
|
430
|
+
const stopEditing = (): void => {
|
|
431
|
+
editingCell.value = null;
|
|
432
|
+
tableRef.value?.focus();
|
|
433
|
+
};
|
|
434
|
+
|
|
435
|
+
// 处理 Enter 键 (编辑中)
|
|
436
|
+
const handleEnter = (): void => {
|
|
437
|
+
if (isComposing.value) {
|
|
438
|
+
return;
|
|
439
|
+
}
|
|
440
|
+
|
|
441
|
+
stopEditing();
|
|
442
|
+
const parsed = parseCellId(selectedCell.value);
|
|
443
|
+
if (parsed && parsed.row < props.rowCount) {
|
|
444
|
+
const nextCellId = `${parsed.row + 1}-${parsed.col}`;
|
|
445
|
+
// 普通导航,不扩展选区
|
|
446
|
+
initializeSingleSelection(nextCellId);
|
|
447
|
+
}
|
|
448
|
+
};
|
|
449
|
+
|
|
450
|
+
// 处理单元格内的键盘事件
|
|
451
|
+
const handleCellKeydown = (event: KeyboardEvent): void => {
|
|
452
|
+
// const { key } = event;
|
|
453
|
+
// const parsed = parseCellId(selectedCell.value);
|
|
454
|
+
// if (!parsed || !selectionStart.value) return;
|
|
455
|
+
// 在编辑状态下,方向键和Tab也用于导航,但会先停止编辑
|
|
456
|
+
// if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Tab'].includes(key)) {
|
|
457
|
+
// event.preventDefault();
|
|
458
|
+
// stopEditing();
|
|
459
|
+
// return;
|
|
460
|
+
// }
|
|
461
|
+
// 其他键由输入框处理
|
|
462
|
+
};
|
|
463
|
+
|
|
464
|
+
// 处理表格级别的键盘事件 (方向键导航和字符输入)
|
|
465
|
+
const handleKeydown = (event: KeyboardEvent): void => {
|
|
466
|
+
const { key, shiftKey, ctrlKey, metaKey, altKey } = event;
|
|
467
|
+
const parsed = parseCellId(selectedCell.value);
|
|
468
|
+
if (!parsed || !selectionStart.value) {
|
|
469
|
+
return;
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
// 如果正在编辑,让单元格内的输入框处理事件
|
|
473
|
+
if (editingCell.value) {
|
|
474
|
+
return;
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
// 检查是否是常见的快捷键 (Ctrl/Command + C, V, X, A 等)
|
|
478
|
+
const isCtrlCmd = ctrlKey || metaKey;
|
|
479
|
+
if (isCtrlCmd) {
|
|
480
|
+
// 阻止浏览器的默认复制/粘贴/剪切行为,由我们自己处理
|
|
481
|
+
if (['c', 'v', 'x', 'a'].includes(key.toLowerCase())) {
|
|
482
|
+
// event.preventDefault();
|
|
483
|
+
return;
|
|
484
|
+
}
|
|
485
|
+
return;
|
|
486
|
+
}
|
|
487
|
+
|
|
488
|
+
// 检查是否是 Alt 键组合
|
|
489
|
+
if (altKey) {
|
|
490
|
+
return;
|
|
491
|
+
}
|
|
492
|
+
|
|
493
|
+
// 处理方向键导航 (支持 Shift 扩展选区)
|
|
494
|
+
const moveAndSelect = (newRow: number, newCol: number): void => {
|
|
495
|
+
const newCellId = `${newRow}-${newCol}`;
|
|
496
|
+
if (shiftKey) {
|
|
497
|
+
updateSelectionRange(selectionStart.value!, newCellId);
|
|
498
|
+
} else {
|
|
499
|
+
initializeSingleSelection(newCellId);
|
|
500
|
+
}
|
|
501
|
+
};
|
|
502
|
+
|
|
503
|
+
const currentRow = parsed.row;
|
|
504
|
+
const currentCol = parsed.col;
|
|
505
|
+
const currentColIdx = columns.value.indexOf(currentCol);
|
|
506
|
+
|
|
507
|
+
switch (key) {
|
|
508
|
+
case 'ArrowUp':
|
|
509
|
+
event.preventDefault();
|
|
510
|
+
if (currentRow > 1) {
|
|
511
|
+
moveAndSelect(currentRow - 1, currentCol);
|
|
512
|
+
}
|
|
513
|
+
break;
|
|
514
|
+
case 'ArrowDown':
|
|
515
|
+
event.preventDefault();
|
|
516
|
+
if (currentRow < props.rowCount) {
|
|
517
|
+
moveAndSelect(currentRow + 1, currentCol);
|
|
518
|
+
}
|
|
519
|
+
break;
|
|
520
|
+
case 'ArrowLeft':
|
|
521
|
+
event.preventDefault();
|
|
522
|
+
if (currentColIdx > 0) {
|
|
523
|
+
moveAndSelect(currentRow, columns.value[currentColIdx - 1]);
|
|
524
|
+
}
|
|
525
|
+
break;
|
|
526
|
+
case 'ArrowRight':
|
|
527
|
+
event.preventDefault();
|
|
528
|
+
if (currentColIdx < columns.value.length - 1) {
|
|
529
|
+
moveAndSelect(currentRow, columns.value[currentColIdx + 1]);
|
|
530
|
+
}
|
|
531
|
+
break;
|
|
532
|
+
case 'Tab':
|
|
533
|
+
event.preventDefault();
|
|
534
|
+
if (!event.shiftKey && currentColIdx < columns.value.length - 1) {
|
|
535
|
+
moveAndSelect(currentRow, columns.value[currentColIdx + 1]);
|
|
536
|
+
} else if (event.shiftKey && currentColIdx > 0) {
|
|
537
|
+
moveAndSelect(currentRow, columns.value[currentColIdx - 1]);
|
|
538
|
+
} else if (!event.shiftKey && currentRow < props.rowCount) {
|
|
539
|
+
moveAndSelect(currentRow + 1, columns.value[0]);
|
|
540
|
+
} else if (event.shiftKey && currentRow > 1) {
|
|
541
|
+
moveAndSelect(currentRow - 1, columns.value[columns.value.length - 1]);
|
|
542
|
+
}
|
|
543
|
+
break;
|
|
544
|
+
case 'Enter':
|
|
545
|
+
event.preventDefault();
|
|
546
|
+
startEditing(selectedCell.value);
|
|
547
|
+
break;
|
|
548
|
+
default:
|
|
549
|
+
if (key.length === 1) {
|
|
550
|
+
event.preventDefault();
|
|
551
|
+
startEditing(selectedCell.value, key);
|
|
552
|
+
} else if (key === 'Backspace' || key === 'Delete') {
|
|
553
|
+
event.preventDefault();
|
|
554
|
+
selectionRange.value.forEach((cellId) => {
|
|
555
|
+
updateCellContent(cellId, '');
|
|
556
|
+
});
|
|
557
|
+
}
|
|
558
|
+
}
|
|
559
|
+
};
|
|
560
|
+
|
|
561
|
+
// 处理复制 (Copy)
|
|
562
|
+
const handleCopy = (event: ClipboardEvent): void => {
|
|
563
|
+
if (inputRef.value.length) {
|
|
564
|
+
return;
|
|
565
|
+
}
|
|
566
|
+
|
|
567
|
+
event.preventDefault();
|
|
568
|
+
if (selectionRange.value.size === 0) {
|
|
569
|
+
return;
|
|
570
|
+
}
|
|
571
|
+
|
|
572
|
+
let minRow = props.rowCount;
|
|
573
|
+
let maxRow = 1;
|
|
574
|
+
let minCol = colCount.value;
|
|
575
|
+
let maxCol = 1;
|
|
576
|
+
selectionRange.value.forEach((cellId) => {
|
|
577
|
+
const indices = getCellIndices(cellId);
|
|
578
|
+
if (indices) {
|
|
579
|
+
minRow = Math.min(minRow, indices.row);
|
|
580
|
+
maxRow = Math.max(maxRow, indices.row);
|
|
581
|
+
minCol = Math.min(minCol, indices.col);
|
|
582
|
+
maxCol = Math.max(maxCol, indices.col);
|
|
583
|
+
}
|
|
584
|
+
});
|
|
585
|
+
|
|
586
|
+
let clipboardText = '';
|
|
587
|
+
for (let r = minRow; r <= maxRow; r++) {
|
|
588
|
+
const rowCells: string[] = [];
|
|
589
|
+
for (let c = minCol; c <= maxCol; c++) {
|
|
590
|
+
const cellId = getCellId(r, c);
|
|
591
|
+
rowCells.push(cellId ? getCellContent(cellId) : '');
|
|
592
|
+
}
|
|
593
|
+
clipboardText += `${rowCells.join('\t')}\n`;
|
|
594
|
+
}
|
|
595
|
+
clipboardText = clipboardText.slice(0, -1);
|
|
596
|
+
|
|
597
|
+
event.clipboardData?.setData('text/plain', clipboardText);
|
|
598
|
+
};
|
|
599
|
+
|
|
600
|
+
// 处理剪切 (Cut)
|
|
601
|
+
const handleCut = (event: ClipboardEvent): void => {
|
|
602
|
+
if (inputRef.value.length) {
|
|
603
|
+
return;
|
|
604
|
+
}
|
|
605
|
+
|
|
606
|
+
handleCopy(event);
|
|
607
|
+
selectionRange.value.forEach((cellId) => {
|
|
608
|
+
updateCellContent(cellId, '');
|
|
609
|
+
});
|
|
610
|
+
initializeSingleSelection(selectionStart.value!);
|
|
611
|
+
};
|
|
612
|
+
|
|
613
|
+
// 处理粘贴 (Paste)
|
|
614
|
+
const handlePaste = (event: ClipboardEvent): void => {
|
|
615
|
+
if (inputRef.value.length) {
|
|
616
|
+
return;
|
|
617
|
+
}
|
|
618
|
+
|
|
619
|
+
event.preventDefault();
|
|
620
|
+
const clipboardData = event.clipboardData || (window as any).clipboardData;
|
|
621
|
+
const pastedData = clipboardData.getData('text/plain');
|
|
622
|
+
if (!pastedData || selectionRange.value.size === 0) {
|
|
623
|
+
return;
|
|
624
|
+
}
|
|
625
|
+
|
|
626
|
+
const pasteStartParsed = parseCellId(selectedCell.value);
|
|
627
|
+
if (!pasteStartParsed) {
|
|
628
|
+
return;
|
|
629
|
+
}
|
|
630
|
+
|
|
631
|
+
const { row: startRow, col: startCol } = pasteStartParsed;
|
|
632
|
+
const startColIdx = columns.value.indexOf(startCol);
|
|
633
|
+
if (startColIdx === -1) {
|
|
634
|
+
return;
|
|
635
|
+
}
|
|
636
|
+
|
|
637
|
+
// 解析CSV格式的粘贴数据,正确处理双引号包裹的换行文本
|
|
638
|
+
const parseCSVData = (data: string, callback: (rows: string[][]) => void): void => {
|
|
639
|
+
const rows: string[][] = [];
|
|
640
|
+
let currentRow: string[] = [];
|
|
641
|
+
let currentCell = '';
|
|
642
|
+
let insideQuotes = false;
|
|
643
|
+
|
|
644
|
+
const chars = data.split('');
|
|
645
|
+
const skipIndices = new Set<number>(); // 记录需要跳过的索引
|
|
646
|
+
|
|
647
|
+
runLongTask(
|
|
648
|
+
chars,
|
|
649
|
+
(char, i) => {
|
|
650
|
+
// 如果当前索引需要跳过,直接返回
|
|
651
|
+
if (skipIndices.has(i)) {
|
|
652
|
+
return;
|
|
653
|
+
}
|
|
654
|
+
|
|
655
|
+
const nextChar = chars[i + 1];
|
|
656
|
+
|
|
657
|
+
if (char === '"') {
|
|
658
|
+
if (insideQuotes && nextChar === '"') {
|
|
659
|
+
// 转义的双引号 (""),添加一个双引号到单元格内容
|
|
660
|
+
currentCell += '"';
|
|
661
|
+
skipIndices.add(i + 1); // 标记下一个索引需要跳过
|
|
662
|
+
} else {
|
|
663
|
+
// 开始或结束引号
|
|
664
|
+
insideQuotes = !insideQuotes;
|
|
665
|
+
}
|
|
666
|
+
} else if (char === '\t' && !insideQuotes) {
|
|
667
|
+
// 制表符分隔符,且不在引号内
|
|
668
|
+
currentRow.push(currentCell);
|
|
669
|
+
currentCell = '';
|
|
670
|
+
} else if (char === '\n' && !insideQuotes) {
|
|
671
|
+
// 换行符,且不在引号内
|
|
672
|
+
currentRow.push(currentCell);
|
|
673
|
+
if (currentRow.some((cell) => cell.trim() !== '')) {
|
|
674
|
+
rows.push(currentRow);
|
|
675
|
+
}
|
|
676
|
+
currentRow = [];
|
|
677
|
+
currentCell = '';
|
|
678
|
+
} else {
|
|
679
|
+
// 普通字符或引号内的换行
|
|
680
|
+
currentCell += char;
|
|
681
|
+
}
|
|
682
|
+
},
|
|
683
|
+
() => {
|
|
684
|
+
// 处理最后一个单元格和行
|
|
685
|
+
if (currentCell || currentRow.length > 0) {
|
|
686
|
+
currentRow.push(currentCell);
|
|
687
|
+
if (currentRow.some((cell) => cell.trim() !== '')) {
|
|
688
|
+
rows.push(currentRow);
|
|
689
|
+
}
|
|
690
|
+
}
|
|
691
|
+
callback(rows);
|
|
692
|
+
}
|
|
693
|
+
);
|
|
694
|
+
};
|
|
695
|
+
|
|
696
|
+
loading.value = true;
|
|
697
|
+
nextTick(() => {
|
|
698
|
+
parseCSVData(pastedData, (rowsData) => {
|
|
699
|
+
const canUseRow = props.rowCount - startRow + 1; // 粘贴的那一行也可以使用
|
|
700
|
+
if (canUseRow < rowsData.length) {
|
|
701
|
+
props.addRowCount(rowsData.length - canUseRow);
|
|
702
|
+
}
|
|
703
|
+
nextTick(() => {
|
|
704
|
+
// 构建新的cells对象,随后一次性赋值 O(n) => O(1) 响应式更新
|
|
705
|
+
const newCells: Record<CellId, string> = { ...cells.value };
|
|
706
|
+
|
|
707
|
+
rowsData.forEach((cellsData, rowOffset) => {
|
|
708
|
+
let currentColOffset = 0;
|
|
709
|
+
cellsData.forEach((cellData) => {
|
|
710
|
+
const targetRowIdx = startRow + rowOffset - 1;
|
|
711
|
+
const targetColIdx = startColIdx + currentColOffset;
|
|
712
|
+
|
|
713
|
+
if (targetColIdx < columns.value.length && tableHeaderValues.value[targetColIdx].readonly) {
|
|
714
|
+
currentColOffset++;
|
|
715
|
+
return;
|
|
716
|
+
}
|
|
717
|
+
|
|
718
|
+
if (targetRowIdx < props.rowCount && targetColIdx < columns.value.length) {
|
|
719
|
+
const targetCellId = `${targetRowIdx + 1}-${columns.value[targetColIdx]}`;
|
|
720
|
+
newCells[targetCellId] = cellData.trim();
|
|
721
|
+
}
|
|
722
|
+
currentColOffset++;
|
|
723
|
+
});
|
|
724
|
+
});
|
|
725
|
+
|
|
726
|
+
cells.value = newCells;
|
|
727
|
+
hasChangeCellValue.value = true;
|
|
728
|
+
|
|
729
|
+
initializeSingleSelection(selectedCell.value);
|
|
730
|
+
if (editingCell.value) {
|
|
731
|
+
stopEditing();
|
|
732
|
+
}
|
|
733
|
+
loading.value = false;
|
|
734
|
+
});
|
|
735
|
+
});
|
|
736
|
+
});
|
|
737
|
+
};
|
|
738
|
+
const convertCellsToArray = (obj: Record<CellId, string>) => {
|
|
739
|
+
const result = [] as (string | null)[][];
|
|
740
|
+
const rows = new Set();
|
|
741
|
+
let maxRow = 0;
|
|
742
|
+
let maxCol = 0;
|
|
743
|
+
|
|
744
|
+
// 收集所有行号和列号,并计算最大行和最大列
|
|
745
|
+
Object.keys(obj).forEach((key) => {
|
|
746
|
+
const [row, col] = key.split('-').map(Number);
|
|
747
|
+
rows.add(row);
|
|
748
|
+
if (row > maxRow) {
|
|
749
|
+
maxRow = row;
|
|
750
|
+
}
|
|
751
|
+
if (col > maxCol) {
|
|
752
|
+
maxCol = col;
|
|
753
|
+
}
|
|
754
|
+
});
|
|
755
|
+
|
|
756
|
+
// 从第1行到最大行,依次处理
|
|
757
|
+
for (let row = 1; row <= maxRow; row++) {
|
|
758
|
+
const currentRow = [] as (string | null)[];
|
|
759
|
+
// 从第1列到最大列,检查是否存在该键
|
|
760
|
+
for (let col = 1; col <= maxCol; col++) {
|
|
761
|
+
const key = `${row}-${col}`;
|
|
762
|
+
currentRow.push(obj.hasOwnProperty(key) ? obj[key] : null);
|
|
763
|
+
}
|
|
764
|
+
result.push(currentRow);
|
|
765
|
+
}
|
|
766
|
+
|
|
767
|
+
return result;
|
|
768
|
+
};
|
|
769
|
+
|
|
770
|
+
defineExpose({
|
|
771
|
+
getOriginCells() {
|
|
772
|
+
return cells.value;
|
|
773
|
+
},
|
|
774
|
+
getCells() {
|
|
775
|
+
return convertCellsToArray(cells.value);
|
|
776
|
+
},
|
|
777
|
+
getTableHeaderValues() {
|
|
778
|
+
const fields: TableFieldOption[] = [];
|
|
779
|
+
for (const tableHeaderValue of tableHeaderValues.value) {
|
|
780
|
+
const { value } = tableHeaderValue;
|
|
781
|
+
if (value === NON_CUT) {
|
|
782
|
+
fields.push(tableHeaderValue);
|
|
783
|
+
} else {
|
|
784
|
+
const target = props.fields.find((v) => v.field === value);
|
|
785
|
+
if (target) {
|
|
786
|
+
fields.push(target);
|
|
787
|
+
}
|
|
788
|
+
}
|
|
789
|
+
}
|
|
790
|
+
return fields;
|
|
791
|
+
},
|
|
792
|
+
setCells(value) {
|
|
793
|
+
cells.value = value;
|
|
794
|
+
},
|
|
795
|
+
getCellStatus() {
|
|
796
|
+
return hasChangeCellValue.value;
|
|
797
|
+
},
|
|
798
|
+
resetExcel() {
|
|
799
|
+
cells.value = {};
|
|
800
|
+
selectedCell.value = '';
|
|
801
|
+
editingCell.value = null;
|
|
802
|
+
selectionStart.value = null;
|
|
803
|
+
selectionEnd.value = null;
|
|
804
|
+
selectionRange.value = new Set();
|
|
805
|
+
hasChangeCellValue.value = false;
|
|
806
|
+
tableHeaderValues.value = [];
|
|
807
|
+
initTableHeaderValues();
|
|
808
|
+
}
|
|
809
|
+
});
|
|
810
|
+
|
|
811
|
+
// ======== 生命周期 =========
|
|
812
|
+
onMounted(() => {
|
|
813
|
+
tableRef.value?.focus();
|
|
814
|
+
initializeSingleSelection('1-A');
|
|
815
|
+
});
|
|
816
|
+
|
|
817
|
+
// 组件卸载时清理事件监听器
|
|
818
|
+
onUnmounted(() => {
|
|
819
|
+
document.removeEventListener('mousemove', handleGlobalMouseMove);
|
|
820
|
+
document.removeEventListener('mouseup', handleGlobalMouseUp);
|
|
821
|
+
});
|
|
822
|
+
</script>
|
|
823
|
+
|
|
824
|
+
<style lang="scss">
|
|
825
|
+
.quick-fill-excel-container {
|
|
826
|
+
width: 100%;
|
|
827
|
+
height: 415px;
|
|
828
|
+
overflow: auto;
|
|
829
|
+
|
|
830
|
+
.excel-table {
|
|
831
|
+
border-collapse: collapse;
|
|
832
|
+
table-layout: fixed;
|
|
833
|
+
width: 100%;
|
|
834
|
+
outline: none;
|
|
835
|
+
|
|
836
|
+
th,
|
|
837
|
+
td {
|
|
838
|
+
background-image: linear-gradient(var(--oio-table-row-body-border), var(--oio-table-row-body-border)),
|
|
839
|
+
linear-gradient(var(--oio-table-row-body-border), var(--oio-table-row-body-border));
|
|
840
|
+
padding: 0;
|
|
841
|
+
margin: 0;
|
|
842
|
+
text-align: left;
|
|
843
|
+
vertical-align: top;
|
|
844
|
+
background-repeat: no-repeat;
|
|
845
|
+
background-size: 1px 100%, 100% 1px;
|
|
846
|
+
background-position: 100% 0, 100% 100%;
|
|
847
|
+
box-sizing: border-box;
|
|
848
|
+
}
|
|
849
|
+
|
|
850
|
+
.corner-cell {
|
|
851
|
+
background-color: var(--oio-table-thead-bg);
|
|
852
|
+
text-align: center;
|
|
853
|
+
width: 40px;
|
|
854
|
+
position: sticky;
|
|
855
|
+
top: 0;
|
|
856
|
+
left: 0;
|
|
857
|
+
z-index: 12;
|
|
858
|
+
}
|
|
859
|
+
|
|
860
|
+
.column-header {
|
|
861
|
+
background-color: var(--oio-table-thead-bg);
|
|
862
|
+
text-align: center;
|
|
863
|
+
height: 40px;
|
|
864
|
+
position: sticky;
|
|
865
|
+
top: 0;
|
|
866
|
+
z-index: 11;
|
|
867
|
+
user-select: none;
|
|
868
|
+
padding: 4px;
|
|
869
|
+
}
|
|
870
|
+
|
|
871
|
+
.row-header {
|
|
872
|
+
background-color: #fff;
|
|
873
|
+
text-align: center;
|
|
874
|
+
width: 40px;
|
|
875
|
+
line-height: 40px;
|
|
876
|
+
position: sticky;
|
|
877
|
+
left: 0;
|
|
878
|
+
color: var(--oio-text-color-secondary);
|
|
879
|
+
z-index: 10;
|
|
880
|
+
user-select: none;
|
|
881
|
+
|
|
882
|
+
&.cell-disabled {
|
|
883
|
+
cursor: not-allowed;
|
|
884
|
+
background-color: var(--oio-table-thead-bg);
|
|
885
|
+
color: var(--oio-disabled-color);
|
|
886
|
+
}
|
|
887
|
+
}
|
|
888
|
+
|
|
889
|
+
.cell {
|
|
890
|
+
position: relative;
|
|
891
|
+
cursor: default;
|
|
892
|
+
|
|
893
|
+
&.selected {
|
|
894
|
+
border: 1px solid var(--oio-primary-color);
|
|
895
|
+
z-index: 5;
|
|
896
|
+
}
|
|
897
|
+
|
|
898
|
+
&.range-selected {
|
|
899
|
+
border: 1px solid var(--oio-primary-color);
|
|
900
|
+
}
|
|
901
|
+
|
|
902
|
+
&.editing {
|
|
903
|
+
z-index: 2;
|
|
904
|
+
}
|
|
905
|
+
|
|
906
|
+
&.cell-disabled {
|
|
907
|
+
cursor: not-allowed;
|
|
908
|
+
background-color: var(--oio-table-thead-bg);
|
|
909
|
+
color: var(--oio-disabled-color);
|
|
910
|
+
}
|
|
911
|
+
|
|
912
|
+
.cell-content {
|
|
913
|
+
display: block;
|
|
914
|
+
padding: 5px 8px;
|
|
915
|
+
width: 100%;
|
|
916
|
+
height: 100%;
|
|
917
|
+
box-sizing: border-box;
|
|
918
|
+
white-space: nowrap;
|
|
919
|
+
overflow: hidden;
|
|
920
|
+
text-overflow: ellipsis;
|
|
921
|
+
outline: none;
|
|
922
|
+
display: flex;
|
|
923
|
+
align-items: center;
|
|
924
|
+
}
|
|
925
|
+
|
|
926
|
+
&:focus-visible {
|
|
927
|
+
outline: none;
|
|
928
|
+
}
|
|
929
|
+
}
|
|
930
|
+
|
|
931
|
+
.cell-input {
|
|
932
|
+
position: absolute;
|
|
933
|
+
top: 2px;
|
|
934
|
+
left: 2px;
|
|
935
|
+
right: 2px;
|
|
936
|
+
bottom: 2px;
|
|
937
|
+
border: none;
|
|
938
|
+
padding: 5px 7px;
|
|
939
|
+
margin: 0;
|
|
940
|
+
font: inherit;
|
|
941
|
+
box-sizing: border-box;
|
|
942
|
+
outline: none;
|
|
943
|
+
z-index: 10;
|
|
944
|
+
}
|
|
945
|
+
|
|
946
|
+
&.excel-table-selecting {
|
|
947
|
+
user-select: none;
|
|
948
|
+
}
|
|
949
|
+
}
|
|
950
|
+
}
|
|
951
|
+
</style>
|