valtech-components 2.0.33 → 2.0.34

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.
@@ -23,7 +23,7 @@ export class ButtonGroupComponent {
23
23
  <val-button
24
24
  *ngFor="let b of props.buttons"
25
25
  [props]="b"
26
- (click)="clickHandler(b?.token)"
26
+ (onClick)="clickHandler(b?.token)"
27
27
  [ngStyle]="{ width: props.buttons.length === 1 ? '100%' : 'auto' }"
28
28
  ></val-button>
29
29
  </div>
@@ -36,7 +36,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
36
36
  <val-button
37
37
  *ngFor="let b of props.buttons"
38
38
  [props]="b"
39
- (click)="clickHandler(b?.token)"
39
+ (onClick)="clickHandler(b?.token)"
40
40
  [ngStyle]="{ width: props.buttons.length === 1 ? '100%' : 'auto' }"
41
41
  ></val-button>
42
42
  </div>
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
46
46
  }], onClick: [{
47
47
  type: Output
48
48
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2J1dHRvbi1ncm91cC9idXR0b24tZ3JvdXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7O0FBa0J0RSxNQUFNLE9BQU8sb0JBQW9CO0lBTy9CO1FBRkEsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFFdEIsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLFlBQVksQ0FBQyxLQUFjO1FBQ3pCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDeEUsT0FBTyxPQUFPLENBQUM7UUFDakIsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUM7SUFDN0IsQ0FBQzsrR0FyQlUsb0JBQW9CO21HQUFwQixvQkFBb0IseUlBWnJCOzs7Ozs7Ozs7R0FTVCxxWUFWUyxZQUFZLCtVQUFFLGVBQWU7OzRGQWE1QixvQkFBb0I7a0JBaEJoQyxTQUFTOytCQUNFLGtCQUFrQixjQUNoQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFlBQzlCOzs7Ozs7Ozs7R0FTVDt3REFLRCxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJ1dHRvbkdyb3VwTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWJ1dHRvbi1ncm91cCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJ1dHRvbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBbbmdDbGFzc109XCJbJ2dyb3VwLWNvbnRhaW5lcicsIFBvc2l0aW9uXVwiIFtjbGFzcy5jb2x1bW5dPVwicHJvcHMuY29sdW1uZWRcIiBzdHlsZT1cIndpZHRoOiAxMDAlO1wiPlxuICAgICAgPHZhbC1idXR0b25cbiAgICAgICAgKm5nRm9yPVwibGV0IGIgb2YgcHJvcHMuYnV0dG9uc1wiXG4gICAgICAgIFtwcm9wc109XCJiXCJcbiAgICAgICAgKGNsaWNrKT1cImNsaWNrSGFuZGxlcihiPy50b2tlbilcIlxuICAgICAgICBbbmdTdHlsZV09XCJ7IHdpZHRoOiBwcm9wcy5idXR0b25zLmxlbmd0aCA9PT0gMSA/ICcxMDAlJyA6ICdhdXRvJyB9XCJcbiAgICAgID48L3ZhbC1idXR0b24+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL2J1dHRvbi1ncm91cC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBCdXR0b25Hcm91cENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpXG4gIHByb3BzOiBCdXR0b25Hcm91cE1ldGFkYXRhO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBjbGlja0hhbmRsZXIodG9rZW4/OiBzdHJpbmcpIHtcbiAgICB0aGlzLm9uQ2xpY2suZW1pdCh0b2tlbik7XG4gIH1cblxuICBnZXQgUG9zaXRpb24oKTogc3RyaW5nIHtcbiAgICBpZiAodGhpcy5wcm9wcy5idXR0b25zLmxlbmd0aCA9PT0gMSAmJiB0aGlzLnByb3BzLnBvc2l0aW9uID09PSAnc3BhY2VkJykge1xuICAgICAgcmV0dXJuICdyaWdodCc7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMucHJvcHMucG9zaXRpb247XG4gIH1cbn1cbiJdfQ==
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2J1dHRvbi1ncm91cC9idXR0b24tZ3JvdXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7O0FBa0J0RSxNQUFNLE9BQU8sb0JBQW9CO0lBTy9CO1FBRkEsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFFdEIsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLFlBQVksQ0FBQyxLQUFjO1FBQ3pCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDeEUsT0FBTyxPQUFPLENBQUM7UUFDakIsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUM7SUFDN0IsQ0FBQzsrR0FyQlUsb0JBQW9CO21HQUFwQixvQkFBb0IseUlBWnJCOzs7Ozs7Ozs7R0FTVCxxWUFWUyxZQUFZLCtVQUFFLGVBQWU7OzRGQWE1QixvQkFBb0I7a0JBaEJoQyxTQUFTOytCQUNFLGtCQUFrQixjQUNoQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFlBQzlCOzs7Ozs7Ozs7R0FTVDt3REFLRCxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJ1dHRvbkdyb3VwTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWJ1dHRvbi1ncm91cCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJ1dHRvbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBbbmdDbGFzc109XCJbJ2dyb3VwLWNvbnRhaW5lcicsIFBvc2l0aW9uXVwiIFtjbGFzcy5jb2x1bW5dPVwicHJvcHMuY29sdW1uZWRcIiBzdHlsZT1cIndpZHRoOiAxMDAlO1wiPlxuICAgICAgPHZhbC1idXR0b25cbiAgICAgICAgKm5nRm9yPVwibGV0IGIgb2YgcHJvcHMuYnV0dG9uc1wiXG4gICAgICAgIFtwcm9wc109XCJiXCJcbiAgICAgICAgKG9uQ2xpY2spPVwiY2xpY2tIYW5kbGVyKGI/LnRva2VuKVwiXG4gICAgICAgIFtuZ1N0eWxlXT1cInsgd2lkdGg6IHByb3BzLmJ1dHRvbnMubGVuZ3RoID09PSAxID8gJzEwMCUnIDogJ2F1dG8nIH1cIlxuICAgICAgPjwvdmFsLWJ1dHRvbj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEJ1dHRvbkdyb3VwQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgcHJvcHM6IEJ1dHRvbkdyb3VwTWV0YWRhdGE7XG5cbiAgQE91dHB1dCgpXG4gIG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxuXG4gIGNsaWNrSGFuZGxlcih0b2tlbj86IHN0cmluZykge1xuICAgIHRoaXMub25DbGljay5lbWl0KHRva2VuKTtcbiAgfVxuXG4gIGdldCBQb3NpdGlvbigpOiBzdHJpbmcge1xuICAgIGlmICh0aGlzLnByb3BzLmJ1dHRvbnMubGVuZ3RoID09PSAxICYmIHRoaXMucHJvcHMucG9zaXRpb24gPT09ICdzcGFjZWQnKSB7XG4gICAgICByZXR1cm4gJ3JpZ2h0JztcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5wcm9wcy5wb3NpdGlvbjtcbiAgfVxufVxuIl19
@@ -34,7 +34,7 @@ export class CardComponent {
34
34
  <val-button
35
35
  *ngFor="let b of props.footerActions"
36
36
  [props]="b"
37
- (click)="clickHandler(sections.footer, b.token)"
37
+ (onClick)="clickHandler(sections.footer, b.token)"
38
38
  ></val-button>
39
39
  </ion-card>
40
40
 
@@ -145,7 +145,7 @@ export class CardComponent {
145
145
  <val-button
146
146
  *ngFor="let b of props.footerActions"
147
147
  [props]="b"
148
- (click)="clickHandler(sections.footer, b.token)"
148
+ (onClick)="clickHandler(sections.footer, b.token)"
149
149
  ></val-button>
150
150
  <ion-buttons
151
151
  style="display: flex; align-items: center; justify-content: flex-end; margin: 8px"
@@ -211,7 +211,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
211
211
  <val-button
212
212
  *ngFor="let b of props.footerActions"
213
213
  [props]="b"
214
- (click)="clickHandler(sections.footer, b.token)"
214
+ (onClick)="clickHandler(sections.footer, b.token)"
215
215
  ></val-button>
216
216
  </ion-card>
217
217
 
@@ -322,7 +322,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
322
322
  <val-button
323
323
  *ngFor="let b of props.footerActions"
324
324
  [props]="b"
325
- (click)="clickHandler(sections.footer, b.token)"
325
+ (onClick)="clickHandler(sections.footer, b.token)"
326
326
  ></val-button>
327
327
  <ion-buttons
328
328
  style="display: flex; align-items: center; justify-content: flex-end; margin: 8px"
@@ -362,4 +362,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
362
362
  }], onClick: [{
363
363
  type: Output
364
364
  }] } });
365
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/card/card.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EACL,SAAS,EACT,UAAU,EACV,OAAO,EACP,cAAc,EACd,aAAa,EACb,eAAe,EACf,YAAY,EACZ,WAAW,EACX,OAAO,GACR,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAgC,WAAW,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;;;AAsL9E,MAAM,OAAO,aAAa;IAUxB;QANA,YAAO,GAAG,IAAI,YAAY,EAAkB,CAAC;QAE7C,UAAK,GAAG,QAAQ,CAAC;QACjB,gBAAW,GAAG,iBAAiB,CAAC;QAChC,aAAQ,GAAG,WAAW,CAAC;IAER,CAAC;IAEhB,QAAQ,KAAI,CAAC;IAEb,YAAY,CAAC,OAAoB,EAAE,KAAc;QAC/C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACxC,CAAC;+GAhBU,aAAa;mGAAb,aAAa,iIAjKd;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8JT,0iBA7KC,YAAY,gQACZ,eAAe,gGACf,eAAe,gGACf,cAAc,yEACd,aAAa,wEACb,OAAO,yLACP,cAAc,+EACd,aAAa,sGACb,YAAY,sFACZ,eAAe,yFACf,WAAW,0KACX,UAAU,8EACV,SAAS,oPACT,OAAO;;4FAmKE,aAAa;kBApLzB,SAAS;+BACE,UAAU,cACR,IAAI,WACP;wBACP,YAAY;wBACZ,eAAe;wBACf,eAAe;wBACf,cAAc;wBACd,aAAa;wBACb,OAAO;wBACP,cAAc;wBACd,aAAa;wBACb,YAAY;wBACZ,eAAe;wBACf,WAAW;wBACX,UAAU;wBACV,SAAS;wBACT,OAAO;qBACR,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8JT;wDAIQ,KAAK;sBAAb,KAAK;gBAGN,OAAO;sBADN,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  IonButton,\n  IonButtons,\n  IonCard,\n  IonCardContent,\n  IonCardHeader,\n  IonCardSubtitle,\n  IonCardTitle,\n  IonCheckbox,\n  IonIcon,\n} from '@ionic/angular/standalone';\nimport { AvatarComponent } from '../../atoms/avatar/avatar.component';\nimport { ButtonComponent } from '../../atoms/button/button.component';\nimport { ImageComponent } from '../../atoms/image/image.component';\nimport { TextComponent } from '../../atoms/text/text.component';\nimport { ToolbarActionType } from '../../types';\nimport { CardClickEvent, CardMetadata, CardSection, CardType } from './types';\n\n@Component({\n  selector: 'val-card',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    AvatarComponent,\n    ImageComponent,\n    TextComponent,\n    IonCard,\n    IonCardContent,\n    IonCardHeader,\n    IonCardTitle,\n    IonCardSubtitle,\n    IonCheckbox,\n    IonButtons,\n    IonButton,\n    IonIcon,\n  ],\n  template: `\n    <ion-card *ngIf=\"props.type === types.native\">\n      <img alt=\"image\" [src]=\"props.image\" />\n      <ion-card-header *ngIf=\"props.title || props.overtitle\">\n        <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n        <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n      </ion-card-header>\n\n      <ion-card-content *ngIf=\"props.content\">{{ props.content }}</ion-card-content>\n\n      <val-button\n        *ngFor=\"let b of props.footerActions\"\n        [props]=\"b\"\n        (click)=\"clickHandler(sections.footer, b.token)\"\n      ></val-button>\n    </ion-card>\n\n    <ion-card\n      *ngIf=\"props.type === types.tappable\"\n      (click)=\"clickHandler(sections.content, props.token)\"\n      class=\"tapable\"\n    >\n      <img alt=\"image\" [src]=\"props.image\" />\n      <ion-card-header *ngIf=\"props.title || props.overtitle\">\n        <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n        <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n      </ion-card-header>\n\n      <ion-card-content *ngIf=\"props.content\">{{ props.content }}</ion-card-content>\n    </ion-card>\n\n    <ion-card\n      *ngIf=\"props.type === types.checker\"\n      (click)=\"clickHandler(sections.content, props.token)\"\n      class=\"tapable\"\n    >\n      <ion-card-header *ngIf=\"props.title || props.overtitle\" class=\"checker\">\n        <div>\n          <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n          <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n        </div>\n        <div>\n          <ion-checkbox [checked]=\"props.selected\"></ion-checkbox>\n        </div>\n      </ion-card-header>\n\n      <ion-card-content *ngIf=\"props.content\">{{ props.content }}</ion-card-content>\n    </ion-card>\n\n    <ion-card *ngIf=\"props.type === types.complex\" class=\"complex\">\n      <ion-card-header class=\"complex-header\">\n        <ion-buttons style=\"display: flex; align-items: center\" *ngIf=\"props.leftActions.length > 0\">\n          <ng-container *ngFor=\"let action of props.leftActions\">\n            <ion-button\n              *ngIf=\"action.type === actionTypes.ICON\"\n              (click)=\"clickHandler(sections.headerLeft, action.token)\"\n            >\n              <ion-icon slot=\"icon-only\" [name]=\"action.description\" color=\"dark\"></ion-icon>\n            </ion-button>\n            <val-avatar\n              style=\"margin-right: 4px; cursor: pointer\"\n              *ngIf=\"action.type === actionTypes.AVATAR\"\n              [props]=\"{ size: 'small', image: action.description, default: '' }\"\n              (onClick)=\"clickHandler(sections.headerLeft, action.token)\"\n            ></val-avatar>\n            <val-image\n              *ngIf=\"action.type === actionTypes.IMAGE\"\n              [props]=\"action.image\"\n              (click)=\"clickHandler(sections.headerLeft, action.token)\"\n            ></val-image>\n            <ion-button\n              *ngIf=\"action.type === actionTypes.BUTTON\"\n              (click)=\"clickHandler(sections.headerLeft, action.token)\"\n            >\n              {{ action.description }}\n            </ion-button>\n            <div *ngIf=\"props.headerText\">\n              <val-text [props]=\"{ content: props.headerText, color: 'dark', bold: true, size: 'medium' }\" />\n            </div>\n          </ng-container>\n        </ion-buttons>\n        <ion-buttons style=\"display: flex; align-items: center\" *ngIf=\"props.rightActions.length > 0\">\n          <ng-container *ngFor=\"let action of props.rightActions\">\n            <ion-button\n              *ngIf=\"action.type === actionTypes.ICON\"\n              (click)=\"clickHandler(sections.headerRight, action.token)\"\n            >\n              <ion-icon slot=\"icon-only\" [name]=\"action.description\" color=\"dark\"></ion-icon>\n            </ion-button>\n            <val-avatar\n              style=\"margin-right: 4px; cursor: pointer\"\n              *ngIf=\"action.type === actionTypes.AVATAR\"\n              [props]=\"{ size: 'small', image: action.description, default: '' }\"\n              (onClick)=\"clickHandler(sections.headerRight, action.token)\"\n            ></val-avatar>\n            <val-image\n              *ngIf=\"action.type === actionTypes.IMAGE\"\n              [props]=\"action.image\"\n              (click)=\"clickHandler(sections.headerRight, action.token)\"\n            ></val-image>\n            <ion-button\n              *ngIf=\"action.type === actionTypes.BUTTON\"\n              (click)=\"clickHandler(sections.headerRight, action.token)\"\n            >\n              {{ action.description }}\n            </ion-button>\n          </ng-container>\n        </ion-buttons>\n      </ion-card-header>\n\n      <div class=\"tapable\" (click)=\"clickHandler(sections.content, props.token)\">\n        <ion-card-header *ngIf=\"props.title || props.overtitle\" class=\"complex-header\">\n          <div>\n            <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n            <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n          </div>\n        </ion-card-header>\n\n        <img alt=\"image\" [src]=\"props.image\" />\n        <ion-card-content *ngIf=\"props.content\" class=\"complex-content\">{{ props.content }}</ion-card-content>\n      </div>\n      <val-button\n        *ngFor=\"let b of props.footerActions\"\n        [props]=\"b\"\n        (click)=\"clickHandler(sections.footer, b.token)\"\n      ></val-button>\n      <ion-buttons\n        style=\"display: flex; align-items: center; justify-content: flex-end; margin: 8px\"\n        *ngIf=\"props.footerComplexActions.length > 0\"\n      >\n        <ng-container *ngFor=\"let action of props.footerComplexActions\">\n          <ion-button\n            *ngIf=\"action.type === actionTypes.ICON\"\n            (click)=\"clickHandler(sections.footerExtra, action.token)\"\n          >\n            <ion-icon slot=\"icon-only\" [name]=\"action.description\" color=\"dark\"></ion-icon>\n          </ion-button>\n          <val-avatar\n            style=\"margin-right: 4px; cursor: pointer\"\n            *ngIf=\"action.type === actionTypes.AVATAR\"\n            [props]=\"{ size: 'small', image: action.description, default: '' }\"\n            (onClick)=\"clickHandler(sections.footerExtra, action.token)\"\n          ></val-avatar>\n          <val-image\n            *ngIf=\"action.type === actionTypes.IMAGE\"\n            [props]=\"action.image\"\n            (click)=\"clickHandler(sections.footerExtra, action.token)\"\n          ></val-image>\n          <ion-button\n            *ngIf=\"action.type === actionTypes.BUTTON\"\n            (click)=\"clickHandler(sections.footerExtra, action.token)\"\n            color=\"dark\"\n          >\n            {{ action.description }}\n          </ion-button>\n        </ng-container>\n      </ion-buttons>\n    </ion-card>\n  `,\n  styleUrls: ['./card.component.scss'],\n})\nexport class CardComponent implements OnInit {\n  @Input() props: CardMetadata;\n\n  @Output()\n  onClick = new EventEmitter<CardClickEvent>();\n\n  types = CardType;\n  actionTypes = ToolbarActionType;\n  sections = CardSection;\n\n  constructor() {}\n\n  ngOnInit() {}\n\n  clickHandler(section: CardSection, token?: string) {\n    this.onClick.emit({ section, token });\n  }\n}\n"]}
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/card/card.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EACL,SAAS,EACT,UAAU,EACV,OAAO,EACP,cAAc,EACd,aAAa,EACb,eAAe,EACf,YAAY,EACZ,WAAW,EACX,OAAO,GACR,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAgC,WAAW,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;;;AAsL9E,MAAM,OAAO,aAAa;IAUxB;QANA,YAAO,GAAG,IAAI,YAAY,EAAkB,CAAC;QAE7C,UAAK,GAAG,QAAQ,CAAC;QACjB,gBAAW,GAAG,iBAAiB,CAAC;QAChC,aAAQ,GAAG,WAAW,CAAC;IAER,CAAC;IAEhB,QAAQ,KAAI,CAAC;IAEb,YAAY,CAAC,OAAoB,EAAE,KAAc;QAC/C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;IACxC,CAAC;+GAhBU,aAAa;mGAAb,aAAa,iIAjKd;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8JT,0iBA7KC,YAAY,gQACZ,eAAe,gGACf,eAAe,gGACf,cAAc,yEACd,aAAa,wEACb,OAAO,yLACP,cAAc,+EACd,aAAa,sGACb,YAAY,sFACZ,eAAe,yFACf,WAAW,0KACX,UAAU,8EACV,SAAS,oPACT,OAAO;;4FAmKE,aAAa;kBApLzB,SAAS;+BACE,UAAU,cACR,IAAI,WACP;wBACP,YAAY;wBACZ,eAAe;wBACf,eAAe;wBACf,cAAc;wBACd,aAAa;wBACb,OAAO;wBACP,cAAc;wBACd,aAAa;wBACb,YAAY;wBACZ,eAAe;wBACf,WAAW;wBACX,UAAU;wBACV,SAAS;wBACT,OAAO;qBACR,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8JT;wDAIQ,KAAK;sBAAb,KAAK;gBAGN,OAAO;sBADN,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  IonButton,\n  IonButtons,\n  IonCard,\n  IonCardContent,\n  IonCardHeader,\n  IonCardSubtitle,\n  IonCardTitle,\n  IonCheckbox,\n  IonIcon,\n} from '@ionic/angular/standalone';\nimport { AvatarComponent } from '../../atoms/avatar/avatar.component';\nimport { ButtonComponent } from '../../atoms/button/button.component';\nimport { ImageComponent } from '../../atoms/image/image.component';\nimport { TextComponent } from '../../atoms/text/text.component';\nimport { ToolbarActionType } from '../../types';\nimport { CardClickEvent, CardMetadata, CardSection, CardType } from './types';\n\n@Component({\n  selector: 'val-card',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    AvatarComponent,\n    ImageComponent,\n    TextComponent,\n    IonCard,\n    IonCardContent,\n    IonCardHeader,\n    IonCardTitle,\n    IonCardSubtitle,\n    IonCheckbox,\n    IonButtons,\n    IonButton,\n    IonIcon,\n  ],\n  template: `\n    <ion-card *ngIf=\"props.type === types.native\">\n      <img alt=\"image\" [src]=\"props.image\" />\n      <ion-card-header *ngIf=\"props.title || props.overtitle\">\n        <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n        <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n      </ion-card-header>\n\n      <ion-card-content *ngIf=\"props.content\">{{ props.content }}</ion-card-content>\n\n      <val-button\n        *ngFor=\"let b of props.footerActions\"\n        [props]=\"b\"\n        (onClick)=\"clickHandler(sections.footer, b.token)\"\n      ></val-button>\n    </ion-card>\n\n    <ion-card\n      *ngIf=\"props.type === types.tappable\"\n      (click)=\"clickHandler(sections.content, props.token)\"\n      class=\"tapable\"\n    >\n      <img alt=\"image\" [src]=\"props.image\" />\n      <ion-card-header *ngIf=\"props.title || props.overtitle\">\n        <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n        <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n      </ion-card-header>\n\n      <ion-card-content *ngIf=\"props.content\">{{ props.content }}</ion-card-content>\n    </ion-card>\n\n    <ion-card\n      *ngIf=\"props.type === types.checker\"\n      (click)=\"clickHandler(sections.content, props.token)\"\n      class=\"tapable\"\n    >\n      <ion-card-header *ngIf=\"props.title || props.overtitle\" class=\"checker\">\n        <div>\n          <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n          <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n        </div>\n        <div>\n          <ion-checkbox [checked]=\"props.selected\"></ion-checkbox>\n        </div>\n      </ion-card-header>\n\n      <ion-card-content *ngIf=\"props.content\">{{ props.content }}</ion-card-content>\n    </ion-card>\n\n    <ion-card *ngIf=\"props.type === types.complex\" class=\"complex\">\n      <ion-card-header class=\"complex-header\">\n        <ion-buttons style=\"display: flex; align-items: center\" *ngIf=\"props.leftActions.length > 0\">\n          <ng-container *ngFor=\"let action of props.leftActions\">\n            <ion-button\n              *ngIf=\"action.type === actionTypes.ICON\"\n              (click)=\"clickHandler(sections.headerLeft, action.token)\"\n            >\n              <ion-icon slot=\"icon-only\" [name]=\"action.description\" color=\"dark\"></ion-icon>\n            </ion-button>\n            <val-avatar\n              style=\"margin-right: 4px; cursor: pointer\"\n              *ngIf=\"action.type === actionTypes.AVATAR\"\n              [props]=\"{ size: 'small', image: action.description, default: '' }\"\n              (onClick)=\"clickHandler(sections.headerLeft, action.token)\"\n            ></val-avatar>\n            <val-image\n              *ngIf=\"action.type === actionTypes.IMAGE\"\n              [props]=\"action.image\"\n              (click)=\"clickHandler(sections.headerLeft, action.token)\"\n            ></val-image>\n            <ion-button\n              *ngIf=\"action.type === actionTypes.BUTTON\"\n              (click)=\"clickHandler(sections.headerLeft, action.token)\"\n            >\n              {{ action.description }}\n            </ion-button>\n            <div *ngIf=\"props.headerText\">\n              <val-text [props]=\"{ content: props.headerText, color: 'dark', bold: true, size: 'medium' }\" />\n            </div>\n          </ng-container>\n        </ion-buttons>\n        <ion-buttons style=\"display: flex; align-items: center\" *ngIf=\"props.rightActions.length > 0\">\n          <ng-container *ngFor=\"let action of props.rightActions\">\n            <ion-button\n              *ngIf=\"action.type === actionTypes.ICON\"\n              (click)=\"clickHandler(sections.headerRight, action.token)\"\n            >\n              <ion-icon slot=\"icon-only\" [name]=\"action.description\" color=\"dark\"></ion-icon>\n            </ion-button>\n            <val-avatar\n              style=\"margin-right: 4px; cursor: pointer\"\n              *ngIf=\"action.type === actionTypes.AVATAR\"\n              [props]=\"{ size: 'small', image: action.description, default: '' }\"\n              (onClick)=\"clickHandler(sections.headerRight, action.token)\"\n            ></val-avatar>\n            <val-image\n              *ngIf=\"action.type === actionTypes.IMAGE\"\n              [props]=\"action.image\"\n              (click)=\"clickHandler(sections.headerRight, action.token)\"\n            ></val-image>\n            <ion-button\n              *ngIf=\"action.type === actionTypes.BUTTON\"\n              (click)=\"clickHandler(sections.headerRight, action.token)\"\n            >\n              {{ action.description }}\n            </ion-button>\n          </ng-container>\n        </ion-buttons>\n      </ion-card-header>\n\n      <div class=\"tapable\" (click)=\"clickHandler(sections.content, props.token)\">\n        <ion-card-header *ngIf=\"props.title || props.overtitle\" class=\"complex-header\">\n          <div>\n            <ion-card-subtitle *ngIf=\"props.overtitle\">{{ props.overtitle }}</ion-card-subtitle>\n            <ion-card-title *ngIf=\"props.title\">{{ props.title }}</ion-card-title>\n          </div>\n        </ion-card-header>\n\n        <img alt=\"image\" [src]=\"props.image\" />\n        <ion-card-content *ngIf=\"props.content\" class=\"complex-content\">{{ props.content }}</ion-card-content>\n      </div>\n      <val-button\n        *ngFor=\"let b of props.footerActions\"\n        [props]=\"b\"\n        (onClick)=\"clickHandler(sections.footer, b.token)\"\n      ></val-button>\n      <ion-buttons\n        style=\"display: flex; align-items: center; justify-content: flex-end; margin: 8px\"\n        *ngIf=\"props.footerComplexActions.length > 0\"\n      >\n        <ng-container *ngFor=\"let action of props.footerComplexActions\">\n          <ion-button\n            *ngIf=\"action.type === actionTypes.ICON\"\n            (click)=\"clickHandler(sections.footerExtra, action.token)\"\n          >\n            <ion-icon slot=\"icon-only\" [name]=\"action.description\" color=\"dark\"></ion-icon>\n          </ion-button>\n          <val-avatar\n            style=\"margin-right: 4px; cursor: pointer\"\n            *ngIf=\"action.type === actionTypes.AVATAR\"\n            [props]=\"{ size: 'small', image: action.description, default: '' }\"\n            (onClick)=\"clickHandler(sections.footerExtra, action.token)\"\n          ></val-avatar>\n          <val-image\n            *ngIf=\"action.type === actionTypes.IMAGE\"\n            [props]=\"action.image\"\n            (click)=\"clickHandler(sections.footerExtra, action.token)\"\n          ></val-image>\n          <ion-button\n            *ngIf=\"action.type === actionTypes.BUTTON\"\n            (click)=\"clickHandler(sections.footerExtra, action.token)\"\n            color=\"dark\"\n          >\n            {{ action.description }}\n          </ion-button>\n        </ng-container>\n      </ion-buttons>\n    </ion-card>\n  `,\n  styleUrls: ['./card.component.scss'],\n})\nexport class CardComponent implements OnInit {\n  @Input() props: CardMetadata;\n\n  @Output()\n  onClick = new EventEmitter<CardClickEvent>();\n\n  types = CardType;\n  actionTypes = ToolbarActionType;\n  sections = CardSection;\n\n  constructor() {}\n\n  ngOnInit() {}\n\n  clickHandler(section: CardSection, token?: string) {\n    this.onClick.emit({ section, token });\n  }\n}\n"]}
@@ -0,0 +1,342 @@
1
+ import { NgClass } from '@angular/common';
2
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
3
+ import { RouterLink } from '@angular/router';
4
+ import { IonAvatar, IonButton, IonIcon, IonItem, IonLabel, IonList, IonListHeader, IonNote, IonSpinner, } from '@ionic/angular/standalone';
5
+ import { ComponentStates } from '../../types';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../services/icons.service";
8
+ export class ItemListComponent {
9
+ constructor(icon) {
10
+ this.states = ComponentStates;
11
+ this.onClick = new EventEmitter();
12
+ this.onActionClick = new EventEmitter();
13
+ }
14
+ ngOnInit() { }
15
+ clickHandler(token) {
16
+ this.onClick.emit(token);
17
+ }
18
+ onActionClickHandler(token) {
19
+ this.onActionClick.emit(token);
20
+ }
21
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ItemListComponent, deps: [{ token: i1.IconService }], target: i0.ɵɵFactoryTarget.Component }); }
22
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ItemListComponent, isStandalone: true, selector: "item-list", inputs: { props: "props" }, outputs: { onClick: "onClick", onActionClick: "onActionClick" }, ngImport: i0, template: `
23
+ <div>
24
+ <ion-list [inset]="props.rounded" [class.shadowed]="props.shadowed">
25
+ <ion-list-header [color]="props.color">
26
+ <ion-label>{{ props.title }}</ion-label>
27
+ </ion-list-header>
28
+ @for (item of props.items; track item.text) {
29
+ @if (item.mode == 'justext') {
30
+ <ion-item
31
+ [lines]="item.lines"
32
+ [button]="item.clickable"
33
+ [disabled]="item.disabled"
34
+ (click)="clickHandler(item.token)"
35
+ >
36
+ @if (item.unreadIndicator) {
37
+ <div class="unread-indicator-wrapper" slot="start">
38
+ <div class="unread-indicator"></div>
39
+ </div>
40
+ }
41
+
42
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
43
+ <h2>{{ item.text }}</h2>
44
+
45
+ @if (item.comments) {
46
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
47
+ }
48
+ </ion-label>
49
+
50
+ @if (item.endNote) {
51
+ <ion-note slot="end">{{ item.endNote }}</ion-note>
52
+ }
53
+ </ion-item>
54
+ }
55
+
56
+ @if (item.mode == 'actionable') {
57
+ <ion-item [lines]="item.lines" [button]="item.clickable" [disabled]="item.disabled">
58
+ @if (item.unreadIndicator) {
59
+ <div class="unread-indicator-wrapper" slot="start">
60
+ <div class="unread-indicator"></div>
61
+ </div>
62
+ }
63
+
64
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
65
+ <h2>{{ item.text }}</h2>
66
+
67
+ @if (item.comments) {
68
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
69
+ }
70
+ </ion-label>
71
+
72
+ @if (item.actions) {
73
+ @for (action of item.actions; track action.token) {
74
+ <ion-button
75
+ fill="outline"
76
+ color="dark"
77
+ slot="end"
78
+ [disabled]="action.state === states.WORKING"
79
+ (click)="onActionClickHandler(action.token)"
80
+ >
81
+ @if (action.state !== states.WORKING) {
82
+ @if (action.icon) {
83
+ <ion-icon aria-hidden="true" [name]="action.icon" size="medium" slot="start"></ion-icon>
84
+ }
85
+
86
+ {{ action.description }}
87
+ }
88
+
89
+ @if (action.state === states.WORKING) {
90
+ <ion-spinner class="action-spinner" name="circular"></ion-spinner>
91
+ }
92
+ </ion-button>
93
+ }
94
+ }
95
+ </ion-item>
96
+ }
97
+
98
+ @if (item.mode == 'route') {
99
+ <ion-item
100
+ [lines]="item.lines"
101
+ [button]="item.clickable"
102
+ [disabled]="item.disabled"
103
+ (click)="clickHandler(item.token)"
104
+ [routerLink]="item.routerLink"
105
+ >
106
+ @if (item.unreadIndicator) {
107
+ <div class="unread-indicator-wrapper" slot="start">
108
+ <div class="unread-indicator"></div>
109
+ </div>
110
+ }
111
+
112
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
113
+ <h2>{{ item.text }}</h2>
114
+
115
+ @if (item.comments) {
116
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
117
+ }
118
+ </ion-label>
119
+ </ion-item>
120
+ }
121
+
122
+ @if (item.mode == 'subtitule') {
123
+ <ion-item
124
+ [lines]="item.lines"
125
+ [button]="item.clickable"
126
+ [disabled]="item.disabled"
127
+ (click)="clickHandler(item.token)"
128
+ >
129
+ @if (item.unreadIndicator) {
130
+ <div class="unread-indicator-wrapper" slot="start">
131
+ <div class="unread-indicator"></div>
132
+ </div>
133
+ }
134
+
135
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
136
+ <h1>{{ item.text }}</h1>
137
+ <p>{{ item.subtitle }}</p>
138
+ </ion-label>
139
+ </ion-item>
140
+ }
141
+
142
+ @if (item.mode == 'avatar') {
143
+ <ion-item
144
+ [lines]="item.lines"
145
+ [button]="item.clickable"
146
+ [disabled]="item.disabled"
147
+ (click)="clickHandler(item.token)"
148
+ >
149
+ <ion-avatar aria-hidden="true" slot="start">
150
+ <img alt="" [src]="item.image" />
151
+ </ion-avatar>
152
+ <ion-label>{{ item.text }}</ion-label>
153
+ </ion-item>
154
+ }
155
+
156
+ @if (item.mode == 'icon') {
157
+ <ion-item
158
+ [lines]="item.lines"
159
+ [button]="item.clickable"
160
+ [disabled]="item.disabled"
161
+ (click)="clickHandler(item.token)"
162
+ >
163
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
164
+ <ion-label>{{ item.text }}</ion-label>
165
+ </ion-item>
166
+ }
167
+ }
168
+ </ion-list>
169
+ </div>
170
+ `, isInline: true, styles: ["ion-label{font-family:var(--ion-default-font),Arial,sans-serif}ion-note{font-family:var(--ion-default-font),Arial,sans-serif;font-weight:400}ion-button{font-family:var(--ion-default-font),Arial,sans-serif}.shadowed{box-shadow:.1875rem .625rem .5rem #1219541a}.unread-indicator{background:var(--ion-color-primary);width:.625rem;height:.625rem;border-radius:100%;position:absolute;inset-inline-start:.75rem;top:.75rem}.action-spinner{width:3.125rem;height:1rem}\n"], dependencies: [{ kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: IonListHeader, selector: "ion-list-header", inputs: ["color", "lines", "mode"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: IonNote, selector: "ion-note", inputs: ["color", "mode"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonAvatar, selector: "ion-avatar" }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }] }); }
171
+ }
172
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ItemListComponent, decorators: [{
173
+ type: Component,
174
+ args: [{ selector: 'item-list', standalone: true, imports: [
175
+ RouterLink,
176
+ NgClass,
177
+ IonList,
178
+ IonListHeader,
179
+ IonLabel,
180
+ IonNote,
181
+ IonItem,
182
+ IonAvatar,
183
+ IonIcon,
184
+ IonButton,
185
+ IonSpinner,
186
+ ], template: `
187
+ <div>
188
+ <ion-list [inset]="props.rounded" [class.shadowed]="props.shadowed">
189
+ <ion-list-header [color]="props.color">
190
+ <ion-label>{{ props.title }}</ion-label>
191
+ </ion-list-header>
192
+ @for (item of props.items; track item.text) {
193
+ @if (item.mode == 'justext') {
194
+ <ion-item
195
+ [lines]="item.lines"
196
+ [button]="item.clickable"
197
+ [disabled]="item.disabled"
198
+ (click)="clickHandler(item.token)"
199
+ >
200
+ @if (item.unreadIndicator) {
201
+ <div class="unread-indicator-wrapper" slot="start">
202
+ <div class="unread-indicator"></div>
203
+ </div>
204
+ }
205
+
206
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
207
+ <h2>{{ item.text }}</h2>
208
+
209
+ @if (item.comments) {
210
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
211
+ }
212
+ </ion-label>
213
+
214
+ @if (item.endNote) {
215
+ <ion-note slot="end">{{ item.endNote }}</ion-note>
216
+ }
217
+ </ion-item>
218
+ }
219
+
220
+ @if (item.mode == 'actionable') {
221
+ <ion-item [lines]="item.lines" [button]="item.clickable" [disabled]="item.disabled">
222
+ @if (item.unreadIndicator) {
223
+ <div class="unread-indicator-wrapper" slot="start">
224
+ <div class="unread-indicator"></div>
225
+ </div>
226
+ }
227
+
228
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
229
+ <h2>{{ item.text }}</h2>
230
+
231
+ @if (item.comments) {
232
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
233
+ }
234
+ </ion-label>
235
+
236
+ @if (item.actions) {
237
+ @for (action of item.actions; track action.token) {
238
+ <ion-button
239
+ fill="outline"
240
+ color="dark"
241
+ slot="end"
242
+ [disabled]="action.state === states.WORKING"
243
+ (click)="onActionClickHandler(action.token)"
244
+ >
245
+ @if (action.state !== states.WORKING) {
246
+ @if (action.icon) {
247
+ <ion-icon aria-hidden="true" [name]="action.icon" size="medium" slot="start"></ion-icon>
248
+ }
249
+
250
+ {{ action.description }}
251
+ }
252
+
253
+ @if (action.state === states.WORKING) {
254
+ <ion-spinner class="action-spinner" name="circular"></ion-spinner>
255
+ }
256
+ </ion-button>
257
+ }
258
+ }
259
+ </ion-item>
260
+ }
261
+
262
+ @if (item.mode == 'route') {
263
+ <ion-item
264
+ [lines]="item.lines"
265
+ [button]="item.clickable"
266
+ [disabled]="item.disabled"
267
+ (click)="clickHandler(item.token)"
268
+ [routerLink]="item.routerLink"
269
+ >
270
+ @if (item.unreadIndicator) {
271
+ <div class="unread-indicator-wrapper" slot="start">
272
+ <div class="unread-indicator"></div>
273
+ </div>
274
+ }
275
+
276
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
277
+ <h2>{{ item.text }}</h2>
278
+
279
+ @if (item.comments) {
280
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
281
+ }
282
+ </ion-label>
283
+ </ion-item>
284
+ }
285
+
286
+ @if (item.mode == 'subtitule') {
287
+ <ion-item
288
+ [lines]="item.lines"
289
+ [button]="item.clickable"
290
+ [disabled]="item.disabled"
291
+ (click)="clickHandler(item.token)"
292
+ >
293
+ @if (item.unreadIndicator) {
294
+ <div class="unread-indicator-wrapper" slot="start">
295
+ <div class="unread-indicator"></div>
296
+ </div>
297
+ }
298
+
299
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
300
+ <h1>{{ item.text }}</h1>
301
+ <p>{{ item.subtitle }}</p>
302
+ </ion-label>
303
+ </ion-item>
304
+ }
305
+
306
+ @if (item.mode == 'avatar') {
307
+ <ion-item
308
+ [lines]="item.lines"
309
+ [button]="item.clickable"
310
+ [disabled]="item.disabled"
311
+ (click)="clickHandler(item.token)"
312
+ >
313
+ <ion-avatar aria-hidden="true" slot="start">
314
+ <img alt="" [src]="item.image" />
315
+ </ion-avatar>
316
+ <ion-label>{{ item.text }}</ion-label>
317
+ </ion-item>
318
+ }
319
+
320
+ @if (item.mode == 'icon') {
321
+ <ion-item
322
+ [lines]="item.lines"
323
+ [button]="item.clickable"
324
+ [disabled]="item.disabled"
325
+ (click)="clickHandler(item.token)"
326
+ >
327
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
328
+ <ion-label>{{ item.text }}</ion-label>
329
+ </ion-item>
330
+ }
331
+ }
332
+ </ion-list>
333
+ </div>
334
+ `, styles: ["ion-label{font-family:var(--ion-default-font),Arial,sans-serif}ion-note{font-family:var(--ion-default-font),Arial,sans-serif;font-weight:400}ion-button{font-family:var(--ion-default-font),Arial,sans-serif}.shadowed{box-shadow:.1875rem .625rem .5rem #1219541a}.unread-indicator{background:var(--ion-color-primary);width:.625rem;height:.625rem;border-radius:100%;position:absolute;inset-inline-start:.75rem;top:.75rem}.action-spinner{width:3.125rem;height:1rem}\n"] }]
335
+ }], ctorParameters: () => [{ type: i1.IconService }], propDecorators: { props: [{
336
+ type: Input
337
+ }], onClick: [{
338
+ type: Output
339
+ }], onActionClick: [{
340
+ type: Output
341
+ }] } });
342
+ //# 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,MAAM,iBAAiB,CAAC;AAC1C,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,EAAkB,eAAe,EAAE,MAAM,aAAa,CAAC;;;AAiN9D,MAAM,OAAO,iBAAiB;IAY5B,YAAY,IAAiB;QAX7B,WAAM,GAAG,eAAe,CAAC;QAMzB,YAAO,GAAG,IAAI,YAAY,EAAU,CAAC;QAGrC,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;IAEX,CAAC;IAEjC,QAAQ,KAAI,CAAC;IAEb,YAAY,CAAC,KAAc;QACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,oBAAoB,CAAC,KAAc;QACjC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;+GAtBU,iBAAiB;mGAAjB,iBAAiB,kKAvJlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoJT,uhBAhKC,UAAU,oOACV,OAAO,oFACP,OAAO,yFACP,aAAa,gGACb,QAAQ,6FACR,OAAO,gFACP,OAAO,0NACP,SAAS,uDACT,OAAO,2JACP,SAAS,oPACT,UAAU;;4FAyJD,iBAAiB;kBAvK7B,SAAS;+BACE,WAAW,cACT,IAAI,WACP;wBACP,UAAU;wBACV,OAAO;wBACP,OAAO;wBACP,aAAa;wBACb,QAAQ;wBACR,OAAO;wBACP,OAAO;wBACP,SAAS;wBACT,OAAO;wBACP,SAAS;wBACT,UAAU;qBACX,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoJT;gFAOD,KAAK;sBADJ,KAAK;gBAIN,OAAO;sBADN,MAAM;gBAIP,aAAa;sBADZ,MAAM","sourcesContent":["import { NgClass } 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 { Color } from '@ionic/core';\nimport { ComponentState, ComponentStates } from '../../types';\nimport { IconService } from '../../../services/icons.service';\n\nexport type ItemAction = {\n  token: string;\n  icon?: string;\n  description: string;\n  state: ComponentState;\n};\n\nexport interface ItemMetadata {\n  token?: string;\n  mode: 'justext' | 'subtitule' | 'avatar' | 'icon' | 'route' | 'actionable';\n  text: string;\n  image?: string;\n  icon?: string;\n  comments?: string;\n  subtitle?: string;\n  endNote?: string;\n  actions?: ItemAction[];\n\n  color?: string;\n  lines?: 'full' | 'inset' | 'none';\n  button?: boolean;\n  detail?: boolean;\n  clickable?: boolean;\n  detailIcon?: string;\n  disabled?: boolean;\n  ellipsis?: boolean;\n  href?: string;\n  routerLink?: string | any[];\n  unreadIndicator?: boolean;\n}\n\nexport interface ListMetadata {\n  color: Color;\n  rounded: boolean;\n  shadowed: boolean;\n  title: string;\n  items: ItemMetadata[];\n}\n\n@Component({\n  selector: 'item-list',\n  standalone: true,\n  imports: [\n    RouterLink,\n    NgClass,\n    IonList,\n    IonListHeader,\n    IonLabel,\n    IonNote,\n    IonItem,\n    IonAvatar,\n    IonIcon,\n    IonButton,\n    IonSpinner,\n  ],\n  template: `\n    <div>\n      <ion-list [inset]=\"props.rounded\" [class.shadowed]=\"props.shadowed\">\n        <ion-list-header [color]=\"props.color\">\n          <ion-label>{{ props.title }}</ion-label>\n        </ion-list-header>\n        @for (item of props.items; track item.text) {\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              </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.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    </div>\n  `,\n  styleUrls: ['./item-list.component.scss'],\n})\nexport class ItemListComponent implements OnInit {\n  states = ComponentStates;\n\n  @Input()\n  props: ListMetadata;\n\n  @Output()\n  onClick = new EventEmitter<string>();\n\n  @Output()\n  onActionClick = new EventEmitter<string>();\n\n  constructor(icon: IconService) {}\n\n  ngOnInit() {}\n\n  clickHandler(token?: string) {\n    this.onClick.emit(token);\n  }\n\n  onActionClickHandler(token?: string) {\n    this.onActionClick.emit(token);\n  }\n}\n"]}
@@ -6,7 +6,7 @@ export class LayoutComponent {
6
6
  <div class="layout-container">
7
7
  <ng-content></ng-content>
8
8
  </div>
9
- `, isInline: true, styles: [".layout-container{margin:0 auto;padding:0 1rem;width:100%;box-sizing:border-box;margin-bottom:1rem}@media (max-width: 768px){.layout-container{max-width:100%}}@media (min-width: 768px){.layout-container{max-width:60rem;margin-bottom:1.5rem}}@media (min-width: 1200px){.layout-container{max-width:75rem}}\n"] }); }
9
+ `, isInline: true, styles: [".layout-container{margin:0 auto;padding:0;width:100%;box-sizing:border-box;margin-bottom:1rem}@media (max-width: 768px){.layout-container{max-width:100%}}@media (min-width: 768px){.layout-container{max-width:60rem;margin-bottom:1.5rem}}@media (min-width: 1200px){.layout-container{max-width:68.75rem}}\n"] }); }
10
10
  }
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LayoutComponent, decorators: [{
12
12
  type: Component,
@@ -14,6 +14,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
14
14
  <div class="layout-container">
15
15
  <ng-content></ng-content>
16
16
  </div>
17
- `, styles: [".layout-container{margin:0 auto;padding:0 1rem;width:100%;box-sizing:border-box;margin-bottom:1rem}@media (max-width: 768px){.layout-container{max-width:100%}}@media (min-width: 768px){.layout-container{max-width:60rem;margin-bottom:1.5rem}}@media (min-width: 1200px){.layout-container{max-width:75rem}}\n"] }]
17
+ `, styles: [".layout-container{margin:0 auto;padding:0;width:100%;box-sizing:border-box;margin-bottom:1rem}@media (max-width: 768px){.layout-container{max-width:100%}}@media (min-width: 768px){.layout-container{max-width:60rem;margin-bottom:1.5rem}}@media (min-width: 1200px){.layout-container{max-width:68.75rem}}\n"] }]
18
18
  }] });
19
19
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdGVtcGxhdGVzL2xheW91dC9sYXlvdXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBYTFDLE1BQU0sT0FBTyxlQUFlOytHQUFmLGVBQWU7bUdBQWYsZUFBZSxzRUFQaEI7Ozs7R0FJVDs7NEZBR1UsZUFBZTtrQkFYM0IsU0FBUzsrQkFDRSxZQUFZLGNBQ1YsSUFBSSxXQUNQLEVBQUUsWUFDRDs7OztHQUlUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1sYXlvdXQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwibGF5b3V0LWNvbnRhaW5lclwiPlxuICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZVVybDogJy4vbGF5b3V0LmNvbXBvbmVudC5zY3NzJyxcbn0pXG5leHBvcnQgY2xhc3MgTGF5b3V0Q29tcG9uZW50IHt9XG4iXX0=
@@ -35,7 +35,7 @@ export class SimpleComponent {
35
35
  <ng-content></ng-content>
36
36
  </val-layout>
37
37
  </ion-content>
38
- `, isInline: true, styles: [".layout-container{margin:0 auto;padding:0 1rem;width:100%;box-sizing:border-box;margin-bottom:1rem}@media (max-width: 768px){.layout-container{max-width:100%}}@media (min-width: 768px){.layout-container{max-width:60rem;margin-bottom:1.5rem}}@media (min-width: 1200px){.layout-container{max-width:75rem}}.description-container{padding-left:.5rem}.description{padding-left:1rem}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "component", type: IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: HeaderComponent, selector: "val-header", inputs: ["props"], outputs: ["onClick"] }, { kind: "component", type: LayoutComponent, selector: "val-layout" }, { kind: "component", type: DividerComponent, selector: "val-divider", inputs: ["props"] }, { kind: "component", type: LinkComponent, selector: "val-link", inputs: ["props"], outputs: ["onClick"] }] }); }
38
+ `, isInline: true, styles: [".description-container{padding-left:.5rem}.description{padding-left:1rem}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "component", type: IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: HeaderComponent, selector: "val-header", inputs: ["props"], outputs: ["onClick"] }, { kind: "component", type: LayoutComponent, selector: "val-layout" }, { kind: "component", type: DividerComponent, selector: "val-divider", inputs: ["props"] }, { kind: "component", type: LinkComponent, selector: "val-link", inputs: ["props"], outputs: ["onClick"] }] }); }
39
39
  }
40
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SimpleComponent, decorators: [{
41
41
  type: Component,
@@ -71,10 +71,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
71
71
  <ng-content></ng-content>
72
72
  </val-layout>
73
73
  </ion-content>
74
- `, styles: [".layout-container{margin:0 auto;padding:0 1rem;width:100%;box-sizing:border-box;margin-bottom:1rem}@media (max-width: 768px){.layout-container{max-width:100%}}@media (min-width: 768px){.layout-container{max-width:60rem;margin-bottom:1.5rem}}@media (min-width: 1200px){.layout-container{max-width:75rem}}.description-container{padding-left:.5rem}.description{padding-left:1rem}\n"] }]
74
+ `, styles: [".description-container{padding-left:.5rem}.description{padding-left:1rem}\n"] }]
75
75
  }], propDecorators: { props: [{
76
76
  type: Input
77
77
  }], onClick: [{
78
78
  type: Output
79
79
  }] } });
80
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdGVtcGxhdGVzL3NpbXBsZS9zaW1wbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDakcsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQTBDN0QsTUFBTSxPQUFPLGVBQWU7SUF2QzVCO1FBNENFLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0tBS3RDO0lBSEMsY0FBYyxDQUFDLEtBQWM7UUFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQzsrR0FUVSxlQUFlO21HQUFmLGVBQWUsbUlBdkJoQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQlQsb2NBaENDLElBQUksNkZBQ0osU0FBUyxvR0FDVCxVQUFVLG1GQUNWLFFBQVEsaUZBQ1IsT0FBTyxnRkFDUCxVQUFVLGtKQUVWLGVBQWUsZ0dBQ2YsZUFBZSx1REFDZixnQkFBZ0IsMkVBQ2hCLGFBQWE7OzRGQXlCSixlQUFlO2tCQXZDM0IsU0FBUzsrQkFDRSxZQUFZLGNBQ1YsSUFBSSxXQUNQO3dCQUNQLElBQUk7d0JBQ0osU0FBUzt3QkFDVCxVQUFVO3dCQUNWLFFBQVE7d0JBQ1IsT0FBTzt3QkFDUCxVQUFVO3dCQUNWLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsYUFBYTtxQkFDZCxZQUNTOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CVDs4QkFLRCxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW9uQ29udGVudCwgSW9uSGVhZGVyLCBJb25UZXh0LCBJb25UaXRsZSwgSW9uVG9vbGJhciB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGl2aWRlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgTGlua0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL21vbGVjdWxlcy9saW5rL2xpbmsuY29tcG9uZW50JztcbmltcG9ydCB7IEhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL29yZ2FuaXNtcy9oZWFkZXIvaGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBMYXlvdXRDb21wb25lbnQgfSBmcm9tICcuLi9sYXlvdXQvbGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTaW1wbGVNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtc2ltcGxlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE5nSWYsXG4gICAgSW9uSGVhZGVyLFxuICAgIElvblRvb2xiYXIsXG4gICAgSW9uVGl0bGUsXG4gICAgSW9uVGV4dCxcbiAgICBJb25Db250ZW50LFxuICAgIEJ1dHRvbkNvbXBvbmVudCxcbiAgICBIZWFkZXJDb21wb25lbnQsXG4gICAgTGF5b3V0Q29tcG9uZW50LFxuICAgIERpdmlkZXJDb21wb25lbnQsXG4gICAgTGlua0NvbXBvbmVudCxcbiAgXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8dmFsLWhlYWRlciBbcHJvcHNdPVwicHJvcHMuaGVhZGVyXCIgLz5cblxuICAgIDxpb24tY29udGVudCBbZnVsbHNjcmVlbl09XCJ0cnVlXCI+XG4gICAgICA8aW9uLWhlYWRlciBjb2xsYXBzZT1cImNvbmRlbnNlXCI+XG4gICAgICAgIDxpb24tdG9vbGJhcj5cbiAgICAgICAgICA8aW9uLXRpdGxlIHNpemU9XCJsYXJnZVwiPnt7IHByb3BzLnBhZ2VUaXRsZSB9fTwvaW9uLXRpdGxlPlxuICAgICAgICA8L2lvbi10b29sYmFyPlxuICAgICAgPC9pb24taGVhZGVyPlxuICAgICAgPGRpdiBjbGFzcz1cImRlc2NyaXB0aW9uLWNvbnRhaW5lclwiICpuZ0lmPVwicHJvcHMucGFnZURlc2NyaXB0aW9uXCI+XG4gICAgICAgIDxpb24tdGV4dD5cbiAgICAgICAgICA8cCBjbGFzcz1cImRlc2NyaXB0aW9uXCI+e3sgcHJvcHMucGFnZURlc2NyaXB0aW9uIH19PC9wPlxuICAgICAgICA8L2lvbi10ZXh0PlxuICAgICAgICA8dmFsLWxpbmsgKm5nSWY9XCJwcm9wcy5saW5rXCIgW3Byb3BzXT1cInByb3BzLmxpbmtcIiAob25DbGljayk9XCJvbkNsaWNrSGFuZGxlcigkZXZlbnQpXCI+PC92YWwtbGluaz5cbiAgICAgIDwvZGl2PlxuICAgICAgPHZhbC1kaXZpZGVyICpuZ0lmPVwicHJvcHMud2l0aERpdmlkZXJcIiBbcHJvcHNdPVwieyBmaWxsOiAnc29saWQnLCBzaXplOiAnbWVkaXVtJywgY29sb3I6ICdkYXJrJyB9XCIgLz5cbiAgICAgIDx2YWwtbGF5b3V0PlxuICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICA8L3ZhbC1sYXlvdXQ+XG4gICAgPC9pb24tY29udGVudD5cbiAgYCxcbiAgc3R5bGVVcmw6ICcuL3NpbXBsZS5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIFNpbXBsZUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIHByb3BzOiBTaW1wbGVNZXRhZGF0YTtcblxuICBAT3V0cHV0KClcbiAgb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xuXG4gIG9uQ2xpY2tIYW5kbGVyKHRva2VuPzogc3RyaW5nKSB7XG4gICAgdGhpcy5vbkNsaWNrLmVtaXQodG9rZW4pO1xuICB9XG59XG4iXX0=
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdGVtcGxhdGVzL3NpbXBsZS9zaW1wbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDakcsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQTBDN0QsTUFBTSxPQUFPLGVBQWU7SUF2QzVCO1FBNENFLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0tBS3RDO0lBSEMsY0FBYyxDQUFDLEtBQWM7UUFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQzsrR0FUVSxlQUFlO21HQUFmLGVBQWUsbUlBdkJoQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQlQscUpBaENDLElBQUksNkZBQ0osU0FBUyxvR0FDVCxVQUFVLG1GQUNWLFFBQVEsaUZBQ1IsT0FBTyxnRkFDUCxVQUFVLGtKQUVWLGVBQWUsZ0dBQ2YsZUFBZSx1REFDZixnQkFBZ0IsMkVBQ2hCLGFBQWE7OzRGQXlCSixlQUFlO2tCQXZDM0IsU0FBUzsrQkFDRSxZQUFZLGNBQ1YsSUFBSSxXQUNQO3dCQUNQLElBQUk7d0JBQ0osU0FBUzt3QkFDVCxVQUFVO3dCQUNWLFFBQVE7d0JBQ1IsT0FBTzt3QkFDUCxVQUFVO3dCQUNWLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsYUFBYTtxQkFDZCxZQUNTOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CVDs4QkFLRCxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW9uQ29udGVudCwgSW9uSGVhZGVyLCBJb25UZXh0LCBJb25UaXRsZSwgSW9uVG9vbGJhciB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGl2aWRlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgTGlua0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL21vbGVjdWxlcy9saW5rL2xpbmsuY29tcG9uZW50JztcbmltcG9ydCB7IEhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL29yZ2FuaXNtcy9oZWFkZXIvaGVhZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBMYXlvdXRDb21wb25lbnQgfSBmcm9tICcuLi9sYXlvdXQvbGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTaW1wbGVNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtc2ltcGxlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE5nSWYsXG4gICAgSW9uSGVhZGVyLFxuICAgIElvblRvb2xiYXIsXG4gICAgSW9uVGl0bGUsXG4gICAgSW9uVGV4dCxcbiAgICBJb25Db250ZW50LFxuICAgIEJ1dHRvbkNvbXBvbmVudCxcbiAgICBIZWFkZXJDb21wb25lbnQsXG4gICAgTGF5b3V0Q29tcG9uZW50LFxuICAgIERpdmlkZXJDb21wb25lbnQsXG4gICAgTGlua0NvbXBvbmVudCxcbiAgXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8dmFsLWhlYWRlciBbcHJvcHNdPVwicHJvcHMuaGVhZGVyXCIgLz5cblxuICAgIDxpb24tY29udGVudCBbZnVsbHNjcmVlbl09XCJ0cnVlXCI+XG4gICAgICA8aW9uLWhlYWRlciBjb2xsYXBzZT1cImNvbmRlbnNlXCI+XG4gICAgICAgIDxpb24tdG9vbGJhcj5cbiAgICAgICAgICA8aW9uLXRpdGxlIHNpemU9XCJsYXJnZVwiPnt7IHByb3BzLnBhZ2VUaXRsZSB9fTwvaW9uLXRpdGxlPlxuICAgICAgICA8L2lvbi10b29sYmFyPlxuICAgICAgPC9pb24taGVhZGVyPlxuICAgICAgPGRpdiBjbGFzcz1cImRlc2NyaXB0aW9uLWNvbnRhaW5lclwiICpuZ0lmPVwicHJvcHMucGFnZURlc2NyaXB0aW9uXCI+XG4gICAgICAgIDxpb24tdGV4dD5cbiAgICAgICAgICA8cCBjbGFzcz1cImRlc2NyaXB0aW9uXCI+e3sgcHJvcHMucGFnZURlc2NyaXB0aW9uIH19PC9wPlxuICAgICAgICA8L2lvbi10ZXh0PlxuICAgICAgICA8dmFsLWxpbmsgKm5nSWY9XCJwcm9wcy5saW5rXCIgW3Byb3BzXT1cInByb3BzLmxpbmtcIiAob25DbGljayk9XCJvbkNsaWNrSGFuZGxlcigkZXZlbnQpXCI+PC92YWwtbGluaz5cbiAgICAgIDwvZGl2PlxuICAgICAgPHZhbC1kaXZpZGVyICpuZ0lmPVwicHJvcHMud2l0aERpdmlkZXJcIiBbcHJvcHNdPVwieyBmaWxsOiAnc29saWQnLCBzaXplOiAnbWVkaXVtJywgY29sb3I6ICdkYXJrJyB9XCIgLz5cbiAgICAgIDx2YWwtbGF5b3V0PlxuICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICA8L3ZhbC1sYXlvdXQ+XG4gICAgPC9pb24tY29udGVudD5cbiAgYCxcbiAgc3R5bGVVcmw6ICcuL3NpbXBsZS5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIFNpbXBsZUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIHByb3BzOiBTaW1wbGVNZXRhZGF0YTtcblxuICBAT3V0cHV0KClcbiAgb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xuXG4gIG9uQ2xpY2tIYW5kbGVyKHRva2VuPzogc3RyaW5nKSB7XG4gICAgdGhpcy5vbkNsaWNrLmVtaXQodG9rZW4pO1xuICB9XG59XG4iXX0=