fantasy-ngzorro 1.3.32 → 1.3.34
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/bundles/fantasy-ngzorro.umd.js +279 -101
- package/bundles/fantasy-ngzorro.umd.js.map +1 -1
- package/bundles/fantasy-ngzorro.umd.min.js +2 -2
- package/bundles/fantasy-ngzorro.umd.min.js.map +1 -1
- package/esm2015/hd-filter/hd-filter.component.js +2 -2
- package/esm2015/hd-filter/hd-filter.service.js +6 -3
- package/esm2015/utils.js +192 -101
- package/esm5/hd-filter/hd-filter.component.js +2 -2
- package/esm5/hd-filter/hd-filter.service.js +4 -2
- package/esm5/utils.js +278 -101
- package/fantasy-ngzorro.metadata.json +1 -1
- package/fesm2015/fantasy-ngzorro.js +196 -102
- package/fesm2015/fantasy-ngzorro.js.map +1 -1
- package/fesm5/fantasy-ngzorro.js +279 -101
- package/fesm5/fantasy-ngzorro.js.map +1 -1
- package/hd-filter/hd-filter.service.d.ts +2 -1
- package/package.json +1 -1
- package/utils.d.ts +29 -5
|
@@ -158,7 +158,7 @@ export class HdFilterComponent {
|
|
|
158
158
|
HdFilterComponent.decorators = [
|
|
159
159
|
{ type: Component, args: [{
|
|
160
160
|
selector: 'hd-filter',
|
|
161
|
-
template: "<form nz-form [formGroup]=\"validateFilterForm\" class=\"ant-advanced-search-form hd-filter-container\">\n <!-- \u6574\u4F53\u7ED3\u6784 -->\n <div nz-row [nzGutter]=\"24\">\n <!-- \u5BF9\u7EC4\u4EF6\u5217\u8868\u5FAA\u73AF\u5904\u7406 -->\n <ng-container *ngFor=\"let filter of filterList\">\n <div nz-col [nzSpan]=\"6\" [hidden]=\"!filter.show\">\n <nz-form-item nzFlex>\n <nz-form-label class=\"hd-filter-label\"><span class=\"hd-red\" *ngIf=\"filter.require\">*</span>{{filter.label}}\n </nz-form-label>\n <nz-form-control class=\"hd-filter-control\">\n <ng-container [ngSwitch]=\"filter.type\">\n <!-- \u8FD9\u91CC\u6570\u5B57\u5BF9\u5E94\u679A\u4E3E\u7C7B\u578B\uFF0C\u53EF\u5728hd-filter.service.ts\u6587\u4EF6\u4E2D\u67E5\u770B\u5BF9\u5E94\u5173\u7CFB -->\n <ng-container *ngSwitchCase=\"0\">\n <nz-input-group [nzSuffix]=\"inputCleanTemplate\">\n <input nz-input [placeholder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u8F93\u5165' + filter.label\"\n
|
|
161
|
+
template: "<form nz-form [formGroup]=\"validateFilterForm\" class=\"ant-advanced-search-form hd-filter-container\">\n <!-- \u6574\u4F53\u7ED3\u6784 -->\n <div nz-row [nzGutter]=\"24\">\n <!-- \u5BF9\u7EC4\u4EF6\u5217\u8868\u5FAA\u73AF\u5904\u7406 -->\n <ng-container *ngFor=\"let filter of filterList\">\n <div nz-col [nzSpan]=\"6\" [hidden]=\"!filter.show\">\n <nz-form-item nzFlex>\n <nz-form-label class=\"hd-filter-label\"><span class=\"hd-red\" *ngIf=\"filter.require\">*</span>{{ filter.label }}\n </nz-form-label>\n <nz-form-control class=\"hd-filter-control\">\n <ng-container [ngSwitch]=\"filter.type\">\n <!-- \u8FD9\u91CC\u6570\u5B57\u5BF9\u5E94\u679A\u4E3E\u7C7B\u578B\uFF0C\u53EF\u5728hd-filter.service.ts\u6587\u4EF6\u4E2D\u67E5\u770B\u5BF9\u5E94\u5173\u7CFB -->\n <ng-container *ngSwitchCase=\"0\">\n <nz-input-group [nzSuffix]=\"inputCleanTemplate\">\n <input nz-input [placeholder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u8F93\u5165' + filter.label\"\n [formControlName]=\"filter.name\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"/>\n </nz-input-group>\n <ng-template #inputCleanTemplate><i nz-icon nz-tooltip class=\"ant-input-clear-icon\" nzTheme=\"fill\"\n nzType=\"close-circle\"\n *ngIf=\"validateFilterForm.get(filter.name).value\"\n (click)=\"inputClean(filter)\"></i></ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"1\">\n <nz-select\n [nzShowSearch]=\"filter.selectOption.hdShowSearch != null ? filter.selectOption.hdShowSearch : true\"\n [nzAllowClear]=\"filter.selectOption.hdAllowClear != null ? filter.selectOption.hdAllowClear : true\"\n [nzServerSearch]=\"filter.selectOption.hdServerSearch || false\"\n [nzDropdownMatchSelectWidth]=\"filter.selectOption.hdDropdownMatchSelectWidth ? filter.selectOption.hdDropdownMatchSelectWidth : false\"\n (nzOnSearch)=\"triggerEvent(filter.onSearchEvent || null, $event, filter.selectOption)\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\">\n <nz-option *ngFor=\"let selectItem of filter.selectOption.selectList\"\n [nzValue]=\"selectItem[filter.selectOption.value]\" [nzLabel]=\"filter.selectOption.showLabelAndValue ? '['+ selectItem[filter.selectOption.value] +']' +\n selectItem[filter.selectOption.label] : selectItem[filter.selectOption.label]\"></nz-option>\n </nz-select>\n </ng-container>\n <ng-container *ngSwitchCase=\"2\">\n <nz-date-picker *ngIf=\"filter.showTime\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" [nzDisabledDate]=\"filter.hdDisabledDate\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\" nzShowTime\n nzFormat=\"yyyy-MM-dd HH:mm:ss\">\n </nz-date-picker>\n <nz-date-picker *ngIf=\"!filter.showTime\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" [nzDisabledDate]=\"filter.hdDisabledDate\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\">\n </nz-date-picker>\n </ng-container>\n <ng-container *ngSwitchCase=\"3\">\n <nz-range-picker [nzPlaceHolder]=\"['\u5F00\u59CB\u65E5\u671F','\u7ED3\u675F\u65E5\u671F']\" [formControlName]=\"filter.name\">\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"\n </nz-range-picker>\n </ng-container>\n <!-- \u591A\u9879\u9009\u62E9\u5668 -->\n <ng-container *ngSwitchCase=\"4\">\n <nz-select\n [nzDropdownMatchSelectWidth]=\"filter.selectOption.hdDropdownMatchSelectWidth ? filter.selectOption.hdDropdownMatchSelectWidth : false\"\n nzMode=\"multiple\"\n [nzShowSearch]=\"filter.selectOption.hdShowSearch != null ? filter.selectOption.hdShowSearch : true\"\n [nzAllowClear]=\"filter.selectOption.hdAllowClear != null ? filter.selectOption.hdAllowClear : true\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" [nzServerSearch]=\"filter.selectOption.hdServerSearch || false\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"\n (nzOnSearch)=\"triggerEvent(filter.onSearchEvent || null, $event)\">\n <nz-option *ngFor=\"let selectItem of filter.selectOption.selectList\"\n [nzValue]=\"selectItem[filter.selectOption.value]\" [nzLabel]=\"filter.selectOption.showLabelAndValue ? '['+ selectItem[filter.selectOption.value] +']' +\n selectItem[filter.selectOption.label] : selectItem[filter.selectOption.label]\"></nz-option>\n </nz-select>\n </ng-container>\n <ng-container *ngSwitchCase=\"5\">\n <nz-cascader [nzOptions]=\"filter.cascaderOption.options\" [formControlName]=\"filter.name\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\">\n </nz-cascader>\n </ng-container>\n <ng-container *ngSwitchCase=\"6\">\n <nz-month-picker [formControlName]=\"filter.name\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"></nz-month-picker>\n </ng-container>\n </ng-container>\n </nz-form-control>\n </nz-form-item>\n </div>\n </ng-container>\n\n <div class=\"hd-filter-btn\" nz-col [nzSpan]=\"6\" [nzOffset]=\"computeOffset()\">\n <a *ngIf=\"filterList.length > 7\" class=\"hd-filter-more\" (click)=\"showMore()\">\n {{ isShowMore ? '\u5C55\u5F00' : '\u6536\u8D77' }}\n <i nz-icon [nzType]=\"isShowMore ? 'down' : 'up'\"></i>\n </a>\n <hd-button type=\"primary\" (click)=\"submitForm()\">\u67E5\u8BE2</hd-button>\n <hd-button type=\"reset\" (click)=\"resetForm()\">\u91CD\u7F6E</hd-button>\n </div>\n </div>\n</form>\n",
|
|
162
162
|
styles: ["::ng-deep .common-btn-group>a{font-size:12px;font-weight:400;color:#12a34f!important;white-space:nowrap}::ng-deep .common-btn-group .common-danger-btn:hover{color:#f05b24!important}::ng-deep .common-btn-group>a:hover{color:#20bd62!important}::ng-deep .common-btn-group>a:not(:last-child)::after{content:'';margin:0 2px}::ng-deep .common-billNumber>a{color:#3b77e3}button{box-shadow:unset;text-shadow:unset}::ng-deep .ant-form-item-label>label{color:#4b504e}::ng-deep .ant-input-number-input{height:28px}::ng-deep .ant-input-number{height:28px}textarea.ant-input{height:auto;min-height:28px}::ng-deep .ant-select-selection--multiple{min-height:28px}::ng-deep .ant-select-selection__rendered>ul>li{height:22px!important;margin-top:3px!important;line-height:22px!important}::ng-deep .ant-advanced-search-form .ant-form-item{margin-bottom:0!important}::ng-deep .ant-select-selection--single{height:28px!important}::ng-deep .ant-input{height:28px}::ng-deep .ant-input[disabled]:hover{border-color:#d9d9d9!important}::ng-deep .ant-select-selection__rendered{line-height:28px!important}::ng-deep .ant-calendar-range-picker-input{text-align:left!important}::ng-deep .ant-calendar-picker{width:100%!important}::ng-deep .ant-row{margin-right:0!important;margin-left:0!important}::ng-deep .ant-col-6{padding-left:12px;padding-right:12px}::ng-deep .ant-col-12{padding-left:12px;padding-right:12px}::ng-deep .ant-col-18{padding-left:12px;padding-right:12px}::ng-deep .ant-col-24{padding-left:12px;padding-right:12px}::ng-deep .ant-alert-info{background-color:#f5f8f6;border:1px solid #cfe3d4}:host ::ng-deep th{background:#f5f8f6!important;font-weight:700!important;white-space:nowrap;font-size:12px;font-family:PingFangSC-Medium,PingFang SC;color:#2a3634;padding:8px!important;box-sizing:border-box}:host ::ng-deep td{font-weight:400;font-style:normal;font-size:12px;color:#2a3634;text-align:left;white-space:nowrap;padding:8px!important;box-sizing:border-box}::ng-deep .ant-pagination-options{display:inline-flex;align-items:center}::ng-deep .ant-time-picker{width:100%}.ant-input-number-disabled,.ant-input[disabled],.ant-select-disabled{color:#4b504e}.hd-filter-container{padding:20px 23px;background:#fff;box-shadow:0 0 12px 0 rgba(93,114,103,.08);border-radius:4px;margin-bottom:8px!important;font-size:12px}.hd-filter-container .ant-row{margin-right:0!important;margin-left:0!important}.hd-filter-container .ant-col-6{padding-left:0!important;padding-right:0!important}.hd-filter-container .hd-filter-label{width:108px;word-break:break-all}.hd-filter-container .hd-filter-control{width:calc(100% - 108px)}.hd-filter-container ::ng-deep .ant-calendar-picker{width:100%}.hd-filter-container .hd-filter-more{color:#12a34f}.hd-filter-container .hd-filter-btn{height:40px;display:inline-flex;align-items:center;justify-content:flex-end}.hd-filter-container hd-button{margin-left:12px}.hd-filter-container ::ng-deep .ant-advanced-search-form .ant-form-item{margin-bottom:0!important}.hd-filter-container ::ng-deep .ant-select-selection--single{height:28px!important}.hd-filter-container ::ng-deep .ant-input{height:28px!important}.hd-filter-container ::ng-deep .ant-calendar-range-picker-input{text-align:left!important}.hd-filter-container .ant-input-number{width:100%}.hd-filter-container .hd-red{color:red}"]
|
|
163
163
|
}] }
|
|
164
164
|
];
|
|
@@ -190,4 +190,4 @@ if (false) {
|
|
|
190
190
|
*/
|
|
191
191
|
HdFilterComponent.prototype.fb;
|
|
192
192
|
}
|
|
193
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hd-filter.component.js","sourceRoot":"ng://fantasy-ngzorro/","sources":["hd-filter/hd-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { Filter } from './hd-filter.service';\n\n@Component({\n  selector: 'hd-filter',\n  templateUrl: './hd-filter.component.html',\n  styleUrls: ['./hd-filter.component.less']\n})\nexport class HdFilterComponent implements OnInit {\n\n  @Input() filterList: Array<Filter>;\n  @Output() searchEvent = new EventEmitter();\n  @Output() resetEvent = new EventEmitter();\n\n  validateFilterForm: FormGroup;\n  isShowMore: boolean = true;\n  // 对filterList取模运算\n  filterListModular: number = 0;\n\n  constructor(private fb: FormBuilder) {\n  }\n\n  ngOnInit() {\n    this.init();\n  }\n\n  ngOnChanges() {\n    this.init();\n  }\n\n  private init(): void {\n    this.isShowMore = true;\n    // 异常捕获\n    if (!this.checkList(this.filterList)) {\n      throw 'filter组件数据格式不规范';\n    }\n    this.filterListModular = this.filterList.length % 4;\n    // 首先根据定义的组件数组  去初始化表单\n    let formGroupList = {};\n    this.filterList.forEach((item, index) => {\n      formGroupList[item.name] = this.fb.control(item.value, []);\n      // 初始化控件显影\n      item.show = index < 7;\n    });\n    this.validateFilterForm = this.fb.group(formGroupList);\n  }\n\n  triggerEvent(fn: any, event: any, selectOption?: any) {\n    if (fn && selectOption) {\n      fn(event, selectOption);\n    } else if (fn) {\n      fn(event);\n    } else {\n      return;\n    }\n  }\n\n  computeOffset() {\n    // 特殊处理下等于4个选项的情况\n    if (this.filterList.length === 4) {\n      return 18;\n    }\n    return this.isShowMore ? ((this.filterListModular === 0 || this.filterList.length > 7) ? 0 : (3 - this.filterListModular) * 6) : (this.filterListModular === 0 ? 18 : (3 - this.filterListModular) * 6);\n  }\n\n  private checkList(list: Array<Filter>): boolean {\n    if (!list || (list && list.length === 0)) {\n      return true;\n    }\n    let nameList = [];\n    list.forEach((item) => {\n      // 校验单项选择器\n      // if (item.type === FilterListType.Select && (!item.selectOption.selectList || (item.selectOption.selectList && item.selectOption.selectList.length === 0))) {\n      //   throw 'filter组件数据格式不规范，存在单项选择器没有传入选项!'\n      // }\n      nameList.push(item.name);\n    });\n    // 校验name是否重复\n    if ([...new Set(nameList)].length !== list.length) {\n      throw 'filter组件数据格式不规范，存在重复name值!';\n    }\n    // ...more check\n    return true;\n  }\n\n  public submitForm(): void {\n    this.searchEvent.emit(this.validateFilterForm.getRawValue());\n  }\n\n  public resetForm(): void {\n    this.validateFilterForm.reset();\n    if (this.resetEvent.observers.length > 0) {\n      // 如果有父组件绑定了 resetEvent 的处理器\n      this.resetEvent.emit(this.validateFilterForm.getRawValue());\n    } else {\n      // 如果没有绑定处理器，则触发 searchEvent\n      this.searchEvent.emit(this.validateFilterForm.getRawValue());\n    }\n  }\n\n  public showMore(): void {\n    this.isShowMore = !this.isShowMore;\n    this.filterList.forEach((item, index) => {\n      item.show = this.isShowMore ? index < 7 : true;\n    });\n  }\n\n  public inputClean(filter: Filter): void {\n    const patchObject = {};\n    patchObject[filter.name] = null;\n\n    this.validateFilterForm.patchValue(patchObject);\n  }\n}\n"]}
|
|
@@ -50,7 +50,8 @@ const FilterListType = {
|
|
|
50
50
|
Date: 2,
|
|
51
51
|
DateRange: 3,
|
|
52
52
|
MultipleSelect: 4,
|
|
53
|
-
Cascader: 5
|
|
53
|
+
Cascader: 5,
|
|
54
|
+
Month: 6 // 月份选择
|
|
54
55
|
,
|
|
55
56
|
};
|
|
56
57
|
export { FilterListType };
|
|
@@ -60,8 +61,10 @@ FilterListType[FilterListType.Date] = 'Date';
|
|
|
60
61
|
FilterListType[FilterListType.DateRange] = 'DateRange';
|
|
61
62
|
FilterListType[FilterListType.MultipleSelect] = 'MultipleSelect';
|
|
62
63
|
FilterListType[FilterListType.Cascader] = 'Cascader';
|
|
64
|
+
FilterListType[FilterListType.Month] = 'Month';
|
|
63
65
|
export class HdFilterService {
|
|
64
|
-
constructor() {
|
|
66
|
+
constructor() {
|
|
67
|
+
}
|
|
65
68
|
}
|
|
66
69
|
HdFilterService.decorators = [
|
|
67
70
|
{ type: Injectable, args: [{
|
|
@@ -71,4 +74,4 @@ HdFilterService.decorators = [
|
|
|
71
74
|
/** @nocollapse */
|
|
72
75
|
HdFilterService.ctorParameters = () => [];
|
|
73
76
|
/** @nocollapse */ HdFilterService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function HdFilterService_Factory() { return new HdFilterService(); }, token: HdFilterService, providedIn: "root" });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGQtZmlsdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9mYW50YXN5LW5nem9ycm8vIiwic291cmNlcyI6WyJoZC1maWx0ZXIvaGQtZmlsdGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUkzQyxNQUFNLE9BQU8sTUFBTTtJQUFuQjs7UUFLRSxVQUFLLEdBQTZELElBQUksQ0FBQyxDQUFFLGNBQWM7O1FBT3ZGLGFBQVEsR0FBYSxLQUFLLENBQUMsQ0FBQyxjQUFjOztRQUMxQyxZQUFPLEdBQWEsS0FBSyxDQUFDLENBQUMsT0FBTztJQUVwQyxDQUFDO0NBQUE7OztJQWRDLHNCQUFxQjs7SUFDckIsdUJBQWM7O0lBQ2Qsc0JBQWE7O0lBQ2IsNkJBQXFCOztJQUNyQix1QkFBdUU7O0lBRXZFLHNCQUFlOztJQUNmLDhCQUE0Qjs7SUFDNUIsK0JBQXlCOztJQUN6QiwrQkFBeUI7O0lBQ3pCLGdDQUEwQjs7SUFDMUIsMEJBQTJCOztJQUMzQix5QkFBMEI7O0lBQzFCLGdDQUFnQzs7OztJQU1oQyxRQUFLO0lBQ0wsU0FBTTtJQUNOLE9BQUk7SUFDSixZQUFTO0lBQ1QsaUJBQWM7SUFDZCxXQUFRO0lBQ1IsUUFBSyxDQUFDLE9BQU87Ozs7Ozs7Ozs7O0FBT2YsTUFBTSxPQUFPLGVBQWU7SUFFMUI7SUFDQSxDQUFDOzs7WUFORixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTZWxlY3RPcHRpb24sIENhc2NhZGVyT3B0aW9uIH0gZnJvbSAnLi4vbW9kZWwvY29tbW9uLXR5cGUnO1xuXG4vLyDmjqfku7bliJfooahcbmV4cG9ydCBjbGFzcyBGaWx0ZXIge1xuICB0eXBlOiBGaWx0ZXJMaXN0VHlwZTtcbiAgbGFiZWw6IHN0cmluZzsgIC8vIOaWh+acrFxuICBuYW1lOiBzdHJpbmc7ICAvLyDlrZfmrrXlkI3np7BcbiAgcGxhY2Vob2xkZXI/OiBzdHJpbmc7IC8vIOi+k+WFpeahhuaPkOekuuaWh+ahiFxuICB2YWx1ZT86IHN0cmluZyB8IGJvb2xlYW4gfCBudW1iZXIgfCBBcnJheTxzdHJpbmcgfCBEYXRlPiB8IG51bGwgPSBudWxsOyAgLy8g5YC8IOS4jeS8oOm7mOiupOS4um51bGxcbiAgLy8g57uE5Lu25YaF6YOo5oiQ5ZGYXG4gIHNob3c/OiBib29sZWFuO1xuICBzZWxlY3RPcHRpb24/OiBTZWxlY3RPcHRpb247ICAvLyDmjqfku7bkuLpTZWxlY3Tml7bvvIzpgInpobnliJfooahcbiAgb25TZWFyY2hFdmVudD86IEZ1bmN0aW9uOyAgLy8gc2VsZWN06YCJ5oup5Zmo5pCc57Si5LqL5Lu2IOWPr+eUqOS6juabtOaWsOWkh+mAiembhuWQiFxuICBvbkNoYW5nZUV2ZW50PzogRnVuY3Rpb247ICAgLy8g5o6n5Lu255qE5YC85pS55Y+Y5LqL5Lu2IOWPr+eUqOS6juaOp+S7tumXtOiBlOWKqFxuICBoZERpc2FibGVkRGF0ZT86IEZ1bmN0aW9uOyAvLyBkYXRlLXBpY2tlcue7hOS7tuS4jeWPr+mAieaLqeeahOaXpeacn1xuICBzaG93VGltZT86IGJvb2xlYW4gPSBmYWxzZTsgLy8g5pel5pyf6YCJ5oup5Zmo5piv5ZCm5YyF5ZCr5pe26Ze0XG4gIHJlcXVpcmU/OiBib29sZWFuID0gZmFsc2U7IC8vIOaYr+WQpuW/heWhq1xuICBjYXNjYWRlck9wdGlvbj86IENhc2NhZGVyT3B0aW9uOyAvLyDnuqfogZTpgInmi6nlmajphY3nva5cbn1cblxuXG4vLyDmjqfku7bnsbvlnotcbmV4cG9ydCBlbnVtIEZpbHRlckxpc3RUeXBlIHtcbiAgSW5wdXQsICAvLyDovpPlhaXmoYZcbiAgU2VsZWN0LCAgLy8g5Y2V6aG56YCJ5oup5ZmoXG4gIERhdGUsICAvLyDljZXkuKrml6XmnJ/pgInmi6lcbiAgRGF0ZVJhbmdlLCAgLy8g5pel5pyf6IyD5Zu06YCJ5oupXG4gIE11bHRpcGxlU2VsZWN0LCAvLyDlpJrpgIlcbiAgQ2FzY2FkZXIsIC8vIOe6p+iBlOmAieaLqVxuICBNb250aCAvLyDmnIjku73pgInmi6lcbn1cblxuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBIZEZpbHRlclNlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG5cbn1cbiJdfQ==
|
package/esm2015/utils.js
CHANGED
|
@@ -2,76 +2,99 @@
|
|
|
2
2
|
* @fileoverview added by tsickle
|
|
3
3
|
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
4
|
*/
|
|
5
|
+
import { round } from 'lodash';
|
|
5
6
|
// 工具类
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
for (let i = 0; i < length; i++) {
|
|
21
|
-
if (returnData[i].name === name) {
|
|
22
|
-
returnData[i].selectOption.selectList = options;
|
|
7
|
+
/** @type {?} */
|
|
8
|
+
export const Utils = {
|
|
9
|
+
/**
|
|
10
|
+
* 填充select控件选项
|
|
11
|
+
* @param {?} formList 入参数组 Array<any>
|
|
12
|
+
* @param {?} name 需要填充options的属性名称
|
|
13
|
+
* @param {?} options 选项列表
|
|
14
|
+
* @return {?}
|
|
15
|
+
*/
|
|
16
|
+
fillSelectOption(formList, name, options) {
|
|
17
|
+
/** @type {?} */
|
|
18
|
+
const returnData = formList;
|
|
19
|
+
if (!returnData || !returnData.length) {
|
|
20
|
+
return returnData;
|
|
23
21
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
*/
|
|
31
|
-
function (list, obj) {
|
|
32
|
-
/** @type {?} */
|
|
33
|
-
let returnData = [];
|
|
34
|
-
if (!list || !list.length) {
|
|
35
|
-
return returnData;
|
|
36
|
-
}
|
|
37
|
-
/** @type {?} */
|
|
38
|
-
const length = list.length;
|
|
39
|
-
for (let i = 0; i < length; i++) {
|
|
40
|
-
if (obj[list[i].name]) {
|
|
41
|
-
list[i].value = obj[list[i].name];
|
|
22
|
+
/** @type {?} */
|
|
23
|
+
const length = formList.length;
|
|
24
|
+
for (let i = 0; i < length; i++) {
|
|
25
|
+
if (returnData[i].name === name) {
|
|
26
|
+
returnData[i].selectOption.selectList = options;
|
|
27
|
+
}
|
|
42
28
|
}
|
|
43
|
-
}
|
|
44
|
-
return list;
|
|
45
|
-
}, ɵ2 = /**
|
|
46
|
-
* @param {?} list
|
|
47
|
-
* @param {?=} option
|
|
48
|
-
* @return {?}
|
|
49
|
-
*/
|
|
50
|
-
function (list, option) {
|
|
51
|
-
/** @type {?} */
|
|
52
|
-
let returnData = [];
|
|
53
|
-
if (!list || !list.length) {
|
|
54
29
|
return returnData;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
30
|
+
},
|
|
31
|
+
/**
|
|
32
|
+
* 填充FormItem数组:针对入参list的每一个FormItem,判断obj中是否有对应的name字段,如果有,则填充value。
|
|
33
|
+
* @param {?} list 入参数组 Array<FormItem>
|
|
34
|
+
* @param {?} obj 需要填充到list的属性
|
|
35
|
+
* @return {?}
|
|
36
|
+
*/
|
|
37
|
+
fillArrayFormItem(list, obj) {
|
|
38
|
+
/** @type {?} */
|
|
39
|
+
const returnData = [];
|
|
40
|
+
if (!list || !list.length) {
|
|
41
|
+
return returnData;
|
|
42
|
+
}
|
|
43
|
+
/** @type {?} */
|
|
44
|
+
const length = list.length;
|
|
45
|
+
for (let i = 0; i < length; i++) {
|
|
46
|
+
if (obj[list[i].name]) {
|
|
47
|
+
list[i].value = obj[list[i].name];
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return list;
|
|
51
|
+
},
|
|
52
|
+
/**
|
|
53
|
+
* 数组转换成选择器的选项数组
|
|
54
|
+
* @param {?} list 入参数组 字符串数组或对象数组
|
|
55
|
+
* @param {?=} option 转换选项
|
|
56
|
+
* 注:list为字符串数组,option不需要传,按照标准的label、value转换
|
|
57
|
+
* @return {?}
|
|
58
|
+
*/
|
|
59
|
+
arrayToSelectOptionList(list, option) {
|
|
60
|
+
/** @type {?} */
|
|
61
|
+
const returnData = [];
|
|
62
|
+
if (!list || !list.length) {
|
|
63
|
+
return returnData;
|
|
64
|
+
}
|
|
65
|
+
if (option) {
|
|
66
|
+
if (option.labelTip && option.valueTip) {
|
|
67
|
+
list.forEach((/**
|
|
68
|
+
* @param {?} item
|
|
69
|
+
* @return {?}
|
|
70
|
+
*/
|
|
71
|
+
(item) => {
|
|
72
|
+
/** @type {?} */
|
|
73
|
+
const returnItem = item;
|
|
74
|
+
returnItem.label = item[option.label];
|
|
75
|
+
returnItem.value = item[option.value];
|
|
76
|
+
if (option.valueTip) {
|
|
77
|
+
returnItem[option.valueTip] = item[option.value];
|
|
78
|
+
}
|
|
79
|
+
if (option.labelTip) {
|
|
80
|
+
returnItem[option.labelTip] = item[option.label];
|
|
81
|
+
}
|
|
82
|
+
returnData.push(returnItem);
|
|
83
|
+
}));
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
list.forEach((/**
|
|
87
|
+
* @param {?} item
|
|
88
|
+
* @return {?}
|
|
89
|
+
*/
|
|
90
|
+
(item) => {
|
|
91
|
+
/** @type {?} */
|
|
92
|
+
const returnItem = item;
|
|
93
|
+
returnItem.label = item[option.label];
|
|
94
|
+
returnItem.value = item[option.value];
|
|
95
|
+
returnData.push(returnItem);
|
|
96
|
+
}));
|
|
97
|
+
}
|
|
75
98
|
}
|
|
76
99
|
else {
|
|
77
100
|
list.forEach((/**
|
|
@@ -80,50 +103,118 @@ function (list, option) {
|
|
|
80
103
|
*/
|
|
81
104
|
(item) => {
|
|
82
105
|
/** @type {?} */
|
|
83
|
-
|
|
84
|
-
returnItem.label = item
|
|
85
|
-
returnItem.value = item
|
|
106
|
+
const returnItem = {};
|
|
107
|
+
returnItem.label = item;
|
|
108
|
+
returnItem.value = item;
|
|
86
109
|
returnData.push(returnItem);
|
|
87
110
|
}));
|
|
88
111
|
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
112
|
+
return returnData;
|
|
113
|
+
},
|
|
114
|
+
/**
|
|
115
|
+
* 求和
|
|
116
|
+
* @param {?} nums 数组
|
|
117
|
+
* @param {?=} precision 精度
|
|
118
|
+
* @return {?}
|
|
119
|
+
*/
|
|
120
|
+
add(nums, precision = 2) {
|
|
121
|
+
if (!Array.isArray(nums)) {
|
|
122
|
+
throw new Error('参数必须是数组');
|
|
123
|
+
}
|
|
124
|
+
if (nums.some((/**
|
|
125
|
+
* @param {?} num
|
|
93
126
|
* @return {?}
|
|
94
127
|
*/
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
}
|
|
105
|
-
/** @type {?} */
|
|
106
|
-
export const Utils = {
|
|
128
|
+
num => typeof num !== 'number'))) {
|
|
129
|
+
throw new Error('数组元素必须是数字');
|
|
130
|
+
}
|
|
131
|
+
/** @type {?} */
|
|
132
|
+
let result = 0;
|
|
133
|
+
for (const num of nums) {
|
|
134
|
+
result += num;
|
|
135
|
+
}
|
|
136
|
+
return round(result, precision);
|
|
137
|
+
},
|
|
107
138
|
/**
|
|
108
|
-
*
|
|
109
|
-
* @param
|
|
110
|
-
* @param
|
|
111
|
-
* @
|
|
139
|
+
* 减法
|
|
140
|
+
* @param {?} nums 数组
|
|
141
|
+
* @param {?=} precision 精度
|
|
142
|
+
* @return {?}
|
|
112
143
|
*/
|
|
113
|
-
|
|
144
|
+
subtract(nums, precision = 2) {
|
|
145
|
+
if (!Array.isArray(nums)) {
|
|
146
|
+
throw new Error('参数必须是数组');
|
|
147
|
+
}
|
|
148
|
+
if (nums.some((/**
|
|
149
|
+
* @param {?} num
|
|
150
|
+
* @return {?}
|
|
151
|
+
*/
|
|
152
|
+
num => typeof num !== 'number'))) {
|
|
153
|
+
throw new Error('数组元素必须是数字');
|
|
154
|
+
}
|
|
155
|
+
if (nums.length < 2) {
|
|
156
|
+
throw new Error('减法入参数量至少要2个!');
|
|
157
|
+
}
|
|
158
|
+
/** @type {?} */
|
|
159
|
+
let result = nums.shift();
|
|
160
|
+
for (const num of nums) {
|
|
161
|
+
result -= num;
|
|
162
|
+
}
|
|
163
|
+
return round(result, precision);
|
|
164
|
+
},
|
|
114
165
|
/**
|
|
115
|
-
*
|
|
116
|
-
* @param
|
|
117
|
-
* @param
|
|
166
|
+
* 乘法
|
|
167
|
+
* @param {?} nums 数组
|
|
168
|
+
* @param {?=} precision 精度
|
|
169
|
+
* @return {?}
|
|
118
170
|
*/
|
|
119
|
-
|
|
171
|
+
multiply(nums, precision = 2) {
|
|
172
|
+
if (!Array.isArray(nums)) {
|
|
173
|
+
throw new Error('参数必须是数组');
|
|
174
|
+
}
|
|
175
|
+
if (nums.some((/**
|
|
176
|
+
* @param {?} num
|
|
177
|
+
* @return {?}
|
|
178
|
+
*/
|
|
179
|
+
num => typeof num !== 'number'))) {
|
|
180
|
+
throw new Error('数组元素必须是数字');
|
|
181
|
+
}
|
|
182
|
+
/** @type {?} */
|
|
183
|
+
let result = 1;
|
|
184
|
+
for (const num of nums) {
|
|
185
|
+
result = result * num;
|
|
186
|
+
}
|
|
187
|
+
return round(result, precision);
|
|
188
|
+
},
|
|
120
189
|
/**
|
|
121
|
-
*
|
|
122
|
-
* @param
|
|
123
|
-
* @param
|
|
124
|
-
*
|
|
190
|
+
* 除法
|
|
191
|
+
* @param {?} nums 数组
|
|
192
|
+
* @param {?=} precision 精度
|
|
193
|
+
* @return {?}
|
|
125
194
|
*/
|
|
126
|
-
|
|
195
|
+
divide(nums, precision = 2) {
|
|
196
|
+
if (!Array.isArray(nums)) {
|
|
197
|
+
throw new Error('参数必须是数组');
|
|
198
|
+
}
|
|
199
|
+
if (nums.some((/**
|
|
200
|
+
* @param {?} num
|
|
201
|
+
* @return {?}
|
|
202
|
+
*/
|
|
203
|
+
num => typeof num !== 'number'))) {
|
|
204
|
+
throw new Error('数组元素必须是数字');
|
|
205
|
+
}
|
|
206
|
+
if (nums.length < 2) {
|
|
207
|
+
throw new Error('除法入参数量至少要2个!');
|
|
208
|
+
}
|
|
209
|
+
/** @type {?} */
|
|
210
|
+
let result = nums.shift();
|
|
211
|
+
for (const num of nums) {
|
|
212
|
+
if (num === 0) {
|
|
213
|
+
throw new Error('除数不能为0!');
|
|
214
|
+
}
|
|
215
|
+
result = result / num;
|
|
216
|
+
}
|
|
217
|
+
return round(result, precision);
|
|
218
|
+
}
|
|
127
219
|
};
|
|
128
|
-
export { ɵ0, ɵ1, ɵ2 };
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9mYW50YXN5LW5nem9ycm8vIiwic291cmNlcyI6WyJ1dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQVVvQixVQUFVLFFBQW9CLEVBQUUsSUFBWSxFQUFFLE9BQW1COztRQUM3RSxVQUFVLEdBQUcsUUFBUTtJQUN6QixJQUFJLENBQUMsVUFBVSxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRTtRQUNyQyxPQUFPLFVBQVUsQ0FBQztLQUNuQjs7VUFDSyxNQUFNLEdBQUcsUUFBUSxDQUFDLE1BQU07SUFDOUIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUMvQixJQUFJLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssSUFBSSxFQUFFO1lBQy9CLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsVUFBVSxHQUFHLE9BQU8sQ0FBQztTQUNqRDtLQUNGO0lBQ0QsT0FBTyxVQUFVLENBQUM7QUFDcEIsQ0FBQzs7Ozs7QUFPa0IsVUFBVSxJQUFxQixFQUFFLEdBQVc7O1FBQ3pELFVBQVUsR0FBRyxFQUFFO0lBQ25CLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFO1FBQ3pCLE9BQU8sVUFBVSxDQUFDO0tBQ25COztVQUNLLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTTtJQUMxQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO1FBQy9CLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNyQixJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDbkM7S0FDRjtJQUNELE9BQU8sSUFBSSxDQUFDO0FBQ2QsQ0FBQzs7Ozs7QUFRd0IsVUFBVSxJQUFnQixFQUFFLE1BQStFOztRQUM5SCxVQUFVLEdBQUcsRUFBRTtJQUNuQixJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRTtRQUN6QixPQUFPLFVBQVUsQ0FBQztLQUNuQjtJQUNELElBQUksTUFBTSxFQUFFO1FBQ1YsSUFBSSxNQUFNLENBQUMsUUFBUSxJQUFJLE1BQU0sQ0FBQyxRQUFRLEVBQUU7WUFDdEMsSUFBSSxDQUFDLE9BQU87Ozs7WUFBQyxDQUFDLElBQUksRUFBRSxFQUFFOztvQkFDaEIsVUFBVSxHQUFRLElBQUk7Z0JBQzFCLFVBQVUsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDdEMsVUFBVSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUN0QyxJQUFJLE1BQU0sQ0FBQyxRQUFRLEVBQUU7b0JBQ25CLFVBQVUsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztpQkFDbEQ7Z0JBQ0QsSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFO29CQUNuQixVQUFVLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7aUJBQ2xEO2dCQUNELFVBQVUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDOUIsQ0FBQyxFQUFDLENBQUE7U0FDSDthQUFNO1lBQ0wsSUFBSSxDQUFDLE9BQU87Ozs7WUFBQyxDQUFDLElBQUksRUFBRSxFQUFFOztvQkFDaEIsVUFBVSxHQUFRLElBQUk7Z0JBQzFCLFVBQVUsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDdEMsVUFBVSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUN0QyxVQUFVLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQzlCLENBQUMsRUFBQyxDQUFBO1NBQ0g7S0FDRjtTQUFNO1FBQ0wsSUFBSSxDQUFDLE9BQU87Ozs7UUFBQyxDQUFDLElBQUksRUFBRSxFQUFFOztnQkFDaEIsVUFBVSxHQUFRLEVBQUU7WUFDeEIsVUFBVSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7WUFDeEIsVUFBVSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7WUFDeEIsVUFBVSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUM5QixDQUFDLEVBQUMsQ0FBQTtLQUNIO0lBQ0QsT0FBTyxVQUFVLENBQUM7QUFDcEIsQ0FBQzs7QUFsRkgsTUFBTSxPQUFPLEtBQUssR0FBRzs7Ozs7OztJQU9uQixnQkFBZ0IsTUFZZjs7Ozs7O0lBT0QsaUJBQWlCLE1BWWhCOzs7Ozs7O0lBUUQsdUJBQXVCLE1Bb0N0QjtDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybUl0ZW0gfSBmcm9tIFwiLi9oZC1mb3JtL2hkLWZvcm0uc2VydmljZVwiO1xuXG4vLyDlt6XlhbfnsbtcbmV4cG9ydCBjb25zdCBVdGlscyA9IHtcbiAgLyoqXG4gICAqIOWhq+WFhXNlbGVjdOaOp+S7tumAiemhuVxuICAgKiBAcGFyYW0gZm9ybUxpc3Qg5YWl5Y+C5pWw57uEIEFycmF5PGFueT5cbiAgICogQHBhcmFtIG5hbWUg6ZyA6KaB5aGr5YWFb3B0aW9uc+eahOWxnuaAp+WQjeensFxuICAgKiBAcGFyYW0gb3B0aW9ucyDpgInpobnliJfooahcbiAgICovXG4gIGZpbGxTZWxlY3RPcHRpb246IGZ1bmN0aW9uIChmb3JtTGlzdDogQXJyYXk8YW55PiwgbmFtZTogc3RyaW5nLCBvcHRpb25zOiBBcnJheTxhbnk+KSB7XG4gICAgbGV0IHJldHVybkRhdGEgPSBmb3JtTGlzdDtcbiAgICBpZiAoIXJldHVybkRhdGEgfHwgIXJldHVybkRhdGEubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gcmV0dXJuRGF0YTtcbiAgICB9XG4gICAgY29uc3QgbGVuZ3RoID0gZm9ybUxpc3QubGVuZ3RoO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbGVuZ3RoOyBpKyspIHtcbiAgICAgIGlmIChyZXR1cm5EYXRhW2ldLm5hbWUgPT09IG5hbWUpIHtcbiAgICAgICAgcmV0dXJuRGF0YVtpXS5zZWxlY3RPcHRpb24uc2VsZWN0TGlzdCA9IG9wdGlvbnM7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiByZXR1cm5EYXRhO1xuICB9LFxuXG4gIC8qKlxuICAgKiDloavlhYVGb3JtSXRlbeaVsOe7hO+8mumSiOWvueWFpeWPgmxpc3TnmoTmr4/kuIDkuKpGb3JtSXRlbe+8jOWIpOaWrW9iauS4reaYr+WQpuacieWvueW6lOeahG5hbWXlrZfmrrXvvIzlpoLmnpzmnInvvIzliJnloavlhYV2YWx1ZeOAglxuICAgKiBAcGFyYW0gbGlzdCDlhaXlj4LmlbDnu4QgQXJyYXk8Rm9ybUl0ZW0+XG4gICAqIEBwYXJhbSBvYmog6ZyA6KaB5aGr5YWF5YiwbGlzdOeahOWxnuaAp1xuICAgKi9cbiAgZmlsbEFycmF5Rm9ybUl0ZW06IGZ1bmN0aW9uIChsaXN0OiBBcnJheTxGb3JtSXRlbT4sIG9iajogT2JqZWN0KSB7XG4gICAgbGV0IHJldHVybkRhdGEgPSBbXTtcbiAgICBpZiAoIWxpc3QgfHwgIWxpc3QubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gcmV0dXJuRGF0YTtcbiAgICB9XG4gICAgY29uc3QgbGVuZ3RoID0gbGlzdC5sZW5ndGg7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBsZW5ndGg7IGkrKykge1xuICAgICAgaWYgKG9ialtsaXN0W2ldLm5hbWVdKSB7XG4gICAgICAgIGxpc3RbaV0udmFsdWUgPSBvYmpbbGlzdFtpXS5uYW1lXTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGxpc3Q7XG4gIH0sXG5cbiAgLyoqXG4gICAqIOaVsOe7hOi9rOaNouaIkOmAieaLqeWZqOeahOmAiemhueaVsOe7hFxuICAgKiBAcGFyYW0gbGlzdCDlhaXlj4LmlbDnu4Qg5a2X56ym5Liy5pWw57uE5oiW5a+56LGh5pWw57uEXG4gICAqIEBwYXJhbSBvcHRpb24g6L2s5o2i6YCJ6aG5XG4gICAqIOazqO+8mmxpc3TkuLrlrZfnrKbkuLLmlbDnu4TvvIxvcHRpb27kuI3pnIDopoHkvKDvvIzmjInnhafmoIflh4bnmoRsYWJlbOOAgXZhbHVl6L2s5o2iXG4gICAqL1xuICBhcnJheVRvU2VsZWN0T3B0aW9uTGlzdDogZnVuY3Rpb24gKGxpc3Q6IEFycmF5PGFueT4sIG9wdGlvbj86IHsgdmFsdWU6IHN0cmluZywgbGFiZWw6IHN0cmluZywgdmFsdWVUaXA/OiBzdHJpbmcsIGxhYmVsVGlwPzogc3RyaW5nIH0pIHtcbiAgICBsZXQgcmV0dXJuRGF0YSA9IFtdO1xuICAgIGlmICghbGlzdCB8fCAhbGlzdC5sZW5ndGgpIHtcbiAgICAgIHJldHVybiByZXR1cm5EYXRhO1xuICAgIH1cbiAgICBpZiAob3B0aW9uKSB7XG4gICAgICBpZiAob3B0aW9uLmxhYmVsVGlwICYmIG9wdGlvbi52YWx1ZVRpcCkge1xuICAgICAgICBsaXN0LmZvckVhY2goKGl0ZW0pID0+IHtcbiAgICAgICAgICBsZXQgcmV0dXJuSXRlbTogYW55ID0gaXRlbTtcbiAgICAgICAgICByZXR1cm5JdGVtLmxhYmVsID0gaXRlbVtvcHRpb24ubGFiZWxdO1xuICAgICAgICAgIHJldHVybkl0ZW0udmFsdWUgPSBpdGVtW29wdGlvbi52YWx1ZV07XG4gICAgICAgICAgaWYgKG9wdGlvbi52YWx1ZVRpcCkge1xuICAgICAgICAgICAgcmV0dXJuSXRlbVtvcHRpb24udmFsdWVUaXBdID0gaXRlbVtvcHRpb24udmFsdWVdO1xuICAgICAgICAgIH1cbiAgICAgICAgICBpZiAob3B0aW9uLmxhYmVsVGlwKSB7XG4gICAgICAgICAgICByZXR1cm5JdGVtW29wdGlvbi5sYWJlbFRpcF0gPSBpdGVtW29wdGlvbi5sYWJlbF07XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybkRhdGEucHVzaChyZXR1cm5JdGVtKTtcbiAgICAgICAgfSlcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGxpc3QuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgICAgICAgIGxldCByZXR1cm5JdGVtOiBhbnkgPSBpdGVtO1xuICAgICAgICAgIHJldHVybkl0ZW0ubGFiZWwgPSBpdGVtW29wdGlvbi5sYWJlbF07XG4gICAgICAgICAgcmV0dXJuSXRlbS52YWx1ZSA9IGl0ZW1bb3B0aW9uLnZhbHVlXTtcbiAgICAgICAgICByZXR1cm5EYXRhLnB1c2gocmV0dXJuSXRlbSk7XG4gICAgICAgIH0pXG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGxpc3QuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgICAgICBsZXQgcmV0dXJuSXRlbTogYW55ID0ge307XG4gICAgICAgIHJldHVybkl0ZW0ubGFiZWwgPSBpdGVtO1xuICAgICAgICByZXR1cm5JdGVtLnZhbHVlID0gaXRlbTtcbiAgICAgICAgcmV0dXJuRGF0YS5wdXNoKHJldHVybkl0ZW0pO1xuICAgICAgfSlcbiAgICB9XG4gICAgcmV0dXJuIHJldHVybkRhdGE7XG4gIH1cbn1cbiJdfQ==
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://fantasy-ngzorro/","sources":["utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormItem } from './hd-form/hd-form.service';\nimport { round } from 'lodash';\n// 工具类\nexport const Utils = {\n  /**\n   * 填充select控件选项\n   * @param formList 入参数组 Array<any>\n   * @param name 需要填充options的属性名称\n   * @param options 选项列表\n   */\n  fillSelectOption(formList: Array<any>, name: string, options: Array<any>) {\n    const returnData = formList;\n    if (!returnData || !returnData.length) {\n      return returnData;\n    }\n    const length = formList.length;\n    for (let i = 0; i < length; i++) {\n      if (returnData[i].name === name) {\n        returnData[i].selectOption.selectList = options;\n      }\n    }\n    return returnData;\n  },\n\n  /**\n   * 填充FormItem数组：针对入参list的每一个FormItem，判断obj中是否有对应的name字段，如果有，则填充value。\n   * @param list 入参数组 Array<FormItem>\n   * @param obj 需要填充到list的属性\n   */\n  fillArrayFormItem(list: Array<FormItem>, obj: Object) {\n    const returnData = [];\n    if (!list || !list.length) {\n      return returnData;\n    }\n    const length = list.length;\n    for (let i = 0; i < length; i++) {\n      if (obj[list[i].name]) {\n        list[i].value = obj[list[i].name];\n      }\n    }\n    return list;\n  },\n\n  /**\n   * 数组转换成选择器的选项数组\n   * @param list 入参数组 字符串数组或对象数组\n   * @param option 转换选项\n   * 注：list为字符串数组，option不需要传，按照标准的label、value转换\n   */\n  arrayToSelectOptionList(list: Array<any>, option?: {\n    value: string,\n    label: string,\n    valueTip?: string,\n    labelTip?: string\n  }) {\n    const returnData = [];\n    if (!list || !list.length) {\n      return returnData;\n    }\n    if (option) {\n      if (option.labelTip && option.valueTip) {\n        list.forEach((item) => {\n          const returnItem: any = item;\n          returnItem.label = item[option.label];\n          returnItem.value = item[option.value];\n          if (option.valueTip) {\n            returnItem[option.valueTip] = item[option.value];\n          }\n          if (option.labelTip) {\n            returnItem[option.labelTip] = item[option.label];\n          }\n          returnData.push(returnItem);\n        });\n      } else {\n        list.forEach((item) => {\n          const returnItem: any = item;\n          returnItem.label = item[option.label];\n          returnItem.value = item[option.value];\n          returnData.push(returnItem);\n        });\n      }\n    } else {\n      list.forEach((item) => {\n        const returnItem: any = {};\n        returnItem.label = item;\n        returnItem.value = item;\n        returnData.push(returnItem);\n      });\n    }\n    return returnData;\n  },\n\n  /**\n   * 求和\n   * @param nums 数组\n   * @param precision 精度\n   */\n  add(nums: number[], precision: number = 2) {\n    if (!Array.isArray(nums)) {\n      throw new Error('参数必须是数组');\n    }\n    if (nums.some(num => typeof num !== 'number')) {\n      throw new Error('数组元素必须是数字');\n    }\n    let result = 0;\n    for (const num of nums) {\n      result += num;\n    }\n    return round(result, precision);\n  },\n\n  /**\n   * 减法\n   * @param nums 数组\n   * @param precision 精度\n   */\n  subtract(nums: number[], precision: number = 2) {\n    if (!Array.isArray(nums)) {\n      throw new Error('参数必须是数组');\n    }\n    if (nums.some(num => typeof num !== 'number')) {\n      throw new Error('数组元素必须是数字');\n    }\n    if (nums.length < 2) {\n      throw new Error('减法入参数量至少要2个！');\n    }\n    let result = nums.shift();\n    for (const num of nums) {\n      result -= num;\n    }\n    return round(result, precision);\n  },\n\n  /**\n   * 乘法\n   * @param nums 数组\n   * @param precision 精度\n   */\n  multiply(nums: number[], precision: number = 2) {\n    if (!Array.isArray(nums)) {\n      throw new Error('参数必须是数组');\n    }\n    if (nums.some(num => typeof num !== 'number')) {\n      throw new Error('数组元素必须是数字');\n    }\n    let result = 1;\n    for (const num of nums) {\n      result = result * num;\n    }\n    return round(result, precision);\n  },\n\n  /**\n   * 除法\n   * @param nums 数组\n   * @param precision 精度\n   */\n  divide(nums: number[], precision: number = 2) {\n    if (!Array.isArray(nums)) {\n      throw new Error('参数必须是数组');\n    }\n    if (nums.some(num => typeof num !== 'number')) {\n      throw new Error('数组元素必须是数字');\n    }\n    if (nums.length < 2) {\n      throw new Error('除法入参数量至少要2个！');\n    }\n    let result = nums.shift();\n    for (const num of nums) {\n      if (num === 0) {\n        throw new Error('除数不能为0！');\n      }\n      result = result / num;\n    }\n    return round(result, precision);\n  }\n};\n"]}
|
|
@@ -194,7 +194,7 @@ var HdFilterComponent = /** @class */ (function () {
|
|
|
194
194
|
HdFilterComponent.decorators = [
|
|
195
195
|
{ type: Component, args: [{
|
|
196
196
|
selector: 'hd-filter',
|
|
197
|
-
template: "<form nz-form [formGroup]=\"validateFilterForm\" class=\"ant-advanced-search-form hd-filter-container\">\n <!-- \u6574\u4F53\u7ED3\u6784 -->\n <div nz-row [nzGutter]=\"24\">\n <!-- \u5BF9\u7EC4\u4EF6\u5217\u8868\u5FAA\u73AF\u5904\u7406 -->\n <ng-container *ngFor=\"let filter of filterList\">\n <div nz-col [nzSpan]=\"6\" [hidden]=\"!filter.show\">\n <nz-form-item nzFlex>\n <nz-form-label class=\"hd-filter-label\"><span class=\"hd-red\" *ngIf=\"filter.require\">*</span>{{filter.label}}\n </nz-form-label>\n <nz-form-control class=\"hd-filter-control\">\n <ng-container [ngSwitch]=\"filter.type\">\n <!-- \u8FD9\u91CC\u6570\u5B57\u5BF9\u5E94\u679A\u4E3E\u7C7B\u578B\uFF0C\u53EF\u5728hd-filter.service.ts\u6587\u4EF6\u4E2D\u67E5\u770B\u5BF9\u5E94\u5173\u7CFB -->\n <ng-container *ngSwitchCase=\"0\">\n <nz-input-group [nzSuffix]=\"inputCleanTemplate\">\n <input nz-input [placeholder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u8F93\u5165' + filter.label\"\n
|
|
197
|
+
template: "<form nz-form [formGroup]=\"validateFilterForm\" class=\"ant-advanced-search-form hd-filter-container\">\n <!-- \u6574\u4F53\u7ED3\u6784 -->\n <div nz-row [nzGutter]=\"24\">\n <!-- \u5BF9\u7EC4\u4EF6\u5217\u8868\u5FAA\u73AF\u5904\u7406 -->\n <ng-container *ngFor=\"let filter of filterList\">\n <div nz-col [nzSpan]=\"6\" [hidden]=\"!filter.show\">\n <nz-form-item nzFlex>\n <nz-form-label class=\"hd-filter-label\"><span class=\"hd-red\" *ngIf=\"filter.require\">*</span>{{ filter.label }}\n </nz-form-label>\n <nz-form-control class=\"hd-filter-control\">\n <ng-container [ngSwitch]=\"filter.type\">\n <!-- \u8FD9\u91CC\u6570\u5B57\u5BF9\u5E94\u679A\u4E3E\u7C7B\u578B\uFF0C\u53EF\u5728hd-filter.service.ts\u6587\u4EF6\u4E2D\u67E5\u770B\u5BF9\u5E94\u5173\u7CFB -->\n <ng-container *ngSwitchCase=\"0\">\n <nz-input-group [nzSuffix]=\"inputCleanTemplate\">\n <input nz-input [placeholder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u8F93\u5165' + filter.label\"\n [formControlName]=\"filter.name\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"/>\n </nz-input-group>\n <ng-template #inputCleanTemplate><i nz-icon nz-tooltip class=\"ant-input-clear-icon\" nzTheme=\"fill\"\n nzType=\"close-circle\"\n *ngIf=\"validateFilterForm.get(filter.name).value\"\n (click)=\"inputClean(filter)\"></i></ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"1\">\n <nz-select\n [nzShowSearch]=\"filter.selectOption.hdShowSearch != null ? filter.selectOption.hdShowSearch : true\"\n [nzAllowClear]=\"filter.selectOption.hdAllowClear != null ? filter.selectOption.hdAllowClear : true\"\n [nzServerSearch]=\"filter.selectOption.hdServerSearch || false\"\n [nzDropdownMatchSelectWidth]=\"filter.selectOption.hdDropdownMatchSelectWidth ? filter.selectOption.hdDropdownMatchSelectWidth : false\"\n (nzOnSearch)=\"triggerEvent(filter.onSearchEvent || null, $event, filter.selectOption)\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\">\n <nz-option *ngFor=\"let selectItem of filter.selectOption.selectList\"\n [nzValue]=\"selectItem[filter.selectOption.value]\" [nzLabel]=\"filter.selectOption.showLabelAndValue ? '['+ selectItem[filter.selectOption.value] +']' +\n selectItem[filter.selectOption.label] : selectItem[filter.selectOption.label]\"></nz-option>\n </nz-select>\n </ng-container>\n <ng-container *ngSwitchCase=\"2\">\n <nz-date-picker *ngIf=\"filter.showTime\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" [nzDisabledDate]=\"filter.hdDisabledDate\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\" nzShowTime\n nzFormat=\"yyyy-MM-dd HH:mm:ss\">\n </nz-date-picker>\n <nz-date-picker *ngIf=\"!filter.showTime\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" [nzDisabledDate]=\"filter.hdDisabledDate\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\">\n </nz-date-picker>\n </ng-container>\n <ng-container *ngSwitchCase=\"3\">\n <nz-range-picker [nzPlaceHolder]=\"['\u5F00\u59CB\u65E5\u671F','\u7ED3\u675F\u65E5\u671F']\" [formControlName]=\"filter.name\">\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"\n </nz-range-picker>\n </ng-container>\n <!-- \u591A\u9879\u9009\u62E9\u5668 -->\n <ng-container *ngSwitchCase=\"4\">\n <nz-select\n [nzDropdownMatchSelectWidth]=\"filter.selectOption.hdDropdownMatchSelectWidth ? filter.selectOption.hdDropdownMatchSelectWidth : false\"\n nzMode=\"multiple\"\n [nzShowSearch]=\"filter.selectOption.hdShowSearch != null ? filter.selectOption.hdShowSearch : true\"\n [nzAllowClear]=\"filter.selectOption.hdAllowClear != null ? filter.selectOption.hdAllowClear : true\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n [formControlName]=\"filter.name\" [nzServerSearch]=\"filter.selectOption.hdServerSearch || false\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"\n (nzOnSearch)=\"triggerEvent(filter.onSearchEvent || null, $event)\">\n <nz-option *ngFor=\"let selectItem of filter.selectOption.selectList\"\n [nzValue]=\"selectItem[filter.selectOption.value]\" [nzLabel]=\"filter.selectOption.showLabelAndValue ? '['+ selectItem[filter.selectOption.value] +']' +\n selectItem[filter.selectOption.label] : selectItem[filter.selectOption.label]\"></nz-option>\n </nz-select>\n </ng-container>\n <ng-container *ngSwitchCase=\"5\">\n <nz-cascader [nzOptions]=\"filter.cascaderOption.options\" [formControlName]=\"filter.name\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\">\n </nz-cascader>\n </ng-container>\n <ng-container *ngSwitchCase=\"6\">\n <nz-month-picker [formControlName]=\"filter.name\"\n [nzPlaceHolder]=\"filter.placeholder ? filter.placeholder : '\u8BF7\u9009\u62E9' + filter.label\"\n (ngModelChange)=\"triggerEvent(filter.onChangeEvent || null, $event)\"></nz-month-picker>\n </ng-container>\n </ng-container>\n </nz-form-control>\n </nz-form-item>\n </div>\n </ng-container>\n\n <div class=\"hd-filter-btn\" nz-col [nzSpan]=\"6\" [nzOffset]=\"computeOffset()\">\n <a *ngIf=\"filterList.length > 7\" class=\"hd-filter-more\" (click)=\"showMore()\">\n {{ isShowMore ? '\u5C55\u5F00' : '\u6536\u8D77' }}\n <i nz-icon [nzType]=\"isShowMore ? 'down' : 'up'\"></i>\n </a>\n <hd-button type=\"primary\" (click)=\"submitForm()\">\u67E5\u8BE2</hd-button>\n <hd-button type=\"reset\" (click)=\"resetForm()\">\u91CD\u7F6E</hd-button>\n </div>\n </div>\n</form>\n",
|
|
198
198
|
styles: ["::ng-deep .common-btn-group>a{font-size:12px;font-weight:400;color:#12a34f!important;white-space:nowrap}::ng-deep .common-btn-group .common-danger-btn:hover{color:#f05b24!important}::ng-deep .common-btn-group>a:hover{color:#20bd62!important}::ng-deep .common-btn-group>a:not(:last-child)::after{content:'';margin:0 2px}::ng-deep .common-billNumber>a{color:#3b77e3}button{box-shadow:unset;text-shadow:unset}::ng-deep .ant-form-item-label>label{color:#4b504e}::ng-deep .ant-input-number-input{height:28px}::ng-deep .ant-input-number{height:28px}textarea.ant-input{height:auto;min-height:28px}::ng-deep .ant-select-selection--multiple{min-height:28px}::ng-deep .ant-select-selection__rendered>ul>li{height:22px!important;margin-top:3px!important;line-height:22px!important}::ng-deep .ant-advanced-search-form .ant-form-item{margin-bottom:0!important}::ng-deep .ant-select-selection--single{height:28px!important}::ng-deep .ant-input{height:28px}::ng-deep .ant-input[disabled]:hover{border-color:#d9d9d9!important}::ng-deep .ant-select-selection__rendered{line-height:28px!important}::ng-deep .ant-calendar-range-picker-input{text-align:left!important}::ng-deep .ant-calendar-picker{width:100%!important}::ng-deep .ant-row{margin-right:0!important;margin-left:0!important}::ng-deep .ant-col-6{padding-left:12px;padding-right:12px}::ng-deep .ant-col-12{padding-left:12px;padding-right:12px}::ng-deep .ant-col-18{padding-left:12px;padding-right:12px}::ng-deep .ant-col-24{padding-left:12px;padding-right:12px}::ng-deep .ant-alert-info{background-color:#f5f8f6;border:1px solid #cfe3d4}:host ::ng-deep th{background:#f5f8f6!important;font-weight:700!important;white-space:nowrap;font-size:12px;font-family:PingFangSC-Medium,PingFang SC;color:#2a3634;padding:8px!important;box-sizing:border-box}:host ::ng-deep td{font-weight:400;font-style:normal;font-size:12px;color:#2a3634;text-align:left;white-space:nowrap;padding:8px!important;box-sizing:border-box}::ng-deep .ant-pagination-options{display:inline-flex;align-items:center}::ng-deep .ant-time-picker{width:100%}.ant-input-number-disabled,.ant-input[disabled],.ant-select-disabled{color:#4b504e}.hd-filter-container{padding:20px 23px;background:#fff;box-shadow:0 0 12px 0 rgba(93,114,103,.08);border-radius:4px;margin-bottom:8px!important;font-size:12px}.hd-filter-container .ant-row{margin-right:0!important;margin-left:0!important}.hd-filter-container .ant-col-6{padding-left:0!important;padding-right:0!important}.hd-filter-container .hd-filter-label{width:108px;word-break:break-all}.hd-filter-container .hd-filter-control{width:calc(100% - 108px)}.hd-filter-container ::ng-deep .ant-calendar-picker{width:100%}.hd-filter-container .hd-filter-more{color:#12a34f}.hd-filter-container .hd-filter-btn{height:40px;display:inline-flex;align-items:center;justify-content:flex-end}.hd-filter-container hd-button{margin-left:12px}.hd-filter-container ::ng-deep .ant-advanced-search-form .ant-form-item{margin-bottom:0!important}.hd-filter-container ::ng-deep .ant-select-selection--single{height:28px!important}.hd-filter-container ::ng-deep .ant-input{height:28px!important}.hd-filter-container ::ng-deep .ant-calendar-range-picker-input{text-align:left!important}.hd-filter-container .ant-input-number{width:100%}.hd-filter-container .hd-red{color:red}"]
|
|
199
199
|
}] }
|
|
200
200
|
];
|
|
@@ -229,4 +229,4 @@ if (false) {
|
|
|
229
229
|
*/
|
|
230
230
|
HdFilterComponent.prototype.fb;
|
|
231
231
|
}
|
|
232
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hd-filter.component.js","sourceRoot":"ng://fantasy-ngzorro/","sources":["hd-filter/hd-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { Filter } from './hd-filter.service';\n\n@Component({\n  selector: 'hd-filter',\n  templateUrl: './hd-filter.component.html',\n  styleUrls: ['./hd-filter.component.less']\n})\nexport class HdFilterComponent implements OnInit {\n\n  @Input() filterList: Array<Filter>;\n  @Output() searchEvent = new EventEmitter();\n  @Output() resetEvent = new EventEmitter();\n\n  validateFilterForm: FormGroup;\n  isShowMore: boolean = true;\n  // 对filterList取模运算\n  filterListModular: number = 0;\n\n  constructor(private fb: FormBuilder) {\n  }\n\n  ngOnInit() {\n    this.init();\n  }\n\n  ngOnChanges() {\n    this.init();\n  }\n\n  private init(): void {\n    this.isShowMore = true;\n    // 异常捕获\n    if (!this.checkList(this.filterList)) {\n      throw 'filter组件数据格式不规范';\n    }\n    this.filterListModular = this.filterList.length % 4;\n    // 首先根据定义的组件数组  去初始化表单\n    let formGroupList = {};\n    this.filterList.forEach((item, index) => {\n      formGroupList[item.name] = this.fb.control(item.value, []);\n      // 初始化控件显影\n      item.show = index < 7;\n    });\n    this.validateFilterForm = this.fb.group(formGroupList);\n  }\n\n  triggerEvent(fn: any, event: any, selectOption?: any) {\n    if (fn && selectOption) {\n      fn(event, selectOption);\n    } else if (fn) {\n      fn(event);\n    } else {\n      return;\n    }\n  }\n\n  computeOffset() {\n    // 特殊处理下等于4个选项的情况\n    if (this.filterList.length === 4) {\n      return 18;\n    }\n    return this.isShowMore ? ((this.filterListModular === 0 || this.filterList.length > 7) ? 0 : (3 - this.filterListModular) * 6) : (this.filterListModular === 0 ? 18 : (3 - this.filterListModular) * 6);\n  }\n\n  private checkList(list: Array<Filter>): boolean {\n    if (!list || (list && list.length === 0)) {\n      return true;\n    }\n    let nameList = [];\n    list.forEach((item) => {\n      // 校验单项选择器\n      // if (item.type === FilterListType.Select && (!item.selectOption.selectList || (item.selectOption.selectList && item.selectOption.selectList.length === 0))) {\n      //   throw 'filter组件数据格式不规范，存在单项选择器没有传入选项!'\n      // }\n      nameList.push(item.name);\n    });\n    // 校验name是否重复\n    if ([...new Set(nameList)].length !== list.length) {\n      throw 'filter组件数据格式不规范，存在重复name值!';\n    }\n    // ...more check\n    return true;\n  }\n\n  public submitForm(): void {\n    this.searchEvent.emit(this.validateFilterForm.getRawValue());\n  }\n\n  public resetForm(): void {\n    this.validateFilterForm.reset();\n    if (this.resetEvent.observers.length > 0) {\n      // 如果有父组件绑定了 resetEvent 的处理器\n      this.resetEvent.emit(this.validateFilterForm.getRawValue());\n    } else {\n      // 如果没有绑定处理器，则触发 searchEvent\n      this.searchEvent.emit(this.validateFilterForm.getRawValue());\n    }\n  }\n\n  public showMore(): void {\n    this.isShowMore = !this.isShowMore;\n    this.filterList.forEach((item, index) => {\n      item.show = this.isShowMore ? index < 7 : true;\n    });\n  }\n\n  public inputClean(filter: Filter): void {\n    const patchObject = {};\n    patchObject[filter.name] = null;\n\n    this.validateFilterForm.patchValue(patchObject);\n  }\n}\n"]}
|