ng-zorro-antd-extension 17.4.2 → 17.4.4
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/configurable-query/configurable-query.component.d.ts +12 -8
- package/configurable-query/configurable-query.module.d.ts +5 -3
- package/configurable-query/controls/abstract.control.d.ts +2 -1
- package/configurable-query/query-config.service.d.ts +3 -0
- package/dynamic-form/config/dynamic-form-config.d.ts +18 -0
- package/dynamic-form/controls/abstract.control.d.ts +11 -0
- package/dynamic-form/controls/date-picker.control.d.ts +6 -0
- package/dynamic-form/controls/input.control.d.ts +6 -0
- package/dynamic-form/controls/range-picker.control.d.ts +6 -0
- package/dynamic-form/controls/select.control.d.ts +6 -0
- package/dynamic-form/controls/template.control.d.ts +6 -0
- package/dynamic-form/dynamic-form-item/dynamic-form-item.component.d.ts +12 -0
- package/dynamic-form/dynamic-form.component.d.ts +5 -0
- package/dynamic-form/dynamic-form.module.d.ts +23 -0
- package/dynamic-form/index.d.ts +5 -0
- package/dynamic-form/public-api.d.ts +7 -0
- package/dynamic-form/wrapper/control/abstract-control-wrapper.d.ts +12 -0
- package/dynamic-form/wrapper/control/built-in-control-wrapper.d.ts +7 -0
- package/dynamic-form/wrapper/item/abstract-item-wrapper.d.ts +14 -0
- package/dynamic-form/wrapper/item/built-in-item-wrapper.d.ts +6 -0
- package/dynamic-form/wrapper/label/abstract-label-wrapper.d.ts +5 -0
- package/dynamic-form/wrapper/label/built-in-label-wrapper.d.ts +6 -0
- package/esm2022/configurable-query/configurable-query-item/configurable-query-item.component.mjs +4 -3
- package/esm2022/configurable-query/configurable-query.component.mjs +18 -12
- package/esm2022/configurable-query/configurable-query.module.mjs +14 -6
- package/esm2022/configurable-query/controls/abstract.control.mjs +4 -1
- package/esm2022/configurable-query/controls/date-picker.control.mjs +6 -5
- package/esm2022/configurable-query/controls/input.control.mjs +6 -5
- package/esm2022/configurable-query/controls/range-picker.control.mjs +6 -5
- package/esm2022/configurable-query/controls/select.control.mjs +6 -5
- package/esm2022/configurable-query/controls/template.control.mjs +6 -5
- package/esm2022/configurable-query/query-config.service.mjs +4 -1
- package/esm2022/dynamic-form/config/dynamic-form-config.mjs +47 -0
- package/esm2022/dynamic-form/controls/abstract.control.mjs +17 -0
- package/esm2022/dynamic-form/controls/date-picker.control.mjs +20 -0
- package/esm2022/dynamic-form/controls/input.control.mjs +15 -0
- package/esm2022/dynamic-form/controls/range-picker.control.mjs +15 -0
- package/esm2022/dynamic-form/controls/select.control.mjs +49 -0
- package/esm2022/dynamic-form/controls/template.control.mjs +30 -0
- package/esm2022/dynamic-form/dynamic-form-item/dynamic-form-item.component.mjs +31 -0
- package/esm2022/dynamic-form/dynamic-form.component.mjs +45 -0
- package/esm2022/dynamic-form/dynamic-form.module.mjs +72 -0
- package/esm2022/dynamic-form/ng-zorro-antd-extension-dynamic-form.mjs +5 -0
- package/esm2022/dynamic-form/public-api.mjs +8 -0
- package/esm2022/dynamic-form/wrapper/control/abstract-control-wrapper.mjs +30 -0
- package/esm2022/dynamic-form/wrapper/control/built-in-control-wrapper.mjs +32 -0
- package/esm2022/dynamic-form/wrapper/item/abstract-item-wrapper.mjs +44 -0
- package/esm2022/dynamic-form/wrapper/item/built-in-item-wrapper.mjs +27 -0
- package/esm2022/dynamic-form/wrapper/label/abstract-label-wrapper.mjs +10 -0
- package/esm2022/dynamic-form/wrapper/label/built-in-label-wrapper.mjs +17 -0
- package/esm2022/print/nzx-print-content.directive.mjs +2 -2
- package/esm2022/print/nzx-print.module.mjs +1 -1
- package/esm2022/util/lib/getElementByTag.mjs +15 -8
- package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs +53 -27
- package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs.map +1 -1
- package/fesm2022/ng-zorro-antd-extension-dynamic-form.mjs +444 -0
- package/fesm2022/ng-zorro-antd-extension-dynamic-form.mjs.map +1 -0
- package/fesm2022/ng-zorro-antd-extension-print.mjs.map +1 -1
- package/fesm2022/ng-zorro-antd-extension-util.mjs +13 -7
- package/fesm2022/ng-zorro-antd-extension-util.mjs.map +1 -1
- package/package.json +12 -6
- package/print/nzx-print-content.directive.d.ts +1 -1
- package/table-select/abstract-table-select.d.ts +1 -1
|
@@ -14,29 +14,32 @@ export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit,
|
|
|
14
14
|
private i18n;
|
|
15
15
|
private fb;
|
|
16
16
|
private cd;
|
|
17
|
-
/**
|
|
17
|
+
/**
|
|
18
|
+
* 配置项用来生成查询表单
|
|
19
|
+
*/
|
|
18
20
|
controls: Array<NzxQueryControlOptions>;
|
|
19
|
-
/**
|
|
21
|
+
/** 查询表单排列方式默认start */
|
|
20
22
|
nzxJustify: NzJustify;
|
|
21
|
-
/**
|
|
23
|
+
/** 查询项间隔默认为8 */
|
|
22
24
|
nzxGutter: number;
|
|
23
|
-
/**
|
|
25
|
+
/** 一行展示多少查询项默认展示3个 */
|
|
24
26
|
lineNumber: number;
|
|
25
27
|
/** 操作按钮所占栅格数,24则换行 */
|
|
26
28
|
nzxBtnSpan: number | null;
|
|
27
|
-
/**
|
|
29
|
+
/** 初始化时,是否主动触发查询 */
|
|
28
30
|
initQuery: boolean;
|
|
29
|
-
/** 缺省
|
|
31
|
+
/** 缺省 固定参数会固定携带在抛出事件中 */
|
|
30
32
|
fixedParams: {};
|
|
31
33
|
/** 查询时会触发抛出查询参数 */
|
|
32
34
|
queryChange: EventEmitter<NzxQueryParams>;
|
|
33
35
|
/** 重置时会触发抛出查询参数 */
|
|
34
36
|
resetChange: EventEmitter<NzxQueryParams>;
|
|
35
|
-
/**
|
|
37
|
+
/** 组件最终的查询参数 */
|
|
36
38
|
get queryParams(): any;
|
|
37
39
|
set queryParams(value: any);
|
|
40
|
+
/** 判断当前组件是否展示展开折叠按钮 */
|
|
38
41
|
get nzxCollapse(): boolean;
|
|
39
|
-
/** form
|
|
42
|
+
/** 内置 form 查询表单实例 */
|
|
40
43
|
queryForm: FormGroup;
|
|
41
44
|
locale: NzxQueryI18nInterface;
|
|
42
45
|
collapseIcon: string;
|
|
@@ -87,6 +90,7 @@ export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit,
|
|
|
87
90
|
/**展开、收起*/
|
|
88
91
|
toggleCollapse(): void;
|
|
89
92
|
ngOnDestroy(): void;
|
|
93
|
+
/** 计算展开收起icon、文案 */
|
|
90
94
|
private calculateText;
|
|
91
95
|
/** 清空表单控件 */
|
|
92
96
|
private clearFormControl;
|
|
@@ -17,12 +17,14 @@ import * as i13 from "ng-zorro-antd/grid";
|
|
|
17
17
|
import * as i14 from "ng-zorro-antd/button";
|
|
18
18
|
import * as i15 from "ng-zorro-antd/select";
|
|
19
19
|
import * as i16 from "ng-zorro-antd/date-picker";
|
|
20
|
-
import * as i17 from "ng-zorro-antd/
|
|
21
|
-
import * as i18 from "ng-zorro-antd/
|
|
20
|
+
import * as i17 from "ng-zorro-antd/card";
|
|
21
|
+
import * as i18 from "ng-zorro-antd/space";
|
|
22
|
+
import * as i19 from "ng-zorro-antd/icon";
|
|
23
|
+
import * as i20 from "ng-zorro-antd/i18n";
|
|
22
24
|
export declare class NzxConfigurableQueryModule {
|
|
23
25
|
static forRoot(nzxQueryConfig: NzxQueryConfig): ModuleWithProviders<NzxConfigurableQueryModule>;
|
|
24
26
|
static forChild(nzxQueryConfig: NzxQueryConfig): ModuleWithProviders<NzxConfigurableQueryModule>;
|
|
25
27
|
static ɵfac: i0.ɵɵFactoryDeclaration<NzxConfigurableQueryModule, never>;
|
|
26
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<NzxConfigurableQueryModule, [typeof i1.NzxConfigurableQueryComponent, typeof i2.NzxControlDirective, typeof i3.NzxConfigurableQueryItemComponent, typeof i4.NzxInputControlComponent, typeof i5.NzxTemplateControlComponent, typeof i6.NzxSelectControlComponent, typeof i7.NzxDatePickerControlComponent, typeof i8.NzxRangePickerControlComponent], [typeof i9.CommonModule, typeof i10.ReactiveFormsModule, typeof i11.NzInputModule, typeof i12.NzFormModule, typeof i13.NzGridModule, typeof i14.NzButtonModule, typeof i15.NzSelectModule, typeof i16.NzDatePickerModule, typeof i17.
|
|
28
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NzxConfigurableQueryModule, [typeof i1.NzxConfigurableQueryComponent, typeof i2.NzxControlDirective, typeof i3.NzxConfigurableQueryItemComponent, typeof i4.NzxInputControlComponent, typeof i5.NzxTemplateControlComponent, typeof i6.NzxSelectControlComponent, typeof i7.NzxDatePickerControlComponent, typeof i8.NzxRangePickerControlComponent], [typeof i9.CommonModule, typeof i10.ReactiveFormsModule, typeof i11.NzInputModule, typeof i12.NzFormModule, typeof i13.NzGridModule, typeof i14.NzButtonModule, typeof i15.NzSelectModule, typeof i16.NzDatePickerModule, typeof i17.NzCardModule, typeof i18.NzSpaceModule, typeof i19.NzIconModule, typeof i20.NzI18nModule], [typeof i2.NzxControlDirective, typeof i1.NzxConfigurableQueryComponent]>;
|
|
27
29
|
static ɵinj: i0.ɵɵInjectorDeclaration<NzxConfigurableQueryModule>;
|
|
28
30
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { NzxQueryControlOptions } from '../type';
|
|
2
|
-
import { FormGroup } from '@angular/forms';
|
|
2
|
+
import { FormControl, FormGroup } from '@angular/forms';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/**
|
|
5
5
|
* 用来动态添加control type类型控件,类型控件需要继承此控件
|
|
@@ -7,6 +7,7 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
export declare abstract class NzxAbstractControl {
|
|
8
8
|
form: FormGroup<any>;
|
|
9
9
|
control: NzxQueryControlOptions;
|
|
10
|
+
get formControl(): FormControl<any>;
|
|
10
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<NzxAbstractControl, never>;
|
|
11
12
|
static ɵdir: i0.ɵɵDirectiveDeclaration<NzxAbstractControl, never, never, { "form": { "alias": "form"; "required": false; }; "control": { "alias": "control"; "required": false; }; }, {}, never, never, false, never>;
|
|
12
13
|
}
|
|
@@ -10,8 +10,11 @@ export declare class NzxQueryConfigService {
|
|
|
10
10
|
private controlTypePoll;
|
|
11
11
|
controlTypes$: BehaviorSubject<NzxQueryControlType[]>;
|
|
12
12
|
constructor(nzxQueryConfig: NzxQueryConfig);
|
|
13
|
+
/** 添加controlType 类型控件 */
|
|
13
14
|
addControlType(controlType: NzxQueryControlType): void;
|
|
15
|
+
/** 删除controlType 类型控件 */
|
|
14
16
|
removeControlType(key: string): void;
|
|
17
|
+
/** 刷新 */
|
|
15
18
|
refreshControlType(): void;
|
|
16
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<NzxQueryConfigService, [{ optional: true; }]>;
|
|
17
20
|
static ɵprov: i0.ɵɵInjectableDeclaration<NzxQueryConfigService>;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NzxDFAbstractItemWrapper } from '../wrapper/item/abstract-item-wrapper';
|
|
2
|
+
import { NzxDFAbstractLabelWrapper } from '../wrapper/label/abstract-label-wrapper';
|
|
3
|
+
import { NzxDFAbstractControlWrapper } from '../wrapper/control/abstract-control-wrapper';
|
|
4
|
+
import { NzxDFAbstractControl } from '../controls/abstract.control';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export declare class NzxDFConfigService {
|
|
7
|
+
private itemWrapperMap;
|
|
8
|
+
private labelWrapperMap;
|
|
9
|
+
private controlWrapperMap;
|
|
10
|
+
private controlMap;
|
|
11
|
+
constructor();
|
|
12
|
+
getItemWrapper(key: string): typeof NzxDFAbstractItemWrapper;
|
|
13
|
+
getLabelWrapper(key: string): typeof NzxDFAbstractLabelWrapper;
|
|
14
|
+
getControlWrapper(key: string): typeof NzxDFAbstractControlWrapper;
|
|
15
|
+
getControl(key: string): typeof NzxDFAbstractControl;
|
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFConfigService, never>;
|
|
17
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<NzxDFConfigService>;
|
|
18
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { FormGroup } from '@angular/forms';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* 用来动态添加control type类型控件,类型控件需要继承此控件
|
|
5
|
+
*/
|
|
6
|
+
export declare class NzxDFAbstractControl {
|
|
7
|
+
form: FormGroup<any>;
|
|
8
|
+
control: any;
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFAbstractControl, never>;
|
|
10
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NzxDFAbstractControl, never, never, { "form": { "alias": "form"; "required": false; }; "control": { "alias": "control"; "required": false; }; }, {}, never, never, false, never>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { NzxDFAbstractControl } from './abstract.control';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFDatePickerControlComponent extends NzxDFAbstractControl {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFDatePickerControlComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFDatePickerControlComponent, "ng-component", never, {}, {}, never, never, false, never>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { NzxDFAbstractControl } from './abstract.control';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFInputControlComponent extends NzxDFAbstractControl {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFInputControlComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFInputControlComponent, "ng-component", never, {}, {}, never, never, false, never>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { NzxDFAbstractControl } from './abstract.control';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFRangePickerControlComponent extends NzxDFAbstractControl {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFRangePickerControlComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFRangePickerControlComponent, "ng-component", never, {}, {}, never, never, false, never>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { NzxDFAbstractControl } from './abstract.control';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFSelectControlComponent extends NzxDFAbstractControl {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFSelectControlComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFSelectControlComponent, "ng-component", never, {}, {}, never, never, false, never>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { NzxDFAbstractControl } from './abstract.control';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFTemplateControlComponent extends NzxDFAbstractControl {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFTemplateControlComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFTemplateControlComponent, "ng-component", never, {}, {}, never, never, false, never>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { NzxDFConfigService } from '../config/dynamic-form-config';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class DynamicFormItemComponent implements OnInit {
|
|
5
|
+
private nzxDFConfig;
|
|
6
|
+
private itemTemplateView;
|
|
7
|
+
constructor(nzxDFConfig: NzxDFConfigService);
|
|
8
|
+
ngOnInit(): void;
|
|
9
|
+
private renderItem;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DynamicFormItemComponent, never>;
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DynamicFormItemComponent, "nzx-dynamic-form-item", never, {}, {}, never, never, false, never>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class NzxDynamicFormComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDynamicFormComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDynamicFormComponent, "nzx-dynamic-form", never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ModuleWithProviders } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "./dynamic-form.component";
|
|
4
|
+
import * as i2 from "./dynamic-form-item/dynamic-form-item.component";
|
|
5
|
+
import * as i3 from "./wrapper/item/built-in-item-wrapper";
|
|
6
|
+
import * as i4 from "./wrapper/label/built-in-label-wrapper";
|
|
7
|
+
import * as i5 from "./wrapper/control/built-in-control-wrapper";
|
|
8
|
+
import * as i6 from "./controls/date-picker.control";
|
|
9
|
+
import * as i7 from "./controls/input.control";
|
|
10
|
+
import * as i8 from "./controls/range-picker.control";
|
|
11
|
+
import * as i9 from "./controls/select.control";
|
|
12
|
+
import * as i10 from "@angular/common";
|
|
13
|
+
import * as i11 from "@angular/forms";
|
|
14
|
+
import * as i12 from "ng-zorro-antd/form";
|
|
15
|
+
import * as i13 from "ng-zorro-antd/input";
|
|
16
|
+
import * as i14 from "ng-zorro-antd/select";
|
|
17
|
+
import * as i15 from "ng-zorro-antd/date-picker";
|
|
18
|
+
export declare class NzxDynamicFormModule {
|
|
19
|
+
static forRoot(): ModuleWithProviders<NzxDynamicFormModule>;
|
|
20
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDynamicFormModule, never>;
|
|
21
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NzxDynamicFormModule, [typeof i1.NzxDynamicFormComponent, typeof i2.DynamicFormItemComponent, typeof i3.NzxDFBuiltInItemWrapperComponent, typeof i4.NzxDFBuiltInLabelWrapperComponent, typeof i5.NzxDFBuiltInControlWrapperComponent, typeof i6.NzxDFDatePickerControlComponent, typeof i7.NzxDFInputControlComponent, typeof i8.NzxDFRangePickerControlComponent, typeof i9.NzxDFSelectControlComponent], [typeof i10.CommonModule, typeof i11.ReactiveFormsModule, typeof i12.NzFormModule, typeof i13.NzInputModule, typeof i14.NzSelectModule, typeof i15.NzDatePickerModule], [typeof i1.NzxDynamicFormComponent]>;
|
|
22
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<NzxDynamicFormModule>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
3
|
+
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
|
|
4
|
+
*/
|
|
5
|
+
export * from './config/dynamic-form-config';
|
|
6
|
+
export * from './dynamic-form.component';
|
|
7
|
+
export * from './dynamic-form.module';
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { NzxDFConfigService } from '../../config/dynamic-form-config';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class NzxDFAbstractControlWrapper implements OnInit {
|
|
5
|
+
private nzxDFConfig;
|
|
6
|
+
private controlTemplateView;
|
|
7
|
+
constructor(nzxDFConfig: NzxDFConfigService);
|
|
8
|
+
ngOnInit(): void;
|
|
9
|
+
private renderControl;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFAbstractControlWrapper, never>;
|
|
11
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NzxDFAbstractControlWrapper, never, never, {}, {}, never, never, false, never>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { NzxDFAbstractControlWrapper } from './abstract-control-wrapper';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFBuiltInControlWrapperComponent extends NzxDFAbstractControlWrapper {
|
|
4
|
+
controlWrapper: boolean;
|
|
5
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFBuiltInControlWrapperComponent, never>;
|
|
6
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFBuiltInControlWrapperComponent, "nzx-built-in-control-wrapper", never, {}, {}, never, never, false, never>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { NzxDFConfigService } from '../../config/dynamic-form-config';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class NzxDFAbstractItemWrapper implements OnInit {
|
|
5
|
+
private nzxDFConfig;
|
|
6
|
+
private labelWrapperTemplateView;
|
|
7
|
+
private controlWrapperTemplateView;
|
|
8
|
+
constructor(nzxDFConfig: NzxDFConfigService);
|
|
9
|
+
ngOnInit(): void;
|
|
10
|
+
private renderLabel;
|
|
11
|
+
private renderControl;
|
|
12
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFAbstractItemWrapper, never>;
|
|
13
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NzxDFAbstractItemWrapper, never, never, {}, {}, never, never, false, never>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { NzxDFAbstractItemWrapper } from './abstract-item-wrapper';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFBuiltInItemWrapperComponent extends NzxDFAbstractItemWrapper {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFBuiltInItemWrapperComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFBuiltInItemWrapperComponent, "nzx-built-in-item-wrapper", never, {}, {}, never, never, false, never>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class NzxDFAbstractLabelWrapper {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFAbstractLabelWrapper, never>;
|
|
4
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NzxDFAbstractLabelWrapper, never, never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { NzxDFAbstractLabelWrapper } from './abstract-label-wrapper';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class NzxDFBuiltInLabelWrapperComponent extends NzxDFAbstractLabelWrapper {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NzxDFBuiltInLabelWrapperComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxDFBuiltInLabelWrapperComponent, "nzx-built-in-label-wrapper", never, {}, {}, never, never, false, never>;
|
|
6
|
+
}
|
package/esm2022/configurable-query/configurable-query-item/configurable-query-item.component.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
2
2
|
import { Subject, takeUntil } from 'rxjs';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../query-config.service";
|
|
@@ -51,7 +51,7 @@ export class NzxConfigurableQueryItemComponent {
|
|
|
51
51
|
<ng-template #controlTemp></ng-template>
|
|
52
52
|
</nz-form-control>
|
|
53
53
|
</nz-form-item>
|
|
54
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NzColDirective, selector: "[nz-col],nz-col,nz-form-control,nz-form-label", inputs: ["nzFlex", "nzSpan", "nzOrder", "nzOffset", "nzPush", "nzPull", "nzXs", "nzSm", "nzMd", "nzLg", "nzXl", "nzXXl"], exportAs: ["nzCol"] }, { kind: "directive", type: i3.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { kind: "component", type: i4.NzFormItemComponent, selector: "nz-form-item", exportAs: ["nzFormItem"] }, { kind: "component", type: i4.NzFormLabelComponent, selector: "nz-form-label", inputs: ["nzFor", "nzRequired", "nzNoColon", "nzTooltipTitle", "nzTooltipIcon", "nzLabelAlign", "nzLabelWrap"], exportAs: ["nzFormLabel"] }, { kind: "component", type: i4.NzFormControlComponent, selector: "nz-form-control", inputs: ["nzSuccessTip", "nzWarningTip", "nzErrorTip", "nzValidatingTip", "nzExtra", "nzAutoTips", "nzDisableAutoTips", "nzHasFeedback", "nzValidateStatus"], exportAs: ["nzFormControl"] }] }); }
|
|
54
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NzColDirective, selector: "[nz-col],nz-col,nz-form-control,nz-form-label", inputs: ["nzFlex", "nzSpan", "nzOrder", "nzOffset", "nzPush", "nzPull", "nzXs", "nzSm", "nzMd", "nzLg", "nzXl", "nzXXl"], exportAs: ["nzCol"] }, { kind: "directive", type: i3.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { kind: "component", type: i4.NzFormItemComponent, selector: "nz-form-item", exportAs: ["nzFormItem"] }, { kind: "component", type: i4.NzFormLabelComponent, selector: "nz-form-label", inputs: ["nzFor", "nzRequired", "nzNoColon", "nzTooltipTitle", "nzTooltipIcon", "nzLabelAlign", "nzLabelWrap"], exportAs: ["nzFormLabel"] }, { kind: "component", type: i4.NzFormControlComponent, selector: "nz-form-control", inputs: ["nzSuccessTip", "nzWarningTip", "nzErrorTip", "nzValidatingTip", "nzExtra", "nzAutoTips", "nzDisableAutoTips", "nzHasFeedback", "nzValidateStatus"], exportAs: ["nzFormControl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
55
55
|
}
|
|
56
56
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NzxConfigurableQueryItemComponent, decorators: [{
|
|
57
57
|
type: Component,
|
|
@@ -73,6 +73,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
73
73
|
</nz-form-control>
|
|
74
74
|
</nz-form-item>
|
|
75
75
|
`,
|
|
76
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
76
77
|
}]
|
|
77
78
|
}], ctorParameters: () => [{ type: i1.NzxQueryConfigService }], propDecorators: { form: [{
|
|
78
79
|
type: Input
|
|
@@ -82,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
82
83
|
type: ViewChild,
|
|
83
84
|
args: ['controlTemp', { static: true, read: ViewContainerRef }]
|
|
84
85
|
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhYmxlLXF1ZXJ5LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vY29tcG9uZW50cy9jb25maWd1cmFibGUtcXVlcnkvY29uZmlndXJhYmxlLXF1ZXJ5LWl0ZW0vY29uZmlndXJhYmxlLXF1ZXJ5LWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssRUFHTCxTQUFTLEVBQ1QsZ0JBQWdCLEdBQ2pCLE1BQU0sZUFBZSxDQUFDO0FBR3ZCLE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7Ozs7QUF3QjFDLE1BQU0sT0FBTyxpQ0FBaUM7SUFTNUMsWUFBb0IscUJBQTRDO1FBQTVDLDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBdUI7UUFGeEQsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFFNEIsQ0FBQztJQUVwRSxRQUFRO1FBQ04sSUFBSSxDQUFDLHFCQUFxQixDQUFDLGFBQWE7YUFDckMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDOUIsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDbEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDckIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUMxQjtJQUNILENBQUM7SUFFTyxhQUFhLENBQUMsSUFBMkI7UUFDL0MsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2pDLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNwRSxJQUFJLE1BQU0sRUFBRTtZQUNWLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxlQUFlLENBQzNELE1BQU0sQ0FBQyxTQUFnQixDQUN4QixDQUFDO1lBQ0YsWUFBWSxDQUFDLFFBQVEsQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQy9DLFlBQVksQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUMxQzthQUFNO1lBQ0wsTUFBTSxrQkFBa0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLGlCQUFpQixDQUFDO1NBQ25FO0lBQ0gsQ0FBQzsrR0F0Q1UsaUNBQWlDO21HQUFqQyxpQ0FBaUMsZ05BSUksZ0JBQWdCLDJDQXRCdEQ7Ozs7Ozs7Ozs7Ozs7OztHQWVUOzs0RkFHVSxpQ0FBaUM7a0JBcEI3QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSw2QkFBNkI7b0JBQ3ZDLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7O0dBZVQ7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2hEOzBGQUVVLElBQUk7c0JBQVosS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBR0UsbUJBQW1CO3NCQUQxQixTQUFTO3VCQUFDLGFBQWEsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSW5wdXQsXG4gIE9uRGVzdHJveSxcbiAgT25Jbml0LFxuICBWaWV3Q2hpbGQsXG4gIFZpZXdDb250YWluZXJSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBTdWJqZWN0LCB0YWtlVW50aWwgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE56eFF1ZXJ5Q29uZmlnU2VydmljZSB9IGZyb20gJy4uL3F1ZXJ5LWNvbmZpZy5zZXJ2aWNlJztcbmltcG9ydCB7IE56eFF1ZXJ5Q29udHJvbE9wdGlvbnMsIE56eFF1ZXJ5Q29udHJvbFR5cGUgfSBmcm9tICcuLi90eXBlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbnp4LWNvbmZpZ3VyYWJsZS1xdWVyeS1pdGVtJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bnotZm9ybS1pdGVtPlxuICAgICAgPG56LWZvcm0tbGFiZWwgKm5nSWY9XCJjb250cm9sLmxhYmVsXCIgW256U3Bhbl09XCJjb250cm9sLm56eExTcGFuIHx8IDZcIj5cbiAgICAgICAge3sgY29udHJvbC5sYWJlbCB9fVxuICAgICAgPC9uei1mb3JtLWxhYmVsPlxuICAgICAgPG56LWZvcm0tY29udHJvbFxuICAgICAgICBbbnpTcGFuXT1cImNvbnRyb2wubnp4UlNwYW4gfHwgMThcIlxuICAgICAgICBbbnpWYWxpZGF0ZVN0YXR1c109XCJcbiAgICAgICAgICBjb250cm9sPy5jb250cm9sSW5zdGFuY2UgPz8gJGFueShmb3JtLmdldChjb250cm9sLmNvbnRyb2xOYW1lISkpXG4gICAgICAgIFwiXG4gICAgICAgIFtuekVycm9yVGlwXT1cImNvbnRyb2wuZXJyb3JUaXBcIlxuICAgICAgPlxuICAgICAgICA8bmctdGVtcGxhdGUgI2NvbnRyb2xUZW1wPjwvbmctdGVtcGxhdGU+XG4gICAgICA8L256LWZvcm0tY29udHJvbD5cbiAgICA8L256LWZvcm0taXRlbT5cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIE56eENvbmZpZ3VyYWJsZVF1ZXJ5SXRlbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgQElucHV0KCkgZm9ybSE6IEZvcm1Hcm91cDtcbiAgQElucHV0KCkgY29udHJvbCE6IE56eFF1ZXJ5Q29udHJvbE9wdGlvbnM7XG5cbiAgQFZpZXdDaGlsZCgnY29udHJvbFRlbXAnLCB7IHN0YXRpYzogdHJ1ZSwgcmVhZDogVmlld0NvbnRhaW5lclJlZiB9KVxuICBwcml2YXRlIGNvbnRyb2xUZW1wbGF0ZVZpZXchOiBWaWV3Q29udGFpbmVyUmVmO1xuXG4gIHByaXZhdGUgZGVzdHJveSQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbnp4UXVlcnlDb25maWdTZXJ2aWNlOiBOenhRdWVyeUNvbmZpZ1NlcnZpY2UpIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5uenhRdWVyeUNvbmZpZ1NlcnZpY2UuY29udHJvbFR5cGVzJFxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKVxuICAgICAgLnN1YnNjcmliZSgobGlzdCkgPT4ge1xuICAgICAgICB0aGlzLnJlbmRlckNvbnRyb2wobGlzdCk7XG4gICAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmRlc3Ryb3kkKSB7XG4gICAgICB0aGlzLmRlc3Ryb3kkLm5leHQoKTtcbiAgICAgIHRoaXMuZGVzdHJveSQuY29tcGxldGUoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIHJlbmRlckNvbnRyb2wobGlzdDogTnp4UXVlcnlDb250cm9sVHlwZVtdKSB7XG4gICAgdGhpcy5jb250cm9sVGVtcGxhdGVWaWV3LmNsZWFyKCk7XG4gICAgY29uc3QgY29uZmlnID0gbGlzdC5maW5kKChpKSA9PiBpLmtleSA9PT0gdGhpcy5jb250cm9sLmNvbnRyb2xUeXBlKTtcbiAgICBpZiAoY29uZmlnKSB7XG4gICAgICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLmNvbnRyb2xUZW1wbGF0ZVZpZXcuY3JlYXRlQ29tcG9uZW50KFxuICAgICAgICBjb25maWcuY29tcG9uZW50IGFzIGFueVxuICAgICAgKTtcbiAgICAgIGNvbXBvbmVudFJlZi5zZXRJbnB1dCgnY29udHJvbCcsIHRoaXMuY29udHJvbCk7XG4gICAgICBjb21wb25lbnRSZWYuc2V0SW5wdXQoJ2Zvcm0nLCB0aGlzLmZvcm0pO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBgQ29udHJvbFR5cGU6OiAnJHt0aGlzLmNvbnRyb2wuY29udHJvbFR5cGV9JyBpcyBpbnZhbGlkYXRlYDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -11,20 +11,23 @@ import * as i5 from "ng-zorro-antd/form";
|
|
|
11
11
|
import * as i6 from "ng-zorro-antd/button";
|
|
12
12
|
import * as i7 from "ng-zorro-antd/core/transition-patch";
|
|
13
13
|
import * as i8 from "ng-zorro-antd/core/wave";
|
|
14
|
-
import * as i9 from "ng-zorro-antd/
|
|
15
|
-
import * as i10 from "
|
|
14
|
+
import * as i9 from "ng-zorro-antd/card";
|
|
15
|
+
import * as i10 from "ng-zorro-antd/space";
|
|
16
|
+
import * as i11 from "ng-zorro-antd/icon";
|
|
17
|
+
import * as i12 from "./configurable-query-item/configurable-query-item.component";
|
|
16
18
|
/**
|
|
17
19
|
* 查询组件
|
|
18
20
|
* 支持模板自定义,在使用模板自定义时,要注意controlType应该设置为Template并且确保controlName与指令上的nzxControl应该相同
|
|
19
21
|
*/
|
|
20
22
|
export class NzxConfigurableQueryComponent {
|
|
21
|
-
/**
|
|
23
|
+
/** 组件最终的查询参数 */
|
|
22
24
|
get queryParams() {
|
|
23
25
|
return this._queryParams;
|
|
24
26
|
}
|
|
25
27
|
set queryParams(value) {
|
|
26
28
|
this._queryParams = value;
|
|
27
29
|
}
|
|
30
|
+
/** 判断当前组件是否展示展开折叠按钮 */
|
|
28
31
|
get nzxCollapse() {
|
|
29
32
|
return this.controls.some((i) => i.hasOwnProperty('collapse'));
|
|
30
33
|
}
|
|
@@ -32,19 +35,21 @@ export class NzxConfigurableQueryComponent {
|
|
|
32
35
|
this.i18n = i18n;
|
|
33
36
|
this.fb = fb;
|
|
34
37
|
this.cd = cd;
|
|
35
|
-
/**
|
|
38
|
+
/**
|
|
39
|
+
* 配置项用来生成查询表单
|
|
40
|
+
*/
|
|
36
41
|
this.controls = [];
|
|
37
|
-
/**
|
|
42
|
+
/** 查询表单排列方式默认start */
|
|
38
43
|
this.nzxJustify = 'start';
|
|
39
|
-
/**
|
|
44
|
+
/** 查询项间隔默认为8 */
|
|
40
45
|
this.nzxGutter = 8;
|
|
41
|
-
/**
|
|
46
|
+
/** 一行展示多少查询项默认展示3个 */
|
|
42
47
|
this.lineNumber = 3;
|
|
43
48
|
/** 操作按钮所占栅格数,24则换行 */
|
|
44
49
|
this.nzxBtnSpan = null;
|
|
45
|
-
/**
|
|
50
|
+
/** 初始化时,是否主动触发查询 */
|
|
46
51
|
this.initQuery = false;
|
|
47
|
-
/** 缺省
|
|
52
|
+
/** 缺省 固定参数会固定携带在抛出事件中 */
|
|
48
53
|
this.fixedParams = {};
|
|
49
54
|
/** 查询时会触发抛出查询参数 */
|
|
50
55
|
this.queryChange = new EventEmitter();
|
|
@@ -212,6 +217,7 @@ export class NzxConfigurableQueryComponent {
|
|
|
212
217
|
this.destroy$.next();
|
|
213
218
|
this.destroy$.complete();
|
|
214
219
|
}
|
|
220
|
+
/** 计算展开收起icon、文案 */
|
|
215
221
|
calculateText() {
|
|
216
222
|
if (this.controls.some((i) => i.collapse === true)) {
|
|
217
223
|
this.collapseIcon = 'down';
|
|
@@ -270,11 +276,11 @@ export class NzxConfigurableQueryComponent {
|
|
|
270
276
|
}
|
|
271
277
|
}
|
|
272
278
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NzxConfigurableQueryComponent, deps: [{ token: i1.NzI18nService }, { token: i2.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
273
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NzxConfigurableQueryComponent, selector: "nzx-configurable-query", inputs: { controls: "controls", nzxJustify: "nzxJustify", nzxGutter: "nzxGutter", lineNumber: "lineNumber", nzxBtnSpan: "nzxBtnSpan", initQuery: "initQuery", fixedParams: "fixedParams" }, outputs: { queryChange: "queryChange", resetChange: "resetChange" }, queries: [{ propertyName: "controlTemplateList", predicate: NzxControlDirective, descendants: true }], viewQueries: [{ propertyName: "queyFormEl", first: true, predicate: ["queyForm"], descendants: true }], exportAs: ["NzxConfigurableQuery"], usesOnChanges: true, ngImport: i0, template: "<form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n
|
|
279
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NzxConfigurableQueryComponent, selector: "nzx-configurable-query", inputs: { controls: "controls", nzxJustify: "nzxJustify", nzxGutter: "nzxGutter", lineNumber: "lineNumber", nzxBtnSpan: "nzxBtnSpan", initQuery: "initQuery", fixedParams: "fixedParams" }, outputs: { queryChange: "queryChange", resetChange: "resetChange" }, queries: [{ propertyName: "controlTemplateList", predicate: NzxControlDirective, descendants: true }], viewQueries: [{ propertyName: "queyFormEl", first: true, predicate: ["queyForm"], descendants: true }], exportAs: ["NzxConfigurableQuery"], usesOnChanges: true, ngImport: i0, template: "<nz-card>\n <form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n <div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n <ng-container *ngFor=\"let config of controls; let i = index\">\n <div\n *ngIf=\"!config.hidden\"\n nz-col\n [nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n [hidden]=\"config.collapse\"\n [nzOrder]=\"i\"\n >\n <nzx-configurable-query-item\n *ngIf=\"config.controlName\"\n [form]=\"queryForm\"\n [control]=\"config\"\n ></nzx-configurable-query-item>\n </div>\n </ng-container>\n\n <div\n class=\"nzx-query-btn\"\n nz-col\n [nzOrder]=\"controls.length\"\n [nzSpan]=\"nzxBtnSpan || 24 / lineNumber\"\n >\n <div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n <nz-space>\n <button\n *nzSpaceItem\n nz-button\n nzType=\"primary\"\n type=\"button\"\n title=\"Enter\"\n (click)=\"search()\"\n >\n {{ locale['query'] }}\n </button>\n <button\n *nzSpaceItem\n nz-button\n type=\"button\"\n title=\"ctrl+r\"\n (click)=\"reset()\"\n >\n {{ locale['reset'] }}\n </button>\n <ng-container *nzSpaceItem>\n <ng-content></ng-content>\n </ng-container>\n <ng-container *ngIf=\"nzxCollapse\">\n <a\n *nzSpaceItem\n nz-button\n nzType=\"link\"\n (click)=\"toggleCollapse()\"\n >\n {{ collapseText }}\n <i nz-icon [nzType]=\"collapseIcon\"></i>\n </a>\n </ng-container>\n </nz-space>\n </div>\n </div>\n </div>\n </form>\n</nz-card>\n", styles: [".nzx-query-container [nz-form-label]{overflow:visible}.nzx-query-container .nzx-query-btn{flex-grow:2;max-width:none}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.NzColDirective, selector: "[nz-col],nz-col,nz-form-control,nz-form-label", inputs: ["nzFlex", "nzSpan", "nzOrder", "nzOffset", "nzPush", "nzPull", "nzXs", "nzSm", "nzMd", "nzLg", "nzXl", "nzXXl"], exportAs: ["nzCol"] }, { kind: "directive", type: i4.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { kind: "directive", type: i5.NzFormDirective, selector: "[nz-form]", inputs: ["nzLayout", "nzNoColon", "nzAutoTips", "nzDisableAutoTips", "nzTooltipIcon", "nzLabelAlign", "nzLabelWrap"], exportAs: ["nzForm"] }, { kind: "component", type: i6.NzButtonComponent, selector: "button[nz-button], a[nz-button]", inputs: ["nzBlock", "nzGhost", "nzSearch", "nzLoading", "nzDanger", "disabled", "tabIndex", "nzType", "nzShape", "nzSize"], exportAs: ["nzButton"] }, { kind: "directive", type: i7.ɵNzTransitionPatchDirective, selector: "[nz-button], nz-button-group, [nz-icon], [nz-menu-item], [nz-submenu], nz-select-top-control, nz-select-placeholder, nz-input-group", inputs: ["hidden"] }, { kind: "directive", type: i8.NzWaveDirective, selector: "[nz-wave],button[nz-button]:not([nzType=\"link\"]):not([nzType=\"text\"])", inputs: ["nzWaveExtraNode"], exportAs: ["nzWave"] }, { kind: "component", type: i9.NzCardComponent, selector: "nz-card", inputs: ["nzBordered", "nzBorderless", "nzLoading", "nzHoverable", "nzBodyStyle", "nzCover", "nzActions", "nzType", "nzSize", "nzTitle", "nzExtra"], exportAs: ["nzCard"] }, { kind: "component", type: i10.NzSpaceComponent, selector: "nz-space, [nz-space]", inputs: ["nzDirection", "nzAlign", "nzSplit", "nzWrap", "nzSize"], exportAs: ["NzSpace"] }, { kind: "directive", type: i10.NzSpaceItemDirective, selector: "[nzSpaceItem]" }, { kind: "directive", type: i11.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "component", type: i12.NzxConfigurableQueryItemComponent, selector: "nzx-configurable-query-item", inputs: ["form", "control"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
274
280
|
}
|
|
275
281
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NzxConfigurableQueryComponent, decorators: [{
|
|
276
282
|
type: Component,
|
|
277
|
-
args: [{ selector: 'nzx-configurable-query', changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'NzxConfigurableQuery', template: "<form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n
|
|
283
|
+
args: [{ selector: 'nzx-configurable-query', changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'NzxConfigurableQuery', template: "<nz-card>\n <form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n <div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n <ng-container *ngFor=\"let config of controls; let i = index\">\n <div\n *ngIf=\"!config.hidden\"\n nz-col\n [nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n [hidden]=\"config.collapse\"\n [nzOrder]=\"i\"\n >\n <nzx-configurable-query-item\n *ngIf=\"config.controlName\"\n [form]=\"queryForm\"\n [control]=\"config\"\n ></nzx-configurable-query-item>\n </div>\n </ng-container>\n\n <div\n class=\"nzx-query-btn\"\n nz-col\n [nzOrder]=\"controls.length\"\n [nzSpan]=\"nzxBtnSpan || 24 / lineNumber\"\n >\n <div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n <nz-space>\n <button\n *nzSpaceItem\n nz-button\n nzType=\"primary\"\n type=\"button\"\n title=\"Enter\"\n (click)=\"search()\"\n >\n {{ locale['query'] }}\n </button>\n <button\n *nzSpaceItem\n nz-button\n type=\"button\"\n title=\"ctrl+r\"\n (click)=\"reset()\"\n >\n {{ locale['reset'] }}\n </button>\n <ng-container *nzSpaceItem>\n <ng-content></ng-content>\n </ng-container>\n <ng-container *ngIf=\"nzxCollapse\">\n <a\n *nzSpaceItem\n nz-button\n nzType=\"link\"\n (click)=\"toggleCollapse()\"\n >\n {{ collapseText }}\n <i nz-icon [nzType]=\"collapseIcon\"></i>\n </a>\n </ng-container>\n </nz-space>\n </div>\n </div>\n </div>\n </form>\n</nz-card>\n", styles: [".nzx-query-container [nz-form-label]{overflow:visible}.nzx-query-container .nzx-query-btn{flex-grow:2;max-width:none}\n"] }]
|
|
278
284
|
}], ctorParameters: () => [{ type: i1.NzI18nService }, { type: i2.FormBuilder }, { type: i0.ChangeDetectorRef }], propDecorators: { controls: [{
|
|
279
285
|
type: Input
|
|
280
286
|
}], nzxJustify: [{
|
|
@@ -300,4 +306,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
300
306
|
type: ContentChildren,
|
|
301
307
|
args: [NzxControlDirective, { descendants: true }]
|
|
302
308
|
}] } });
|
|
303
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configurable-query.component.js","sourceRoot":"","sources":["../../../../components/configurable-query/configurable-query.component.ts","../../../../components/configurable-query/configurable-query.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentInit,\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChildren,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, FormBuilder, FormGroup } from '@angular/forms';\r\n\r\nimport { NzxQueryI18nInterface } from 'ng-zorro-antd-extension/i18n';\r\nimport { updateControlStatus } from 'ng-zorro-antd-extension/util';\r\nimport { NzJustify } from 'ng-zorro-antd/grid';\r\nimport { NzI18nService } from 'ng-zorro-antd/i18n';\r\nimport { Subject, fromEvent, takeUntil } from 'rxjs';\r\nimport { NzxControlDirective } from './control.directive';\r\nimport { NzxQueryControlOptions, NzxQueryParams } from './type';\r\n\r\n/**\r\n * 查询组件\r\n * 支持模板自定义，在使用模板自定义时，要注意controlType应该设置为Template并且确保controlName与指令上的nzxControl应该相同\r\n */\r\n\r\n@Component({\r\n  selector: 'nzx-configurable-query',\r\n  templateUrl: './configurable-query.component.html',\r\n  styleUrls: ['./configurable-query.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  exportAs: 'NzxConfigurableQuery',\r\n})\r\nexport class NzxConfigurableQueryComponent\r\n  implements OnChanges, OnInit, AfterViewInit, AfterContentInit, OnDestroy\r\n{\r\n  /** 配置项 */\r\n  @Input() controls: Array<NzxQueryControlOptions> = [];\r\n  /** 查询表单排列方式 */\r\n  @Input() nzxJustify: NzJustify = 'start';\r\n  /** 查询项间隔 */\r\n  @Input() nzxGutter: number = 8;\r\n  /** 一行展示多少查询项 */\r\n  @Input() lineNumber: number = 3;\r\n  /** 操作按钮所占栅格数，24则换行 */\r\n  @Input() nzxBtnSpan: number | null = null;\r\n  /** 初始化时，主动查询 */\r\n  @Input() initQuery = false;\r\n  /** 缺省 固定参数 */\r\n  @Input() fixedParams = {};\r\n\r\n  /** 查询时会触发抛出查询参数 */\r\n  @Output() queryChange = new EventEmitter<NzxQueryParams>();\r\n  /** 重置时会触发抛出查询参数 */\r\n  @Output() resetChange = new EventEmitter<NzxQueryParams>();\r\n\r\n  /** 查询组件出参*/\r\n  get queryParams() {\r\n    return this._queryParams;\r\n  }\r\n  set queryParams(value: any) {\r\n    this._queryParams = value;\r\n  }\r\n\r\n  get nzxCollapse() {\r\n    return this.controls.some((i) => i.hasOwnProperty('collapse'));\r\n  }\r\n\r\n  /** form 表单*/\r\n  queryForm!: FormGroup;\r\n  locale!: NzxQueryI18nInterface;\r\n  collapseIcon: string = 'down';\r\n  collapseText: string = '';\r\n\r\n  private _queryParams: NzxQueryParams = {};\r\n  /** 重置时用来给查询框默认值 */\r\n  private defaultValue: NzxQueryParams = {};\r\n  private cacheParams: NzxQueryParams = {};\r\n  private destroy$ = new Subject<void>();\r\n\r\n  @ViewChild('queyForm') private queyFormEl!: ElementRef<HTMLFormElement>;\r\n  @ContentChildren(NzxControlDirective, { descendants: true })\r\n  controlTemplateList!: QueryList<NzxControlDirective>;\r\n\r\n  constructor(\r\n    private i18n: NzI18nService,\r\n    private fb: FormBuilder,\r\n    private cd: ChangeDetectorRef\r\n  ) {\r\n    this.queryForm = this.fb.group({});\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['controls'] && !changes['controls'].isFirstChange()) {\r\n      const controls = changes['controls'].currentValue;\r\n      if (Array.isArray(controls)) {\r\n        this.generateForm(controls);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n      this.locale = this.i18n.getLocaleData('Query');\r\n      this.cd.markForCheck();\r\n    });\r\n\r\n    this.queryForm.valueChanges\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((val) => {\r\n        this._queryParams = {\r\n          ...val,\r\n          ...this.fixedParams,\r\n        };\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.queyFormEl) {\r\n      fromEvent<KeyboardEvent>(this.queyFormEl.nativeElement, 'keydown')\r\n        .pipe(takeUntil(this.destroy$))\r\n        .subscribe((event) => {\r\n          if (event.key === 'Enter') {\r\n            event.stopPropagation();\r\n            event.preventDefault();\r\n            this.search();\r\n          }\r\n          // 检查是否同时按下了Ctrl键（在Windows/Linux上）和S键\r\n          if ((event.ctrlKey || event.metaKey) && event.key === 'r') {\r\n            // 注意：event.metaKey用于兼容Mac的Command键\r\n            event.preventDefault(); // 阻止浏览器默认的保存行为\r\n            event.stopPropagation();\r\n            this.reset();\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    this.generateForm(this.controls);\r\n\r\n    if (this.initQuery) {\r\n      this.search();\r\n    }\r\n  }\r\n\r\n  /** 设置查询值进行回显 */\r\n  setQueryParams(cacheParams: NzxQueryParams): void {\r\n    this.cacheParams = cacheParams;\r\n    this.queryForm.patchValue(cacheParams);\r\n  }\r\n\r\n  /**\r\n   * 根据controlName设置config值\r\n   * @param defaultValueResettable 添加的表单控件默认值是否可以重置，默认不可以\r\n   */\r\n  setControl(\r\n    controlName: string,\r\n    config: Partial<NzxQueryControlOptions>,\r\n    defaultValueResettable = false\r\n  ): void {\r\n    const control = this.getControl(controlName);\r\n    if (control) {\r\n      Object.keys(config).forEach((key) => {\r\n        (control as any)[key] = (config as any)[key];\r\n      });\r\n      this.generateControl(control, defaultValueResettable);\r\n      this.cd.markForCheck();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 动态添加控件\r\n   * @param config 配置项\r\n   * @param position 添加位置 不传为末尾\r\n   * @param defaultValueResettable 添加的表单控件默认值是否可以重置，默认不可以\r\n   */\r\n  addControl(\r\n    config: NzxQueryControlOptions,\r\n    position?: number | undefined,\r\n    defaultValueResettable = false\r\n  ): void {\r\n    const control = this.getControl(config.controlName);\r\n    if (!control) {\r\n      if (config && config['hasOwnProperty']('collapse')) {\r\n        const hasCollapseProperty = this.controls.some((i) =>\r\n          i['hasOwnProperty']('collapse')\r\n        );\r\n        if (hasCollapseProperty) {\r\n          config.collapse = this.controls.some((i) => i.collapse === true);\r\n        }\r\n      }\r\n\r\n      this.generateControl(config, defaultValueResettable);\r\n\r\n      if (position === void 0 || position === null) {\r\n        this.controls.push(config);\r\n      } else {\r\n        this.controls.splice(position - 1, 0, config);\r\n      }\r\n      this.calculateText();\r\n    } else {\r\n      throw `The control name: '${config.controlName}' already exists!`;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 根据控件名删除控件\r\n   */\r\n  removeControl(controlName: string): void {\r\n    const control = this.getControl(controlName);\r\n    if (control) {\r\n      this.queryForm.removeControl(controlName);\r\n      this.controls = this.controls.filter(\r\n        (c) => c.controlName !== controlName\r\n      );\r\n      this.calculateText();\r\n    } else {\r\n      throw `The control name: '${controlName}' not find!`;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 根据controlName获取config项\r\n   */\r\n  getControl(\r\n    controlName: string | undefined\r\n  ): NzxQueryControlOptions | undefined {\r\n    return this.controls.find((config) => config.controlName === controlName);\r\n  }\r\n\r\n  /**\r\n   * 检索给定控件名称或路径的子控件。\r\n   * 这个 getFormControl 签名支持字符串和 const 数组（.getFormControl(['foo', 'bar'] as const)）\r\n   */\r\n  getFormControl(\r\n    path: string | readonly (string | number)[]\r\n  ): AbstractControl<any, any> | null {\r\n    return this.queryForm.get(path);\r\n  }\r\n\r\n  /** 查询 */\r\n  search(): void {\r\n    if (this.queryForm.invalid) {\r\n      updateControlStatus(this.queryForm);\r\n      return;\r\n    }\r\n    this.queryChange.emit(this._queryParams);\r\n  }\r\n\r\n  /** 重置 */\r\n  reset(): void {\r\n    this.queryForm.reset(this.defaultValue);\r\n    this.resetChange.emit(this._queryParams);\r\n  }\r\n\r\n  /**展开、收起*/\r\n  toggleCollapse(): void {\r\n    for (let index = 0; index < this.controls.length; index++) {\r\n      const config = this.controls[index];\r\n      const hasProperty = config.hasOwnProperty('collapse');\r\n      if (hasProperty && config.collapse) {\r\n        config.collapse = false;\r\n      } else if (hasProperty && !config.collapse) {\r\n        config.collapse = true;\r\n      }\r\n    }\r\n    this.calculateText();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  private calculateText() {\r\n    if (this.controls.some((i) => i.collapse === true)) {\r\n      this.collapseIcon = 'down';\r\n      this.collapseText = this.locale.expand;\r\n    } else {\r\n      this.collapseIcon = 'up';\r\n      this.collapseText = this.locale.collapse;\r\n    }\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  /** 清空表单控件 */\r\n  private clearFormControl(): void {\r\n    Object.keys(this.queryForm.controls).forEach((key) => {\r\n      this.queryForm.removeControl(key);\r\n    });\r\n  }\r\n\r\n  /** 生成 queryForm 表单 */\r\n  private generateForm(controlConfigs: Array<NzxQueryControlOptions>): void {\r\n    this.clearFormControl();\r\n\r\n    for (const config of controlConfigs) {\r\n      this.generateControl(config);\r\n    }\r\n    this.defaultValue = this.queryForm.getRawValue();\r\n\r\n    if (this.cacheParams) {\r\n      // 缓存回显查询条件\r\n      this.queryForm.patchValue(this.cacheParams);\r\n    }\r\n\r\n    this.calculateText();\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param controlConfig control配置\r\n   * @param defaultValueResettable 添加的表单控件默认值是否可以重置，默认不可以\r\n   *\r\n   * 1. 生成单个表单控件并将其添加到queryForm中\r\n   * 2. 如果没有templateRef根据controlName获取投影的templateList中的templateRef给 templateRef 赋值\r\n   *\r\n   **/\r\n  private generateControl(\r\n    config: NzxQueryControlOptions,\r\n    defaultValueResettable = false\r\n  ) {\r\n    if (config.controlName) {\r\n      if (!config?.templateRef) {\r\n        const d = this.controlTemplateList.find(\r\n          (d) => d.nzxControl === config.controlName\r\n        );\r\n        if (d) {\r\n          config.templateRef = d.templateRef;\r\n        }\r\n      }\r\n\r\n      this.queryForm.setControl(\r\n        config.controlName,\r\n        config.controlInstance ?? this.fb.control(config.default ?? null)\r\n      );\r\n\r\n      if (!defaultValueResettable) {\r\n        const control = this.queryForm.get(config.controlName);\r\n        this.defaultValue = {\r\n          ...this.defaultValue,\r\n          [config.controlName]: control.value,\r\n        };\r\n      }\r\n    }\r\n  }\r\n}\r\n","<form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n  <div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n    <ng-container *ngFor=\"let config of controls; let i = index\">\n      <div\n        *ngIf=\"!config.hidden\"\n        nz-col\n        [nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n        [hidden]=\"config.collapse\"\n        [nzOrder]=\"i\"\n      >\n        <nzx-configurable-query-item\n          *ngIf=\"config.controlName\"\n          [form]=\"queryForm\"\n          [control]=\"config\"\n        ></nzx-configurable-query-item>\n      </div>\n    </ng-container>\n\n    <div\n      [nzOrder]=\"controls.length\"\n      class=\"nzx-query-btn\"\n      nz-col\n      [nzSpan]=\"nzxBtnSpan || 24 / lineNumber\"\n    >\n      <div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n        <button\n          nz-button\n          nzType=\"primary\"\n          type=\"button\"\n          title=\"Enter\"\n          (click)=\"search()\"\n        >\n          {{ locale['query'] }}\n        </button>\n        <button nz-button type=\"button\" title=\"ctrl+r\" (click)=\"reset()\">\n          {{ locale['reset'] }}\n        </button>\n        <ng-content></ng-content>\n        <a\n          *ngIf=\"nzxCollapse\"\n          nz-button\n          nzType=\"link\"\n          (click)=\"toggleCollapse()\"\n        >\n          {{ collapseText }}\n          <i nz-icon [nzType]=\"collapseIcon\"></i>\n        </a>\n      </div>\n    </div>\n  </div>\n</form>\n"]}
|
|
309
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configurable-query.component.js","sourceRoot":"","sources":["../../../../components/configurable-query/configurable-query.component.ts","../../../../components/configurable-query/configurable-query.component.html"],"names":[],"mappings":"AAAA,OAAO,EAGL,uBAAuB,EAEvB,SAAS,EACT,eAAe,EAEf,YAAY,EACZ,KAAK,EAIL,MAAM,EAGN,SAAS,GACV,MAAM,eAAe,CAAC;AAIvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAGnE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;;;;;;AAG1D;;;GAGG;AASH,MAAM,OAAO,6BAA6B;IAyBxC,gBAAgB;IAChB,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IACD,IAAI,WAAW,CAAC,KAAU;QACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,uBAAuB;IACvB,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;IACjE,CAAC;IAkBD,YACU,IAAmB,EACnB,EAAe,EACf,EAAqB;QAFrB,SAAI,GAAJ,IAAI,CAAe;QACnB,OAAE,GAAF,EAAE,CAAa;QACf,OAAE,GAAF,EAAE,CAAmB;QAtD/B;;WAEG;QACM,aAAQ,GAAkC,EAAE,CAAC;QACtD,sBAAsB;QACb,eAAU,GAAc,OAAO,CAAC;QACzC,gBAAgB;QACP,cAAS,GAAW,CAAC,CAAC;QAC/B,sBAAsB;QACb,eAAU,GAAW,CAAC,CAAC;QAChC,sBAAsB;QACb,eAAU,GAAkB,IAAI,CAAC;QAC1C,oBAAoB;QACX,cAAS,GAAG,KAAK,CAAC;QAC3B,yBAAyB;QAChB,gBAAW,GAAG,EAAE,CAAC;QAE1B,mBAAmB;QACT,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QAC3D,mBAAmB;QACT,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QAkB3D,iBAAY,GAAW,MAAM,CAAC;QAC9B,iBAAY,GAAW,EAAE,CAAC;QAElB,iBAAY,GAAmB,EAAE,CAAC;QAC1C,mBAAmB;QACX,iBAAY,GAAmB,EAAE,CAAC;QAClC,gBAAW,GAAmB,EAAE,CAAC;QACjC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAWrC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,aAAa,EAAE,EAAE;YAC/D,MAAM,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC;YAClD,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAC3B,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;aAC7B;SACF;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACnE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YAC/C,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,YAAY;aACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACjB,IAAI,CAAC,YAAY,GAAG;gBAClB,GAAG,GAAG;gBACN,GAAG,IAAI,CAAC,WAAW;aACpB,CAAC;QACJ,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,SAAS,CAAgB,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,CAAC;iBAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBAC9B,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBACnB,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;oBACzB,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,MAAM,EAAE,CAAC;iBACf;gBACD,qCAAqC;gBACrC,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE;oBACzD,mCAAmC;oBACnC,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC,eAAe;oBACvC,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,IAAI,CAAC,KAAK,EAAE,CAAC;iBACd;YACH,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEjC,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,MAAM,EAAE,CAAC;SACf;IACH,CAAC;IAED,gBAAgB;IAChB,cAAc,CAAC,WAA2B;QACxC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAED;;;OAGG;IACH,UAAU,CACR,WAAmB,EACnB,MAAuC,EACvC,sBAAsB,GAAG,KAAK;QAE9B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAC7C,IAAI,OAAO,EAAE;YACX,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBACjC,OAAe,CAAC,GAAG,CAAC,GAAI,MAAc,CAAC,GAAG,CAAC,CAAC;YAC/C,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,sBAAsB,CAAC,CAAC;YACtD,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;SACxB;IACH,CAAC;IAED;;;;;OAKG;IACH,UAAU,CACR,MAA8B,EAC9B,QAA6B,EAC7B,sBAAsB,GAAG,KAAK;QAE9B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QACpD,IAAI,CAAC,OAAO,EAAE;YACZ,IAAI,MAAM,IAAI,MAAM,CAAC,gBAAgB,CAAC,CAAC,UAAU,CAAC,EAAE;gBAClD,MAAM,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CACnD,CAAC,CAAC,gBAAgB,CAAC,CAAC,UAAU,CAAC,CAChC,CAAC;gBACF,IAAI,mBAAmB,EAAE;oBACvB,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC;iBAClE;aACF;YAED,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,sBAAsB,CAAC,CAAC;YAErD,IAAI,QAAQ,KAAK,KAAK,CAAC,IAAI,QAAQ,KAAK,IAAI,EAAE;gBAC5C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aAC5B;iBAAM;gBACL,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,GAAG,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;aAC/C;YACD,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;aAAM;YACL,MAAM,sBAAsB,MAAM,CAAC,WAAW,mBAAmB,CAAC;SACnE;IACH,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,WAAmB;QAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAC7C,IAAI,OAAO,EAAE;YACX,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;YAC1C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,WAAW,CACrC,CAAC;YACF,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;aAAM;YACL,MAAM,sBAAsB,WAAW,aAAa,CAAC;SACtD;IACH,CAAC;IAED;;OAEG;IACH,UAAU,CACR,WAA+B;QAE/B,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,KAAK,WAAW,CAAC,CAAC;IAC5E,CAAC;IAED;;;OAGG;IACH,cAAc,CACZ,IAA2C;QAE3C,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAED,SAAS;IACT,MAAM;QACJ,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;YAC1B,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACpC,OAAO;SACR;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC3C,CAAC;IAED,SAAS;IACT,KAAK;QACH,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACxC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC3C,CAAC;IAED,UAAU;IACV,cAAc;QACZ,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YACzD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACpC,MAAM,WAAW,GAAG,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;YACtD,IAAI,WAAW,IAAI,MAAM,CAAC,QAAQ,EAAE;gBAClC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;aACzB;iBAAM,IAAI,WAAW,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC1C,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC;aACxB;SACF;QACD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,oBAAoB;IACZ,aAAa;QACnB,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,EAAE;YAClD,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;YAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;SACxC;aAAM;YACL,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;SAC1C;QACD,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IACzB,CAAC;IAED,aAAa;IACL,gBAAgB;QACtB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YACnD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB;IACd,YAAY,CAAC,cAA6C;QAChE,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,KAAK,MAAM,MAAM,IAAI,cAAc,EAAE;YACnC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;SAC9B;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;QAEjD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,WAAW;YACX,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC7C;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED;;;;;;;;QAQI;IACI,eAAe,CACrB,MAA8B,EAC9B,sBAAsB,GAAG,KAAK;QAE9B,IAAI,MAAM,CAAC,WAAW,EAAE;YACtB,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE;gBACxB,MAAM,CAAC,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACrC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,MAAM,CAAC,WAAW,CAC3C,CAAC;gBACF,IAAI,CAAC,EAAE;oBACL,MAAM,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC;iBACpC;aACF;YAED,IAAI,CAAC,SAAS,CAAC,UAAU,CACvB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,eAAe,IAAI,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC,CAClE,CAAC;YAEF,IAAI,CAAC,sBAAsB,EAAE;gBAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;gBACvD,IAAI,CAAC,YAAY,GAAG;oBAClB,GAAG,IAAI,CAAC,YAAY;oBACpB,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,OAAO,CAAC,KAAK;iBACpC,CAAC;aACH;SACF;IACH,CAAC;+GA7TU,6BAA6B;mGAA7B,6BAA6B,mWAmDvB,mBAAmB,iNC3FtC,09DAkEA;;4FD1Ba,6BAA6B;kBAPzC,SAAS;+BACE,wBAAwB,mBAGjB,uBAAuB,CAAC,MAAM,YACrC,sBAAsB;4IAQvB,QAAQ;sBAAhB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAGI,WAAW;sBAApB,MAAM;gBAEG,WAAW;sBAApB,MAAM;gBA2BwB,UAAU;sBAAxC,SAAS;uBAAC,UAAU;gBAErB,mBAAmB;sBADlB,eAAe;uBAAC,mBAAmB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE","sourcesContent":["import {\r\n  AfterContentInit,\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChildren,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, FormBuilder, FormGroup } from '@angular/forms';\r\n\r\nimport { NzxQueryI18nInterface } from 'ng-zorro-antd-extension/i18n';\r\nimport { updateControlStatus } from 'ng-zorro-antd-extension/util';\r\nimport { NzJustify } from 'ng-zorro-antd/grid';\r\nimport { NzI18nService } from 'ng-zorro-antd/i18n';\r\nimport { Subject, fromEvent, takeUntil } from 'rxjs';\r\nimport { NzxControlDirective } from './control.directive';\r\nimport { NzxQueryControlOptions, NzxQueryParams } from './type';\r\n\r\n/**\r\n * 查询组件\r\n * 支持模板自定义，在使用模板自定义时，要注意controlType应该设置为Template并且确保controlName与指令上的nzxControl应该相同\r\n */\r\n\r\n@Component({\r\n  selector: 'nzx-configurable-query',\r\n  templateUrl: './configurable-query.component.html',\r\n  styleUrls: ['./configurable-query.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  exportAs: 'NzxConfigurableQuery',\r\n})\r\nexport class NzxConfigurableQueryComponent\r\n  implements OnChanges, OnInit, AfterViewInit, AfterContentInit, OnDestroy\r\n{\r\n  /**\r\n   * 配置项用来生成查询表单\r\n   */\r\n  @Input() controls: Array<NzxQueryControlOptions> = [];\r\n  /** 查询表单排列方式默认start */\r\n  @Input() nzxJustify: NzJustify = 'start';\r\n  /** 查询项间隔默认为8 */\r\n  @Input() nzxGutter: number = 8;\r\n  /** 一行展示多少查询项默认展示3个 */\r\n  @Input() lineNumber: number = 3;\r\n  /** 操作按钮所占栅格数，24则换行 */\r\n  @Input() nzxBtnSpan: number | null = null;\r\n  /** 初始化时，是否主动触发查询 */\r\n  @Input() initQuery = false;\r\n  /** 缺省 固定参数会固定携带在抛出事件中 */\r\n  @Input() fixedParams = {};\r\n\r\n  /** 查询时会触发抛出查询参数 */\r\n  @Output() queryChange = new EventEmitter<NzxQueryParams>();\r\n  /** 重置时会触发抛出查询参数 */\r\n  @Output() resetChange = new EventEmitter<NzxQueryParams>();\r\n\r\n  /** 组件最终的查询参数 */\r\n  get queryParams() {\r\n    return this._queryParams;\r\n  }\r\n  set queryParams(value: any) {\r\n    this._queryParams = value;\r\n  }\r\n\r\n  /** 判断当前组件是否展示展开折叠按钮 */\r\n  get nzxCollapse() {\r\n    return this.controls.some((i) => i.hasOwnProperty('collapse'));\r\n  }\r\n\r\n  /** 内置 form 查询表单实例 */\r\n  queryForm!: FormGroup;\r\n  locale!: NzxQueryI18nInterface;\r\n  collapseIcon: string = 'down';\r\n  collapseText: string = '';\r\n\r\n  private _queryParams: NzxQueryParams = {};\r\n  /** 重置时用来给查询框默认值 */\r\n  private defaultValue: NzxQueryParams = {};\r\n  private cacheParams: NzxQueryParams = {};\r\n  private destroy$ = new Subject<void>();\r\n\r\n  @ViewChild('queyForm') private queyFormEl!: ElementRef<HTMLFormElement>;\r\n  @ContentChildren(NzxControlDirective, { descendants: true })\r\n  controlTemplateList!: QueryList<NzxControlDirective>;\r\n\r\n  constructor(\r\n    private i18n: NzI18nService,\r\n    private fb: FormBuilder,\r\n    private cd: ChangeDetectorRef\r\n  ) {\r\n    this.queryForm = this.fb.group({});\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['controls'] && !changes['controls'].isFirstChange()) {\r\n      const controls = changes['controls'].currentValue;\r\n      if (Array.isArray(controls)) {\r\n        this.generateForm(controls);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n      this.locale = this.i18n.getLocaleData('Query');\r\n      this.cd.markForCheck();\r\n    });\r\n\r\n    this.queryForm.valueChanges\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((val) => {\r\n        this._queryParams = {\r\n          ...val,\r\n          ...this.fixedParams,\r\n        };\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.queyFormEl) {\r\n      fromEvent<KeyboardEvent>(this.queyFormEl.nativeElement, 'keydown')\r\n        .pipe(takeUntil(this.destroy$))\r\n        .subscribe((event) => {\r\n          if (event.key === 'Enter') {\r\n            event.stopPropagation();\r\n            event.preventDefault();\r\n            this.search();\r\n          }\r\n          // 检查是否同时按下了Ctrl键（在Windows/Linux上）和S键\r\n          if ((event.ctrlKey || event.metaKey) && event.key === 'r') {\r\n            // 注意：event.metaKey用于兼容Mac的Command键\r\n            event.preventDefault(); // 阻止浏览器默认的保存行为\r\n            event.stopPropagation();\r\n            this.reset();\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    this.generateForm(this.controls);\r\n\r\n    if (this.initQuery) {\r\n      this.search();\r\n    }\r\n  }\r\n\r\n  /** 设置查询值进行回显 */\r\n  setQueryParams(cacheParams: NzxQueryParams): void {\r\n    this.cacheParams = cacheParams;\r\n    this.queryForm.patchValue(cacheParams);\r\n  }\r\n\r\n  /**\r\n   * 根据controlName设置config值\r\n   * @param defaultValueResettable 添加的表单控件默认值是否可以重置，默认不可以\r\n   */\r\n  setControl(\r\n    controlName: string,\r\n    config: Partial<NzxQueryControlOptions>,\r\n    defaultValueResettable = false\r\n  ): void {\r\n    const control = this.getControl(controlName);\r\n    if (control) {\r\n      Object.keys(config).forEach((key) => {\r\n        (control as any)[key] = (config as any)[key];\r\n      });\r\n      this.generateControl(control, defaultValueResettable);\r\n      this.cd.markForCheck();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 动态添加控件\r\n   * @param config 配置项\r\n   * @param position 添加位置 不传为末尾\r\n   * @param defaultValueResettable 添加的表单控件默认值是否可以重置，默认不可以\r\n   */\r\n  addControl(\r\n    config: NzxQueryControlOptions,\r\n    position?: number | undefined,\r\n    defaultValueResettable = false\r\n  ): void {\r\n    const control = this.getControl(config.controlName);\r\n    if (!control) {\r\n      if (config && config['hasOwnProperty']('collapse')) {\r\n        const hasCollapseProperty = this.controls.some((i) =>\r\n          i['hasOwnProperty']('collapse')\r\n        );\r\n        if (hasCollapseProperty) {\r\n          config.collapse = this.controls.some((i) => i.collapse === true);\r\n        }\r\n      }\r\n\r\n      this.generateControl(config, defaultValueResettable);\r\n\r\n      if (position === void 0 || position === null) {\r\n        this.controls.push(config);\r\n      } else {\r\n        this.controls.splice(position - 1, 0, config);\r\n      }\r\n      this.calculateText();\r\n    } else {\r\n      throw `The control name: '${config.controlName}' already exists!`;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 根据控件名删除控件\r\n   */\r\n  removeControl(controlName: string): void {\r\n    const control = this.getControl(controlName);\r\n    if (control) {\r\n      this.queryForm.removeControl(controlName);\r\n      this.controls = this.controls.filter(\r\n        (c) => c.controlName !== controlName\r\n      );\r\n      this.calculateText();\r\n    } else {\r\n      throw `The control name: '${controlName}' not find!`;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * 根据controlName获取config项\r\n   */\r\n  getControl(\r\n    controlName: string | undefined\r\n  ): NzxQueryControlOptions | undefined {\r\n    return this.controls.find((config) => config.controlName === controlName);\r\n  }\r\n\r\n  /**\r\n   * 检索给定控件名称或路径的子控件。\r\n   * 这个 getFormControl 签名支持字符串和 const 数组（.getFormControl(['foo', 'bar'] as const)）\r\n   */\r\n  getFormControl(\r\n    path: string | readonly (string | number)[]\r\n  ): AbstractControl<any, any> | null {\r\n    return this.queryForm.get(path);\r\n  }\r\n\r\n  /** 查询 */\r\n  search(): void {\r\n    if (this.queryForm.invalid) {\r\n      updateControlStatus(this.queryForm);\r\n      return;\r\n    }\r\n    this.queryChange.emit(this._queryParams);\r\n  }\r\n\r\n  /** 重置 */\r\n  reset(): void {\r\n    this.queryForm.reset(this.defaultValue);\r\n    this.resetChange.emit(this._queryParams);\r\n  }\r\n\r\n  /**展开、收起*/\r\n  toggleCollapse(): void {\r\n    for (let index = 0; index < this.controls.length; index++) {\r\n      const config = this.controls[index];\r\n      const hasProperty = config.hasOwnProperty('collapse');\r\n      if (hasProperty && config.collapse) {\r\n        config.collapse = false;\r\n      } else if (hasProperty && !config.collapse) {\r\n        config.collapse = true;\r\n      }\r\n    }\r\n    this.calculateText();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  /** 计算展开收起icon、文案 */\r\n  private calculateText() {\r\n    if (this.controls.some((i) => i.collapse === true)) {\r\n      this.collapseIcon = 'down';\r\n      this.collapseText = this.locale.expand;\r\n    } else {\r\n      this.collapseIcon = 'up';\r\n      this.collapseText = this.locale.collapse;\r\n    }\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  /** 清空表单控件 */\r\n  private clearFormControl(): void {\r\n    Object.keys(this.queryForm.controls).forEach((key) => {\r\n      this.queryForm.removeControl(key);\r\n    });\r\n  }\r\n\r\n  /** 生成 queryForm 表单 */\r\n  private generateForm(controlConfigs: Array<NzxQueryControlOptions>): void {\r\n    this.clearFormControl();\r\n\r\n    for (const config of controlConfigs) {\r\n      this.generateControl(config);\r\n    }\r\n    this.defaultValue = this.queryForm.getRawValue();\r\n\r\n    if (this.cacheParams) {\r\n      // 缓存回显查询条件\r\n      this.queryForm.patchValue(this.cacheParams);\r\n    }\r\n\r\n    this.calculateText();\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param controlConfig control配置\r\n   * @param defaultValueResettable 添加的表单控件默认值是否可以重置，默认不可以\r\n   *\r\n   * 1. 生成单个表单控件并将其添加到queryForm中\r\n   * 2. 如果没有templateRef根据controlName获取投影的templateList中的templateRef给 templateRef 赋值\r\n   *\r\n   **/\r\n  private generateControl(\r\n    config: NzxQueryControlOptions,\r\n    defaultValueResettable = false\r\n  ) {\r\n    if (config.controlName) {\r\n      if (!config?.templateRef) {\r\n        const d = this.controlTemplateList.find(\r\n          (d) => d.nzxControl === config.controlName\r\n        );\r\n        if (d) {\r\n          config.templateRef = d.templateRef;\r\n        }\r\n      }\r\n\r\n      this.queryForm.setControl(\r\n        config.controlName,\r\n        config.controlInstance ?? this.fb.control(config.default ?? null)\r\n      );\r\n\r\n      if (!defaultValueResettable) {\r\n        const control = this.queryForm.get(config.controlName);\r\n        this.defaultValue = {\r\n          ...this.defaultValue,\r\n          [config.controlName]: control.value,\r\n        };\r\n      }\r\n    }\r\n  }\r\n}\r\n","<nz-card>\n  <form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n    <div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n      <ng-container *ngFor=\"let config of controls; let i = index\">\n        <div\n          *ngIf=\"!config.hidden\"\n          nz-col\n          [nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n          [hidden]=\"config.collapse\"\n          [nzOrder]=\"i\"\n        >\n          <nzx-configurable-query-item\n            *ngIf=\"config.controlName\"\n            [form]=\"queryForm\"\n            [control]=\"config\"\n          ></nzx-configurable-query-item>\n        </div>\n      </ng-container>\n\n      <div\n        class=\"nzx-query-btn\"\n        nz-col\n        [nzOrder]=\"controls.length\"\n        [nzSpan]=\"nzxBtnSpan || 24 / lineNumber\"\n      >\n        <div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n          <nz-space>\n            <button\n              *nzSpaceItem\n              nz-button\n              nzType=\"primary\"\n              type=\"button\"\n              title=\"Enter\"\n              (click)=\"search()\"\n            >\n              {{ locale['query'] }}\n            </button>\n            <button\n              *nzSpaceItem\n              nz-button\n              type=\"button\"\n              title=\"ctrl+r\"\n              (click)=\"reset()\"\n            >\n              {{ locale['reset'] }}\n            </button>\n            <ng-container *nzSpaceItem>\n              <ng-content></ng-content>\n            </ng-container>\n            <ng-container *ngIf=\"nzxCollapse\">\n              <a\n                *nzSpaceItem\n                nz-button\n                nzType=\"link\"\n                (click)=\"toggleCollapse()\"\n              >\n                {{ collapseText }}\n                <i nz-icon [nzType]=\"collapseIcon\"></i>\n              </a>\n            </ng-container>\n          </nz-space>\n        </div>\n      </div>\n    </div>\n  </form>\n</nz-card>\n"]}
|