valtech-components 2.0.56 → 2.0.57

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.
@@ -25,160 +25,158 @@ export class ItemListComponent {
25
25
  }
26
26
  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 }); }
27
27
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ItemListComponent, isStandalone: true, selector: "val-item-list", inputs: { props: "props" }, outputs: { onClick: "onClick", onActionClick: "onActionClick" }, ngImport: i0, template: `
28
- <div>
29
- <ion-list
30
- [inset]="props.rounded"
31
- [class.shadowed]="props.shadowed"
32
- [class.bordered]="props.bordered"
33
- [style.borderColor]="this.color()"
34
- >
28
+ <ion-list
29
+ [inset]="props.rounded"
30
+ [class.shadowed]="props.shadowed"
31
+ [class.bordered]="props.bordered"
32
+ [style.borderColor]="this.color()"
33
+ >
35
34
  @if (props.title) {
36
35
  <ion-list-header>
37
36
  <ion-label>{{ props.title }}</ion-label>
38
37
  </ion-list-header>
39
38
  }
40
- @for (item of props.items; track item.text) {
41
- @if (item.mode == 'justext') {
42
- <ion-item
43
- [lines]="item.lines"
44
- [button]="item.clickable"
45
- [disabled]="item.disabled"
46
- (click)="clickHandler(item.token)"
47
- >
48
- @if (item.unreadIndicator) {
49
- <div class="unread-indicator-wrapper" slot="start">
50
- <div class="unread-indicator"></div>
51
- </div>
39
+ @for (item of props.items; track item.text) {
40
+ @if (item.mode == 'justext') {
41
+ <ion-item
42
+ [lines]="item.lines"
43
+ [button]="item.clickable"
44
+ [disabled]="item.disabled"
45
+ (click)="clickHandler(item.token)"
46
+ >
47
+ @if (item.unreadIndicator) {
48
+ <div class="unread-indicator-wrapper" slot="start">
49
+ <div class="unread-indicator"></div>
50
+ </div>
51
+ }
52
+
53
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
54
+ <h2>{{ item.text }}</h2>
55
+
56
+ @if (item.comments) {
57
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
52
58
  }
59
+ </ion-label>
53
60
 
54
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
55
- <h2>{{ item.text }}</h2>
61
+ @if (item.endNote) {
62
+ <ion-note slot="end">{{ item.endNote }}</ion-note>
63
+ }
64
+ </ion-item>
65
+ }
56
66
 
57
- @if (item.comments) {
58
- <ion-note color="medium"> {{ item.comments }} </ion-note>
59
- }
60
- </ion-label>
67
+ @if (item.mode == 'actionable') {
68
+ <ion-item [lines]="item.lines" [button]="item.clickable" [disabled]="item.disabled">
69
+ @if (item.unreadIndicator) {
70
+ <div class="unread-indicator-wrapper" slot="start">
71
+ <div class="unread-indicator"></div>
72
+ </div>
73
+ }
61
74
 
62
- @if (item.endNote) {
63
- <ion-note slot="end">{{ item.endNote }}</ion-note>
64
- }
65
- </ion-item>
66
- }
67
-
68
- @if (item.mode == 'actionable') {
69
- <ion-item [lines]="item.lines" [button]="item.clickable" [disabled]="item.disabled">
70
- @if (item.unreadIndicator) {
71
- <div class="unread-indicator-wrapper" slot="start">
72
- <div class="unread-indicator"></div>
73
- </div>
74
- }
75
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
76
+ <h2>{{ item.text }}</h2>
75
77
 
76
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
77
- <h2>{{ item.text }}</h2>
78
-
79
- @if (item.comments) {
80
- <ion-note color="medium"> {{ item.comments }} </ion-note>
81
- }
82
- </ion-label>
83
-
84
- @if (item.actions) {
85
- @for (action of item.actions; track action.token) {
86
- <ion-button
87
- fill="outline"
88
- color="dark"
89
- slot="end"
90
- [disabled]="action.state === states.WORKING"
91
- (click)="onActionClickHandler(action.token)"
92
- >
93
- @if (action.state !== states.WORKING) {
94
- @if (action.icon) {
95
- <ion-icon aria-hidden="true" [name]="action.icon" size="medium" slot="start"></ion-icon>
96
- }
97
-
98
- {{ action.description }}
78
+ @if (item.comments) {
79
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
80
+ }
81
+ </ion-label>
82
+
83
+ @if (item.actions) {
84
+ @for (action of item.actions; track action.token) {
85
+ <ion-button
86
+ fill="outline"
87
+ color="dark"
88
+ slot="end"
89
+ [disabled]="action.state === states.WORKING"
90
+ (click)="onActionClickHandler(action.token)"
91
+ >
92
+ @if (action.state !== states.WORKING) {
93
+ @if (action.icon) {
94
+ <ion-icon aria-hidden="true" [name]="action.icon" size="medium" slot="start"></ion-icon>
99
95
  }
100
96
 
101
- @if (action.state === states.WORKING) {
102
- <ion-spinner class="action-spinner" name="circular"></ion-spinner>
103
- }
104
- </ion-button>
105
- }
106
- }
107
- </ion-item>
108
- }
109
-
110
- @if (item.mode == 'route') {
111
- <ion-item
112
- [lines]="item.lines"
113
- [button]="item.clickable"
114
- [disabled]="item.disabled"
115
- (click)="clickHandler(item.token)"
116
- [routerLink]="item.routerLink"
117
- >
118
- @if (item.unreadIndicator) {
119
- <div class="unread-indicator-wrapper" slot="start">
120
- <div class="unread-indicator"></div>
121
- </div>
97
+ {{ action.description }}
98
+ }
99
+
100
+ @if (action.state === states.WORKING) {
101
+ <ion-spinner class="action-spinner" name="circular"></ion-spinner>
102
+ }
103
+ </ion-button>
122
104
  }
105
+ }
106
+ </ion-item>
107
+ }
123
108
 
124
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
125
- <h2>{{ item.text }}</h2>
126
-
127
- @if (item.comments) {
128
- <ion-note color="medium"> {{ item.comments }} </ion-note>
129
- }
130
- </ion-label>
131
- </ion-item>
132
- }
133
-
134
- @if (item.mode == 'subtitule') {
135
- <ion-item
136
- [lines]="item.lines"
137
- [button]="item.clickable"
138
- [disabled]="item.disabled"
139
- (click)="clickHandler(item.token)"
140
- >
141
- @if (item.unreadIndicator) {
142
- <div class="unread-indicator-wrapper" slot="start">
143
- <div class="unread-indicator"></div>
144
- </div>
109
+ @if (item.mode == 'route') {
110
+ <ion-item
111
+ [lines]="item.lines"
112
+ [button]="item.clickable"
113
+ [disabled]="item.disabled"
114
+ (click)="clickHandler(item.token)"
115
+ [routerLink]="item.routerLink"
116
+ >
117
+ @if (item.unreadIndicator) {
118
+ <div class="unread-indicator-wrapper" slot="start">
119
+ <div class="unread-indicator"></div>
120
+ </div>
121
+ }
122
+
123
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
124
+ <h2>{{ item.text }}</h2>
125
+
126
+ @if (item.comments) {
127
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
145
128
  }
129
+ </ion-label>
130
+ </ion-item>
131
+ }
132
+
133
+ @if (item.mode == 'subtitule') {
134
+ <ion-item
135
+ [lines]="item.lines"
136
+ [button]="item.clickable"
137
+ [disabled]="item.disabled"
138
+ (click)="clickHandler(item.token)"
139
+ >
140
+ @if (item.unreadIndicator) {
141
+ <div class="unread-indicator-wrapper" slot="start">
142
+ <div class="unread-indicator"></div>
143
+ </div>
144
+ }
145
+
146
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
147
+ <h1>{{ item.text }}</h1>
148
+ <p>{{ item.subtitle }}</p>
149
+ </ion-label>
150
+ </ion-item>
151
+ }
146
152
 
147
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
148
- <h1>{{ item.text }}</h1>
149
- <p>{{ item.subtitle }}</p>
150
- </ion-label>
151
- </ion-item>
152
- }
153
-
154
- @if (item.mode == 'avatar') {
155
- <ion-item
156
- [lines]="item.lines"
157
- [button]="item.clickable"
158
- [disabled]="item.disabled"
159
- (click)="clickHandler(item.token)"
160
- >
161
- <ion-avatar aria-hidden="true" slot="start">
162
- <img alt="" [src]="item.image" />
163
- </ion-avatar>
164
- <ion-label>{{ item.text }}</ion-label>
165
- </ion-item>
166
- }
167
-
168
- @if (item.mode == 'icon') {
169
- <ion-item
170
- [lines]="item.lines"
171
- [button]="item.clickable"
172
- [disabled]="item.disabled"
173
- (click)="clickHandler(item.token)"
174
- >
175
- <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
176
- <ion-label>{{ item.text }}</ion-label>
177
- </ion-item>
178
- }
153
+ @if (item.mode == 'avatar') {
154
+ <ion-item
155
+ [lines]="item.lines"
156
+ [button]="item.clickable"
157
+ [disabled]="item.disabled"
158
+ (click)="clickHandler(item.token)"
159
+ >
160
+ <ion-avatar aria-hidden="true" slot="start">
161
+ <img alt="" [src]="item.image" />
162
+ </ion-avatar>
163
+ <ion-label>{{ item.text }}</ion-label>
164
+ </ion-item>
179
165
  }
180
- </ion-list>
181
- </div>
166
+
167
+ @if (item.mode == 'icon') {
168
+ <ion-item
169
+ [lines]="item.lines"
170
+ [button]="item.clickable"
171
+ [disabled]="item.disabled"
172
+ (click)="clickHandler(item.token)"
173
+ >
174
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
175
+ <ion-label>{{ item.text }}</ion-label>
176
+ </ion-item>
177
+ }
178
+ }
179
+ </ion-list>
182
180
  `, 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}.bordered{border:1px solid}.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"] }] }); }
183
181
  }
184
182
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ItemListComponent, decorators: [{
@@ -197,160 +195,158 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
197
195
  IonButton,
198
196
  IonSpinner,
199
197
  ], template: `
200
- <div>
201
- <ion-list
202
- [inset]="props.rounded"
203
- [class.shadowed]="props.shadowed"
204
- [class.bordered]="props.bordered"
205
- [style.borderColor]="this.color()"
206
- >
198
+ <ion-list
199
+ [inset]="props.rounded"
200
+ [class.shadowed]="props.shadowed"
201
+ [class.bordered]="props.bordered"
202
+ [style.borderColor]="this.color()"
203
+ >
207
204
  @if (props.title) {
208
205
  <ion-list-header>
209
206
  <ion-label>{{ props.title }}</ion-label>
210
207
  </ion-list-header>
211
208
  }
212
- @for (item of props.items; track item.text) {
213
- @if (item.mode == 'justext') {
214
- <ion-item
215
- [lines]="item.lines"
216
- [button]="item.clickable"
217
- [disabled]="item.disabled"
218
- (click)="clickHandler(item.token)"
219
- >
220
- @if (item.unreadIndicator) {
221
- <div class="unread-indicator-wrapper" slot="start">
222
- <div class="unread-indicator"></div>
223
- </div>
209
+ @for (item of props.items; track item.text) {
210
+ @if (item.mode == 'justext') {
211
+ <ion-item
212
+ [lines]="item.lines"
213
+ [button]="item.clickable"
214
+ [disabled]="item.disabled"
215
+ (click)="clickHandler(item.token)"
216
+ >
217
+ @if (item.unreadIndicator) {
218
+ <div class="unread-indicator-wrapper" slot="start">
219
+ <div class="unread-indicator"></div>
220
+ </div>
221
+ }
222
+
223
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
224
+ <h2>{{ item.text }}</h2>
225
+
226
+ @if (item.comments) {
227
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
224
228
  }
229
+ </ion-label>
225
230
 
226
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
227
- <h2>{{ item.text }}</h2>
231
+ @if (item.endNote) {
232
+ <ion-note slot="end">{{ item.endNote }}</ion-note>
233
+ }
234
+ </ion-item>
235
+ }
228
236
 
229
- @if (item.comments) {
230
- <ion-note color="medium"> {{ item.comments }} </ion-note>
231
- }
232
- </ion-label>
237
+ @if (item.mode == 'actionable') {
238
+ <ion-item [lines]="item.lines" [button]="item.clickable" [disabled]="item.disabled">
239
+ @if (item.unreadIndicator) {
240
+ <div class="unread-indicator-wrapper" slot="start">
241
+ <div class="unread-indicator"></div>
242
+ </div>
243
+ }
233
244
 
234
- @if (item.endNote) {
235
- <ion-note slot="end">{{ item.endNote }}</ion-note>
236
- }
237
- </ion-item>
238
- }
239
-
240
- @if (item.mode == 'actionable') {
241
- <ion-item [lines]="item.lines" [button]="item.clickable" [disabled]="item.disabled">
242
- @if (item.unreadIndicator) {
243
- <div class="unread-indicator-wrapper" slot="start">
244
- <div class="unread-indicator"></div>
245
- </div>
246
- }
245
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
246
+ <h2>{{ item.text }}</h2>
247
247
 
248
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
249
- <h2>{{ item.text }}</h2>
250
-
251
- @if (item.comments) {
252
- <ion-note color="medium"> {{ item.comments }} </ion-note>
253
- }
254
- </ion-label>
255
-
256
- @if (item.actions) {
257
- @for (action of item.actions; track action.token) {
258
- <ion-button
259
- fill="outline"
260
- color="dark"
261
- slot="end"
262
- [disabled]="action.state === states.WORKING"
263
- (click)="onActionClickHandler(action.token)"
264
- >
265
- @if (action.state !== states.WORKING) {
266
- @if (action.icon) {
267
- <ion-icon aria-hidden="true" [name]="action.icon" size="medium" slot="start"></ion-icon>
268
- }
269
-
270
- {{ action.description }}
248
+ @if (item.comments) {
249
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
250
+ }
251
+ </ion-label>
252
+
253
+ @if (item.actions) {
254
+ @for (action of item.actions; track action.token) {
255
+ <ion-button
256
+ fill="outline"
257
+ color="dark"
258
+ slot="end"
259
+ [disabled]="action.state === states.WORKING"
260
+ (click)="onActionClickHandler(action.token)"
261
+ >
262
+ @if (action.state !== states.WORKING) {
263
+ @if (action.icon) {
264
+ <ion-icon aria-hidden="true" [name]="action.icon" size="medium" slot="start"></ion-icon>
271
265
  }
272
266
 
273
- @if (action.state === states.WORKING) {
274
- <ion-spinner class="action-spinner" name="circular"></ion-spinner>
275
- }
276
- </ion-button>
277
- }
278
- }
279
- </ion-item>
280
- }
281
-
282
- @if (item.mode == 'route') {
283
- <ion-item
284
- [lines]="item.lines"
285
- [button]="item.clickable"
286
- [disabled]="item.disabled"
287
- (click)="clickHandler(item.token)"
288
- [routerLink]="item.routerLink"
289
- >
290
- @if (item.unreadIndicator) {
291
- <div class="unread-indicator-wrapper" slot="start">
292
- <div class="unread-indicator"></div>
293
- </div>
267
+ {{ action.description }}
268
+ }
269
+
270
+ @if (action.state === states.WORKING) {
271
+ <ion-spinner class="action-spinner" name="circular"></ion-spinner>
272
+ }
273
+ </ion-button>
294
274
  }
275
+ }
276
+ </ion-item>
277
+ }
295
278
 
296
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
297
- <h2>{{ item.text }}</h2>
298
-
299
- @if (item.comments) {
300
- <ion-note color="medium"> {{ item.comments }} </ion-note>
301
- }
302
- </ion-label>
303
- </ion-item>
304
- }
305
-
306
- @if (item.mode == 'subtitule') {
307
- <ion-item
308
- [lines]="item.lines"
309
- [button]="item.clickable"
310
- [disabled]="item.disabled"
311
- (click)="clickHandler(item.token)"
312
- >
313
- @if (item.unreadIndicator) {
314
- <div class="unread-indicator-wrapper" slot="start">
315
- <div class="unread-indicator"></div>
316
- </div>
279
+ @if (item.mode == 'route') {
280
+ <ion-item
281
+ [lines]="item.lines"
282
+ [button]="item.clickable"
283
+ [disabled]="item.disabled"
284
+ (click)="clickHandler(item.token)"
285
+ [routerLink]="item.routerLink"
286
+ >
287
+ @if (item.unreadIndicator) {
288
+ <div class="unread-indicator-wrapper" slot="start">
289
+ <div class="unread-indicator"></div>
290
+ </div>
291
+ }
292
+
293
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
294
+ <h2>{{ item.text }}</h2>
295
+
296
+ @if (item.comments) {
297
+ <ion-note color="medium"> {{ item.comments }} </ion-note>
317
298
  }
299
+ </ion-label>
300
+ </ion-item>
301
+ }
302
+
303
+ @if (item.mode == 'subtitule') {
304
+ <ion-item
305
+ [lines]="item.lines"
306
+ [button]="item.clickable"
307
+ [disabled]="item.disabled"
308
+ (click)="clickHandler(item.token)"
309
+ >
310
+ @if (item.unreadIndicator) {
311
+ <div class="unread-indicator-wrapper" slot="start">
312
+ <div class="unread-indicator"></div>
313
+ </div>
314
+ }
315
+
316
+ <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
317
+ <h1>{{ item.text }}</h1>
318
+ <p>{{ item.subtitle }}</p>
319
+ </ion-label>
320
+ </ion-item>
321
+ }
318
322
 
319
- <ion-label [ngClass]="{ 'ion-text-nowrap': item.ellipsis }">
320
- <h1>{{ item.text }}</h1>
321
- <p>{{ item.subtitle }}</p>
322
- </ion-label>
323
- </ion-item>
324
- }
325
-
326
- @if (item.mode == 'avatar') {
327
- <ion-item
328
- [lines]="item.lines"
329
- [button]="item.clickable"
330
- [disabled]="item.disabled"
331
- (click)="clickHandler(item.token)"
332
- >
333
- <ion-avatar aria-hidden="true" slot="start">
334
- <img alt="" [src]="item.image" />
335
- </ion-avatar>
336
- <ion-label>{{ item.text }}</ion-label>
337
- </ion-item>
338
- }
339
-
340
- @if (item.mode == 'icon') {
341
- <ion-item
342
- [lines]="item.lines"
343
- [button]="item.clickable"
344
- [disabled]="item.disabled"
345
- (click)="clickHandler(item.token)"
346
- >
347
- <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
348
- <ion-label>{{ item.text }}</ion-label>
349
- </ion-item>
350
- }
323
+ @if (item.mode == 'avatar') {
324
+ <ion-item
325
+ [lines]="item.lines"
326
+ [button]="item.clickable"
327
+ [disabled]="item.disabled"
328
+ (click)="clickHandler(item.token)"
329
+ >
330
+ <ion-avatar aria-hidden="true" slot="start">
331
+ <img alt="" [src]="item.image" />
332
+ </ion-avatar>
333
+ <ion-label>{{ item.text }}</ion-label>
334
+ </ion-item>
351
335
  }
352
- </ion-list>
353
- </div>
336
+
337
+ @if (item.mode == 'icon') {
338
+ <ion-item
339
+ [lines]="item.lines"
340
+ [button]="item.clickable"
341
+ [disabled]="item.disabled"
342
+ (click)="clickHandler(item.token)"
343
+ >
344
+ <ion-icon aria-hidden="true" [name]="item.icon" size="medium" slot="start"></ion-icon>
345
+ <ion-label>{{ item.text }}</ion-label>
346
+ </ion-item>
347
+ }
348
+ }
349
+ </ion-list>
354
350
  `, 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}.bordered{border:1px solid}.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"] }]
355
351
  }], ctorParameters: () => [{ type: i1.IconService }], propDecorators: { props: [{
356
352
  type: Input
@@ -359,4 +355,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
359
355
  }], onActionClick: [{
360
356
  type: Output
361
357
  }] } });
362
- //# 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;;;AAkL9C,MAAM,OAAO,iBAAiB;IAa5B,YAAY,IAAiB;QAZ7B,WAAM,GAAG,eAAe,CAAC;QACzB,iBAAY,GAAG,SAAS,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;IAED,KAAK;QACH,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;+GA3BU,iBAAiB;mGAAjB,iBAAiB,sKA9JlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2JT,kjBAxKC,UAAU,oOAEV,OAAO,oFACP,OAAO,yFACP,aAAa,gGACb,QAAQ,6FACR,OAAO,gFACP,OAAO,0NACP,SAAS,uDACT,OAAO,2JACP,SAAS,oPACT,UAAU;;4FAgKD,iBAAiB;kBA/K7B,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2JT;gFAQD,KAAK;sBADJ,KAAK;gBAIN,OAAO;sBADN,MAAM;gBAIP,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    <div>\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.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  defaultColor = 'primary';\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  color() {\n    return resolveColor(this.props.color || this.defaultColor);\n  }\n}\n"]}
358
+ //# 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;;;AAgL9C,MAAM,OAAO,iBAAiB;IAa5B,YAAY,IAAiB;QAZ7B,WAAM,GAAG,eAAe,CAAC;QACzB,iBAAY,GAAG,SAAS,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;IAED,KAAK;QACH,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;+GA3BU,iBAAiB;mGAAjB,iBAAiB,sKA5JlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyJT,kjBAtKC,UAAU,oOAEV,OAAO,oFACP,OAAO,yFACP,aAAa,gGACb,QAAQ,6FACR,OAAO,gFACP,OAAO,0NACP,SAAS,uDACT,OAAO,2JACP,SAAS,oPACT,UAAU;;4FA8JD,iBAAiB;kBA7K7B,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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyJT;gFAQD,KAAK;sBADJ,KAAK;gBAIN,OAAO;sBADN,MAAM;gBAIP,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.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  `,\n  styleUrls: ['./item-list.component.scss'],\n})\nexport class ItemListComponent implements OnInit {\n  states = ComponentStates;\n  defaultColor = 'primary';\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  color() {\n    return resolveColor(this.props.color || this.defaultColor);\n  }\n}\n"]}