@decaf-ts/for-angular 0.0.11 → 0.0.12

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 (97) hide show
  1. package/dist/for-angular/cli/cli-module.d.ts +22 -0
  2. package/dist/for-angular/cli/cli-module.d.ts.map +1 -0
  3. package/dist/for-angular/cli/cli-module.js +131 -0
  4. package/dist/for-angular/cli/cli-module.js.map +1 -0
  5. package/dist/lib/components/component-renderer/component-renderer.component.d.ts +1 -0
  6. package/dist/lib/components/component-renderer/component-renderer.component.d.ts.map +1 -0
  7. package/dist/lib/components/crud-field/crud-field.component.d.ts +1 -0
  8. package/dist/lib/components/crud-field/crud-field.component.d.ts.map +1 -0
  9. package/dist/lib/components/crud-form/constants.d.ts +1 -0
  10. package/dist/lib/components/crud-form/constants.d.ts.map +1 -0
  11. package/dist/lib/components/crud-form/crud-form.component.d.ts +1 -0
  12. package/dist/lib/components/crud-form/crud-form.component.d.ts.map +1 -0
  13. package/dist/lib/components/crud-form/types.d.ts +1 -0
  14. package/dist/lib/components/crud-form/types.d.ts.map +1 -0
  15. package/dist/lib/components/empty-state/empty-state.component.d.ts +1 -0
  16. package/dist/lib/components/empty-state/empty-state.component.d.ts.map +1 -0
  17. package/dist/lib/components/fieldset/fieldset.component.d.ts +1 -0
  18. package/dist/lib/components/fieldset/fieldset.component.d.ts.map +1 -0
  19. package/dist/lib/components/filter/filter.component.d.ts +1 -0
  20. package/dist/lib/components/filter/filter.component.d.ts.map +1 -0
  21. package/dist/lib/components/for-angular-components.module.d.ts +1 -0
  22. package/dist/lib/components/for-angular-components.module.d.ts.map +1 -0
  23. package/dist/lib/components/index.d.ts +1 -0
  24. package/dist/lib/components/index.d.ts.map +1 -0
  25. package/dist/lib/components/layout/layout.component.d.ts +1 -0
  26. package/dist/lib/components/layout/layout.component.d.ts.map +1 -0
  27. package/dist/lib/components/list/constants.d.ts +1 -0
  28. package/dist/lib/components/list/constants.d.ts.map +1 -0
  29. package/dist/lib/components/list/list.component.d.ts +1 -0
  30. package/dist/lib/components/list/list.component.d.ts.map +1 -0
  31. package/dist/lib/components/list-item/list-item.component.d.ts +1 -0
  32. package/dist/lib/components/list-item/list-item.component.d.ts.map +1 -0
  33. package/dist/lib/components/model-renderer/model-renderer.component.d.ts +1 -0
  34. package/dist/lib/components/model-renderer/model-renderer.component.d.ts.map +1 -0
  35. package/dist/lib/components/pagination/constants.d.ts +1 -0
  36. package/dist/lib/components/pagination/constants.d.ts.map +1 -0
  37. package/dist/lib/components/pagination/pagination.component.d.ts +1 -0
  38. package/dist/lib/components/pagination/pagination.component.d.ts.map +1 -0
  39. package/dist/lib/components/searchbar/searchbar.component.d.ts +1 -0
  40. package/dist/lib/components/searchbar/searchbar.component.d.ts.map +1 -0
  41. package/dist/lib/decaf-ts-for-angular.d.ts.map +1 -0
  42. package/dist/lib/directives/collapsable.directive.d.ts +1 -0
  43. package/dist/lib/directives/collapsable.directive.d.ts.map +1 -0
  44. package/dist/lib/directives/index.d.ts +1 -0
  45. package/dist/lib/directives/index.d.ts.map +1 -0
  46. package/dist/lib/engine/DynamicModule.d.ts +1 -0
  47. package/dist/lib/engine/DynamicModule.d.ts.map +1 -0
  48. package/dist/lib/engine/NgxBaseComponent.d.ts +1 -0
  49. package/dist/lib/engine/NgxBaseComponent.d.ts.map +1 -0
  50. package/dist/lib/engine/NgxCrudFormField.d.ts +1 -0
  51. package/dist/lib/engine/NgxCrudFormField.d.ts.map +1 -0
  52. package/dist/lib/engine/NgxFormService.d.ts +1 -0
  53. package/dist/lib/engine/NgxFormService.d.ts.map +1 -0
  54. package/dist/lib/engine/NgxRenderingEngine.d.ts +1 -0
  55. package/dist/lib/engine/NgxRenderingEngine.d.ts.map +1 -0
  56. package/dist/lib/engine/NgxRenderingEngine2.d.ts +1 -0
  57. package/dist/lib/engine/NgxRenderingEngine2.d.ts.map +1 -0
  58. package/dist/lib/engine/ValidatorFactory.d.ts +1 -0
  59. package/dist/lib/engine/ValidatorFactory.d.ts.map +1 -0
  60. package/dist/lib/engine/constants.d.ts +1 -0
  61. package/dist/lib/engine/constants.d.ts.map +1 -0
  62. package/dist/lib/engine/decorators.d.ts +1 -0
  63. package/dist/lib/engine/decorators.d.ts.map +1 -0
  64. package/dist/lib/engine/index.d.ts +1 -0
  65. package/dist/lib/engine/index.d.ts.map +1 -0
  66. package/dist/lib/engine/types.d.ts +1 -0
  67. package/dist/lib/engine/types.d.ts.map +1 -0
  68. package/dist/lib/esm2022/components/component-renderer/component-renderer.component.mjs +70 -24
  69. package/dist/lib/esm2022/components/crud-field/crud-field.component.mjs +271 -116
  70. package/dist/lib/esm2022/components/crud-form/crud-form.component.mjs +170 -37
  71. package/dist/lib/esm2022/components/empty-state/empty-state.component.mjs +103 -41
  72. package/dist/lib/esm2022/components/fieldset/fieldset.component.mjs +41 -16
  73. package/dist/lib/esm2022/components/filter/filter.component.mjs +248 -31
  74. package/dist/lib/esm2022/components/for-angular-components.module.mjs +38 -37
  75. package/dist/lib/esm2022/components/layout/layout.component.mjs +84 -15
  76. package/dist/lib/esm2022/components/list/list.component.mjs +252 -83
  77. package/dist/lib/esm2022/components/list-item/list-item.component.mjs +250 -46
  78. package/dist/lib/esm2022/components/model-renderer/model-renderer.component.mjs +66 -22
  79. package/dist/lib/esm2022/components/pagination/pagination.component.mjs +58 -17
  80. package/dist/lib/esm2022/components/searchbar/searchbar.component.mjs +66 -56
  81. package/dist/lib/esm2022/directives/collapsable.directive.mjs +10 -10
  82. package/dist/lib/esm2022/engine/NgxBaseComponent.mjs +53 -46
  83. package/dist/lib/esm2022/for-angular.module.mjs +40 -39
  84. package/dist/lib/fesm2022/decaf-ts-for-angular.mjs +1805 -621
  85. package/dist/lib/fesm2022/decaf-ts-for-angular.mjs.map +1 -1
  86. package/dist/lib/for-angular.module.d.ts +1 -0
  87. package/dist/lib/for-angular.module.d.ts.map +1 -0
  88. package/dist/lib/helpers/index.d.ts +1 -0
  89. package/dist/lib/helpers/index.d.ts.map +1 -0
  90. package/dist/lib/helpers/utils.d.ts +1 -0
  91. package/dist/lib/helpers/utils.d.ts.map +1 -0
  92. package/dist/lib/index.d.ts +1 -0
  93. package/dist/lib/interfaces.d.ts +1 -0
  94. package/dist/lib/interfaces.d.ts.map +1 -0
  95. package/dist/lib/public-apis.d.ts +1 -0
  96. package/dist/lib/public-apis.d.ts.map +1 -0
  97. package/package.json +3 -2
@@ -10,6 +10,128 @@ import { IonIcon } from '@ionic/angular/standalone';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "@ionic/angular/standalone";
12
12
  import * as i2 from "@angular/forms";
13
+ const _c0 = ["reactiveForm"];
14
+ const _c1 = ["*"];
15
+ const _c2 = () => ["create", "update"];
16
+ const _c3 = () => ["delete", "read", "update"];
17
+ function CrudFormComponent_Conditional_0_Conditional_6_Template(rf, ctx) { if (rf & 1) {
18
+ i0.ɵɵelement(0, "ion-icon", 6);
19
+ } if (rf & 2) {
20
+ const ctx_r1 = i0.ɵɵnextContext(2);
21
+ i0.ɵɵproperty("slot", ctx_r1.options.buttons.submit.iconSlot)("name", ctx_r1.options.buttons.submit.icon);
22
+ } }
23
+ function CrudFormComponent_Conditional_0_Conditional_9_Conditional_1_Template(rf, ctx) { if (rf & 1) {
24
+ i0.ɵɵelement(0, "ion-icon", 6);
25
+ } if (rf & 2) {
26
+ const ctx_r1 = i0.ɵɵnextContext(3);
27
+ i0.ɵɵproperty("slot", ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.iconSlot)("name", ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.icon);
28
+ } }
29
+ function CrudFormComponent_Conditional_0_Conditional_9_Template(rf, ctx) { if (rf & 1) {
30
+ const _r3 = i0.ɵɵgetCurrentView();
31
+ i0.ɵɵelementStart(0, "ion-button", 8);
32
+ i0.ɵɵlistener("click", function CrudFormComponent_Conditional_0_Conditional_9_Template_ion_button_click_0_listener() { i0.ɵɵrestoreView(_r3); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.handleReset()); });
33
+ i0.ɵɵtemplate(1, CrudFormComponent_Conditional_0_Conditional_9_Conditional_1_Template, 1, 2, "ion-icon", 6);
34
+ i0.ɵɵtext(2);
35
+ i0.ɵɵelementEnd();
36
+ } if (rf & 2) {
37
+ const ctx_r1 = i0.ɵɵnextContext(2);
38
+ i0.ɵɵadvance();
39
+ i0.ɵɵconditional((ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.icon) ? 1 : -1);
40
+ i0.ɵɵadvance();
41
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpureFunction0(2, _c2).includes(ctx_r1.operation) ? "Back" : ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.text, " ");
42
+ } }
43
+ function CrudFormComponent_Conditional_0_Template(rf, ctx) { if (rf & 1) {
44
+ const _r1 = i0.ɵɵgetCurrentView();
45
+ i0.ɵɵelementStart(0, "form", 3, 0);
46
+ i0.ɵɵlistener("submit", function CrudFormComponent_Conditional_0_Template_form_submit_0_listener($event) { i0.ɵɵrestoreView(_r1); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.submit($event)); });
47
+ i0.ɵɵprojection(2, 0, ["#formContent", ""]);
48
+ i0.ɵɵelementStart(3, "div", 4)(4, "div")(5, "ion-button", 5);
49
+ i0.ɵɵtemplate(6, CrudFormComponent_Conditional_0_Conditional_6_Template, 1, 2, "ion-icon", 6);
50
+ i0.ɵɵtext(7);
51
+ i0.ɵɵelementEnd()();
52
+ i0.ɵɵelementStart(8, "div");
53
+ i0.ɵɵtemplate(9, CrudFormComponent_Conditional_0_Conditional_9_Template, 3, 3, "ion-button", 7);
54
+ i0.ɵɵelementEnd()()();
55
+ } if (rf & 2) {
56
+ const ctx_r1 = i0.ɵɵnextContext();
57
+ i0.ɵɵproperty("id", ctx_r1.rendererId)("formGroup", ctx_r1.formGroup)("target", ctx_r1.target);
58
+ i0.ɵɵadvance(6);
59
+ i0.ɵɵconditional(ctx_r1.options.buttons.submit.icon ? 6 : -1);
60
+ i0.ɵɵadvance();
61
+ i0.ɵɵtextInterpolate1(" ", ctx_r1.action ? ctx_r1.action : ctx_r1.options.buttons.submit.text, " ");
62
+ i0.ɵɵadvance(2);
63
+ i0.ɵɵconditional(ctx_r1.options.buttons.clear ? 9 : -1);
64
+ } }
65
+ function CrudFormComponent_Conditional_1_Conditional_1_Conditional_2_Template(rf, ctx) { if (rf & 1) {
66
+ i0.ɵɵelement(0, "ion-icon", 6);
67
+ } if (rf & 2) {
68
+ const ctx_r1 = i0.ɵɵnextContext(3);
69
+ i0.ɵɵproperty("slot", ctx_r1.options.buttons.submit.iconSlot)("name", ctx_r1.options.buttons.submit.icon);
70
+ } }
71
+ function CrudFormComponent_Conditional_1_Conditional_1_Template(rf, ctx) { if (rf & 1) {
72
+ const _r4 = i0.ɵɵgetCurrentView();
73
+ i0.ɵɵelementStart(0, "div")(1, "ion-button", 10);
74
+ i0.ɵɵlistener("click", function CrudFormComponent_Conditional_1_Conditional_1_Template_ion_button_click_1_listener() { i0.ɵɵrestoreView(_r4); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.handleDelete()); });
75
+ i0.ɵɵtemplate(2, CrudFormComponent_Conditional_1_Conditional_1_Conditional_2_Template, 1, 2, "ion-icon", 6);
76
+ i0.ɵɵtext(3, " Delete ");
77
+ i0.ɵɵelementEnd()();
78
+ } if (rf & 2) {
79
+ const ctx_r1 = i0.ɵɵnextContext(2);
80
+ i0.ɵɵadvance(2);
81
+ i0.ɵɵconditional(ctx_r1.options.buttons.submit.icon ? 2 : -1);
82
+ } }
83
+ function CrudFormComponent_Conditional_1_Conditional_2_Conditional_2_Template(rf, ctx) { if (rf & 1) {
84
+ i0.ɵɵelement(0, "ion-icon", 6);
85
+ } if (rf & 2) {
86
+ const ctx_r1 = i0.ɵɵnextContext(3);
87
+ i0.ɵɵproperty("slot", ctx_r1.options.buttons.submit.iconSlot)("name", ctx_r1.options.buttons.submit.icon);
88
+ } }
89
+ function CrudFormComponent_Conditional_1_Conditional_2_Template(rf, ctx) { if (rf & 1) {
90
+ i0.ɵɵelementStart(0, "div")(1, "ion-button", 5);
91
+ i0.ɵɵtemplate(2, CrudFormComponent_Conditional_1_Conditional_2_Conditional_2_Template, 1, 2, "ion-icon", 6);
92
+ i0.ɵɵtext(3);
93
+ i0.ɵɵelementEnd()();
94
+ } if (rf & 2) {
95
+ const ctx_r1 = i0.ɵɵnextContext(2);
96
+ i0.ɵɵadvance(2);
97
+ i0.ɵɵconditional(ctx_r1.options.buttons.submit.icon ? 2 : -1);
98
+ i0.ɵɵadvance();
99
+ i0.ɵɵtextInterpolate1(" ", ctx_r1.options.buttons.submit.text, " ");
100
+ } }
101
+ function CrudFormComponent_Conditional_1_Conditional_3_Conditional_2_Template(rf, ctx) { if (rf & 1) {
102
+ i0.ɵɵelement(0, "ion-icon", 6);
103
+ } if (rf & 2) {
104
+ const ctx_r1 = i0.ɵɵnextContext(3);
105
+ i0.ɵɵproperty("slot", ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.iconSlot)("name", ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.icon);
106
+ } }
107
+ function CrudFormComponent_Conditional_1_Conditional_3_Template(rf, ctx) { if (rf & 1) {
108
+ const _r5 = i0.ɵɵgetCurrentView();
109
+ i0.ɵɵelementStart(0, "div")(1, "ion-button", 8);
110
+ i0.ɵɵlistener("click", function CrudFormComponent_Conditional_1_Conditional_3_Template_ion_button_click_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.handleReset()); });
111
+ i0.ɵɵtemplate(2, CrudFormComponent_Conditional_1_Conditional_3_Conditional_2_Template, 1, 2, "ion-icon", 6);
112
+ i0.ɵɵtext(3);
113
+ i0.ɵɵelementEnd()();
114
+ } if (rf & 2) {
115
+ const ctx_r1 = i0.ɵɵnextContext(2);
116
+ i0.ɵɵadvance(2);
117
+ i0.ɵɵconditional((ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.icon) ? 2 : -1);
118
+ i0.ɵɵadvance();
119
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpureFunction0(2, _c3).includes(ctx_r1.operation) ? "Back" : ctx_r1.options.buttons.clear == null ? null : ctx_r1.options.buttons.clear.text, " ");
120
+ } }
121
+ function CrudFormComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
122
+ i0.ɵɵelementStart(0, "div", 9);
123
+ i0.ɵɵtemplate(1, CrudFormComponent_Conditional_1_Conditional_1_Template, 4, 1, "div")(2, CrudFormComponent_Conditional_1_Conditional_2_Template, 4, 2, "div")(3, CrudFormComponent_Conditional_1_Conditional_3_Template, 4, 3, "div");
124
+ i0.ɵɵelementEnd();
125
+ } if (rf & 2) {
126
+ const ctx_r1 = i0.ɵɵnextContext();
127
+ i0.ɵɵclassMap("dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left " + ctx_r1.operation);
128
+ i0.ɵɵadvance();
129
+ i0.ɵɵconditional(ctx_r1.operation === "delete" && ctx_r1.uid ? 1 : -1);
130
+ i0.ɵɵadvance();
131
+ i0.ɵɵconditional(ctx_r1.operation === ctx_r1.OperationKeys.CREATE || ctx_r1.operation === ctx_r1.OperationKeys.UPDATE ? 2 : -1);
132
+ i0.ɵɵadvance();
133
+ i0.ɵɵconditional(ctx_r1.options.buttons.clear ? 3 : -1);
134
+ } }
13
135
  /**
14
136
  * @component CrudFormComponent
15
137
  * @example <ngx-decaf-crud-form
@@ -95,45 +217,56 @@ let CrudFormComponent = class CrudFormComponent {
95
217
  name: EventConstants.SUBMIT_EVENT,
96
218
  });
97
219
  }
98
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CrudFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
99
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CrudFormComponent, isStandalone: true, selector: "ngx-decaf-crud-form", inputs: { model: "model", updateOn: "updateOn", target: "target", method: "method", options: "options", action: "action", operation: "operation", handlers: "handlers", formGroup: "formGroup", childOf: "childOf", rendererId: "rendererId", uid: "uid" }, outputs: { submitEvent: "submitEvent" }, viewQueries: [{ propertyName: "component", first: true, predicate: ["reactiveForm"], descendants: true, read: ElementRef }], ngImport: i0, template: "@if(operation !== 'read' && operation !== 'delete') {\n <form #reactiveForm [id]=\"rendererId\" [formGroup]=\"formGroup\" (submit)=\"submit($event)\" novalidate [target]=\"target\">\n <ng-content #formContent></ng-content>\n <div id=\"dcf-buttons-container\" class=\"dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left\">\n <div>\n <ion-button\n type=\"submit\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n {{ action ? action : options.buttons.submit.text}}\n </ion-button>\n </div>\n <div>\n @if(options.buttons.clear) {\n <ion-button fill=\"clear\" (click)=\"handleReset()\">\n @if(options.buttons.clear?.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n }\n {{ ['create', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n </ion-button>\n }\n </div>\n </div>\n </form>\n} @else {\n <div [class]=\"'dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left ' + operation\" id=\"dcf-buttons-container\">\n\n @if(operation === 'delete' && uid) {\n <div>\n <ion-button\n (click)=\"handleDelete()\"\n color=\"danger\"\n type=\"button\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n Delete\n </ion-button>\n </div>\n\n }\n @if(operation === OperationKeys.CREATE || operation === OperationKeys.UPDATE) {\n <div>\n <ion-button\n type=\"submit\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n {{options.buttons.submit.text}}\n </ion-button>\n </div>\n }\n\n @if(options.buttons.clear) {\n <div>\n <ion-button fill=\"clear\" (click)=\"handleReset()\">\n @if(options.buttons.clear?.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n }\n {{ ['delete', 'read', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n </ion-button>\n </div>\n\n }\n </div>\n}\n\n", styles: ["#dcf-buttons-container{margin-top:1.8rem;margin-bottom:0}@media (min-width: 991px){#dcf-buttons-container.dcf-flex{flex-direction:row-reverse}}@media (max-width: 990px){#dcf-buttons-container.dcf-flex div{width:100%}#dcf-buttons-container.dcf-flex ion-button{width:100%;margin-bottom:1rem}}\n"], dependencies: [{ kind: "ngmodule", type: ForAngularModule }, { kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
220
+ static { this.ɵfac = function CrudFormComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || CrudFormComponent)(); }; }
221
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CrudFormComponent, selectors: [["ngx-decaf-crud-form"]], viewQuery: function CrudFormComponent_Query(rf, ctx) { if (rf & 1) {
222
+ i0.ɵɵviewQuery(_c0, 5, ElementRef);
223
+ } if (rf & 2) {
224
+ let _t;
225
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.component = _t.first);
226
+ } }, inputs: { model: "model", updateOn: "updateOn", target: "target", method: "method", options: "options", action: "action", operation: "operation", handlers: "handlers", formGroup: "formGroup", childOf: "childOf", rendererId: "rendererId", uid: "uid" }, outputs: { submitEvent: "submitEvent" }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c1, decls: 2, vars: 1, consts: [["reactiveForm", ""], ["novalidate", "", 3, "id", "formGroup", "target"], ["id", "dcf-buttons-container", 3, "class"], ["novalidate", "", 3, "submit", "id", "formGroup", "target"], ["id", "dcf-buttons-container", 1, "dcf-grid", "dcf-grid-collapse", "dcf-flex", "dcf-flex-left"], ["type", "submit"], ["aria-hidden", "true", 3, "slot", "name"], ["fill", "clear"], ["fill", "clear", 3, "click"], ["id", "dcf-buttons-container"], ["color", "danger", "type", "button", 3, "click"]], template: function CrudFormComponent_Template(rf, ctx) { if (rf & 1) {
227
+ i0.ɵɵprojectionDef();
228
+ i0.ɵɵtemplate(0, CrudFormComponent_Conditional_0_Template, 10, 6, "form", 1)(1, CrudFormComponent_Conditional_1_Template, 4, 5, "div", 2);
229
+ } if (rf & 2) {
230
+ i0.ɵɵconditional(ctx.operation !== "read" && ctx.operation !== "delete" ? 0 : 1);
231
+ } }, dependencies: [ForAngularModule, i1.IonButton, i2.ɵNgNoValidate, i2.NgControlStatusGroup, i2.FormGroupDirective, IonIcon], styles: ["#dcf-buttons-container[_ngcontent-%COMP%]{margin-top:1.8rem;margin-bottom:0}@media (min-width: 991px){#dcf-buttons-container.dcf-flex[_ngcontent-%COMP%]{flex-direction:row-reverse}}@media (max-width: 990px){#dcf-buttons-container.dcf-flex[_ngcontent-%COMP%] div[_ngcontent-%COMP%]{width:100%}#dcf-buttons-container.dcf-flex[_ngcontent-%COMP%] ion-button[_ngcontent-%COMP%]{width:100%;margin-bottom:1rem}}"] }); }
100
232
  };
101
233
  CrudFormComponent = __decorate([
102
234
  Dynamic()
103
235
  ], CrudFormComponent);
104
236
  export { CrudFormComponent };
105
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CrudFormComponent, decorators: [{
106
- type: Component,
107
- args: [{ standalone: true, selector: 'ngx-decaf-crud-form', imports: [ForAngularModule, IonIcon], template: "@if(operation !== 'read' && operation !== 'delete') {\n <form #reactiveForm [id]=\"rendererId\" [formGroup]=\"formGroup\" (submit)=\"submit($event)\" novalidate [target]=\"target\">\n <ng-content #formContent></ng-content>\n <div id=\"dcf-buttons-container\" class=\"dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left\">\n <div>\n <ion-button\n type=\"submit\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n {{ action ? action : options.buttons.submit.text}}\n </ion-button>\n </div>\n <div>\n @if(options.buttons.clear) {\n <ion-button fill=\"clear\" (click)=\"handleReset()\">\n @if(options.buttons.clear?.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n }\n {{ ['create', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n </ion-button>\n }\n </div>\n </div>\n </form>\n} @else {\n <div [class]=\"'dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left ' + operation\" id=\"dcf-buttons-container\">\n\n @if(operation === 'delete' && uid) {\n <div>\n <ion-button\n (click)=\"handleDelete()\"\n color=\"danger\"\n type=\"button\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n Delete\n </ion-button>\n </div>\n\n }\n @if(operation === OperationKeys.CREATE || operation === OperationKeys.UPDATE) {\n <div>\n <ion-button\n type=\"submit\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n {{options.buttons.submit.text}}\n </ion-button>\n </div>\n }\n\n @if(options.buttons.clear) {\n <div>\n <ion-button fill=\"clear\" (click)=\"handleReset()\">\n @if(options.buttons.clear?.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n }\n {{ ['delete', 'read', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n </ion-button>\n </div>\n\n }\n </div>\n}\n\n", styles: ["#dcf-buttons-container{margin-top:1.8rem;margin-bottom:0}@media (min-width: 991px){#dcf-buttons-container.dcf-flex{flex-direction:row-reverse}}@media (max-width: 990px){#dcf-buttons-container.dcf-flex div{width:100%}#dcf-buttons-container.dcf-flex ion-button{width:100%;margin-bottom:1rem}}\n"] }]
108
- }], propDecorators: { model: [{
109
- type: Input
110
- }], updateOn: [{
111
- type: Input
112
- }], component: [{
113
- type: ViewChild,
114
- args: ['reactiveForm', { static: false, read: ElementRef }]
115
- }], target: [{
116
- type: Input
117
- }], method: [{
118
- type: Input
119
- }], options: [{
120
- type: Input
121
- }], action: [{
122
- type: Input
123
- }], operation: [{
124
- type: Input,
125
- args: [{ required: true }]
126
- }], handlers: [{
127
- type: Input
128
- }], formGroup: [{
129
- type: Input
130
- }], childOf: [{
131
- type: Input
132
- }], rendererId: [{
133
- type: Input
134
- }], uid: [{
135
- type: Input
136
- }], submitEvent: [{
137
- type: Output
138
- }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crud-form.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/crud-form/crud-form.component.ts","../../../../../src/lib/components/crud-form/crud-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { Location } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { FormElement } from '../../interfaces';\nimport { NgxFormService } from '../../engine/NgxFormService';\nimport { CrudFormEvent, Dynamic, EventConstants, FieldUpdateMode, HTMLFormTarget, RenderedModel } from '../../engine';\nimport { CrudFormOptions } from './types';\nimport { CrudOperations, OperationKeys } from '@decaf-ts/db-decorators';\nimport { DefaultFormReactiveOptions } from './constants';\nimport { ForAngularModule, getLogger } from '../../for-angular.module';\nimport { IonIcon } from '@ionic/angular/standalone';\nimport { Model } from '@decaf-ts/decorator-validation';\nimport { Logger } from '@decaf-ts/logging';\n\n\n/**\n * @component CrudFormComponent\n * @example <ngx-decaf-crud-form\n *   action=\"create\"\n *   operation=\"create\"\n *   formGroup=\"formGroup\"\n *   rendererId=\"rendererId\"\n *   submitEvent=\"submitEvent\"\n *   target=\"_self\"\n *   method=\"event\">\n * </ngx-decaf-crud-form>\n *\n * @param {string} action - The action to be performed (create, read, update, delete)\n * @param {CrudOperations} operation - The CRUD operation being performed (create, read, update, delete)\n * @param {FormGroup} formGroup - The form group\n * @param {string} rendererId - The renderer id\n * @param {SubmitEvent} submitEvent - The submit event\n * @param {string} target - The target\n * @param {string} method - The method\n */\n@Dynamic()\n@Component({\n  standalone: true,\n  selector: 'ngx-decaf-crud-form',\n  templateUrl: './crud-form.component.html',\n  styleUrls: ['./crud-form.component.scss'],\n  imports: [ForAngularModule, IonIcon],\n})\nexport class CrudFormComponent implements OnInit, FormElement, OnDestroy, RenderedModel {\n\n  /**\n   * @description Repository model for data operations.\n   * @summary The data model repository that this component will use for CRUD operations.\n   * This provides a connection to the data layer for retrieving and manipulating data.\n   *\n   * @type {Model| undefined}\n   */\n  @Input()\n  model!: Model | undefined;\n\n  @Input()\n  updateOn: FieldUpdateMode = 'change';\n\n  @ViewChild('reactiveForm', { static: false, read: ElementRef })\n  component!: ElementRef;\n\n  @Input()\n  target: HTMLFormTarget = '_self';\n\n  @Input()\n  method: 'get' | 'post' | 'event' = 'event';\n\n  @Input()\n  options!: CrudFormOptions;\n\n  @Input()\n  action?: string;\n\n  @Input({ required: true })\n  operation!: CrudOperations;\n\n  @Input()\n  handlers!: Record<string, (...args: unknown[]) => unknown | Promise<unknown>>;\n\n  @Input()\n  formGroup!: FormGroup | undefined;\n\n  /**\n   * @description Path to the parent FormGroup, if nested.\n   * @summary Full dot-delimited path of the parent FormGroup. Set only when is part of a nested structure.\n   *\n   * @type {string}\n   * @memberOf CrudFormComponent\n   */\n  @Input()\n  childOf?: string;\n\n  @Input()\n  rendererId!: string;\n\n  /**\n   * @description Unique identifier for the current record.\n   * @summary A unique identifier for the current record being displayed or manipulated.\n   * This is typically used in conjunction with the primary key for operations on specific records.\n   *\n   * @type {string | number}\n   */\n  @Input()\n  uid!: string | number | undefined;\n\n\n  @Output()\n  submitEvent = new EventEmitter<CrudFormEvent>();\n\n  /**\n   * @description Logger instance for the component.\n   * @summary Provides logging capabilities for the component, allowing for consistent\n   * and structured logging of information, warnings, and errors. This logger is initialized\n   * in the ngOnInit method using the getLogger function from the ForAngularModule.\n   *\n   * The logger is used throughout the component to record important events, debug information,\n   * and potential issues. It helps in monitoring the component's behavior, tracking the flow\n   * of operations, and facilitating easier debugging and maintenance.\n   *\n   * @type {Logger}\n   * @private\n   * @memberOf CrudFormComponent\n   */\n  private logger!: Logger;\n\n  /**\n   * @description Angular Location service.\n   * @summary Injected service that provides access to the browser's URL and history.\n   * This service is used for interacting with the browser's history API, allowing\n   * for back navigation and URL manipulation outside of Angular's router.\n   *\n   * @private\n   * @type {Location}\n   * @memberOf CrudFormComponent\n   */\n  private location: Location = inject(Location);\n\n  // ngAfterViewInit() {\n    // if (![OperationKeys.READ, OperationKeys.DELETE].includes(this.operation))\n    //   NgxFormService.formAfterViewInit(this, this.rendererId);\n  // }\n\n  async ngOnInit() {\n    if (!this.logger)\n      this.logger = getLogger(this);\n    if (this.operation === OperationKeys.READ || this.operation === OperationKeys.DELETE)\n      this.formGroup = undefined;\n    this.options = Object.assign(\n      {},\n      DefaultFormReactiveOptions,\n      this.options || {},\n    );\n  }\n\n  ngOnDestroy() {\n    if (this.formGroup)\n      NgxFormService.unregister(this.formGroup);\n  }\n\n  /**\n   * @param  {SubmitEvent} event\n   */\n  async submit(event: SubmitEvent): Promise<boolean | void> {\n    event.preventDefault();\n    event.stopImmediatePropagation();\n    event.stopPropagation();\n\n    if (!NgxFormService.validateFields(this.formGroup as FormGroup))\n      return false;\n\n    const data = NgxFormService.getFormData(this.formGroup as FormGroup);\n    this.submitEvent.emit({\n      data,\n      component: 'CrudFormComponent',\n      name: this.action || EventConstants.SUBMIT_EVENT,\n      handlers: this.handlers,\n    });\n  }\n\n  handleReset() {\n    this.location.back();\n    // if(OperationKeys.DELETE !== this.operation)\n    //   NgxFormService.reset(this.formGroup);\n    // else\n    //   this.location.back();\n  }\n\n  handleDelete() {\n    this.submitEvent.emit({\n      data: this.uid,\n      component: 'CrudFormComponent',\n      name: EventConstants.SUBMIT_EVENT,\n    });\n  }\n\n  protected readonly OperationKeys = OperationKeys;\n}\n","@if(operation !== 'read' && operation !== 'delete') {\n  <form #reactiveForm [id]=\"rendererId\" [formGroup]=\"formGroup\" (submit)=\"submit($event)\" novalidate [target]=\"target\">\n    <ng-content #formContent></ng-content>\n    <div id=\"dcf-buttons-container\" class=\"dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left\">\n      <div>\n        <ion-button\n          type=\"submit\">\n          @if(options.buttons.submit.icon) {\n            <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n          }\n          {{ action ? action : options.buttons.submit.text}}\n        </ion-button>\n      </div>\n      <div>\n          @if(options.buttons.clear) {\n            <ion-button fill=\"clear\" (click)=\"handleReset()\">\n              @if(options.buttons.clear?.icon) {\n                <ion-icon  aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n              }\n              {{ ['create', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n            </ion-button>\n          }\n        </div>\n    </div>\n  </form>\n} @else {\n  <div [class]=\"'dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left ' + operation\" id=\"dcf-buttons-container\">\n\n    @if(operation === 'delete' && uid) {\n      <div>\n        <ion-button\n          (click)=\"handleDelete()\"\n          color=\"danger\"\n          type=\"button\">\n          @if(options.buttons.submit.icon) {\n            <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n          }\n          Delete\n        </ion-button>\n      </div>\n\n    }\n    @if(operation === OperationKeys.CREATE || operation === OperationKeys.UPDATE) {\n      <div>\n        <ion-button\n          type=\"submit\">\n          @if(options.buttons.submit.icon) {\n            <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n          }\n          {{options.buttons.submit.text}}\n        </ion-button>\n      </div>\n    }\n\n    @if(options.buttons.clear) {\n      <div>\n       <ion-button fill=\"clear\" (click)=\"handleReset()\">\n          @if(options.buttons.clear?.icon) {\n            <ion-icon  aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n          }\n          {{ ['delete', 'read', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n        </ion-button>\n      </div>\n\n    }\n  </div>\n}\n\n"]}
237
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CrudFormComponent, [{
238
+ type: Component,
239
+ args: [{ standalone: true, selector: 'ngx-decaf-crud-form', imports: [ForAngularModule, IonIcon], template: "@if(operation !== 'read' && operation !== 'delete') {\n <form #reactiveForm [id]=\"rendererId\" [formGroup]=\"formGroup\" (submit)=\"submit($event)\" novalidate [target]=\"target\">\n <ng-content #formContent></ng-content>\n <div id=\"dcf-buttons-container\" class=\"dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left\">\n <div>\n <ion-button\n type=\"submit\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n {{ action ? action : options.buttons.submit.text}}\n </ion-button>\n </div>\n <div>\n @if(options.buttons.clear) {\n <ion-button fill=\"clear\" (click)=\"handleReset()\">\n @if(options.buttons.clear?.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n }\n {{ ['create', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n </ion-button>\n }\n </div>\n </div>\n </form>\n} @else {\n <div [class]=\"'dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left ' + operation\" id=\"dcf-buttons-container\">\n\n @if(operation === 'delete' && uid) {\n <div>\n <ion-button\n (click)=\"handleDelete()\"\n color=\"danger\"\n type=\"button\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n Delete\n </ion-button>\n </div>\n\n }\n @if(operation === OperationKeys.CREATE || operation === OperationKeys.UPDATE) {\n <div>\n <ion-button\n type=\"submit\">\n @if(options.buttons.submit.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n }\n {{options.buttons.submit.text}}\n </ion-button>\n </div>\n }\n\n @if(options.buttons.clear) {\n <div>\n <ion-button fill=\"clear\" (click)=\"handleReset()\">\n @if(options.buttons.clear?.icon) {\n <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n }\n {{ ['delete', 'read', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n </ion-button>\n </div>\n\n }\n </div>\n}\n\n", styles: ["#dcf-buttons-container{margin-top:1.8rem;margin-bottom:0}@media (min-width: 991px){#dcf-buttons-container.dcf-flex{flex-direction:row-reverse}}@media (max-width: 990px){#dcf-buttons-container.dcf-flex div{width:100%}#dcf-buttons-container.dcf-flex ion-button{width:100%;margin-bottom:1rem}}\n"] }]
240
+ }], null, { model: [{
241
+ type: Input
242
+ }], updateOn: [{
243
+ type: Input
244
+ }], component: [{
245
+ type: ViewChild,
246
+ args: ['reactiveForm', { static: false, read: ElementRef }]
247
+ }], target: [{
248
+ type: Input
249
+ }], method: [{
250
+ type: Input
251
+ }], options: [{
252
+ type: Input
253
+ }], action: [{
254
+ type: Input
255
+ }], operation: [{
256
+ type: Input,
257
+ args: [{ required: true }]
258
+ }], handlers: [{
259
+ type: Input
260
+ }], formGroup: [{
261
+ type: Input
262
+ }], childOf: [{
263
+ type: Input
264
+ }], rendererId: [{
265
+ type: Input
266
+ }], uid: [{
267
+ type: Input
268
+ }], submitEvent: [{
269
+ type: Output
270
+ }] }); })();
271
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CrudFormComponent, { className: "CrudFormComponent", filePath: "components/crud-form/crud-form.component.ts", lineNumber: 54 }); })();
272
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crud-form.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/crud-form/crud-form.component.ts","../../../../../src/lib/components/crud-form/crud-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { Location } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { FormElement } from '../../interfaces';\nimport { NgxFormService } from '../../engine/NgxFormService';\nimport { CrudFormEvent, Dynamic, EventConstants, FieldUpdateMode, HTMLFormTarget, RenderedModel } from '../../engine';\nimport { CrudFormOptions } from './types';\nimport { CrudOperations, OperationKeys } from '@decaf-ts/db-decorators';\nimport { DefaultFormReactiveOptions } from './constants';\nimport { ForAngularModule, getLogger } from '../../for-angular.module';\nimport { IonIcon } from '@ionic/angular/standalone';\nimport { Model } from '@decaf-ts/decorator-validation';\nimport { Logger } from '@decaf-ts/logging';\n\n\n/**\n * @component CrudFormComponent\n * @example <ngx-decaf-crud-form\n *   action=\"create\"\n *   operation=\"create\"\n *   formGroup=\"formGroup\"\n *   rendererId=\"rendererId\"\n *   submitEvent=\"submitEvent\"\n *   target=\"_self\"\n *   method=\"event\">\n * </ngx-decaf-crud-form>\n *\n * @param {string} action - The action to be performed (create, read, update, delete)\n * @param {CrudOperations} operation - The CRUD operation being performed (create, read, update, delete)\n * @param {FormGroup} formGroup - The form group\n * @param {string} rendererId - The renderer id\n * @param {SubmitEvent} submitEvent - The submit event\n * @param {string} target - The target\n * @param {string} method - The method\n */\n@Dynamic()\n@Component({\n  standalone: true,\n  selector: 'ngx-decaf-crud-form',\n  templateUrl: './crud-form.component.html',\n  styleUrls: ['./crud-form.component.scss'],\n  imports: [ForAngularModule, IonIcon],\n})\nexport class CrudFormComponent implements OnInit, FormElement, OnDestroy, RenderedModel {\n\n  /**\n   * @description Repository model for data operations.\n   * @summary The data model repository that this component will use for CRUD operations.\n   * This provides a connection to the data layer for retrieving and manipulating data.\n   *\n   * @type {Model| undefined}\n   */\n  @Input()\n  model!: Model | undefined;\n\n  @Input()\n  updateOn: FieldUpdateMode = 'change';\n\n  @ViewChild('reactiveForm', { static: false, read: ElementRef })\n  component!: ElementRef;\n\n  @Input()\n  target: HTMLFormTarget = '_self';\n\n  @Input()\n  method: 'get' | 'post' | 'event' = 'event';\n\n  @Input()\n  options!: CrudFormOptions;\n\n  @Input()\n  action?: string;\n\n  @Input({ required: true })\n  operation!: CrudOperations;\n\n  @Input()\n  handlers!: Record<string, (...args: unknown[]) => unknown | Promise<unknown>>;\n\n  @Input()\n  formGroup!: FormGroup | undefined;\n\n  /**\n   * @description Path to the parent FormGroup, if nested.\n   * @summary Full dot-delimited path of the parent FormGroup. Set only when is part of a nested structure.\n   *\n   * @type {string}\n   * @memberOf CrudFormComponent\n   */\n  @Input()\n  childOf?: string;\n\n  @Input()\n  rendererId!: string;\n\n  /**\n   * @description Unique identifier for the current record.\n   * @summary A unique identifier for the current record being displayed or manipulated.\n   * This is typically used in conjunction with the primary key for operations on specific records.\n   *\n   * @type {string | number}\n   */\n  @Input()\n  uid!: string | number | undefined;\n\n\n  @Output()\n  submitEvent = new EventEmitter<CrudFormEvent>();\n\n  /**\n   * @description Logger instance for the component.\n   * @summary Provides logging capabilities for the component, allowing for consistent\n   * and structured logging of information, warnings, and errors. This logger is initialized\n   * in the ngOnInit method using the getLogger function from the ForAngularModule.\n   *\n   * The logger is used throughout the component to record important events, debug information,\n   * and potential issues. It helps in monitoring the component's behavior, tracking the flow\n   * of operations, and facilitating easier debugging and maintenance.\n   *\n   * @type {Logger}\n   * @private\n   * @memberOf CrudFormComponent\n   */\n  private logger!: Logger;\n\n  /**\n   * @description Angular Location service.\n   * @summary Injected service that provides access to the browser's URL and history.\n   * This service is used for interacting with the browser's history API, allowing\n   * for back navigation and URL manipulation outside of Angular's router.\n   *\n   * @private\n   * @type {Location}\n   * @memberOf CrudFormComponent\n   */\n  private location: Location = inject(Location);\n\n  // ngAfterViewInit() {\n    // if (![OperationKeys.READ, OperationKeys.DELETE].includes(this.operation))\n    //   NgxFormService.formAfterViewInit(this, this.rendererId);\n  // }\n\n  async ngOnInit() {\n    if (!this.logger)\n      this.logger = getLogger(this);\n    if (this.operation === OperationKeys.READ || this.operation === OperationKeys.DELETE)\n      this.formGroup = undefined;\n    this.options = Object.assign(\n      {},\n      DefaultFormReactiveOptions,\n      this.options || {},\n    );\n  }\n\n  ngOnDestroy() {\n    if (this.formGroup)\n      NgxFormService.unregister(this.formGroup);\n  }\n\n  /**\n   * @param  {SubmitEvent} event\n   */\n  async submit(event: SubmitEvent): Promise<boolean | void> {\n    event.preventDefault();\n    event.stopImmediatePropagation();\n    event.stopPropagation();\n\n    if (!NgxFormService.validateFields(this.formGroup as FormGroup))\n      return false;\n\n    const data = NgxFormService.getFormData(this.formGroup as FormGroup);\n    this.submitEvent.emit({\n      data,\n      component: 'CrudFormComponent',\n      name: this.action || EventConstants.SUBMIT_EVENT,\n      handlers: this.handlers,\n    });\n  }\n\n  handleReset() {\n    this.location.back();\n    // if(OperationKeys.DELETE !== this.operation)\n    //   NgxFormService.reset(this.formGroup);\n    // else\n    //   this.location.back();\n  }\n\n  handleDelete() {\n    this.submitEvent.emit({\n      data: this.uid,\n      component: 'CrudFormComponent',\n      name: EventConstants.SUBMIT_EVENT,\n    });\n  }\n\n  protected readonly OperationKeys = OperationKeys;\n}\n","@if(operation !== 'read' && operation !== 'delete') {\n  <form #reactiveForm [id]=\"rendererId\" [formGroup]=\"formGroup\" (submit)=\"submit($event)\" novalidate [target]=\"target\">\n    <ng-content #formContent></ng-content>\n    <div id=\"dcf-buttons-container\" class=\"dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left\">\n      <div>\n        <ion-button\n          type=\"submit\">\n          @if(options.buttons.submit.icon) {\n            <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n          }\n          {{ action ? action : options.buttons.submit.text}}\n        </ion-button>\n      </div>\n      <div>\n          @if(options.buttons.clear) {\n            <ion-button fill=\"clear\" (click)=\"handleReset()\">\n              @if(options.buttons.clear?.icon) {\n                <ion-icon  aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n              }\n              {{ ['create', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n            </ion-button>\n          }\n        </div>\n    </div>\n  </form>\n} @else {\n  <div [class]=\"'dcf-grid dcf-grid-collapse dcf-flex dcf-flex-left ' + operation\" id=\"dcf-buttons-container\">\n\n    @if(operation === 'delete' && uid) {\n      <div>\n        <ion-button\n          (click)=\"handleDelete()\"\n          color=\"danger\"\n          type=\"button\">\n          @if(options.buttons.submit.icon) {\n            <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n          }\n          Delete\n        </ion-button>\n      </div>\n\n    }\n    @if(operation === OperationKeys.CREATE || operation === OperationKeys.UPDATE) {\n      <div>\n        <ion-button\n          type=\"submit\">\n          @if(options.buttons.submit.icon) {\n            <ion-icon aria-hidden=\"true\" [slot]=\"options.buttons.submit.iconSlot\" [name]=\"options.buttons.submit.icon\"></ion-icon>\n          }\n          {{options.buttons.submit.text}}\n        </ion-button>\n      </div>\n    }\n\n    @if(options.buttons.clear) {\n      <div>\n       <ion-button fill=\"clear\" (click)=\"handleReset()\">\n          @if(options.buttons.clear?.icon) {\n            <ion-icon  aria-hidden=\"true\" [slot]=\"options.buttons.clear?.iconSlot\" [name]=\"options.buttons.clear?.icon\"></ion-icon>\n          }\n          {{ ['delete', 'read', 'update'].includes(operation) ? 'Back' : options.buttons.clear?.text}}\n        </ion-button>\n      </div>\n\n    }\n  </div>\n}\n\n"]}
@@ -12,6 +12,51 @@ import { TranslateService } from '@ngx-translate/core';
12
12
  import * as i0 from "@angular/core";
13
13
  import * as i1 from "@ionic/angular/standalone";
14
14
  import * as i2 from "@angular/common";
15
+ function EmptyStateComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
16
+ i0.ɵɵelementStart(0, "div", 1);
17
+ i0.ɵɵelement(1, "ion-icon", 3);
18
+ i0.ɵɵelementEnd();
19
+ } }
20
+ function EmptyStateComponent_Conditional_3_Template(rf, ctx) { if (rf & 1) {
21
+ i0.ɵɵelement(0, "h5", 4);
22
+ } if (rf & 2) {
23
+ const ctx_r0 = i0.ɵɵnextContext();
24
+ i0.ɵɵclassMap(ctx_r0.titleColor);
25
+ i0.ɵɵproperty("innerHTML", ctx_r0.title, i0.ɵɵsanitizeHtml);
26
+ } }
27
+ function EmptyStateComponent_Conditional_4_Conditional_0_Template(rf, ctx) { if (rf & 1) {
28
+ i0.ɵɵelement(0, "p", 4);
29
+ } if (rf & 2) {
30
+ const ctx_r0 = i0.ɵɵnextContext(2);
31
+ i0.ɵɵclassMap(ctx_r0.subtitleColor);
32
+ i0.ɵɵproperty("innerHTML", ctx_r0.subtitle, i0.ɵɵsanitizeHtml);
33
+ } }
34
+ function EmptyStateComponent_Conditional_4_Conditional_1_Template(rf, ctx) { if (rf & 1) {
35
+ i0.ɵɵelement(0, "p", 4);
36
+ } if (rf & 2) {
37
+ const ctx_r0 = i0.ɵɵnextContext(2);
38
+ i0.ɵɵclassMap(ctx_r0.subtitleColor);
39
+ i0.ɵɵproperty("innerHTML", ctx_r0.searchSubtitle, i0.ɵɵsanitizeHtml);
40
+ } }
41
+ function EmptyStateComponent_Conditional_4_Template(rf, ctx) { if (rf & 1) {
42
+ i0.ɵɵtemplate(0, EmptyStateComponent_Conditional_4_Conditional_0_Template, 1, 3, "p", 2)(1, EmptyStateComponent_Conditional_4_Conditional_1_Template, 1, 3, "p", 2);
43
+ } if (rf & 2) {
44
+ const ctx_r0 = i0.ɵɵnextContext();
45
+ i0.ɵɵconditional(!ctx_r0.searchValue ? 0 : 1);
46
+ } }
47
+ function EmptyStateComponent_Conditional_5_Template(rf, ctx) { if (rf & 1) {
48
+ const _r2 = i0.ɵɵgetCurrentView();
49
+ i0.ɵɵelementStart(0, "div")(1, "ion-button", 5);
50
+ i0.ɵɵlistener("click", function EmptyStateComponent_Conditional_5_Template_ion_button_click_1_listener() { i0.ɵɵrestoreView(_r2); const ctx_r0 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r0.handleClick()); });
51
+ i0.ɵɵtext(2);
52
+ i0.ɵɵelementEnd()();
53
+ } if (rf & 2) {
54
+ const ctx_r0 = i0.ɵɵnextContext();
55
+ i0.ɵɵadvance();
56
+ i0.ɵɵproperty("size", ctx_r0.buttonSize)("fill", ctx_r0.buttonFill)("color", ctx_r0.buttonColor);
57
+ i0.ɵɵadvance();
58
+ i0.ɵɵtextInterpolate1(" ", ctx_r0.buttonText, " ");
59
+ } }
15
60
  /**
16
61
  * @description Component for displaying empty state messages with optional actions.
17
62
  * @summary This component provides a standardized way to display empty state messages
@@ -299,50 +344,67 @@ let EmptyStateComponent = class EmptyStateComponent extends NgxBaseComponent {
299
344
  const result = await this.translate.instant(content, { 'value0': this.searchValue });
300
345
  return this.sanitizer.bypassSecurityTrustHtml(result);
301
346
  }
302
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EmptyStateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
303
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: EmptyStateComponent, isStandalone: true, selector: "ngx-decaf-empty-state", inputs: { title: "title", titleColor: "titleColor", subtitle: "subtitle", subtitleColor: "subtitleColor", showIcon: "showIcon", icon: "icon", iconSize: "iconSize", iconColor: "iconColor", buttonLink: "buttonLink", buttonText: "buttonText", buttonFill: "buttonFill", buttonColor: "buttonColor", buttonSize: "buttonSize", searchValue: "searchValue" }, usesInheritance: true, ngImport: i0, template: "\n<ion-card id=\"dcf-card-empty-state\" [ngClass]=\"className\">\n <ion-card-content>\n @if(icon && showIcon) {\n <div class=\"dcf-icon-container\">\n <ion-icon\n name=\"alert-circle-outline\"\n size=\"large\"\n color=\"danger\"\n />\n </div>\n }\n @if(title) {\n <h5 [class]=\"titleColor\" [innerHTML]=\"title\"></h5>\n }\n @if(subtitle) {\n @if(!searchValue) {\n <p [class]=\"subtitleColor\" [innerHTML]=\"subtitle\"></p>\n } @else {\n <p [class]=\"subtitleColor\" [innerHTML]=\"searchSubtitle\"></p>\n }\n }\n @if(buttonLink && buttonText) {\n <div>\n <ion-button\n [size]=\"buttonSize\"\n [fill]=\"buttonFill\"\n [color]=\"buttonColor\"\n (click)=\"handleClick()\">\n {{ buttonText }}\n </ion-button>\n </div>\n }\n </ion-card-content>\n</ion-card>\n", styles: ["ion-card{text-align:center}ion-card ion-button{margin-top:.75rem}ion-card ion-icon{font-size:2.5rem}ion-card .dcf-icon-container{transform:scale(1.25);opacity:.75;margin-top:1.25rem!important;margin-bottom:.5rem!important}ion-card .dcf-ititle{font-weight:600!important;color:var(--ion-color-gray-6)!important}ion-card .dcf-isubtitle{font-weight:500!important}\n"], dependencies: [{ kind: "ngmodule", type: ForAngularModule }, { kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
347
+ static { this.ɵfac = function EmptyStateComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || EmptyStateComponent)(); }; }
348
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: EmptyStateComponent, selectors: [["ngx-decaf-empty-state"]], inputs: { title: "title", titleColor: "titleColor", subtitle: "subtitle", subtitleColor: "subtitleColor", showIcon: "showIcon", icon: "icon", iconSize: "iconSize", iconColor: "iconColor", buttonLink: "buttonLink", buttonText: "buttonText", buttonFill: "buttonFill", buttonColor: "buttonColor", buttonSize: "buttonSize", searchValue: "searchValue" }, standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 6, vars: 5, consts: [["id", "dcf-card-empty-state", 3, "ngClass"], [1, "dcf-icon-container"], [3, "class", "innerHTML"], ["name", "alert-circle-outline", "size", "large", "color", "danger"], [3, "innerHTML"], [3, "click", "size", "fill", "color"]], template: function EmptyStateComponent_Template(rf, ctx) { if (rf & 1) {
349
+ i0.ɵɵelementStart(0, "ion-card", 0)(1, "ion-card-content");
350
+ i0.ɵɵtemplate(2, EmptyStateComponent_Conditional_2_Template, 2, 0, "div", 1)(3, EmptyStateComponent_Conditional_3_Template, 1, 3, "h5", 2)(4, EmptyStateComponent_Conditional_4_Template, 2, 1)(5, EmptyStateComponent_Conditional_5_Template, 3, 4, "div");
351
+ i0.ɵɵelementEnd()();
352
+ } if (rf & 2) {
353
+ i0.ɵɵproperty("ngClass", ctx.className);
354
+ i0.ɵɵadvance(2);
355
+ i0.ɵɵconditional(ctx.icon && ctx.showIcon ? 2 : -1);
356
+ i0.ɵɵadvance();
357
+ i0.ɵɵconditional(ctx.title ? 3 : -1);
358
+ i0.ɵɵadvance();
359
+ i0.ɵɵconditional(ctx.subtitle ? 4 : -1);
360
+ i0.ɵɵadvance();
361
+ i0.ɵɵconditional(ctx.buttonLink && ctx.buttonText ? 5 : -1);
362
+ } }, dependencies: [ForAngularModule, i1.IonButton, i2.NgClass, IonCard,
363
+ IonCardContent,
364
+ IonIcon], styles: ["ion-card[_ngcontent-%COMP%]{text-align:center}ion-card[_ngcontent-%COMP%] ion-button[_ngcontent-%COMP%]{margin-top:.75rem}ion-card[_ngcontent-%COMP%] ion-icon[_ngcontent-%COMP%]{font-size:2.5rem}ion-card[_ngcontent-%COMP%] .dcf-icon-container[_ngcontent-%COMP%]{transform:scale(1.25);opacity:.75;margin-top:1.25rem!important;margin-bottom:.5rem!important}ion-card[_ngcontent-%COMP%] .dcf-ititle[_ngcontent-%COMP%]{font-weight:600!important;color:var(--ion-color-gray-6)!important}ion-card[_ngcontent-%COMP%] .dcf-isubtitle[_ngcontent-%COMP%]{font-weight:500!important}"] }); }
304
365
  };
305
366
  EmptyStateComponent = __decorate([
306
367
  Dynamic(),
307
368
  __metadata("design:paramtypes", [])
308
369
  ], EmptyStateComponent);
309
370
  export { EmptyStateComponent };
310
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EmptyStateComponent, decorators: [{
311
- type: Component,
312
- args: [{ selector: 'ngx-decaf-empty-state', standalone: true, imports: [
313
- ForAngularModule,
314
- IonCard,
315
- IonCardContent,
316
- IonTitle,
317
- IonIcon
318
- ], template: "\n<ion-card id=\"dcf-card-empty-state\" [ngClass]=\"className\">\n <ion-card-content>\n @if(icon && showIcon) {\n <div class=\"dcf-icon-container\">\n <ion-icon\n name=\"alert-circle-outline\"\n size=\"large\"\n color=\"danger\"\n />\n </div>\n }\n @if(title) {\n <h5 [class]=\"titleColor\" [innerHTML]=\"title\"></h5>\n }\n @if(subtitle) {\n @if(!searchValue) {\n <p [class]=\"subtitleColor\" [innerHTML]=\"subtitle\"></p>\n } @else {\n <p [class]=\"subtitleColor\" [innerHTML]=\"searchSubtitle\"></p>\n }\n }\n @if(buttonLink && buttonText) {\n <div>\n <ion-button\n [size]=\"buttonSize\"\n [fill]=\"buttonFill\"\n [color]=\"buttonColor\"\n (click)=\"handleClick()\">\n {{ buttonText }}\n </ion-button>\n </div>\n }\n </ion-card-content>\n</ion-card>\n", styles: ["ion-card{text-align:center}ion-card ion-button{margin-top:.75rem}ion-card ion-icon{font-size:2.5rem}ion-card .dcf-icon-container{transform:scale(1.25);opacity:.75;margin-top:1.25rem!important;margin-bottom:.5rem!important}ion-card .dcf-ititle{font-weight:600!important;color:var(--ion-color-gray-6)!important}ion-card .dcf-isubtitle{font-weight:500!important}\n"] }]
319
- }], ctorParameters: () => [], propDecorators: { title: [{
320
- type: Input
321
- }], titleColor: [{
322
- type: Input
323
- }], subtitle: [{
324
- type: Input
325
- }], subtitleColor: [{
326
- type: Input
327
- }], showIcon: [{
328
- type: Input
329
- }], icon: [{
330
- type: Input
331
- }], iconSize: [{
332
- type: Input
333
- }], iconColor: [{
334
- type: Input
335
- }], buttonLink: [{
336
- type: Input
337
- }], buttonText: [{
338
- type: Input
339
- }], buttonFill: [{
340
- type: Input
341
- }], buttonColor: [{
342
- type: Input
343
- }], buttonSize: [{
344
- type: Input
345
- }], searchValue: [{
346
- type: Input
347
- }] } });
348
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"empty-state.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/empty-state/empty-state.component.ts","../../../../../src/lib/components/empty-state/empty-state.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnInit  } from '@angular/core';\nimport { Color, PredefinedColors } from '@ionic/core';\nimport {\n  IonCard,\n  IonCardContent,\n  IonIcon,\n  IonTitle,\n  NavController\n}\nfrom '@ionic/angular/standalone';\nimport * as allIcons from 'ionicons/icons';\nimport { addIcons } from 'ionicons';\nimport { ForAngularModule } from '../../for-angular.module';\nimport { Dynamic, StringOrBoolean } from '../../engine';\nimport { stringToBoolean } from '../../helpers';\nimport { NgxBaseComponent } from '../../engine/NgxBaseComponent';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { TranslateService } from '@ngx-translate/core';\nimport { FunctionLike } from '../../engine/types';\n\n\n/**\n * @description Component for displaying empty state messages with optional actions.\n * @summary This component provides a standardized way to display empty state messages\n * when no data is available or when a user needs to take an action to populate content.\n * It includes customizable title, subtitle, icon, and action button elements that can be\n * styled and configured through input properties. The component supports localization\n * and can trigger navigation or custom actions when the button is clicked.\n *\n * @mermaid\n * classDiagram\n *   class EmptyStateComponent {\n *     +string title\n *     +string titleColor\n *     +string subtitle\n *     +string subtitleColor\n *     +StringOrBoolean showIcon\n *     +string icon\n *     +string iconSize\n *     +PredefinedColors iconColor\n *     +string|Function buttonLink\n *     +string buttonText\n *     +string buttonFill\n *     +Color buttonColor\n *     +string buttonSize\n *     +string searchValue\n *     -NavController navController\n *     +ngOnInit()\n *     +handleClick()\n *   }\n *   EmptyStateComponent --|> NgxBaseComponent\n *   EmptyStateComponent --|> OnInit\n *\n * @extends {NgxBaseComponent}\n * @implements {OnInit}\n */\n@Dynamic()\n@Component({\n  selector: 'ngx-decaf-empty-state',\n  templateUrl: './empty-state.component.html',\n  styleUrls: ['./empty-state.component.scss'],\n  standalone: true,\n  imports: [\n    ForAngularModule,\n    IonCard,\n    IonCardContent,\n    IonTitle,\n    IonIcon\n  ]\n\n})\nexport class EmptyStateComponent extends NgxBaseComponent implements OnInit {\n\n  /**\n   * @description The main title displayed in the empty state.\n   * @summary Specifies the primary message to show in the empty state component.\n   * This text is typically used to inform the user about why they're seeing an empty view.\n   * If translatable is true, this will be processed through the localization system.\n   *\n   * @type {string}\n   * @default \"title\"\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  title: string = \"title\";\n\n  /**\n   * @description The color of the title text.\n   * @summary Specifies the color for the title text using the application's color system.\n   * The value should correspond to a color variable defined in the application's theme.\n   * The component will automatically prefix this with \"color-\" to create the CSS class.\n   *\n   * @type {string}\n   * @default 'gray-6'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  titleColor = 'gray-6';\n\n  /**\n   * @description The secondary message displayed in the empty state.\n   * @summary Provides additional context or instructions below the main title.\n   * This text is typically used to guide the user on what actions they can take.\n   * If translatable is true, this will be processed through the localization system.\n   *\n   * @type {string | undefined}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  subtitle: string = \"\";\n\n  /**\n   * @description The color of the subtitle text.\n   * @summary Specifies the color for the subtitle text using the application's color system.\n   * The value should correspond to a color variable defined in the application's theme.\n   * The component will automatically prefix this with \"color-\" to create the CSS class.\n   *\n   * @type {string}\n   * @default 'gray-4'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  subtitleColor: string = 'gray-4';\n\n  /**\n   * @description Controls whether the icon is displayed.\n   * @summary Determines if the visual icon should be shown in the empty state.\n   * This can be provided as a boolean or a string that will be converted to a boolean.\n   * Icons help visually communicate the empty state context to users.\n   *\n   * @type {StringOrBoolean}\n   * @default true\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  showIcon: StringOrBoolean = true;\n\n  /**\n   * @description The name of the icon to display.\n   * @summary Specifies which icon to show when showIcon is true.\n   * The component uses the icon system defined in the application,\n   * and this value should correspond to an available icon name.\n   *\n   * @type {string}\n   * @default \"ti-info-square-rounded\"\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  icon: string = \"ti-info-square-rounded\";\n\n  /**\n   * @description The size of the displayed icon.\n   * @summary Controls the size of the icon shown in the empty state.\n   * Can be either 'large' or 'small' to accommodate different layout needs.\n   *\n   * @type {'large' | 'small' | undefined}\n   * @default 'large'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  iconSize?: 'large' | 'small' = 'large';\n\n  /**\n   * @description The color of the displayed icon.\n   * @summary Specifies the color for the icon using Ionic's predefined color system.\n   * This allows the icon to match the application's color scheme.\n   *\n   * @type {PredefinedColors | undefined}\n   * @default 'medium'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  iconColor?: PredefinedColors = 'medium';\n\n  /**\n   * @description The navigation target or action for the button.\n   * @summary Specifies where the button should navigate to when clicked or what function\n   * it should execute. This can be either a URL string or a function that handles navigation.\n   * When not provided, the button will not perform any action.\n   *\n   * @type {string | FunctionLike | undefined}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonLink?: string | FunctionLike;\n\n  /**\n   * @description The text displayed on the action button.\n   * @summary Specifies the label for the action button in the empty state.\n   * If translatable is true, this will be processed through the localization system.\n   * If not provided, the button will not display any text.\n   *\n   * @type {string | undefined}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonText?: string;\n\n  /**\n   * @description The fill style of the action button.\n   * @summary Controls the visual style of the button using Ionic's button fill options.\n   * 'solid' creates a button with a solid background, 'outline' creates a button with\n   * just a border, and 'clear' creates a button with no background or border.\n   *\n   * @type {'clear' | 'solid' | 'outline'}\n   * @default 'solid'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonFill: 'clear' | 'solid' | 'outline' =  'solid';\n\n  /**\n   * @description The color of the action button.\n   * @summary Specifies the color for the button using Ionic's color system.\n   * This allows the button to match the application's color scheme.\n   *\n   * @type {Color}\n   * @default 'primary'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonColor: Color =  'primary';\n\n  /**\n   * @description The size of the action button.\n   * @summary Controls the size of the button shown in the empty state.\n   * Can be 'large', 'small', or 'default' to accommodate different layout needs.\n   *\n   * @type {'large' | 'small' | 'default'}\n   * @default 'default'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonSize: 'large' | 'small' | 'default' =  'default';\n\n  /**\n   * @description The search value that resulted in no results.\n   * @summary When the empty state is shown due to a search with no results,\n   * this property can hold the search term that was used. This can be displayed\n   * in the empty state message to provide context to the user.\n   *\n   * @type {string}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  searchValue!: string;\n\n  /**\n   * @description Service for handling navigation operations.\n   * @summary Injected service that provides methods for navigating between routes.\n   * This service is used when the buttonLink is a string URL to navigate to that location.\n   *\n   * @private\n   * @type {NavController}\n   * @memberOf EmptyStateComponent\n   */\n  private navController: NavController = inject(NavController);\n\n  private sanitizer: DomSanitizer = inject(DomSanitizer);\n\n  private translate: TranslateService = inject(TranslateService);\n\n  searchSubtitle!: SafeHtml\n\n\n  /**\n   * @description Creates an instance of EmptyStateComponent.\n   * @summary Initializes a new EmptyStateComponent by calling the parent class constructor\n   * with the component name for logging and identification purposes. This component provides\n   * a standardized way to display empty state messages with optional icons and action buttons.\n   *\n   * @memberOf EmptyStateComponent\n   */\n  constructor() {\n    super(\"EmptyStateComponent\");\n    addIcons(allIcons);\n  }\n\n  /**\n   * @description Initializes the component after Angular first displays the data-bound properties.\n   * @summary Sets up the component by processing boolean inputs, applying localization to text\n   * elements if translation is enabled, and formatting CSS classes for title and subtitle colors.\n   * This method prepares the component for user interaction by ensuring all properties are\n   * properly initialized and localized.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as Angular Lifecycle\n   *   participant E as EmptyStateComponent\n   *\n   *   A->>E: ngOnInit()\n   *   E->>E: Process translatable flag\n   *   E->>E: Process showIcon flag\n   *   E->>E: Get locale settings\n   *   alt translatable is true\n   *     E->>E: Localize title\n   *     E->>E: Localize subtitle\n   *     E->>E: Localize buttonText\n   *   end\n   *   E->>E: Format title CSS class\n   *   E->>E: Format subtitle CSS class\n   *\n   * @return {Promise<void>}\n   * @memberOf EmptyStateComponent\n   */\n  async ngOnInit(): Promise<void> {\n    this.parseProps(this);\n    this.translatable = stringToBoolean(this.translatable);\n    this.showIcon = stringToBoolean(this.showIcon);\n    this.locale = this.getLocale(this.translatable);\n\n    // if(this.translatable) {\n    //   this.title = generateLocaleFromString(this.locale, this.title);\n    //   this.subtitle = generateLocaleFromString(this.locale, this.subtitle);\n    //   this.buttonText = generateLocaleFromString(this.locale, this.buttonText);\n    // }\n\n    this.titleColor = `dcf-title color-${this.titleColor}`;\n    this.subtitleColor = `dcf-subtitle color-${this.titleColor}`;\n\n    if(this.searchValue && this.translatable)\n      this.searchSubtitle = await this.getSearchSubtitle(this.subtitle as string);\n  }\n\n  /**\n   * @description Handles click events on the action button.\n   * @summary This method is triggered when the user clicks the action button in the empty state\n   * component. It supports three navigation patterns: 1) no action when buttonLink is not provided,\n   * 2) custom function execution when buttonLink is a function, and 3) navigation to a specific URL\n   * when buttonLink is a string. This flexibility allows the empty state to trigger various actions\n   * based on the context in which it's used.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant E as EmptyStateComponent\n   *   participant N as NavController\n   *\n   *   U->>E: Click action button\n   *   E->>E: handleClick()\n   *   alt buttonLink is not provided\n   *     E-->>U: Return false (no action)\n   *   else buttonLink is a function\n   *     E->>E: Execute buttonLink function\n   *     E-->>U: Return function result\n   *   else buttonLink is a URL string\n   *     E->>N: navigateForward(buttonLink)\n   *     N-->>E: Return navigation result\n   *     E-->>U: Return navigation result\n   *   end\n   *\n   * @return {boolean | void | Promise<boolean>}\n   *   - false if no action is taken\n   *   - The result of the buttonLink function if it's a function\n   *   - A Promise resolving to the navigation result if buttonLink is a URL\n   * @memberOf EmptyStateComponent\n   */\n  handleClick(): boolean | void | Promise<boolean> {\n    const fn = this.buttonLink;\n    if(!fn)\n      return false;\n    if(fn instanceof Function)\n      return fn();\n    return this.navController.navigateForward(fn as string);\n  }\n\n\n /**\n   * @description Generates a localized and sanitized subtitle for search results.\n   * @summary This method takes a content string, typically the subtitle, and processes it\n   * through the translation service. It replaces a placeholder ('value0') with the actual\n   * search value, then sanitizes the result to safely use as HTML. This is particularly\n   * useful for displaying dynamic, localized messages in the empty state when a search\n   * yields no results.\n   *\n   * @param {string} content - The content string to be translated and processed\n   * @return {Promise<SafeHtml>} A promise that resolves to a sanitized HTML string\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant E as EmptyStateComponent\n   *   participant T as TranslateService\n   *   participant S as DomSanitizer\n   *\n   *   E->>T: instant(content, {'value0': searchValue})\n   *   T-->>E: Return translated string\n   *   E->>S: bypassSecurityTrustHtml(translatedString)\n   *   S-->>E: Return sanitized SafeHtml\n   *\n   * @memberOf EmptyStateComponent\n   */\n  async getSearchSubtitle(content: string): Promise<SafeHtml> {\n    const result = await this.translate.instant(content, {'value0': this.searchValue});\n    return this.sanitizer.bypassSecurityTrustHtml(result);\n  }\n}\n","\n<ion-card id=\"dcf-card-empty-state\" [ngClass]=\"className\">\n  <ion-card-content>\n    @if(icon && showIcon) {\n      <div class=\"dcf-icon-container\">\n        <ion-icon\n          name=\"alert-circle-outline\"\n          size=\"large\"\n          color=\"danger\"\n          />\n      </div>\n    }\n    @if(title) {\n      <h5 [class]=\"titleColor\" [innerHTML]=\"title\"></h5>\n    }\n    @if(subtitle) {\n      @if(!searchValue) {\n        <p [class]=\"subtitleColor\" [innerHTML]=\"subtitle\"></p>\n      } @else {\n        <p [class]=\"subtitleColor\" [innerHTML]=\"searchSubtitle\"></p>\n      }\n    }\n    @if(buttonLink && buttonText) {\n      <div>\n        <ion-button\n          [size]=\"buttonSize\"\n          [fill]=\"buttonFill\"\n          [color]=\"buttonColor\"\n          (click)=\"handleClick()\">\n          {{  buttonText }}\n        </ion-button>\n      </div>\n    }\n  </ion-card-content>\n</ion-card>\n"]}
371
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(EmptyStateComponent, [{
372
+ type: Component,
373
+ args: [{ selector: 'ngx-decaf-empty-state', standalone: true, imports: [
374
+ ForAngularModule,
375
+ IonCard,
376
+ IonCardContent,
377
+ IonTitle,
378
+ IonIcon
379
+ ], template: "\n<ion-card id=\"dcf-card-empty-state\" [ngClass]=\"className\">\n <ion-card-content>\n @if(icon && showIcon) {\n <div class=\"dcf-icon-container\">\n <ion-icon\n name=\"alert-circle-outline\"\n size=\"large\"\n color=\"danger\"\n />\n </div>\n }\n @if(title) {\n <h5 [class]=\"titleColor\" [innerHTML]=\"title\"></h5>\n }\n @if(subtitle) {\n @if(!searchValue) {\n <p [class]=\"subtitleColor\" [innerHTML]=\"subtitle\"></p>\n } @else {\n <p [class]=\"subtitleColor\" [innerHTML]=\"searchSubtitle\"></p>\n }\n }\n @if(buttonLink && buttonText) {\n <div>\n <ion-button\n [size]=\"buttonSize\"\n [fill]=\"buttonFill\"\n [color]=\"buttonColor\"\n (click)=\"handleClick()\">\n {{ buttonText }}\n </ion-button>\n </div>\n }\n </ion-card-content>\n</ion-card>\n", styles: ["ion-card{text-align:center}ion-card ion-button{margin-top:.75rem}ion-card ion-icon{font-size:2.5rem}ion-card .dcf-icon-container{transform:scale(1.25);opacity:.75;margin-top:1.25rem!important;margin-bottom:.5rem!important}ion-card .dcf-ititle{font-weight:600!important;color:var(--ion-color-gray-6)!important}ion-card .dcf-isubtitle{font-weight:500!important}\n"] }]
380
+ }], () => [], { title: [{
381
+ type: Input
382
+ }], titleColor: [{
383
+ type: Input
384
+ }], subtitle: [{
385
+ type: Input
386
+ }], subtitleColor: [{
387
+ type: Input
388
+ }], showIcon: [{
389
+ type: Input
390
+ }], icon: [{
391
+ type: Input
392
+ }], iconSize: [{
393
+ type: Input
394
+ }], iconColor: [{
395
+ type: Input
396
+ }], buttonLink: [{
397
+ type: Input
398
+ }], buttonText: [{
399
+ type: Input
400
+ }], buttonFill: [{
401
+ type: Input
402
+ }], buttonColor: [{
403
+ type: Input
404
+ }], buttonSize: [{
405
+ type: Input
406
+ }], searchValue: [{
407
+ type: Input
408
+ }] }); })();
409
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(EmptyStateComponent, { className: "EmptyStateComponent", filePath: "components/empty-state/empty-state.component.ts", lineNumber: 72 }); })();
410
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"empty-state.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/empty-state/empty-state.component.ts","../../../../../src/lib/components/empty-state/empty-state.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAW,MAAM,eAAe,CAAC;AAElE,OAAO,EACL,OAAO,EACP,cAAc,EACd,OAAO,EACP,QAAQ,EACR,aAAa,EACd,MACI,2BAA2B,CAAC;AACjC,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,OAAO,EAAmB,MAAM,cAAc,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,YAAY,EAAY,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;;;;ICbjD,8BAAgC;IAC9B,8BAII;IACN,iBAAM;;;IAGN,wBAAkD;;;IAA9C,gCAAoB;IAAC,2DAAmB;;;IAI1C,uBAAsD;;;IAAnD,mCAAuB;IAAC,8DAAsB;;;IAEjD,uBAA4D;;;IAAzD,mCAAuB;IAAC,oEAA4B;;;IADvD,AAFF,wFAAmB,2EAEV;;;IAFT,6CAIC;;;;IAIC,AADF,2BAAK,oBAKuB;IAAxB,2LAAS,oBAAa,KAAC;IACvB,YACF;IACF,AADE,iBAAa,EACT;;;IANF,cAAmB;IAEnB,AADA,AADA,wCAAmB,2BACA,6BACE;IAErB,cACF;IADE,kDACF;;ADTR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AAgBI,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,gBAAgB;IAkMvD;;;;;;;OAOG;IACH;QACE,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAzM/B;;;;;;;;;WASG;QAEH,UAAK,GAAW,OAAO,CAAC;QAExB;;;;;;;;;WASG;QAEH,eAAU,GAAG,QAAQ,CAAC;QAEtB;;;;;;;;WAQG;QAEH,aAAQ,GAAW,EAAE,CAAC;QAEtB;;;;;;;;;WASG;QAEH,kBAAa,GAAW,QAAQ,CAAC;QAEjC;;;;;;;;;WASG;QAEH,aAAQ,GAAoB,IAAI,CAAC;QAEjC;;;;;;;;;WASG;QAEH,SAAI,GAAW,wBAAwB,CAAC;QAExC;;;;;;;;WAQG;QAEH,aAAQ,GAAuB,OAAO,CAAC;QAEvC;;;;;;;;WAQG;QAEH,cAAS,GAAsB,QAAQ,CAAC;QA0BxC;;;;;;;;;WASG;QAEH,eAAU,GAAmC,OAAO,CAAC;QAErD;;;;;;;;WAQG;QAEH,gBAAW,GAAW,SAAS,CAAC;QAEhC;;;;;;;;WAQG;QAEH,eAAU,GAAmC,SAAS,CAAC;QAcvD;;;;;;;;WAQG;QACK,kBAAa,GAAkB,MAAM,CAAC,aAAa,CAAC,CAAC;QAErD,cAAS,GAAiB,MAAM,CAAC,YAAY,CAAC,CAAC;QAE/C,cAAS,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAe7D,QAAQ,CAAC,QAAQ,CAAC,CAAC;IACrB,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;IACH,KAAK,CAAC,QAAQ;QACZ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,YAAY,GAAG,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,GAAG,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC/C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAEhD,0BAA0B;QAC1B,oEAAoE;QACpE,0EAA0E;QAC1E,8EAA8E;QAC9E,IAAI;QAEJ,IAAI,CAAC,UAAU,GAAG,mBAAmB,IAAI,CAAC,UAAU,EAAE,CAAC;QACvD,IAAI,CAAC,aAAa,GAAG,sBAAsB,IAAI,CAAC,UAAU,EAAE,CAAC;QAE7D,IAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY;YACtC,IAAI,CAAC,cAAc,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAkB,CAAC,CAAC;IAChF,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAgCG;IACH,WAAW;QACT,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC;QAC3B,IAAG,CAAC,EAAE;YACJ,OAAO,KAAK,CAAC;QACf,IAAG,EAAE,YAAY,QAAQ;YACvB,OAAO,EAAE,EAAE,CAAC;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,EAAY,CAAC,CAAC;IAC1D,CAAC;IAGF;;;;;;;;;;;;;;;;;;;;;;;QAuBI;IACH,KAAK,CAAC,iBAAiB,CAAC,OAAe;QACrC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,EAAC,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAC,CAAC,CAAC;QACnF,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC;IACxD,CAAC;oHAnUU,mBAAmB;oEAAnB,mBAAmB;YCrE9B,AADF,mCAA0D,uBACtC;YAoBhB,AAPA,AAHA,AATA,4EAAuB,8DASX,qDAGG,4DAOgB;YAYnC,AADE,iBAAmB,EACV;;YAjCyB,uCAAqB;YAErD,eAQC;YARD,mDAQC;YACD,cAEC;YAFD,oCAEC;YACD,cAMC;YAND,uCAMC;YACD,cAUC;YAVD,2DAUC;4BD+BD,gBAAgB,4BAChB,OAAO;YACP,cAAc;YAEd,OAAO;;AAIE,mBAAmB;IAf/B,OAAO,EAAE;;GAeG,mBAAmB,CAoU/B;;iFApUY,mBAAmB;cAd/B,SAAS;2BACE,uBAAuB,cAGrB,IAAI,WACP;oBACP,gBAAgB;oBAChB,OAAO;oBACP,cAAc;oBACd,QAAQ;oBACR,OAAO;iBACR;oBAgBD,KAAK;kBADJ,KAAK;YAcN,UAAU;kBADT,KAAK;YAaN,QAAQ;kBADP,KAAK;YAcN,aAAa;kBADZ,KAAK;YAcN,QAAQ;kBADP,KAAK;YAcN,IAAI;kBADH,KAAK;YAaN,QAAQ;kBADP,KAAK;YAaN,SAAS;kBADR,KAAK;YAaN,UAAU;kBADT,KAAK;YAaN,UAAU;kBADT,KAAK;YAcN,UAAU;kBADT,KAAK;YAaN,WAAW;kBADV,KAAK;YAaN,UAAU;kBADT,KAAK;YAaN,WAAW;kBADV,KAAK;;kFA7KK,mBAAmB","sourcesContent":["import { Component, inject, Input, OnInit  } from '@angular/core';\nimport { Color, PredefinedColors } from '@ionic/core';\nimport {\n  IonCard,\n  IonCardContent,\n  IonIcon,\n  IonTitle,\n  NavController\n}\nfrom '@ionic/angular/standalone';\nimport * as allIcons from 'ionicons/icons';\nimport { addIcons } from 'ionicons';\nimport { ForAngularModule } from '../../for-angular.module';\nimport { Dynamic, StringOrBoolean } from '../../engine';\nimport { stringToBoolean } from '../../helpers';\nimport { NgxBaseComponent } from '../../engine/NgxBaseComponent';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { TranslateService } from '@ngx-translate/core';\nimport { FunctionLike } from '../../engine/types';\n\n\n/**\n * @description Component for displaying empty state messages with optional actions.\n * @summary This component provides a standardized way to display empty state messages\n * when no data is available or when a user needs to take an action to populate content.\n * It includes customizable title, subtitle, icon, and action button elements that can be\n * styled and configured through input properties. The component supports localization\n * and can trigger navigation or custom actions when the button is clicked.\n *\n * @mermaid\n * classDiagram\n *   class EmptyStateComponent {\n *     +string title\n *     +string titleColor\n *     +string subtitle\n *     +string subtitleColor\n *     +StringOrBoolean showIcon\n *     +string icon\n *     +string iconSize\n *     +PredefinedColors iconColor\n *     +string|Function buttonLink\n *     +string buttonText\n *     +string buttonFill\n *     +Color buttonColor\n *     +string buttonSize\n *     +string searchValue\n *     -NavController navController\n *     +ngOnInit()\n *     +handleClick()\n *   }\n *   EmptyStateComponent --|> NgxBaseComponent\n *   EmptyStateComponent --|> OnInit\n *\n * @extends {NgxBaseComponent}\n * @implements {OnInit}\n */\n@Dynamic()\n@Component({\n  selector: 'ngx-decaf-empty-state',\n  templateUrl: './empty-state.component.html',\n  styleUrls: ['./empty-state.component.scss'],\n  standalone: true,\n  imports: [\n    ForAngularModule,\n    IonCard,\n    IonCardContent,\n    IonTitle,\n    IonIcon\n  ]\n\n})\nexport class EmptyStateComponent extends NgxBaseComponent implements OnInit {\n\n  /**\n   * @description The main title displayed in the empty state.\n   * @summary Specifies the primary message to show in the empty state component.\n   * This text is typically used to inform the user about why they're seeing an empty view.\n   * If translatable is true, this will be processed through the localization system.\n   *\n   * @type {string}\n   * @default \"title\"\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  title: string = \"title\";\n\n  /**\n   * @description The color of the title text.\n   * @summary Specifies the color for the title text using the application's color system.\n   * The value should correspond to a color variable defined in the application's theme.\n   * The component will automatically prefix this with \"color-\" to create the CSS class.\n   *\n   * @type {string}\n   * @default 'gray-6'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  titleColor = 'gray-6';\n\n  /**\n   * @description The secondary message displayed in the empty state.\n   * @summary Provides additional context or instructions below the main title.\n   * This text is typically used to guide the user on what actions they can take.\n   * If translatable is true, this will be processed through the localization system.\n   *\n   * @type {string | undefined}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  subtitle: string = \"\";\n\n  /**\n   * @description The color of the subtitle text.\n   * @summary Specifies the color for the subtitle text using the application's color system.\n   * The value should correspond to a color variable defined in the application's theme.\n   * The component will automatically prefix this with \"color-\" to create the CSS class.\n   *\n   * @type {string}\n   * @default 'gray-4'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  subtitleColor: string = 'gray-4';\n\n  /**\n   * @description Controls whether the icon is displayed.\n   * @summary Determines if the visual icon should be shown in the empty state.\n   * This can be provided as a boolean or a string that will be converted to a boolean.\n   * Icons help visually communicate the empty state context to users.\n   *\n   * @type {StringOrBoolean}\n   * @default true\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  showIcon: StringOrBoolean = true;\n\n  /**\n   * @description The name of the icon to display.\n   * @summary Specifies which icon to show when showIcon is true.\n   * The component uses the icon system defined in the application,\n   * and this value should correspond to an available icon name.\n   *\n   * @type {string}\n   * @default \"ti-info-square-rounded\"\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  icon: string = \"ti-info-square-rounded\";\n\n  /**\n   * @description The size of the displayed icon.\n   * @summary Controls the size of the icon shown in the empty state.\n   * Can be either 'large' or 'small' to accommodate different layout needs.\n   *\n   * @type {'large' | 'small' | undefined}\n   * @default 'large'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  iconSize?: 'large' | 'small' = 'large';\n\n  /**\n   * @description The color of the displayed icon.\n   * @summary Specifies the color for the icon using Ionic's predefined color system.\n   * This allows the icon to match the application's color scheme.\n   *\n   * @type {PredefinedColors | undefined}\n   * @default 'medium'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  iconColor?: PredefinedColors = 'medium';\n\n  /**\n   * @description The navigation target or action for the button.\n   * @summary Specifies where the button should navigate to when clicked or what function\n   * it should execute. This can be either a URL string or a function that handles navigation.\n   * When not provided, the button will not perform any action.\n   *\n   * @type {string | FunctionLike | undefined}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonLink?: string | FunctionLike;\n\n  /**\n   * @description The text displayed on the action button.\n   * @summary Specifies the label for the action button in the empty state.\n   * If translatable is true, this will be processed through the localization system.\n   * If not provided, the button will not display any text.\n   *\n   * @type {string | undefined}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonText?: string;\n\n  /**\n   * @description The fill style of the action button.\n   * @summary Controls the visual style of the button using Ionic's button fill options.\n   * 'solid' creates a button with a solid background, 'outline' creates a button with\n   * just a border, and 'clear' creates a button with no background or border.\n   *\n   * @type {'clear' | 'solid' | 'outline'}\n   * @default 'solid'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonFill: 'clear' | 'solid' | 'outline' =  'solid';\n\n  /**\n   * @description The color of the action button.\n   * @summary Specifies the color for the button using Ionic's color system.\n   * This allows the button to match the application's color scheme.\n   *\n   * @type {Color}\n   * @default 'primary'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonColor: Color =  'primary';\n\n  /**\n   * @description The size of the action button.\n   * @summary Controls the size of the button shown in the empty state.\n   * Can be 'large', 'small', or 'default' to accommodate different layout needs.\n   *\n   * @type {'large' | 'small' | 'default'}\n   * @default 'default'\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  buttonSize: 'large' | 'small' | 'default' =  'default';\n\n  /**\n   * @description The search value that resulted in no results.\n   * @summary When the empty state is shown due to a search with no results,\n   * this property can hold the search term that was used. This can be displayed\n   * in the empty state message to provide context to the user.\n   *\n   * @type {string}\n   * @memberOf EmptyStateComponent\n   */\n  @Input()\n  searchValue!: string;\n\n  /**\n   * @description Service for handling navigation operations.\n   * @summary Injected service that provides methods for navigating between routes.\n   * This service is used when the buttonLink is a string URL to navigate to that location.\n   *\n   * @private\n   * @type {NavController}\n   * @memberOf EmptyStateComponent\n   */\n  private navController: NavController = inject(NavController);\n\n  private sanitizer: DomSanitizer = inject(DomSanitizer);\n\n  private translate: TranslateService = inject(TranslateService);\n\n  searchSubtitle!: SafeHtml\n\n\n  /**\n   * @description Creates an instance of EmptyStateComponent.\n   * @summary Initializes a new EmptyStateComponent by calling the parent class constructor\n   * with the component name for logging and identification purposes. This component provides\n   * a standardized way to display empty state messages with optional icons and action buttons.\n   *\n   * @memberOf EmptyStateComponent\n   */\n  constructor() {\n    super(\"EmptyStateComponent\");\n    addIcons(allIcons);\n  }\n\n  /**\n   * @description Initializes the component after Angular first displays the data-bound properties.\n   * @summary Sets up the component by processing boolean inputs, applying localization to text\n   * elements if translation is enabled, and formatting CSS classes for title and subtitle colors.\n   * This method prepares the component for user interaction by ensuring all properties are\n   * properly initialized and localized.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as Angular Lifecycle\n   *   participant E as EmptyStateComponent\n   *\n   *   A->>E: ngOnInit()\n   *   E->>E: Process translatable flag\n   *   E->>E: Process showIcon flag\n   *   E->>E: Get locale settings\n   *   alt translatable is true\n   *     E->>E: Localize title\n   *     E->>E: Localize subtitle\n   *     E->>E: Localize buttonText\n   *   end\n   *   E->>E: Format title CSS class\n   *   E->>E: Format subtitle CSS class\n   *\n   * @return {Promise<void>}\n   * @memberOf EmptyStateComponent\n   */\n  async ngOnInit(): Promise<void> {\n    this.parseProps(this);\n    this.translatable = stringToBoolean(this.translatable);\n    this.showIcon = stringToBoolean(this.showIcon);\n    this.locale = this.getLocale(this.translatable);\n\n    // if(this.translatable) {\n    //   this.title = generateLocaleFromString(this.locale, this.title);\n    //   this.subtitle = generateLocaleFromString(this.locale, this.subtitle);\n    //   this.buttonText = generateLocaleFromString(this.locale, this.buttonText);\n    // }\n\n    this.titleColor = `dcf-title color-${this.titleColor}`;\n    this.subtitleColor = `dcf-subtitle color-${this.titleColor}`;\n\n    if(this.searchValue && this.translatable)\n      this.searchSubtitle = await this.getSearchSubtitle(this.subtitle as string);\n  }\n\n  /**\n   * @description Handles click events on the action button.\n   * @summary This method is triggered when the user clicks the action button in the empty state\n   * component. It supports three navigation patterns: 1) no action when buttonLink is not provided,\n   * 2) custom function execution when buttonLink is a function, and 3) navigation to a specific URL\n   * when buttonLink is a string. This flexibility allows the empty state to trigger various actions\n   * based on the context in which it's used.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant E as EmptyStateComponent\n   *   participant N as NavController\n   *\n   *   U->>E: Click action button\n   *   E->>E: handleClick()\n   *   alt buttonLink is not provided\n   *     E-->>U: Return false (no action)\n   *   else buttonLink is a function\n   *     E->>E: Execute buttonLink function\n   *     E-->>U: Return function result\n   *   else buttonLink is a URL string\n   *     E->>N: navigateForward(buttonLink)\n   *     N-->>E: Return navigation result\n   *     E-->>U: Return navigation result\n   *   end\n   *\n   * @return {boolean | void | Promise<boolean>}\n   *   - false if no action is taken\n   *   - The result of the buttonLink function if it's a function\n   *   - A Promise resolving to the navigation result if buttonLink is a URL\n   * @memberOf EmptyStateComponent\n   */\n  handleClick(): boolean | void | Promise<boolean> {\n    const fn = this.buttonLink;\n    if(!fn)\n      return false;\n    if(fn instanceof Function)\n      return fn();\n    return this.navController.navigateForward(fn as string);\n  }\n\n\n /**\n   * @description Generates a localized and sanitized subtitle for search results.\n   * @summary This method takes a content string, typically the subtitle, and processes it\n   * through the translation service. It replaces a placeholder ('value0') with the actual\n   * search value, then sanitizes the result to safely use as HTML. This is particularly\n   * useful for displaying dynamic, localized messages in the empty state when a search\n   * yields no results.\n   *\n   * @param {string} content - The content string to be translated and processed\n   * @return {Promise<SafeHtml>} A promise that resolves to a sanitized HTML string\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant E as EmptyStateComponent\n   *   participant T as TranslateService\n   *   participant S as DomSanitizer\n   *\n   *   E->>T: instant(content, {'value0': searchValue})\n   *   T-->>E: Return translated string\n   *   E->>S: bypassSecurityTrustHtml(translatedString)\n   *   S-->>E: Return sanitized SafeHtml\n   *\n   * @memberOf EmptyStateComponent\n   */\n  async getSearchSubtitle(content: string): Promise<SafeHtml> {\n    const result = await this.translate.instant(content, {'value0': this.searchValue});\n    return this.sanitizer.bypassSecurityTrustHtml(result);\n  }\n}\n","\n<ion-card id=\"dcf-card-empty-state\" [ngClass]=\"className\">\n  <ion-card-content>\n    @if(icon && showIcon) {\n      <div class=\"dcf-icon-container\">\n        <ion-icon\n          name=\"alert-circle-outline\"\n          size=\"large\"\n          color=\"danger\"\n          />\n      </div>\n    }\n    @if(title) {\n      <h5 [class]=\"titleColor\" [innerHTML]=\"title\"></h5>\n    }\n    @if(subtitle) {\n      @if(!searchValue) {\n        <p [class]=\"subtitleColor\" [innerHTML]=\"subtitle\"></p>\n      } @else {\n        <p [class]=\"subtitleColor\" [innerHTML]=\"searchSubtitle\"></p>\n      }\n    }\n    @if(buttonLink && buttonText) {\n      <div>\n        <ion-button\n          [size]=\"buttonSize\"\n          [fill]=\"buttonFill\"\n          [color]=\"buttonColor\"\n          (click)=\"handleClick()\">\n          {{  buttonText }}\n        </ion-button>\n      </div>\n    }\n  </ion-card-content>\n</ion-card>\n"]}