ng-zorro-antd-extension 17.0.2 → 17.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/configurable-query/configurable-query.component.d.ts +13 -14
- package/configurable-query/type.d.ts +2 -2
- package/esm2022/configurable-query/configurable-query.component.mjs +66 -42
- package/esm2022/configurable-query/type.mjs +1 -1
- package/esm2022/print/ng-zorro-antd-extension-print.mjs +5 -0
- package/esm2022/print/nzx-print-content.directive.mjs +22 -0
- package/esm2022/print/nzx-print-v.component.mjs +300 -0
- package/esm2022/print/nzx-print.component.mjs +189 -0
- package/esm2022/print/nzx-print.directive.mjs +91 -0
- package/esm2022/print/nzx-print.module.mjs +39 -0
- package/esm2022/print/public-api.mjs +10 -0
- package/esm2022/table-select/page-table-select/page-table-select.component.mjs +3 -3
- package/esm2022/table-select/table-select/table-select.component.mjs +3 -3
- package/esm2022/util/lib/getElementByTag.mjs +31 -0
- package/esm2022/util/public-api.mjs +2 -1
- package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs +64 -40
- package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs.map +1 -1
- package/fesm2022/ng-zorro-antd-extension-print.mjs +637 -0
- package/fesm2022/ng-zorro-antd-extension-print.mjs.map +1 -0
- package/fesm2022/ng-zorro-antd-extension-table-select.mjs +4 -4
- package/fesm2022/ng-zorro-antd-extension-table-select.mjs.map +1 -1
- package/fesm2022/ng-zorro-antd-extension-util.mjs +32 -1
- package/fesm2022/ng-zorro-antd-extension-util.mjs.map +1 -1
- package/package.json +14 -7
- package/pipes/safe-url.pipe.d.ts +1 -1
- package/print/index.d.ts +5 -0
- package/print/nzx-print-content.directive.d.ts +10 -0
- package/print/nzx-print-v.component.d.ts +45 -0
- package/print/nzx-print.component.d.ts +34 -0
- package/print/nzx-print.directive.d.ts +17 -0
- package/print/nzx-print.module.d.ts +13 -0
- package/print/public-api.d.ts +9 -0
- package/public-api.d.ts +1 -1
- package/table-select/abstract-table-select.d.ts +1 -1
- package/timer-button/timer-button.directive.d.ts +1 -1
- package/util/lib/getElementByTag.d.ts +8 -0
- package/util/public-api.d.ts +1 -0
package/README.md
CHANGED
|
@@ -65,6 +65,7 @@ export class AppModule {}
|
|
|
65
65
|
| ^14.0.0 | ^14.0.0 | ^14.0.0 | end |
|
|
66
66
|
| ^15.0.0 | ^15.0.0 | ^15.0.0 | 2024-05-18 |
|
|
67
67
|
| ^16.0.0 | ^16.0.0 | ^15.6.0 | 2024-11-08 |
|
|
68
|
+
| ^17.0.0 | ^17.0.0 | ^15.6.0 | 2025-05-15 |
|
|
68
69
|
|
|
69
70
|
Install the specified version if required using:
|
|
70
71
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AfterContentInit, ChangeDetectorRef, EventEmitter, OnChanges, OnDestroy, OnInit, QueryList, SimpleChanges } from '@angular/core';
|
|
1
|
+
import { AfterContentInit, AfterViewInit, ChangeDetectorRef, EventEmitter, OnChanges, OnDestroy, OnInit, QueryList, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { AbstractControl, FormBuilder, FormGroup } from '@angular/forms';
|
|
3
3
|
import { NzxQueryI18nInterface } from 'ng-zorro-antd-extension/i18n';
|
|
4
4
|
import { NzJustify } from 'ng-zorro-antd/grid';
|
|
@@ -10,7 +10,7 @@ import * as i0 from "@angular/core";
|
|
|
10
10
|
* 查询组件
|
|
11
11
|
* 支持模板自定义,在使用模板自定义时,要注意controlType应该设置为Template并且确保controlName与指令上的nzxControl应该相同
|
|
12
12
|
*/
|
|
13
|
-
export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit, AfterContentInit, OnDestroy {
|
|
13
|
+
export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit, AfterViewInit, AfterContentInit, OnDestroy {
|
|
14
14
|
private i18n;
|
|
15
15
|
private fb;
|
|
16
16
|
private cd;
|
|
@@ -24,8 +24,6 @@ export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit,
|
|
|
24
24
|
lineNumber: number;
|
|
25
25
|
/** 操作按钮所占栅格数,24则换行 */
|
|
26
26
|
nzxBtnSpan: number | null;
|
|
27
|
-
/**启用折叠 */
|
|
28
|
-
nzxCollapse: boolean;
|
|
29
27
|
/** 初始化时,主动查询 */
|
|
30
28
|
initQuery: boolean;
|
|
31
29
|
/** 缺省 固定参数 */
|
|
@@ -39,18 +37,19 @@ export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit,
|
|
|
39
37
|
/** 查询组件出参*/
|
|
40
38
|
get queryParams(): any;
|
|
41
39
|
set queryParams(value: any);
|
|
42
|
-
get
|
|
43
|
-
get collapseIcon(): "down" | "up";
|
|
40
|
+
get nzxCollapse(): boolean;
|
|
44
41
|
locale: NzxQueryI18nInterface;
|
|
45
|
-
|
|
46
|
-
|
|
42
|
+
collapseIcon: string;
|
|
43
|
+
collapseText: string;
|
|
47
44
|
private _queryParams;
|
|
48
45
|
private defaultValue;
|
|
49
46
|
private cacheParams;
|
|
50
47
|
private destroy$;
|
|
51
48
|
private _nzxBtnSpan;
|
|
49
|
+
private queyFormEl;
|
|
52
50
|
controlTemplateList: QueryList<NzxControlDirective>;
|
|
53
51
|
constructor(i18n: NzI18nService, fb: FormBuilder, cd: ChangeDetectorRef);
|
|
52
|
+
ngAfterViewInit(): void;
|
|
54
53
|
ngOnChanges(changes: SimpleChanges): void;
|
|
55
54
|
ngOnInit(): void;
|
|
56
55
|
ngAfterContentInit(): void;
|
|
@@ -62,8 +61,10 @@ export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit,
|
|
|
62
61
|
setControl(controlName: string, config: Partial<NzxQueryControlOptions>): void;
|
|
63
62
|
/**
|
|
64
63
|
* 动态添加控件
|
|
64
|
+
* @param config 配置项
|
|
65
|
+
* @param position 添加位置 不传为末尾
|
|
65
66
|
*/
|
|
66
|
-
addControl(config: NzxQueryControlOptions): void;
|
|
67
|
+
addControl(config: NzxQueryControlOptions, position?: number | undefined): void;
|
|
67
68
|
/**
|
|
68
69
|
* 根据控件名删除控件
|
|
69
70
|
*/
|
|
@@ -75,22 +76,20 @@ export declare class NzxConfigurableQueryComponent implements OnChanges, OnInit,
|
|
|
75
76
|
/**
|
|
76
77
|
* 检索给定控件名称或路径的子控件。
|
|
77
78
|
* 这个 getFormControl 签名支持字符串和 const 数组(.getFormControl(['foo', 'bar'] as const))
|
|
78
|
-
* 注意调用时机,最好在afterViewInit中调用
|
|
79
79
|
*/
|
|
80
80
|
getFormControl(path: string | readonly (string | number)[]): AbstractControl<any, any> | null;
|
|
81
81
|
/** 查询 */
|
|
82
|
-
search(): void;
|
|
82
|
+
search(event?: Event): void;
|
|
83
83
|
/** 重置 */
|
|
84
84
|
reset(): void;
|
|
85
85
|
/**展开、收起*/
|
|
86
86
|
toggleCollapse(): void;
|
|
87
87
|
ngOnDestroy(): void;
|
|
88
|
+
private calculateText;
|
|
88
89
|
/** 清空表单控件 */
|
|
89
90
|
private clearFormControl;
|
|
90
|
-
/** 折叠 */
|
|
91
|
-
private collapse;
|
|
92
91
|
/** 生成表单 */
|
|
93
92
|
private generateForm;
|
|
94
93
|
static ɵfac: i0.ɵɵFactoryDeclaration<NzxConfigurableQueryComponent, never>;
|
|
95
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NzxConfigurableQueryComponent, "nzx-configurable-query", ["NzxConfigurableQuery"], { "controls": { "alias": "controls"; "required": false; }; "nzxJustify": { "alias": "nzxJustify"; "required": false; }; "nzxGutter": { "alias": "nzxGutter"; "required": false; }; "lineNumber": { "alias": "lineNumber"; "required": false; }; "nzxBtnSpan": { "alias": "nzxBtnSpan"; "required": false; }; "
|
|
94
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NzxConfigurableQueryComponent, "nzx-configurable-query", ["NzxConfigurableQuery"], { "controls": { "alias": "controls"; "required": false; }; "nzxJustify": { "alias": "nzxJustify"; "required": false; }; "nzxGutter": { "alias": "nzxGutter"; "required": false; }; "lineNumber": { "alias": "lineNumber"; "required": false; }; "nzxBtnSpan": { "alias": "nzxBtnSpan"; "required": false; }; "initQuery": { "alias": "initQuery"; "required": false; }; "fixedParams": { "alias": "fixedParams"; "required": false; }; }, { "queryChange": "queryChange"; "resetChange": "resetChange"; }, ["controlTemplateList"], ["*"], false, never>;
|
|
96
95
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { updateControlStatus } from 'ng-zorro-antd-extension/util';
|
|
3
|
-
import { Subject, takeUntil } from 'rxjs';
|
|
3
|
+
import { Subject, fromEvent, takeUntil } from 'rxjs';
|
|
4
4
|
import { NzxControlDirective } from './control.directive';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "ng-zorro-antd/i18n";
|
|
@@ -25,11 +25,8 @@ export class NzxConfigurableQueryComponent {
|
|
|
25
25
|
set queryParams(value) {
|
|
26
26
|
this._queryParams = value;
|
|
27
27
|
}
|
|
28
|
-
get
|
|
29
|
-
return this.
|
|
30
|
-
}
|
|
31
|
-
get collapseIcon() {
|
|
32
|
-
return this.isCollapse ? 'down' : 'up';
|
|
28
|
+
get nzxCollapse() {
|
|
29
|
+
return this.controls.some((i) => i.hasOwnProperty('collapse'));
|
|
33
30
|
}
|
|
34
31
|
constructor(i18n, fb, cd) {
|
|
35
32
|
this.i18n = i18n;
|
|
@@ -45,8 +42,6 @@ export class NzxConfigurableQueryComponent {
|
|
|
45
42
|
this.lineNumber = 3;
|
|
46
43
|
/** 操作按钮所占栅格数,24则换行 */
|
|
47
44
|
this.nzxBtnSpan = null;
|
|
48
|
-
/**启用折叠 */
|
|
49
|
-
this.nzxCollapse = true;
|
|
50
45
|
/** 初始化时,主动查询 */
|
|
51
46
|
this.initQuery = false;
|
|
52
47
|
/** 缺省 固定参数 */
|
|
@@ -55,8 +50,8 @@ export class NzxConfigurableQueryComponent {
|
|
|
55
50
|
this.queryChange = new EventEmitter();
|
|
56
51
|
/** 重置时会触发抛出查询参数 */
|
|
57
52
|
this.resetChange = new EventEmitter();
|
|
58
|
-
|
|
59
|
-
this.
|
|
53
|
+
this.collapseIcon = 'down';
|
|
54
|
+
this.collapseText = '';
|
|
60
55
|
this._queryParams = {};
|
|
61
56
|
this.defaultValue = {};
|
|
62
57
|
this.cacheParams = {};
|
|
@@ -64,6 +59,26 @@ export class NzxConfigurableQueryComponent {
|
|
|
64
59
|
this._nzxBtnSpan = null;
|
|
65
60
|
this.queryForm = this.fb.group({});
|
|
66
61
|
}
|
|
62
|
+
ngAfterViewInit() {
|
|
63
|
+
if (this.queyFormEl) {
|
|
64
|
+
fromEvent(this.queyFormEl.nativeElement, 'keydown')
|
|
65
|
+
.pipe(takeUntil(this.destroy$))
|
|
66
|
+
.subscribe((event) => {
|
|
67
|
+
if (event.key === 'Enter') {
|
|
68
|
+
event.stopPropagation();
|
|
69
|
+
event.preventDefault();
|
|
70
|
+
this.search();
|
|
71
|
+
}
|
|
72
|
+
// 检查是否同时按下了Ctrl键(在Windows/Linux上)和S键
|
|
73
|
+
if ((event.ctrlKey || event.metaKey) && event.key === 'r') {
|
|
74
|
+
// 注意:event.metaKey用于兼容Mac的Command键
|
|
75
|
+
event.preventDefault(); // 阻止浏览器默认的保存行为
|
|
76
|
+
event.stopPropagation();
|
|
77
|
+
this.reset();
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
67
82
|
ngOnChanges(changes) {
|
|
68
83
|
if (changes['controls'] && !changes['controls'].isFirstChange()) {
|
|
69
84
|
const controls = changes['controls'].currentValue;
|
|
@@ -113,16 +128,22 @@ export class NzxConfigurableQueryComponent {
|
|
|
113
128
|
}
|
|
114
129
|
/**
|
|
115
130
|
* 动态添加控件
|
|
131
|
+
* @param config 配置项
|
|
132
|
+
* @param position 添加位置 不传为末尾
|
|
116
133
|
*/
|
|
117
|
-
addControl(config) {
|
|
134
|
+
addControl(config, position) {
|
|
118
135
|
const control = this.getControl(config.controlName);
|
|
119
136
|
if (!control) {
|
|
120
|
-
this.collapse();
|
|
121
137
|
if (config.controlName) {
|
|
122
138
|
this.queryForm.addControl(config.controlName, config.controlInstance ?? this.fb.control(config.default ?? null));
|
|
123
139
|
}
|
|
124
|
-
|
|
125
|
-
|
|
140
|
+
if (position === void 0 || position === null) {
|
|
141
|
+
this.controls.push(config);
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
this.controls.splice(position - 1, 0, config);
|
|
145
|
+
}
|
|
146
|
+
this.calculateText();
|
|
126
147
|
}
|
|
127
148
|
else {
|
|
128
149
|
throw `The control name: '${config.controlName}' already exists!`;
|
|
@@ -134,10 +155,9 @@ export class NzxConfigurableQueryComponent {
|
|
|
134
155
|
removeControl(controlName) {
|
|
135
156
|
const control = this.getControl(controlName);
|
|
136
157
|
if (control) {
|
|
137
|
-
this.collapse();
|
|
138
158
|
this.queryForm.removeControl(controlName);
|
|
139
159
|
this.controls = this.controls.filter((c) => c.controlName !== controlName);
|
|
140
|
-
this.
|
|
160
|
+
this.calculateText();
|
|
141
161
|
}
|
|
142
162
|
else {
|
|
143
163
|
throw `The control name: '${controlName}' not find!`;
|
|
@@ -152,13 +172,15 @@ export class NzxConfigurableQueryComponent {
|
|
|
152
172
|
/**
|
|
153
173
|
* 检索给定控件名称或路径的子控件。
|
|
154
174
|
* 这个 getFormControl 签名支持字符串和 const 数组(.getFormControl(['foo', 'bar'] as const))
|
|
155
|
-
* 注意调用时机,最好在afterViewInit中调用
|
|
156
175
|
*/
|
|
157
176
|
getFormControl(path) {
|
|
158
177
|
return this.queryForm.get(path);
|
|
159
178
|
}
|
|
160
179
|
/** 查询 */
|
|
161
|
-
search() {
|
|
180
|
+
search(event) {
|
|
181
|
+
if (event) {
|
|
182
|
+
event.stopPropagation();
|
|
183
|
+
}
|
|
162
184
|
if (this.queryForm.invalid) {
|
|
163
185
|
updateControlStatus(this.queryForm);
|
|
164
186
|
return;
|
|
@@ -176,39 +198,39 @@ export class NzxConfigurableQueryComponent {
|
|
|
176
198
|
}
|
|
177
199
|
/**展开、收起*/
|
|
178
200
|
toggleCollapse() {
|
|
179
|
-
this.controls.
|
|
180
|
-
|
|
181
|
-
|
|
201
|
+
for (let index = 0; index < this.controls.length; index++) {
|
|
202
|
+
const config = this.controls[index];
|
|
203
|
+
if (config.hasOwnProperty('collapse') && config.collapse === true) {
|
|
182
204
|
config.collapse = false;
|
|
183
|
-
this.nzxBtnSpan = 24;
|
|
184
205
|
}
|
|
185
|
-
if (
|
|
206
|
+
else if (config.hasOwnProperty('collapse') &&
|
|
207
|
+
config.collapse === false) {
|
|
186
208
|
config.collapse = true;
|
|
187
|
-
this.nzxBtnSpan = this._nzxBtnSpan;
|
|
188
209
|
}
|
|
189
|
-
}
|
|
190
|
-
this.
|
|
210
|
+
}
|
|
211
|
+
this.calculateText();
|
|
191
212
|
}
|
|
192
213
|
ngOnDestroy() {
|
|
193
214
|
this.destroy$.next();
|
|
194
215
|
this.destroy$.complete();
|
|
195
216
|
}
|
|
217
|
+
calculateText() {
|
|
218
|
+
if (this.controls.some((i) => i.collapse === true)) {
|
|
219
|
+
this.collapseIcon = 'down';
|
|
220
|
+
this.collapseText = this.locale.expand;
|
|
221
|
+
}
|
|
222
|
+
else {
|
|
223
|
+
this.collapseIcon = 'up';
|
|
224
|
+
this.collapseText = this.locale.collapse;
|
|
225
|
+
}
|
|
226
|
+
this.cd.markForCheck();
|
|
227
|
+
}
|
|
196
228
|
/** 清空表单控件 */
|
|
197
229
|
clearFormControl() {
|
|
198
230
|
Object.keys(this.queryForm.controls).forEach((key) => {
|
|
199
231
|
this.queryForm.removeControl(key);
|
|
200
232
|
});
|
|
201
233
|
}
|
|
202
|
-
/** 折叠 */
|
|
203
|
-
collapse() {
|
|
204
|
-
this.isCollapse = true;
|
|
205
|
-
this.controls.forEach((config) => {
|
|
206
|
-
if (config.collapse === false) {
|
|
207
|
-
config.collapse = true;
|
|
208
|
-
this.nzxBtnSpan = this._nzxBtnSpan;
|
|
209
|
-
}
|
|
210
|
-
});
|
|
211
|
-
}
|
|
212
234
|
/** 生成表单 */
|
|
213
235
|
generateForm(controlConfigs) {
|
|
214
236
|
this.clearFormControl();
|
|
@@ -228,13 +250,14 @@ export class NzxConfigurableQueryComponent {
|
|
|
228
250
|
// 缓存回显查询条件
|
|
229
251
|
this.queryForm.patchValue(this.cacheParams);
|
|
230
252
|
}
|
|
253
|
+
this.calculateText();
|
|
231
254
|
}
|
|
232
255
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxConfigurableQueryComponent, deps: [{ token: i1.NzI18nService }, { token: i2.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
233
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.3", type: NzxConfigurableQueryComponent, selector: "nzx-configurable-query", inputs: { controls: "controls", nzxJustify: "nzxJustify", nzxGutter: "nzxGutter", lineNumber: "lineNumber", nzxBtnSpan: "nzxBtnSpan",
|
|
256
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.3", 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\t<div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n\t\t<ng-container *ngFor=\"let config of controls; let i = index\">\n\t\t\t<div\n\t\t\t\t*ngIf=\"!config.hidden\"\n\t\t\t\tnz-col\n\t\t\t\t[nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n\t\t\t\t[hidden]=\"config.collapse\"\n\t\t\t\t[nzOrder]=\"i\"\n\t\t\t>\n\t\t\t\t<nzx-configurable-query-item\n\t\t\t\t\t*ngIf=\"config.controlName\"\n\t\t\t\t\t[form]=\"queryForm\"\n\t\t\t\t\t[control]=\"config\"\n\t\t\t\t></nzx-configurable-query-item>\n\t\t\t</div>\n\t\t</ng-container>\n\n\t\t<div\n\t\t\t[nzOrder]=\"controls.length\"\n\t\t\tclass=\"nzx-query-btn\"\n\t\t\tnz-col\n\t\t\t[nzSpan]=\"nzxBtnSpan || 24 / lineNumber\"\n\t\t>\n\t\t\t<div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n\t\t\t\t<button\n\t\t\t\t\tnz-button\n\t\t\t\t\tnzType=\"primary\"\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\ttitle=\"Enter\"\n\t\t\t\t\t(click)=\"search($event)\"\n\t\t\t\t>\n\t\t\t\t\t{{ locale['query'] }}\n\t\t\t\t</button>\n\t\t\t\t<button nz-button type=\"button\" title=\"ctrl+r\" (click)=\"reset()\">\n\t\t\t\t\t{{ locale['reset'] }}\n\t\t\t\t</button>\n\t\t\t\t<ng-content></ng-content>\n\t\t\t\t<a\n\t\t\t\t\t*ngIf=\"nzxCollapse\"\n\t\t\t\t\tnz-button\n\t\t\t\t\tnzType=\"link\"\n\t\t\t\t\t(click)=\"toggleCollapse()\"\n\t\t\t\t>\n\t\t\t\t\t{{ collapseText }}\n\t\t\t\t\t<i nz-icon [nzType]=\"collapseIcon\"></i>\n\t\t\t\t</a>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</form>\n", styles: [".nzx-query-container{padding:12px;background-color:#fff;border-radius:8px}.nzx-query-container [nz-form-label]{overflow:visible}.nzx-query-container .nzx-query-btn{flex-grow:2;max-width:none}.nzx-query-container .nzx-query-btn button{margin:0 4px}\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: "directive", type: i9.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "component", type: i10.NzxConfigurableQueryItemComponent, selector: "nzx-configurable-query-item", inputs: ["form", "control"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
234
257
|
}
|
|
235
258
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxConfigurableQueryComponent, decorators: [{
|
|
236
259
|
type: Component,
|
|
237
|
-
args: [{ selector: 'nzx-configurable-query', changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'NzxConfigurableQuery', template: "<form class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n
|
|
260
|
+
args: [{ selector: 'nzx-configurable-query', changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'NzxConfigurableQuery', template: "<form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n\t<div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n\t\t<ng-container *ngFor=\"let config of controls; let i = index\">\n\t\t\t<div\n\t\t\t\t*ngIf=\"!config.hidden\"\n\t\t\t\tnz-col\n\t\t\t\t[nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n\t\t\t\t[hidden]=\"config.collapse\"\n\t\t\t\t[nzOrder]=\"i\"\n\t\t\t>\n\t\t\t\t<nzx-configurable-query-item\n\t\t\t\t\t*ngIf=\"config.controlName\"\n\t\t\t\t\t[form]=\"queryForm\"\n\t\t\t\t\t[control]=\"config\"\n\t\t\t\t></nzx-configurable-query-item>\n\t\t\t</div>\n\t\t</ng-container>\n\n\t\t<div\n\t\t\t[nzOrder]=\"controls.length\"\n\t\t\tclass=\"nzx-query-btn\"\n\t\t\tnz-col\n\t\t\t[nzSpan]=\"nzxBtnSpan || 24 / lineNumber\"\n\t\t>\n\t\t\t<div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n\t\t\t\t<button\n\t\t\t\t\tnz-button\n\t\t\t\t\tnzType=\"primary\"\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\ttitle=\"Enter\"\n\t\t\t\t\t(click)=\"search($event)\"\n\t\t\t\t>\n\t\t\t\t\t{{ locale['query'] }}\n\t\t\t\t</button>\n\t\t\t\t<button nz-button type=\"button\" title=\"ctrl+r\" (click)=\"reset()\">\n\t\t\t\t\t{{ locale['reset'] }}\n\t\t\t\t</button>\n\t\t\t\t<ng-content></ng-content>\n\t\t\t\t<a\n\t\t\t\t\t*ngIf=\"nzxCollapse\"\n\t\t\t\t\tnz-button\n\t\t\t\t\tnzType=\"link\"\n\t\t\t\t\t(click)=\"toggleCollapse()\"\n\t\t\t\t>\n\t\t\t\t\t{{ collapseText }}\n\t\t\t\t\t<i nz-icon [nzType]=\"collapseIcon\"></i>\n\t\t\t\t</a>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</form>\n", styles: [".nzx-query-container{padding:12px;background-color:#fff;border-radius:8px}.nzx-query-container [nz-form-label]{overflow:visible}.nzx-query-container .nzx-query-btn{flex-grow:2;max-width:none}.nzx-query-container .nzx-query-btn button{margin:0 4px}\n"] }]
|
|
238
261
|
}], ctorParameters: () => [{ type: i1.NzI18nService }, { type: i2.FormBuilder }, { type: i0.ChangeDetectorRef }], propDecorators: { controls: [{
|
|
239
262
|
type: Input
|
|
240
263
|
}], nzxJustify: [{
|
|
@@ -245,8 +268,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
|
|
|
245
268
|
type: Input
|
|
246
269
|
}], nzxBtnSpan: [{
|
|
247
270
|
type: Input
|
|
248
|
-
}], nzxCollapse: [{
|
|
249
|
-
type: Input
|
|
250
271
|
}], initQuery: [{
|
|
251
272
|
type: Input
|
|
252
273
|
}], fixedParams: [{
|
|
@@ -255,8 +276,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
|
|
|
255
276
|
type: Output
|
|
256
277
|
}], resetChange: [{
|
|
257
278
|
type: Output
|
|
279
|
+
}], queyFormEl: [{
|
|
280
|
+
type: ViewChild,
|
|
281
|
+
args: ['queyForm']
|
|
258
282
|
}], controlTemplateList: [{
|
|
259
283
|
type: ContentChildren,
|
|
260
284
|
args: [NzxControlDirective, { descendants: true }]
|
|
261
285
|
}] } });
|
|
262
|
-
//# 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  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChildren,\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  ViewEncapsulation,\r\n} from '@angular/core';\r\n\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, 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, 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() nzxCollapse = true;\r\n  /** 初始化时，主动查询 */\r\n  @Input() initQuery = false;\r\n\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  /** form 表单*/\r\n  queryForm!: FormGroup;\r\n\r\n  /** 查询组件出参*/\r\n  get queryParams() {\r\n    return this._queryParams;\r\n  }\r\n\r\n  set queryParams(value: any) {\r\n    this._queryParams = value;\r\n  }\r\n\r\n  get collapseText() {\r\n    return this.isCollapse ? this.locale.expand : this.locale.collapse;\r\n  }\r\n\r\n  get collapseIcon() {\r\n    return this.isCollapse ? 'down' : 'up';\r\n  }\r\n\r\n  locale!: NzxQueryI18nInterface;\r\n\r\n  /**是否展开状态*/\r\n  private isCollapse = true;\r\n  private _queryParams: NzxQueryParams = {};\r\n  private defaultValue: NzxQueryParams = {};\r\n  private cacheParams: NzxQueryParams = {};\r\n  private destroy$ = new Subject<void>();\r\n  private _nzxBtnSpan: number | null = null;\r\n\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    this._nzxBtnSpan = this.nzxBtnSpan;\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   */\r\n  setControl(\r\n    controlName: string,\r\n    config: Partial<NzxQueryControlOptions>\r\n  ): void {\r\n    Promise.resolve().then(() => {\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      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * 动态添加控件\r\n   */\r\n  addControl(config: NzxQueryControlOptions): void {\r\n    const control = this.getControl(config.controlName);\r\n    if (!control) {\r\n      this.collapse();\r\n      if (config.controlName) {\r\n        this.queryForm.addControl(\r\n          config.controlName,\r\n          config.controlInstance ?? this.fb.control(config.default ?? null)\r\n        );\r\n      }\r\n      this.controls.push(config);\r\n      this.cd.markForCheck();\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.collapse();\r\n      this.queryForm.removeControl(controlName);\r\n      this.controls = this.controls.filter(\r\n        (c) => c.controlName !== controlName\r\n      );\r\n\r\n      this.cd.markForCheck();\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   * 注意调用时机，最好在afterViewInit中调用\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    if (this.queryForm.invalid) {\r\n      updateControlStatus(this.queryForm);\r\n      return;\r\n    }\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    this.controls.forEach((config) => {\r\n      if (this.isCollapse && config.collapse === true) {\r\n        // 展开\r\n        config.collapse = false;\r\n        this.nzxBtnSpan = 24;\r\n      }\r\n      if (!this.isCollapse && config.collapse === false) {\r\n        config.collapse = true;\r\n        this.nzxBtnSpan = this._nzxBtnSpan;\r\n      }\r\n    });\r\n    this.isCollapse = !this.isCollapse;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\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  /** 折叠 */\r\n  private collapse(): void {\r\n    this.isCollapse = true;\r\n    this.controls.forEach((config) => {\r\n      if (config.collapse === false) {\r\n        config.collapse = true;\r\n        this.nzxBtnSpan = this._nzxBtnSpan;\r\n      }\r\n    });\r\n  }\r\n\r\n  /** 生成表单 */\r\n  private generateForm(controlConfigs: Array<NzxQueryControlOptions>): void {\r\n    this.clearFormControl();\r\n\r\n    for (const config of controlConfigs) {\r\n      if (config.controlType === 'Template') {\r\n        const item = this.controlTemplateList.find(\r\n          (directive) => directive.nzxControl === config.controlName\r\n        );\r\n        if (item) {\r\n          config.templateRef = item.templateRef;\r\n        }\r\n      }\r\n      if (config.controlName) {\r\n        this.queryForm.addControl(\r\n          config.controlName,\r\n          config.controlInstance ?? this.fb.control(config.default ?? null)\r\n        );\r\n      }\r\n    }\r\n    this.defaultValue = this.queryForm.getRawValue();\r\n    if (this.cacheParams) {\r\n      // 缓存回显查询条件\r\n      this.queryForm.patchValue(this.cacheParams);\r\n    }\r\n  }\r\n}\r\n","<form class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n  <div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n    <ng-container *ngFor=\"let config of controls\">\n      <div\n        *ngIf=\"!config.hidden\"\n        nz-col\n        [nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n        [hidden]=\"nzxCollapse && config.collapse\"\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 class=\"nzx-query-btn\" nz-col [nzSpan]=\"nzxBtnSpan || 24 / lineNumber\">\n      <div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n        <button nz-button nzType=\"primary\" type=\"button\" (click)=\"search()\">\n          {{ locale[\"query\"] }}\n        </button>\n        <button nz-button type=\"button\" (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"]}
|
|
286
|
+
//# 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\tAfterContentInit,\r\n\tAfterViewInit,\r\n\tChangeDetectionStrategy,\r\n\tChangeDetectorRef,\r\n\tComponent,\r\n\tContentChildren,\r\n\tElementRef,\r\n\tEventEmitter,\r\n\tInput,\r\n\tOnChanges,\r\n\tOnDestroy,\r\n\tOnInit,\r\n\tOutput,\r\n\tQueryList,\r\n\tSimpleChanges,\r\n\tViewChild,\r\n\tViewEncapsulation,\r\n} from '@angular/core';\r\n\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\tselector: 'nzx-configurable-query',\r\n\ttemplateUrl: './configurable-query.component.html',\r\n\tstyleUrls: ['./configurable-query.component.less'],\r\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\r\n\texportAs: 'NzxConfigurableQuery',\r\n})\r\nexport class NzxConfigurableQueryComponent\r\n\timplements OnChanges, OnInit, AfterViewInit, AfterContentInit, OnDestroy\r\n{\r\n\t/** 配置项 */\r\n\t@Input() controls: Array<NzxQueryControlOptions> = [];\r\n\r\n\t/** 查询表单排列方式 */\r\n\t@Input() nzxJustify: NzJustify = 'start';\r\n\t/** 查询项间隔 */\r\n\t@Input() nzxGutter: number = 8;\r\n\t/** 一行展示多少查询项 */\r\n\t@Input() lineNumber: number = 3;\r\n\t/** 操作按钮所占栅格数，24则换行 */\r\n\t@Input() nzxBtnSpan: number | null = null;\r\n\r\n\t/** 初始化时，主动查询 */\r\n\t@Input() initQuery = false;\r\n\r\n\t/** 缺省 固定参数 */\r\n\t@Input() fixedParams = {};\r\n\r\n\t/** 查询时会触发抛出查询参数 */\r\n\t@Output() queryChange = new EventEmitter<NzxQueryParams>();\r\n\t/** 重置时会触发抛出查询参数 */\r\n\t@Output() resetChange = new EventEmitter<NzxQueryParams>();\r\n\r\n\t/** form 表单*/\r\n\tqueryForm!: FormGroup;\r\n\r\n\t/** 查询组件出参*/\r\n\tget queryParams() {\r\n\t\treturn this._queryParams;\r\n\t}\r\n\r\n\tset queryParams(value: any) {\r\n\t\tthis._queryParams = value;\r\n\t}\r\n\r\n\tget nzxCollapse() {\r\n\t\treturn this.controls.some((i) => i.hasOwnProperty('collapse'));\r\n\t}\r\n\r\n\tlocale!: NzxQueryI18nInterface;\r\n\tcollapseIcon: string = 'down';\r\n\tcollapseText: string = '';\r\n\r\n\tprivate _queryParams: NzxQueryParams = {};\r\n\tprivate defaultValue: NzxQueryParams = {};\r\n\tprivate cacheParams: NzxQueryParams = {};\r\n\tprivate destroy$ = new Subject<void>();\r\n\tprivate _nzxBtnSpan: number | null = null;\r\n\r\n\t@ViewChild('queyForm') private queyFormEl!: ElementRef<HTMLFormElement>;\r\n\r\n\t@ContentChildren(NzxControlDirective, { descendants: true })\r\n\tcontrolTemplateList!: QueryList<NzxControlDirective>;\r\n\r\n\tconstructor(\r\n\t\tprivate i18n: NzI18nService,\r\n\t\tprivate fb: FormBuilder,\r\n\t\tprivate cd: ChangeDetectorRef\r\n\t) {\r\n\t\tthis.queryForm = this.fb.group({});\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tif (this.queyFormEl) {\r\n\t\t\tfromEvent<KeyboardEvent>(this.queyFormEl.nativeElement, 'keydown')\r\n\t\t\t\t.pipe(takeUntil(this.destroy$))\r\n\t\t\t\t.subscribe((event) => {\r\n\t\t\t\t\tif (event.key === 'Enter') {\r\n\t\t\t\t\t\tevent.stopPropagation();\r\n\t\t\t\t\t\tevent.preventDefault();\r\n\t\t\t\t\t\tthis.search();\r\n\t\t\t\t\t}\r\n\t\t\t\t\t// 检查是否同时按下了Ctrl键（在Windows/Linux上）和S键\r\n\t\t\t\t\tif ((event.ctrlKey || event.metaKey) && event.key === 'r') {\r\n\t\t\t\t\t\t// 注意：event.metaKey用于兼容Mac的Command键\r\n\t\t\t\t\t\tevent.preventDefault(); // 阻止浏览器默认的保存行为\r\n\t\t\t\t\t\tevent.stopPropagation();\r\n\t\t\t\t\t\tthis.reset();\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tngOnChanges(changes: SimpleChanges): void {\r\n\t\tif (changes['controls'] && !changes['controls'].isFirstChange()) {\r\n\t\t\tconst controls = changes['controls'].currentValue;\r\n\t\t\tif (Array.isArray(controls)) {\r\n\t\t\t\tthis.generateForm(controls);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tngOnInit(): void {\r\n\t\tthis.i18n.localeChange.pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n\t\t\tthis.locale = this.i18n.getLocaleData('Query');\r\n\r\n\t\t\tthis.cd.markForCheck();\r\n\t\t});\r\n\r\n\t\tthis.queryForm.valueChanges\r\n\t\t\t.pipe(takeUntil(this.destroy$))\r\n\t\t\t.subscribe((val) => {\r\n\t\t\t\tthis._queryParams = {\r\n\t\t\t\t\t...val,\r\n\t\t\t\t\t...this.fixedParams,\r\n\t\t\t\t};\r\n\t\t\t});\r\n\r\n\t\tthis._nzxBtnSpan = this.nzxBtnSpan;\r\n\t}\r\n\r\n\tngAfterContentInit(): void {\r\n\t\tthis.generateForm(this.controls);\r\n\r\n\t\tif (this.initQuery) {\r\n\t\t\tthis.search();\r\n\t\t}\r\n\t}\r\n\r\n\t/** 设置查询值进行回显 */\r\n\tsetQueryParams(cacheParams: NzxQueryParams): void {\r\n\t\tthis.cacheParams = cacheParams;\r\n\t\tthis.queryForm.patchValue(cacheParams);\r\n\t}\r\n\r\n\t/**\r\n\t * 根据controlName设置config值\r\n\t */\r\n\tsetControl(\r\n\t\tcontrolName: string,\r\n\t\tconfig: Partial<NzxQueryControlOptions>\r\n\t): void {\r\n\t\tPromise.resolve().then(() => {\r\n\t\t\tconst control = this.getControl(controlName);\r\n\t\t\tif (control) {\r\n\t\t\t\tObject.keys(config).forEach((key) => {\r\n\t\t\t\t\t(control as any)[key] = (config as any)[key];\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n\t * 动态添加控件\r\n\t * @param config 配置项\r\n\t * @param position 添加位置 不传为末尾\r\n\t */\r\n\taddControl(\r\n\t\tconfig: NzxQueryControlOptions,\r\n\t\tposition?: number | undefined\r\n\t): void {\r\n\t\tconst control = this.getControl(config.controlName);\r\n\t\tif (!control) {\r\n\t\t\tif (config.controlName) {\r\n\t\t\t\tthis.queryForm.addControl(\r\n\t\t\t\t\tconfig.controlName,\r\n\t\t\t\t\tconfig.controlInstance ?? this.fb.control(config.default ?? null)\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t\tif (position === void 0 || position === null) {\r\n\t\t\t\tthis.controls.push(config);\r\n\t\t\t} else {\r\n\t\t\t\tthis.controls.splice(position - 1, 0, config);\r\n\t\t\t}\r\n\t\t\tthis.calculateText();\r\n\t\t} else {\r\n\t\t\tthrow `The control name: '${config.controlName}' already exists!`;\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * 根据控件名删除控件\r\n\t */\r\n\tremoveControl(controlName: string): void {\r\n\t\tconst control = this.getControl(controlName);\r\n\t\tif (control) {\r\n\t\t\tthis.queryForm.removeControl(controlName);\r\n\t\t\tthis.controls = this.controls.filter(\r\n\t\t\t\t(c) => c.controlName !== controlName\r\n\t\t\t);\r\n\r\n\t\t\tthis.calculateText();\r\n\t\t} else {\r\n\t\t\tthrow `The control name: '${controlName}' not find!`;\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * 根据controlName获取config项\r\n\t */\r\n\tgetControl(\r\n\t\tcontrolName: string | undefined\r\n\t): NzxQueryControlOptions | undefined {\r\n\t\treturn this.controls.find((config) => config.controlName === controlName);\r\n\t}\r\n\r\n\t/**\r\n\t * 检索给定控件名称或路径的子控件。\r\n\t * 这个 getFormControl 签名支持字符串和 const 数组（.getFormControl(['foo', 'bar'] as const)）\r\n\t */\r\n\tgetFormControl(\r\n\t\tpath: string | readonly (string | number)[]\r\n\t): AbstractControl<any, any> | null {\r\n\t\treturn this.queryForm.get(path);\r\n\t}\r\n\r\n\t/** 查询 */\r\n\tsearch(event?: Event): void {\r\n\t\tif (event) {\r\n\t\t\tevent.stopPropagation();\r\n\t\t}\r\n\t\tif (this.queryForm.invalid) {\r\n\t\t\tupdateControlStatus(this.queryForm);\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tthis.queryChange.emit(this._queryParams);\r\n\t}\r\n\r\n\t/** 重置 */\r\n\treset(): void {\r\n\t\tif (this.queryForm.invalid) {\r\n\t\t\tupdateControlStatus(this.queryForm);\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tthis.queryForm.reset(this.defaultValue);\r\n\t\tthis.resetChange.emit(this._queryParams);\r\n\t}\r\n\r\n\t/**展开、收起*/\r\n\ttoggleCollapse(): void {\r\n\t\tfor (let index = 0; index < this.controls.length; index++) {\r\n\t\t\tconst config = this.controls[index];\r\n\t\t\tif (config.hasOwnProperty('collapse') && config.collapse === true) {\r\n\t\t\t\t(config.collapse as boolean) = false;\r\n\t\t\t} else if (\r\n\t\t\t\tconfig.hasOwnProperty('collapse') &&\r\n\t\t\t\t(config.collapse as boolean) === false\r\n\t\t\t) {\r\n\t\t\t\tconfig.collapse = true;\r\n\t\t\t}\r\n\t\t}\r\n\t\tthis.calculateText();\r\n\t}\r\n\r\n\tngOnDestroy(): void {\r\n\t\tthis.destroy$.next();\r\n\t\tthis.destroy$.complete();\r\n\t}\r\n\r\n\tprivate calculateText() {\r\n\t\tif (this.controls.some((i) => i.collapse === true)) {\r\n\t\t\tthis.collapseIcon = 'down';\r\n\t\t\tthis.collapseText = this.locale.expand;\r\n\t\t} else {\r\n\t\t\tthis.collapseIcon = 'up';\r\n\t\t\tthis.collapseText = this.locale.collapse;\r\n\t\t}\r\n\t\tthis.cd.markForCheck();\r\n\t}\r\n\r\n\t/** 清空表单控件 */\r\n\tprivate clearFormControl(): void {\r\n\t\tObject.keys(this.queryForm.controls).forEach((key) => {\r\n\t\t\tthis.queryForm.removeControl(key);\r\n\t\t});\r\n\t}\r\n\r\n\t/** 生成表单 */\r\n\tprivate generateForm(controlConfigs: Array<NzxQueryControlOptions>): void {\r\n\t\tthis.clearFormControl();\r\n\r\n\t\tfor (const config of controlConfigs) {\r\n\t\t\tif (config.controlType === 'Template') {\r\n\t\t\t\tconst item = this.controlTemplateList.find(\r\n\t\t\t\t\t(directive) => directive.nzxControl === config.controlName\r\n\t\t\t\t);\r\n\t\t\t\tif (item) {\r\n\t\t\t\t\tconfig.templateRef = item.templateRef;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif (config.controlName) {\r\n\t\t\t\tthis.queryForm.addControl(\r\n\t\t\t\t\tconfig.controlName,\r\n\t\t\t\t\tconfig.controlInstance ?? this.fb.control(config.default ?? null)\r\n\t\t\t\t);\r\n\t\t\t}\r\n\t\t}\r\n\t\tthis.defaultValue = this.queryForm.getRawValue();\r\n\t\tif (this.cacheParams) {\r\n\t\t\t// 缓存回显查询条件\r\n\t\t\tthis.queryForm.patchValue(this.cacheParams);\r\n\t\t}\r\n\r\n\t\tthis.calculateText();\r\n\t}\r\n}\r\n","<form #queyForm class=\"nzx-query-container\" nz-form [formGroup]=\"queryForm\">\n\t<div nz-row [nzGutter]=\"nzxGutter\" [nzJustify]=\"nzxJustify\">\n\t\t<ng-container *ngFor=\"let config of controls; let i = index\">\n\t\t\t<div\n\t\t\t\t*ngIf=\"!config.hidden\"\n\t\t\t\tnz-col\n\t\t\t\t[nzSpan]=\"config.nzxSpan || 24 / lineNumber\"\n\t\t\t\t[hidden]=\"config.collapse\"\n\t\t\t\t[nzOrder]=\"i\"\n\t\t\t>\n\t\t\t\t<nzx-configurable-query-item\n\t\t\t\t\t*ngIf=\"config.controlName\"\n\t\t\t\t\t[form]=\"queryForm\"\n\t\t\t\t\t[control]=\"config\"\n\t\t\t\t></nzx-configurable-query-item>\n\t\t\t</div>\n\t\t</ng-container>\n\n\t\t<div\n\t\t\t[nzOrder]=\"controls.length\"\n\t\t\tclass=\"nzx-query-btn\"\n\t\t\tnz-col\n\t\t\t[nzSpan]=\"nzxBtnSpan || 24 / lineNumber\"\n\t\t>\n\t\t\t<div nz-row nzJustify=\"end\" nzAlign=\"middle\">\n\t\t\t\t<button\n\t\t\t\t\tnz-button\n\t\t\t\t\tnzType=\"primary\"\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\ttitle=\"Enter\"\n\t\t\t\t\t(click)=\"search($event)\"\n\t\t\t\t>\n\t\t\t\t\t{{ locale['query'] }}\n\t\t\t\t</button>\n\t\t\t\t<button nz-button type=\"button\" title=\"ctrl+r\" (click)=\"reset()\">\n\t\t\t\t\t{{ locale['reset'] }}\n\t\t\t\t</button>\n\t\t\t\t<ng-content></ng-content>\n\t\t\t\t<a\n\t\t\t\t\t*ngIf=\"nzxCollapse\"\n\t\t\t\t\tnz-button\n\t\t\t\t\tnzType=\"link\"\n\t\t\t\t\t(click)=\"toggleCollapse()\"\n\t\t\t\t>\n\t\t\t\t\t{{ collapseText }}\n\t\t\t\t\t<i nz-icon [nzType]=\"collapseIcon\"></i>\n\t\t\t\t</a>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</form>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2NvbXBvbmVudHMvY29uZmlndXJhYmxlLXF1ZXJ5L3R5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBOenhPcHRpb25zIH0gZnJvbSAnbmctem9ycm8tYW50ZC1leHRlbnNpb24vdHlwZXMnO1xuaW1wb3J0IHsgTnp4QWJzdHJhY3RDb250cm9sIH0gZnJvbSAnLi9jb250cm9scy9hYnN0cmFjdC5jb250cm9sJztcblxuLyoqXG4gKiDmn6Xor6Llj4LmlbBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBOenhRdWVyeVBhcmFtcyB7XG5cdFtrZXk6IHN0cmluZ106IGFueTtcbn1cblxudHlwZSBDb250cm9sVHlwZSA9XG5cdHwgJ2lucHV0J1xuXHR8ICdzZWxlY3QnXG5cdHwgJ2RhdGVQaWNrZXInXG5cdHwgJ3JhbmdlUGlja2VyJ1xuXHR8ICdUZW1wbGF0ZSdcblx0fCBzdHJpbmc7XG5cbi8qKlxuICog6YWN572u6aG5XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTnp4UXVlcnlDb250cm9sT3B0aW9ucyB7XG5cdC8qKlxuXHQgKiDmjqfku7blkI3lr7nlupTmn6Xor6Llj4LmlbDnmoRrZXlcblx0ICovXG5cdGNvbnRyb2xOYW1lPzogc3RyaW5nO1xuXHQvKipcblx0ICog5o6n5Lu257G75Z6LXG5cdCAqL1xuXHRjb250cm9sVHlwZT86IENvbnRyb2xUeXBlO1xuXG5cdC8qKlxuXHQgKiDmn6Xor6LmoYZsYWJlbFxuXHQgKi9cblx0bGFiZWw/OiBzdHJpbmc7XG5cdC8qKlxuXHQgKiDmn6Xor6LmoYZwbGFjZWhvbGRlclxuXHQgKi9cblx0cGxhY2Vob2xkZXI/OiBzdHJpbmc7XG5cdC8qKlxuXHQgKiDmjqfku7bkuLpzZWxlY3Tml7bkuIvmi4npm4blkIhcblx0ICovXG5cdG1lbnVMaXN0PzogQXJyYXk8Tnp4T3B0aW9uczxhbnk+Pjtcblx0LyoqXG5cdCAqIOaOp+S7tuS4unNlbGVjdOaXtuWFgeiuuOWNleeLrOa4heepulxuXHQgKi9cblx0bnp4QWxsb3dDbGVhcj86IGJvb2xlYW47XG5cdC8qKlxuXHQgKiDmjqfku7bkuLpzZWxlY3Tml7blhYHorrjliY3nq6/mkJzntKJcblx0ICovXG5cdG56eFNob3dTZWFyY2g/OiBib29sZWFuO1xuXHQvKipcblx0ICog5p+l6K+i6aG55omA5Y2g5qCF5qC85pWwXG5cdCAqL1xuXHRuenhTcGFuPzogbnVtYmVyO1xuXHQvKipcblx0ICog5o6n5Lu26buY6K6k5YC877yM5rOo5oSP6buY6K6k5YC86YeN572u5pe25LiN5Lya5riF56m6XG5cdCAqL1xuXHRkZWZhdWx0PzogYW55O1xuXHQvKipcblx0ICog5p+l6K+i6aG5bGFiZWzmiYDljaDmoIXmoLzmlbBcblx0ICovXG5cdG56eExTcGFuPzogbnVtYmVyO1xuXHQvKipcblx0ICog5p+l6K+i6aG55o6n5Lu25omA5Y2g5qCF5qC85pWwXG5cdCAqL1xuXHRuenhSU3Bhbj86IG51bWJlcjtcblx0LyoqXG5cdCAqIOagoemqjOmUmeivr+aPkOekulxuXHQgKi9cblx0ZXJyb3JUaXA/OiBzdHJpbmc7XG5cdC8qKlxuXHQgKiDmipjlj6Bcblx0ICovXG5cdGNvbGxhcHNlPzogdHJ1ZTtcblx0LyoqXG5cdCAqIOmakOiXj+aOp+S7tijkuLvopoHnlKjmnaXmkLrluKbmn6Xor6Llj4LmlbDkvYbnlYzpnaLkuI3lj6/op4EpXG5cdCAqL1xuXHRoaWRkZW4/OiBib29sZWFuO1xuXHQvKipcblx0ICog5o6n5Lu25a6e5L6L77yM5Y+v6YCJXG5cdCAqL1xuXHRjb250cm9sSW5zdGFuY2U/OiBBYnN0cmFjdENvbnRyb2w7XG5cdC8qKlxuXHQgKiDoh6rlrprkuYnmqKHmnb9cblx0ICovXG5cdHRlbXBsYXRlUmVmPzogVGVtcGxhdGVSZWY8dW5rbm93bj47XG5cblx0W2tleTogc3RyaW5nXTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE56eFF1ZXJ5Q29udHJvbFR5cGUge1xuXHRrZXk6IHN0cmluZztcblx0Y29tcG9uZW50OiB0eXBlb2YgTnp4QWJzdHJhY3RDb250cm9sO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE56eFF1ZXJ5Q29uZmlnIHtcblx0Y29udHJvbFR5cGVzOiBOenhRdWVyeUNvbnRyb2xUeXBlW107XG59XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctem9ycm8tYW50ZC1leHRlbnNpb24tcHJpbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9jb21wb25lbnRzL3ByaW50L25nLXpvcnJvLWFudGQtZXh0ZW5zaW9uLXByaW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Directive, Input } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NzxPrintContentDirective {
|
|
4
|
+
constructor(elementRef) {
|
|
5
|
+
this.elementRef = elementRef;
|
|
6
|
+
this.identifierStr = '';
|
|
7
|
+
this.customStyle = '';
|
|
8
|
+
}
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintContentDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
10
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: NzxPrintContentDirective, selector: "[nzxPrintContent]", inputs: { identifierStr: "identifierStr", customStyle: "customStyle" }, ngImport: i0 }); }
|
|
11
|
+
}
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintContentDirective, decorators: [{
|
|
13
|
+
type: Directive,
|
|
14
|
+
args: [{
|
|
15
|
+
selector: '[nzxPrintContent]',
|
|
16
|
+
}]
|
|
17
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { identifierStr: [{
|
|
18
|
+
type: Input
|
|
19
|
+
}], customStyle: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}] } });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnp4LXByaW50LWNvbnRlbnQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vY29tcG9uZW50cy9wcmludC9uengtcHJpbnQtY29udGVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzdELE1BQU0sT0FBTyx3QkFBd0I7SUFHcEMsWUFBbUIsVUFBc0I7UUFBdEIsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUZoQyxrQkFBYSxHQUFzQixFQUFFLENBQUM7UUFDdEMsZ0JBQVcsR0FBRyxFQUFFLENBQUM7SUFDa0IsQ0FBQzs4R0FIakMsd0JBQXdCO2tHQUF4Qix3QkFBd0I7OzJGQUF4Qix3QkFBd0I7a0JBSHBDLFNBQVM7bUJBQUM7b0JBQ1YsUUFBUSxFQUFFLG1CQUFtQjtpQkFDN0I7K0VBRVMsYUFBYTtzQkFBckIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbkBEaXJlY3RpdmUoe1xuXHRzZWxlY3RvcjogJ1tuenhQcmludENvbnRlbnRdJyxcbn0pXG5leHBvcnQgY2xhc3MgTnp4UHJpbnRDb250ZW50RGlyZWN0aXZlIHtcblx0QElucHV0KCkgaWRlbnRpZmllclN0cjogc3RyaW5nIHwgc3RyaW5nW10gPSAnJztcblx0QElucHV0KCkgY3VzdG9tU3R5bGUgPSAnJztcblx0Y29uc3RydWN0b3IocHVibGljIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG59XG4iXX0=
|