@cauca-911/material 18.0.0 → 18.0.1-beta2

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 (81) hide show
  1. package/esm2022/lib/buttons/base-button.mjs +33 -0
  2. package/esm2022/lib/buttons/basic-button/basic-button.component.mjs +64 -0
  3. package/esm2022/lib/buttons/flat-button/flat-button.component.mjs +64 -0
  4. package/esm2022/lib/buttons/icon-button/icon-button.component.mjs +28 -0
  5. package/esm2022/lib/buttons/menu-item/menu-item.component.mjs +68 -0
  6. package/esm2022/lib/buttons/raised-button/raised-button.component.mjs +64 -0
  7. package/esm2022/lib/buttons/stroked-button/stroked-button.component.mjs +71 -0
  8. package/esm2022/lib/cauca-material.component.mjs +6 -5
  9. package/esm2022/lib/cauca-material.module.mjs +14 -52
  10. package/esm2022/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.mjs +14 -10
  11. package/esm2022/lib/cauca-menu-vertical/cauca-menu-vertical.component.mjs +16 -8
  12. package/esm2022/lib/cauca-simple-dialog/cauca-simple-dialog.component.mjs +14 -10
  13. package/esm2022/lib/cauca-slideshow/cauca-slideshow.component.mjs +6 -6
  14. package/esm2022/lib/dialogs/alert-dialog/alert-dialog.component.mjs +57 -0
  15. package/esm2022/lib/dialogs/confirm-dialog/confirm-dialog.component.mjs +69 -0
  16. package/esm2022/lib/dialogs/services/dialog.service.mjs +52 -0
  17. package/esm2022/lib/inputs/cauca-date-time-picker/cauca-date-time-picker.component.mjs +137 -0
  18. package/esm2022/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.mjs +2 -2
  19. package/esm2022/lib/inputs/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +358 -0
  20. package/esm2022/lib/inputs/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +74 -0
  21. package/esm2022/lib/inputs/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +2 -0
  22. package/esm2022/lib/inputs/cauca-input-file/cauca-input-file.component.mjs +147 -0
  23. package/esm2022/lib/inputs/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +99 -0
  24. package/esm2022/lib/inputs/password/models/password-validation.mjs +13 -0
  25. package/esm2022/lib/inputs/password/password-criteria/password-criteria.component.mjs +49 -0
  26. package/esm2022/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.mjs +29 -0
  27. package/esm2022/lib/inputs/password/password-input/password-input.component.mjs +112 -0
  28. package/esm2022/lib/inputs/password/password-selection/password-selection.component.mjs +112 -0
  29. package/esm2022/lib/inputs/password/validators/password-validator.mjs +19 -0
  30. package/esm2022/lib/inputs/select-with-search/select-with-search.component.mjs +157 -0
  31. package/esm2022/lib/layout/expandable-panel/expandable-panel.component.mjs +75 -0
  32. package/esm2022/lib/layout/menu-expandable-panel/menu-expandable-panel.component.mjs +148 -0
  33. package/esm2022/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.mjs +50 -0
  34. package/esm2022/lib/layout/page-title/page-title.component.mjs +86 -0
  35. package/esm2022/lib/notifications/snack-bar/snack-bar.component.mjs +75 -0
  36. package/esm2022/public-api.mjs +21 -4
  37. package/fesm2022/cauca-911-material.mjs +1988 -648
  38. package/fesm2022/cauca-911-material.mjs.map +1 -1
  39. package/lib/buttons/base-button.d.ts +21 -0
  40. package/lib/buttons/basic-button/basic-button.component.d.ts +6 -0
  41. package/lib/buttons/flat-button/flat-button.component.d.ts +6 -0
  42. package/lib/buttons/icon-button/icon-button.component.d.ts +6 -0
  43. package/lib/buttons/menu-item/menu-item.component.d.ts +9 -0
  44. package/lib/buttons/raised-button/raised-button.component.d.ts +6 -0
  45. package/lib/buttons/stroked-button/stroked-button.component.d.ts +6 -0
  46. package/lib/cauca-material.component.d.ts +1 -1
  47. package/lib/cauca-material.module.d.ts +4 -14
  48. package/lib/cauca-menu-sidebar/cauca-menu-sidebar.component.d.ts +1 -1
  49. package/lib/cauca-menu-vertical/cauca-menu-vertical.component.d.ts +1 -1
  50. package/lib/cauca-simple-dialog/cauca-simple-dialog.component.d.ts +1 -1
  51. package/lib/cauca-slideshow/cauca-slideshow.component.d.ts +1 -1
  52. package/lib/dialogs/alert-dialog/alert-dialog.component.d.ts +18 -0
  53. package/lib/dialogs/confirm-dialog/confirm-dialog.component.d.ts +17 -0
  54. package/lib/dialogs/services/dialog.service.d.ts +26 -0
  55. package/lib/{cauca-input-file → inputs/cauca-input-file}/cauca-input-file.component.d.ts +1 -1
  56. package/lib/{cauca-input-multiple-langue → inputs/cauca-input-multiple-langue}/cauca-input-multiple-langue.component.d.ts +1 -1
  57. package/lib/inputs/password/models/password-validation.d.ts +9 -0
  58. package/lib/inputs/password/password-criteria/password-criteria.component.d.ts +9 -0
  59. package/lib/inputs/password/password-criteria-viewer/password-criteria-viewer.component.d.ts +9 -0
  60. package/lib/inputs/password/password-input/password-input.component.d.ts +25 -0
  61. package/lib/inputs/password/password-selection/password-selection.component.d.ts +20 -0
  62. package/lib/inputs/password/validators/password-validator.d.ts +9 -0
  63. package/lib/inputs/select-with-search/select-with-search.component.d.ts +32 -0
  64. package/lib/layout/expandable-panel/expandable-panel.component.d.ts +10 -0
  65. package/lib/layout/menu-expandable-panel/menu-expandable-panel.component.d.ts +29 -0
  66. package/lib/layout/menu-expandable-panel-item/menu-expandable-panel-item.component.d.ts +13 -0
  67. package/lib/layout/page-title/page-title.component.d.ts +11 -0
  68. package/lib/notifications/snack-bar/snack-bar.component.d.ts +17 -0
  69. package/package.json +3 -2
  70. package/public-api.d.ts +20 -3
  71. package/esm2022/lib/cauca-date-time-picker/cauca-date-time-picker.component.mjs +0 -137
  72. package/esm2022/lib/cauca-date-time-picker/components/dialog-date-time-picker/dialog-date-time-picker.component.mjs +0 -357
  73. package/esm2022/lib/cauca-date-time-picker/components/mobile-time-picker/mobile-time-picker.component.mjs +0 -74
  74. package/esm2022/lib/cauca-date-time-picker/models/dialog-date-time-picker-data.mjs +0 -2
  75. package/esm2022/lib/cauca-input-file/cauca-input-file.component.mjs +0 -148
  76. package/esm2022/lib/cauca-input-multiple-langue/cauca-input-multiple-langue.component.mjs +0 -87
  77. /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/cauca-date-time-picker.component.d.ts +0 -0
  78. /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/desktop-time-picker/desktop-time-picker.component.d.ts +0 -0
  79. /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/dialog-date-time-picker/dialog-date-time-picker.component.d.ts +0 -0
  80. /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/components/mobile-time-picker/mobile-time-picker.component.d.ts +0 -0
  81. /package/lib/{cauca-date-time-picker → inputs/cauca-date-time-picker}/models/dialog-date-time-picker-data.d.ts +0 -0
@@ -0,0 +1,112 @@
1
+ import { Component, forwardRef, HostBinding, Input } from '@angular/core';
2
+ import { TranslateModule } from '@ngx-translate/core';
3
+ import { PasswordCriteriaViewerComponent } from '../password-criteria-viewer/password-criteria-viewer.component';
4
+ import { FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators } from '@angular/forms';
5
+ import { filter } from 'rxjs';
6
+ import { PasswordInputComponent } from '../password-input/password-input.component';
7
+ import { PasswordValidation } from '../models/password-validation';
8
+ import { PasswordValidator } from '../validators/password-validator';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/forms";
11
+ const _c0 = ["*"];
12
+ export class PasswordSelectionComponent {
13
+ constructor(formBuilder) {
14
+ this.passwordValidation = new PasswordValidation();
15
+ this.disabled = false;
16
+ this.direction = 'row';
17
+ this.formWidth = '50%';
18
+ this.lastPasswordValidationSent = false;
19
+ this.onChange = (value) => value;
20
+ this.onTouched = () => { };
21
+ this.form = formBuilder.group({
22
+ password: ['', Validators.required],
23
+ confirmation: ['', Validators.required]
24
+ }, { validators: (formGroup) => {
25
+ this.passwordValidation = PasswordValidator.validate(formGroup);
26
+ if (!this.passwordValidation.isValid()) {
27
+ return ({ validation: this.passwordValidation });
28
+ }
29
+ return null;
30
+ } });
31
+ this.form.valueChanges.pipe(filter(_ => this.form.valid != this.lastPasswordValidationSent)).subscribe(form => {
32
+ this.lastPasswordValidationSent = this.form.valid;
33
+ if (this.form.valid) {
34
+ this.onChange(form.password);
35
+ }
36
+ else {
37
+ this.onChange('');
38
+ }
39
+ });
40
+ }
41
+ writeValue(value) {
42
+ this.form.get('password').setValue(value);
43
+ this.form.get('confirmation').setValue(value);
44
+ }
45
+ registerOnChange(fn) {
46
+ this.onChange = fn;
47
+ }
48
+ registerOnTouched(fn) {
49
+ this.onTouched = fn;
50
+ }
51
+ setDisabledState(isDisabled) {
52
+ this.disabled = isDisabled;
53
+ if (isDisabled) {
54
+ this.form.get('password').disable();
55
+ this.form.get('confirmation').disable();
56
+ }
57
+ else {
58
+ this.form.get('password').enable();
59
+ this.form.get('confirmation').enable();
60
+ }
61
+ }
62
+ static { this.ɵfac = function PasswordSelectionComponent_Factory(t) { return new (t || PasswordSelectionComponent)(i0.ɵɵdirectiveInject(i1.UntypedFormBuilder)); }; }
63
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PasswordSelectionComponent, selectors: [["app-password-selection"]], hostVars: 4, hostBindings: function PasswordSelectionComponent_HostBindings(rf, ctx) { if (rf & 2) {
64
+ i0.ɵɵstyleProp("flex-direction", ctx.direction)("form", ctx.formWidth, "width");
65
+ } }, inputs: { direction: "direction", formWidth: "formWidth" }, standalone: true, features: [i0.ɵɵProvidersFeature([
66
+ {
67
+ provide: NG_VALUE_ACCESSOR,
68
+ multi: true,
69
+ useExisting: forwardRef(() => PasswordSelectionComponent),
70
+ },
71
+ ]), i0.ɵɵStandaloneFeature], ngContentSelectors: _c0, decls: 7, vars: 9, consts: [[3, "formGroup"], [1, "passwords"], ["autocomplete", "new-password", "label", "password", "formControlName", "password", 3, "translateLabel", "required"], ["autocomplete", "new-password", "label", "passwordConfirmation", "formControlName", "confirmation", 3, "translateLabel", "required"], [1, "errors"], [3, "disabled", "passwordValidation"]], template: function PasswordSelectionComponent_Template(rf, ctx) { if (rf & 1) {
72
+ i0.ɵɵprojectionDef();
73
+ i0.ɵɵelementStart(0, "form", 0)(1, "div", 1);
74
+ i0.ɵɵelement(2, "app-password-input", 2)(3, "app-password-input", 3);
75
+ i0.ɵɵelementEnd();
76
+ i0.ɵɵelementStart(4, "div", 4);
77
+ i0.ɵɵprojection(5);
78
+ i0.ɵɵelementEnd()();
79
+ i0.ɵɵelement(6, "app-password-criteria-viewer", 5);
80
+ } if (rf & 2) {
81
+ i0.ɵɵclassProp("full-width-form", ctx.direction === "column");
82
+ i0.ɵɵproperty("formGroup", ctx.form);
83
+ i0.ɵɵadvance(2);
84
+ i0.ɵɵproperty("translateLabel", true)("required", true);
85
+ i0.ɵɵadvance();
86
+ i0.ɵɵproperty("translateLabel", true)("required", true);
87
+ i0.ɵɵadvance(3);
88
+ i0.ɵɵproperty("disabled", ctx.disabled)("passwordValidation", ctx.passwordValidation);
89
+ } }, dependencies: [PasswordInputComponent, FormsModule, i1.ɵNgNoValidate, i1.NgControlStatus, i1.NgControlStatusGroup, i1.RequiredValidator, ReactiveFormsModule, i1.FormGroupDirective, i1.FormControlName, TranslateModule, PasswordCriteriaViewerComponent], styles: ["[_nghost-%COMP%]{display:flex;gap:20px}form[_ngcontent-%COMP%]{width:50%;display:flex;flex-direction:column}.full-width-form[_ngcontent-%COMP%]{width:100%}.passwords[_ngcontent-%COMP%]{gap:16px;display:flex;flex-direction:column}.criteria[_ngcontent-%COMP%]{flex-grow:1}.disabled[_ngcontent-%COMP%]{opacity:.5}.errors[_ngcontent-%COMP%]{padding:0 16px}"] }); }
90
+ }
91
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PasswordSelectionComponent, [{
92
+ type: Component,
93
+ args: [{ selector: 'app-password-selection', standalone: true, imports: [PasswordInputComponent, FormsModule, ReactiveFormsModule, TranslateModule, PasswordCriteriaViewerComponent], providers: [
94
+ {
95
+ provide: NG_VALUE_ACCESSOR,
96
+ multi: true,
97
+ useExisting: forwardRef(() => PasswordSelectionComponent),
98
+ },
99
+ ], template: "<form [formGroup]=\"form\" [class.full-width-form]=\"direction === 'column'\">\r\n <div class=\"passwords\">\r\n <app-password-input autocomplete=\"new-password\" label=\"password\" [translateLabel]=\"true\" [required]=\"true\" formControlName=\"password\" />\r\n <app-password-input autocomplete=\"new-password\" label=\"passwordConfirmation\" [translateLabel]=\"true\" [required]=\"true\" formControlName=\"confirmation\" />\r\n </div>\r\n <div class=\"errors\">\r\n <ng-content></ng-content>\r\n </div>\r\n</form>\r\n<app-password-criteria-viewer [disabled]=\"disabled\" [passwordValidation]=\"passwordValidation\"></app-password-criteria-viewer>", styles: [":host{display:flex;gap:20px}form{width:50%;display:flex;flex-direction:column}.full-width-form{width:100%}.passwords{gap:16px;display:flex;flex-direction:column}.criteria{flex-grow:1}.disabled{opacity:.5}.errors{padding:0 16px}\n"] }]
100
+ }], () => [{ type: i1.UntypedFormBuilder }], { direction: [{
101
+ type: Input
102
+ }, {
103
+ type: HostBinding,
104
+ args: ['style.flex-direction']
105
+ }], formWidth: [{
106
+ type: Input
107
+ }, {
108
+ type: HostBinding,
109
+ args: ['style.form.width']
110
+ }] }); })();
111
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PasswordSelectionComponent, { className: "PasswordSelectionComponent", filePath: "lib\\inputs\\password\\password-selection\\password-selection.component.ts", lineNumber: 24 }); })();
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"password-selection.component.js","sourceRoot":"","sources":["../../../../../../../projects/cauca-material/src/lib/inputs/password/password-selection/password-selection.component.ts","../../../../../../../projects/cauca-material/src/lib/inputs/password/password-selection/password-selection.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,+BAA+B,EAAE,MAAM,gEAAgE,CAAC;AACjH,OAAO,EAAwB,WAAW,EAAE,iBAAiB,EAAE,mBAAmB,EAA0D,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC/K,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;;;;AAgBrE,MAAM,OAAO,0BAA0B;IAUrC,YAAmB,WAA+B;QAR3C,uBAAkB,GAAuB,IAAI,kBAAkB,EAAE,CAAC;QAClE,aAAQ,GAAY,KAAK,CAAC;QAEoB,cAAS,GAAmB,KAAK,CAAC;QACtC,cAAS,GAAW,KAAK,CAAC;QAEnE,+BAA0B,GAAG,KAAK,CAAC;QAgDpC,aAAQ,GAAG,CAAC,KAAa,EAAU,EAAE,CAAC,KAAK,CAAC;QAE5C,cAAS,GAAG,GAAS,EAAE,GAAsC,CAAC,CAAC;QA/CpE,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC;YAC5B,QAAQ,EAAE,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;YACnC,YAAY,EAAE,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;SACxC,EAAE,EAAE,UAAU,EAAE,CAAC,SAA2B,EAA2B,EAAE;gBACxE,IAAI,CAAC,kBAAkB,GAAG,iBAAiB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;gBAChE,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,EAAE,CAAC;oBACvC,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,kBAAkB,EAAC,CAAC,CAAC;gBAClD,CAAC;gBACD,OAAO,IAAI,CAAC;YACd,CAAC,EAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAC5G,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;YAClD,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;gBACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YACpB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,UAAU,CAAC,KAAa;QAC7B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAEM,iBAAiB,CAAC,EAAO;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAEM,gBAAgB,CAAE,UAAmB;QAC1C,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,UAAU,EAAE,CAAC;YACf,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,OAAO,EAAE,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,MAAM,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;2FAtDU,0BAA0B;oEAA1B,0BAA0B;YAA1B,+CAA0B,gCAAA;4HAR1B;gBACT;oBACE,OAAO,EAAE,iBAAiB;oBAC1B,KAAK,EAAE,IAAI;oBACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;iBAC1D;aACF;;YCpBC,AADJ,+BAA0E,aAC/C;YAEnB,AADA,wCAAwI,4BACgB;YAC5J,iBAAM;YACN,8BAAoB;YAChB,kBAAyB;YAEjC,AADI,iBAAM,EACH;YACP,kDAA6H;;YATpG,6DAAgD;YAAnE,oCAAkB;YAEiD,eAAuB;YAAC,AAAxB,qCAAuB,kBAAkB;YAC7B,cAAuB;YAAC,AAAxB,qCAAuB,kBAAkB;YAMhG,eAAqB;YAAC,AAAtB,uCAAqB,8CAA0C;4BDGjF,sBAAsB,EAAE,WAAW,uFAAE,mBAAmB,6CAAE,eAAe,EAAE,+BAA+B;;iFAWzG,0BAA0B;cAdtC,SAAS;2BACE,wBAAwB,cACtB,IAAI,WACP,CAAC,sBAAsB,EAAE,WAAW,EAAE,mBAAmB,EAAE,eAAe,EAAE,+BAA+B,CAAC,aAG1G;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,KAAK,EAAE,IAAI;wBACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,2BAA2B,CAAC;qBAC1D;iBACF;mDAOoD,SAAS;kBAA7D,KAAK;;kBAAI,WAAW;mBAAC,sBAAsB;YACK,SAAS;kBAAzD,KAAK;;kBAAI,WAAW;mBAAC,kBAAkB;;kFAN7B,0BAA0B","sourcesContent":["import { Component, forwardRef, HostBinding, Input } from '@angular/core';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { PasswordCriteriaViewerComponent } from '../password-criteria-viewer/password-criteria-viewer.component';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule, UntypedFormBuilder, UntypedFormGroup, ValidationErrors, Validators } from '@angular/forms';\r\nimport { filter } from 'rxjs';\r\nimport { PasswordInputComponent } from '../password-input/password-input.component';\r\nimport { PasswordValidation } from '../models/password-validation';\r\nimport { PasswordValidator } from '../validators/password-validator';\r\n\r\n@Component({\r\n  selector: 'app-password-selection',\r\n  standalone: true,\r\n  imports: [PasswordInputComponent, FormsModule, ReactiveFormsModule, TranslateModule, PasswordCriteriaViewerComponent],\r\n  templateUrl: './password-selection.component.html',\r\n  styleUrl: './password-selection.component.scss',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: forwardRef(() => PasswordSelectionComponent),\r\n    },\r\n  ],\r\n})\r\nexport class PasswordSelectionComponent implements ControlValueAccessor {\r\n  public form: UntypedFormGroup;\r\n  public passwordValidation: PasswordValidation = new PasswordValidation();\r\n  public disabled: boolean = false;\r\n\r\n  @Input() @HostBinding('style.flex-direction') public direction: 'row'|'column' = 'row';\r\n  @Input() @HostBinding('style.form.width') public formWidth: string = '50%';\r\n\r\n  private lastPasswordValidationSent = false;\r\n\r\n  public constructor(formBuilder: UntypedFormBuilder) {\r\n    this.form = formBuilder.group({\r\n      password: ['', Validators.required],\r\n      confirmation: ['', Validators.required]\r\n    }, { validators: (formGroup: UntypedFormGroup): ValidationErrors | null => {\r\n      this.passwordValidation = PasswordValidator.validate(formGroup);\r\n      if (!this.passwordValidation.isValid()) {\r\n        return ({ validation: this.passwordValidation});\r\n      }\r\n      return null;\r\n    }});\r\n\r\n    this.form.valueChanges.pipe(filter(_ => this.form.valid != this.lastPasswordValidationSent)).subscribe(form => {\r\n      this.lastPasswordValidationSent = this.form.valid;\r\n      if (this.form.valid) {\r\n        this.onChange(form.password);\r\n      } else {\r\n        this.onChange('');\r\n      }\r\n    });\r\n  }\r\n\r\n  public writeValue(value: string): void {\r\n    this.form.get('password').setValue(value);\r\n    this.form.get('confirmation').setValue(value);\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    if (isDisabled) {\r\n      this.form.get('password').disable();\r\n      this.form.get('confirmation').disable();\r\n    } else {\r\n      this.form.get('password').enable();\r\n      this.form.get('confirmation').enable();\r\n    }\r\n  }\r\n\r\n  public onChange = (value: string): string => value;\r\n\r\n  public onTouched = (): void => {/* This method needs to be empty */ };\r\n\r\n}\r\n","<form [formGroup]=\"form\" [class.full-width-form]=\"direction === 'column'\">\r\n    <div class=\"passwords\">\r\n        <app-password-input autocomplete=\"new-password\" label=\"password\" [translateLabel]=\"true\" [required]=\"true\" formControlName=\"password\" />\r\n        <app-password-input autocomplete=\"new-password\" label=\"passwordConfirmation\" [translateLabel]=\"true\" [required]=\"true\" formControlName=\"confirmation\" />\r\n    </div>\r\n    <div class=\"errors\">\r\n        <ng-content></ng-content>\r\n    </div>\r\n</form>\r\n<app-password-criteria-viewer [disabled]=\"disabled\" [passwordValidation]=\"passwordValidation\"></app-password-criteria-viewer>"]}
@@ -0,0 +1,19 @@
1
+ import { PasswordValidation } from '../models/password-validation';
2
+ export class PasswordValidator {
3
+ static { this.passwordMinLength = 13; }
4
+ static validate(formGroup) {
5
+ const password = formGroup.controls['password'].value;
6
+ const confirmedPassword = formGroup.controls['confirmation'].value;
7
+ return new PasswordValidation(password.length >= this.passwordMinLength, this.hasNumeric(password), this.hasLowerCaseAndUpperCase(password), this.hasSpecialCharacter(password), password && password === confirmedPassword);
8
+ }
9
+ static hasLowerCaseAndUpperCase(password) {
10
+ return /^(?=.*[a-z])(?=.*[A-Z])/.test(password);
11
+ }
12
+ static hasNumeric(password) {
13
+ return /(?=.*\d)/.test(password);
14
+ }
15
+ static hasSpecialCharacter(password) {
16
+ return new RegExp(/[!@#$%^&*()_+\-=\[\]{};':"\\|,.<>\/?]/).test(password);
17
+ }
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQtdmFsaWRhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2F1Y2EtbWF0ZXJpYWwvc3JjL2xpYi9pbnB1dHMvcGFzc3dvcmQvdmFsaWRhdG9ycy9wYXNzd29yZC12YWxpZGF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFbkUsTUFBTSxPQUFPLGlCQUFpQjthQUNILHNCQUFpQixHQUFHLEVBQUUsQ0FBQztJQUV2QyxNQUFNLENBQUMsUUFBUSxDQUFDLFNBQTJCO1FBQzlDLE1BQU0sUUFBUSxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUMsS0FBSyxDQUFDO1FBQ3RELE1BQU0saUJBQWlCLEdBQUcsU0FBUyxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDbkUsT0FBTyxJQUFJLGtCQUFrQixDQUN6QixRQUFRLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFDekMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsRUFDekIsSUFBSSxDQUFDLHdCQUF3QixDQUFDLFFBQVEsQ0FBQyxFQUN2QyxJQUFJLENBQUMsbUJBQW1CLENBQUMsUUFBUSxDQUFDLEVBQ2xDLFFBQVEsSUFBSSxRQUFRLEtBQUssaUJBQWlCLENBQzdDLENBQUM7SUFDTixDQUFDO0lBRU0sTUFBTSxDQUFDLHdCQUF3QixDQUFDLFFBQWdCO1FBQ25ELE9BQU8seUJBQXlCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxNQUFNLENBQUMsVUFBVSxDQUFDLFFBQWE7UUFDbEMsT0FBTyxVQUFVLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFTSxNQUFNLENBQUMsbUJBQW1CLENBQUMsUUFBYTtRQUMzQyxPQUFPLElBQUksTUFBTSxDQUFDLHVDQUF1QyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzlFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBVbnR5cGVkRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgUGFzc3dvcmRWYWxpZGF0aW9uIH0gZnJvbSAnLi4vbW9kZWxzL3Bhc3N3b3JkLXZhbGlkYXRpb24nO1xuXG5leHBvcnQgY2xhc3MgUGFzc3dvcmRWYWxpZGF0b3Ige1xuICAgIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgcGFzc3dvcmRNaW5MZW5ndGggPSAxMztcblxuICAgIHB1YmxpYyBzdGF0aWMgdmFsaWRhdGUoZm9ybUdyb3VwOiBVbnR5cGVkRm9ybUdyb3VwKTogUGFzc3dvcmRWYWxpZGF0aW9uIHtcbiAgICAgICAgY29uc3QgcGFzc3dvcmQgPSBmb3JtR3JvdXAuY29udHJvbHNbJ3Bhc3N3b3JkJ10udmFsdWU7XG4gICAgICAgIGNvbnN0IGNvbmZpcm1lZFBhc3N3b3JkID0gZm9ybUdyb3VwLmNvbnRyb2xzWydjb25maXJtYXRpb24nXS52YWx1ZTtcbiAgICAgICAgcmV0dXJuIG5ldyBQYXNzd29yZFZhbGlkYXRpb24oXG4gICAgICAgICAgICBwYXNzd29yZC5sZW5ndGggPj0gdGhpcy5wYXNzd29yZE1pbkxlbmd0aCxcbiAgICAgICAgICAgIHRoaXMuaGFzTnVtZXJpYyhwYXNzd29yZCksXG4gICAgICAgICAgICB0aGlzLmhhc0xvd2VyQ2FzZUFuZFVwcGVyQ2FzZShwYXNzd29yZCksXG4gICAgICAgICAgICB0aGlzLmhhc1NwZWNpYWxDaGFyYWN0ZXIocGFzc3dvcmQpLFxuICAgICAgICAgICAgcGFzc3dvcmQgJiYgcGFzc3dvcmQgPT09IGNvbmZpcm1lZFBhc3N3b3JkLFxuICAgICAgICApO1xuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgaGFzTG93ZXJDYXNlQW5kVXBwZXJDYXNlKHBhc3N3b3JkOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIC9eKD89LipbYS16XSkoPz0uKltBLVpdKS8udGVzdChwYXNzd29yZCk7XG4gICAgfVxuXG4gICAgcHVibGljIHN0YXRpYyBoYXNOdW1lcmljKHBhc3N3b3JkOiBhbnkpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIC8oPz0uKlxcZCkvLnRlc3QocGFzc3dvcmQpO1xuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgaGFzU3BlY2lhbENoYXJhY3RlcihwYXNzd29yZDogYW55KTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiBuZXcgUmVnRXhwKC9bIUAjJCVeJiooKV8rXFwtPVxcW1xcXXt9Oyc6XCJcXFxcfCwuPD5cXC8/XS8pLnRlc3QocGFzc3dvcmQpO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,157 @@
1
+ import { NgForOf, AsyncPipe } from '@angular/common';
2
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
+ import { ReactiveFormsModule, FormsModule, FormControl } from '@angular/forms';
4
+ import { MatError, MatFormFieldModule } from '@angular/material/form-field';
5
+ import { MatSelectModule } from '@angular/material/select';
6
+ import { TranslateModule } from '@ngx-translate/core';
7
+ import { NgxMatSelectSearchModule } from 'ngx-mat-select-search';
8
+ import { ReplaySubject, Subject, takeUntil } from 'rxjs';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/material/form-field";
11
+ import * as i2 from "@angular/material/select";
12
+ import * as i3 from "@angular/material/core";
13
+ import * as i4 from "@ngx-translate/core";
14
+ import * as i5 from "@angular/forms";
15
+ import * as i6 from "ngx-mat-select-search";
16
+ const _c0 = ["singleSelect"];
17
+ const _c1 = ["*"];
18
+ function SelectWithSearchComponent_mat_option_10_Template(rf, ctx) { if (rf & 1) {
19
+ i0.ɵɵelementStart(0, "mat-option", 4);
20
+ i0.ɵɵtext(1);
21
+ i0.ɵɵelementEnd();
22
+ } if (rf & 2) {
23
+ const option_r1 = ctx.$implicit;
24
+ i0.ɵɵproperty("value", option_r1.id);
25
+ i0.ɵɵadvance();
26
+ i0.ɵɵtextInterpolate1(" ", option_r1.name, " ");
27
+ } }
28
+ export class SelectWithSearchComponent {
29
+ constructor() {
30
+ this.selectFirstOptionByDefault = false;
31
+ this.optionFilterControl = new FormControl('');
32
+ this.filteredOptions = new ReplaySubject();
33
+ this.isDisabled = true;
34
+ this.valueChanged = new EventEmitter();
35
+ this._onDestroy = new Subject();
36
+ this.allOptions = [];
37
+ }
38
+ set options(newOptions) {
39
+ if (newOptions) {
40
+ this.allOptions = newOptions;
41
+ this.filteredOptions.next(newOptions.slice());
42
+ this.setInitialSelectedOption();
43
+ this.isDisabled = (this.options.length < 1);
44
+ }
45
+ else {
46
+ this.allOptions = [];
47
+ this.isDisabled = (this.options.length < 1);
48
+ }
49
+ }
50
+ get options() {
51
+ return this.allOptions;
52
+ }
53
+ set value(newValue) {
54
+ if (newValue !== this.selectedOptionId) {
55
+ this.selectedOptionId = newValue;
56
+ this.valueChanged.emit(this.value);
57
+ }
58
+ }
59
+ get value() {
60
+ return this.selectedOptionId;
61
+ }
62
+ ngOnInit() {
63
+ this.optionFilterControl.valueChanges
64
+ .pipe(takeUntil(this._onDestroy))
65
+ .subscribe(() => {
66
+ this.filterCities();
67
+ });
68
+ }
69
+ ngOnDestroy() {
70
+ this._onDestroy.next();
71
+ this._onDestroy.complete();
72
+ }
73
+ filterCities() {
74
+ if (!this.options) {
75
+ return;
76
+ }
77
+ let filter = this.optionFilterControl.value;
78
+ if (!filter) {
79
+ this.filteredOptions.next(this.options.slice());
80
+ return;
81
+ }
82
+ else {
83
+ filter = filter.toLowerCase();
84
+ }
85
+ this.filteredOptions.next(this.options
86
+ .filter(option => option.name.toLowerCase().indexOf(filter) > -1));
87
+ }
88
+ setInitialSelectedOption() {
89
+ if (this.value) {
90
+ const city = this.options.find((c) => c.id === this.value);
91
+ if (!city) {
92
+ this.selectFirstOption();
93
+ }
94
+ }
95
+ else if (this.options.length > 0 && this.selectFirstOptionByDefault) {
96
+ this.selectFirstOption();
97
+ }
98
+ }
99
+ selectFirstOption() {
100
+ this.value = this.options[0].id;
101
+ }
102
+ static { this.ɵfac = function SelectWithSearchComponent_Factory(t) { return new (t || SelectWithSearchComponent)(); }; }
103
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectWithSearchComponent, selectors: [["app-select-with-search"]], viewQuery: function SelectWithSearchComponent_Query(rf, ctx) { if (rf & 1) {
104
+ i0.ɵɵviewQuery(_c0, 7);
105
+ } if (rf & 2) {
106
+ let _t;
107
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.singleSelect = _t.first);
108
+ } }, inputs: { label: "label", selectFirstOptionByDefault: "selectFirstOptionByDefault", options: "options", value: "value" }, outputs: { valueChanged: "valueChanged" }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c1, decls: 12, vars: 15, consts: [["subscriptSizing", "dynamic", 1, "full-width-field", "header", "dense"], [3, "valueChange", "value", "disabled"], [3, "formControl", "placeholderLabel", "noEntriesFoundLabel"], [3, "value", 4, "ngFor", "ngForOf"], [3, "value"]], template: function SelectWithSearchComponent_Template(rf, ctx) { if (rf & 1) {
109
+ i0.ɵɵprojectionDef();
110
+ i0.ɵɵelementStart(0, "mat-form-field", 0);
111
+ i0.ɵɵprojection(1);
112
+ i0.ɵɵelementStart(2, "mat-label");
113
+ i0.ɵɵtext(3);
114
+ i0.ɵɵpipe(4, "translate");
115
+ i0.ɵɵelementEnd();
116
+ i0.ɵɵelementStart(5, "mat-select", 1);
117
+ i0.ɵɵtwoWayListener("valueChange", function SelectWithSearchComponent_Template_mat_select_valueChange_5_listener($event) { i0.ɵɵtwoWayBindingSet(ctx.value, $event) || (ctx.value = $event); return $event; });
118
+ i0.ɵɵelementStart(6, "mat-option");
119
+ i0.ɵɵelement(7, "ngx-mat-select-search", 2);
120
+ i0.ɵɵpipe(8, "translate");
121
+ i0.ɵɵpipe(9, "translate");
122
+ i0.ɵɵelementEnd();
123
+ i0.ɵɵtemplate(10, SelectWithSearchComponent_mat_option_10_Template, 2, 2, "mat-option", 3);
124
+ i0.ɵɵpipe(11, "async");
125
+ i0.ɵɵelementEnd()();
126
+ } if (rf & 2) {
127
+ i0.ɵɵadvance(3);
128
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(4, 7, ctx.label));
129
+ i0.ɵɵadvance(2);
130
+ i0.ɵɵtwoWayProperty("value", ctx.value);
131
+ i0.ɵɵproperty("disabled", ctx.isDisabled);
132
+ i0.ɵɵadvance(2);
133
+ i0.ɵɵproperty("formControl", ctx.optionFilterControl)("placeholderLabel", i0.ɵɵpipeBind1(8, 9, "search"))("noEntriesFoundLabel", i0.ɵɵpipeBind1(9, 11, "noResult"));
134
+ i0.ɵɵadvance(3);
135
+ i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(11, 13, ctx.filteredOptions));
136
+ } }, dependencies: [NgForOf, AsyncPipe, MatSelectModule, i1.MatFormField, i1.MatLabel, i2.MatSelect, i3.MatOption, TranslateModule, i4.TranslatePipe, MatFormFieldModule, ReactiveFormsModule, i5.NgControlStatus, i5.FormControlDirective, FormsModule, NgxMatSelectSearchModule, i6.MatSelectSearchComponent] }); }
137
+ }
138
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectWithSearchComponent, [{
139
+ type: Component,
140
+ args: [{ selector: 'app-select-with-search', standalone: true, imports: [NgForOf, AsyncPipe, MatError, MatSelectModule, TranslateModule, MatFormFieldModule, ReactiveFormsModule, FormsModule, NgxMatSelectSearchModule], template: "<mat-form-field class=\"full-width-field header dense\" subscriptSizing=\"dynamic\">\r\n <ng-content></ng-content>\r\n <mat-label>{{ label | translate }}</mat-label>\r\n <mat-select [(value)]=\"value\" [disabled]=\"isDisabled\">\r\n <mat-option>\r\n <ngx-mat-select-search [formControl]=\"optionFilterControl\" [placeholderLabel]=\"'search' | translate\"\r\n [noEntriesFoundLabel]=\"'noResult' | translate\">\r\n </ngx-mat-select-search>\r\n </mat-option>\r\n <mat-option *ngFor=\"let option of filteredOptions | async\" [value]=\"option.id\">\r\n {{option.name}}\r\n </mat-option>\r\n </mat-select>\r\n\r\n</mat-form-field>" }]
141
+ }], null, { label: [{
142
+ type: Input,
143
+ args: [{ required: true }]
144
+ }], selectFirstOptionByDefault: [{
145
+ type: Input
146
+ }], singleSelect: [{
147
+ type: ViewChild,
148
+ args: ['singleSelect', { static: true }]
149
+ }], valueChanged: [{
150
+ type: Output
151
+ }], options: [{
152
+ type: Input
153
+ }], value: [{
154
+ type: Input
155
+ }] }); })();
156
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectWithSearchComponent, { className: "SelectWithSearchComponent", filePath: "lib\\inputs\\select-with-search\\select-with-search.component.ts", lineNumber: 22 }); })();
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-with-search.component.js","sourceRoot":"","sources":["../../../../../../projects/cauca-material/src/lib/inputs/select-with-search/select-with-search.component.ts","../../../../../../projects/cauca-material/src/lib/inputs/select-with-search/select-with-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgForOf, AsyncPipe } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { ReactiveFormsModule, FormsModule, FormControl } from '@angular/forms';\r\nimport { MatError, MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatSelect, MatSelectModule } from '@angular/material/select';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { NgxMatSelectSearchModule } from 'ngx-mat-select-search';\r\nimport { ReplaySubject, Subject, takeUntil } from 'rxjs';\r\n\r\nexport interface Option {\r\n  id: string;\r\n  name: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-select-with-search',\r\n  standalone: true,\r\n  imports: [NgForOf, AsyncPipe, MatError, MatSelectModule, TranslateModule, MatFormFieldModule, ReactiveFormsModule, FormsModule, NgxMatSelectSearchModule],\r\n  templateUrl: './select-with-search.component.html',\r\n  styleUrl: './select-with-search.component.scss'\r\n})\r\nexport class SelectWithSearchComponent implements OnInit, OnDestroy {\r\n  @Input({required: true}) public label: string;\r\n  @Input() public selectFirstOptionByDefault: boolean = false;\r\n\r\n  public optionFilterControl: FormControl<string> = new FormControl<string>('');\r\n  public filteredOptions: ReplaySubject<Option[]> = new ReplaySubject<Option[]>();\r\n  @ViewChild('singleSelect', { static: true }) public singleSelect: MatSelect;\r\n  public isDisabled: boolean = true;\r\n\r\n  @Output()\r\n  public valueChanged = new EventEmitter();\r\n\r\n  protected _onDestroy = new Subject<void>();\r\n\r\n  private selectedOptionId: string;\r\n  private allOptions: Option[] = [];\r\n\r\n  @Input()\r\n  public set options(newOptions: Option[]) {\r\n    if (newOptions) {\r\n      this.allOptions = newOptions;\r\n      this.filteredOptions.next(newOptions.slice());\r\n      this.setInitialSelectedOption();\r\n      this.isDisabled = (this.options.length < 1);\r\n    } else {\r\n      this.allOptions = [];\r\n      this.isDisabled = (this.options.length < 1);\r\n    }\r\n  }\r\n  public get options(): Option[] {\r\n    return this.allOptions;\r\n  }\r\n\r\n  @Input()\r\n  public set value(newValue: string) {\r\n    if (newValue !== this.selectedOptionId) {\r\n      this.selectedOptionId = newValue;\r\n      this.valueChanged.emit(this.value);\r\n    }\r\n  }\r\n  public get value(): string {\r\n    return this.selectedOptionId;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.optionFilterControl.valueChanges\r\n      .pipe(takeUntil(this._onDestroy))\r\n      .subscribe(() => {\r\n        this.filterCities();\r\n      });\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this._onDestroy.next();\r\n    this._onDestroy.complete();\r\n  }\r\n\r\n  private filterCities() {\r\n    if (!this.options) {\r\n      return;\r\n    }\r\n\r\n    let filter = this.optionFilterControl.value;\r\n    if (!filter) {\r\n      this.filteredOptions.next(this.options.slice());\r\n      return;\r\n    } else {\r\n      filter = filter.toLowerCase();\r\n    }\r\n    this.filteredOptions.next(this.options\r\n      .filter(option => option.name.toLowerCase().indexOf(filter) > -1));\r\n  }\r\n\r\n  private setInitialSelectedOption(): void {\r\n    if (this.value) {\r\n      const city = this.options.find((c: Option) => c.id === this.value);\r\n      if (!city) {\r\n        this.selectFirstOption();\r\n      }\r\n    } else if (this.options.length > 0 && this.selectFirstOptionByDefault) {\r\n      this.selectFirstOption();\r\n    }\r\n  }\r\n\r\n  private selectFirstOption(): void {\r\n    this.value = this.options[0].id;\r\n  }\r\n}\r\n","<mat-form-field class=\"full-width-field header dense\" subscriptSizing=\"dynamic\">\r\n    <ng-content></ng-content>\r\n    <mat-label>{{ label | translate }}</mat-label>\r\n    <mat-select [(value)]=\"value\" [disabled]=\"isDisabled\">\r\n        <mat-option>\r\n            <ngx-mat-select-search [formControl]=\"optionFilterControl\" [placeholderLabel]=\"'search' | translate\"\r\n                [noEntriesFoundLabel]=\"'noResult' | translate\">\r\n            </ngx-mat-select-search>\r\n        </mat-option>\r\n        <mat-option *ngFor=\"let option of filteredOptions | async\" [value]=\"option.id\">\r\n            {{option.name}}\r\n        </mat-option>\r\n    </mat-select>\r\n\r\n</mat-form-field>"]}
@@ -0,0 +1,75 @@
1
+ import { AUTO_STYLE, animate, state, style, transition, trigger } from '@angular/animations';
2
+ import { ChangeDetectionStrategy, Component, input, model } from '@angular/core';
3
+ import { MatIcon } from '@angular/material/icon';
4
+ import * as i0 from "@angular/core";
5
+ const _c0 = ["*"];
6
+ const DEFAULT_DURATION = 500;
7
+ export class ExpandablePanelComponent {
8
+ constructor() {
9
+ this.isCollapsed = model(false);
10
+ this.title = input('');
11
+ this.subTitle = input('');
12
+ }
13
+ changeState() {
14
+ this.isCollapsed.update(value => !value);
15
+ }
16
+ static { this.ɵfac = function ExpandablePanelComponent_Factory(t) { return new (t || ExpandablePanelComponent)(); }; }
17
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ExpandablePanelComponent, selectors: [["app-expandable-panel"]], inputs: { isCollapsed: [1, "isCollapsed"], title: [1, "title"], subTitle: [1, "subTitle"] }, outputs: { isCollapsed: "isCollapsedChange" }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c0, decls: 11, vars: 4, consts: [[1, "expansion-button", 3, "click"], [1, "primary"], [1, "body2"], [1, "expansion-panel"]], template: function ExpandablePanelComponent_Template(rf, ctx) { if (rf & 1) {
18
+ i0.ɵɵprojectionDef();
19
+ i0.ɵɵelementStart(0, "section")(1, "div", 0);
20
+ i0.ɵɵlistener("click", function ExpandablePanelComponent_Template_div_click_1_listener() { return ctx.changeState(); });
21
+ i0.ɵɵelementStart(2, "mat-icon");
22
+ i0.ɵɵtext(3, "expand_less");
23
+ i0.ɵɵelementEnd();
24
+ i0.ɵɵelementStart(4, "div")(5, "div", 1);
25
+ i0.ɵɵtext(6);
26
+ i0.ɵɵelementEnd();
27
+ i0.ɵɵelementStart(7, "div", 2);
28
+ i0.ɵɵtext(8);
29
+ i0.ɵɵelementEnd()()();
30
+ i0.ɵɵelementStart(9, "div", 3);
31
+ i0.ɵɵprojection(10);
32
+ i0.ɵɵelementEnd()();
33
+ } if (rf & 2) {
34
+ i0.ɵɵadvance(2);
35
+ i0.ɵɵproperty("@arrow-collapse", ctx.isCollapsed());
36
+ i0.ɵɵadvance(4);
37
+ i0.ɵɵtextInterpolate(ctx.title());
38
+ i0.ɵɵadvance(2);
39
+ i0.ɵɵtextInterpolate(ctx.subTitle());
40
+ i0.ɵɵadvance();
41
+ i0.ɵɵproperty("@collapse", ctx.isCollapsed());
42
+ } }, dependencies: [MatIcon], styles: ["section[_ngcontent-%COMP%]{display:flex;padding:16px 0}.primary[_ngcontent-%COMP%]{font-weight:600}.body2[_ngcontent-%COMP%]{width:fit-content;white-space:nowrap}.expansion-button[_ngcontent-%COMP%]{display:flex;gap:4px;width:240px;padding:0 16px 8px 0;cursor:pointer;height:fit-content}.expansion-panel[_ngcontent-%COMP%]{overflow:hidden;flex:1}"], data: { animation: [
43
+ trigger('collapse', [
44
+ state('false', style({ height: AUTO_STYLE, opacity: 1, visibility: AUTO_STYLE })),
45
+ state('true', style({ height: '0', opacity: 0, visibility: 'hidden' })),
46
+ transition('false => true', animate(DEFAULT_DURATION + 'ms ease-in')),
47
+ transition('true => false', animate(DEFAULT_DURATION + 'ms ease-out'))
48
+ ]),
49
+ trigger('arrow-collapse', [
50
+ state('false', style({ transform: 'rotate(0deg)' })),
51
+ state('true', style({ transform: 'rotate(180deg)' })),
52
+ transition('false => true', animate(DEFAULT_DURATION + 'ms ease-in')),
53
+ transition('true => false', animate(DEFAULT_DURATION + 'ms ease-out'))
54
+ ])
55
+ ] }, changeDetection: 0 }); }
56
+ }
57
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ExpandablePanelComponent, [{
58
+ type: Component,
59
+ args: [{ selector: 'app-expandable-panel', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [MatIcon], animations: [
60
+ trigger('collapse', [
61
+ state('false', style({ height: AUTO_STYLE, opacity: 1, visibility: AUTO_STYLE })),
62
+ state('true', style({ height: '0', opacity: 0, visibility: 'hidden' })),
63
+ transition('false => true', animate(DEFAULT_DURATION + 'ms ease-in')),
64
+ transition('true => false', animate(DEFAULT_DURATION + 'ms ease-out'))
65
+ ]),
66
+ trigger('arrow-collapse', [
67
+ state('false', style({ transform: 'rotate(0deg)' })),
68
+ state('true', style({ transform: 'rotate(180deg)' })),
69
+ transition('false => true', animate(DEFAULT_DURATION + 'ms ease-in')),
70
+ transition('true => false', animate(DEFAULT_DURATION + 'ms ease-out'))
71
+ ])
72
+ ], template: "<section>\r\n <div class=\"expansion-button\" (click)=\"changeState()\">\r\n <mat-icon [@arrow-collapse]=\"isCollapsed()\">expand_less</mat-icon>\r\n <div>\r\n <div class=\"primary\">{{title()}}</div>\r\n <div class=\"body2\">{{subTitle()}}</div>\r\n </div>\r\n </div>\r\n <div class=\"expansion-panel\" [@collapse]=\"isCollapsed()\">\r\n <ng-content></ng-content>\r\n </div>\r\n</section>", styles: ["section{display:flex;padding:16px 0}.primary{font-weight:600}.body2{width:fit-content;white-space:nowrap}.expansion-button{display:flex;gap:4px;width:240px;padding:0 16px 8px 0;cursor:pointer;height:fit-content}.expansion-panel{overflow:hidden;flex:1}\n"] }]
73
+ }], null, null); })();
74
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ExpandablePanelComponent, { className: "ExpandablePanelComponent", filePath: "lib\\layout\\expandable-panel\\expandable-panel.component.ts", lineNumber: 29 }); })();
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwYW5kYWJsZS1wYW5lbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYXVjYS1tYXRlcmlhbC9zcmMvbGliL2xheW91dC9leHBhbmRhYmxlLXBhbmVsL2V4cGFuZGFibGUtcGFuZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2F1Y2EtbWF0ZXJpYWwvc3JjL2xpYi9sYXlvdXQvZXhwYW5kYWJsZS1wYW5lbC9leHBhbmRhYmxlLXBhbmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzdGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQTRCLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0csT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7QUFFakQsTUFBTSxnQkFBZ0IsR0FBRyxHQUFHLENBQUM7QUF3QjdCLE1BQU0sT0FBTyx3QkFBd0I7SUF0QnJDO1FBdUJTLGdCQUFXLEdBQXlCLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNqRCxVQUFLLEdBQXdCLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUN2QyxhQUFRLEdBQXdCLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztLQUtsRDtJQUhRLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNDLENBQUM7eUZBUFUsd0JBQXdCO29FQUF4Qix3QkFBd0I7O1lDM0JqQyxBQURKLCtCQUFTLGFBQ2lEO1lBQXhCLGtHQUFTLGlCQUFhLElBQUM7WUFD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QztpQkFDSDs7a0ZBRVUsd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVVUT19TVFlMRSwgYW5pbWF0ZSwgc3RhdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XHJcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0U2lnbmFsLCBNb2RlbFNpZ25hbCwgaW5wdXQsIG1vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdEljb24gfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuXHJcbmNvbnN0IERFRkFVTFRfRFVSQVRJT04gPSA1MDA7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1leHBhbmRhYmxlLXBhbmVsJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIGltcG9ydHM6IFtNYXRJY29uXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vZXhwYW5kYWJsZS1wYW5lbC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL2V4cGFuZGFibGUtcGFuZWwuY29tcG9uZW50LnNjc3MnLFxyXG4gIGFuaW1hdGlvbnM6IFtcclxuICAgIHRyaWdnZXIoJ2NvbGxhcHNlJywgW1xyXG4gICAgICBzdGF0ZSgnZmFsc2UnLCBzdHlsZSh7IGhlaWdodDogQVVUT19TVFlMRSwgb3BhY2l0eTogMSwgdmlzaWJpbGl0eTogQVVUT19TVFlMRSB9KSksXHJcbiAgICAgIHN0YXRlKCd0cnVlJywgc3R5bGUoeyBoZWlnaHQ6ICcwJywgb3BhY2l0eTogMCwgdmlzaWJpbGl0eTogJ2hpZGRlbicgfSkpLFxyXG4gICAgICB0cmFuc2l0aW9uKCdmYWxzZSA9PiB0cnVlJywgYW5pbWF0ZShERUZBVUxUX0RVUkFUSU9OICsgJ21zIGVhc2UtaW4nKSksXHJcbiAgICAgIHRyYW5zaXRpb24oJ3RydWUgPT4gZmFsc2UnLCBhbmltYXRlKERFRkFVTFRfRFVSQVRJT04gKyAnbXMgZWFzZS1vdXQnKSlcclxuICAgIF0pLFxyXG4gICAgdHJpZ2dlcignYXJyb3ctY29sbGFwc2UnLCBbXHJcbiAgICAgIHN0YXRlKCdmYWxzZScsIHN0eWxlKHsgdHJhbnNmb3JtOiAncm90YXRlKDBkZWcpJyB9KSksXHJcbiAgICAgIHN0YXRlKCd0cnVlJywgc3R5bGUoeyB0cmFuc2Zvcm06ICdyb3RhdGUoMTgwZGVnKScgfSkpLFxyXG4gICAgICB0cmFuc2l0aW9uKCdmYWxzZSA9PiB0cnVlJywgYW5pbWF0ZShERUZBVUxUX0RVUkFUSU9OICsgJ21zIGVhc2UtaW4nKSksXHJcbiAgICAgIHRyYW5zaXRpb24oJ3RydWUgPT4gZmFsc2UnLCBhbmltYXRlKERFRkFVTFRfRFVSQVRJT04gKyAnbXMgZWFzZS1vdXQnKSlcclxuICAgIF0pXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRXhwYW5kYWJsZVBhbmVsQ29tcG9uZW50IHtcclxuICBwdWJsaWMgaXNDb2xsYXBzZWQ6IE1vZGVsU2lnbmFsPGJvb2xlYW4+ID0gbW9kZWwoZmFsc2UpO1xyXG4gIHB1YmxpYyB0aXRsZTogSW5wdXRTaWduYWw8c3RyaW5nPiA9IGlucHV0KCcnKTtcclxuICBwdWJsaWMgc3ViVGl0bGU6IElucHV0U2lnbmFsPHN0cmluZz4gPSBpbnB1dCgnJyk7XHJcblxyXG4gIHB1YmxpYyBjaGFuZ2VTdGF0ZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuaXNDb2xsYXBzZWQudXBkYXRlKHZhbHVlID0+ICF2YWx1ZSk7XHJcbiAgfVxyXG59XHJcbiIsIjxzZWN0aW9uPlxyXG4gICAgPGRpdiBjbGFzcz1cImV4cGFuc2lvbi1idXR0b25cIiAoY2xpY2spPVwiY2hhbmdlU3RhdGUoKVwiPlxyXG4gICAgICAgIDxtYXQtaWNvbiBbQGFycm93LWNvbGxhcHNlXT1cImlzQ29sbGFwc2VkKClcIj5leHBhbmRfbGVzczwvbWF0LWljb24+XHJcbiAgICAgICAgPGRpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInByaW1hcnlcIj57e3RpdGxlKCl9fTwvZGl2PlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiYm9keTJcIj57e3N1YlRpdGxlKCl9fTwvZGl2PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZXhwYW5zaW9uLXBhbmVsXCIgW0Bjb2xsYXBzZV09XCJpc0NvbGxhcHNlZCgpXCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgPC9kaXY+XHJcbjwvc2VjdGlvbj4iXX0=
@@ -0,0 +1,148 @@
1
+ import { Component, HostBinding, inject, input, signal } from '@angular/core';
2
+ import { MatIconModule } from '@angular/material/icon';
3
+ import { Router } from '@angular/router';
4
+ import { TranslateModule } from '@ngx-translate/core';
5
+ import { MenuExpandablePanelItemComponent } from '../menu-expandable-panel-item/menu-expandable-panel-item.component';
6
+ import { NgClass } from '@angular/common';
7
+ import { trigger, state, style, transition, animate } from '@angular/animations';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/material/icon";
10
+ import * as i2 from "@ngx-translate/core";
11
+ const _forTrack0 = ($index, $item) => $item.title;
12
+ function MenuExpandablePanelComponent_Conditional_7_Template(rf, ctx) { if (rf & 1) {
13
+ i0.ɵɵelementStart(0, "div", 2);
14
+ i0.ɵɵtext(1);
15
+ i0.ɵɵpipe(2, "translate");
16
+ i0.ɵɵelementEnd();
17
+ } if (rf & 2) {
18
+ const ctx_r0 = i0.ɵɵnextContext();
19
+ i0.ɵɵadvance();
20
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(2, 1, ctx_r0.subTitle()));
21
+ } }
22
+ function MenuExpandablePanelComponent_Conditional_8_Template(rf, ctx) { if (rf & 1) {
23
+ i0.ɵɵelementStart(0, "mat-icon");
24
+ i0.ɵɵtext(1, "arrow_forward_ios");
25
+ i0.ɵɵelementEnd();
26
+ } if (rf & 2) {
27
+ const ctx_r0 = i0.ɵɵnextContext();
28
+ i0.ɵɵproperty("@arrow-collapse", ctx_r0.opened());
29
+ } }
30
+ function MenuExpandablePanelComponent_Conditional_9_For_1_Template(rf, ctx) { if (rf & 1) {
31
+ i0.ɵɵelement(0, "app-menu-expandable-panel-item", 3);
32
+ } if (rf & 2) {
33
+ const item_r2 = ctx.$implicit;
34
+ i0.ɵɵproperty("icon", item_r2.icon)("title", item_r2.title)("route", item_r2.route)("isSubItem", true)("action", item_r2.action);
35
+ } }
36
+ function MenuExpandablePanelComponent_Conditional_9_Template(rf, ctx) { if (rf & 1) {
37
+ i0.ɵɵrepeaterCreate(0, MenuExpandablePanelComponent_Conditional_9_For_1_Template, 1, 5, "app-menu-expandable-panel-item", 3, _forTrack0);
38
+ } if (rf & 2) {
39
+ const ctx_r0 = i0.ɵɵnextContext();
40
+ i0.ɵɵrepeater(ctx_r0.items());
41
+ } }
42
+ const DEFAULT_DURATION = 200;
43
+ export class MenuExpandablePanelComponent {
44
+ constructor() {
45
+ this.title = input();
46
+ this.isSubItem = input(false);
47
+ this.subTitle = input();
48
+ this.menuIcon = input();
49
+ this.showExpansionIcon = input(true);
50
+ this.addTopBorderRadius = input(false);
51
+ this.bottomBorder = input(false);
52
+ this.addBottomBorderRadius = input(false);
53
+ this.route = input([]);
54
+ this.items = input([]);
55
+ this.opened = signal(false);
56
+ this.router = inject(Router);
57
+ }
58
+ get topLeftRadius() {
59
+ return this.addTopBorderRadius() ? '12px' : '0px';
60
+ }
61
+ get topRightRadius() {
62
+ return this.addTopBorderRadius() ? '12px' : '0px';
63
+ }
64
+ get bottomLeftRadius() {
65
+ return this.addBottomBorderRadius() ? '12px' : '0px';
66
+ }
67
+ get bottomRightRadius() {
68
+ return this.addBottomBorderRadius() ? '12px' : '0px';
69
+ }
70
+ get bottomBorderClass() {
71
+ return this.bottomBorder();
72
+ }
73
+ handleClick() {
74
+ if (this.route().length > 0 && this.items().length === 0) {
75
+ this.router.navigate(this.route());
76
+ }
77
+ else {
78
+ this.opened.set(!this.opened());
79
+ }
80
+ }
81
+ static { this.ɵfac = function MenuExpandablePanelComponent_Factory(t) { return new (t || MenuExpandablePanelComponent)(); }; }
82
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: MenuExpandablePanelComponent, selectors: [["app-menu-expandable-panel"]], hostVars: 10, hostBindings: function MenuExpandablePanelComponent_HostBindings(rf, ctx) { if (rf & 2) {
83
+ i0.ɵɵstyleProp("border-top-left-radius", ctx.topLeftRadius)("border-top-right-radius", ctx.topRightRadius)("border-bottom-left-radius", ctx.bottomLeftRadius)("border-bottom-right-radius", ctx.bottomRightRadius);
84
+ i0.ɵɵclassProp("bottom-border", ctx.bottomBorderClass);
85
+ } }, inputs: { title: [1, "title"], isSubItem: [1, "isSubItem"], subTitle: [1, "subTitle"], menuIcon: [1, "menuIcon"], showExpansionIcon: [1, "showExpansionIcon"], addTopBorderRadius: [1, "addTopBorderRadius"], bottomBorder: [1, "bottomBorder"], addBottomBorderRadius: [1, "addBottomBorderRadius"], route: [1, "route"], items: [1, "items"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 10, vars: 8, consts: [[3, "click", "ngClass"], [1, "subtitle1"], [1, "body2"], [3, "icon", "title", "route", "isSubItem", "action"]], template: function MenuExpandablePanelComponent_Template(rf, ctx) { if (rf & 1) {
86
+ i0.ɵɵelementStart(0, "section", 0);
87
+ i0.ɵɵlistener("click", function MenuExpandablePanelComponent_Template_section_click_0_listener() { return ctx.handleClick(); });
88
+ i0.ɵɵelementStart(1, "mat-icon");
89
+ i0.ɵɵtext(2);
90
+ i0.ɵɵelementEnd();
91
+ i0.ɵɵelementStart(3, "div")(4, "div", 1);
92
+ i0.ɵɵtext(5);
93
+ i0.ɵɵpipe(6, "translate");
94
+ i0.ɵɵelementEnd();
95
+ i0.ɵɵtemplate(7, MenuExpandablePanelComponent_Conditional_7_Template, 3, 3, "div", 2);
96
+ i0.ɵɵelementEnd();
97
+ i0.ɵɵtemplate(8, MenuExpandablePanelComponent_Conditional_8_Template, 2, 1, "mat-icon");
98
+ i0.ɵɵelementEnd();
99
+ i0.ɵɵtemplate(9, MenuExpandablePanelComponent_Conditional_9_Template, 2, 0);
100
+ } if (rf & 2) {
101
+ i0.ɵɵproperty("ngClass", ctx.opened() ? "bottom-padding" : "");
102
+ i0.ɵɵadvance(2);
103
+ i0.ɵɵtextInterpolate(ctx.menuIcon());
104
+ i0.ɵɵadvance(3);
105
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(6, 6, ctx.title()));
106
+ i0.ɵɵadvance(2);
107
+ i0.ɵɵconditional(ctx.subTitle() ? 7 : -1);
108
+ i0.ɵɵadvance();
109
+ i0.ɵɵconditional(ctx.showExpansionIcon() ? 8 : -1);
110
+ i0.ɵɵadvance();
111
+ i0.ɵɵconditional(ctx.opened() ? 9 : -1);
112
+ } }, dependencies: [MatIconModule, i1.MatIcon, TranslateModule, i2.TranslatePipe, MenuExpandablePanelItemComponent, NgClass], styles: ["[_nghost-%COMP%]{padding:10px 12px;background-color:#fff;cursor:pointer;display:block}section[_ngcontent-%COMP%]{display:flex;gap:16px;align-items:center}section.bottom-padding[_ngcontent-%COMP%]{padding-bottom:10px}div[_ngcontent-%COMP%]{flex:1}"], data: { animation: [
113
+ trigger('arrow-collapse', [
114
+ state('false', style({ transform: 'rotate(0deg)' })),
115
+ state('true', style({ transform: 'rotate(-90deg)' })),
116
+ transition('false => true', animate(DEFAULT_DURATION + 'ms ease-in-out')),
117
+ transition('true => false', animate(DEFAULT_DURATION + 'ms ease-in-out'))
118
+ ])
119
+ ] } }); }
120
+ }
121
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MenuExpandablePanelComponent, [{
122
+ type: Component,
123
+ args: [{ selector: 'app-menu-expandable-panel', standalone: true, imports: [MatIconModule, TranslateModule, MenuExpandablePanelItemComponent, NgClass], animations: [
124
+ trigger('arrow-collapse', [
125
+ state('false', style({ transform: 'rotate(0deg)' })),
126
+ state('true', style({ transform: 'rotate(-90deg)' })),
127
+ transition('false => true', animate(DEFAULT_DURATION + 'ms ease-in-out')),
128
+ transition('true => false', animate(DEFAULT_DURATION + 'ms ease-in-out'))
129
+ ])
130
+ ], template: "<section [ngClass]=\"opened() ? 'bottom-padding' : ''\" (click)=\"handleClick()\">\r\n <mat-icon>{{menuIcon()}}</mat-icon>\r\n <div>\r\n <div class=\"subtitle1\">{{title() | translate}}</div>\r\n @if(subTitle()) {<div class=\"body2\">{{subTitle() | translate}}</div>}\r\n </div>\r\n @if (showExpansionIcon()) {<mat-icon [@arrow-collapse]=\"opened()\">arrow_forward_ios</mat-icon>}\r\n</section>\r\n@if(opened()) {\r\n @for (item of items(); track item.title) {\r\n <app-menu-expandable-panel-item [icon]=\"item.icon\" [title]=\"item.title\" [route]=\"item.route\" [isSubItem]=\"true\" [action]=\"item.action\" />\r\n }\r\n}", styles: [":host{padding:10px 12px;background-color:#fff;cursor:pointer;display:block}section{display:flex;gap:16px;align-items:center}section.bottom-padding{padding-bottom:10px}div{flex:1}\n"] }]
131
+ }], null, { topLeftRadius: [{
132
+ type: HostBinding,
133
+ args: ['style.border-top-left-radius']
134
+ }], topRightRadius: [{
135
+ type: HostBinding,
136
+ args: ['style.border-top-right-radius']
137
+ }], bottomLeftRadius: [{
138
+ type: HostBinding,
139
+ args: ['style.border-bottom-left-radius']
140
+ }], bottomRightRadius: [{
141
+ type: HostBinding,
142
+ args: ['style.border-bottom-right-radius']
143
+ }], bottomBorderClass: [{
144
+ type: HostBinding,
145
+ args: ['class.bottom-border']
146
+ }] }); })();
147
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MenuExpandablePanelComponent, { className: "MenuExpandablePanelComponent", filePath: "lib\\layout\\menu-expandable-panel\\menu-expandable-panel.component.ts", lineNumber: 26 }); })();
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-expandable-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/cauca-material/src/lib/layout/menu-expandable-panel/menu-expandable-panel.component.ts","../../../../../../projects/cauca-material/src/lib/layout/menu-expandable-panel/menu-expandable-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, inject, input, InputSignal, signal, WritableSignal } from '@angular/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { Router } from '@angular/router';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { MenuExpandablePanelItemComponent } from '../menu-expandable-panel-item/menu-expandable-panel-item.component';\r\nimport { NgClass } from '@angular/common';\r\nimport { trigger, state, style, transition, animate } from '@angular/animations';\r\n\r\nconst DEFAULT_DURATION = 200;\r\n\r\n@Component({\r\n  selector: 'app-menu-expandable-panel',\r\n  standalone: true,\r\n  imports: [MatIconModule, TranslateModule, MenuExpandablePanelItemComponent, NgClass],\r\n  templateUrl: './menu-expandable-panel.component.html',\r\n  styleUrl: './menu-expandable-panel.component.scss',\r\n  animations: [\r\n    trigger('arrow-collapse', [\r\n      state('false', style({ transform: 'rotate(0deg)' })),\r\n      state('true', style({ transform: 'rotate(-90deg)' })),\r\n      transition('false => true', animate(DEFAULT_DURATION + 'ms ease-in-out')),\r\n      transition('true => false', animate(DEFAULT_DURATION + 'ms ease-in-out'))\r\n    ])\r\n  ]\r\n})\r\nexport class MenuExpandablePanelComponent {\r\n  public title: InputSignal<string> = input();\r\n  public isSubItem: InputSignal<boolean> = input(false);\r\n  public subTitle: InputSignal<string> = input();\r\n  public menuIcon: InputSignal<string> = input();\r\n  public showExpansionIcon: InputSignal<boolean> = input(true);\r\n  public addTopBorderRadius: InputSignal<boolean> = input(false);\r\n  public bottomBorder: InputSignal<boolean> = input(false);\r\n  public addBottomBorderRadius: InputSignal<boolean> = input(false);\r\n  public route: InputSignal<string[]> = input([]);\r\n  public items: InputSignal<{ icon: string, title: string, route?: string[], action?: () => void }[]> = input([]);\r\n\r\n  public opened: WritableSignal<boolean> = signal(false);\r\n\r\n  private readonly router = inject(Router);\r\n\r\n  @HostBinding('style.border-top-left-radius') public get topLeftRadius(): string {\r\n    return this.addTopBorderRadius() ? '12px' : '0px';\r\n  }\r\n  @HostBinding('style.border-top-right-radius') public get topRightRadius(): string {\r\n    return this.addTopBorderRadius() ? '12px' : '0px';\r\n  }\r\n  @HostBinding('style.border-bottom-left-radius') public get bottomLeftRadius(): string {\r\n    return this.addBottomBorderRadius() ? '12px' : '0px';\r\n  }\r\n  @HostBinding('style.border-bottom-right-radius') public get bottomRightRadius(): string {\r\n    return this.addBottomBorderRadius() ? '12px' : '0px';\r\n  }\r\n  @HostBinding('class.bottom-border') public get bottomBorderClass(): boolean {\r\n    return this.bottomBorder();\r\n  }\r\n\r\n  public handleClick(): void {\r\n    if (this.route().length > 0 && this.items().length === 0) {\r\n      this.router.navigate(this.route());\r\n    } else {\r\n      this.opened.set(!this.opened());\r\n    }\r\n  }\r\n}\r\n","<section [ngClass]=\"opened() ? 'bottom-padding' : ''\" (click)=\"handleClick()\">\r\n    <mat-icon>{{menuIcon()}}</mat-icon>\r\n    <div>\r\n        <div class=\"subtitle1\">{{title() | translate}}</div>\r\n        @if(subTitle()) {<div class=\"body2\">{{subTitle() | translate}}</div>}\r\n    </div>\r\n    @if (showExpansionIcon()) {<mat-icon [@arrow-collapse]=\"opened()\">arrow_forward_ios</mat-icon>}\r\n</section>\r\n@if(opened()) {\r\n    @for (item of items(); track item.title) {\r\n        <app-menu-expandable-panel-item [icon]=\"item.icon\" [title]=\"item.title\" [route]=\"item.route\" [isSubItem]=\"true\" [action]=\"item.action\" />\r\n    }\r\n}"]}