my-common-zzp 0.0.1
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/README.md +24 -0
- package/esm2022/lib/ag-grid/AgGridSubPageBase.mjs +138 -0
- package/esm2022/lib/ag-grid/AgGridSubPageBaseEx.mjs +274 -0
- package/esm2022/lib/ag-grid/DEFAULT_COL_DEF.mjs +109 -0
- package/esm2022/lib/ag-grid/FIX_COLDEFS.mjs +23 -0
- package/esm2022/lib/ag-grid/ag-gird-toolbar/component.mjs +110 -0
- package/esm2022/lib/ag-grid/index.mjs +49 -0
- package/esm2022/lib/component/_componentBase.mjs +104 -0
- package/esm2022/lib/component/_objectPageBase.mjs +14 -0
- package/esm2022/lib/component/_subPageBase.mjs +49 -0
- package/esm2022/lib/component/_subPageBaseEx.mjs +117 -0
- package/esm2022/lib/component/_viewStateServiceBase.mjs +212 -0
- package/esm2022/lib/component/_viewStateServiceBaseEx.mjs +173 -0
- package/esm2022/lib/component/_workListBase.mjs +68 -0
- package/esm2022/lib/component/fullScreenDot.mjs +134 -0
- package/esm2022/lib/component/index.mjs +11 -0
- package/esm2022/lib/component/object-headerBase.mjs +297 -0
- package/esm2022/lib/component/object-pageBase.mjs +135 -0
- package/esm2022/lib/component/viewStateService/GetDefaultObjectPageActions.mjs +21 -0
- package/esm2022/lib/component/viewStateService/ILayoutSetting.mjs +2 -0
- package/esm2022/lib/component/viewStateService/IObjectHeader.mjs +2 -0
- package/esm2022/lib/component/viewStateService/IObjectPage.mjs +2 -0
- package/esm2022/lib/component/viewStateService/IObjectPageLayoutSetting.mjs +2 -0
- package/esm2022/lib/component/viewStateService/IViewStateService.mjs +2 -0
- package/esm2022/lib/component/viewStateService/IWorkListLayoutSetting.mjs +2 -0
- package/esm2022/lib/component/work-listBase.mjs +220 -0
- package/esm2022/lib/formly-config/formlyModuleConfig.mjs +74 -0
- package/esm2022/lib/formly-config/index.mjs +8 -0
- package/esm2022/lib/formly-config/types/avatar/component.mjs +206 -0
- package/esm2022/lib/formly-config/types/avatar/cropImageModal/component.mjs +294 -0
- package/esm2022/lib/formly-config/types/avatar/cropImageModal/data.mjs +70 -0
- package/esm2022/lib/formly-config/types/avatar/cropImageModal/method.mjs +239 -0
- package/esm2022/lib/formly-config/types/buttonType.mjs +302 -0
- package/esm2022/lib/formly-config/types/checkbox.mjs +83 -0
- package/esm2022/lib/formly-config/types/date/date-range.mjs +152 -0
- package/esm2022/lib/formly-config/types/date/date.mjs +148 -0
- package/esm2022/lib/formly-config/types/date/method.mjs +53 -0
- package/esm2022/lib/formly-config/types/display-text.mjs +120 -0
- package/esm2022/lib/formly-config/types/input/Input-percent-number.mjs +128 -0
- package/esm2022/lib/formly-config/types/input/input-number.mjs +183 -0
- package/esm2022/lib/formly-config/types/input/input-text.mjs +83 -0
- package/esm2022/lib/formly-config/types/input/input-textarea.mjs +128 -0
- package/esm2022/lib/formly-config/types/pickup.mjs +186 -0
- package/esm2022/lib/formly-config/types/select/addNewModal.mjs +170 -0
- package/esm2022/lib/formly-config/types/select/checkbox-group.mjs +242 -0
- package/esm2022/lib/formly-config/types/select/radio-group.mjs +165 -0
- package/esm2022/lib/formly-config/types/select/select/component.mjs +211 -0
- package/esm2022/lib/formly-config/types/select/select-cascader.mjs +138 -0
- package/esm2022/lib/formly-config/types/select/select-multi-ex/component.mjs +321 -0
- package/esm2022/lib/formly-config/types/select/select-multi.mjs +204 -0
- package/esm2022/lib/formly-config/types/select/switch-group.mjs +251 -0
- package/esm2022/lib/formly-config/utils/DISPLAYFIELD.mjs +13 -0
- package/esm2022/lib/formly-config/utils/VALUEFIELD.mjs +9 -0
- package/esm2022/lib/formly-config/utils/createFormlyField.mjs +216 -0
- package/esm2022/lib/formly-config/utils/formlyField.mjs +18 -0
- package/esm2022/lib/formly-config/utils/formlyField.utils.mjs +97 -0
- package/esm2022/lib/formly-config/validators/index.mjs +164 -0
- package/esm2022/lib/formly-config/validators/regular.mjs +10 -0
- package/esm2022/lib/formly-config/wrappers/collapseWrapper.mjs +37 -0
- package/esm2022/lib/formly-config/wrappers/label-horizontal.mjs +52 -0
- package/esm2022/lib/formly-config/wrappers/label-vertical.mjs +234 -0
- package/esm2022/lib/formly-config/wrappers/navRepeatWrapper.mjs +199 -0
- package/esm2022/lib/formly-config/wrappers/repeatWrapper.mjs +71 -0
- package/esm2022/lib/formly-config/wrappers/sectionWrapper.mjs +55 -0
- package/esm2022/lib/formly-config/wrappers/separatorWrapper.mjs +21 -0
- package/esm2022/lib/grid-config/editor/date/date.mjs +159 -0
- package/esm2022/lib/grid-config/editor/input/input-number-type.mjs +67 -0
- package/esm2022/lib/grid-config/editor/input/input-text-type.mjs +67 -0
- package/esm2022/lib/grid-config/editor/pickup/ag-grid-pickup.mjs +170 -0
- package/esm2022/lib/grid-config/editor/select/select-type.mjs +115 -0
- package/esm2022/lib/grid-config/index.mjs +11 -0
- package/esm2022/lib/grid-config/renderer/action/component.mjs +161 -0
- package/esm2022/lib/grid-config/renderer/codeMap.mjs +44 -0
- package/esm2022/lib/grid-config/renderer/date.mjs +33 -0
- package/esm2022/lib/grid-config/renderer/number.mjs +37 -0
- package/esm2022/lib/grid-config/type.mjs +2 -0
- package/esm2022/lib/material.module.mjs +188 -0
- package/esm2022/lib/ngZorroAntd.module.mjs +301 -0
- package/esm2022/lib/service/GeneralServiceBase.mjs +10 -0
- package/esm2022/lib/service/GlobalStateService.mjs +30 -0
- package/esm2022/lib/service/UserSetting.mjs +31 -0
- package/esm2022/lib/service/_appInjector.mjs +22 -0
- package/esm2022/lib/service/_notificationService.mjs +29 -0
- package/esm2022/lib/service/_storeBase.mjs +581 -0
- package/esm2022/lib/service/application.mjs +135 -0
- package/esm2022/lib/service/index.mjs +12 -0
- package/esm2022/lib/service/inject.token.mjs +10 -0
- package/esm2022/lib/service/layoutService.mjs +282 -0
- package/esm2022/lib/service/model/Criteria.mjs +2 -0
- package/esm2022/lib/service/model/FieldFilterInfo.mjs +11 -0
- package/esm2022/lib/service/model/FilterGroup.mjs +117 -0
- package/esm2022/lib/service/model/Msg.mjs +3 -0
- package/esm2022/lib/service/model/PrepareFilter.mjs +61 -0
- package/esm2022/lib/service/model/createFilterGroups.mjs +24 -0
- package/esm2022/lib/service/model/dialogSetting.mjs +24 -0
- package/esm2022/lib/service/model/index.mjs +7 -0
- package/esm2022/lib/service/staticService.mjs +123 -0
- package/esm2022/lib/service/utils/CreateStoreService.mjs +12 -0
- package/esm2022/lib/service/utils/PrepareCriteria.mjs +60 -0
- package/esm2022/lib/service/utils/SyncEntities.mjs +58 -0
- package/esm2022/lib/service/utils/index.mjs +7 -0
- package/esm2022/lib/service/utils/isValidHttpUrl.mjs +10 -0
- package/esm2022/lib/service/utils/obj2Str.mjs +27 -0
- package/esm2022/lib/service/utils/str2Obj.mjs +25 -0
- package/esm2022/lib/uc/common/barItem.const.mjs +73 -0
- package/esm2022/lib/uc/common/barItem.mjs +3 -0
- package/esm2022/lib/uc/common/index.mjs +8 -0
- package/esm2022/lib/uc/common/node.mjs +2 -0
- package/esm2022/lib/uc/common/state-action.mjs +61 -0
- package/esm2022/lib/uc/common/tableColumn.utils.mjs +108 -0
- package/esm2022/lib/uc/common/tableColumnSetting.const.mjs +155 -0
- package/esm2022/lib/uc/common/tableColumnSetting.mjs +22 -0
- package/esm2022/lib/uc/index.mjs +22 -0
- package/esm2022/lib/uc/uc-date-range/component.mjs +256 -0
- package/esm2022/lib/uc/uc-dialog/ucNzModalContent.Component.mjs +110 -0
- package/esm2022/lib/uc/uc-fields/component.mjs +432 -0
- package/esm2022/lib/uc/uc-fields/data-model.mjs +11 -0
- package/esm2022/lib/uc/uc-fields/fieldsEdit.component.mjs +241 -0
- package/esm2022/lib/uc/uc-fields/fieldsReadonly.component.mjs +85 -0
- package/esm2022/lib/uc/uc-fields/uc-form.component.mjs +157 -0
- package/esm2022/lib/uc/uc-list-filter/uc-list-filterOption.mjs +37 -0
- package/esm2022/lib/uc/uc-list-nav/component.mjs +106 -0
- package/esm2022/lib/uc/uc-list-table/component.mjs +102 -0
- package/esm2022/lib/uc/uc-list-table/readExcel.mjs +99 -0
- package/esm2022/lib/uc/uc-list-table/table.component.mjs +473 -0
- package/esm2022/lib/uc/uc-list-tree/component.mjs +130 -0
- package/esm2022/lib/uc/uc-list-tree/readExcel.mjs +99 -0
- package/esm2022/lib/uc/uc-list-tree/table.component.mjs +650 -0
- package/esm2022/lib/uc/uc-list-tree/tableColumnSetting.mjs +145 -0
- package/esm2022/lib/uc/uc-nav-list/component.mjs +67 -0
- package/esm2022/lib/uc/uc-nav1/uc-nav1.component.mjs +196 -0
- package/esm2022/lib/uc/uc-perfect-scrollbar/component.mjs +112 -0
- package/esm2022/lib/uc/uc-pickup-window/colDefs.mjs +515 -0
- package/esm2022/lib/uc/uc-pickup-window/component.mjs +359 -0
- package/esm2022/lib/uc/uc-pickup-window/header.component.mjs +158 -0
- package/esm2022/lib/uc/uc-subheader/component.mjs +35 -0
- package/esm2022/lib/uc/uc-title-nav/animations.mjs +121 -0
- package/esm2022/lib/uc/uc-title-nav/component.mjs +289 -0
- package/esm2022/lib/uc/uc-toolbar/component.mjs +76 -0
- package/esm2022/lib/ucModel.mjs +469 -0
- package/esm2022/lib/utils/I18nService.mjs +37 -0
- package/esm2022/lib/utils/allowEdit.directive.mjs +20 -0
- package/esm2022/lib/utils/applyFilter.mjs +153 -0
- package/esm2022/lib/utils/canDeactivate.mjs +16 -0
- package/esm2022/lib/utils/confirmClick.directive.mjs +49 -0
- package/esm2022/lib/utils/datetimeUtils.mjs +31 -0
- package/esm2022/lib/utils/formatNumberT.mjs +36 -0
- package/esm2022/lib/utils/getColumnByLabel.mjs +15 -0
- package/esm2022/lib/utils/getDateAbbr.mjs +69 -0
- package/esm2022/lib/utils/getObjectPropertyValue.mjs +16 -0
- package/esm2022/lib/utils/getUniqueIdWithPrefix.mjs +17 -0
- package/esm2022/lib/utils/getValueChanges.mjs +85 -0
- package/esm2022/lib/utils/getViewPort.mjs +16 -0
- package/esm2022/lib/utils/index.mjs +58 -0
- package/esm2022/lib/utils/message-utils.mjs +108 -0
- package/esm2022/lib/utils/modal-utils.mjs +144 -0
- package/esm2022/lib/utils/ro.directive.mjs +44 -0
- package/esm2022/lib/utils/saveAsExcel.mjs +17 -0
- package/esm2022/lib/utils/time-elapsed.pipe.mjs +94 -0
- package/esm2022/my-common-zzp.mjs +5 -0
- package/esm2022/my-common.mjs +5 -0
- package/esm2022/public-api.mjs +11 -0
- package/fesm2022/my-common-zzp.mjs +16169 -0
- package/fesm2022/my-common-zzp.mjs.map +1 -0
- package/fesm2022/my-common.mjs +16169 -0
- package/fesm2022/my-common.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/ag-grid/AgGridSubPageBase.d.ts +53 -0
- package/lib/ag-grid/AgGridSubPageBaseEx.d.ts +69 -0
- package/lib/ag-grid/DEFAULT_COL_DEF.d.ts +2 -0
- package/lib/ag-grid/FIX_COLDEFS.d.ts +2 -0
- package/lib/ag-grid/ag-gird-toolbar/component.d.ts +33 -0
- package/lib/ag-grid/index.d.ts +9 -0
- package/lib/component/_componentBase.d.ts +73 -0
- package/lib/component/_objectPageBase.d.ts +16 -0
- package/lib/component/_subPageBase.d.ts +27 -0
- package/lib/component/_subPageBaseEx.d.ts +54 -0
- package/lib/component/_viewStateServiceBase.d.ts +128 -0
- package/lib/component/_viewStateServiceBaseEx.d.ts +123 -0
- package/lib/component/_workListBase.d.ts +24 -0
- package/lib/component/fullScreenDot.d.ts +26 -0
- package/lib/component/index.d.ts +10 -0
- package/lib/component/object-headerBase.d.ts +26 -0
- package/lib/component/object-pageBase.d.ts +30 -0
- package/lib/component/viewStateService/GetDefaultObjectPageActions.d.ts +4 -0
- package/lib/component/viewStateService/ILayoutSetting.d.ts +15 -0
- package/lib/component/viewStateService/IObjectHeader.d.ts +18 -0
- package/lib/component/viewStateService/IObjectPage.d.ts +15 -0
- package/lib/component/viewStateService/IObjectPageLayoutSetting.d.ts +39 -0
- package/lib/component/viewStateService/IViewStateService.d.ts +24 -0
- package/lib/component/viewStateService/IWorkListLayoutSetting.d.ts +20 -0
- package/lib/component/work-listBase.d.ts +38 -0
- package/lib/formly-config/formlyModuleConfig.d.ts +102 -0
- package/lib/formly-config/index.d.ts +6 -0
- package/lib/formly-config/types/avatar/component.d.ts +30 -0
- package/lib/formly-config/types/avatar/cropImageModal/component.d.ts +53 -0
- package/lib/formly-config/types/avatar/cropImageModal/data.d.ts +21 -0
- package/lib/formly-config/types/avatar/cropImageModal/method.d.ts +28 -0
- package/lib/formly-config/types/buttonType.d.ts +18 -0
- package/lib/formly-config/types/checkbox.d.ts +14 -0
- package/lib/formly-config/types/date/date-range.d.ts +18 -0
- package/lib/formly-config/types/date/date.d.ts +19 -0
- package/lib/formly-config/types/date/method.d.ts +3 -0
- package/lib/formly-config/types/display-text.d.ts +17 -0
- package/lib/formly-config/types/input/Input-percent-number.d.ts +19 -0
- package/lib/formly-config/types/input/input-number.d.ts +22 -0
- package/lib/formly-config/types/input/input-text.d.ts +13 -0
- package/lib/formly-config/types/input/input-textarea.d.ts +25 -0
- package/lib/formly-config/types/pickup.d.ts +46 -0
- package/lib/formly-config/types/select/addNewModal.d.ts +29 -0
- package/lib/formly-config/types/select/checkbox-group.d.ts +25 -0
- package/lib/formly-config/types/select/radio-group.d.ts +19 -0
- package/lib/formly-config/types/select/select/component.d.ts +40 -0
- package/lib/formly-config/types/select/select-cascader.d.ts +43 -0
- package/lib/formly-config/types/select/select-multi-ex/component.d.ts +44 -0
- package/lib/formly-config/types/select/select-multi.d.ts +25 -0
- package/lib/formly-config/types/select/switch-group.d.ts +31 -0
- package/lib/formly-config/utils/DISPLAYFIELD.d.ts +11 -0
- package/lib/formly-config/utils/VALUEFIELD.d.ts +7 -0
- package/lib/formly-config/utils/createFormlyField.d.ts +8 -0
- package/lib/formly-config/utils/formlyField.d.ts +53 -0
- package/lib/formly-config/utils/formlyField.utils.d.ts +43 -0
- package/lib/formly-config/validators/index.d.ts +72 -0
- package/lib/formly-config/validators/regular.d.ts +9 -0
- package/lib/formly-config/wrappers/collapseWrapper.d.ts +6 -0
- package/lib/formly-config/wrappers/label-horizontal.d.ts +7 -0
- package/lib/formly-config/wrappers/label-vertical.d.ts +25 -0
- package/lib/formly-config/wrappers/navRepeatWrapper.d.ts +18 -0
- package/lib/formly-config/wrappers/repeatWrapper.d.ts +7 -0
- package/lib/formly-config/wrappers/sectionWrapper.d.ts +6 -0
- package/lib/formly-config/wrappers/separatorWrapper.d.ts +6 -0
- package/lib/grid-config/editor/date/date.d.ts +37 -0
- package/lib/grid-config/editor/input/input-number-type.d.ts +18 -0
- package/lib/grid-config/editor/input/input-text-type.d.ts +15 -0
- package/lib/grid-config/editor/pickup/ag-grid-pickup.d.ts +47 -0
- package/lib/grid-config/editor/select/select-type.d.ts +25 -0
- package/lib/grid-config/index.d.ts +9 -0
- package/lib/grid-config/renderer/action/component.d.ts +28 -0
- package/lib/grid-config/renderer/codeMap.d.ts +15 -0
- package/lib/grid-config/renderer/date.d.ts +12 -0
- package/lib/grid-config/renderer/number.d.ts +12 -0
- package/lib/grid-config/type.d.ts +7 -0
- package/lib/material.module.d.ts +49 -0
- package/lib/ngZorroAntd.module.d.ts +78 -0
- package/lib/service/GeneralServiceBase.d.ts +14 -0
- package/lib/service/GlobalStateService.d.ts +16 -0
- package/lib/service/UserSetting.d.ts +16 -0
- package/lib/service/_appInjector.d.ts +14 -0
- package/lib/service/_notificationService.d.ts +13 -0
- package/lib/service/_storeBase.d.ts +232 -0
- package/lib/service/application.d.ts +61 -0
- package/lib/service/index.d.ts +11 -0
- package/lib/service/inject.token.d.ts +3 -0
- package/lib/service/layoutService.d.ts +61 -0
- package/lib/service/model/Criteria.d.ts +20 -0
- package/lib/service/model/FieldFilterInfo.d.ts +9 -0
- package/lib/service/model/FilterGroup.d.ts +43 -0
- package/lib/service/model/Msg.d.ts +5 -0
- package/lib/service/model/PrepareFilter.d.ts +11 -0
- package/lib/service/model/createFilterGroups.d.ts +17 -0
- package/lib/service/model/dialogSetting.d.ts +29 -0
- package/lib/service/model/index.d.ts +7 -0
- package/lib/service/staticService.d.ts +23 -0
- package/lib/service/utils/CreateStoreService.d.ts +7 -0
- package/lib/service/utils/PrepareCriteria.d.ts +22 -0
- package/lib/service/utils/SyncEntities.d.ts +1 -0
- package/lib/service/utils/index.d.ts +6 -0
- package/lib/service/utils/isValidHttpUrl.d.ts +1 -0
- package/lib/service/utils/obj2Str.d.ts +8 -0
- package/lib/service/utils/str2Obj.d.ts +7 -0
- package/lib/uc/common/barItem.const.d.ts +27 -0
- package/lib/uc/common/barItem.d.ts +14 -0
- package/lib/uc/common/index.d.ts +7 -0
- package/lib/uc/common/node.d.ts +6 -0
- package/lib/uc/common/state-action.d.ts +42 -0
- package/lib/uc/common/tableColumn.utils.d.ts +3 -0
- package/lib/uc/common/tableColumnSetting.const.d.ts +55 -0
- package/lib/uc/common/tableColumnSetting.d.ts +127 -0
- package/lib/uc/index.d.ts +21 -0
- package/lib/uc/uc-date-range/component.d.ts +34 -0
- package/lib/uc/uc-dialog/ucNzModalContent.Component.d.ts +19 -0
- package/lib/uc/uc-fields/component.d.ts +74 -0
- package/lib/uc/uc-fields/data-model.d.ts +61 -0
- package/lib/uc/uc-fields/fieldsEdit.component.d.ts +44 -0
- package/lib/uc/uc-fields/fieldsReadonly.component.d.ts +14 -0
- package/lib/uc/uc-fields/uc-form.component.d.ts +27 -0
- package/lib/uc/uc-list-filter/uc-list-filterOption.d.ts +11 -0
- package/lib/uc/uc-list-nav/component.d.ts +32 -0
- package/lib/uc/uc-list-table/component.d.ts +34 -0
- package/lib/uc/uc-list-table/readExcel.d.ts +21 -0
- package/lib/uc/uc-list-table/table.component.d.ts +95 -0
- package/lib/uc/uc-list-tree/component.d.ts +44 -0
- package/lib/uc/uc-list-tree/readExcel.d.ts +21 -0
- package/lib/uc/uc-list-tree/table.component.d.ts +124 -0
- package/lib/uc/uc-list-tree/tableColumnSetting.d.ts +113 -0
- package/lib/uc/uc-nav-list/component.d.ts +24 -0
- package/lib/uc/uc-nav1/uc-nav1.component.d.ts +28 -0
- package/lib/uc/uc-perfect-scrollbar/component.d.ts +26 -0
- package/lib/uc/uc-pickup-window/colDefs.d.ts +561 -0
- package/lib/uc/uc-pickup-window/component.d.ts +68 -0
- package/lib/uc/uc-pickup-window/header.component.d.ts +27 -0
- package/lib/uc/uc-subheader/component.d.ts +15 -0
- package/lib/uc/uc-title-nav/animations.d.ts +22 -0
- package/lib/uc/uc-title-nav/component.d.ts +32 -0
- package/lib/uc/uc-toolbar/component.d.ts +19 -0
- package/lib/ucModel.d.ts +84 -0
- package/lib/utils/I18nService.d.ts +14 -0
- package/lib/utils/allowEdit.directive.d.ts +10 -0
- package/lib/utils/applyFilter.d.ts +8 -0
- package/lib/utils/canDeactivate.d.ts +11 -0
- package/lib/utils/confirmClick.directive.d.ts +14 -0
- package/lib/utils/datetimeUtils.d.ts +10 -0
- package/lib/utils/formatNumberT.d.ts +8 -0
- package/lib/utils/getColumnByLabel.d.ts +8 -0
- package/lib/utils/getDateAbbr.d.ts +6 -0
- package/lib/utils/getObjectPropertyValue.d.ts +7 -0
- package/lib/utils/getUniqueIdWithPrefix.d.ts +7 -0
- package/lib/utils/getValueChanges.d.ts +15 -0
- package/lib/utils/getViewPort.d.ts +4 -0
- package/lib/utils/index.d.ts +22 -0
- package/lib/utils/message-utils.d.ts +33 -0
- package/lib/utils/modal-utils.d.ts +19 -0
- package/lib/utils/ro.directive.d.ts +12 -0
- package/lib/utils/saveAsExcel.d.ts +1 -0
- package/lib/utils/time-elapsed.pipe.d.ts +42 -0
- package/package.json +26 -0
- package/public-api.d.ts +10 -0
package/README.md
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
# MyCommon
|
|
2
|
+
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 18.1.0.
|
|
4
|
+
|
|
5
|
+
## Code scaffolding
|
|
6
|
+
|
|
7
|
+
Run `ng generate component component-name --project my-common` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project my-common`.
|
|
8
|
+
> Note: Don't forget to add `--project my-common` or else it will be added to the default project in your `angular.json` file.
|
|
9
|
+
|
|
10
|
+
## Build
|
|
11
|
+
|
|
12
|
+
Run `ng build my-common` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
13
|
+
|
|
14
|
+
## Publishing
|
|
15
|
+
|
|
16
|
+
After building your library with `ng build my-common`, go to the dist folder `cd dist/my-common` and run `npm publish`.
|
|
17
|
+
|
|
18
|
+
## Running unit tests
|
|
19
|
+
|
|
20
|
+
Run `ng test my-common` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
21
|
+
|
|
22
|
+
## Further help
|
|
23
|
+
|
|
24
|
+
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.dev/tools/cli) page.
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
//#region
|
|
2
|
+
import { Directive, signal, ViewChild } from '@angular/core';
|
|
3
|
+
import _ from 'lodash';
|
|
4
|
+
import { ComponentBase, } from '../component';
|
|
5
|
+
import { DEFAULT_COL_DEF } from './DEFAULT_COL_DEF';
|
|
6
|
+
import { AgGridToolbarComponent } from './ag-gird-toolbar/component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../component";
|
|
9
|
+
//#endregion
|
|
10
|
+
/**
|
|
11
|
+
* 只读的 AG-GRID
|
|
12
|
+
*/
|
|
13
|
+
export class AgGridSubPageBase extends ComponentBase {
|
|
14
|
+
constructor(vss = null) {
|
|
15
|
+
super();
|
|
16
|
+
this.vss = vss;
|
|
17
|
+
// 列表所有数据
|
|
18
|
+
this.dataRows = [];
|
|
19
|
+
//页面ID
|
|
20
|
+
this.pageId = '';
|
|
21
|
+
// toolbar 变量
|
|
22
|
+
this.allowShowCheckbox = true;
|
|
23
|
+
this.columnDefs = [];
|
|
24
|
+
this.gridOptions = {
|
|
25
|
+
//columnDefs: colDefs,
|
|
26
|
+
defaultColDef: DEFAULT_COL_DEF,
|
|
27
|
+
rowSelection: 'multiple',
|
|
28
|
+
onRowClicked: this.onRowClicked.bind(this),
|
|
29
|
+
onSelectionChanged: this.onSelectionChanged.bind(this),
|
|
30
|
+
};
|
|
31
|
+
// 加总列数据计算
|
|
32
|
+
this.pinnedBottomRowData = [];
|
|
33
|
+
//#region 行选择、取消选择 相关功能
|
|
34
|
+
this.selectedRowsCount = signal(0); // 微变量
|
|
35
|
+
this._previousMasterId = 0;
|
|
36
|
+
this._previousRowData = [];
|
|
37
|
+
}
|
|
38
|
+
onGridReady(params) {
|
|
39
|
+
this.gridApi = params.api;
|
|
40
|
+
this.gridApi.addEventListener('cellKeyDown', this.onCellKeyDown.bind(this));
|
|
41
|
+
}
|
|
42
|
+
// 用于即时验证、保存单元格数据以及更新依赖单元格的其他组件。
|
|
43
|
+
onCellEditingStopped(event) { }
|
|
44
|
+
// 行修改事件,用于批量处理数据、同步整个数据集、刷新统计数据等,粗粒度,处理整行或整个数据集的变化
|
|
45
|
+
onRowDataUpdated(event) {
|
|
46
|
+
// 获取所有的数据
|
|
47
|
+
const rowData = this.getAllGridData();
|
|
48
|
+
//console.log('onRowDataUpdated');
|
|
49
|
+
// 计算总计行
|
|
50
|
+
const totalRow = rowData.reduce((acc, row) => {
|
|
51
|
+
return {
|
|
52
|
+
name: 'Total',
|
|
53
|
+
description: acc.description + 1,
|
|
54
|
+
};
|
|
55
|
+
}, { name: 'Total', description: 0 });
|
|
56
|
+
this.pinnedBottomRowData = [totalRow];
|
|
57
|
+
// 更新旧数据状态
|
|
58
|
+
this._previousRowData = _.cloneDeep(rowData);
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* 通过 UI HOT-KEY 处理新增删除拖拽编辑数据
|
|
62
|
+
* 注册各种热键操作
|
|
63
|
+
* @param event
|
|
64
|
+
*/
|
|
65
|
+
onCellKeyDown(event) { }
|
|
66
|
+
onRowClicked(event) {
|
|
67
|
+
// 单选情况下,点击选择,并取消之前的选择
|
|
68
|
+
if (!this.allowShowCheckbox) {
|
|
69
|
+
//console.log(event.node);
|
|
70
|
+
event.node.setSelected(true, true);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
cancelSelected() {
|
|
74
|
+
// 取消选择所有行
|
|
75
|
+
this.gridApi.deselectAll();
|
|
76
|
+
//this.gridApi.getSelectedNodes().map((node) => node.setSelected(false));
|
|
77
|
+
}
|
|
78
|
+
onSelectionChanged(event) {
|
|
79
|
+
this.selectedRowsCount.update(() => this.gridApi.getSelectedNodes().length);
|
|
80
|
+
}
|
|
81
|
+
//#endregion
|
|
82
|
+
//sortByConfigs = [];
|
|
83
|
+
menuItemClick(params = undefined) {
|
|
84
|
+
// 排序相关操作
|
|
85
|
+
if ('sort' in params) {
|
|
86
|
+
// todo: 'code,name:desc' 字符串转成数组的模式
|
|
87
|
+
const sortCols = [].concat(params['sort']);
|
|
88
|
+
this.gridApi.applyColumnState({
|
|
89
|
+
state: sortCols,
|
|
90
|
+
applyOrder: false,
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* 读取所有数据
|
|
96
|
+
* @returns
|
|
97
|
+
*/
|
|
98
|
+
getAllGridData() {
|
|
99
|
+
const rowData = [];
|
|
100
|
+
this.gridApi?.forEachNode((node) => rowData.push(node.data));
|
|
101
|
+
return rowData;
|
|
102
|
+
}
|
|
103
|
+
//#region 数据更新
|
|
104
|
+
agGridSetData(list) {
|
|
105
|
+
// id 不相同,则更新,
|
|
106
|
+
if (this._previousMasterId !== this.vss.masterModel.id) {
|
|
107
|
+
this.dataRows = list;
|
|
108
|
+
//this.gridApi.refreshCells(); //.setRowData(this.rowData); // 更新表格数据
|
|
109
|
+
this._previousMasterId = this.vss.masterModel.id;
|
|
110
|
+
this._previousRowData = _.cloneDeep(list);
|
|
111
|
+
}
|
|
112
|
+
// 如果相同,且已提交,则刷新
|
|
113
|
+
else if (this.dataStore.isDirty === false) {
|
|
114
|
+
this.dataRows = list;
|
|
115
|
+
//this.gridApi.redrawRows();
|
|
116
|
+
this._previousRowData = _.cloneDeep(list);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
//#endregion
|
|
120
|
+
onAgGridToolbarClick(event) {
|
|
121
|
+
if (event.actionCode === 'CANCEL_SELECT') {
|
|
122
|
+
this.cancelSelected();
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
// 在组件销毁时移除全局点击事件监听器
|
|
126
|
+
ngOnDestroy() {
|
|
127
|
+
console.log('SubPageBaseExt Destroy...');
|
|
128
|
+
}
|
|
129
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AgGridSubPageBase, deps: [{ token: i1.ViewStateServiceBaseEx }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
130
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.0", type: AgGridSubPageBase, viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["agGridToolbar"], descendants: true, read: AgGridToolbarComponent }], usesInheritance: true, ngImport: i0 }); }
|
|
131
|
+
}
|
|
132
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AgGridSubPageBase, decorators: [{
|
|
133
|
+
type: Directive
|
|
134
|
+
}], ctorParameters: () => [{ type: i1.ViewStateServiceBaseEx }], propDecorators: { toolbar: [{
|
|
135
|
+
type: ViewChild,
|
|
136
|
+
args: ['agGridToolbar', { read: AgGridToolbarComponent }]
|
|
137
|
+
}] } });
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AgGridSubPageBase.js","sourceRoot":"","sources":["../../../../../projects/my-common/src/lib/ag-grid/AgGridSubPageBase.ts"],"names":[],"mappings":"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","sourcesContent":["//#region\r\nimport { Directive, signal, ViewChild } from '@angular/core';\r\nimport {\r\n    ColDef,\r\n    GridApi,\r\n    GridReadyEvent,\r\n    RowDataUpdatedEvent,\r\n    SelectionChangedEvent,\r\n} from 'ag-grid-community';\r\nimport _ from 'lodash';\r\n\r\nimport {\r\n    ComponentBase,\r\n    ViewStateServiceBaseEx,\r\n} from '../component';\r\nimport { DEFAULT_COL_DEF } from './DEFAULT_COL_DEF';\r\nimport { AgGridToolbarComponent } from './ag-gird-toolbar/component';\r\nimport { IStoreBase } from '../service';\r\n\r\n//#endregion\r\n\r\n/**\r\n * 只读的 AG-GRID\r\n */\r\n@Directive()\r\nexport abstract class AgGridSubPageBase extends ComponentBase {\r\n    // 当前行数据\r\n    currModel;\r\n    // 增删改服务\r\n    dataStore: IStoreBase;\r\n    // 列表所有数据\r\n    dataRows = [];\r\n\r\n    //页面ID\r\n    pageId = '';\r\n\r\n    // toolbar 变量\r\n    allowShowCheckbox = true;\r\n    //allowSortable = false;\r\n    //allowFilter = false;\r\n\r\n    @ViewChild('agGridToolbar', { read: AgGridToolbarComponent })\r\n    protected toolbar!: AgGridToolbarComponent;\r\n\r\n    protected gridApi!: GridApi<any>;\r\n    protected columnDefs: ColDef[] = [];\r\n    protected gridOptions = {\r\n        //columnDefs: colDefs,\r\n        defaultColDef: DEFAULT_COL_DEF,\r\n        rowSelection: 'multiple',\r\n        onRowClicked: this.onRowClicked.bind(this),\r\n        onSelectionChanged: this.onSelectionChanged.bind(this),\r\n    };\r\n\r\n    constructor(public vss: ViewStateServiceBaseEx = null) {\r\n        super();\r\n    }\r\n\r\n    protected onGridReady(params: GridReadyEvent) {\r\n        this.gridApi = params.api;\r\n        this.gridApi.addEventListener(\r\n            'cellKeyDown',\r\n            this.onCellKeyDown.bind(this)\r\n        );\r\n    }\r\n\r\n    // 用于即时验证、保存单元格数据以及更新依赖单元格的其他组件。\r\n    protected onCellEditingStopped(event) {}\r\n\r\n    // 加总列数据计算\r\n    pinnedBottomRowData = [];\r\n    // 行修改事件，用于批量处理数据、同步整个数据集、刷新统计数据等,粗粒度，处理整行或整个数据集的变化\r\n    protected onRowDataUpdated(event: RowDataUpdatedEvent) {\r\n        // 获取所有的数据\r\n        const rowData = this.getAllGridData();\r\n\r\n        //console.log('onRowDataUpdated');\r\n\r\n        // 计算总计行\r\n        const totalRow = rowData.reduce(\r\n            (acc, row) => {\r\n                return {\r\n                    name: 'Total',\r\n                    description: acc.description + 1,\r\n                };\r\n            },\r\n            { name: 'Total', description: 0 }\r\n        );\r\n        this.pinnedBottomRowData = [totalRow];\r\n\r\n        // 更新旧数据状态\r\n        this._previousRowData = _.cloneDeep(rowData);\r\n    }\r\n    /**\r\n     * 通过 UI HOT-KEY 处理新增删除拖拽编辑数据\r\n     * 注册各种热键操作\r\n     * @param event\r\n     */\r\n    protected onCellKeyDown(event: any) {}\r\n\r\n    //#region 行选择、取消选择 相关功能\r\n\r\n    selectedRowsCount = signal(0); // 微变量\r\n    protected onRowClicked(event) {\r\n        // 单选情况下，点击选择,并取消之前的选择\r\n        if (!this.allowShowCheckbox) {\r\n            //console.log(event.node);\r\n            event.node.setSelected(true, true);\r\n        }\r\n    }\r\n    protected cancelSelected() {\r\n        // 取消选择所有行\r\n        this.gridApi.deselectAll();\r\n        //this.gridApi.getSelectedNodes().map((node) => node.setSelected(false));\r\n    }\r\n\r\n    protected onSelectionChanged(event: SelectionChangedEvent) {\r\n        this.selectedRowsCount.update(\r\n            () => this.gridApi.getSelectedNodes().length\r\n        );\r\n    }\r\n\r\n    //#endregion\r\n\r\n    //sortByConfigs = [];\r\n\r\n    protected menuItemClick(params: any = undefined) {\r\n        // 排序相关操作\r\n        if ('sort' in params) {\r\n            // todo: 'code,name:desc' 字符串转成数组的模式\r\n            const sortCols = [].concat(params['sort']);\r\n            this.gridApi.applyColumnState({\r\n                state: sortCols,\r\n                applyOrder: false,\r\n            });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * 读取所有数据\r\n     * @returns\r\n     */\r\n    protected getAllGridData(): any[] {\r\n        const rowData: any[] = [];\r\n        this.gridApi?.forEachNode((node) => rowData.push(node.data));\r\n        return rowData;\r\n    }\r\n\r\n    //#region 数据更新\r\n    protected agGridSetData(list) {\r\n        // id 不相同，则更新，\r\n        if (this._previousMasterId !== this.vss.masterModel.id) {\r\n            this.dataRows = list;\r\n            //this.gridApi.refreshCells(); //.setRowData(this.rowData); // 更新表格数据\r\n            this._previousMasterId = this.vss.masterModel.id;\r\n            this._previousRowData = _.cloneDeep(list);\r\n        }\r\n        // 如果相同，且已提交，则刷新\r\n        else if (this.dataStore.isDirty === false) {\r\n            this.dataRows = list;\r\n            //this.gridApi.redrawRows();\r\n            this._previousRowData = _.cloneDeep(list);\r\n        }\r\n    }\r\n    protected _previousMasterId = 0;\r\n    protected _previousRowData = [];\r\n    //#endregion\r\n\r\n    protected onAgGridToolbarClick(event) {\r\n        if (event.actionCode === 'CANCEL_SELECT') {\r\n            this.cancelSelected();\r\n        }\r\n    }\r\n\r\n    // 在组件销毁时移除全局点击事件监听器\r\n    ngOnDestroy() {\r\n        console.log('SubPageBaseExt Destroy...');\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,274 @@
|
|
|
1
|
+
/***
|
|
2
|
+
* ag-grid 缺省功能: 增删改、拖拽
|
|
3
|
+
* 1、每个栏位都可以编辑,存档
|
|
4
|
+
* 2、tab 键到最后一行最后一列,自动新增一行
|
|
5
|
+
* 3、新增 + 按钮、在当前位置新增一行
|
|
6
|
+
* 4、快捷键 shift+insert, 当前行上方插入新行
|
|
7
|
+
* 5、快捷键 ctrl+d, 删除当前行
|
|
8
|
+
* 6、删除选择行
|
|
9
|
+
* 7、拖拽排序并存档(需要设定 lineCodeField) *
|
|
10
|
+
* 8、自定义编辑控件
|
|
11
|
+
* 9、自定义渲染控件
|
|
12
|
+
* 10、分组栏位第二行不显示
|
|
13
|
+
* 11、赠品、配件、主要标记
|
|
14
|
+
* 12、加总区域
|
|
15
|
+
*
|
|
16
|
+
* ag-grid toolbar
|
|
17
|
+
* 1、已选择行数、取消选择功能
|
|
18
|
+
* 2、取消编辑
|
|
19
|
+
* 3、多选开启或关闭
|
|
20
|
+
* 4、拖拽开启或关闭
|
|
21
|
+
* 5、新增
|
|
22
|
+
* 6、存档
|
|
23
|
+
*/
|
|
24
|
+
//#region
|
|
25
|
+
import { Directive } from '@angular/core';
|
|
26
|
+
import { AgGridSubPageBase } from './AgGridSubPageBase';
|
|
27
|
+
import { calcFloatStepValue } from './index';
|
|
28
|
+
import { AppInjector, Application } from '../service';
|
|
29
|
+
import * as i0 from "@angular/core";
|
|
30
|
+
import * as i1 from "../component";
|
|
31
|
+
//#endregion
|
|
32
|
+
export class AgGridSubPageBaseEx extends AgGridSubPageBase {
|
|
33
|
+
constructor(vss) {
|
|
34
|
+
super(vss);
|
|
35
|
+
this.vss = vss;
|
|
36
|
+
this.App = AppInjector.get(Application);
|
|
37
|
+
//lineCode
|
|
38
|
+
this.lineCodeField = '';
|
|
39
|
+
}
|
|
40
|
+
onGridReady(params) {
|
|
41
|
+
this.gridApi = params.api;
|
|
42
|
+
this.gridApi.addEventListener('cellKeyDown', this.onCellKeyDown.bind(this));
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* 通过 UI HOT-KEY 处理新增删除拖拽编辑数据
|
|
46
|
+
* 注册各种热键操作
|
|
47
|
+
* @param event
|
|
48
|
+
*/
|
|
49
|
+
onCellKeyDown(event) {
|
|
50
|
+
if (event.event.code === 'Tab' && this.isLastCell(event)) {
|
|
51
|
+
// 新增至末尾
|
|
52
|
+
event.event.preventDefault();
|
|
53
|
+
this.addNewRow();
|
|
54
|
+
}
|
|
55
|
+
else if (event.event.ctrlKey && event.event.key === 'Insert') {
|
|
56
|
+
// 当前位置新增
|
|
57
|
+
event.event.preventDefault();
|
|
58
|
+
this.addNewRow(event.node.rowIndex);
|
|
59
|
+
}
|
|
60
|
+
else if (event.event.ctrlKey && event.event.key === 'd') {
|
|
61
|
+
// 删除当前笔
|
|
62
|
+
event.event.preventDefault();
|
|
63
|
+
this.deleteSelectedRow(event.node);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
cellClicked(e) {
|
|
67
|
+
this.currRowIndex = e.rowIndex;
|
|
68
|
+
this.currModel = e.data;
|
|
69
|
+
}
|
|
70
|
+
onCellValueChanged(event) { }
|
|
71
|
+
// 用于即时验证、保存单元格数据以及更新依赖单元格的其他组件。
|
|
72
|
+
onCellEditingStopped(event) {
|
|
73
|
+
//console.log(event);
|
|
74
|
+
if (event.valueChanged) {
|
|
75
|
+
//console.log(event);
|
|
76
|
+
if (!this.validateField()) {
|
|
77
|
+
this.App.notify('提示', '请在提交或取消编辑后执行此操作');
|
|
78
|
+
this.gridApi.startEditingCell({
|
|
79
|
+
rowIndex: event.rowIndex,
|
|
80
|
+
colKey: event.column.colId,
|
|
81
|
+
});
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const field = event.colDef.field;
|
|
85
|
+
// 需要更新,否则订阅流的相关方法不会执行
|
|
86
|
+
this.dataStore.update(event.data.id, {
|
|
87
|
+
[field]: event.value,
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* 指定位置新增,并设定焦点
|
|
93
|
+
* @param indexToAdd
|
|
94
|
+
*/
|
|
95
|
+
addNewRow(indexToAdd = -1) {
|
|
96
|
+
this.currModel = this.addNew();
|
|
97
|
+
const params = {
|
|
98
|
+
add: [this.currModel],
|
|
99
|
+
};
|
|
100
|
+
// 在特定位置新增
|
|
101
|
+
indexToAdd > -1 && (params.addIndex = indexToAdd);
|
|
102
|
+
const transactionResult = this.gridApi.applyTransaction(params);
|
|
103
|
+
if (transactionResult.add) {
|
|
104
|
+
// 根据插入位置,设定row 对象序号
|
|
105
|
+
this.calcNewSeqValue(transactionResult.add[0], this.getAllGridData());
|
|
106
|
+
console.log(transactionResult.add[0]);
|
|
107
|
+
// 获取新添加行的最大索引
|
|
108
|
+
const maxIndex = Math.max(...transactionResult.add.map((rowNode) => rowNode.rowIndex));
|
|
109
|
+
// 设定焦点
|
|
110
|
+
this.gridApi.ensureIndexVisible(maxIndex);
|
|
111
|
+
this.gridApi.setFocusedCell(maxIndex, 'code');
|
|
112
|
+
}
|
|
113
|
+
this.dataStore.add(this.currModel);
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* 删除当前行 或者 选择行,并重新设置焦点
|
|
117
|
+
* @param node
|
|
118
|
+
*/
|
|
119
|
+
deleteSelectedRow(node) {
|
|
120
|
+
const selectedNodes = node ? [node] : this.gridApi.getSelectedNodes();
|
|
121
|
+
const selectedData = selectedNodes.map((node) => node.data);
|
|
122
|
+
const lastRemovedRowIndex = selectedNodes[selectedNodes.length - 1].rowIndex;
|
|
123
|
+
const transactionResult = this.gridApi.applyTransaction({
|
|
124
|
+
remove: selectedData,
|
|
125
|
+
});
|
|
126
|
+
selectedData.forEach((row) => this.dataStore.remove(row));
|
|
127
|
+
// this.gridApi.refreshCells({ force: true });
|
|
128
|
+
// 设置焦点
|
|
129
|
+
if (transactionResult.remove.length > 0) {
|
|
130
|
+
let focusIndex;
|
|
131
|
+
if (lastRemovedRowIndex < this.gridApi.getDisplayedRowCount() - 1) {
|
|
132
|
+
focusIndex = lastRemovedRowIndex; // Focus on the next row
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
focusIndex = lastRemovedRowIndex - 1; // Focus on the previous row
|
|
136
|
+
}
|
|
137
|
+
if (focusIndex >= 0) {
|
|
138
|
+
this.gridApi.ensureIndexVisible(focusIndex);
|
|
139
|
+
this.gridApi.setFocusedCell(focusIndex, 'code');
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* 拖拽后 设定行序号
|
|
145
|
+
* @param event
|
|
146
|
+
*/
|
|
147
|
+
onRowDragEnd(event) {
|
|
148
|
+
if (!this.lineCodeField)
|
|
149
|
+
return;
|
|
150
|
+
const rowData = [];
|
|
151
|
+
event.api.forEachNode((node) => rowData.push(node.data));
|
|
152
|
+
// 计算拖拽后行的 seq 值
|
|
153
|
+
this.calcNewSeqValue(event.node, rowData);
|
|
154
|
+
//console.log(rowData);
|
|
155
|
+
// 更新到后台
|
|
156
|
+
this.dataStore.update(event.node.data.id, {
|
|
157
|
+
[this.lineCodeField]: event.node.data[this.lineCodeField],
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
onAgGridToolbarClick(event) {
|
|
161
|
+
super.onAgGridToolbarClick(event);
|
|
162
|
+
// 一般增、删改、操作
|
|
163
|
+
if (event.actionCode === 'ADD_NEWROW') {
|
|
164
|
+
this.addNewRow();
|
|
165
|
+
}
|
|
166
|
+
else if (event.actionCode === 'DELETE_SELECT') {
|
|
167
|
+
this.deleteSelectedRow();
|
|
168
|
+
}
|
|
169
|
+
else if (event.actionCode === 'CANCEL_EDIT') {
|
|
170
|
+
this.dataStore.cancel();
|
|
171
|
+
}
|
|
172
|
+
else if (event.actionCode === 'MENUITEM_CLICK') {
|
|
173
|
+
this.menuItemClick(event.params);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
//sortByConfigs = [];
|
|
177
|
+
menuItemClick(params = undefined) {
|
|
178
|
+
// 排序相关操作
|
|
179
|
+
if ('sort' in params) {
|
|
180
|
+
// todo: 'code,name:desc' 字符串转成数组的模式
|
|
181
|
+
const sortCols = [].concat(params['sort']);
|
|
182
|
+
this.gridApi.applyColumnState({
|
|
183
|
+
state: sortCols,
|
|
184
|
+
applyOrder: false,
|
|
185
|
+
});
|
|
186
|
+
//此处的排序,是需要存档的,下次载入就是按照这个顺序。
|
|
187
|
+
const rowNodes = this.gridApi.getRenderedNodes();
|
|
188
|
+
const sortedData = rowNodes.map((rowNode) => rowNode.data);
|
|
189
|
+
this.calcNewSeqValue2(sortedData);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
// 校验所有
|
|
193
|
+
validate() {
|
|
194
|
+
return true;
|
|
195
|
+
}
|
|
196
|
+
validateField() {
|
|
197
|
+
return true;
|
|
198
|
+
}
|
|
199
|
+
validateObject() {
|
|
200
|
+
return true;
|
|
201
|
+
}
|
|
202
|
+
validateList() {
|
|
203
|
+
return true;
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* 判断 cell 是否为 最右下
|
|
207
|
+
* @param event
|
|
208
|
+
* @returns
|
|
209
|
+
*/
|
|
210
|
+
isLastCell(event) {
|
|
211
|
+
const displayedRowCount = this.gridApi.getDisplayedRowCount();
|
|
212
|
+
const lastRowIndex = displayedRowCount - 1;
|
|
213
|
+
// Get all visible columns
|
|
214
|
+
const allColumns = this.gridApi.getAllDisplayedColumns();
|
|
215
|
+
const lastColumnIndex = allColumns.length - 1;
|
|
216
|
+
const columnIndex = allColumns.indexOf(event.column);
|
|
217
|
+
return (event.rowIndex === lastRowIndex && columnIndex === lastColumnIndex);
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* node.seq = 前后笔之差,取最大步进,100,10,1,0.1
|
|
221
|
+
* @param node
|
|
222
|
+
* @param rows
|
|
223
|
+
* @returns
|
|
224
|
+
*/
|
|
225
|
+
calcNewSeqValue(draggedNode, rows) {
|
|
226
|
+
if (!this.lineCodeField)
|
|
227
|
+
return;
|
|
228
|
+
const draggedIndex = draggedNode.rowIndex;
|
|
229
|
+
// 仅一笔
|
|
230
|
+
let newSeq = 1;
|
|
231
|
+
// 多笔的情况下,重新赋值
|
|
232
|
+
if (rows.length >= 2) {
|
|
233
|
+
// 如果拖拽到第一行
|
|
234
|
+
if (draggedIndex === 0) {
|
|
235
|
+
newSeq = parseFloat(rows[1][this.lineCodeField]);
|
|
236
|
+
newSeq = calcFloatStepValue(newSeq);
|
|
237
|
+
}
|
|
238
|
+
// 如果拖拽到最后一行
|
|
239
|
+
else if (draggedIndex === rows.length - 1) {
|
|
240
|
+
newSeq =
|
|
241
|
+
parseFloat(rows[rows.length - 2][this.lineCodeField]) + 1;
|
|
242
|
+
}
|
|
243
|
+
// 多行的中间
|
|
244
|
+
else if (rows.length >= 3) {
|
|
245
|
+
const prevSeq = parseFloat(rows[draggedIndex - 1][this.lineCodeField]);
|
|
246
|
+
const nextSeq = parseFloat(rows[draggedIndex + 1][this.lineCodeField]);
|
|
247
|
+
newSeq = prevSeq + calcFloatStepValue(nextSeq - prevSeq);
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
// 更新拖拽后行的 seq 值
|
|
251
|
+
draggedNode.data[this.lineCodeField] = newSeq;
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* node.seq = 重新排序,1,2,3...
|
|
255
|
+
* @param node
|
|
256
|
+
* @param rows
|
|
257
|
+
* @returns
|
|
258
|
+
*/
|
|
259
|
+
calcNewSeqValue2(rows) {
|
|
260
|
+
if (this.lineCodeField)
|
|
261
|
+
rows.forEach((row, index) => {
|
|
262
|
+
row[this.lineCodeField] = index + 1; // 或者根据你的需求重新排序
|
|
263
|
+
this.dataStore.update(row.id, {
|
|
264
|
+
[this.lineCodeField]: row[this.lineCodeField],
|
|
265
|
+
});
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AgGridSubPageBaseEx, deps: [{ token: i1.ViewStateServiceBaseEx }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
269
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.0", type: AgGridSubPageBaseEx, usesInheritance: true, ngImport: i0 }); }
|
|
270
|
+
}
|
|
271
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: AgGridSubPageBaseEx, decorators: [{
|
|
272
|
+
type: Directive
|
|
273
|
+
}], ctorParameters: () => [{ type: i1.ViewStateServiceBaseEx }] });
|
|
274
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AgGridSubPageBaseEx.js","sourceRoot":"","sources":["../../../../../projects/my-common/src/lib/ag-grid/AgGridSubPageBaseEx.ts"],"names":[],"mappings":"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","sourcesContent":["/***\r\n * ag-grid 缺省功能: 增删改、拖拽\r\n * 1、每个栏位都可以编辑，存档\r\n * 2、tab 键到最后一行最后一列，自动新增一行\r\n * 3、新增 + 按钮、在当前位置新增一行\r\n * 4、快捷键 shift+insert, 当前行上方插入新行\r\n * 5、快捷键 ctrl+d, 删除当前行\r\n * 6、删除选择行\r\n * 7、拖拽排序并存档(需要设定 lineCodeField) *\r\n * 8、自定义编辑控件\r\n * 9、自定义渲染控件\r\n * 10、分组栏位第二行不显示\r\n * 11、赠品、配件、主要标记\r\n * 12、加总区域\r\n *\r\n * ag-grid toolbar\r\n * 1、已选择行数、取消选择功能\r\n * 2、取消编辑\r\n * 3、多选开启或关闭\r\n * 4、拖拽开启或关闭\r\n * 5、新增\r\n * 6、存档\r\n */\r\n//#region\r\nimport { Directive } from '@angular/core';\r\nimport { GridReadyEvent } from 'ag-grid-community';\r\nimport { AgGridSubPageBase } from './AgGridSubPageBase';\r\nimport { calcFloatStepValue } from './index';\r\nimport { AppInjector, Application } from '../service';\r\nimport { ViewStateServiceBaseEx } from '../component';\r\n\r\n//#endregion\r\n\r\n@Directive()\r\nexport abstract class AgGridSubPageBaseEx extends AgGridSubPageBase {\r\n    public App = AppInjector.get(Application);\r\n    //lineCode\r\n    lineCodeField = '';\r\n\r\n    constructor(public vss: ViewStateServiceBaseEx) {\r\n        super(vss);\r\n    }\r\n\r\n    protected onGridReady(params: GridReadyEvent) {\r\n        this.gridApi = params.api;\r\n        this.gridApi.addEventListener(\r\n            'cellKeyDown',\r\n            this.onCellKeyDown.bind(this)\r\n        );\r\n    }\r\n    /**\r\n     * 通过 UI HOT-KEY 处理新增删除拖拽编辑数据\r\n     * 注册各种热键操作\r\n     * @param event\r\n     */\r\n    protected onCellKeyDown(event: any) {\r\n        if (event.event.code === 'Tab' && this.isLastCell(event)) {\r\n            // 新增至末尾\r\n            event.event.preventDefault();\r\n            this.addNewRow();\r\n        } else if (event.event.ctrlKey && event.event.key === 'Insert') {\r\n            // 当前位置新增\r\n            event.event.preventDefault();\r\n            this.addNewRow(event.node.rowIndex);\r\n        } else if (event.event.ctrlKey && event.event.key === 'd') {\r\n            // 删除当前笔\r\n            event.event.preventDefault();\r\n            this.deleteSelectedRow(event.node);\r\n        }\r\n    }\r\n    // (cellClicked)=\"cellClicked($event)\"\r\n    // (cellValueChanged)=\"onCellValueChanged($event)\"\r\n\r\n    currRowIndex;\r\n\r\n    protected cellClicked(e) {\r\n        this.currRowIndex = e.rowIndex;\r\n        this.currModel = e.data;\r\n    }\r\n    protected onCellValueChanged(event) {}\r\n    // 用于即时验证、保存单元格数据以及更新依赖单元格的其他组件。\r\n    protected onCellEditingStopped(event) {\r\n        //console.log(event);\r\n        if (event.valueChanged) {\r\n            //console.log(event);\r\n            if (!this.validateField()) {\r\n                this.App.notify('提示', '请在提交或取消编辑后执行此操作');\r\n                this.gridApi.startEditingCell({\r\n                    rowIndex: event.rowIndex,\r\n                    colKey: event.column.colId,\r\n                });\r\n                return;\r\n            }\r\n            const field = event.colDef.field;\r\n            // 需要更新，否则订阅流的相关方法不会执行\r\n            this.dataStore.update(event.data.id, {\r\n                [field]: event.value,\r\n            });\r\n        }\r\n    }\r\n    /**\r\n     * 继承类必须自定义新增default字段\r\n     */\r\n    abstract addNew(): object;\r\n    /**\r\n     * 指定位置新增，并设定焦点\r\n     * @param indexToAdd\r\n     */\r\n    addNewRow(indexToAdd = -1) {\r\n        this.currModel = this.addNew();\r\n\r\n        const params: any = {\r\n            add: [this.currModel],\r\n        };\r\n        // 在特定位置新增\r\n        indexToAdd > -1 && (params.addIndex = indexToAdd);\r\n        const transactionResult = this.gridApi.applyTransaction(params);\r\n\r\n        if (transactionResult.add) {\r\n            // 根据插入位置，设定row 对象序号\r\n            this.calcNewSeqValue(\r\n                transactionResult.add[0],\r\n                this.getAllGridData()\r\n            );\r\n            console.log(transactionResult.add[0]);\r\n            // 获取新添加行的最大索引\r\n            const maxIndex = Math.max(\r\n                ...transactionResult.add.map((rowNode) => rowNode.rowIndex)\r\n            );\r\n\r\n            // 设定焦点\r\n            this.gridApi.ensureIndexVisible(maxIndex);\r\n            this.gridApi.setFocusedCell(maxIndex, 'code');\r\n        }\r\n\r\n        this.dataStore.add(this.currModel);\r\n    }\r\n\r\n    /**\r\n     * 删除当前行 或者 选择行，并重新设置焦点\r\n     * @param node\r\n     */\r\n    deleteSelectedRow(node?: any) {\r\n        const selectedNodes = node ? [node] : this.gridApi.getSelectedNodes();\r\n        const selectedData = selectedNodes.map((node) => node.data);\r\n        const lastRemovedRowIndex =\r\n            selectedNodes[selectedNodes.length - 1].rowIndex;\r\n        const transactionResult = this.gridApi.applyTransaction({\r\n            remove: selectedData,\r\n        });\r\n        selectedData.forEach((row) => this.dataStore.remove(row));\r\n        // this.gridApi.refreshCells({ force: true });\r\n\r\n        // 设置焦点\r\n        if (transactionResult.remove.length > 0) {\r\n            let focusIndex;\r\n            if (lastRemovedRowIndex < this.gridApi.getDisplayedRowCount() - 1) {\r\n                focusIndex = lastRemovedRowIndex; // Focus on the next row\r\n            } else {\r\n                focusIndex = lastRemovedRowIndex - 1; // Focus on the previous row\r\n            }\r\n\r\n            if (focusIndex >= 0) {\r\n                this.gridApi.ensureIndexVisible(focusIndex);\r\n                this.gridApi.setFocusedCell(focusIndex, 'code');\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * 拖拽后 设定行序号\r\n     * @param event\r\n     */\r\n    protected onRowDragEnd(event: any) {\r\n        if (!this.lineCodeField) return;\r\n        const rowData = [];\r\n        event.api.forEachNode((node: any) => rowData.push(node.data));\r\n\r\n        // 计算拖拽后行的 seq 值\r\n        this.calcNewSeqValue(event.node, rowData);\r\n        //console.log(rowData);\r\n\r\n        // 更新到后台\r\n        this.dataStore.update(event.node.data.id, {\r\n            [this.lineCodeField]: event.node.data[this.lineCodeField],\r\n        });\r\n    }\r\n\r\n    protected onAgGridToolbarClick(event) {\r\n        super.onAgGridToolbarClick(event);\r\n        // 一般增、删改、操作\r\n        if (event.actionCode === 'ADD_NEWROW') {\r\n            this.addNewRow();\r\n        } else if (event.actionCode === 'DELETE_SELECT') {\r\n            this.deleteSelectedRow();\r\n        } else if (event.actionCode === 'CANCEL_EDIT') {\r\n            this.dataStore.cancel();\r\n        } else if (event.actionCode === 'MENUITEM_CLICK') {\r\n            this.menuItemClick(event.params);\r\n        }\r\n    }\r\n    //sortByConfigs = [];\r\n\r\n    protected menuItemClick(params: any = undefined) {\r\n        // 排序相关操作\r\n        if ('sort' in params) {\r\n            // todo: 'code,name:desc' 字符串转成数组的模式\r\n            const sortCols = [].concat(params['sort']);\r\n            this.gridApi.applyColumnState({\r\n                state: sortCols,\r\n                applyOrder: false,\r\n            });\r\n\r\n            //此处的排序，是需要存档的，下次载入就是按照这个顺序。\r\n            const rowNodes = this.gridApi.getRenderedNodes();\r\n            const sortedData = rowNodes.map((rowNode) => rowNode.data);\r\n            this.calcNewSeqValue2(sortedData);\r\n        }\r\n    }\r\n\r\n    // 校验所有\r\n    validate(): boolean {\r\n        return true;\r\n    }\r\n    validateField(): boolean {\r\n        return true;\r\n    }\r\n    validateObject(): boolean {\r\n        return true;\r\n    }\r\n    validateList(): boolean {\r\n        return true;\r\n    }\r\n\r\n    /**\r\n     * 判断 cell 是否为 最右下\r\n     * @param event\r\n     * @returns\r\n     */\r\n    protected isLastCell(event: any): boolean {\r\n        const displayedRowCount = this.gridApi.getDisplayedRowCount();\r\n        const lastRowIndex = displayedRowCount - 1;\r\n\r\n        // Get all visible columns\r\n        const allColumns = this.gridApi.getAllDisplayedColumns();\r\n        const lastColumnIndex = allColumns.length - 1;\r\n\r\n        const columnIndex = allColumns.indexOf(event.column);\r\n        return (\r\n            event.rowIndex === lastRowIndex && columnIndex === lastColumnIndex\r\n        );\r\n    }\r\n\r\n    /**\r\n     * node.seq = 前后笔之差，取最大步进，100，10，1，0.1\r\n     * @param node\r\n     * @param rows\r\n     * @returns\r\n     */\r\n    protected calcNewSeqValue(draggedNode, rows) {\r\n        if (!this.lineCodeField) return;\r\n\r\n        const draggedIndex = draggedNode.rowIndex;\r\n\r\n        // 仅一笔\r\n        let newSeq = 1;\r\n\r\n        // 多笔的情况下，重新赋值\r\n        if (rows.length >= 2) {\r\n            // 如果拖拽到第一行\r\n            if (draggedIndex === 0) {\r\n                newSeq = parseFloat(rows[1][this.lineCodeField]);\r\n                newSeq = calcFloatStepValue(newSeq);\r\n            }\r\n            // 如果拖拽到最后一行\r\n            else if (draggedIndex === rows.length - 1) {\r\n                newSeq =\r\n                    parseFloat(rows[rows.length - 2][this.lineCodeField]) + 1;\r\n            }\r\n            // 多行的中间\r\n            else if (rows.length >= 3) {\r\n                const prevSeq = parseFloat(\r\n                    rows[draggedIndex - 1][this.lineCodeField]\r\n                );\r\n                const nextSeq = parseFloat(\r\n                    rows[draggedIndex + 1][this.lineCodeField]\r\n                );\r\n                newSeq = prevSeq + calcFloatStepValue(nextSeq - prevSeq);\r\n            }\r\n        }\r\n\r\n        // 更新拖拽后行的 seq 值\r\n        draggedNode.data[this.lineCodeField] = newSeq;\r\n    }\r\n\r\n    /**\r\n     * node.seq = 重新排序，1，2，3...\r\n     * @param node\r\n     * @param rows\r\n     * @returns\r\n     */\r\n    protected calcNewSeqValue2(rows) {\r\n        if (this.lineCodeField)\r\n            rows.forEach((row, index) => {\r\n                row[this.lineCodeField] = index + 1; // 或者根据你的需求重新排序\r\n                this.dataStore.update(row.id, {\r\n                    [this.lineCodeField]: row[this.lineCodeField],\r\n                });\r\n            });\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
// 每一列的缺省属性
|
|
2
|
+
export const DEFAULT_COL_DEF = {
|
|
3
|
+
resizable: true,
|
|
4
|
+
editable: true,
|
|
5
|
+
suppressHeaderMenuButton: true,
|
|
6
|
+
suppressHeaderFilterButton: true,
|
|
7
|
+
sortable: true,
|
|
8
|
+
filter: true,
|
|
9
|
+
// UTF-7 排序
|
|
10
|
+
comparator: (a, b) => {
|
|
11
|
+
if (!a && !b)
|
|
12
|
+
return 0;
|
|
13
|
+
if (!a && b)
|
|
14
|
+
return -1;
|
|
15
|
+
if (a && !b)
|
|
16
|
+
return 1;
|
|
17
|
+
// 中文打头 用中文排序规则 todo: 区分 简体繁体日文韩文
|
|
18
|
+
const chineseCharRegex = /^[\u4E00-\u9FFF\u3400-\u4DBF\uF900-\uFAFF]/;
|
|
19
|
+
const zhHansCNa = chineseCharRegex.test(a);
|
|
20
|
+
const zhHansCNb = chineseCharRegex.test(b);
|
|
21
|
+
if (!zhHansCNa && zhHansCNb) {
|
|
22
|
+
return -1; // 字母排在汉字前面
|
|
23
|
+
}
|
|
24
|
+
if (zhHansCNa && !zhHansCNb) {
|
|
25
|
+
return 1; // 汉字排在字母后面
|
|
26
|
+
}
|
|
27
|
+
// 如果都是字母或都是汉字,按拼音排序
|
|
28
|
+
if (zhHansCNa && zhHansCNb) {
|
|
29
|
+
return a.localeCompare(b, 'zh-Hans-CN', {
|
|
30
|
+
sensitivity: 'base',
|
|
31
|
+
numeric: true,
|
|
32
|
+
ignorePunctuation: true,
|
|
33
|
+
caseFirst: 'upper',
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
return a.localeCompare(b);
|
|
37
|
+
// 仅中文,
|
|
38
|
+
const chineseCharRegex2 = /[\u4E00-\u9FFF\u3400-\u4DBF\uF900-\uFAFF]/;
|
|
39
|
+
const isALetter = !chineseCharRegex2.test(a);
|
|
40
|
+
const isBLetter = !chineseCharRegex2.test(b);
|
|
41
|
+
if (isALetter && isBLetter)
|
|
42
|
+
return a.localeCompare(b);
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
function compareStrings(a, b) {
|
|
46
|
+
if (!a && !b)
|
|
47
|
+
return 0;
|
|
48
|
+
if (!a && b)
|
|
49
|
+
return -1;
|
|
50
|
+
if (a && !b)
|
|
51
|
+
return 1;
|
|
52
|
+
// 判断语言类型
|
|
53
|
+
const getLanguage = (str) => {
|
|
54
|
+
if (/^[\u4E00-\u9FFF\u3400-\u4DBF\uF900-\uFAFF]/.test(str)) {
|
|
55
|
+
// 判断是简体中文还是繁体中文
|
|
56
|
+
if (/^[\u4E00-\u9FFF]/.test(str))
|
|
57
|
+
return 'zh-Hans-CN'; // 简体中文
|
|
58
|
+
return 'zh-Hant-TW'; // 繁体中文
|
|
59
|
+
}
|
|
60
|
+
if (/^[\u3040-\u309F\u30A0-\u30FF]/.test(str))
|
|
61
|
+
return 'ja'; // 日文
|
|
62
|
+
if (/^[\u00C0-\u1EF9]/.test(str))
|
|
63
|
+
return 'vi'; // 越南文
|
|
64
|
+
return 'en'; // 英文或其他
|
|
65
|
+
};
|
|
66
|
+
const langA = getLanguage(a);
|
|
67
|
+
const langB = getLanguage(b);
|
|
68
|
+
if (langA !== langB) {
|
|
69
|
+
// 按语言分组排序
|
|
70
|
+
const languageOrder = ['vi', 'en', 'zh-Hans-CN', 'zh-Hant-TW', 'ja'];
|
|
71
|
+
return languageOrder.indexOf(langA) - languageOrder.indexOf(langB);
|
|
72
|
+
}
|
|
73
|
+
// 同语言按拼音或字母排序
|
|
74
|
+
return a.localeCompare(b, langA, {
|
|
75
|
+
sensitivity: 'base', // 忽略大小写和重音符号
|
|
76
|
+
numeric: true, // 支持数字的自然排序
|
|
77
|
+
ignorePunctuation: true, // 忽略标点符号
|
|
78
|
+
caseFirst: 'upper', // 大写字母优先
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
import { pinyin } from 'pinyin-pro';
|
|
82
|
+
// 中文转拼音函数(支持简体和繁体)
|
|
83
|
+
function convertToPinyin(str) {
|
|
84
|
+
const r = pinyin(str, {
|
|
85
|
+
type: 'array',
|
|
86
|
+
//style: 4, // 带声调
|
|
87
|
+
//heteronym: false, // 不显示多音字
|
|
88
|
+
//returnString: true, // 返回字符串
|
|
89
|
+
});
|
|
90
|
+
return r.flat().join('');
|
|
91
|
+
}
|
|
92
|
+
function getSortKey(str) {
|
|
93
|
+
if (/^[\u4E00-\u9FFF]/.test(str)) {
|
|
94
|
+
return convertToPinyin(str); // 中文转换为拼音
|
|
95
|
+
}
|
|
96
|
+
if (/^[\u3040-\u309F\u30A0-\u30FF]/.test(str)) {
|
|
97
|
+
return str; // 日文直接使用原字符串
|
|
98
|
+
}
|
|
99
|
+
if (/^[\u00C0-\u1EF9]/.test(str)) {
|
|
100
|
+
return str.normalize('NFD').replace(/[\u0300-\u036f]/g, ''); // 越南文标准化
|
|
101
|
+
}
|
|
102
|
+
return str; // 英文或其他
|
|
103
|
+
}
|
|
104
|
+
function compareStringsBySortKey(a, b) {
|
|
105
|
+
const keyA = getSortKey(a);
|
|
106
|
+
const keyB = getSortKey(b);
|
|
107
|
+
return keyA.localeCompare(keyB, 'en'); // 使用英文语言环境比较
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DEFAULT_COL_DEF.js","sourceRoot":"","sources":["../../../../../projects/my-common/src/lib/ag-grid/DEFAULT_COL_DEF.ts"],"names":[],"mappings":"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","sourcesContent":["import { ColDef } from 'ag-grid-community';\r\n\r\n// 每一列的缺省属性\r\nexport const DEFAULT_COL_DEF: ColDef = {\r\n    resizable: true,\r\n    editable: true,\r\n    suppressHeaderMenuButton: true,\r\n    suppressHeaderFilterButton: true,\r\n    sortable: true,\r\n    filter: true,\r\n    // UTF-7 排序\r\n    comparator: (a: string, b: string) => {\r\n        if (!a && !b) return 0;\r\n        if (!a && b) return -1;\r\n        if (a && !b) return 1;\r\n\r\n        // 中文打头 用中文排序规则 todo: 区分 简体繁体日文韩文\r\n        const chineseCharRegex = /^[\\u4E00-\\u9FFF\\u3400-\\u4DBF\\uF900-\\uFAFF]/;\r\n        const zhHansCNa = chineseCharRegex.test(a);\r\n        const zhHansCNb = chineseCharRegex.test(b);\r\n\r\n        if (!zhHansCNa && zhHansCNb) {\r\n            return -1; // 字母排在汉字前面\r\n        }\r\n        if (zhHansCNa && !zhHansCNb) {\r\n            return 1; // 汉字排在字母后面\r\n        }\r\n        // 如果都是字母或都是汉字，按拼音排序\r\n        if (zhHansCNa && zhHansCNb) {\r\n            return a.localeCompare(b, 'zh-Hans-CN', {\r\n                sensitivity: 'base',\r\n                numeric: true,\r\n                ignorePunctuation: true,\r\n                caseFirst: 'upper',\r\n            });\r\n        }\r\n        return a.localeCompare(b);\r\n        // 仅中文，\r\n        const chineseCharRegex2 = /[\\u4E00-\\u9FFF\\u3400-\\u4DBF\\uF900-\\uFAFF]/;\r\n        const isALetter = !chineseCharRegex2.test(a);\r\n        const isBLetter = !chineseCharRegex2.test(b);\r\n        if (isALetter && isBLetter) return a.localeCompare(b);\r\n    },\r\n};\r\n\r\nfunction compareStrings(a: string, b: string): number {\r\n    if (!a && !b) return 0;\r\n    if (!a && b) return -1;\r\n    if (a && !b) return 1;\r\n\r\n    // 判断语言类型\r\n    const getLanguage = (str: string) => {\r\n        if (/^[\\u4E00-\\u9FFF\\u3400-\\u4DBF\\uF900-\\uFAFF]/.test(str)) {\r\n            // 判断是简体中文还是繁体中文\r\n            if (/^[\\u4E00-\\u9FFF]/.test(str)) return 'zh-Hans-CN'; // 简体中文\r\n            return 'zh-Hant-TW'; // 繁体中文\r\n        }\r\n        if (/^[\\u3040-\\u309F\\u30A0-\\u30FF]/.test(str)) return 'ja'; // 日文\r\n        if (/^[\\u00C0-\\u1EF9]/.test(str)) return 'vi'; // 越南文\r\n        return 'en'; // 英文或其他\r\n    };\r\n\r\n    const langA = getLanguage(a);\r\n    const langB = getLanguage(b);\r\n\r\n    if (langA !== langB) {\r\n        // 按语言分组排序\r\n        const languageOrder = ['vi', 'en', 'zh-Hans-CN', 'zh-Hant-TW', 'ja'];\r\n        return languageOrder.indexOf(langA) - languageOrder.indexOf(langB);\r\n    }\r\n\r\n    // 同语言按拼音或字母排序\r\n    return a.localeCompare(b, langA, {\r\n        sensitivity: 'base', // 忽略大小写和重音符号\r\n        numeric: true, // 支持数字的自然排序\r\n        ignorePunctuation: true, // 忽略标点符号\r\n        caseFirst: 'upper', // 大写字母优先\r\n    });\r\n}\r\n\r\nimport { pinyin } from 'pinyin-pro';\r\n// 中文转拼音函数（支持简体和繁体）\r\nfunction convertToPinyin(str: string): string {\r\n    const r = pinyin(str, {\r\n        type: 'array',\r\n        //style: 4, // 带声调\r\n        //heteronym: false, // 不显示多音字\r\n        //returnString: true,            // 返回字符串\r\n    });\r\n    return r.flat().join('');\r\n}\r\nfunction getSortKey(str: string): string {\r\n    if (/^[\\u4E00-\\u9FFF]/.test(str)) {\r\n        return convertToPinyin(str); // 中文转换为拼音\r\n    }\r\n    if (/^[\\u3040-\\u309F\\u30A0-\\u30FF]/.test(str)) {\r\n        return str; // 日文直接使用原字符串\r\n    }\r\n    if (/^[\\u00C0-\\u1EF9]/.test(str)) {\r\n        return str.normalize('NFD').replace(/[\\u0300-\\u036f]/g, ''); // 越南文标准化\r\n    }\r\n    return str; // 英文或其他\r\n}\r\n\r\nfunction compareStringsBySortKey(a: string, b: string): number {\r\n    const keyA = getSortKey(a);\r\n    const keyB = getSortKey(b);\r\n    return keyA.localeCompare(keyB, 'en'); // 使用英文语言环境比较\r\n}\r\n"]}
|