valtech-components 2.0.32 → 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.
- package/esm2022/lib/components/atoms/avatar/avatar.component.mjs +3 -3
- package/esm2022/lib/components/atoms/icon/icon.component.mjs +8 -7
- package/esm2022/lib/components/molecules/button-group/button-group.component.mjs +3 -3
- package/esm2022/lib/components/molecules/card/card.component.mjs +5 -5
- package/esm2022/lib/components/organisms/item-list/item-list.component.mjs +342 -0
- package/esm2022/lib/components/organisms/no-content/no-content.component.mjs +14 -4
- package/esm2022/lib/components/organisms/no-content/types.mjs +1 -1
- package/esm2022/lib/components/organisms/wizard/wizard.component.mjs +3 -3
- package/esm2022/lib/components/templates/layout/layout.component.mjs +2 -2
- package/esm2022/lib/components/templates/simple/simple.component.mjs +3 -3
- package/esm2022/lib/services/icons.service.mjs +30 -0
- package/esm2022/public-api.mjs +5 -3
- package/fesm2022/valtech-components.mjs +399 -28
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/atoms/icon/icon.component.d.ts +2 -1
- package/lib/components/organisms/item-list/item-list.component.d.ts +57 -0
- package/lib/components/organisms/no-content/types.d.ts +2 -1
- package/lib/services/icons.service.d.ts +6 -0
- package/package.json +2 -1
- package/public-api.d.ts +4 -2
- package/src/lib/components/styles/variables.scss +1 -1
|
@@ -11,7 +11,7 @@ export class AvatarComponent {
|
|
|
11
11
|
}
|
|
12
12
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
13
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AvatarComponent, isStandalone: true, selector: "val-avatar", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: `
|
|
14
|
-
<ion-avatar [class]="props.size" [class.box]="props.box" (click)="onClickHandler()">
|
|
14
|
+
<ion-avatar aria-hidden="true" [class]="props.size" [class.box]="props.box" (click)="onClickHandler()">
|
|
15
15
|
<img alt="profile image" [src]="props.image || props.default" />
|
|
16
16
|
</ion-avatar>
|
|
17
17
|
`, isInline: true, styles: [".box{--border-radius: pxToRem(4)}.small{width:1.75rem;height:1.75rem}.medium{width:2.375rem;height:2.375rem}.large{width:3rem;height:3rem}\n"], dependencies: [{ kind: "component", type: IonAvatar, selector: "ion-avatar" }] }); }
|
|
@@ -19,7 +19,7 @@ export class AvatarComponent {
|
|
|
19
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AvatarComponent, decorators: [{
|
|
20
20
|
type: Component,
|
|
21
21
|
args: [{ selector: 'val-avatar', standalone: true, imports: [IonAvatar], template: `
|
|
22
|
-
<ion-avatar [class]="props.size" [class.box]="props.box" (click)="onClickHandler()">
|
|
22
|
+
<ion-avatar aria-hidden="true" [class]="props.size" [class.box]="props.box" (click)="onClickHandler()">
|
|
23
23
|
<img alt="profile image" [src]="props.image || props.default" />
|
|
24
24
|
</ion-avatar>
|
|
25
25
|
`, styles: [".box{--border-radius: pxToRem(4)}.small{width:1.75rem;height:1.75rem}.medium{width:2.375rem;height:2.375rem}.large{width:3rem;height:3rem}\n"] }]
|
|
@@ -28,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
28
28
|
}], onClick: [{
|
|
29
29
|
type: Output
|
|
30
30
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvYXRvbXMvYXZhdGFyL2F2YXRhci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBY3RELE1BQU0sT0FBTyxlQUFlO0lBTTFCO1FBRkEsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7SUFFZCxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDO0lBRWIsY0FBYztRQUNaLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdEIsQ0FBQzsrR0FaVSxlQUFlO21HQUFmLGVBQWUsbUlBUGhCOzs7O0dBSVQsc05BTFMsU0FBUzs7NEZBUVIsZUFBZTtrQkFYM0IsU0FBUzsrQkFDRSxZQUFZLGNBQ1YsSUFBSSxXQUNQLENBQUMsU0FBUyxDQUFDLFlBQ1Y7Ozs7R0FJVDt3REFJUSxLQUFLO3NCQUFiLEtBQUs7Z0JBR04sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW9uQXZhdGFyIH0gZnJvbSAnQGlvbmljL2FuZ3VsYXIvc3RhbmRhbG9uZSc7XG5pbXBvcnQgeyBBdmF0YXJNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtYXZhdGFyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0lvbkF2YXRhcl0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGlvbi1hdmF0YXIgYXJpYS1oaWRkZW49XCJ0cnVlXCIgW2NsYXNzXT1cInByb3BzLnNpemVcIiBbY2xhc3MuYm94XT1cInByb3BzLmJveFwiIChjbGljayk9XCJvbkNsaWNrSGFuZGxlcigpXCI+XG4gICAgICA8aW1nIGFsdD1cInByb2ZpbGUgaW1hZ2VcIiBbc3JjXT1cInByb3BzLmltYWdlIHx8IHByb3BzLmRlZmF1bHRcIiAvPlxuICAgIDwvaW9uLWF2YXRhcj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vYXZhdGFyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEF2YXRhckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIHByb3BzOiBBdmF0YXJNZXRhZGF0YTtcblxuICBAT3V0cHV0KClcbiAgb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxuXG4gIG9uQ2xpY2tIYW5kbGVyKCkge1xuICAgIHRoaXMub25DbGljay5lbWl0KCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -2,17 +2,18 @@ import { CommonModule } from '@angular/common';
|
|
|
2
2
|
import { Component, Input } from '@angular/core';
|
|
3
3
|
import { IonIcon } from '@ionic/angular/standalone';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "
|
|
5
|
+
import * as i1 from "../../../services/icons.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
6
7
|
export class IconComponent {
|
|
7
|
-
constructor() { }
|
|
8
|
+
constructor(service) { }
|
|
8
9
|
ngOnInit() { }
|
|
9
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: IconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: IconComponent, isStandalone: true, selector: "val-icon", inputs: { props: "props" }, ngImport: i0, template: ` <ion-icon [ngClass]="[props.size]" [name]="props.name" [color]="props.color"
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: IconComponent, deps: [{ token: i1.IconService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: IconComponent, isStandalone: true, selector: "val-icon", inputs: { props: "props" }, ngImport: i0, template: ` <ion-icon aria-hidden="true" [ngClass]="[props.size]" [name]="props.name" [color]="props.color" /> `, isInline: true, styles: [".small{font-size:.75rem;line-height:1.25rem;font-weight:400}.small.bold{font-size:.75rem;line-height:1.25rem;font-weight:700}.medium{font-size:.875rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.medium{font-size:1rem;line-height:1.5rem}}.medium.bold{font-size:.875rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.medium.bold{font-size:1rem;line-height:1.5rem}}.large{font-size:1rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.large{font-size:1.125rem;line-height:1.5rem}}.large.bold{font-size:1rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.large.bold{font-size:1.125rem;line-height:1.5rem}}.xlarge{font-size:1.125rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.xlarge{font-size:1.5rem;line-height:2rem}}.xlarge.bold{font-size:1.125rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.xlarge.bold{font-size:1.5rem;line-height:2rem}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
|
|
11
12
|
}
|
|
12
13
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: IconComponent, decorators: [{
|
|
13
14
|
type: Component,
|
|
14
|
-
args: [{ selector: 'val-icon', standalone: true, imports: [CommonModule, IonIcon], template: ` <ion-icon [ngClass]="[props.size]" [name]="props.name" [color]="props.color"
|
|
15
|
-
}], ctorParameters: () => [], propDecorators: { props: [{
|
|
15
|
+
args: [{ selector: 'val-icon', standalone: true, imports: [CommonModule, IonIcon], template: ` <ion-icon aria-hidden="true" [ngClass]="[props.size]" [name]="props.name" [color]="props.color" /> `, styles: [".small{font-size:.75rem;line-height:1.25rem;font-weight:400}.small.bold{font-size:.75rem;line-height:1.25rem;font-weight:700}.medium{font-size:.875rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.medium{font-size:1rem;line-height:1.5rem}}.medium.bold{font-size:.875rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.medium.bold{font-size:1rem;line-height:1.5rem}}.large{font-size:1rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.large{font-size:1.125rem;line-height:1.5rem}}.large.bold{font-size:1rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.large.bold{font-size:1.125rem;line-height:1.5rem}}.xlarge{font-size:1.125rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.xlarge{font-size:1.5rem;line-height:2rem}}.xlarge.bold{font-size:1.125rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.xlarge.bold{font-size:1.5rem;line-height:2rem}}\n"] }]
|
|
16
|
+
}], ctorParameters: () => [{ type: i1.IconService }], propDecorators: { props: [{
|
|
16
17
|
type: Input
|
|
17
18
|
}] } });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2F0b21zL2ljb24vaWNvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7OztBQVdwRCxNQUFNLE9BQU8sYUFBYTtJQUl4QixZQUFZLE9BQW9CLElBQUcsQ0FBQztJQUVwQyxRQUFRLEtBQUksQ0FBQzsrR0FORixhQUFhO21HQUFiLGFBQWEsZ0dBSGQsc0dBQXNHLGsvQkFEdEcsWUFBWSw2SEFBRSxPQUFPOzs0RkFJcEIsYUFBYTtrQkFQekIsU0FBUzsrQkFDRSxVQUFVLGNBQ1IsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLE9BQU8sQ0FBQyxZQUN0QixzR0FBc0c7Z0ZBS2hILEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElvbkljb24gfSBmcm9tICdAaW9uaWMvYW5ndWxhci9zdGFuZGFsb25lJztcbmltcG9ydCB7IEljb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvaWNvbnMuc2VydmljZSc7XG5pbXBvcnQgeyBJY29uTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWljb24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBJb25JY29uXSxcbiAgdGVtcGxhdGU6IGAgPGlvbi1pY29uIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIFtuZ0NsYXNzXT1cIltwcm9wcy5zaXplXVwiIFtuYW1lXT1cInByb3BzLm5hbWVcIiBbY29sb3JdPVwicHJvcHMuY29sb3JcIiAvPiBgLFxuICBzdHlsZVVybHM6IFsnLi9pY29uLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEljb25Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBwcm9wczogSWNvbk1ldGFkYXRhO1xuXG4gIGNvbnN0cnVjdG9yKHNlcnZpY2U6IEljb25TZXJ2aWNlKSB7fVxuXG4gIG5nT25Jbml0KCkge31cbn1cbiJdfQ==
|
|
@@ -23,7 +23,7 @@ export class ButtonGroupComponent {
|
|
|
23
23
|
<val-button
|
|
24
24
|
*ngFor="let b of props.buttons"
|
|
25
25
|
[props]="b"
|
|
26
|
-
(
|
|
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
|
-
(
|
|
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,
|
|
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
|
-
(
|
|
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
|
-
(
|
|
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
|
-
(
|
|
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
|
-
(
|
|
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"]}
|