valtech-components 2.0.217 → 2.0.218

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.
@@ -91,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
91
91
  }], ctorParameters: () => [], propDecorators: { props: [{
92
92
  type: Input
93
93
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9hdG9tcy9pbWFnZS9pbWFnZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7QUF3Q3pEOzs7Ozs7Ozs7R0FTRztBQUNILE1BQU0sT0FBTyxjQUFjO0lBb0J6QjtRQUZBLGNBQVMsR0FBWSxJQUFJLENBQUM7SUFFWCxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDO0lBRWIsZUFBZTtRQUNiLFdBQVcsQ0FBQyxHQUFHLEVBQUU7WUFDZixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN4QixDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDVixDQUFDOytHQTVCVSxjQUFjO21HQUFkLGNBQWMsaUdBM0NmOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E4QlQsay9GQS9CUyxZQUFZOzs0RkE0Q1gsY0FBYztrQkEvQzFCLFNBQVM7K0JBQ0UsV0FBVyxjQUNULElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxZQUNiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E4QlQ7d0RBNkJELEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEltYWdlTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWltYWdlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgQGlmIChwcm9wcy5zcmMuaW5jbHVkZXMoJy0tJykpIHtcbiAgICAgIDxpbWdcbiAgICAgICAgW25nQ2xhc3NdPVwiWydpbWFnZScsIHByb3BzLm1vZGUsIHByb3BzLnNpemVdXCJcbiAgICAgICAgW25nU3R5bGVdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6ICd2YXIoJyArIHByb3BzLnNyYyArICcpJyxcbiAgICAgICAgfVwiXG4gICAgICAgIFtjbGFzcy5ib3JkZXJlZF09XCJwcm9wcy5ib3JkZXJlZFwiXG4gICAgICAgIFtjbGFzcy5zaGFkZWRdPVwicHJvcHMuc2hhZGVkXCJcbiAgICAgICAgW2NsYXNzLmRhcmtdPVwicHJvcHMuZGFya1wiXG4gICAgICAgIFtjbGFzcy5saW1pdGVkXT1cInByb3BzLmxpbWl0ZWRcIlxuICAgICAgICBbYWx0XT1cInByb3BzLmFsdFwiXG4gICAgICAgIFtzdHlsZS53aWR0aC5weF09XCJwcm9wcy53aWR0aFwiXG4gICAgICAgIFtzdHlsZS5tYXgtd2lkdGgucHhdPVwicHJvcHMud2lkdGhcIlxuICAgICAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cInByb3BzLmhlaWdodFwiXG4gICAgICAvPlxuICAgIH0gQGVsc2Uge1xuICAgICAgPGltZ1xuICAgICAgICBbbmdDbGFzc109XCJbJ2ltYWdlJywgcHJvcHMubW9kZSwgcHJvcHMuc2l6ZV1cIlxuICAgICAgICBbY2xhc3MuYm9yZGVyZWRdPVwicHJvcHMuYm9yZGVyZWRcIlxuICAgICAgICBbY2xhc3Muc2hhZGVkXT1cInByb3BzLnNoYWRlZFwiXG4gICAgICAgIFtjbGFzcy5kYXJrXT1cInByb3BzLmRhcmtcIlxuICAgICAgICBbY2xhc3MubGltaXRlZF09XCJwcm9wcy5saW1pdGVkXCJcbiAgICAgICAgW3NyY109XCJwcm9wcy5zcmNcIlxuICAgICAgICBbYWx0XT1cInByb3BzLmFsdFwiXG4gICAgICAgIFtzdHlsZS53aWR0aC5weF09XCJwcm9wcy53aWR0aFwiXG4gICAgICAgIFtzdHlsZS5tYXgtd2lkdGgucHhdPVwicHJvcHMud2lkdGhcIlxuICAgICAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cInByb3BzLmhlaWdodFwiXG4gICAgICAvPlxuICAgIH1cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vaW1hZ2UuY29tcG9uZW50LnNjc3MnXSxcbn0pXG4vKipcbiAqIHZhbC1pbWFnZVxuICpcbiAqIERpc3BsYXlzIGFuIGltYWdlIHdpdGggdmFyaW91cyBkaXNwbGF5IG9wdGlvbnMgKGJvcmRlcmVkLCBzaGFkZWQsIGRhcmssIGV0YykuXG4gKlxuICogQGV4YW1wbGVcbiAqIDx2YWwtaW1hZ2UgW3Byb3BzXT1cInsgc3JjOiAndXJsJywgYWx0OiAnZGVzYycsIHdpZHRoOiAxMDAsIGhlaWdodDogMTAwLCBib3JkZXJlZDogdHJ1ZSB9XCI+PC92YWwtaW1hZ2U+XG4gKlxuICogQGlucHV0IHByb3BzOiBJbWFnZU1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIGltYWdlIChzcmMsIGFsdCwgc2l6ZSwgbW9kZSwgZXRjLilcbiAqL1xuZXhwb3J0IGNsYXNzIEltYWdlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIEltYWdlIGNvbmZpZ3VyYXRpb24gb2JqZWN0LlxuICAgKiBAdHlwZSB7SW1hZ2VNZXRhZGF0YX1cbiAgICogQHByb3BlcnR5IHNyYyAtIFRoZSBpbWFnZSBzb3VyY2UgVVJMLlxuICAgKiBAcHJvcGVydHkgYWx0IC0gVGhlIGFsdCB0ZXh0IGZvciB0aGUgaW1hZ2UuXG4gICAqIEBwcm9wZXJ0eSBtb2RlIC0gVGhlIGRpc3BsYXkgbW9kZSAoJ3JvdW5kZWQnIHwgJ2NpcmN1bGFyJyB8ICdib3gnKS5cbiAgICogQHByb3BlcnR5IHNoYWRlZCAtIFdoZXRoZXIgdGhlIGltYWdlIGhhcyBhIHNoYWRlZCBlZmZlY3QuXG4gICAqIEBwcm9wZXJ0eSBib3JkZXJlZCAtIFdoZXRoZXIgdGhlIGltYWdlIGhhcyBhIGJvcmRlci5cbiAgICogQHByb3BlcnR5IGxpbWl0ZWQgLSBXaGV0aGVyIHRoZSBpbWFnZSBpcyBsaW1pdGVkIGluIHNpemUgKG9wdGlvbmFsKS5cbiAgICogQHByb3BlcnR5IGRhcmsgLSBXaGV0aGVyIHRoZSBpbWFnZSB1c2VzIGEgZGFyayBzdHlsZSAob3B0aW9uYWwpLlxuICAgKiBAcHJvcGVydHkgc2l6ZSAtIFRoZSBpbWFnZSBzaXplICgnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnIHwgJ3hsYXJnZScpLlxuICAgKiBAcHJvcGVydHkgd2lkdGggLSBUaGUgaW1hZ2Ugd2lkdGggaW4gcHggKG9wdGlvbmFsKS5cbiAgICogQHByb3BlcnR5IGhlaWdodCAtIFRoZSBpbWFnZSBoZWlnaHQgaW4gcHggKG9wdGlvbmFsKS5cbiAgICovXG4gIEBJbnB1dCgpXG4gIHByb3BzOiBJbWFnZU1ldGFkYXRhO1xuXG4gIGF2YWlsYWJsZTogYm9vbGVhbiA9IHRydWU7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBjaGFuZ2VUb1Zpc2libGUoKSB7XG4gICAgc2V0SW50ZXJ2YWwoKCkgPT4ge1xuICAgICAgdGhpcy5hdmFpbGFibGUgPSB0cnVlO1xuICAgIH0sIDEwMCk7XG4gIH1cbn1cbiJdfQ==
94
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9hdG9tcy9pbWFnZS9pbWFnZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7QUF3Q3pEOzs7Ozs7Ozs7R0FTRztBQUNILE1BQU0sT0FBTyxjQUFjO0lBTXpCO1FBRkEsY0FBUyxHQUFZLElBQUksQ0FBQztJQUVYLENBQUM7SUFFaEIsUUFBUSxLQUFJLENBQUM7SUFFYixlQUFlO1FBQ2IsV0FBVyxDQUFDLEdBQUcsRUFBRTtZQUNmLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNWLENBQUM7K0dBZFUsY0FBYzttR0FBZCxjQUFjLGlHQTNDZjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBOEJULGsvRkEvQlMsWUFBWTs7NEZBNENYLGNBQWM7a0JBL0MxQixTQUFTOytCQUNFLFdBQVcsY0FDVCxJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBOEJUO3dEQWVELEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEltYWdlTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWltYWdlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgQGlmIChwcm9wcy5zcmMuaW5jbHVkZXMoJy0tJykpIHtcbiAgICAgIDxpbWdcbiAgICAgICAgW25nQ2xhc3NdPVwiWydpbWFnZScsIHByb3BzLm1vZGUsIHByb3BzLnNpemVdXCJcbiAgICAgICAgW25nU3R5bGVdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6ICd2YXIoJyArIHByb3BzLnNyYyArICcpJyxcbiAgICAgICAgfVwiXG4gICAgICAgIFtjbGFzcy5ib3JkZXJlZF09XCJwcm9wcy5ib3JkZXJlZFwiXG4gICAgICAgIFtjbGFzcy5zaGFkZWRdPVwicHJvcHMuc2hhZGVkXCJcbiAgICAgICAgW2NsYXNzLmRhcmtdPVwicHJvcHMuZGFya1wiXG4gICAgICAgIFtjbGFzcy5saW1pdGVkXT1cInByb3BzLmxpbWl0ZWRcIlxuICAgICAgICBbYWx0XT1cInByb3BzLmFsdFwiXG4gICAgICAgIFtzdHlsZS53aWR0aC5weF09XCJwcm9wcy53aWR0aFwiXG4gICAgICAgIFtzdHlsZS5tYXgtd2lkdGgucHhdPVwicHJvcHMud2lkdGhcIlxuICAgICAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cInByb3BzLmhlaWdodFwiXG4gICAgICAvPlxuICAgIH0gQGVsc2Uge1xuICAgICAgPGltZ1xuICAgICAgICBbbmdDbGFzc109XCJbJ2ltYWdlJywgcHJvcHMubW9kZSwgcHJvcHMuc2l6ZV1cIlxuICAgICAgICBbY2xhc3MuYm9yZGVyZWRdPVwicHJvcHMuYm9yZGVyZWRcIlxuICAgICAgICBbY2xhc3Muc2hhZGVkXT1cInByb3BzLnNoYWRlZFwiXG4gICAgICAgIFtjbGFzcy5kYXJrXT1cInByb3BzLmRhcmtcIlxuICAgICAgICBbY2xhc3MubGltaXRlZF09XCJwcm9wcy5saW1pdGVkXCJcbiAgICAgICAgW3NyY109XCJwcm9wcy5zcmNcIlxuICAgICAgICBbYWx0XT1cInByb3BzLmFsdFwiXG4gICAgICAgIFtzdHlsZS53aWR0aC5weF09XCJwcm9wcy53aWR0aFwiXG4gICAgICAgIFtzdHlsZS5tYXgtd2lkdGgucHhdPVwicHJvcHMud2lkdGhcIlxuICAgICAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cInByb3BzLmhlaWdodFwiXG4gICAgICAvPlxuICAgIH1cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vaW1hZ2UuY29tcG9uZW50LnNjc3MnXSxcbn0pXG4vKipcbiAqIHZhbC1pbWFnZVxuICpcbiAqIERpc3BsYXlzIGFuIGltYWdlIHdpdGggdmFyaW91cyBkaXNwbGF5IG9wdGlvbnMgKGJvcmRlcmVkLCBzaGFkZWQsIGRhcmssIGV0YykuXG4gKlxuICogQGV4YW1wbGVcbiAqIDx2YWwtaW1hZ2UgW3Byb3BzXT1cInsgc3JjOiAndXJsJywgYWx0OiAnZGVzYycsIHdpZHRoOiAxMDAsIGhlaWdodDogMTAwLCBib3JkZXJlZDogdHJ1ZSB9XCI+PC92YWwtaW1hZ2U+XG4gKlxuICogQGlucHV0IHByb3BzOiBJbWFnZU1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIGltYWdlIChzcmMsIGFsdCwgc2l6ZSwgbW9kZSwgZXRjLilcbiAqL1xuZXhwb3J0IGNsYXNzIEltYWdlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgcHJvcHM6IEltYWdlTWV0YWRhdGE7XG5cbiAgYXZhaWxhYmxlOiBib29sZWFuID0gdHJ1ZTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxuXG4gIGNoYW5nZVRvVmlzaWJsZSgpIHtcbiAgICBzZXRJbnRlcnZhbCgoKSA9PiB7XG4gICAgICB0aGlzLmF2YWlsYWJsZSA9IHRydWU7XG4gICAgfSwgMTAwKTtcbiAgfVxufVxuIl19
@@ -161,6 +161,9 @@ export class ItemListComponent {
161
161
  <div class="unread-indicator"></div>
162
162
  </div>
163
163
  }
164
+ @if (item.icon) {
165
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
166
+ }
164
167
 
165
168
  <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
166
169
  <h2>{{ item.text }}</h2>
@@ -343,6 +346,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
343
346
  <div class="unread-indicator"></div>
344
347
  </div>
345
348
  }
349
+ @if (item.icon) {
350
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
351
+ }
346
352
 
347
353
  <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
348
354
  <h2>{{ item.text }}</h2>
@@ -409,4 +415,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
409
415
  }], onActionClick: [{
410
416
  type: Output
411
417
  }] } });
412
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/item-list/item-list.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,SAAS,EACT,SAAS,EACT,OAAO,EACP,OAAO,EACP,QAAQ,EACR,OAAO,EACP,aAAa,EACb,OAAO,EACP,UAAU,GACX,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;;;AA4L9C;;;;;;;;;;;;GAYG;AACH,MAAM,OAAO,iBAAiB;IAsB5B,YAAY,IAAiB;QArB7B,WAAM,GAAG,eAAe,CAAC;QACzB,iBAAY,GAAG,SAAS,CAAC;QAQzB;;WAEG;QAEH,YAAO,GAAG,IAAI,YAAY,EAAU,CAAC;QAErC;;WAEG;QAEH,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;IAEX,CAAC;IAEjC,QAAQ,KAAI,CAAC;IAEb;;;OAGG;IACH,YAAY,CAAC,KAAc;QACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,KAAc;QACjC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,KAAK;QACH,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;+GA/CU,iBAAiB;mGAAjB,iBAAiB,sKArLlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqKT,ggGAlLC,UAAU,oOAEV,OAAO,oFACP,OAAO,yFACP,aAAa,gGACb,QAAQ,6FACR,OAAO,gFACP,OAAO,0NACP,SAAS,uDACT,OAAO,2JACP,SAAS,oPACT,UAAU;;4FAuLD,iBAAiB;kBAtM7B,SAAS;+BACE,eAAe,cACb,IAAI,WACP;wBACP,UAAU;wBACV,OAAO;wBACP,OAAO;wBACP,OAAO;wBACP,aAAa;wBACb,QAAQ;wBACR,OAAO;wBACP,OAAO;wBACP,SAAS;wBACT,OAAO;wBACP,SAAS;wBACT,UAAU;qBACX,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqKT;gFAwBD,KAAK;sBADJ,KAAK;gBAON,OAAO;sBADN,MAAM;gBAOP,aAAa;sBADZ,MAAM","sourcesContent":["import { NgClass, NgStyle } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { RouterLink } from '@angular/router';\nimport {\n  IonAvatar,\n  IonButton,\n  IonIcon,\n  IonItem,\n  IonLabel,\n  IonList,\n  IonListHeader,\n  IonNote,\n  IonSpinner,\n} from '@ionic/angular/standalone';\nimport { IconService } from '../../../services/icons.service';\nimport { resolveColor } from '../../../shared/utils/styles';\nimport { ComponentStates } from '../../types';\nimport { ListMetadata } from './types';\n\n@Component({\n  selector: 'val-item-list',\n  standalone: true,\n  imports: [\n    RouterLink,\n    NgStyle,\n    NgClass,\n    IonList,\n    IonListHeader,\n    IonLabel,\n    IonNote,\n    IonItem,\n    IonAvatar,\n    IonIcon,\n    IonButton,\n    IonSpinner,\n  ],\n  template: `\n    <ion-list\n      [inset]=\"props.rounded\"\n      [class.shadowed]=\"props.shadowed\"\n      [class.bordered]=\"props.bordered\"\n      [style.borderColor]=\"this.color()\"\n    >\n      @if (props.title) {\n        <ion-list-header>\n          <ion-label>{{ props.title }}</ion-label>\n        </ion-list-header>\n      }\n      @for (item of props.items; track item.token) {\n        @if (item.mode == 'justext') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h2>{{ item.text }}</h2>\n\n              @if (item.comments) {\n                <ion-note color=\"medium\"> {{ item.comments }} </ion-note>\n              }\n\n              @if (item.subtitle) {\n                <p>{{ item.subtitle }}</p>\n              }\n            </ion-label>\n\n            @if (item.endNote) {\n              <ion-note slot=\"end\">{{ item.endNote }}</ion-note>\n            }\n          </ion-item>\n        }\n\n        @if (item.mode == 'actionable') {\n          <ion-item [lines]=\"item.lines\" [button]=\"item.clickable\" [disabled]=\"item.disabled\">\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h2>{{ item.text }}</h2>\n\n              @if (item.endNote) {\n                <h3>{{ item.endNote }}</h3>\n              }\n\n              @if (item.subtitle) {\n                <ion-note color=\"medium\"> {{ item.subtitle }} </ion-note>\n              }\n\n              @if (item.comments) {\n                <ion-note color=\"medium\"> {{ item.comments }} </ion-note>\n              }\n            </ion-label>\n\n            @if (item.actions) {\n              @for (action of item.actions; track action.token) {\n                <ion-button\n                  fill=\"outline\"\n                  color=\"dark\"\n                  slot=\"end\"\n                  [disabled]=\"action.state === states.WORKING\"\n                  (click)=\"onActionClickHandler(action.token)\"\n                >\n                  @if (action.state !== states.WORKING) {\n                    @if (action.icon) {\n                      <ion-icon aria-hidden=\"true\" [name]=\"action.icon\" size=\"medium\" slot=\"start\"></ion-icon>\n                    }\n\n                    {{ action.description }}\n                  }\n\n                  @if (action.state === states.WORKING) {\n                    <ion-spinner class=\"action-spinner\" name=\"circular\"></ion-spinner>\n                  }\n                </ion-button>\n              }\n            }\n          </ion-item>\n        }\n\n        @if (item.mode == 'route') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n            [routerLink]=\"item.routerLink\"\n          >\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h2>{{ item.text }}</h2>\n\n              @if (item.comments) {\n                <ion-note color=\"medium\"> {{ item.comments }} </ion-note>\n              }\n            </ion-label>\n          </ion-item>\n        }\n\n        @if (item.mode == 'subtitule') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h1>{{ item.text }}</h1>\n              <p>{{ item.subtitle }}</p>\n            </ion-label>\n          </ion-item>\n        }\n\n        @if (item.mode == 'avatar') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            <ion-avatar aria-hidden=\"true\" slot=\"start\">\n              <img alt=\"\" [src]=\"item.image\" />\n            </ion-avatar>\n            <ion-label>{{ item.text }}</ion-label>\n          </ion-item>\n        }\n\n        @if (item.mode == 'icon') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            <ion-icon aria-hidden=\"true\" [name]=\"item.icon\" size=\"medium\" slot=\"start\"></ion-icon>\n            <ion-label>{{ item.text }}</ion-label>\n          </ion-item>\n        }\n      }\n    </ion-list>\n  `,\n  styleUrls: ['./item-list.component.scss'],\n})\n/**\n * ItemListComponent\n *\n * Componente de lista reutilizable para mostrar una colección de elementos con diferentes modos de visualización (texto, subtítulo, avatar, icono, ruta, acciones).\n * Permite acciones por elemento, indicadores de no leído, y personalización de estilos.\n *\n * @example\n * <val-item-list [props]=\"{ title: 'Usuarios', items: [{ text: 'Juan', mode: 'avatar', image: 'avatar.jpg' }] }\" (onClick)=\"handleClick($event)\"></val-item-list>\n *\n * @input props {ListMetadata} - Metadatos de la lista y sus elementos.\n * @output onClick - Emite el token del elemento clicado.\n * @output onActionClick - Emite el token de la acción clicada en un elemento.\n */\nexport class ItemListComponent implements OnInit {\n  states = ComponentStates;\n  defaultColor = 'primary';\n\n  /**\n   * Metadatos de la lista y sus elementos.\n   */\n  @Input()\n  props: ListMetadata;\n\n  /**\n   * Evento emitido al hacer click en un elemento de la lista.\n   */\n  @Output()\n  onClick = new EventEmitter<string>();\n\n  /**\n   * Evento emitido al hacer click en una acción de un elemento.\n   */\n  @Output()\n  onActionClick = new EventEmitter<string>();\n\n  constructor(icon: IconService) {}\n\n  ngOnInit() {}\n\n  /**\n   * Emite el token del elemento clicado.\n   * @param token Token del elemento\n   */\n  clickHandler(token?: string) {\n    this.onClick.emit(token);\n  }\n\n  /**\n   * Emite el token de la acción clicada.\n   * @param token Token de la acción\n   */\n  onActionClickHandler(token?: string) {\n    this.onActionClick.emit(token);\n  }\n\n  /**\n   * Devuelve el color de borde de la lista.\n   */\n  color() {\n    return resolveColor(this.props.color || this.defaultColor);\n  }\n}\n"]}
418
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/item-list/item-list.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,SAAS,EACT,SAAS,EACT,OAAO,EACP,OAAO,EACP,QAAQ,EACR,OAAO,EACP,aAAa,EACb,OAAO,EACP,UAAU,GACX,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;;;AA+L9C;;;;;;;;;;;;GAYG;AACH,MAAM,OAAO,iBAAiB;IAsB5B,YAAY,IAAiB;QArB7B,WAAM,GAAG,eAAe,CAAC;QACzB,iBAAY,GAAG,SAAS,CAAC;QAQzB;;WAEG;QAEH,YAAO,GAAG,IAAI,YAAY,EAAU,CAAC;QAErC;;WAEG;QAEH,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;IAEX,CAAC;IAEjC,QAAQ,KAAI,CAAC;IAEb;;;OAGG;IACH,YAAY,CAAC,KAAc;QACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,KAAc;QACjC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,KAAK;QACH,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;+GA/CU,iBAAiB;mGAAjB,iBAAiB,sKAxLlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwKT,ggGArLC,UAAU,oOAEV,OAAO,oFACP,OAAO,yFACP,aAAa,gGACb,QAAQ,6FACR,OAAO,gFACP,OAAO,0NACP,SAAS,uDACT,OAAO,2JACP,SAAS,oPACT,UAAU;;4FA0LD,iBAAiB;kBAzM7B,SAAS;+BACE,eAAe,cACb,IAAI,WACP;wBACP,UAAU;wBACV,OAAO;wBACP,OAAO;wBACP,OAAO;wBACP,aAAa;wBACb,QAAQ;wBACR,OAAO;wBACP,OAAO;wBACP,SAAS;wBACT,OAAO;wBACP,SAAS;wBACT,UAAU;qBACX,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwKT;gFAwBD,KAAK;sBADJ,KAAK;gBAON,OAAO;sBADN,MAAM;gBAOP,aAAa;sBADZ,MAAM","sourcesContent":["import { NgClass, NgStyle } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { RouterLink } from '@angular/router';\nimport {\n  IonAvatar,\n  IonButton,\n  IonIcon,\n  IonItem,\n  IonLabel,\n  IonList,\n  IonListHeader,\n  IonNote,\n  IonSpinner,\n} from '@ionic/angular/standalone';\nimport { IconService } from '../../../services/icons.service';\nimport { resolveColor } from '../../../shared/utils/styles';\nimport { ComponentStates } from '../../types';\nimport { ListMetadata } from './types';\n\n@Component({\n  selector: 'val-item-list',\n  standalone: true,\n  imports: [\n    RouterLink,\n    NgStyle,\n    NgClass,\n    IonList,\n    IonListHeader,\n    IonLabel,\n    IonNote,\n    IonItem,\n    IonAvatar,\n    IonIcon,\n    IonButton,\n    IonSpinner,\n  ],\n  template: `\n    <ion-list\n      [inset]=\"props.rounded\"\n      [class.shadowed]=\"props.shadowed\"\n      [class.bordered]=\"props.bordered\"\n      [style.borderColor]=\"this.color()\"\n    >\n      @if (props.title) {\n        <ion-list-header>\n          <ion-label>{{ props.title }}</ion-label>\n        </ion-list-header>\n      }\n      @for (item of props.items; track item.token) {\n        @if (item.mode == 'justext') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h2>{{ item.text }}</h2>\n\n              @if (item.comments) {\n                <ion-note color=\"medium\"> {{ item.comments }} </ion-note>\n              }\n\n              @if (item.subtitle) {\n                <p>{{ item.subtitle }}</p>\n              }\n            </ion-label>\n\n            @if (item.endNote) {\n              <ion-note slot=\"end\">{{ item.endNote }}</ion-note>\n            }\n          </ion-item>\n        }\n\n        @if (item.mode == 'actionable') {\n          <ion-item [lines]=\"item.lines\" [button]=\"item.clickable\" [disabled]=\"item.disabled\">\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h2>{{ item.text }}</h2>\n\n              @if (item.endNote) {\n                <h3>{{ item.endNote }}</h3>\n              }\n\n              @if (item.subtitle) {\n                <ion-note color=\"medium\"> {{ item.subtitle }} </ion-note>\n              }\n\n              @if (item.comments) {\n                <ion-note color=\"medium\"> {{ item.comments }} </ion-note>\n              }\n            </ion-label>\n\n            @if (item.actions) {\n              @for (action of item.actions; track action.token) {\n                <ion-button\n                  fill=\"outline\"\n                  color=\"dark\"\n                  slot=\"end\"\n                  [disabled]=\"action.state === states.WORKING\"\n                  (click)=\"onActionClickHandler(action.token)\"\n                >\n                  @if (action.state !== states.WORKING) {\n                    @if (action.icon) {\n                      <ion-icon aria-hidden=\"true\" [name]=\"action.icon\" size=\"medium\" slot=\"start\"></ion-icon>\n                    }\n\n                    {{ action.description }}\n                  }\n\n                  @if (action.state === states.WORKING) {\n                    <ion-spinner class=\"action-spinner\" name=\"circular\"></ion-spinner>\n                  }\n                </ion-button>\n              }\n            }\n          </ion-item>\n        }\n\n        @if (item.mode == 'route') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n            [routerLink]=\"item.routerLink\"\n          >\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n            @if (item.icon) {\n              <ion-icon aria-hidden=\"true\" [name]=\"item.icon\" size=\"medium\" slot=\"start\"></ion-icon>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h2>{{ item.text }}</h2>\n\n              @if (item.comments) {\n                <ion-note color=\"medium\"> {{ item.comments }} </ion-note>\n              }\n            </ion-label>\n          </ion-item>\n        }\n\n        @if (item.mode == 'subtitule') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            @if (item.unreadIndicator) {\n              <div class=\"unread-indicator-wrapper\" slot=\"start\">\n                <div class=\"unread-indicator\"></div>\n              </div>\n            }\n\n            <ion-label [ngClass]=\"{ 'ion-text-nowrap': item.ellipsis }\">\n              <h1>{{ item.text }}</h1>\n              <p>{{ item.subtitle }}</p>\n            </ion-label>\n          </ion-item>\n        }\n\n        @if (item.mode == 'avatar') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            <ion-avatar aria-hidden=\"true\" slot=\"start\">\n              <img alt=\"\" [src]=\"item.image\" />\n            </ion-avatar>\n            <ion-label>{{ item.text }}</ion-label>\n          </ion-item>\n        }\n\n        @if (item.mode == 'icon') {\n          <ion-item\n            [lines]=\"item.lines\"\n            [button]=\"item.clickable\"\n            [disabled]=\"item.disabled\"\n            (click)=\"clickHandler(item.token)\"\n          >\n            <ion-icon aria-hidden=\"true\" [name]=\"item.icon\" size=\"medium\" slot=\"start\"></ion-icon>\n            <ion-label>{{ item.text }}</ion-label>\n          </ion-item>\n        }\n      }\n    </ion-list>\n  `,\n  styleUrls: ['./item-list.component.scss'],\n})\n/**\n * ItemListComponent\n *\n * Componente de lista reutilizable para mostrar una colección de elementos con diferentes modos de visualización (texto, subtítulo, avatar, icono, ruta, acciones).\n * Permite acciones por elemento, indicadores de no leído, y personalización de estilos.\n *\n * @example\n * <val-item-list [props]=\"{ title: 'Usuarios', items: [{ text: 'Juan', mode: 'avatar', image: 'avatar.jpg' }] }\" (onClick)=\"handleClick($event)\"></val-item-list>\n *\n * @input props {ListMetadata} - Metadatos de la lista y sus elementos.\n * @output onClick - Emite el token del elemento clicado.\n * @output onActionClick - Emite el token de la acción clicada en un elemento.\n */\nexport class ItemListComponent implements OnInit {\n  states = ComponentStates;\n  defaultColor = 'primary';\n\n  /**\n   * Metadatos de la lista y sus elementos.\n   */\n  @Input()\n  props: ListMetadata;\n\n  /**\n   * Evento emitido al hacer click en un elemento de la lista.\n   */\n  @Output()\n  onClick = new EventEmitter<string>();\n\n  /**\n   * Evento emitido al hacer click en una acción de un elemento.\n   */\n  @Output()\n  onActionClick = new EventEmitter<string>();\n\n  constructor(icon: IconService) {}\n\n  ngOnInit() {}\n\n  /**\n   * Emite el token del elemento clicado.\n   * @param token Token del elemento\n   */\n  clickHandler(token?: string) {\n    this.onClick.emit(token);\n  }\n\n  /**\n   * Emite el token de la acción clicada.\n   * @param token Token de la acción\n   */\n  onActionClickHandler(token?: string) {\n    this.onActionClick.emit(token);\n  }\n\n  /**\n   * Devuelve el color de borde de la lista.\n   */\n  color() {\n    return resolveColor(this.props.color || this.defaultColor);\n  }\n}\n"]}
@@ -116,7 +116,7 @@ export class WizardComponent {
116
116
  size: 'large',
117
117
  text: 'Por favor espere...',
118
118
  }"
119
- ></val-content-loader>
119
+ />
120
120
  </div>
121
121
  <ng-content select="[step]"></ng-content>
122
122
  </div>
@@ -142,7 +142,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
142
142
  size: 'large',
143
143
  text: 'Por favor espere...',
144
144
  }"
145
- ></val-content-loader>
145
+ />
146
146
  </div>
147
147
  <ng-content select="[step]"></ng-content>
148
148
  </div>
@@ -157,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
157
157
  }], onClick: [{
158
158
  type: Output
159
159
  }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/wizard/wizard.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { goToTop } from '../../../shared/utils/dom';\nimport { ContentLoaderComponent } from '../../molecules/content-loader/content-loader.component';\nimport { ComponentStates } from '../../types';\nimport { NoContentComponent } from '../no-content/no-content.component';\nimport { MOTION, Step, WizardMetadata } from './types';\n\n@Component({\n  selector: 'val-wizard',\n  standalone: true,\n  imports: [CommonModule, NoContentComponent, ContentLoaderComponent],\n  template: `\n    <div [id]=\"wrapperId\" class=\"wrapper\">\n      <ng-container *ngIf=\"props.state !== 'ERROR'\">\n        <val-no-content [props]=\"Current.titles\"></val-no-content>\n        <div class=\"step\">\n          <div *ngIf=\"props.state === 'WORKING'\">\n            <val-content-loader\n              [props]=\"{\n                name: 'circular',\n                color: 'primary',\n                size: 'large',\n                text: 'Por favor espere...',\n              }\"\n            ></val-content-loader>\n          </div>\n          <ng-content select=\"[step]\"></ng-content>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"props.state === 'ERROR'\">\n        <val-no-content [props]=\"props.error.titles\" (onClick)=\"clickHandler($event)\"></val-no-content>\n      </ng-container>\n    </div>\n  `,\n  styleUrls: ['./wizard.component.scss'],\n})\n/**\n * WizardComponent\n *\n * Componente para flujos de pasos (wizard) reutilizable, con soporte para estados, errores y navegación entre pasos.\n * Permite mostrar contenido personalizado por paso y manejar acciones de navegación.\n *\n * @example\n * <val-wizard [props]=\"wizardProps\" (onClick)=\"handleWizardNav($event)\">\n *   <div step>Contenido del paso</div>\n * </val-wizard>\n *\n * @input props {WizardMetadata} - Metadatos del wizard, pasos y estado.\n * @output onClick - Emite el paso actual y la acción de navegación (MOTION).\n */\nexport class WizardComponent implements OnInit {\n  /**\n   * Metadatos del wizard, pasos y estado.\n   */\n  @Input()\n  props: WizardMetadata;\n\n  /**\n   * Evento emitido al hacer click en una acción de navegación.\n   */\n  @Output()\n  onClick = new EventEmitter<{ current: number; motion: MOTION }>();\n\n  wrapperId = 'wizard-wrapper';\n\n  constructor() {}\n\n  ngOnInit() {}\n\n  /**\n   * Cambia el estado del wizard a 'WORKING' y deshabilita los botones del paso actual.\n   */\n  working() {\n    this.props.state = ComponentStates.WORKING;\n    this.Current.buttons.map(x => {\n      x.state = ComponentStates.DISABLED;\n    });\n  }\n\n  /**\n   * Cambia el estado del wizard a 'ENABLED' y habilita los botones del paso actual.\n   * No realiza cambios si ya está en estado 'ENABLED'.\n   */\n  done() {\n    if (this.props.state === ComponentStates.ENABLED) {\n      return;\n    }\n\n    this.props.state = ComponentStates.ENABLED;\n    this.Current.buttons.map(x => {\n      x.state = ComponentStates.ENABLED;\n    });\n  }\n\n  /**\n   * Devuelve el paso actual del wizard.\n   */\n  get Current(): Step {\n    return this.props.steps[this.props.current];\n  }\n\n  /**\n   * Cambia el paso actual del wizard y hace scroll al inicio.\n   * @param newStep Nuevo índice de paso\n   */\n  setCurrent(newStep: number) {\n    if (newStep === this.props.current) {\n      return;\n    }\n    this.props.current = newStep;\n    goToTop(this.wrapperId);\n  }\n\n  /**\n   * Establece el estado de error y muestra el mensaje de error en el banner inferior.\n   * @param error Mensaje de error a mostrar\n   */\n  setError(error: string) {\n    if (this.props.state === ComponentStates.ERROR) {\n      return;\n    }\n\n    this.props.error.titles.bottomContent.content.bellowTitle.content = error;\n    this.props.state = ComponentStates.ERROR;\n    goToTop(this.wrapperId);\n  }\n\n  /**\n   * Reinicia el estado de error y vuelve a estado 'ENABLED'.\n   */\n  reset() {\n    this.props.error.titles.bottomContent.content.bellowTitle.content = '';\n    this.done();\n  }\n\n  /**\n   * Maneja el click en el banner de error y emite el evento de navegación.\n   * Si el token contiene 'retry', reinicia el wizard.\n   * @param token Token de la acción clicada\n   */\n  clickHandler(token?: string) {\n    if (!token) {\n      return;\n    }\n    if (token.includes('retry')) {\n      this.reset();\n    }\n\n    this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });\n  }\n}\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/wizard/wizard.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { goToTop } from '../../../shared/utils/dom';\nimport { ContentLoaderComponent } from '../../molecules/content-loader/content-loader.component';\nimport { ComponentStates } from '../../types';\nimport { NoContentComponent } from '../no-content/no-content.component';\nimport { MOTION, Step, WizardMetadata } from './types';\n\n@Component({\n  selector: 'val-wizard',\n  standalone: true,\n  imports: [CommonModule, NoContentComponent, ContentLoaderComponent],\n  template: `\n    <div [id]=\"wrapperId\" class=\"wrapper\">\n      <ng-container *ngIf=\"props.state !== 'ERROR'\">\n        <val-no-content [props]=\"Current.titles\"></val-no-content>\n        <div class=\"step\">\n          <div *ngIf=\"props.state === 'WORKING'\">\n            <val-content-loader\n              [props]=\"{\n                name: 'circular',\n                color: 'primary',\n                size: 'large',\n                text: 'Por favor espere...',\n              }\"\n            />\n          </div>\n          <ng-content select=\"[step]\"></ng-content>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"props.state === 'ERROR'\">\n        <val-no-content [props]=\"props.error.titles\" (onClick)=\"clickHandler($event)\"></val-no-content>\n      </ng-container>\n    </div>\n  `,\n  styleUrls: ['./wizard.component.scss'],\n})\n/**\n * WizardComponent\n *\n * Componente para flujos de pasos (wizard) reutilizable, con soporte para estados, errores y navegación entre pasos.\n * Permite mostrar contenido personalizado por paso y manejar acciones de navegación.\n *\n * @example\n * <val-wizard [props]=\"wizardProps\" (onClick)=\"handleWizardNav($event)\">\n *   <div step>Contenido del paso</div>\n * </val-wizard>\n *\n * @input props {WizardMetadata} - Metadatos del wizard, pasos y estado.\n * @output onClick - Emite el paso actual y la acción de navegación (MOTION).\n */\nexport class WizardComponent implements OnInit {\n  /**\n   * Metadatos del wizard, pasos y estado.\n   */\n  @Input()\n  props: WizardMetadata;\n\n  /**\n   * Evento emitido al hacer click en una acción de navegación.\n   */\n  @Output()\n  onClick = new EventEmitter<{ current: number; motion: MOTION }>();\n\n  wrapperId = 'wizard-wrapper';\n\n  constructor() {}\n\n  ngOnInit() {}\n\n  /**\n   * Cambia el estado del wizard a 'WORKING' y deshabilita los botones del paso actual.\n   */\n  working() {\n    this.props.state = ComponentStates.WORKING;\n    this.Current.buttons.map(x => {\n      x.state = ComponentStates.DISABLED;\n    });\n  }\n\n  /**\n   * Cambia el estado del wizard a 'ENABLED' y habilita los botones del paso actual.\n   * No realiza cambios si ya está en estado 'ENABLED'.\n   */\n  done() {\n    if (this.props.state === ComponentStates.ENABLED) {\n      return;\n    }\n\n    this.props.state = ComponentStates.ENABLED;\n    this.Current.buttons.map(x => {\n      x.state = ComponentStates.ENABLED;\n    });\n  }\n\n  /**\n   * Devuelve el paso actual del wizard.\n   */\n  get Current(): Step {\n    return this.props.steps[this.props.current];\n  }\n\n  /**\n   * Cambia el paso actual del wizard y hace scroll al inicio.\n   * @param newStep Nuevo índice de paso\n   */\n  setCurrent(newStep: number) {\n    if (newStep === this.props.current) {\n      return;\n    }\n    this.props.current = newStep;\n    goToTop(this.wrapperId);\n  }\n\n  /**\n   * Establece el estado de error y muestra el mensaje de error en el banner inferior.\n   * @param error Mensaje de error a mostrar\n   */\n  setError(error: string) {\n    if (this.props.state === ComponentStates.ERROR) {\n      return;\n    }\n\n    this.props.error.titles.bottomContent.content.bellowTitle.content = error;\n    this.props.state = ComponentStates.ERROR;\n    goToTop(this.wrapperId);\n  }\n\n  /**\n   * Reinicia el estado de error y vuelve a estado 'ENABLED'.\n   */\n  reset() {\n    this.props.error.titles.bottomContent.content.bellowTitle.content = '';\n    this.done();\n  }\n\n  /**\n   * Maneja el click en el banner de error y emite el evento de navegación.\n   * Si el token contiene 'retry', reinicia el wizard.\n   * @param token Token de la acción clicada\n   */\n  clickHandler(token?: string) {\n    if (!token) {\n      return;\n    }\n    if (token.includes('retry')) {\n      this.reset();\n    }\n\n    this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });\n  }\n}\n"]}
@@ -4034,6 +4034,9 @@ class ItemListComponent {
4034
4034
  <div class="unread-indicator"></div>
4035
4035
  </div>
4036
4036
  }
4037
+ @if (item.icon) {
4038
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
4039
+ }
4037
4040
 
4038
4041
  <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
4039
4042
  <h2>{{ item.text }}</h2>
@@ -4216,6 +4219,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4216
4219
  <div class="unread-indicator"></div>
4217
4220
  </div>
4218
4221
  }
4222
+ @if (item.icon) {
4223
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
4224
+ }
4219
4225
 
4220
4226
  <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
4221
4227
  <h2>{{ item.text }}</h2>
@@ -4559,7 +4565,7 @@ class WizardComponent {
4559
4565
  size: 'large',
4560
4566
  text: 'Por favor espere...',
4561
4567
  }"
4562
- ></val-content-loader>
4568
+ />
4563
4569
  </div>
4564
4570
  <ng-content select="[step]"></ng-content>
4565
4571
  </div>
@@ -4585,7 +4591,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4585
4591
  size: 'large',
4586
4592
  text: 'Por favor espere...',
4587
4593
  }"
4588
- ></val-content-loader>
4594
+ />
4589
4595
  </div>
4590
4596
  <ng-content select="[step]"></ng-content>
4591
4597
  </div>