@wemake4u/form-player-se 1.0.23 → 1.0.25

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.
Files changed (83) hide show
  1. package/esm2022/lib/components/actionsCellRenderer/actionsCellRenderer.component.mjs +69 -0
  2. package/esm2022/lib/components/deleteRowRenderer/deleteRowRenderer.component.mjs +25 -0
  3. package/esm2022/lib/components/hostCellRenderer/hostCellRenderer.component.mjs +101 -0
  4. package/esm2022/lib/components/objectURLRenderer/objectURLRenderer.component.mjs +27 -0
  5. package/esm2022/lib/components/setFilter/setFilter.component.mjs +111 -0
  6. package/esm2022/lib/dialog/dialog.component.mjs +15 -7
  7. package/esm2022/lib/directives/collapse.directive.mjs +20 -12
  8. package/esm2022/lib/directives/date.directive.mjs +2 -2
  9. package/esm2022/lib/directives/dialog.directive.mjs +2 -1
  10. package/esm2022/lib/directives/dropdown.directive.mjs +23 -5
  11. package/esm2022/lib/directives/formIndex.directive.mjs +25 -0
  12. package/esm2022/lib/directives/grid.directive.mjs +94 -17
  13. package/esm2022/lib/directives/readonly.directive.mjs +101 -0
  14. package/esm2022/lib/directives/updateblur.directive.mjs +10 -3
  15. package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +64 -26
  16. package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +96 -95
  17. package/esm2022/lib/dynamic-host/dynamic-host.component.mjs +121 -0
  18. package/esm2022/lib/locale/locale-de.mjs +3 -2
  19. package/esm2022/lib/locale/locale-en.mjs +3 -2
  20. package/esm2022/lib/locale/locale-es.mjs +3 -2
  21. package/esm2022/lib/locale/locale-fr.mjs +3 -2
  22. package/esm2022/lib/locale/locale-it.mjs +3 -2
  23. package/esm2022/lib/locale/locale-pt.mjs +3 -2
  24. package/esm2022/lib/services/chart.service.mjs +62 -56
  25. package/esm2022/lib/services/dialog.service.mjs +1 -1
  26. package/esm2022/lib/services/feel.service.mjs +186 -19
  27. package/esm2022/lib/services/form.service.mjs +360 -0
  28. package/esm2022/lib/services/formatter.service.mjs +68 -54
  29. package/esm2022/lib/services/function.service.mjs +9 -5
  30. package/esm2022/lib/services/global.service.mjs +42 -0
  31. package/esm2022/lib/services/grid.service.mjs +189 -53
  32. package/esm2022/lib/services/metadata.service.mjs +1 -8
  33. package/esm2022/lib/services/programmability.service.mjs +338 -64
  34. package/esm2022/lib/services/weak.service.mjs +3 -5
  35. package/esm2022/lib/utils/feelable.mjs +28 -0
  36. package/esm2022/lib/utils/groupByRow.mjs +3 -1
  37. package/esm2022/public-api.mjs +2 -1
  38. package/fesm2022/wemake4u-form-player-se.mjs +1896 -577
  39. package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
  40. package/lib/components/actionsCellRenderer/actionsCellRenderer.component.d.ts +18 -0
  41. package/lib/components/deleteRowRenderer/deleteRowRenderer.component.d.ts +49 -0
  42. package/lib/components/hostCellRenderer/hostCellRenderer.component.d.ts +29 -0
  43. package/lib/components/objectURLRenderer/objectURLRenderer.component.d.ts +50 -0
  44. package/lib/{utils/setFilter.d.ts → components/setFilter/setFilter.component.d.ts} +1 -0
  45. package/lib/dialog/dialog.component.d.ts +11 -0
  46. package/lib/directives/collapse.directive.d.ts +7 -4
  47. package/lib/directives/dropdown.directive.d.ts +4 -0
  48. package/lib/directives/formIndex.directive.d.ts +10 -0
  49. package/lib/directives/grid.directive.d.ts +21 -4
  50. package/lib/directives/readonly.directive.d.ts +28 -0
  51. package/lib/dynamic-fields/dynamic-fields.component.d.ts +28 -4
  52. package/lib/dynamic-form/dynamic-form.component.d.ts +20 -10
  53. package/lib/dynamic-host/dynamic-host.component.d.ts +27 -0
  54. package/lib/locale/locale-de.d.ts +1 -0
  55. package/lib/locale/locale-en.d.ts +1 -0
  56. package/lib/locale/locale-es.d.ts +1 -0
  57. package/lib/locale/locale-fr.d.ts +1 -0
  58. package/lib/locale/locale-it.d.ts +1 -0
  59. package/lib/locale/locale-pt.d.ts +1 -0
  60. package/lib/locale/locale.d.ts +7 -0
  61. package/lib/services/chart.service.d.ts +5 -2
  62. package/lib/services/dialog.service.d.ts +0 -1
  63. package/lib/services/feel.service.d.ts +8 -0
  64. package/lib/services/form.service.d.ts +51 -0
  65. package/lib/services/formatter.service.d.ts +8 -6
  66. package/lib/services/function.service.d.ts +1 -1
  67. package/lib/services/global.service.d.ts +16 -0
  68. package/lib/services/grid.service.d.ts +16 -4
  69. package/lib/services/metadata.service.d.ts +0 -3
  70. package/lib/services/programmability.service.d.ts +33 -5
  71. package/lib/utils/feelable.d.ts +2 -0
  72. package/lib/utils/groupByRow.d.ts +2 -0
  73. package/package.json +2 -2
  74. package/public-api.d.ts +1 -0
  75. package/esm2022/lib/directives/disable.directive.mjs +0 -71
  76. package/esm2022/lib/directives/disableform.directive.mjs +0 -42
  77. package/esm2022/lib/utils/gridCells.mjs +0 -108
  78. package/esm2022/lib/utils/patchForm.mjs +0 -75
  79. package/esm2022/lib/utils/setFilter.mjs +0 -111
  80. package/lib/directives/disable.directive.d.ts +0 -20
  81. package/lib/directives/disableform.directive.d.ts +0 -17
  82. package/lib/utils/gridCells.d.ts +0 -110
  83. package/lib/utils/patchForm.d.ts +0 -9
@@ -0,0 +1,69 @@
1
+ import { Component } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { SirioButtonComponent } from 'ngx-sirio-lib';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services/programmability.service";
6
+ import * as i2 from "@angular/common";
7
+ export class ActionsCellRendererComponent {
8
+ programmability;
9
+ constructor(programmability) {
10
+ this.programmability = programmability;
11
+ }
12
+ params;
13
+ agInit(params) {
14
+ this.params = params;
15
+ }
16
+ refresh() {
17
+ return false;
18
+ }
19
+ evaluateBoolean(value) {
20
+ const options = {
21
+ cacheable: false,
22
+ extendContext: () => ({
23
+ "event": {
24
+ params: this.params,
25
+ data: this.getData(),
26
+ rowIndex: this.getRowIndex()
27
+ }
28
+ })
29
+ };
30
+ return this.programmability.evaluateBoolean(this.getFormGroup(), value, options);
31
+ }
32
+ evaluateString(value) {
33
+ return this.programmability.evaluateString(this.getFormGroup(), value);
34
+ }
35
+ clickButton(action, event) {
36
+ if (action.click) {
37
+ const options = {
38
+ cacheable: false,
39
+ extendContext: () => ({
40
+ "event": {
41
+ params: this.params,
42
+ action: action,
43
+ data: this.getData(),
44
+ rowIndex: this.getRowIndex()
45
+ }
46
+ })
47
+ };
48
+ return this.programmability.evaluate(this.getFormGroup(), action.click, options);
49
+ }
50
+ }
51
+ getData() {
52
+ return this.params.data;
53
+ }
54
+ getRowIndex() {
55
+ return this.params.node.rowIndex;
56
+ }
57
+ getFormGroup() {
58
+ return this.params.formGroup;
59
+ }
60
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionsCellRendererComponent, deps: [{ token: i1.ProgrammabilityService }], target: i0.ɵɵFactoryTarget.Component });
61
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ActionsCellRendererComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<div class=\"btn-small-group\">\r\n <ng-container *ngFor=\"let action of params.component.actions\">\r\n <ngx-sirio-button class=\"btn-small\"\r\n [ariaLabel]=\"evaluateString(action.label)\"\r\n [title]=\"evaluateString(action.label)\"\r\n [color]=\"null\"\r\n [disabled]=\"evaluateBoolean(action.disabled)\"\r\n (clickEvent)=\"clickButton(action, $event)\"\r\n [icon]=\"evaluateString(action.icon)\">\r\n </ngx-sirio-button>\r\n </ng-container>\r\n</div>\r\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: SirioButtonComponent, selector: "ngx-sirio-button", inputs: ["ariaExpanded", "ariaControls", "ariaActivedescendant", "ariaHaspopup", "ariaLabel", "ariaRequired", "ariaInvalid", "ariaDescribedby", "icon", "title", "role", "color", "isFloating", "isExtended", "isLight", "isSmall", "disabled", "isDropdown", "type", "dismissType", "isBtnBlock"], outputs: ["clickEvent", "focusEvent", "blurEvent"] }] });
62
+ }
63
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionsCellRendererComponent, decorators: [{
64
+ type: Component,
65
+ args: [{ standalone: true, imports: [
66
+ CommonModule, SirioButtonComponent
67
+ ], template: "<div class=\"btn-small-group\">\r\n <ng-container *ngFor=\"let action of params.component.actions\">\r\n <ngx-sirio-button class=\"btn-small\"\r\n [ariaLabel]=\"evaluateString(action.label)\"\r\n [title]=\"evaluateString(action.label)\"\r\n [color]=\"null\"\r\n [disabled]=\"evaluateBoolean(action.disabled)\"\r\n (clickEvent)=\"clickButton(action, $event)\"\r\n [icon]=\"evaluateString(action.icon)\">\r\n </ngx-sirio-button>\r\n </ng-container>\r\n</div>\r\n" }]
68
+ }], ctorParameters: () => [{ type: i1.ProgrammabilityService }] });
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uc0NlbGxSZW5kZXJlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9jb21wb25lbnRzL2FjdGlvbnNDZWxsUmVuZGVyZXIvYWN0aW9uc0NlbGxSZW5kZXJlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9jb21wb25lbnRzL2FjdGlvbnNDZWxsUmVuZGVyZXIvYWN0aW9uc0NlbGxSZW5kZXJlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFXckQsTUFBTSxPQUFPLDRCQUE0QjtJQUVuQjtJQUFwQixZQUFvQixlQUF1QztRQUF2QyxvQkFBZSxHQUFmLGVBQWUsQ0FBd0I7SUFBSSxDQUFDO0lBRWhFLE1BQU0sQ0FBTTtJQUVaLE1BQU0sQ0FBQyxNQUFXO1FBQ2hCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsZUFBZSxDQUFDLEtBQThCO1FBRTVDLE1BQU0sT0FBTyxHQUFvQjtZQUMvQixTQUFTLEVBQUUsS0FBSztZQUNoQixhQUFhLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztnQkFDcEIsT0FBTyxFQUFFO29CQUNQLE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTTtvQkFDbkIsSUFBSSxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUU7b0JBQ3BCLFFBQVEsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFO2lCQUM3QjthQUNGLENBQUM7U0FDSCxDQUFBO1FBRUQsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBb0I7UUFDakMsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDekUsQ0FBQztJQUVELFdBQVcsQ0FBQyxNQUFXLEVBQUUsS0FBVTtRQUNqQyxJQUFJLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUVqQixNQUFNLE9BQU8sR0FBb0I7Z0JBQy9CLFNBQVMsRUFBRSxLQUFLO2dCQUNoQixhQUFhLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztvQkFDcEIsT0FBTyxFQUFFO3dCQUNQLE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTTt3QkFDbkIsTUFBTSxFQUFFLE1BQU07d0JBQ2QsSUFBSSxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUU7d0JBQ3BCLFFBQVEsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFO3FCQUM3QjtpQkFDRixDQUFDO2FBQ0gsQ0FBQTtZQUVELE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDbkYsQ0FBQztJQUNILENBQUM7SUFFTyxPQUFPO1FBQ2IsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztJQUMxQixDQUFDO0lBRU8sV0FBVztRQUNqQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUNuQyxDQUFDO0lBRU8sWUFBWTtRQUNsQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBc0IsQ0FBQztJQUM1QyxDQUFDO3dHQS9EVSw0QkFBNEI7NEZBQTVCLDRCQUE0Qix3RUNkekMsb2xCQVlBLDJDRERJLFlBQVksNEpBQUUsb0JBQW9COzs0RkFHekIsNEJBQTRCO2tCQVB4QyxTQUFTO2lDQUVJLElBQUksV0FDUDt3QkFDUCxZQUFZLEVBQUUsb0JBQW9CO3FCQUNuQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBJQ2VsbFJlbmRlcmVyQW5ndWxhckNvbXAgfSBmcm9tICdhZy1ncmlkLWFuZ3VsYXInO1xyXG5pbXBvcnQgeyBTaXJpb0J1dHRvbkNvbXBvbmVudCB9IGZyb20gJ25neC1zaXJpby1saWInO1xyXG5pbXBvcnQgeyBQcm9ncmFtbWFiaWxpdHlTZXJ2aWNlLCBFdmFsdWF0ZU9wdGlvbnMgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9wcm9ncmFtbWFiaWxpdHkuc2VydmljZSc7XHJcbmltcG9ydCB7IEZvcm1Hcm91cCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHRlbXBsYXRlVXJsOiAnLi9hY3Rpb25zQ2VsbFJlbmRlcmVyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSwgU2lyaW9CdXR0b25Db21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBY3Rpb25zQ2VsbFJlbmRlcmVyQ29tcG9uZW50IGltcGxlbWVudHMgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIHtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBwcm9ncmFtbWFiaWxpdHk6IFByb2dyYW1tYWJpbGl0eVNlcnZpY2UpIHsgfVxyXG5cclxuICBwYXJhbXM6IGFueTtcclxuXHJcbiAgYWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLnBhcmFtcyA9IHBhcmFtcztcclxuICB9XHJcblxyXG4gIHJlZnJlc2goKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gZmFsc2U7XHJcbiAgfVxyXG5cclxuICBldmFsdWF0ZUJvb2xlYW4odmFsdWU6IGJvb2xlYW4gfCBzdHJpbmcgfCBudWxsKTogYm9vbGVhbiB8IG51bGwge1xyXG5cclxuICAgIGNvbnN0IG9wdGlvbnM6IEV2YWx1YXRlT3B0aW9ucyA9IHtcclxuICAgICAgY2FjaGVhYmxlOiBmYWxzZSxcclxuICAgICAgZXh0ZW5kQ29udGV4dDogKCkgPT4gKHtcclxuICAgICAgICBcImV2ZW50XCI6IHtcclxuICAgICAgICAgIHBhcmFtczogdGhpcy5wYXJhbXMsXHJcbiAgICAgICAgICBkYXRhOiB0aGlzLmdldERhdGEoKSxcclxuICAgICAgICAgIHJvd0luZGV4OiB0aGlzLmdldFJvd0luZGV4KClcclxuICAgICAgICB9XHJcbiAgICAgIH0pXHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHRoaXMucHJvZ3JhbW1hYmlsaXR5LmV2YWx1YXRlQm9vbGVhbih0aGlzLmdldEZvcm1Hcm91cCgpLCB2YWx1ZSwgb3B0aW9ucyk7XHJcbiAgfVxyXG5cclxuICBldmFsdWF0ZVN0cmluZyh2YWx1ZTogc3RyaW5nIHwgbnVsbCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5wcm9ncmFtbWFiaWxpdHkuZXZhbHVhdGVTdHJpbmcodGhpcy5nZXRGb3JtR3JvdXAoKSwgdmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgY2xpY2tCdXR0b24oYWN0aW9uOiBhbnksIGV2ZW50OiBhbnkpIHtcclxuICAgIGlmIChhY3Rpb24uY2xpY2spIHtcclxuXHJcbiAgICAgIGNvbnN0IG9wdGlvbnM6IEV2YWx1YXRlT3B0aW9ucyA9IHtcclxuICAgICAgICBjYWNoZWFibGU6IGZhbHNlLFxyXG4gICAgICAgIGV4dGVuZENvbnRleHQ6ICgpID0+ICh7XHJcbiAgICAgICAgICBcImV2ZW50XCI6IHtcclxuICAgICAgICAgICAgcGFyYW1zOiB0aGlzLnBhcmFtcyxcclxuICAgICAgICAgICAgYWN0aW9uOiBhY3Rpb24sXHJcbiAgICAgICAgICAgIGRhdGE6IHRoaXMuZ2V0RGF0YSgpLFxyXG4gICAgICAgICAgICByb3dJbmRleDogdGhpcy5nZXRSb3dJbmRleCgpXHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSlcclxuICAgICAgfVxyXG5cclxuICAgICAgcmV0dXJuIHRoaXMucHJvZ3JhbW1hYmlsaXR5LmV2YWx1YXRlKHRoaXMuZ2V0Rm9ybUdyb3VwKCksIGFjdGlvbi5jbGljaywgb3B0aW9ucyk7XHJcbiAgICB9ICAgIFxyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBnZXREYXRhKCk6IGFueSB7XHJcbiAgICByZXR1cm4gdGhpcy5wYXJhbXMuZGF0YTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZ2V0Um93SW5kZXgoKTogYW55IHtcclxuICAgIHJldHVybiB0aGlzLnBhcmFtcy5ub2RlLnJvd0luZGV4O1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBnZXRGb3JtR3JvdXAoKTogRm9ybUdyb3VwIHtcclxuICAgIHJldHVybiB0aGlzLnBhcmFtcy5mb3JtR3JvdXAgYXMgRm9ybUdyb3VwO1xyXG4gIH1cclxufVxyXG5cclxuIiwiPGRpdiBjbGFzcz1cImJ0bi1zbWFsbC1ncm91cFwiPlxyXG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGFjdGlvbiBvZiBwYXJhbXMuY29tcG9uZW50LmFjdGlvbnNcIj5cclxuICAgIDxuZ3gtc2lyaW8tYnV0dG9uIGNsYXNzPVwiYnRuLXNtYWxsXCJcclxuICAgICAgICAgICAgICAgICAgICAgIFthcmlhTGFiZWxdPVwiZXZhbHVhdGVTdHJpbmcoYWN0aW9uLmxhYmVsKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICBbdGl0bGVdPVwiZXZhbHVhdGVTdHJpbmcoYWN0aW9uLmxhYmVsKVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICBbY29sb3JdPVwibnVsbFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICBbZGlzYWJsZWRdPVwiZXZhbHVhdGVCb29sZWFuKGFjdGlvbi5kaXNhYmxlZClcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgKGNsaWNrRXZlbnQpPVwiY2xpY2tCdXR0b24oYWN0aW9uLCAkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAgICAgICAgIFtpY29uXT1cImV2YWx1YXRlU3RyaW5nKGFjdGlvbi5pY29uKVwiPlxyXG4gICAgPC9uZ3gtc2lyaW8tYnV0dG9uPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG48L2Rpdj5cclxuIl19
@@ -0,0 +1,25 @@
1
+ import { Component } from '@angular/core';
2
+ import { Texts } from '../../locale/locale-it';
3
+ import * as i0 from "@angular/core";
4
+ export class DeleteRowRendererComponent {
5
+ params;
6
+ Texts = Texts;
7
+ agInit(params) {
8
+ this.params = params;
9
+ }
10
+ onClick(event) {
11
+ if ('remove' in this.params.data && typeof this.params.data.remove === 'function') {
12
+ this.params.data.remove();
13
+ }
14
+ }
15
+ refresh() {
16
+ return false;
17
+ }
18
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeleteRowRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
19
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DeleteRowRendererComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<a [attr.aria-label]=\"Texts.Remove\" title=\"{{ Texts.Remove }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-trash\"></span>\r\n</a>\r\n" });
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeleteRowRendererComponent, decorators: [{
22
+ type: Component,
23
+ args: [{ standalone: true, template: "<a [attr.aria-label]=\"Texts.Remove\" title=\"{{ Texts.Remove }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-trash\"></span>\r\n</a>\r\n" }]
24
+ }] });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVsZXRlUm93UmVuZGVyZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvY29tcG9uZW50cy9kZWxldGVSb3dSZW5kZXJlci9kZWxldGVSb3dSZW5kZXJlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9jb21wb25lbnRzL2RlbGV0ZVJvd1JlbmRlcmVyL2RlbGV0ZVJvd1JlbmRlcmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUMsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU0vQyxNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLE1BQU0sQ0FBTTtJQUVaLEtBQUssR0FBRyxLQUFLLENBQUM7SUFFZCxNQUFNLENBQUMsTUFBVztRQUNoQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQVk7UUFFbEIsSUFBSSxRQUFRLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLEtBQUssVUFBVSxFQUFFLENBQUM7WUFDbEYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDNUIsQ0FBQztJQUNILENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO3dHQWxCVSwwQkFBMEI7NEZBQTFCLDBCQUEwQix3RUNSdkMsbUxBR0E7OzRGREthLDBCQUEwQjtrQkFKdEMsU0FBUztpQ0FFSSxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IElDZWxsUmVuZGVyZXJBbmd1bGFyQ29tcCB9IGZyb20gJ2FnLWdyaWQtYW5ndWxhcic7XHJcbmltcG9ydCB7IFRleHRzIH0gZnJvbSAnLi4vLi4vbG9jYWxlL2xvY2FsZS1pdCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICB0ZW1wbGF0ZVVybDogJy4vZGVsZXRlUm93UmVuZGVyZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0YW5kYWxvbmU6IHRydWVcclxufSlcclxuZXhwb3J0IGNsYXNzIERlbGV0ZVJvd1JlbmRlcmVyQ29tcG9uZW50IGltcGxlbWVudHMgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIHtcclxuICBwYXJhbXM6IGFueTtcclxuXHJcbiAgVGV4dHMgPSBUZXh0cztcclxuXHJcbiAgYWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLnBhcmFtcyA9IHBhcmFtcztcclxuICB9XHJcblxyXG4gIG9uQ2xpY2soZXZlbnQ6IEV2ZW50KSB7XHJcblxyXG4gICAgaWYgKCdyZW1vdmUnIGluIHRoaXMucGFyYW1zLmRhdGEgJiYgdHlwZW9mIHRoaXMucGFyYW1zLmRhdGEucmVtb3ZlID09PSAnZnVuY3Rpb24nKSB7XHJcbiAgICAgIHRoaXMucGFyYW1zLmRhdGEucmVtb3ZlKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICByZWZyZXNoKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxufVxyXG5cclxuIiwiPGEgW2F0dHIuYXJpYS1sYWJlbF09XCJUZXh0cy5SZW1vdmVcIiB0aXRsZT1cInt7IFRleHRzLlJlbW92ZSB9fVwiIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIiAoY2xpY2spPVwib25DbGljaygkZXZlbnQpXCI+XHJcbiAgPHNwYW4gY2xhc3M9XCJmYXMgZmEtdHJhc2hcIj48L3NwYW4+XHJcbjwvYT5cclxuIl19
@@ -0,0 +1,101 @@
1
+ import { Component, ViewChild, ViewContainerRef } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../services/programmability.service";
5
+ import * as i2 from "../../services/global.service";
6
+ export class HostCellRendererComponent {
7
+ injector;
8
+ programmability;
9
+ globalService;
10
+ container;
11
+ constructor(injector, programmability, globalService) {
12
+ this.injector = injector;
13
+ this.programmability = programmability;
14
+ this.globalService = globalService;
15
+ }
16
+ params;
17
+ agInit(params) {
18
+ this.params = params;
19
+ }
20
+ refresh() {
21
+ return false;
22
+ }
23
+ ngAfterViewInit() {
24
+ const componentType = this.resolveComponentType(this.getComponentType());
25
+ if (componentType) {
26
+ this.componentRef = this.container.createComponent(componentType, {
27
+ injector: this.injector,
28
+ });
29
+ this.setProperties();
30
+ }
31
+ }
32
+ //#region Private Members
33
+ componentRef = null;
34
+ resolveComponentType(type) {
35
+ return this.globalService.getComponent(type);
36
+ }
37
+ resolveProperties() {
38
+ const properties = this.getProperties();
39
+ if (properties) {
40
+ return this.evaluate(properties) ?? {};
41
+ }
42
+ else {
43
+ return {};
44
+ }
45
+ }
46
+ setProperties() {
47
+ if (!this.componentRef)
48
+ return;
49
+ const properties = this.resolveProperties();
50
+ for (const key of Object.keys(properties)) {
51
+ const value = properties[key];
52
+ if (key in this.componentRef.instance) {
53
+ this.componentRef.setInput?.(key, value);
54
+ }
55
+ }
56
+ }
57
+ evaluate(value) {
58
+ const options = {
59
+ cacheable: false,
60
+ extendContext: () => ({
61
+ "event": {
62
+ params: this.params,
63
+ value: this.getValue(),
64
+ data: this.getData(),
65
+ rowIndex: this.getRowIndex()
66
+ }
67
+ })
68
+ };
69
+ return this.programmability.evaluate(this.getFormGroup(), value, options);
70
+ }
71
+ getComponentType() {
72
+ return this.params.componentType;
73
+ }
74
+ getProperties() {
75
+ return this.params.properties;
76
+ }
77
+ getFormGroup() {
78
+ return this.params.formGroup;
79
+ }
80
+ getData() {
81
+ return this.params.data;
82
+ }
83
+ getValue() {
84
+ return this.params.value;
85
+ }
86
+ getRowIndex() {
87
+ return this.params.node.rowIndex;
88
+ }
89
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HostCellRendererComponent, deps: [{ token: i0.Injector }, { token: i1.ProgrammabilityService }, { token: i2.GlobalService }], target: i0.ɵɵFactoryTarget.Component });
90
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: HostCellRendererComponent, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<ng-container #container></ng-container>\r\n", dependencies: [{ kind: "ngmodule", type: CommonModule }] });
91
+ }
92
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HostCellRendererComponent, decorators: [{
93
+ type: Component,
94
+ args: [{ standalone: true, imports: [
95
+ CommonModule
96
+ ], template: "<ng-container #container></ng-container>\r\n" }]
97
+ }], ctorParameters: () => [{ type: i0.Injector }, { type: i1.ProgrammabilityService }, { type: i2.GlobalService }], propDecorators: { container: [{
98
+ type: ViewChild,
99
+ args: ['container', { read: ViewContainerRef, static: true }]
100
+ }] } });
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hostCellRenderer.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sirio/src/lib/components/hostCellRenderer/hostCellRenderer.component.ts","../../../../../../projects/ngx-sirio/src/lib/components/hostCellRenderer/hostCellRenderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, ViewChild, ViewContainerRef, AfterViewInit, ComponentRef, Type\r\n  , Injector\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { ICellRendererAngularComp } from 'ag-grid-angular';\r\nimport { ProgrammabilityService, EvaluateOptions } from '../../services/programmability.service';\r\nimport { GlobalService } from '../../services/global.service';\r\n\r\n@Component({\r\n  templateUrl: './hostCellRenderer.component.html',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule\r\n  ]\r\n})\r\nexport class HostCellRendererComponent implements ICellRendererAngularComp, AfterViewInit {\r\n  @ViewChild('container', { read: ViewContainerRef, static: true }) container!: ViewContainerRef;\r\n\r\n  constructor(private injector: Injector,\r\n    private programmability: ProgrammabilityService,\r\n    private globalService: GlobalService) { }\r\n\r\n  params: any;\r\n\r\n  agInit(params: any): void {\r\n    this.params = params;\r\n  }\r\n\r\n  refresh(): boolean {\r\n    return false;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const componentType = this.resolveComponentType(this.getComponentType());\r\n    if (componentType) {\r\n      this.componentRef = this.container.createComponent(componentType, {\r\n        injector: this.injector,\r\n      });\r\n\r\n      this.setProperties();\r\n    }\r\n  }\r\n\r\n  //#region Private Members\r\n\r\n  private componentRef: ComponentRef<any> | null = null;\r\n\r\n  private resolveComponentType(type: string): Type<any> | null {\r\n    return this.globalService.getComponent(type);\r\n  }\r\n\r\n  private resolveProperties(): Record<string, any> {\r\n    const properties = this.getProperties();\r\n    if (properties) {\r\n      return this.evaluate(properties) ?? {}\r\n    }\r\n    else\r\n    {\r\n      return { };\r\n    }    \r\n  }\r\n\r\n  private setProperties(): void {\r\n    if (!this.componentRef) return;\r\n    const properties = this.resolveProperties();\r\n    for (const key of Object.keys(properties)) {\r\n      const value = properties[key];\r\n      if (key in this.componentRef.instance) {\r\n        this.componentRef.setInput?.(key, value);\r\n      }\r\n    }\r\n  }\r\n\r\n  private evaluate(value: string) {\r\n\r\n    const options: EvaluateOptions = {\r\n      cacheable: false,\r\n      extendContext: () => ({\r\n        \"event\": {\r\n          params: this.params,\r\n          value: this.getValue(),\r\n          data: this.getData(),\r\n          rowIndex: this.getRowIndex()\r\n        }\r\n      })\r\n    }\r\n\r\n    return this.programmability.evaluate(this.getFormGroup(), value, options);\r\n  }\r\n\r\n  private getComponentType(): string {\r\n    return this.params.componentType;\r\n  }\r\n\r\n  private getProperties(): string | undefined\r\n  {\r\n    return this.params.properties;\r\n  }\r\n\r\n  private getFormGroup(): FormGroup {\r\n    return this.params.formGroup;\r\n  }\r\n\r\n  private getData(): any {\r\n    return this.params.data;\r\n  }\r\n\r\n  private getValue(): any {\r\n    return this.params.value;\r\n  }\r\n\r\n  private getRowIndex(): any {\r\n    return this.params.node.rowIndex;\r\n  }\r\n\r\n  //#endregion\r\n}\r\n\r\n","<ng-container #container></ng-container>\r\n"]}
@@ -0,0 +1,27 @@
1
+ import { Component } from '@angular/core';
2
+ import { Texts } from '../../locale/locale-it';
3
+ import * as i0 from "@angular/core";
4
+ export class ObjectURLRendererComponent {
5
+ params;
6
+ Texts = Texts;
7
+ agInit(params) {
8
+ this.params = params;
9
+ }
10
+ onClick(event) {
11
+ const fileURL = URL.createObjectURL(this.params.data);
12
+ window.open(fileURL, '_blank');
13
+ setTimeout(() => {
14
+ URL.revokeObjectURL(fileURL);
15
+ }, 1000);
16
+ }
17
+ refresh() {
18
+ return false;
19
+ }
20
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ObjectURLRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
21
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ObjectURLRendererComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<a [attr.aria-label]=\"Texts.Show\" title=\"{{ Texts.Show }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-paperclip\"></span>\r\n</a>\r\n" });
22
+ }
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ObjectURLRendererComponent, decorators: [{
24
+ type: Component,
25
+ args: [{ standalone: true, template: "<a [attr.aria-label]=\"Texts.Show\" title=\"{{ Texts.Show }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-paperclip\"></span>\r\n</a>\r\n" }]
26
+ }] });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0VVJMUmVuZGVyZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvY29tcG9uZW50cy9vYmplY3RVUkxSZW5kZXJlci9vYmplY3RVUkxSZW5kZXJlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9jb21wb25lbnRzL29iamVjdFVSTFJlbmRlcmVyL29iamVjdFVSTFJlbmRlcmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHMUMsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU0vQyxNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLE1BQU0sQ0FBdUI7SUFFN0IsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUVkLE1BQU0sQ0FBQyxNQUEyQjtRQUNoQyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQVk7UUFDbEIsTUFBTSxPQUFPLEdBQUcsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3RELE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQy9CLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxHQUFHLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQy9CLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO3dHQW5CVSwwQkFBMEI7NEZBQTFCLDBCQUEwQix3RUNUdkMsbUxBR0E7OzRGRE1hLDBCQUEwQjtrQkFKdEMsU0FBUztpQ0FFSSxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IElDZWxsUmVuZGVyZXJBbmd1bGFyQ29tcCB9IGZyb20gJ2FnLWdyaWQtYW5ndWxhcic7XHJcbmltcG9ydCB7IElDZWxsUmVuZGVyZXJQYXJhbXMgfSBmcm9tICdhZy1ncmlkLWNvbW11bml0eSc7XHJcbmltcG9ydCB7IFRleHRzIH0gZnJvbSAnLi4vLi4vbG9jYWxlL2xvY2FsZS1pdCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICB0ZW1wbGF0ZVVybDogJy4vb2JqZWN0VVJMUmVuZGVyZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0YW5kYWxvbmU6IHRydWVcclxufSlcclxuZXhwb3J0IGNsYXNzIE9iamVjdFVSTFJlbmRlcmVyQ29tcG9uZW50IGltcGxlbWVudHMgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIHtcclxuICBwYXJhbXMhOiBJQ2VsbFJlbmRlcmVyUGFyYW1zO1xyXG5cclxuICBUZXh0cyA9IFRleHRzO1xyXG5cclxuICBhZ0luaXQocGFyYW1zOiBJQ2VsbFJlbmRlcmVyUGFyYW1zKTogdm9pZCB7XHJcbiAgICB0aGlzLnBhcmFtcyA9IHBhcmFtcztcclxuICB9XHJcblxyXG4gIG9uQ2xpY2soZXZlbnQ6IEV2ZW50KSB7XHJcbiAgICBjb25zdCBmaWxlVVJMID0gVVJMLmNyZWF0ZU9iamVjdFVSTCh0aGlzLnBhcmFtcy5kYXRhKTtcclxuICAgIHdpbmRvdy5vcGVuKGZpbGVVUkwsICdfYmxhbmsnKTtcclxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICBVUkwucmV2b2tlT2JqZWN0VVJMKGZpbGVVUkwpO1xyXG4gICAgfSwgMTAwMCk7XHJcbiAgfVxyXG5cclxuICByZWZyZXNoKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxufVxyXG4iLCI8YSBbYXR0ci5hcmlhLWxhYmVsXT1cIlRleHRzLlNob3dcIiB0aXRsZT1cInt7IFRleHRzLlNob3cgfX1cIiBocmVmPVwiamF2YXNjcmlwdDp2b2lkKDApXCIgKGNsaWNrKT1cIm9uQ2xpY2soJGV2ZW50KVwiPlxyXG4gIDxzcGFuIGNsYXNzPVwiZmFzIGZhLXBhcGVyY2xpcFwiPjwvc3Bhbj5cclxuPC9hPlxyXG4iXX0=
@@ -0,0 +1,111 @@
1
+ import { Component } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { SirioInputComponent, SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioButtonComponent } from 'ngx-sirio-lib';
5
+ import { isRecord } from '../../common/record';
6
+ import { Texts } from '../../locale/locale-it';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/common";
9
+ import * as i2 from "@angular/forms";
10
+ export class SetFilterComponent {
11
+ params;
12
+ fieldName;
13
+ Texts = Texts;
14
+ selectAll = true;
15
+ searchText = '';
16
+ options = [];
17
+ filteredOptions = [];
18
+ agInit(params) {
19
+ this.params = params;
20
+ this.fieldName = params.colDef.field;
21
+ const map = params.colDef.filterParams?.map;
22
+ const result = isRecord(map, key => typeof key === 'string' || typeof key === 'number', val => typeof val === 'string');
23
+ if (result) {
24
+ this.options = Object.entries(map).map(([key, label]) => ({
25
+ value: this.parseKey(key),
26
+ label: label,
27
+ selected: true
28
+ }));
29
+ }
30
+ else {
31
+ this.options = [];
32
+ }
33
+ this.filteredOptions = [...this.options];
34
+ }
35
+ isFilterActive() {
36
+ return this.options.some(o => !o.selected);
37
+ }
38
+ doesFilterPass(params) {
39
+ const value = this.resolvePath(params.data, this.fieldName);
40
+ return this.options.some(o => o.selected && o.value === value);
41
+ }
42
+ getModel() {
43
+ const selectedValues = this.options
44
+ .filter(o => o.selected)
45
+ .map(o => o.value);
46
+ if (selectedValues.length === this.options.length) {
47
+ return null;
48
+ }
49
+ if (selectedValues.length === 0) {
50
+ return {
51
+ filterType: 'text',
52
+ type: 'excludeAll'
53
+ };
54
+ }
55
+ const filters = selectedValues.map(value => ({
56
+ filterType: 'number',
57
+ type: 'equals',
58
+ filter: value
59
+ }));
60
+ if (filters.length === 1)
61
+ return filters[0];
62
+ return {
63
+ filterType: 'number',
64
+ operator: 'OR',
65
+ conditions: filters
66
+ };
67
+ }
68
+ setModel(model) {
69
+ const selected = model?.values ?? this.options.map(o => o.value);
70
+ this.options.forEach(o => o.selected = selected.includes(o.value));
71
+ this.updateFilteredOptions();
72
+ }
73
+ onSelectionChange() {
74
+ this.params.filterChangedCallback();
75
+ }
76
+ onSearchChange() {
77
+ this.updateFilteredOptions();
78
+ }
79
+ onSelectAllChange() {
80
+ this.setAll(this.selectAll);
81
+ }
82
+ parseKey(key) {
83
+ if (key === 'true')
84
+ return true;
85
+ if (key === 'false')
86
+ return false;
87
+ const num = Number(key);
88
+ return isNaN(num) ? key : num;
89
+ }
90
+ setAll(select) {
91
+ this.options.forEach(o => o.selected = select);
92
+ this.updateFilteredOptions();
93
+ this.params.filterChangedCallback();
94
+ }
95
+ updateFilteredOptions() {
96
+ const search = this.searchText.toLowerCase();
97
+ this.filteredOptions = this.options.filter(o => o.label.toLowerCase().includes(search));
98
+ }
99
+ resolvePath(obj, path) {
100
+ return path.split('.').reduce((acc, part) => acc?.[part], obj);
101
+ }
102
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SetFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
103
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SetFilterComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<div style=\"padding: 5px;background-color: white;\">\r\n\r\n <div style=\"padding: 5px\">\r\n <ngx-sirio-input type=\"text\"\r\n [placeholder]=\"Texts.TypeToSearch\"\r\n [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchChange()\">\r\n </ngx-sirio-input>\r\n </div>\r\n\r\n <div style=\"padding: 5px; max-height: 200px; overflow-y: auto;\">\r\n <ngx-sirio-checkbox [(ngModel)]=\"selectAll\" (ngModelChange)=\"onSelectAllChange()\">{{Texts.SelectAll}}</ngx-sirio-checkbox>\r\n\r\n <ngx-sirio-checkbox-group>\r\n <ngx-sirio-checkbox *ngFor=\"let option of filteredOptions\"\r\n [(ngModel)]=\"option.selected\"\r\n [value]=\"option.value\"\r\n (change)=\"onSelectionChange()\">\r\n {{ option.label }}\r\n </ngx-sirio-checkbox>\r\n </ngx-sirio-checkbox-group>\r\n </div>\r\n\r\n</div>\r\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { 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: "component", type: SirioInputComponent, selector: "ngx-sirio-input", inputs: ["disabledState", "value", "label", "labelPopover", "ariaLabelPopoverButton", "type", "name", "placeholder", "textHelp", "textFeedback", "rows", "cols", "ariaLabel", "ariaAutocomplete", "ariaInvalid", "ariaDescribedBy", "role"], outputs: ["focusEvent", "inputEvent", "blurEvent", "keyupEvent", "keydownEvent"] }, { kind: "component", type: SirioCheckboxComponent, selector: "ngx-sirio-checkbox", inputs: ["disabled", "name", "textHelp", "textFeedback", "value", "ariaInvalid", "ariaDescribedBy", "disabledState", "checked"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }, { kind: "component", type: SirioCheckboxGroupComponent, selector: "ngx-sirio-checkbox-group", inputs: ["textHelp", "textFeedback", "label", "labelPopover", "ariaLabelPopoverButton", "ariaLabel", "ariaInvalid", "ariaDescribedBy", "disabledState", "value"], outputs: ["focusEvent", "blurEvent", "changeEvent"] }] });
104
+ }
105
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SetFilterComponent, decorators: [{
106
+ type: Component,
107
+ args: [{ standalone: true, imports: [CommonModule, FormsModule, SirioInputComponent,
108
+ SirioCheckboxComponent, SirioCheckboxGroupComponent,
109
+ SirioButtonComponent], template: "<div style=\"padding: 5px;background-color: white;\">\r\n\r\n <div style=\"padding: 5px\">\r\n <ngx-sirio-input type=\"text\"\r\n [placeholder]=\"Texts.TypeToSearch\"\r\n [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchChange()\">\r\n </ngx-sirio-input>\r\n </div>\r\n\r\n <div style=\"padding: 5px; max-height: 200px; overflow-y: auto;\">\r\n <ngx-sirio-checkbox [(ngModel)]=\"selectAll\" (ngModelChange)=\"onSelectAllChange()\">{{Texts.SelectAll}}</ngx-sirio-checkbox>\r\n\r\n <ngx-sirio-checkbox-group>\r\n <ngx-sirio-checkbox *ngFor=\"let option of filteredOptions\"\r\n [(ngModel)]=\"option.selected\"\r\n [value]=\"option.value\"\r\n (change)=\"onSelectionChange()\">\r\n {{ option.label }}\r\n </ngx-sirio-checkbox>\r\n </ngx-sirio-checkbox-group>\r\n </div>\r\n\r\n</div>\r\n" }]
110
+ }] });
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"setFilter.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sirio/src/lib/components/setFilter/setFilter.component.ts","../../../../../../projects/ngx-sirio/src/lib/components/setFilter/setfilter.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7C,OAAO,EAAE,mBAAmB,EAAE,2BAA2B,EAAE,sBAAsB,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAC/H,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;;;;AAS/C,MAAM,OAAO,kBAAkB;IACrB,MAAM,CAAiB;IACvB,SAAS,CAAU;IAE3B,KAAK,GAAG,KAAK,CAAC;IAEd,SAAS,GAAY,IAAI,CAAC;IAC1B,UAAU,GAAW,EAAE,CAAC;IAExB,OAAO,GAAuD,EAAE,CAAC;IACjE,eAAe,GAAwB,EAAE,CAAC;IAE1C,MAAM,CAAC,MAAqB;QAC1B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,KAAM,CAAC;QAEtC,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,GAAG,CAAC;QAE5C,MAAM,MAAM,GAAG,QAAQ,CACrB,GAAG,EACH,GAAG,CAAC,EAAE,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,QAAQ,EACzD,GAAG,CAAC,EAAE,CAAC,OAAO,GAAG,KAAK,QAAQ,CAC/B,CAAC;QAEF,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;gBACxD,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC;gBACzB,KAAK,EAAE,KAAK;gBACZ,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC,CAAC;QACN,CAAC;aACI,CAAC;YACJ,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QACpB,CAAC;QAED,IAAI,CAAC,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;IAC3C,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAED,cAAc,CAAC,MAA6B;QAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAC5D,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;IACjE,CAAC;IAED,QAAQ;QACN,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO;aAChC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;aACvB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,cAAc,CAAC,MAAM,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YAClD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChC,OAAO;gBACL,UAAU,EAAE,MAAM;gBAClB,IAAI,EAAE,YAAY;aACnB,CAAA;QACH,CAAC;QAED,MAAM,OAAO,GAAG,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAC3C,UAAU,EAAE,QAAQ;YACpB,IAAI,EAAE,QAAQ;YACd,MAAM,EAAE,KAAK;SACd,CAAC,CAAC,CAAC;QAEJ,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;YACtB,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;QAEpB,OAAO;YACL,UAAU,EAAE,QAAQ;YACpB,QAAQ,EAAE,IAAI;YACd,UAAU,EAAE,OAAO;SACpB,CAAA;IACH,CAAC;IAED,QAAQ,CAAC,KAAU;QACjB,MAAM,QAAQ,GAAG,KAAK,EAAE,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACjE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC;IACtC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC9B,CAAC;IAEO,QAAQ,CAAC,GAAW;QAC1B,IAAI,GAAG,KAAK,MAAM;YAAE,OAAO,IAAI,CAAC;QAChC,IAAI,GAAG,KAAK,OAAO;YAAE,OAAO,KAAK,CAAC;QAClC,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;QACxB,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IAChC,CAAC;IAEO,MAAM,CAAC,MAAe;QAC5B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,GAAG,MAAM,CAAC,CAAC;QAC/C,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC;IACtC,CAAC;IAEO,qBAAqB;QAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;QAC7C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAC7C,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CACvC,CAAC;IACJ,CAAC;IAEO,WAAW,CAAC,GAAQ,EAAE,IAAY;QACxC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;IACjE,CAAC;wGAvHU,kBAAkB;4FAAlB,kBAAkB,wEChB/B,q8BAwBA,2CDZY,YAAY,2JAAE,WAAW,+VAAE,mBAAmB,2XACpD,sBAAsB,qPAAE,2BAA2B;;4FAG5C,kBAAkB;kBAP9B,SAAS;iCAEI,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,mBAAmB;wBACpD,sBAAsB,EAAE,2BAA2B;wBACnD,oBAAoB,CAAC","sourcesContent":["import { Component } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { IFilterParams, IDoesFilterPassParams } from 'ag-grid-community';\r\nimport { IFilterAngularComp } from '@ag-grid-community/angular';\r\nimport { SirioInputComponent, SirioCheckboxGroupComponent, SirioCheckboxComponent, SirioButtonComponent } from 'ngx-sirio-lib';\r\nimport { isRecord } from '../../common/record';\r\nimport { Texts } from '../../locale/locale-it';\r\n\r\n@Component({\r\n  templateUrl: './setfilter.component.html',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule, SirioInputComponent\r\n    , SirioCheckboxComponent, SirioCheckboxGroupComponent\r\n    , SirioButtonComponent],  \r\n})\r\nexport class SetFilterComponent implements IFilterAngularComp {\r\n  private params!: IFilterParams;\r\n  private fieldName!: string;\r\n\r\n  Texts = Texts;\r\n\r\n  selectAll: boolean = true;\r\n  searchText: string = '';\r\n\r\n  options: { value: any; label: string; selected: boolean }[] = [];\r\n  filteredOptions: typeof this.options = [];\r\n\r\n  agInit(params: IFilterParams): void {\r\n    this.params = params;\r\n    this.fieldName = params.colDef.field!;\r\n\r\n    const map = params.colDef.filterParams?.map;\r\n\r\n    const result = isRecord(\r\n      map,\r\n      key => typeof key === 'string' || typeof key === 'number',\r\n      val => typeof val === 'string'\r\n    );\r\n\r\n    if (result) {\r\n      this.options = Object.entries(map).map(([key, label]) => ({\r\n        value: this.parseKey(key),\r\n        label: label,\r\n        selected: true\r\n      }));\r\n    }\r\n    else {\r\n      this.options = [];\r\n    }\r\n    \r\n    this.filteredOptions = [...this.options];\r\n  }\r\n\r\n  isFilterActive(): boolean {\r\n    return this.options.some(o => !o.selected);\r\n  }\r\n\r\n  doesFilterPass(params: IDoesFilterPassParams): boolean {\r\n    const value = this.resolvePath(params.data, this.fieldName);\r\n    return this.options.some(o => o.selected && o.value === value);\r\n  }\r\n\r\n  getModel() {\r\n    const selectedValues = this.options\r\n      .filter(o => o.selected)\r\n      .map(o => o.value);\r\n\r\n    if (selectedValues.length === this.options.length) { \r\n      return null;\r\n    }\r\n\r\n    if (selectedValues.length === 0) {\r\n      return {\r\n        filterType: 'text',\r\n        type: 'excludeAll'\r\n      }\r\n    }\r\n\r\n    const filters = selectedValues.map(value => ({\r\n      filterType: 'number',\r\n      type: 'equals',\r\n      filter: value\r\n    }));\r\n\r\n    if (filters.length === 1)\r\n      return filters[0];\r\n\r\n    return {\r\n      filterType: 'number',\r\n      operator: 'OR',\r\n      conditions: filters\r\n    }\r\n  }\r\n\r\n  setModel(model: any): void {\r\n    const selected = model?.values ?? this.options.map(o => o.value);\r\n    this.options.forEach(o => o.selected = selected.includes(o.value));\r\n    this.updateFilteredOptions();\r\n  }\r\n\r\n  onSelectionChange(): void {\r\n    this.params.filterChangedCallback();\r\n  }\r\n\r\n  onSearchChange(): void {\r\n    this.updateFilteredOptions();\r\n  }\r\n\r\n  onSelectAllChange(): void {    \r\n    this.setAll(this.selectAll);\r\n  }\r\n\r\n  private parseKey(key: string): boolean | number | string {\r\n    if (key === 'true') return true;\r\n    if (key === 'false') return false;\r\n    const num = Number(key);\r\n    return isNaN(num) ? key : num;\r\n  }\r\n\r\n  private setAll(select: boolean): void {\r\n    this.options.forEach(o => o.selected = select);\r\n    this.updateFilteredOptions();\r\n    this.params.filterChangedCallback();\r\n  }\r\n\r\n  private updateFilteredOptions(): void {\r\n    const search = this.searchText.toLowerCase();\r\n    this.filteredOptions = this.options.filter(o =>\r\n      o.label.toLowerCase().includes(search)\r\n    );\r\n  }\r\n\r\n  private resolvePath(obj: any, path: string): any {\r\n    return path.split('.').reduce((acc, part) => acc?.[part], obj);\r\n  }\r\n}\r\n","<div style=\"padding: 5px;background-color: white;\">\r\n\r\n  <div style=\"padding: 5px\">\r\n    <ngx-sirio-input type=\"text\"\r\n                     [placeholder]=\"Texts.TypeToSearch\"\r\n                     [(ngModel)]=\"searchText\"\r\n                     (ngModelChange)=\"onSearchChange()\">\r\n    </ngx-sirio-input>\r\n  </div>\r\n\r\n  <div style=\"padding: 5px; max-height: 200px; overflow-y: auto;\">\r\n    <ngx-sirio-checkbox [(ngModel)]=\"selectAll\" (ngModelChange)=\"onSelectAllChange()\">{{Texts.SelectAll}}</ngx-sirio-checkbox>\r\n\r\n    <ngx-sirio-checkbox-group>\r\n      <ngx-sirio-checkbox *ngFor=\"let option of filteredOptions\"\r\n                          [(ngModel)]=\"option.selected\"\r\n                          [value]=\"option.value\"\r\n                          (change)=\"onSelectionChange()\">\r\n        {{ option.label }}\r\n      </ngx-sirio-checkbox>\r\n    </ngx-sirio-checkbox-group>\r\n  </div>\r\n\r\n</div>\r\n"]}
@@ -6,12 +6,18 @@ import { SirioDialogComponent, SirioDialogBodyComponent, SirioDialogHeaderCompon
6
6
  import { Texts } from '../locale/locale';
7
7
  import { localize } from '../locale/localize';
8
8
  import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/common";
9
+ import * as i1 from "@wemake4u/interact";
10
+ import * as i2 from "@angular/common";
10
11
  export class DialogComponent extends SirioDialogElement {
12
+ languageService;
11
13
  formHost;
12
14
  formRef;
13
15
  dynamicFormType;
14
16
  Texts = Texts;
17
+ constructor(languageService) {
18
+ super();
19
+ this.languageService = languageService;
20
+ }
15
21
  ngOnInit() {
16
22
  this.options = this.data.options ?? {};
17
23
  this.currentValue = this.options.value;
@@ -24,7 +30,6 @@ export class DialogComponent extends SirioDialogElement {
24
30
  const componentRef = this.formHost.createComponent(this.dynamicFormType, { injector });
25
31
  const instance = componentRef.instance;
26
32
  componentRef.setInput('schema', this.data.formSchema);
27
- componentRef.setInput('language', this.data.language);
28
33
  componentRef.setInput('value', this.options.value ?? {});
29
34
  componentRef.setInput('showNav', this.options.showNav ?? false);
30
35
  componentRef.setInput('showNavButton', this.options.showNavButton ?? false);
@@ -63,13 +68,16 @@ export class DialogComponent extends SirioDialogElement {
63
68
  return (this.formRef?.instance?.formGroup?.valid ?? true) !== true;
64
69
  }
65
70
  locale(component, key) {
66
- return localize(this.options.language ?? '', component, key);
71
+ return localize(this.language, component, key);
67
72
  }
68
73
  destroy$ = new Subject();
69
74
  currentValue;
70
75
  setCurrentValue(value) {
71
76
  this.currentValue = value;
72
77
  }
78
+ get language() {
79
+ return this.languageService.getLanguage();
80
+ }
73
81
  SendResult(action) {
74
82
  if (typeof this.options.onResult === 'function') {
75
83
  const result = {
@@ -79,8 +87,8 @@ export class DialogComponent extends SirioDialogElement {
79
87
  this.options.onResult(result);
80
88
  }
81
89
  }
82
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DialogComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
83
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DialogComponent, isStandalone: true, selector: "dynamic-dialog", viewQueries: [{ propertyName: "formHost", first: true, predicate: ["formHost"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: "<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n dialog\r\n [type]=\"options.type ?? 'info'\"\r\n [size]=\"options.size ?? 'default'\"\r\n [isDrawer]=\"options.isDrawer ?? false\"\r\n [withCloseButton]=\"showCloseButton()\">\r\n\r\n <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n </ngx-sirio-dialog-header>\r\n\r\n <ngx-sirio-dialog-body>\r\n <ng-template #formHost></ng-template>\r\n </ngx-sirio-dialog-body>\r\n\r\n <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n <ng-container [ngSwitch]=\"options.buttons\">\r\n <!-- OK -->\r\n <ng-container *ngSwitchCase=\"'OK'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: OKCancel -->\r\n <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: ConfirmClose -->\r\n <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: AbortRetryIgnore -->\r\n <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNoCancel -->\r\n <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNo -->\r\n <ng-container *ngSwitchCase=\"'YesNo'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: RetryCancel -->\r\n <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: CancelTryContinue -->\r\n <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- Templates -->\r\n <ng-template #confirmTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n [disabled]=\"isInvalid()\"\r\n color=\"primary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #closeTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n color=\"secondary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n\r\n </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n", styles: ["::ng-deep .sirio-dialog{background-color:#0000007f!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: DialogDirective, selector: "[dialog]" }, { kind: "component", type: SirioDialogComponent, selector: "ngx-sirio-dialog", inputs: ["type", "size", "drawerContext", "withCloseButton", "isDrawer", "dialogId"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioDialogBodyComponent, selector: "ngx-sirio-dialog-body" }, { kind: "component", type: SirioDialogHeaderComponent, selector: "ngx-sirio-dialog-header", inputs: ["closeButtonAriaLabel"], outputs: ["closeEvent"] }, { kind: "component", type: SirioDialogFooterComponent, selector: "ngx-sirio-dialog-footer", inputs: ["actionsLabel"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioButtonComponent, selector: "ngx-sirio-button", inputs: ["ariaExpanded", "ariaControls", "ariaActivedescendant", "ariaHaspopup", "ariaLabel", "ariaRequired", "ariaInvalid", "ariaDescribedby", "icon", "title", "role", "color", "isFloating", "isExtended", "isLight", "isSmall", "disabled", "isDropdown", "type", "dismissType", "isBtnBlock"], outputs: ["clickEvent", "focusEvent", "blurEvent"] }, { kind: "component", type: SirioDialogTitleComponent, selector: "ngx-sirio-dialog-title" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
90
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DialogComponent, deps: [{ token: i1.LanguageService }], target: i0.ɵɵFactoryTarget.Component });
91
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DialogComponent, isStandalone: true, selector: "dynamic-dialog", viewQueries: [{ propertyName: "formHost", first: true, predicate: ["formHost"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: "<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n dialog\r\n [type]=\"options.type ?? 'info'\"\r\n [size]=\"options.size ?? 'default'\"\r\n [isDrawer]=\"options.isDrawer ?? false\"\r\n [withCloseButton]=\"showCloseButton()\">\r\n\r\n <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n </ngx-sirio-dialog-header>\r\n\r\n <ngx-sirio-dialog-body>\r\n <ng-template #formHost></ng-template>\r\n </ngx-sirio-dialog-body>\r\n\r\n <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n <ng-container [ngSwitch]=\"options.buttons\">\r\n <!-- OK -->\r\n <ng-container *ngSwitchCase=\"'OK'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: OKCancel -->\r\n <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: ConfirmClose -->\r\n <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: AbortRetryIgnore -->\r\n <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNoCancel -->\r\n <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNo -->\r\n <ng-container *ngSwitchCase=\"'YesNo'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: RetryCancel -->\r\n <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: CancelTryContinue -->\r\n <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- Templates -->\r\n <ng-template #confirmTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n [disabled]=\"isInvalid()\"\r\n color=\"primary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #closeTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n color=\"secondary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n\r\n </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n", styles: ["::ng-deep .sirio-dialog{background-color:#0000007f!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: DialogDirective, selector: "[dialog]" }, { kind: "component", type: SirioDialogComponent, selector: "ngx-sirio-dialog", inputs: ["type", "size", "drawerContext", "withCloseButton", "isDrawer", "dialogId"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioDialogBodyComponent, selector: "ngx-sirio-dialog-body" }, { kind: "component", type: SirioDialogHeaderComponent, selector: "ngx-sirio-dialog-header", inputs: ["closeButtonAriaLabel"], outputs: ["closeEvent"] }, { kind: "component", type: SirioDialogFooterComponent, selector: "ngx-sirio-dialog-footer", inputs: ["actionsLabel"], outputs: ["closeEvent", "confirmEvent"] }, { kind: "component", type: SirioButtonComponent, selector: "ngx-sirio-button", inputs: ["ariaExpanded", "ariaControls", "ariaActivedescendant", "ariaHaspopup", "ariaLabel", "ariaRequired", "ariaInvalid", "ariaDescribedby", "icon", "title", "role", "color", "isFloating", "isExtended", "isLight", "isSmall", "disabled", "isDropdown", "type", "dismissType", "isBtnBlock"], outputs: ["clickEvent", "focusEvent", "blurEvent"] }, { kind: "component", type: SirioDialogTitleComponent, selector: "ngx-sirio-dialog-title" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
84
92
  }
85
93
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DialogComponent, decorators: [{
86
94
  type: Component,
@@ -95,8 +103,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
95
103
  SirioDialogActionDirective,
96
104
  SirioDialogTitleComponent
97
105
  ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n dialog\r\n [type]=\"options.type ?? 'info'\"\r\n [size]=\"options.size ?? 'default'\"\r\n [isDrawer]=\"options.isDrawer ?? false\"\r\n [withCloseButton]=\"showCloseButton()\">\r\n\r\n <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n </ngx-sirio-dialog-header>\r\n\r\n <ngx-sirio-dialog-body>\r\n <ng-template #formHost></ng-template>\r\n </ngx-sirio-dialog-body>\r\n\r\n <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n <ng-container [ngSwitch]=\"options.buttons\">\r\n <!-- OK -->\r\n <ng-container *ngSwitchCase=\"'OK'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: OKCancel -->\r\n <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: ConfirmClose -->\r\n <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: AbortRetryIgnore -->\r\n <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNoCancel -->\r\n <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: YesNo -->\r\n <ng-container *ngSwitchCase=\"'YesNo'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: RetryCancel -->\r\n <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n </ng-container>\r\n <!-- Caso: CancelTryContinue -->\r\n <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <!-- Templates -->\r\n <ng-template #confirmTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n [disabled]=\"isInvalid()\"\r\n color=\"primary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n <ng-template #closeTemplate let-action=\"action\">\r\n <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n color=\"secondary\">\r\n {{ locale(Texts, action) }}\r\n </ngx-sirio-button>\r\n </ng-template>\r\n\r\n </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n", styles: ["::ng-deep .sirio-dialog{background-color:#0000007f!important}\n"] }]
98
- }], propDecorators: { formHost: [{
106
+ }], ctorParameters: () => [{ type: i1.LanguageService }], propDecorators: { formHost: [{
99
107
  type: ViewChild,
100
108
  args: ['formHost', { read: ViewContainerRef, static: true }]
101
109
  }] } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.ts","../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, ChangeDetectionStrategy, ViewContainerRef, ViewChild, ComponentRef, Type\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { FormDialogOptions, DialogAction, DialogResult } from '../services/dialog.service';\r\nimport { DialogDirective } from '../directives/dialog.directive';\r\nimport {\r\n  SirioDialogComponent, SirioDialogBodyComponent, SirioDialogHeaderComponent\r\n  , SirioDialogFooterComponent, SirioButtonComponent, SirioDialogActionDirective\r\n  , SirioDialogTitleComponent, SirioDialogElement\r\n} from 'ngx-sirio-lib';\r\n\r\nimport { Texts } from '../locale/locale';\r\nimport { localize } from '../locale/localize';\r\n\r\n@Component({\r\n  selector: 'dynamic-dialog',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    DialogDirective,\r\n    SirioDialogComponent,\r\n    SirioDialogBodyComponent,\r\n    SirioDialogHeaderComponent,\r\n    SirioDialogFooterComponent,\r\n    SirioButtonComponent,\r\n    SirioDialogActionDirective,\r\n    SirioDialogTitleComponent    \r\n  ],\r\n  templateUrl: './dialog.component.html',\r\n  styleUrl: './dialog.component.css',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DialogComponent extends SirioDialogElement {\r\n  @ViewChild('formHost', { read: ViewContainerRef, static: true })\r\n  private formHost!: ViewContainerRef;\r\n  private formRef!: ComponentRef<any>\r\n  private dynamicFormType!: Type<any>;\r\n  Texts = Texts;\r\n\r\n  ngOnInit() {\r\n    this.options = this.data.options ?? {};\r\n    this.currentValue = this.options.value;\r\n    this.dynamicFormType = this.data.dynamicFormType;\r\n  }\r\n\r\n  options: FormDialogOptions = { };\r\n  \r\n  ngAfterViewInit() {\r\n\r\n    let injector = this.options.injector\r\n      ?? this.formHost.injector;\r\n\r\n    const componentRef = this.formHost.createComponent(this.dynamicFormType, { injector });\r\n    const instance = componentRef.instance as any;\r\n\r\n    componentRef.setInput('schema', this.data.formSchema);\r\n    componentRef.setInput('language', this.data.language);\r\n    componentRef.setInput('value', this.options.value ?? { });\r\n    componentRef.setInput('showNav', this.options.showNav ?? false);\r\n    componentRef.setInput('showNavButton', this.options.showNavButton ?? false);\r\n    componentRef.setInput('showProgress', this.options.showProgress ?? false);\r\n    componentRef.setInput('showFormTitle', this.options.showFormTitle ?? false);\r\n\r\n    instance.valueChange\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((value: any) => this.setCurrentValue(value));\r\n\r\n    this.formRef = componentRef;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  doClose() {\r\n    this.doAction('Close');\r\n  }\r\n\r\n  doAction(action: DialogAction) {\r\n    this.sirioDialogService.closeDialog();\r\n    this.SendResult(action);    \r\n  }\r\n\r\n  showHeader(): boolean {\r\n    return this.showTitle() || this.showCloseButton();    \r\n  }\r\n\r\n  showTitle(): boolean {\r\n    return this.options.title ? true: false;\r\n  }\r\n\r\n  showCloseButton(): boolean {\r\n    const result = this.options.closeButton === true;\r\n    return result;\r\n  }\r\n\r\n  showFooter(): boolean {\r\n    return this.options.buttons !== undefined;\r\n  }\r\n\r\n  isInvalid(): boolean {\r\n    return (this.formRef?.instance?.formGroup?.valid ?? true) !== true;\r\n  }\r\n\r\n  locale(component: any, key: string): string {\r\n    return localize(this.options.language ?? '', component, key);\r\n  }\r\n\r\n  private destroy$ = new Subject<void>();\r\n\r\n  private currentValue: any;\r\n\r\n  private setCurrentValue(value: any): void {\r\n    this.currentValue = value;\r\n  }\r\n\r\n  private SendResult(action: DialogAction) {\r\n    if (typeof this.options.onResult === 'function') {\r\n      const result: DialogResult = {\r\n        action: action,\r\n        value: this.currentValue\r\n      };\r\n      this.options.onResult(result);\r\n    }\r\n  }\r\n}\r\n","<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n                  dialog\r\n                  [type]=\"options.type ?? 'info'\"\r\n                  [size]=\"options.size ?? 'default'\"\r\n                  [isDrawer]=\"options.isDrawer ?? false\"\r\n                  [withCloseButton]=\"showCloseButton()\">\r\n\r\n  <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n    <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n  </ngx-sirio-dialog-header>\r\n\r\n  <ngx-sirio-dialog-body>\r\n    <ng-template #formHost></ng-template>\r\n  </ngx-sirio-dialog-body>\r\n\r\n  <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n    <ng-container [ngSwitch]=\"options.buttons\">\r\n      <!-- OK -->\r\n      <ng-container *ngSwitchCase=\"'OK'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: OKCancel -->\r\n      <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: ConfirmClose -->\r\n      <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: AbortRetryIgnore -->\r\n      <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNoCancel -->\r\n      <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNo -->\r\n      <ng-container *ngSwitchCase=\"'YesNo'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: RetryCancel -->\r\n      <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: CancelTryContinue -->\r\n      <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n      </ng-container>\r\n    </ng-container>\r\n    <!-- Templates -->\r\n    <ng-template #confirmTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        [disabled]=\"isInvalid()\"\r\n                        color=\"primary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n    <ng-template #closeTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        color=\"secondary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n\r\n  </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.ts","../../../../../projects/ngx-sirio/src/lib/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, ChangeDetectionStrategy, ViewContainerRef, ViewChild, ComponentRef, Type\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { FormDialogOptions, DialogAction, DialogResult } from '../services/dialog.service';\r\nimport { DialogDirective } from '../directives/dialog.directive';\r\nimport {\r\n  SirioDialogComponent, SirioDialogBodyComponent, SirioDialogHeaderComponent\r\n  , SirioDialogFooterComponent, SirioButtonComponent, SirioDialogActionDirective\r\n  , SirioDialogTitleComponent, SirioDialogElement\r\n} from 'ngx-sirio-lib';\r\n\r\nimport { LanguageService } from '@wemake4u/interact';\r\nimport { Texts } from '../locale/locale';\r\nimport { localize } from '../locale/localize';\r\n\r\n@Component({\r\n  selector: 'dynamic-dialog',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    DialogDirective,\r\n    SirioDialogComponent,\r\n    SirioDialogBodyComponent,\r\n    SirioDialogHeaderComponent,\r\n    SirioDialogFooterComponent,\r\n    SirioButtonComponent,\r\n    SirioDialogActionDirective,\r\n    SirioDialogTitleComponent    \r\n  ],\r\n  templateUrl: './dialog.component.html',\r\n  styleUrl: './dialog.component.css',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DialogComponent extends SirioDialogElement {\r\n  @ViewChild('formHost', { read: ViewContainerRef, static: true })\r\n  private formHost!: ViewContainerRef;\r\n  private formRef!: ComponentRef<any>\r\n  private dynamicFormType!: Type<any>;\r\n  Texts = Texts;\r\n\r\n  constructor(private languageService: LanguageService) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.options = this.data.options ?? {};\r\n    this.currentValue = this.options.value;\r\n    this.dynamicFormType = this.data.dynamicFormType;\r\n  }\r\n\r\n  options: FormDialogOptions = { };\r\n  \r\n  ngAfterViewInit() {\r\n\r\n    let injector = this.options.injector\r\n      ?? this.formHost.injector;\r\n\r\n    const componentRef = this.formHost.createComponent(this.dynamicFormType, { injector });\r\n    const instance = componentRef.instance as any;\r\n\r\n    componentRef.setInput('schema', this.data.formSchema);\r\n    componentRef.setInput('value', this.options.value ?? { });\r\n    componentRef.setInput('showNav', this.options.showNav ?? false);\r\n    componentRef.setInput('showNavButton', this.options.showNavButton ?? false);\r\n    componentRef.setInput('showProgress', this.options.showProgress ?? false);\r\n    componentRef.setInput('showFormTitle', this.options.showFormTitle ?? false);\r\n\r\n    instance.valueChange\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((value: any) => this.setCurrentValue(value));\r\n\r\n    this.formRef = componentRef;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  doClose() {\r\n    this.doAction('Close');\r\n  }\r\n\r\n  doAction(action: DialogAction) {\r\n    this.sirioDialogService.closeDialog();\r\n    this.SendResult(action);    \r\n  }\r\n\r\n  showHeader(): boolean {\r\n    return this.showTitle() || this.showCloseButton();    \r\n  }\r\n\r\n  showTitle(): boolean {\r\n    return this.options.title ? true: false;\r\n  }\r\n\r\n  showCloseButton(): boolean {\r\n    const result = this.options.closeButton === true;\r\n    return result;\r\n  }\r\n\r\n  showFooter(): boolean {\r\n    return this.options.buttons !== undefined;\r\n  }\r\n\r\n  isInvalid(): boolean {\r\n    return (this.formRef?.instance?.formGroup?.valid ?? true) !== true;\r\n  }\r\n\r\n  locale(component: any, key: string): string {\r\n    return localize(this.language, component, key);\r\n  }\r\n\r\n  private destroy$ = new Subject<void>();\r\n\r\n  private currentValue: any;\r\n\r\n  private setCurrentValue(value: any): void {\r\n    this.currentValue = value;\r\n  }\r\n\r\n  private get language(): string {\r\n    return this.languageService.getLanguage();\r\n  }\r\n\r\n  private SendResult(action: DialogAction) {\r\n    if (typeof this.options.onResult === 'function') {\r\n      const result: DialogResult = {\r\n        action: action,\r\n        value: this.currentValue\r\n      };\r\n      this.options.onResult(result);\r\n    }\r\n  }\r\n}\r\n","<ngx-sirio-dialog (closeEvent)=\"doClose()\"\r\n                  dialog\r\n                  [type]=\"options.type ?? 'info'\"\r\n                  [size]=\"options.size ?? 'default'\"\r\n                  [isDrawer]=\"options.isDrawer ?? false\"\r\n                  [withCloseButton]=\"showCloseButton()\">\r\n\r\n  <ngx-sirio-dialog-header [hidden]=\"!showHeader()\">\r\n    <ngx-sirio-dialog-title [hidden]=\"!showTitle()\">{{ options.title }}</ngx-sirio-dialog-title>\r\n  </ngx-sirio-dialog-header>\r\n\r\n  <ngx-sirio-dialog-body>\r\n    <ng-template #formHost></ng-template>\r\n  </ngx-sirio-dialog-body>\r\n\r\n  <ngx-sirio-dialog-footer *ngIf=\"showFooter()\">\r\n    <ng-container [ngSwitch]=\"options.buttons\">\r\n      <!-- OK -->\r\n      <ng-container *ngSwitchCase=\"'OK'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: OKCancel -->\r\n      <ng-container *ngSwitchCase=\"'OKCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'OK' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: ConfirmClose -->\r\n      <ng-container *ngSwitchCase=\"'ConfirmCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Confirm' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: AbortRetryIgnore -->\r\n      <ng-container *ngSwitchCase=\"'AbortRetryIgnore'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Abort' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Ignore' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNoCancel -->\r\n      <ng-container *ngSwitchCase=\"'YesNoCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: YesNo -->\r\n      <ng-container *ngSwitchCase=\"'YesNo'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Yes' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'No' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: RetryCancel -->\r\n      <ng-container *ngSwitchCase=\"'RetryCancel'\">\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Retry' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n      </ng-container>\r\n      <!-- Caso: CancelTryContinue -->\r\n      <ng-container *ngSwitchCase=\"'CancelTryContinue'\">\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Cancel' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"confirmTemplate; context: { action: 'Try' }\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"closeTemplate; context: { action: 'Continue' }\"></ng-container>\r\n      </ng-container>\r\n    </ng-container>\r\n    <!-- Templates -->\r\n    <ng-template #confirmTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        [disabled]=\"isInvalid()\"\r\n                        color=\"primary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n    <ng-template #closeTemplate let-action=\"action\">\r\n      <ngx-sirio-button (clickEvent)=\"doAction(action)\"\r\n                        color=\"secondary\">\r\n        {{ locale(Texts, action) }}\r\n      </ngx-sirio-button>\r\n    </ng-template>\r\n\r\n  </ngx-sirio-dialog-footer>\r\n\r\n</ngx-sirio-dialog>\r\n"]}