ets-fe-ng-sdk 17.0.172 → 17.0.174
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/esm2022/lib/Services/base.service.mjs +23 -1
- package/esm2022/lib/Shared/components/file-upload/file-upload.component.mjs +90 -0
- package/esm2022/lib/Shared/components/table-input/table-input.component.mjs +28 -10
- package/esm2022/lib/Shared/components/text-area-modal/text-area-modal.component.mjs +37 -0
- package/esm2022/lib/Shared/components/text-area-modal/text-area-modal.service.mjs +22 -0
- package/esm2022/lib/Shared/pipes/utility.pipe.mjs +4 -3
- package/esm2022/public-api.mjs +4 -1
- package/fesm2022/ets-fe-ng-sdk.mjs +181 -12
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Services/base.service.d.ts +5 -0
- package/lib/Services/utility.service.d.ts +1 -1
- package/lib/Shared/components/file-upload/file-upload.component.d.ts +30 -0
- package/lib/Shared/components/info-dialog/info-dialog.component.d.ts +1 -1
- package/lib/Shared/components/page-template/page-template.component.d.ts +1 -1
- package/lib/Shared/components/table-input/table-input.component.d.ts +4 -2
- package/lib/Shared/components/text-area-modal/text-area-modal.component.d.ts +27 -0
- package/lib/Shared/components/text-area-modal/text-area-modal.service.d.ts +10 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
|
@@ -19,6 +19,28 @@ export class BaseService {
|
|
|
19
19
|
delete(path = '', query) {
|
|
20
20
|
return query ? this.apiS.deleteWithBody(this.formatRoute(this.baseURL + path), query) : this.apiS.delete(this.baseURL + path);
|
|
21
21
|
}
|
|
22
|
+
deleteWithBody(path, body) {
|
|
23
|
+
return this.apiS.deleteWithBody(this.formatRoute(this.baseURL + path || ''), body);
|
|
24
|
+
}
|
|
25
|
+
postFile(path, body) {
|
|
26
|
+
const formData = new FormData();
|
|
27
|
+
for (const key in body) {
|
|
28
|
+
if (Object.prototype.hasOwnProperty.call(body, key)) {
|
|
29
|
+
const element = body[key];
|
|
30
|
+
if (element instanceof File)
|
|
31
|
+
formData.append(key, element, element.name);
|
|
32
|
+
else
|
|
33
|
+
formData.append(key, element);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return this.apiS.postFile(this.formatRoute(this.baseURL + path || ''), formData);
|
|
37
|
+
}
|
|
38
|
+
postFileFD(path, body) {
|
|
39
|
+
return this.apiS.postFile(this.formatRoute(this.baseURL + path || ''), body);
|
|
40
|
+
}
|
|
41
|
+
putFileFD(path, body) {
|
|
42
|
+
return this.apiS.putFile(this.formatRoute(this.baseURL + path || ''), body);
|
|
43
|
+
}
|
|
22
44
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: BaseService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
23
45
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: BaseService, providedIn: 'root' }); }
|
|
24
46
|
}
|
|
@@ -28,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
28
50
|
providedIn: 'root',
|
|
29
51
|
}]
|
|
30
52
|
}], ctorParameters: () => [] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXRzLWZlLW5nLXNkay9zcmMvbGliL1NlcnZpY2VzL2Jhc2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0zQyxNQUFNLE9BQU8sV0FBVztJQUd0QjtRQUZVLFNBQUksR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDMUIsWUFBTyxHQUFHLEVBQUUsQ0FBQztRQXNDdkIsZ0JBQVcsR0FBRyxDQUFDLEtBQWEsRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQXJDbkYsQ0FBQztJQUVOLElBQUksQ0FBSSxJQUFVLEVBQUUsSUFBSSxHQUFHLEVBQUU7UUFDckMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBSSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUVTLEdBQUcsQ0FBSSxJQUFVLEVBQUUsSUFBSSxHQUFHLEVBQUU7UUFDcEMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBSSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDdkUsQ0FBQztJQUVTLEdBQUcsQ0FBSSxJQUFJLEdBQUcsRUFBRSxFQUFFLEtBQVc7UUFDckMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBSSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUVTLE1BQU0sQ0FBSSxJQUFJLEdBQUcsRUFBRSxFQUFFLEtBQVc7UUFDeEMsT0FBTyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUksSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN0SSxDQUFDO0lBQ1MsY0FBYyxDQUFJLElBQWEsRUFBRSxJQUFVO1FBQ25ELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNyRixDQUFDO0lBQ1MsUUFBUSxDQUFJLElBQVksRUFBRSxJQUFvQjtRQUN0RCxNQUFNLFFBQVEsR0FBYSxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQzFDLEtBQUssTUFBTSxHQUFHLElBQUksSUFBSSxFQUFFO1lBQ3RCLElBQUksTUFBTSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsRUFBRTtnQkFDbkQsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUMxQixJQUFJLE9BQU8sWUFBWSxJQUFJO29CQUFFLFFBQVEsQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7O29CQUNwRSxRQUFRLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQzthQUNwQztTQUNGO1FBQ0QsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBSSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQ3RGLENBQUM7SUFDUyxVQUFVLENBQUksSUFBWSxFQUFFLElBQWM7UUFDbEQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBSSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2xGLENBQUM7SUFDUyxTQUFTLENBQUksSUFBWSxFQUFFLElBQWM7UUFDakQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBSSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2pGLENBQUM7OEdBdkNVLFdBQVc7a0hBQVgsV0FBVyxjQUZWLE1BQU07OzJGQUVQLFdBQVc7a0JBSHZCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBcGlTZXJ2aWNlIH0gZnJvbSAnLi9hcGkuc2VydmljZSc7XG5pbXBvcnQgeyBJT2JqZWN0TGl0ZXJhbCB9IGZyb20gJy4uL1NoYXJlZC9tb2RlbHMvaW5kZXgubW9kZWwnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgQmFzZVNlcnZpY2Uge1xuICBwcm90ZWN0ZWQgYXBpUyA9IGluamVjdChBcGlTZXJ2aWNlKTtcbiAgcHJvdGVjdGVkIGJhc2VVUkwgPSBgYDtcbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIHByb3RlY3RlZCBwb3N0PFQ+KGRhdGE/OiBhbnksIHBhdGggPSAnJykge1xuICAgIHJldHVybiB0aGlzLmFwaVMucG9zdDxUPih0aGlzLmZvcm1hdFJvdXRlKHRoaXMuYmFzZVVSTCArIHBhdGgpLCBkYXRhKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBwdXQ8VD4oZGF0YT86IGFueSwgcGF0aCA9ICcnKSB7XG4gICAgcmV0dXJuIHRoaXMuYXBpUy5wdXQ8VD4odGhpcy5mb3JtYXRSb3V0ZSh0aGlzLmJhc2VVUkwgKyBwYXRoKSwgZGF0YSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgZ2V0PFQ+KHBhdGggPSAnJywgcXVlcnk/OiBhbnkpIHtcbiAgICByZXR1cm4gdGhpcy5hcGlTLmdldDxUPih0aGlzLmZvcm1hdFJvdXRlKHRoaXMuYmFzZVVSTCArIHBhdGgpLCBxdWVyeSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgZGVsZXRlPFQ+KHBhdGggPSAnJywgcXVlcnk/OiBhbnkpIHtcbiAgICByZXR1cm4gcXVlcnkgPyB0aGlzLmFwaVMuZGVsZXRlV2l0aEJvZHk8VD4odGhpcy5mb3JtYXRSb3V0ZSh0aGlzLmJhc2VVUkwgKyBwYXRoKSwgcXVlcnkpIDogdGhpcy5hcGlTLmRlbGV0ZTxUPih0aGlzLmJhc2VVUkwgKyBwYXRoKTtcbiAgfVxuICBwcm90ZWN0ZWQgZGVsZXRlV2l0aEJvZHk8VD4ocGF0aD86IHN0cmluZywgYm9keT86IGFueSkge1xuICAgIHJldHVybiB0aGlzLmFwaVMuZGVsZXRlV2l0aEJvZHkodGhpcy5mb3JtYXRSb3V0ZSh0aGlzLmJhc2VVUkwgKyBwYXRoIHx8ICcnKSwgYm9keSk7XG4gIH0gXG4gIHByb3RlY3RlZCBwb3N0RmlsZTxUPihwYXRoOiBzdHJpbmcsIGJvZHk6IElPYmplY3RMaXRlcmFsKSB7XG4gICAgY29uc3QgZm9ybURhdGE6IEZvcm1EYXRhID0gbmV3IEZvcm1EYXRhKCk7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gYm9keSkge1xuICAgICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChib2R5LCBrZXkpKSB7XG4gICAgICAgIGNvbnN0IGVsZW1lbnQgPSBib2R5W2tleV07XG4gICAgICAgIGlmIChlbGVtZW50IGluc3RhbmNlb2YgRmlsZSkgZm9ybURhdGEuYXBwZW5kKGtleSwgZWxlbWVudCwgZWxlbWVudC5uYW1lKTtcbiAgICAgICAgZWxzZSBmb3JtRGF0YS5hcHBlbmQoa2V5LCBlbGVtZW50KTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuYXBpUy5wb3N0RmlsZTxUPih0aGlzLmZvcm1hdFJvdXRlKHRoaXMuYmFzZVVSTCArIHBhdGggfHwgJycpLCBmb3JtRGF0YSk7XG4gIH1cbiAgcHJvdGVjdGVkIHBvc3RGaWxlRkQ8VD4ocGF0aDogc3RyaW5nLCBib2R5OiBGb3JtRGF0YSkge1xuICAgIHJldHVybiB0aGlzLmFwaVMucG9zdEZpbGU8VD4odGhpcy5mb3JtYXRSb3V0ZSh0aGlzLmJhc2VVUkwgKyBwYXRoIHx8ICcnKSwgYm9keSk7XG4gIH1cbiAgcHJvdGVjdGVkIHB1dEZpbGVGRDxUPihwYXRoOiBzdHJpbmcsIGJvZHk6IEZvcm1EYXRhKSB7XG4gICAgcmV0dXJuIHRoaXMuYXBpUy5wdXRGaWxlPFQ+KHRoaXMuZm9ybWF0Um91dGUodGhpcy5iYXNlVVJMICsgcGF0aCB8fCAnJyksIGJvZHkpO1xuICB9XG4gIGZvcm1hdFJvdXRlID0gKHJvdXRlOiBzdHJpbmcpID0+IChyb3V0ZS5lbmRzV2l0aCgnLycpID8gcm91dGUuc2xpY2UoMCwgcm91dGUubGVuZ3RoIC0gMSkgOiByb3V0ZSk7XG59XG4iXX0=
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, inject, input } from '@angular/core';
|
|
2
|
+
import { NgIf, NgClass, NgFor } from '@angular/common';
|
|
3
|
+
import { BtnComponent } from '../btn/btn.component';
|
|
4
|
+
import { UtilityService } from '../../../Services/utility.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class FileUploadComponent {
|
|
7
|
+
set _accept(v) {
|
|
8
|
+
switch (v) {
|
|
9
|
+
case 'image':
|
|
10
|
+
this.accept = '.png,.jpg,.docx,.pdf';
|
|
11
|
+
break;
|
|
12
|
+
default:
|
|
13
|
+
this.accept = v;
|
|
14
|
+
break;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
constructor() {
|
|
18
|
+
this.class = input();
|
|
19
|
+
this.mini = input(true);
|
|
20
|
+
this.listFiles = input(true);
|
|
21
|
+
this.fileChange = new EventEmitter();
|
|
22
|
+
this.filesChange = new EventEmitter();
|
|
23
|
+
this.uS = inject(UtilityService);
|
|
24
|
+
}
|
|
25
|
+
ngOnInit() { }
|
|
26
|
+
get isSingle() {
|
|
27
|
+
return !this.multiple;
|
|
28
|
+
}
|
|
29
|
+
acceptFiles(...files) {
|
|
30
|
+
this.files = files;
|
|
31
|
+
this.file = files ? files[0] : null;
|
|
32
|
+
}
|
|
33
|
+
emitFiles() {
|
|
34
|
+
if (this.multiple)
|
|
35
|
+
this.filesChange.emit(this.files);
|
|
36
|
+
else
|
|
37
|
+
this.fileChange.emit(this.file);
|
|
38
|
+
}
|
|
39
|
+
onUpload(event) {
|
|
40
|
+
const files = Array.from(event.target.files);
|
|
41
|
+
this.acceptFiles(...files);
|
|
42
|
+
this.emitFiles();
|
|
43
|
+
}
|
|
44
|
+
removeFile(index) {
|
|
45
|
+
this.files.splice(index, 1);
|
|
46
|
+
this.file = this.files ? this.files[0] : null;
|
|
47
|
+
this.fileChange.emit(this.file);
|
|
48
|
+
this.filesChange.emit(this.files);
|
|
49
|
+
}
|
|
50
|
+
openDialog() {
|
|
51
|
+
const inp = document.createElement('input');
|
|
52
|
+
inp.type = 'file';
|
|
53
|
+
inp.accept = this.accept;
|
|
54
|
+
inp.multiple = this.multiple;
|
|
55
|
+
inp.onchange = (e) => {
|
|
56
|
+
this.onUpload(e);
|
|
57
|
+
inp.remove();
|
|
58
|
+
};
|
|
59
|
+
// document.body.appendChild(inp);
|
|
60
|
+
inp.click();
|
|
61
|
+
}
|
|
62
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: FileUploadComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
63
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.0", type: FileUploadComponent, isStandalone: true, selector: "app-file-upload", inputs: { help: { classPropertyName: "help", publicName: "help", isSignal: false, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: false, isRequired: false, transformFunction: null }, class: { classPropertyName: "class", publicName: "class", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: false, isRequired: false, transformFunction: null }, mini: { classPropertyName: "mini", publicName: "mini", isSignal: true, isRequired: false, transformFunction: null }, useDocumentModal: { classPropertyName: "useDocumentModal", publicName: "useDocumentModal", isSignal: false, isRequired: false, transformFunction: null }, listFiles: { classPropertyName: "listFiles", publicName: "listFiles", isSignal: true, isRequired: false, transformFunction: null }, _accept: { classPropertyName: "_accept", publicName: "accept", isSignal: false, isRequired: false, transformFunction: null }, file: { classPropertyName: "file", publicName: "file", isSignal: false, isRequired: false, transformFunction: null }, files: { classPropertyName: "files", publicName: "files", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { fileChange: "fileChange", filesChange: "filesChange" }, ngImport: i0, template: "\n@if (listFiles()) {\n<div [ngClass]=\"{meta:mini()}\" class=\"{{class()}} form-label mb-2 hide-scroll\">\n @for (item of files; track item;) {\n <div class=\"row align-items-start mb-1\">\n <div class=\"col\">\n <div class=\"hide-scroll file-name\">\n {{item?.name}}\n </div>\n </div>\n <div class=\"col-auto text-end\">\n <span class=\"text-danger pointer p-1 fa fa-close\" (click)=\"removeFile($index);\"></span>\n </div>\n </div>\n}\n</div>\n}\n<!-- <input type=\"file\" style=\"display: none;\" accept=\"{{accept}}\" (change)=\"onUpload($event)\" #uploadInput [multiple]=\"multiple\"> -->\n<app-btn icon=\"upload\" (mclick)=\"openDialog()\" [type]=\"file?'primary':'secondary'\"\n [disabled]=\"disabled\" [help]=\"help\" [text]=\"label\">\n\n</app-btn>", styles: [".meta,.file-name{height:23px}.meta{overflow-y:auto}.file-name{overflow:auto}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "disabled", "form", "forms", "help", "iconBtn", "loading", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid"], outputs: ["mclick"] }] }); }
|
|
64
|
+
}
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: FileUploadComponent, decorators: [{
|
|
66
|
+
type: Component,
|
|
67
|
+
args: [{ selector: 'app-file-upload', standalone: true, imports: [NgIf, NgClass, NgFor, BtnComponent], template: "\n@if (listFiles()) {\n<div [ngClass]=\"{meta:mini()}\" class=\"{{class()}} form-label mb-2 hide-scroll\">\n @for (item of files; track item;) {\n <div class=\"row align-items-start mb-1\">\n <div class=\"col\">\n <div class=\"hide-scroll file-name\">\n {{item?.name}}\n </div>\n </div>\n <div class=\"col-auto text-end\">\n <span class=\"text-danger pointer p-1 fa fa-close\" (click)=\"removeFile($index);\"></span>\n </div>\n </div>\n}\n</div>\n}\n<!-- <input type=\"file\" style=\"display: none;\" accept=\"{{accept}}\" (change)=\"onUpload($event)\" #uploadInput [multiple]=\"multiple\"> -->\n<app-btn icon=\"upload\" (mclick)=\"openDialog()\" [type]=\"file?'primary':'secondary'\"\n [disabled]=\"disabled\" [help]=\"help\" [text]=\"label\">\n\n</app-btn>", styles: [".meta,.file-name{height:23px}.meta{overflow-y:auto}.file-name{overflow:auto}\n"] }]
|
|
68
|
+
}], ctorParameters: () => [], propDecorators: { help: [{
|
|
69
|
+
type: Input
|
|
70
|
+
}], label: [{
|
|
71
|
+
type: Input
|
|
72
|
+
}], disabled: [{
|
|
73
|
+
type: Input
|
|
74
|
+
}], multiple: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}], useDocumentModal: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], _accept: [{
|
|
79
|
+
type: Input,
|
|
80
|
+
args: ['accept']
|
|
81
|
+
}], file: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], fileChange: [{
|
|
84
|
+
type: Output
|
|
85
|
+
}], files: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], filesChange: [{
|
|
88
|
+
type: Output
|
|
89
|
+
}] } });
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXRzLWZlLW5nLXNkay9zcmMvbGliL1NoYXJlZC9jb21wb25lbnRzL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V0cy1mZS1uZy1zZGsvc3JjL2xpYi9TaGFyZWQvY29tcG9uZW50cy9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFhLE1BQU0sRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFHN0gsT0FBTyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFTbkUsTUFBTSxPQUFPLG1CQUFtQjtJQVU5QixJQUFxQixPQUFPLENBQUMsQ0FBUztRQUNwQyxRQUFRLENBQUMsRUFBRTtZQUNULEtBQUssT0FBTztnQkFDVixJQUFJLENBQUMsTUFBTSxHQUFHLHNCQUFzQixDQUFDO2dCQUNyQyxNQUFNO1lBRVI7Z0JBQ0UsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7Z0JBQ2hCLE1BQU07U0FDVDtJQUNILENBQUM7SUFTRDtRQTFCQSxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFHeEIsU0FBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUVuQixjQUFTLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBZWQsZUFBVSxHQUFHLElBQUks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c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBWaWV3Q2hpbGQsIGluamVjdCwgaW5wdXQsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgSURvY01ldGFkYXRhLCBJRmlsZV9NZXRhZGF0YSB9IGZyb20gJy4uLy4uL21vZGVscy9pbmRleC5tb2RlbCc7XG5pbXBvcnQgeyBOZ0lmLCBOZ0NsYXNzLCBOZ0ZvciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBCdG5Db21wb25lbnQgfSBmcm9tICcuLi9idG4vYnRuLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBVdGlsaXR5U2VydmljZSB9IGZyb20gJy4uLy4uLy4uL1NlcnZpY2VzL3V0aWxpdHkuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1maWxlLXVwbG9hZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWxlLXVwbG9hZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2ZpbGUtdXBsb2FkLmNvbXBvbmVudC5zY3NzJ10sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0lmLCBOZ0NsYXNzLCBOZ0ZvciwgQnRuQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIGhlbHA6IHN0cmluZztcbiAgQElucHV0KCkgbGFiZWw6IHN0cmluZztcbiAgY2xhc3MgPSBpbnB1dDxzdHJpbmc+KCk7XG4gIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuO1xuICBASW5wdXQoKSBtdWx0aXBsZTogYm9vbGVhbjtcbiAgbWluaSA9IGlucHV0KHRydWUpO1xuICBASW5wdXQoKSB1c2VEb2N1bWVudE1vZGFsOiBib29sZWFuO1xuICBsaXN0RmlsZXMgPSBpbnB1dCh0cnVlKTtcbiAgYWNjZXB0OiBzdHJpbmc7XG4gIEBJbnB1dCgnYWNjZXB0Jykgc2V0IF9hY2NlcHQodjogc3RyaW5nKSB7XG4gICAgc3dpdGNoICh2KSB7XG4gICAgICBjYXNlICdpbWFnZSc6XG4gICAgICAgIHRoaXMuYWNjZXB0ID0gJy5wbmcsLmpwZywuZG9jeCwucGRmJztcbiAgICAgICAgYnJlYWs7XG5cbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHRoaXMuYWNjZXB0ID0gdjtcbiAgICAgICAgYnJlYWs7XG4gICAgfVxuICB9XG4gIC8vIEBWaWV3Q2hpbGQoJ3VwbG9hZElucHV0JykgdXBsb2FkSW5wdXRSZWY6IEVsZW1lbnRSZWY8SFRNTElucHV0RWxlbWVudD47XG4gIEBJbnB1dCgpIGZpbGU6IEZpbGU7XG4gIEBPdXRwdXQoKSBmaWxlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxGaWxlPigpO1xuICBASW5wdXQoKSBmaWxlczogRmlsZVtdO1xuICBAT3V0cHV0KCkgZmlsZXNDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPEZpbGVbXT4oKTtcblxuICBwdWJsaWMgdVMgPSBpbmplY3QoVXRpbGl0eVNlcnZpY2UpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHt9XG5cbiAgZ2V0IGlzU2luZ2xlKCkge1xuICAgIHJldHVybiAhdGhpcy5tdWx0aXBsZTtcbiAgfVxuICBwcml2YXRlIGFjY2VwdEZpbGVzKC4uLmZpbGVzOiBGaWxlW10pIHtcbiAgICB0aGlzLmZpbGVzID0gZmlsZXM7XG4gICAgdGhpcy5maWxlID0gZmlsZXMgPyBmaWxlc1swXSA6IG51bGw7XG4gIH1cbiAgcHJpdmF0ZSBlbWl0RmlsZXMoKSB7XG4gICAgaWYgKHRoaXMubXVsdGlwbGUpIHRoaXMuZmlsZXNDaGFuZ2UuZW1pdCh0aGlzLmZpbGVzKTtcbiAgICBlbHNlIHRoaXMuZmlsZUNoYW5nZS5lbWl0KHRoaXMuZmlsZSk7XG4gIH1cblxuICBvblVwbG9hZChldmVudDogYW55KSB7XG4gICAgY29uc3QgZmlsZXMgPSBBcnJheS5mcm9tPEZpbGU+KGV2ZW50LnRhcmdldC5maWxlcyk7XG4gICAgdGhpcy5hY2NlcHRGaWxlcyguLi5maWxlcyk7XG4gICAgdGhpcy5lbWl0RmlsZXMoKTtcbiAgfVxuXG4gIHJlbW92ZUZpbGUoaW5kZXg6IG51bWJlcikge1xuICAgIHRoaXMuZmlsZXMuc3BsaWNlKGluZGV4LCAxKTtcbiAgICB0aGlzLmZpbGUgPSB0aGlzLmZpbGVzID8gdGhpcy5maWxlc1swXSA6IG51bGw7XG5cbiAgICB0aGlzLmZpbGVDaGFuZ2UuZW1pdCh0aGlzLmZpbGUpO1xuICAgIHRoaXMuZmlsZXNDaGFuZ2UuZW1pdCh0aGlzLmZpbGVzKTtcbiAgfVxuICBvcGVuRGlhbG9nKCkge1xuICAgIGNvbnN0IGlucCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2lucHV0Jyk7XG4gICAgaW5wLnR5cGUgPSAnZmlsZSc7XG4gICAgaW5wLmFjY2VwdCA9IHRoaXMuYWNjZXB0O1xuICAgIGlucC5tdWx0aXBsZSA9IHRoaXMubXVsdGlwbGU7XG4gICAgaW5wLm9uY2hhbmdlID0gKGUpID0+IHtcbiAgICAgIHRoaXMub25VcGxvYWQoZSk7XG4gICAgICBpbnAucmVtb3ZlKCk7XG4gICAgfTtcbiAgICAvLyBkb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKGlucCk7XG4gICAgaW5wLmNsaWNrKCk7XG4gIH1cbn1cbiIsIlxuQGlmIChsaXN0RmlsZXMoKSkge1xuPGRpdiBbbmdDbGFzc109XCJ7bWV0YTptaW5pKCl9XCIgY2xhc3M9XCJ7e2NsYXNzKCl9fSBmb3JtLWxhYmVsIG1iLTIgaGlkZS1zY3JvbGxcIj5cbiAgQGZvciAoaXRlbSBvZiBmaWxlczsgdHJhY2sgaXRlbTspIHtcbiAgPGRpdiBjbGFzcz1cInJvdyBhbGlnbi1pdGVtcy1zdGFydCBtYi0xXCI+XG4gICAgPGRpdiBjbGFzcz1cImNvbFwiPlxuICAgICAgPGRpdiBjbGFzcz1cImhpZGUtc2Nyb2xsIGZpbGUtbmFtZVwiPlxuICAgICAgICB7e2l0ZW0/Lm5hbWV9fVxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImNvbC1hdXRvIHRleHQtZW5kXCI+XG4gICAgICA8c3BhbiBjbGFzcz1cInRleHQtZGFuZ2VyIHBvaW50ZXIgcC0xIGZhIGZhLWNsb3NlXCIgKGNsaWNrKT1cInJlbW92ZUZpbGUoJGluZGV4KTtcIj48L3NwYW4+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxufVxuPC9kaXY+XG59XG48IS0tIDxpbnB1dCB0eXBlPVwiZmlsZVwiICBzdHlsZT1cImRpc3BsYXk6IG5vbmU7XCIgYWNjZXB0PVwie3thY2NlcHR9fVwiIChjaGFuZ2UpPVwib25VcGxvYWQoJGV2ZW50KVwiICN1cGxvYWRJbnB1dCBbbXVsdGlwbGVdPVwibXVsdGlwbGVcIj4gLS0+XG48YXBwLWJ0biBpY29uPVwidXBsb2FkXCIgKG1jbGljayk9XCJvcGVuRGlhbG9nKClcIiBbdHlwZV09XCJmaWxlPydwcmltYXJ5Jzonc2Vjb25kYXJ5J1wiXG4gIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIFtoZWxwXT1cImhlbHBcIiBbdGV4dF09XCJsYWJlbFwiPlxuXG48L2FwcC1idG4+Il19
|
|
@@ -26,8 +26,6 @@ import * as i0 from "@angular/core";
|
|
|
26
26
|
export class TableInputComponent extends FormGeneratorComponent {
|
|
27
27
|
constructor() {
|
|
28
28
|
super(...arguments);
|
|
29
|
-
// @Input() pageType
|
|
30
|
-
this.formArray = input();
|
|
31
29
|
this.filterContainerClass = input();
|
|
32
30
|
this.border = input(true);
|
|
33
31
|
this.isShow = input();
|
|
@@ -40,15 +38,22 @@ export class TableInputComponent extends FormGeneratorComponent {
|
|
|
40
38
|
this.usePaginator = signal(true);
|
|
41
39
|
this.childrenFormSchemaMap = {};
|
|
42
40
|
this.filterFormValueSignal = toSignal(this.filterForm.valueChanges);
|
|
41
|
+
this.formArrayLengthSignal = signal(undefined);
|
|
43
42
|
this.filteredFormArray = computed(() => {
|
|
44
|
-
|
|
43
|
+
this.formArrayLengthSignal();
|
|
44
|
+
const formArray = this.formArray, filterFormValue = this.filterFormValueSignal();
|
|
45
45
|
const formGroups = formArray?.controls?.map((c, index) => ({ index, form: c }));
|
|
46
46
|
const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);
|
|
47
|
-
return
|
|
47
|
+
return filterObject
|
|
48
|
+
? formGroups.filter(({ form }) => this.filterFormArrayGroupPipe.filterFunc(filterObject)(form))
|
|
49
|
+
: formGroups;
|
|
48
50
|
});
|
|
49
51
|
this.paginatedAndFilteredFormArray = computed(() => {
|
|
50
52
|
const formArray = this.filteredFormArray(), pageState = this.pageState();
|
|
51
|
-
|
|
53
|
+
// debugger;
|
|
54
|
+
return this.usePaginator()
|
|
55
|
+
? this.paginatorPipe.transform(formArray, pageState?.pageSize || this.pageSize(), pageState?.pageIndex || 0)
|
|
56
|
+
: formArray;
|
|
52
57
|
});
|
|
53
58
|
this.filteredFormArrayLength = computed(() => this.filteredFormArray().length);
|
|
54
59
|
this.utilityService = inject(UtilityService);
|
|
@@ -75,6 +80,14 @@ export class TableInputComponent extends FormGeneratorComponent {
|
|
|
75
80
|
console.log(this.singleFormStructure);
|
|
76
81
|
};
|
|
77
82
|
}
|
|
83
|
+
// @Input() pageType
|
|
84
|
+
set _formArray(v) {
|
|
85
|
+
this.formArray = v;
|
|
86
|
+
if (v)
|
|
87
|
+
v.valueChanges.subscribe((r) => {
|
|
88
|
+
this.formArrayLengthSignal.set(v?.length);
|
|
89
|
+
});
|
|
90
|
+
}
|
|
78
91
|
set _pageSize(v) {
|
|
79
92
|
this.pageSize.set(v);
|
|
80
93
|
}
|
|
@@ -156,10 +169,12 @@ export class TableInputComponent extends FormGeneratorComponent {
|
|
|
156
169
|
formSchemaStr: scheme.children.map((x) => x.field),
|
|
157
170
|
};
|
|
158
171
|
}
|
|
159
|
-
scheme.isRequired =
|
|
172
|
+
scheme.isRequired =
|
|
173
|
+
scheme.isRequired ||
|
|
174
|
+
this.singleFormStructure?.controls[scheme.field]?.hasValidator(Validators.required);
|
|
160
175
|
}
|
|
161
176
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: TableInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
162
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: {
|
|
177
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.0", type: TableInputComponent, isStandalone: true, selector: "table-input", inputs: { _formArray: { classPropertyName: "_formArray", publicName: "formArray", isSignal: false, isRequired: false, transformFunction: null }, filterContainerClass: { classPropertyName: "filterContainerClass", publicName: "filterContainerClass", isSignal: true, isRequired: false, transformFunction: null }, border: { classPropertyName: "border", publicName: "border", isSignal: true, isRequired: false, transformFunction: null }, isShow: { classPropertyName: "isShow", publicName: "isShow", isSignal: true, isRequired: false, transformFunction: null }, _pageSize: { classPropertyName: "_pageSize", publicName: "pageSize", isSignal: false, isRequired: false, transformFunction: null }, actionBtns: { classPropertyName: "actionBtns", publicName: "actionBtns", isSignal: true, isRequired: false, transformFunction: null }, _formSchema: { classPropertyName: "_formSchema", publicName: "formSchema", isSignal: false, isRequired: true, transformFunction: null }, singleFormStructure: { classPropertyName: "singleFormStructure", publicName: "singleFormStructure", isSignal: false, isRequired: true, transformFunction: null }, deleteRowFunc: { classPropertyName: "deleteRowFunc", publicName: "deleteRowFunc", isSignal: false, isRequired: false, transformFunction: null }, addRowFunc: { classPropertyName: "addRowFunc", publicName: "addRowFunc", isSignal: false, isRequired: false, transformFunction: null }, _usePaginator: { classPropertyName: "_usePaginator", publicName: "usePaginator", isSignal: false, isRequired: false, transformFunction: null }, tableClass: { classPropertyName: "tableClass", publicName: "tableClass", isSignal: true, isRequired: false, transformFunction: null } }, providers: [FilterFormArrayGroupPipe, PaginatorPipe], viewQueries: [{ propertyName: "paginatorComponent", first: true, predicate: PaginatorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "disabled", "form", "forms", "help", "iconBtn", "loading", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid"], outputs: ["mclick"] }, { kind: "component", type: FormGeneratorComponent, selector: "form-generator", inputs: ["keyField", "submitFunc", "submitBtnText", "submitBtnTemplate", "submitSuccessText", "showSubmitBtn", "gridStyle", "gridMDStyle", "gridLGStyle", "gridXXLStyle", "formGridClass", "useLoader", "loading", "form", "formSchema", "isShow"], outputs: ["onSubmit", "mchange", "submissionResponse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatExpansionModule }, { kind: "ngmodule", type: MatTabsModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PaginatorComponent, selector: "paginator", inputs: ["pageSize", "pageIndex", "arrayLength", "resetIndexFunc", "pageSizeOptions"], outputs: ["pageChanged"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: TableInputRowComponent, selector: "tr[table-input-row]", inputs: ["isShow", "hideAdd", "actionBtns", "childrenFormSchemaMap"], outputs: ["onDeleteRowFunc", "onAddRowFunc", "onActionButtonClick"] }, { kind: "pipe", type: TranslatePipe, name: "appTranslate" }] }); }
|
|
163
178
|
}
|
|
164
179
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: TableInputComponent, decorators: [{
|
|
165
180
|
type: Component,
|
|
@@ -195,8 +210,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
195
210
|
TranslatePipe,
|
|
196
211
|
FilterFormArrayGroupPipe,
|
|
197
212
|
ValidationMessageComponent,
|
|
198
|
-
], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
|
|
199
|
-
}], propDecorators: {
|
|
213
|
+
], providers: [FilterFormArrayGroupPipe, PaginatorPipe], template: "<div class=\"table-input\">\n @if (filterForms()?.length) {\n <div class=\"mb-3 {{ filterContainerClass() }}\">\n <div class=\"d-flex\">\n <app-btn\n text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n </div>\n <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n <div class=\"d-flex justify-content-end\">\n <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n </div>\n </div>\n </div>\n }\n\n <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n <div class=\" \">\n <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n <tr class=\"text-center\">\n @for (item of formSchema(); track item.label) {\n <th class=\"{{ item.cls }}\">\n {{ item.label | appTranslate | async }}\n {{ item.isRequired ? '*' : '' }}\n </th>\n }\n @if (!isShow()) {\n <th></th>\n <th></th>\n @for (actionBtn of actionBtns(); track actionBtn) {\n <th></th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n <tr\n table-input-row\n (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n [isShow]=\"isShow()\"\n [form]=\"subForm.form\"\n [actionBtns]=\"actionBtns()\"\n [formSchema]=\"formSchema()\"\n [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n (onDeleteRowFunc)=\"\n deleteRowClicked(subForm.index, subForm.form, {\n btn: $event?.btn\n })\n \"\n (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n } @empty {\n <tr>\n <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n {{ 'There are no items' | appTranslate | async }}\n </td>\n </tr>\n }\n </tbody>\n </table>\n </div>\n\n <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n <paginator\n #paginatorTag\n [arrayLength]=\"filteredFormArrayLength()\"\n (pageChanged)=\"pageChanged($event)\"\n [pageSize]=\"pageSize()\"\n [resetIndexFunc]=\"filterForm.valueChanges\" />\n </div>\n </div>\n</div>\n", styles: ["tr{vertical-align:top}:host ::ng-deep .text-center input{text-align:center}\n"] }]
|
|
214
|
+
}], propDecorators: { _formArray: [{
|
|
215
|
+
type: Input,
|
|
216
|
+
args: ['formArray']
|
|
217
|
+
}], _pageSize: [{
|
|
200
218
|
type: Input,
|
|
201
219
|
args: ['pageSize']
|
|
202
220
|
}], _formSchema: [{
|
|
@@ -216,4 +234,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
216
234
|
type: ViewChild,
|
|
217
235
|
args: [PaginatorComponent]
|
|
218
236
|
}] } });
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewChild, computed, inject, input, signal } from '@angular/core';\nimport { AbstractControl, FormArray, FormControl, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport { FilterFormArrayGroupPipe, FormValuePipe, FunctionCaller2, HasFormValuePipe, ToAnyPipe } from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { AsyncPipe, JsonPipe, NgClass, NgFor, NgIf, NgSwitch, NgSwitchCase, NgSwitchDefault } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    TranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  // @Input() pageType\n  formArray = input<FormArray<FormGroup<TFormGroup>>>();\n  filterContainerClass = input<string>();\n  border = input(true);\n  isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  pageSize = signal<number>(10);\n  pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(v: IFormSchema<TFormGroup>[]) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (index: number, data?: FormGroup<TFormGroup>['value'], config?: { btn: BtnComponent }) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize = undefined;\n    }\n  }\n\n  tableClass = input<'table table-responsive table-responsive table-borderless'>();\n  protected readonly filterForm = new FormGroup({});\n  protected filterForms = signal<IFormSchema[]>([]);\n  protected usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n\n  filteredFormArray = computed<{ form: FormGroup<TFormGroup>; index: number }[]>(() => {\n    const formArray = this.formArray(),\n      filterFormValue = this.filterForm.getRawValue();\n    const formGroups = formArray?.controls?.map((c, index) => ({ index, form: c }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return formGroups.filter(({ form }) => this.filterFormArrayGroupPipe.filterFunc(filterObject)(form));\n  });\n  paginatedAndFilteredFormArray = computed<{ form: FormGroup<TFormGroup>; index: number }[]>(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    return this.usePaginator() ? this.paginatorPipe.transform(formArray, pageState.pageSize, pageState.pageIndex) : formArray;\n  });\n\n  filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(index: number, form: FormGroup<TFormGroup>, e: { btn?: BtnComponent; actionButton: ITableInputBtn }) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (index: number, rowForm: FormGroup<TFormGroup>, config?: { btn: BtnComponent }) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField)) scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired = scheme.isRequired || (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(Validators.required);\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/table-input/table-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewChild, computed, inject, input, signal } from '@angular/core';\nimport { AbstractControl, FormArray, FormControl, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\nimport { IFormSchema } from '../../models/form-schema.model';\nimport { FilterFormArrayGroupPipe, FormValuePipe, FunctionCaller2, HasFormValuePipe, ToAnyPipe } from '../../pipes/utility.pipe';\n\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { AsyncPipe, JsonPipe, NgClass, NgFor, NgIf, NgSwitch, NgSwitchCase, NgSwitchDefault } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { FormGeneratorComponent } from '../form-generator/form-generator.component';\n\nimport { PaginatorComponent } from '../paginator/paginator.component';\nimport { ModalComponent } from '../modal/modal.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { TableInputRowComponent } from './table-input-row/table-input-row.component';\nimport { Subscription, filter } from 'rxjs';\nimport { IBtn } from '../btn/btn.model';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { PaginatorPipe } from '../../pipes/paginator.pipe';\nimport { toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Table Input Component\n */\n@Component({\n  selector: 'table-input',\n  standalone: true,\n  imports: [\n    AsyncPipe,\n    AutocompleteComponent,\n    BtnComponent,\n    FilterFormArrayGroupPipe,\n    FormGeneratorComponent,\n    FormsModule,\n    FormValuePipe,\n    FunctionCaller2,\n    HasFormValuePipe,\n    InputBasicComponent,\n    JsonPipe,\n    LoaderComponent,\n    MatExpansionModule,\n    MatTabsModule,\n    MatTooltipModule,\n    ModalComponent,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    PaginatorComponent,\n    PaginatorPipe,\n    PhoneNumberComponent,\n    ReactiveFormsModule,\n    TableInputRowComponent,\n    ToAnyPipe,\n    TranslatePipe,\n    FilterFormArrayGroupPipe,\n    ValidationMessageComponent,\n  ],\n  templateUrl: './table-input.component.html',\n  styleUrls: ['./table-input.component.scss'],\n  providers: [FilterFormArrayGroupPipe, PaginatorPipe],\n})\nexport class TableInputComponent<\n    TFormGroup extends {\n      [K in keyof TFormGroup]: AbstractControl<any, any>;\n    } = any,\n  >\n  extends FormGeneratorComponent<TFormGroup>\n  implements OnInit\n{\n  formArray: FormArray<FormGroup<TFormGroup>>;\n  // @Input() pageType\n  @Input('formArray') set _formArray(v: FormArray<FormGroup<TFormGroup>>) {\n    this.formArray = v;\n    if (v)\n      v.valueChanges.subscribe((r) => {\n        this.formArrayLengthSignal.set(v?.length);\n      });\n  }\n  filterContainerClass = input<string>();\n  border = input(true);\n  isShow = input<boolean>();\n  @Input('pageSize') set _pageSize(v: number) {\n    this.pageSize.set(v);\n  }\n  pageSize = signal<number>(10);\n  pageState = signal<{ pageIndex: number; pageSize: number }>(null);\n  actionBtns = input<ITableInputBtn[]>();\n  @Input({ required: true, alias: 'formSchema' }) override set _formSchema(v: IFormSchema<TFormGroup>[]) {\n    this.preFormatFormSchema(v);\n    super._formSchema = v;\n  }\n  @Input({ required: true })\n  singleFormStructure: FormGroup<TFormGroup>;\n  /**\n   * Leave empty if you don't want the delete button to show\n   */\n  @Input() deleteRowFunc: (\n    index: number,\n    data?: FormGroup<TFormGroup>['value'],\n    config?: { btn: BtnComponent },\n  ) => any;\n  /**\n   * Leave empty if you don't want the add button to show\n   */\n  @Input() addRowFunc: (index: number, data?: FormGroup<TFormGroup>['value']) => any;\n  @Input('usePaginator') set _usePaginator(v: boolean) {\n    if (v) {\n      this.usePaginator.set(true);\n      this.pageSize.update((pageSize) => pageSize || 10);\n    } else {\n      this.usePaginator.set(false);\n      this.pageSize = undefined;\n    }\n  }\n\n  tableClass = input<'table table-responsive table-responsive table-borderless'>();\n  protected readonly filterForm = new FormGroup({});\n  protected filterForms = signal<IFormSchema[]>([]);\n  protected usePaginator = signal<boolean>(true);\n  protected childrenFormSchemaMap: {\n    [k in keyof TFormGroup]?: {\n      formSchema: IFormSchema[];\n      formSchemaStr: string[];\n    };\n  } = {};\n  refresher: number;\n  formArrayPaginationSub: Subscription;\n\n  @ViewChild(PaginatorComponent) paginatorComponent: PaginatorComponent;\n\n  filterFormValueSignal = toSignal(this.filterForm.valueChanges);\n  formArrayLengthSignal = signal<number>(undefined);\n\n  filteredFormArray = computed<{ form: FormGroup<TFormGroup>; index: number }[]>(() => {\n    this.formArrayLengthSignal();\n    const formArray = this.formArray,\n      filterFormValue = this.filterFormValueSignal();\n    const formGroups = formArray?.controls?.map((c, index) => ({ index, form: c }));\n    const filterObject = this.filterFormArrayGroupPipe.queryMapper(filterFormValue);\n    return filterObject\n      ? formGroups.filter(({ form }) => this.filterFormArrayGroupPipe.filterFunc(filterObject)(form))\n      : formGroups;\n  });\n  paginatedAndFilteredFormArray = computed<{ form: FormGroup<TFormGroup>; index: number }[]>(() => {\n    const formArray = this.filteredFormArray(),\n      pageState = this.pageState();\n    // debugger;\n    return this.usePaginator()\n      ? this.paginatorPipe.transform(\n          formArray,\n          pageState?.pageSize || this.pageSize(),\n          pageState?.pageIndex || 0,\n        )\n      : formArray;\n  });\n\n  filteredFormArrayLength = computed(() => this.filteredFormArray().length);\n\n  public override utilityService = inject(UtilityService);\n  public filterFormArrayGroupPipe = inject(FilterFormArrayGroupPipe);\n  public paginatorPipe = inject(PaginatorPipe);\n\n  ngOnInit(): void {\n    if (this.usePaginator == undefined) {\n      this._usePaginator = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.refresh();\n    }, 1000);\n  }\n\n  refresh() {\n    this.refresher = Math.random();\n  }\n\n  override onDestroy() {\n    this.formArrayPaginationSub?.unsubscribe();\n    return super.onDestroy();\n  }\n\n  pageChanged($event: { pageIndex: number; pageSize: number }) {\n    this.pageState.set($event);\n  }\n\n  resetPaginator() {\n    this.paginatorComponent?.reset();\n  }\n\n  protected preFormatFormSchema = (items: IFormSchema<TFormGroup>[]) => {\n    items.forEach((x) => {\n      if (x.onChangeFunc) x.triggerOnChangeOnInit = true;\n      else if (x.type == 'button') this.preFormatFormSchema(x.children);\n    });\n  };\n\n  override init(schema: IFormSchema<TFormGroup>[]): void {\n    this.filterForms.set([]);\n    for (const key in this.filterForm.controls) {\n      if (Object.prototype.hasOwnProperty.call(this.filterForm.controls, key)) {\n        this.filterForm.removeControl(key);\n      }\n    }\n    // debugger;\n    this.onDestroy();\n    if (schema)\n      for (const scheme of schema) {\n        // scheme.form = this.form || scheme.form;\n        this.handleFormScheme(scheme);\n      }\n    this._setFormSchemas(schema);\n  }\n\n  handleActionButtonClick(\n    index: number,\n    form: FormGroup<TFormGroup>,\n    e: { btn?: BtnComponent; actionButton: ITableInputBtn },\n  ) {\n    e.actionButton.action({ index, form, btn: e.btn });\n    // this.refresh();\n  }\n\n  deleteRowClicked = (index: number, rowForm: FormGroup<TFormGroup>, config?: { btn: BtnComponent }) => {\n    this.deleteRowFunc(index, rowForm?.getRawValue(), config);\n    // this.refresh();\n  };\n\n  addRowClicked = (index: number) => {\n    this.addRowFunc(index + 1, this.filterFormValueSignal());\n    // this.refresh();\n    // this.filterForm.updateValueAndValidity();\n  };\n\n  checkRequiredFields = () => {\n    console.log(this.singleFormStructure);\n  };\n\n  override handleFormScheme(scheme: IFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n      scheme.autoPickValueField = true;\n\n    if (scheme.optionsInitFunc) {\n      scheme.optionsInitFunc.subscribe((r) => {\n        scheme.options = r;\n        // this.optionsMap[scheme.field] = r;\n      });\n    }\n    if (scheme.isSearchField) {\n      this.filterForms.update((filterForms) => filterForms.concat([scheme]));\n      this.filterForm.addControl(scheme.field?.toString(), new FormControl());\n    } else if (scheme.type == 'button') {\n      if (scheme.children?.length)\n        this.childrenFormSchemaMap[scheme.field as string] = {\n          formSchema: scheme.children,\n          formSchemaStr: scheme.children.map((x) => x.field as string),\n        };\n    }\n    scheme.isRequired =\n      scheme.isRequired ||\n      (<FormGroup>this.singleFormStructure?.controls[scheme.field])?.hasValidator(Validators.required);\n  }\n}\n\nexport interface ITableInputBtn extends IBtn {\n  action?: (arg?: { index: number; form: FormGroup; btn: BtnComponent }) => void;\n}\n","<div class=\"table-input\">\n  @if (filterForms()?.length) {\n    <div class=\"mb-3 {{ filterContainerClass() }}\">\n      <div class=\"d-flex\">\n        <app-btn\n          text=\"{{ filterSection.hidden ? 'Show Filter' : 'Hide Filter' }}\"\n          [icon]=\"filterSection.hidden ? 'search' : 'close'\"\n          (mclick)=\"filterSection.hidden = !filterSection.hidden\" />\n      </div>\n      <div class=\"border p-3 mt-3 rounded-10\" #filterSection [hidden]=\"true\">\n        <form-generator [form]=\"filterForm\" [formSchema]=\"filterForms()\" [gridLGStyle]=\"3\" [showSubmitBtn]=\"false\" (mchange)=\"resetPaginator()\" />\n        <div class=\"d-flex justify-content-end\">\n          <app-btn type=\"danger-outline\" text=\"Clear\" (mclick)=\"filterForm.reset()\" />\n        </div>\n      </div>\n    </div>\n  }\n\n  <div class=\"bg-white\" [ngClass]=\"{ 'border rounded-10': border() }\">\n    <div class=\" \">\n      <table class=\" {{ tableClass() }} \" [ngClass]=\"{ 'is-show-form': isShow() }\">\n        <thead (click)=\"utilityService.logForm(filteredFormArray())\">\n          <tr class=\"text-center\">\n            @for (item of formSchema(); track item.label) {\n              <th class=\"{{ item.cls }}\">\n                {{ item.label | appTranslate | async }}\n                {{ item.isRequired ? '*' : '' }}\n              </th>\n            }\n            @if (!isShow()) {\n              <th></th>\n              <th></th>\n              @for (actionBtn of actionBtns(); track actionBtn) {\n                <th></th>\n              }\n            }\n          </tr>\n        </thead>\n        <tbody>\n          @for (subForm of paginatedAndFilteredFormArray(); track subForm; let i = $index) {\n            <tr\n              table-input-row\n              (onAddRowFunc)=\"addRowClicked(subForm.index)\"\n              [isShow]=\"isShow()\"\n              [form]=\"subForm.form\"\n              [actionBtns]=\"actionBtns()\"\n              [formSchema]=\"formSchema()\"\n              [childrenFormSchemaMap]=\"childrenFormSchemaMap\"\n              (onDeleteRowFunc)=\"\n                deleteRowClicked(subForm.index, subForm.form, {\n                  btn: $event?.btn\n                })\n              \"\n              (onActionButtonClick)=\"handleActionButtonClick(subForm.index, subForm.form, $event)\"></tr>\n          } @empty {\n            <tr>\n              <td class=\"text-center\" [colSpan]=\"formSchema()?.length\">\n                {{ 'There are no items' | appTranslate | async }}\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    </div>\n\n    <div class=\"\" [hidden]=\"!usePaginator() || !filteredFormArrayLength() || filteredFormArrayLength() < pageSize()\">\n      <paginator\n        #paginatorTag\n        [arrayLength]=\"filteredFormArrayLength()\"\n        (pageChanged)=\"pageChanged($event)\"\n        [pageSize]=\"pageSize()\"\n        [resetIndexFunc]=\"filterForm.valueChanges\" />\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA as MAT_DIALOG_DATA, } from '@angular/material/dialog';
|
|
3
|
+
import { clone } from 'lodash-es';
|
|
4
|
+
import { TranslatePipe } from '../../../Shared/pipes/translate.pipe';
|
|
5
|
+
import { CommonModule } from '@angular/common';
|
|
6
|
+
import { FormsModule } from '@angular/forms';
|
|
7
|
+
import { ModalHeaderComponent } from "../../../Shared/components/modal-header/modal-header.component";
|
|
8
|
+
import { BtnComponent } from '../btn/btn.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/material/dialog";
|
|
11
|
+
import * as i2 from "@angular/forms";
|
|
12
|
+
import * as i3 from "@angular/common";
|
|
13
|
+
export class TextAreaModalComponent {
|
|
14
|
+
constructor(dialogRef, data) {
|
|
15
|
+
this.dialogRef = dialogRef;
|
|
16
|
+
this.data = data;
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
this._data = clone(this.data);
|
|
20
|
+
}
|
|
21
|
+
close() {
|
|
22
|
+
this.dialogRef.close(this.data);
|
|
23
|
+
}
|
|
24
|
+
save() {
|
|
25
|
+
this.dialogRef.close(this._data);
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: TextAreaModalComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.0", type: TextAreaModalComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<modal-header [header]=\"_data?.label\" [dialogRef]=\"dialogRef\" [onCloseValue]=\"data\" />\n<div class=\"mt-4\">\n @if (!data.isShow) {\n <textarea class=\"control-bg-gray p-1\" [(ngModel)]=\"_data.value\"></textarea>\n }\n @if (data.isShow) {\n <div class=\" \" [innerHTML]=\"_data.value\"></div>\n }\n</div>\n<div class=\"row row-cols-auto justify-content-between align-items-center mt-4\">\n <div class=\"\">\n @if (data.showLength) {\n <span>{{ 'Characters: ' + (_data.value?.length || 0) | appTranslate | async }}</span>\n }\n </div>\n <div class=\"d-flex justify-content-end\">\n @if (!data.isShow) {\n <app-btn text=\"Save\" (mclick)=\"save()\" type=\"secondary\" icon=\"save\"></app-btn>\n }\n </div>\n</div>\n", styles: ["textarea{height:calc(80vh - 150px);width:100%}\n"], dependencies: [{ kind: "component", type: BtnComponent, selector: "app-btn", inputs: ["formSchema", "debug", "centerBtn", "danger", "warning", "icon", "rightIcon", "leftIcon", "type", "group", "actionType", "animate", "excludeLogging", "loggingValue", "badge", "class", "customIcon", "disabled", "form", "forms", "help", "iconBtn", "loading", "mclass", "showHelpIcon", "rightCustomIcon", "leftCustomIcon", "text", "valid", "mini", "onFormInvalid"], outputs: ["mclick"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: TranslatePipe, name: "appTranslate" }, { kind: "component", type: ModalHeaderComponent, selector: "modal-header", inputs: ["dialogRef", "header", "onCloseValue"] }] }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: TextAreaModalComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ standalone: true, imports: [BtnComponent, FormsModule, CommonModule, TranslatePipe, ModalHeaderComponent], template: "<modal-header [header]=\"_data?.label\" [dialogRef]=\"dialogRef\" [onCloseValue]=\"data\" />\n<div class=\"mt-4\">\n @if (!data.isShow) {\n <textarea class=\"control-bg-gray p-1\" [(ngModel)]=\"_data.value\"></textarea>\n }\n @if (data.isShow) {\n <div class=\" \" [innerHTML]=\"_data.value\"></div>\n }\n</div>\n<div class=\"row row-cols-auto justify-content-between align-items-center mt-4\">\n <div class=\"\">\n @if (data.showLength) {\n <span>{{ 'Characters: ' + (_data.value?.length || 0) | appTranslate | async }}</span>\n }\n </div>\n <div class=\"d-flex justify-content-end\">\n @if (!data.isShow) {\n <app-btn text=\"Save\" (mclick)=\"save()\" type=\"secondary\" icon=\"save\"></app-btn>\n }\n </div>\n</div>\n", styles: ["textarea{height:calc(80vh - 150px);width:100%}\n"] }]
|
|
33
|
+
}], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
34
|
+
type: Inject,
|
|
35
|
+
args: [MAT_DIALOG_DATA]
|
|
36
|
+
}] }] });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1hcmVhLW1vZGFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V0cy1mZS1uZy1zZGsvc3JjL2xpYi9TaGFyZWQvY29tcG9uZW50cy90ZXh0LWFyZWEtbW9kYWwvdGV4dC1hcmVhLW1vZGFsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V0cy1mZS1uZy1zZGsvc3JjL2xpYi9TaGFyZWQvY29tcG9uZW50cy90ZXh0LWFyZWEtbW9kYWwvdGV4dC1hcmVhLW1vZGFsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFFTCxlQUFlLElBQUksZUFBZSxHQUNuQyxNQUFNLDBCQUEwQixDQUFDO0FBQ2xDLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDbEMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0VBQWdFLENBQUM7QUFDdEcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7OztBQVFwRCxNQUFNLE9BQU8sc0JBQXNCO0lBRWpDLFlBQ1MsU0FBK0MsRUFFL0MsSUFLTjtRQVBNLGNBQVMsR0FBVCxTQUFTLENBQXNDO1FBRS9DLFNBQUksR0FBSixJQUFJLENBS1Y7SUFDQSxDQUFDO0lBRUosUUFBUTtRQUNOLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBQ0QsS0FBSztRQUNILElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBQ0QsSUFBSTtRQUNGLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDOzhHQXJCVSxzQkFBc0IsOENBSXZCLGVBQWU7a0dBSmQsc0JBQXNCLHdFQ2xCbkMsc3ZCQXFCQSwwR0RMYyxZQUFZLDRiQUFFLFdBQVcsOG1CQUFFLFlBQVksK0VBQUUsYUFBYSxxREFBRSxvQkFBb0I7OzJGQUU3RSxzQkFBc0I7a0JBTmxDLFNBQVM7aUNBR00sSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsYUFBYSxFQUFFLG9CQUFvQixDQUFDOzswQkFNdEYsTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgTWF0RGlhbG9nUmVmIGFzIE1hdERpYWxvZ1JlZixcbiAgTUFUX0RJQUxPR19EQVRBIGFzIE1BVF9ESUFMT0dfREFUQSxcbn0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IGNsb25lIH0gZnJvbSAnbG9kYXNoLWVzJztcbmltcG9ydCB7IFRyYW5zbGF0ZVBpcGUgfSBmcm9tICcuLi8uLi8uLi9TaGFyZWQvcGlwZXMvdHJhbnNsYXRlLnBpcGUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTW9kYWxIZWFkZXJDb21wb25lbnQgfSBmcm9tIFwiLi4vLi4vLi4vU2hhcmVkL2NvbXBvbmVudHMvbW9kYWwtaGVhZGVyL21vZGFsLWhlYWRlci5jb21wb25lbnRcIjtcbmltcG9ydCB7IEJ0bkNvbXBvbmVudCB9IGZyb20gJy4uL2J0bi9idG4uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICcuL3RleHQtYXJlYS1tb2RhbC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdGV4dC1hcmVhLW1vZGFsLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQnRuQ29tcG9uZW50LCBGb3Jtc01vZHVsZSwgQ29tbW9uTW9kdWxlLCBUcmFuc2xhdGVQaXBlLCBNb2RhbEhlYWRlckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgVGV4dEFyZWFNb2RhbENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIF9kYXRhOiB7IGxhYmVsOiBzdHJpbmc7IHZhbHVlOiBzdHJpbmcgfTtcbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPFRleHRBcmVhTW9kYWxDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKVxuICAgIHB1YmxpYyBkYXRhOiB7XG4gICAgICBzaG93TGVuZ3RoOiBib29sZWFuO1xuICAgICAgbGFiZWw6IHN0cmluZztcbiAgICAgIHZhbHVlOiBzdHJpbmc7XG4gICAgICBpc1Nob3c6IGJvb2xlYW47XG4gICAgfVxuICApIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fZGF0YSA9IGNsb25lKHRoaXMuZGF0YSk7XG4gIH1cbiAgY2xvc2UoKSB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UodGhpcy5kYXRhKTtcbiAgfVxuICBzYXZlKCkge1xuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKHRoaXMuX2RhdGEpO1xuICB9XG59XG4iLCI8bW9kYWwtaGVhZGVyIFtoZWFkZXJdPVwiX2RhdGE/LmxhYmVsXCIgW2RpYWxvZ1JlZl09XCJkaWFsb2dSZWZcIiBbb25DbG9zZVZhbHVlXT1cImRhdGFcIiAvPlxuPGRpdiBjbGFzcz1cIm10LTRcIj5cbiAgQGlmICghZGF0YS5pc1Nob3cpIHtcbiAgICA8dGV4dGFyZWEgY2xhc3M9XCJjb250cm9sLWJnLWdyYXkgcC0xXCIgWyhuZ01vZGVsKV09XCJfZGF0YS52YWx1ZVwiPjwvdGV4dGFyZWE+XG4gIH1cbiAgQGlmIChkYXRhLmlzU2hvdykge1xuICAgIDxkaXYgY2xhc3M9XCIgXCIgW2lubmVySFRNTF09XCJfZGF0YS52YWx1ZVwiPjwvZGl2PlxuICB9XG48L2Rpdj5cbjxkaXYgY2xhc3M9XCJyb3cgcm93LWNvbHMtYXV0byBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlbiBhbGlnbi1pdGVtcy1jZW50ZXIgbXQtNFwiPlxuICA8ZGl2IGNsYXNzPVwiXCI+XG4gICAgQGlmIChkYXRhLnNob3dMZW5ndGgpIHtcbiAgICAgIDxzcGFuPnt7ICdDaGFyYWN0ZXJzOiAnICsgKF9kYXRhLnZhbHVlPy5sZW5ndGggfHwgMCkgfCBhcHBUcmFuc2xhdGUgfCBhc3luYyB9fTwvc3Bhbj5cbiAgICB9XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1lbmRcIj5cbiAgICBAaWYgKCFkYXRhLmlzU2hvdykge1xuICAgICAgPGFwcC1idG4gdGV4dD1cIlNhdmVcIiAobWNsaWNrKT1cInNhdmUoKVwiIHR5cGU9XCJzZWNvbmRhcnlcIiBpY29uPVwic2F2ZVwiPjwvYXBwLWJ0bj5cbiAgICB9XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { TextAreaModalComponent } from './text-area-modal.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/material/dialog";
|
|
5
|
+
export class TextAreaModalService {
|
|
6
|
+
constructor(dialog) {
|
|
7
|
+
this.dialog = dialog;
|
|
8
|
+
this.openTextAreaModal = (label, value, isShow, showLength) => {
|
|
9
|
+
return this.dialog.open(TextAreaModalComponent, {
|
|
10
|
+
data: { label, value, isShow, showLength },
|
|
11
|
+
height: '80vh',
|
|
12
|
+
width: '90%',
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: TextAreaModalService, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
17
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: TextAreaModalService }); }
|
|
18
|
+
}
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: TextAreaModalService, decorators: [{
|
|
20
|
+
type: Injectable
|
|
21
|
+
}], ctorParameters: () => [{ type: i1.MatDialog }] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1hcmVhLW1vZGFsLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ldHMtZmUtbmctc2RrL3NyYy9saWIvU2hhcmVkL2NvbXBvbmVudHMvdGV4dC1hcmVhLW1vZGFsL3RleHQtYXJlYS1tb2RhbC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7OztBQUdyRSxNQUFNLE9BQU8sb0JBQW9CO0lBQy9CLFlBQW1CLE1BQWlCO1FBQWpCLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDcEMsc0JBQWlCLEdBQUcsQ0FBQyxLQUFhLEVBQUUsS0FBYSxFQUFFLE1BQWUsRUFBRSxVQUFtQixFQUFFLEVBQUU7WUFDekYsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsRUFBRTtnQkFDOUMsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFO2dCQUMxQyxNQUFNLEVBQUUsTUFBTTtnQkFDZCxLQUFLLEVBQUUsS0FBSzthQUNiLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQztJQVBxQyxDQUFDOzhHQUQ3QixvQkFBb0I7a0hBQXBCLG9CQUFvQjs7MkZBQXBCLG9CQUFvQjtrQkFEaEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdERpYWxvZyBhcyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgVGV4dEFyZWFNb2RhbENvbXBvbmVudCB9IGZyb20gJy4vdGV4dC1hcmVhLW1vZGFsLmNvbXBvbmVudCc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUZXh0QXJlYU1vZGFsU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZykge31cbiAgb3BlblRleHRBcmVhTW9kYWwgPSAobGFiZWw6IHN0cmluZywgdmFsdWU6IHN0cmluZywgaXNTaG93OiBib29sZWFuLCBzaG93TGVuZ3RoOiBib29sZWFuKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMuZGlhbG9nLm9wZW4oVGV4dEFyZWFNb2RhbENvbXBvbmVudCwge1xuICAgICAgZGF0YTogeyBsYWJlbCwgdmFsdWUsIGlzU2hvdywgc2hvd0xlbmd0aCB9LFxuICAgICAgaGVpZ2h0OiAnODB2aCcsXG4gICAgICB3aWR0aDogJzkwJScsXG4gICAgfSk7XG4gIH07XG59XG4iXX0=
|