tnx-shared 5.3.375 → 5.3.376
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/tnx-shared.umd.js +16 -6
- package/bundles/tnx-shared.umd.js.map +1 -1
- package/bundles/tnx-shared.umd.min.js +1 -1
- package/bundles/tnx-shared.umd.min.js.map +1 -1
- package/components/entity-picker/entity-picker-dialog/components/entity-picker-search-form/entity-picker-search-form.component.d.ts +1 -0
- package/components/entity-picker/entity-picker-dialog/components/entity-picker-search-form/entity-picker-search-form.component.d.ts.map +1 -1
- package/esm2015/components/entity-picker/entity-picker-dialog/components/entity-picker-search-form/entity-picker-search-form.component.js +17 -7
- package/fesm2015/tnx-shared.js +16 -6
- package/fesm2015/tnx-shared.js.map +1 -1
- package/package.json +2 -2
- package/tnx-shared.metadata.json +1 -1
|
@@ -3,6 +3,7 @@ import { DataFormBase, EventData } from '../../../../../public-api';
|
|
|
3
3
|
export declare class EntityPickerSearchFormComponent extends DataFormBase implements OnInit {
|
|
4
4
|
protected _injector: Injector;
|
|
5
5
|
datasourceFieldFilter: any[];
|
|
6
|
+
formData: any;
|
|
6
7
|
set lstDataNotExist(value: string[]);
|
|
7
8
|
onSearch: EventEmitter<any>;
|
|
8
9
|
constructor(_injector: Injector);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"entity-picker-search-form.component.d.ts","sourceRoot":"","sources":["../../../../../../../projects/tnx-shared/src/lib/components/entity-picker/entity-picker-dialog/components/entity-picker-search-form/entity-picker-search-form.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,YAAY,EAAE,QAAQ,EAAS,MAAM,EAAU,MAAM,eAAe,CAAC;AACzF,OAAO,EAA2B,YAAY,EAAE,SAAS,EAAuD,MAAM,2BAA2B,CAAC;AAElJ,qBAMa,+BAAgC,SAAQ,YAAa,YAAW,MAAM;
|
|
1
|
+
{"version":3,"file":"entity-picker-search-form.component.d.ts","sourceRoot":"","sources":["../../../../../../../projects/tnx-shared/src/lib/components/entity-picker/entity-picker-dialog/components/entity-picker-search-form/entity-picker-search-form.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,YAAY,EAAE,QAAQ,EAAS,MAAM,EAAU,MAAM,eAAe,CAAC;AACzF,OAAO,EAA2B,YAAY,EAAE,SAAS,EAAuD,MAAM,2BAA2B,CAAC;AAElJ,qBAMa,+BAAgC,SAAQ,YAAa,YAAW,MAAM;IAmB3E,SAAS,CAAC,SAAS,EAAE,QAAQ;IAjBxB,qBAAqB,QAAM;IAC3B,QAAQ,EAAE,GAAG,CAKpB;IACF,IAAa,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,EAO3C;IACS,QAAQ,oBAA2B;gBAE/B,SAAS,EAAE,QAAQ;IAMjC,QAAQ;IAkCF,iBAAiB,CAAC,QAAQ,EAAE,SAAS;IAIrC,WAAW,CAAC,GAAG,EAAE,SAAS;IAQ1B,gBAAgB,CAAC,IAAI,KAAA;IAIrB,UAAU;CAQnB"}
|
|
@@ -6,6 +6,12 @@ export class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
6
6
|
super(_injector);
|
|
7
7
|
this._injector = _injector;
|
|
8
8
|
this.datasourceFieldFilter = [];
|
|
9
|
+
this.formData = {
|
|
10
|
+
placeholder: 'linh123\nnam123',
|
|
11
|
+
doiTuong: 'người dùng',
|
|
12
|
+
iconSave: 'pi pi-search',
|
|
13
|
+
labelSave: 'Tìm kiếm'
|
|
14
|
+
};
|
|
9
15
|
this.onSearch = new EventEmitter();
|
|
10
16
|
}
|
|
11
17
|
set lstDataNotExist(value) {
|
|
@@ -25,6 +31,7 @@ export class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
25
31
|
dataSource: this.datasourceFieldFilter,
|
|
26
32
|
required: true,
|
|
27
33
|
mdWidth: 12,
|
|
34
|
+
hidden: !this.datasourceFieldFilter.length,
|
|
28
35
|
onChanged: (evt) => {
|
|
29
36
|
const plusPlaceholder = evt.parentModel.fieldFilter == 'email' ? '@gmail.com' : '';
|
|
30
37
|
evt.formControls['lstDataCheck'].placeholder = `linh123${plusPlaceholder}\nnam123${plusPlaceholder}`;
|
|
@@ -32,16 +39,16 @@ export class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
32
39
|
}),
|
|
33
40
|
new TextAreaControlSchema({
|
|
34
41
|
field: 'lstDataCheck',
|
|
35
|
-
label:
|
|
36
|
-
description:
|
|
42
|
+
label: `Danh sách ${this.formData.doiTuong}`,
|
|
43
|
+
description: `nhập mỗi ${this.formData.doiTuong} là một dòng`,
|
|
37
44
|
mdWidth: 12,
|
|
38
45
|
rows: 10,
|
|
39
46
|
required: true,
|
|
40
|
-
placeholder:
|
|
47
|
+
placeholder: this.formData.placeholder
|
|
41
48
|
}),
|
|
42
49
|
new TextAreaControlSchema({
|
|
43
50
|
field: 'lstDataNotExist',
|
|
44
|
-
label:
|
|
51
|
+
label: `Danh sách ${this.formData.doiTuong} không hợp lệ`,
|
|
45
52
|
hidden: true,
|
|
46
53
|
mdWidth: 12
|
|
47
54
|
}),
|
|
@@ -55,7 +62,9 @@ export class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
55
62
|
}
|
|
56
63
|
initDataAdd(evt) {
|
|
57
64
|
return __awaiter(this, void 0, void 0, function* () {
|
|
58
|
-
|
|
65
|
+
if (this.datasourceFieldFilter.length) {
|
|
66
|
+
evt.rootModel.fieldFilter = this.datasourceFieldFilter[0].id;
|
|
67
|
+
}
|
|
59
68
|
evt.rootModel.lstDataCheck = undefined;
|
|
60
69
|
evt.rootModel.lstDataNotExist = undefined;
|
|
61
70
|
});
|
|
@@ -79,7 +88,7 @@ export class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
79
88
|
EntityPickerSearchFormComponent.decorators = [
|
|
80
89
|
{ type: Component, args: [{
|
|
81
90
|
selector: 'entity-picker-search-form',
|
|
82
|
-
template: "<crud-form #crudForm [setting]=\"setting\" [context]=\"context\" [disableCaching]=\"true\" [(data)]=\"model.data\"\n (onFormReady)=\"_handleFormReady($event)\">\n</crud-form>\n<ng-template #buttonTemplate>\n <button pButton type=\"button\" icon=\"
|
|
91
|
+
template: "<crud-form #crudForm [setting]=\"setting\" [context]=\"context\" [disableCaching]=\"true\" [(data)]=\"model.data\"\n (onFormReady)=\"_handleFormReady($event)\">\n</crud-form>\n<ng-template #buttonTemplate>\n <button pButton type=\"button\" [icon]=\"formData.iconSave\" class=\"p-button-text\" [label]=\"formData.labelSave\"\n (click)=\"customSave()\"></button>\n <button pButton preventTab type=\"button\" icon=\"pi pi-replay\" class=\"p-button-text p-button-secondary\"\n [label]=\"'FORM.CANCEL' | translate\" (click)=\"_handleCancel($event)\"></button>\n</ng-template>",
|
|
83
92
|
providers: [ComponentContextService],
|
|
84
93
|
styles: [""]
|
|
85
94
|
},] }
|
|
@@ -89,7 +98,8 @@ EntityPickerSearchFormComponent.ctorParameters = () => [
|
|
|
89
98
|
];
|
|
90
99
|
EntityPickerSearchFormComponent.propDecorators = {
|
|
91
100
|
datasourceFieldFilter: [{ type: Input }],
|
|
101
|
+
formData: [{ type: Input }],
|
|
92
102
|
lstDataNotExist: [{ type: Input }],
|
|
93
103
|
onSearch: [{ type: Output }]
|
|
94
104
|
};
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-picker-search-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tnx-shared/src/lib/components/entity-picker/entity-picker-dialog/components/entity-picker-search-form/entity-picker-search-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Injector, Input, OnInit, Output } from '@angular/core';\nimport { ComponentContextService, DataFormBase, EventData, RadioButtonListControlSchema, TextAreaControlSchema } from '../../../../../public-api';\n\n@Component({\n    selector: 'entity-picker-search-form',\n    templateUrl: './entity-picker-search-form.component.html',\n    styleUrls: ['./entity-picker-search-form.component.scss'],\n    providers: [ComponentContextService],\n})\nexport class EntityPickerSearchFormComponent extends DataFormBase implements OnInit {\n\n    @Input() datasourceFieldFilter = [];\n    @Input() formData: any = {\n        placeholder: 'linh123\\nnam123',\n        doiTuong: 'người dùng',\n        iconSave: 'pi pi-search',\n        labelSave: 'Tìm kiếm'\n    };\n    @Input() set lstDataNotExist(value: string[]) {\n        if (!value.length) return;\n\n        const strValue = value.join('\\n');\n        this.model.data.lstDataNotExist = strValue;\n        this.crudForm._modelData.lstDataNotExist = strValue;\n        this.formControls['lstDataNotExist'].hidden = false;\n    }\n    @Output() onSearch = new EventEmitter<any>();\n    constructor(\n        protected _injector: Injector,\n\n    ) {\n        super(_injector);\n    }\n\n    ngOnInit() {\n        this.doNotCheckBaseService = true;\n        this.setting.schema = [\n            new RadioButtonListControlSchema({\n                field: 'fieldFilter',\n                label: 'Chọn tiêu chí tìm kiếm',\n                dataSource: this.datasourceFieldFilter,\n                required: true,\n                mdWidth: 12,\n                hidden: !this.datasourceFieldFilter.length,\n                onChanged: (evt: EventData) => {\n                    const plusPlaceholder = evt.parentModel.fieldFilter == 'email' ? '@gmail.com' : '';\n                    evt.formControls['lstDataCheck'].placeholder = `linh123${plusPlaceholder}\\nnam123${plusPlaceholder}`;\n                }\n            }),\n            new TextAreaControlSchema({\n                field: 'lstDataCheck',\n                label: `Danh sách ${this.formData.doiTuong}`,\n                description: `nhập mỗi ${this.formData.doiTuong} là một dòng`,\n                mdWidth: 12,\n                rows: 10,\n                required: true,\n                placeholder: this.formData.placeholder\n            }),\n            new TextAreaControlSchema({\n                field: 'lstDataNotExist',\n                label: `Danh sách ${this.formData.doiTuong} không hợp lệ`,\n                hidden: true,\n                mdWidth: 12\n            }),\n        ];\n        super.ngOnInit();\n    }\n\n    async onFormInitialized(controls: EventData) {\n        // tiền xử lý dữ liệu (ví dụ tổng hợp datasource), trước khi gọi api get detail\n\n    }\n    async initDataAdd(evt: EventData) {\n        if (this.datasourceFieldFilter.length) {\n            evt.rootModel.fieldFilter = this.datasourceFieldFilter[0].id;\n        }\n        evt.rootModel.lstDataCheck = undefined;\n        evt.rootModel.lstDataNotExist = undefined;\n    }\n\n    async modifyDetailData(data) {\n        // xử lý dữ liệu lấy từ get detail về\n    }\n\n    async customSave() {\n        // trước khi lưu\n        const isValid = await this.crudForm.validateForm();\n        if (!isValid) return;\n        this.model.data.lstData = this.model.data.lstDataCheck.split('\\n').map(p => p.trim()).filter(p => p);\n        this.onSearch.emit(this.model.data);\n    }\n\n}\n"]}
|
package/fesm2015/tnx-shared.js
CHANGED
|
@@ -41585,6 +41585,12 @@ class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
41585
41585
|
super(_injector);
|
|
41586
41586
|
this._injector = _injector;
|
|
41587
41587
|
this.datasourceFieldFilter = [];
|
|
41588
|
+
this.formData = {
|
|
41589
|
+
placeholder: 'linh123\nnam123',
|
|
41590
|
+
doiTuong: 'người dùng',
|
|
41591
|
+
iconSave: 'pi pi-search',
|
|
41592
|
+
labelSave: 'Tìm kiếm'
|
|
41593
|
+
};
|
|
41588
41594
|
this.onSearch = new EventEmitter();
|
|
41589
41595
|
}
|
|
41590
41596
|
set lstDataNotExist(value) {
|
|
@@ -41604,6 +41610,7 @@ class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
41604
41610
|
dataSource: this.datasourceFieldFilter,
|
|
41605
41611
|
required: true,
|
|
41606
41612
|
mdWidth: 12,
|
|
41613
|
+
hidden: !this.datasourceFieldFilter.length,
|
|
41607
41614
|
onChanged: (evt) => {
|
|
41608
41615
|
const plusPlaceholder = evt.parentModel.fieldFilter == 'email' ? '@gmail.com' : '';
|
|
41609
41616
|
evt.formControls['lstDataCheck'].placeholder = `linh123${plusPlaceholder}\nnam123${plusPlaceholder}`;
|
|
@@ -41611,16 +41618,16 @@ class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
41611
41618
|
}),
|
|
41612
41619
|
new TextAreaControlSchema({
|
|
41613
41620
|
field: 'lstDataCheck',
|
|
41614
|
-
label:
|
|
41615
|
-
description:
|
|
41621
|
+
label: `Danh sách ${this.formData.doiTuong}`,
|
|
41622
|
+
description: `nhập mỗi ${this.formData.doiTuong} là một dòng`,
|
|
41616
41623
|
mdWidth: 12,
|
|
41617
41624
|
rows: 10,
|
|
41618
41625
|
required: true,
|
|
41619
|
-
placeholder:
|
|
41626
|
+
placeholder: this.formData.placeholder
|
|
41620
41627
|
}),
|
|
41621
41628
|
new TextAreaControlSchema({
|
|
41622
41629
|
field: 'lstDataNotExist',
|
|
41623
|
-
label:
|
|
41630
|
+
label: `Danh sách ${this.formData.doiTuong} không hợp lệ`,
|
|
41624
41631
|
hidden: true,
|
|
41625
41632
|
mdWidth: 12
|
|
41626
41633
|
}),
|
|
@@ -41634,7 +41641,9 @@ class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
41634
41641
|
}
|
|
41635
41642
|
initDataAdd(evt) {
|
|
41636
41643
|
return __awaiter(this, void 0, void 0, function* () {
|
|
41637
|
-
|
|
41644
|
+
if (this.datasourceFieldFilter.length) {
|
|
41645
|
+
evt.rootModel.fieldFilter = this.datasourceFieldFilter[0].id;
|
|
41646
|
+
}
|
|
41638
41647
|
evt.rootModel.lstDataCheck = undefined;
|
|
41639
41648
|
evt.rootModel.lstDataNotExist = undefined;
|
|
41640
41649
|
});
|
|
@@ -41658,7 +41667,7 @@ class EntityPickerSearchFormComponent extends DataFormBase {
|
|
|
41658
41667
|
EntityPickerSearchFormComponent.decorators = [
|
|
41659
41668
|
{ type: Component, args: [{
|
|
41660
41669
|
selector: 'entity-picker-search-form',
|
|
41661
|
-
template: "<crud-form #crudForm [setting]=\"setting\" [context]=\"context\" [disableCaching]=\"true\" [(data)]=\"model.data\"\n (onFormReady)=\"_handleFormReady($event)\">\n</crud-form>\n<ng-template #buttonTemplate>\n <button pButton type=\"button\" icon=\"
|
|
41670
|
+
template: "<crud-form #crudForm [setting]=\"setting\" [context]=\"context\" [disableCaching]=\"true\" [(data)]=\"model.data\"\n (onFormReady)=\"_handleFormReady($event)\">\n</crud-form>\n<ng-template #buttonTemplate>\n <button pButton type=\"button\" [icon]=\"formData.iconSave\" class=\"p-button-text\" [label]=\"formData.labelSave\"\n (click)=\"customSave()\"></button>\n <button pButton preventTab type=\"button\" icon=\"pi pi-replay\" class=\"p-button-text p-button-secondary\"\n [label]=\"'FORM.CANCEL' | translate\" (click)=\"_handleCancel($event)\"></button>\n</ng-template>",
|
|
41662
41671
|
providers: [ComponentContextService],
|
|
41663
41672
|
styles: [""]
|
|
41664
41673
|
},] }
|
|
@@ -41668,6 +41677,7 @@ EntityPickerSearchFormComponent.ctorParameters = () => [
|
|
|
41668
41677
|
];
|
|
41669
41678
|
EntityPickerSearchFormComponent.propDecorators = {
|
|
41670
41679
|
datasourceFieldFilter: [{ type: Input }],
|
|
41680
|
+
formData: [{ type: Input }],
|
|
41671
41681
|
lstDataNotExist: [{ type: Input }],
|
|
41672
41682
|
onSearch: [{ type: Output }]
|
|
41673
41683
|
};
|