c3-components 0.8.4 → 0.8.6

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.
@@ -11,10 +11,12 @@ import { C3PromptDialogComponent } from './components/c3-dialog-prompt.component
11
11
  import { C3DialogService } from './services/c3-dialog.service';
12
12
  import { MatToolbarModule } from '@angular/material/toolbar';
13
13
  import { MatIconModule } from '@angular/material/icon';
14
+ import { C3AlertDialogComponent } from './components/c3-dialog-alert.component';
14
15
  import * as i0 from "@angular/core";
15
16
  export class C3DialogModule {
16
17
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3DialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
17
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.1", ngImport: i0, type: C3DialogModule, declarations: [ConfirmDialogComponent,
18
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.1", ngImport: i0, type: C3DialogModule, declarations: [C3AlertDialogComponent,
19
+ ConfirmDialogComponent,
18
20
  C3PromptDialogComponent,
19
21
  C3DialogEmbedChildComponent], imports: [CommonModule,
20
22
  FormsModule,
@@ -39,6 +41,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
39
41
  type: NgModule,
40
42
  args: [{
41
43
  declarations: [
44
+ C3AlertDialogComponent,
42
45
  ConfirmDialogComponent,
43
46
  C3PromptDialogComponent,
44
47
  C3DialogEmbedChildComponent,
@@ -57,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
57
60
  providers: [C3DialogService],
58
61
  }]
59
62
  }] });
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1kaWFsb2cvYzMtZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDM0YsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFxQnZELE1BQU0sT0FBTyxjQUFjOzhHQUFkLGNBQWM7K0dBQWQsY0FBYyxpQkFqQnZCLHNCQUFzQjtZQUN0Qix1QkFBdUI7WUFDdkIsMkJBQTJCLGFBRzNCLFlBQVk7WUFDWixXQUFXO1lBQ1gsZUFBZTtZQUNmLGVBQWU7WUFDZixrQkFBa0I7WUFDbEIsYUFBYTtZQUNiLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsbUJBQW1COytHQUlWLGNBQWMsYUFGZCxDQUFDLGVBQWUsQ0FBQyxZQVYxQixZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWU7WUFDZixlQUFlO1lBQ2Ysa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixjQUFjO1lBQ2QsZ0JBQWdCO1lBQ2hCLG1CQUFtQjs7MkZBSVYsY0FBYztrQkFuQjFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3dCQUN2QiwyQkFBMkI7cUJBQzVCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGtCQUFrQjt3QkFDbEIsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsbUJBQW1CO3FCQUNwQjtvQkFDRCxTQUFTLEVBQUUsQ0FBQyxlQUFlLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IENvbmZpcm1EaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50JztcbmltcG9ydCB7IEMzRGlhbG9nRW1iZWRDaGlsZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1kaWFsb2ctZW1iZWQtY2hpbGQuY29tcG9uZW50JztcbmltcG9ydCB7IEMzUHJvbXB0RGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWRpYWxvZy1wcm9tcHQuY29tcG9uZW50JztcbmltcG9ydCB7IEMzRGlhbG9nU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvYzMtZGlhbG9nLnNlcnZpY2UnO1xuaW1wb3J0IHsgTWF0VG9vbGJhck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2xiYXInO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBDb25maXJtRGlhbG9nQ29tcG9uZW50LFxuICAgIEMzUHJvbXB0RGlhbG9nQ29tcG9uZW50LFxuICAgIEMzRGlhbG9nRW1iZWRDaGlsZENvbXBvbmVudCxcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0RGlhbG9nTW9kdWxlLFxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIE1hdFRvb2xiYXJNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbQzNEaWFsb2dTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgQzNEaWFsb2dNb2R1bGUge31cbiJdfQ==
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1kaWFsb2cvYzMtZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDM0YsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQzs7QUFzQmhGLE1BQU0sT0FBTyxjQUFjOzhHQUFkLGNBQWM7K0dBQWQsY0FBYyxpQkFsQnZCLHNCQUFzQjtZQUN0QixzQkFBc0I7WUFDdEIsdUJBQXVCO1lBQ3ZCLDJCQUEyQixhQUczQixZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWU7WUFDZixlQUFlO1lBQ2Ysa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixjQUFjO1lBQ2QsZ0JBQWdCO1lBQ2hCLG1CQUFtQjsrR0FJVixjQUFjLGFBRmQsQ0FBQyxlQUFlLENBQUMsWUFWMUIsWUFBWTtZQUNaLFdBQVc7WUFDWCxlQUFlO1lBQ2YsZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixhQUFhO1lBQ2IsY0FBYztZQUNkLGdCQUFnQjtZQUNoQixtQkFBbUI7OzJGQUlWLGNBQWM7a0JBcEIxQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixzQkFBc0I7d0JBQ3RCLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3dCQUN2QiwyQkFBMkI7cUJBQzVCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGtCQUFrQjt3QkFDbEIsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsbUJBQW1CO3FCQUNwQjtvQkFDRCxTQUFTLEVBQUUsQ0FBQyxlQUFlLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IENvbmZpcm1EaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50JztcbmltcG9ydCB7IEMzRGlhbG9nRW1iZWRDaGlsZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1kaWFsb2ctZW1iZWQtY2hpbGQuY29tcG9uZW50JztcbmltcG9ydCB7IEMzUHJvbXB0RGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWRpYWxvZy1wcm9tcHQuY29tcG9uZW50JztcbmltcG9ydCB7IEMzRGlhbG9nU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvYzMtZGlhbG9nLnNlcnZpY2UnO1xuaW1wb3J0IHsgTWF0VG9vbGJhck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2xiYXInO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgQzNBbGVydERpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1kaWFsb2ctYWxlcnQuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQzNBbGVydERpYWxvZ0NvbXBvbmVudCxcbiAgICBDb25maXJtRGlhbG9nQ29tcG9uZW50LFxuICAgIEMzUHJvbXB0RGlhbG9nQ29tcG9uZW50LFxuICAgIEMzRGlhbG9nRW1iZWRDaGlsZENvbXBvbmVudCxcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0RGlhbG9nTW9kdWxlLFxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIE1hdFRvb2xiYXJNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbQzNEaWFsb2dTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgQzNEaWFsb2dNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,45 @@
1
+ import { Component, Inject } from '@angular/core';
2
+ import { MAT_DIALOG_DATA } from '@angular/material/dialog';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/material/dialog";
5
+ import * as i2 from "@angular/material/button";
6
+ export class C3AlertDialogComponent {
7
+ constructor(dialogRef, data) {
8
+ this.dialogRef = dialogRef;
9
+ this.data = data;
10
+ }
11
+ onNoClick() {
12
+ this.dialogRef.close();
13
+ }
14
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3AlertDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
15
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: C3AlertDialogComponent, selector: "AlertDialogComponent", ngImport: i0, template: `
16
+ <mat-dialog-content>
17
+ <div [innerHtml]="data.text"></div>
18
+ </mat-dialog-content>
19
+ <mat-dialog-actions>
20
+ <button mat-button [mat-dialog-close]="true">
21
+ {{ data.acceptText || 'ok' }}
22
+ </button>
23
+ </mat-dialog-actions>
24
+ `, isInline: true, dependencies: [{ kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] }); }
25
+ }
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3AlertDialogComponent, decorators: [{
27
+ type: Component,
28
+ args: [{
29
+ selector: 'AlertDialogComponent',
30
+ template: `
31
+ <mat-dialog-content>
32
+ <div [innerHtml]="data.text"></div>
33
+ </mat-dialog-content>
34
+ <mat-dialog-actions>
35
+ <button mat-button [mat-dialog-close]="true">
36
+ {{ data.acceptText || 'ok' }}
37
+ </button>
38
+ </mat-dialog-actions>
39
+ `,
40
+ }]
41
+ }], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
42
+ type: Inject,
43
+ args: [MAT_DIALOG_DATA]
44
+ }] }] });
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZGlhbG9nLWFsZXJ0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1kaWFsb2cvY29tcG9uZW50cy9jMy1kaWFsb2ctYWxlcnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBZ0IsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7QUFxQnpFLE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsWUFDUyxTQUErQyxFQUUvQyxJQUFpQjtRQUZqQixjQUFTLEdBQVQsU0FBUyxDQUFzQztRQUUvQyxTQUFJLEdBQUosSUFBSSxDQUFhO0lBQ3ZCLENBQUM7SUFFSixTQUFTO1FBQ1AsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN6QixDQUFDOzhHQVRVLHNCQUFzQiw4Q0FHdkIsZUFBZTtrR0FIZCxzQkFBc0IsNERBWHZCOzs7Ozs7Ozs7R0FTVDs7MkZBRVUsc0JBQXNCO2tCQWJsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFFBQVEsRUFBRTs7Ozs7Ozs7O0dBU1Q7aUJBQ0Y7OzBCQUlJLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXREaWFsb2dSZWYsIE1BVF9ESUFMT0dfREFUQSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWxlcnRDb25maWcge1xuICB0ZXh0OiBzdHJpbmc7XG4gIHdpZHRoPzogc3RyaW5nO1xuICBhY2NlcHRUZXh0Pzogc3RyaW5nO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdBbGVydERpYWxvZ0NvbXBvbmVudCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPG1hdC1kaWFsb2ctY29udGVudD5cbiAgICAgIDxkaXYgW2lubmVySHRtbF09XCJkYXRhLnRleHRcIj48L2Rpdj5cbiAgICA8L21hdC1kaWFsb2ctY29udGVudD5cbiAgICA8bWF0LWRpYWxvZy1hY3Rpb25zPlxuICAgICAgPGJ1dHRvbiBtYXQtYnV0dG9uIFttYXQtZGlhbG9nLWNsb3NlXT1cInRydWVcIj5cbiAgICAgICAge3sgZGF0YS5hY2NlcHRUZXh0IHx8ICdvaycgfX1cbiAgICAgIDwvYnV0dG9uPlxuICAgIDwvbWF0LWRpYWxvZy1hY3Rpb25zPlxuICBgLFxufSlcbmV4cG9ydCBjbGFzcyBDM0FsZXJ0RGlhbG9nQ29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPEMzQWxlcnREaWFsb2dDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKVxuICAgIHB1YmxpYyBkYXRhOiBBbGVydENvbmZpZ1xuICApIHt9XG5cbiAgb25Ob0NsaWNrKCk6IHZvaWQge1xuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XG4gIH1cbn1cbiJdfQ==
@@ -5,6 +5,7 @@ import { C3PromptDialogComponent, } from '../components/c3-dialog-prompt.compone
5
5
  import 'reflect-metadata';
6
6
  import { C3DialogEmbedChildComponent } from '../components/c3-dialog-embed-child.component';
7
7
  import { Subject } from 'rxjs';
8
+ import { C3AlertDialogComponent, } from '../components/c3-dialog-alert.component';
8
9
  import * as i0 from "@angular/core";
9
10
  export class C3DialogService {
10
11
  constructor() {
@@ -101,6 +102,15 @@ export class C3DialogService {
101
102
  });
102
103
  return this.createC3DialogResult(dialog);
103
104
  }
105
+ alert(text, data) {
106
+ const dialogRef = this.#dialog.open(C3AlertDialogComponent, {
107
+ data: {
108
+ ...data,
109
+ text,
110
+ },
111
+ });
112
+ return dialogRef.afterClosed();
113
+ }
104
114
  createC3DialogResult(dialog) {
105
115
  const _afterComponentMounted = new Subject();
106
116
  const result = {
@@ -145,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
145
155
  providedIn: 'root',
146
156
  }]
147
157
  }] });
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c3-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-dialog/services/c3-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  Injectable,\n  Injector,\n  Type,\n  effect,\n  inject,\n} from '@angular/core';\nimport {\n  MatDialog,\n  MatDialogConfig,\n  MatDialogContainer,\n  MatDialogRef,\n  MatDialogState,\n} from '@angular/material/dialog';\nimport {\n  ConfirmConfig,\n  ConfirmDialogComponent,\n} from '../components/c3-dialog-confirm.component';\nimport {\n  PromptConfig,\n  C3PromptDialogComponent,\n} from '../components/c3-dialog-prompt.component';\nimport { ComponentType } from '@angular/cdk/portal';\nimport 'reflect-metadata';\nimport { C3DialogEmbedChildComponent } from '../components/c3-dialog-embed-child.component';\nimport { Observable, Subject } from 'rxjs';\n\nexport type C3CreateDialogFromComponentConfig<C> = MatDialogConfig<\n  Partial<Record<keyof C, unknown>>\n> & {\n  component: ComponentType<C>;\n  toolbar?: {\n    title: string;\n    closeBtn?: boolean;\n    closeColor?: string;\n    color?: string;\n  };\n};\n\nexport type C3CreateDialogFromComponentResult<C> = {\n  _containerInstance: MatDialogContainer;\n  rootComponentRef: ComponentRef<C3DialogEmbedChildComponent<C>> | null;\n  rootComponentInstance: C3DialogEmbedChildComponent<C>;\n  componentRef: ComponentRef<C> | null;\n  componentInstance: C | undefined;\n  id: string;\n  disableClose: boolean;\n  close: (dialogResult?: C) => void;\n  afterClosed: () => Observable<C | null>;\n  afterOpened: () => Observable<void>;\n  beforeClosed: () => Observable<C | null>;\n  backdropClick: () => Observable<MouseEvent>;\n  getState: () => MatDialogState;\n  keydownEvents: () => Observable<KeyboardEvent>;\n  updateSize: () => void;\n  updatePosition: () => void;\n  addPanelClass: (className: string) => void;\n  removePanelClass: (className: string) => void;\n  afterComponentMounted: () => Observable<C3CreateDialogFromComponentResult<C>>;\n};\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class C3DialogService {\n  readonly #dialog = inject(MatDialog);\n  private readonly _injector = inject(Injector);\n\n  /**\n   * Opens a confirm dialog and returns a promise that resolves to a boolean indicating whether the user accepted or rejected the confirmation.\n   *\n   * @param {ConfirmConfig} data Configuration options for the confirm dialog. See ConfirmConfig below.\n   * @returns {C3ExtendedPromise<boolean>} A promise that resolves to `true` if the user accepted the confirmation, and `false` otherwise.\n   */\n  public confirm(data: ConfirmConfig) {\n    const dialogRef = this.#dialog.open(ConfirmDialogComponent, {\n      width: data.width || '250px',\n      data: {\n        text: data.text,\n        reject: {\n          color:\n            data.reject && data.reject.color ? data.reject.color : undefined,\n          text: (data.reject && data.reject.text) || 'Annuler',\n        },\n        accept: {\n          color: (data.accept && data.accept.color) || 'primary',\n          text: (data.accept && data.accept.text) || 'Accepter',\n        },\n      },\n    });\n\n    return new Promise<boolean>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          resolve(value);\n        },\n        error: reject,\n      });\n    });\n  }\n\n  /**\n   * Opens a prompt dialog and returns a promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   *\n   * @param {PromptConfig} data Configuration options for the prompt dialog. See PromptConfig below.\n   * @returns {C3ExtendedPromise<false | T>} A promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   */\n  public prompt(data: PromptConfig): Promise<false | string> {\n    const dialogRef = this.#dialog.open<C3PromptDialogComponent, any, string>(\n      C3PromptDialogComponent,\n      {\n        width: data.width || '250px',\n        maxWidth: data.maxWidth || '100vw',\n        data: {\n          text: data.text,\n          defaultValue: data.defaultValue,\n          placeholder: data.placeholder,\n          multiline: data.multiline,\n          validators: data.validators,\n          required: data.required,\n          reject: {\n            color:\n              data.reject && data.reject.color ? data.reject.color : undefined,\n            text: (data.reject && data.reject.text) || 'Annuler',\n          },\n          accept: {\n            color: (data.accept && data.accept.color) || 'primary',\n            text: (data.accept && data.accept.text) || 'Accepter',\n          },\n        },\n      },\n    );\n\n    return new Promise<string | false>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          if (value === undefined) {\n            resolve(false);\n          } else {\n            resolve(value);\n          }\n        },\n        error: reject,\n      });\n    });\n  }\n\n  /**\n   * Opens a dialog with the provided component and inputs.\n   * @param {C3CreateDialogFromComponentConfig<C>} config Configuration options for the dialog. See MatDialogConfig below.\n   * @returns {MatDialogRef<C> & {component: ComponentRef<C> | undefined}} The dialog reference.\n   */\n  createDialogFromComponent<C>({\n    component,\n    toolbar,\n    data,\n    ...config\n  }: C3CreateDialogFromComponentConfig<C>) {\n    if (!component) throw new Error('No component provided');\n\n    const dialog = this.#dialog.open(C3DialogEmbedChildComponent<C>, {\n      ...config,\n      data: {\n        component,\n        toolbar,\n        inputs: data,\n      },\n    });\n\n    return this.createC3DialogResult(dialog);\n  }\n\n  private createC3DialogResult<C>(\n    dialog: MatDialogRef<C3DialogEmbedChildComponent<C>>,\n  ) {\n    const _afterComponentMounted = new Subject<\n      C3CreateDialogFromComponentResult<C>\n    >();\n\n    const result: C3CreateDialogFromComponentResult<C> = {\n      _containerInstance: dialog._containerInstance,\n      rootComponentRef: dialog.componentRef,\n      rootComponentInstance: dialog.componentInstance,\n      componentRef: dialog.componentInstance.createdComponent(),\n      componentInstance: dialog.componentInstance.createdComponent()?.instance,\n      id: dialog.id,\n      disableClose: dialog.disableClose || false,\n      close: dialog.close.bind(dialog),\n      afterClosed: dialog.afterClosed.bind(dialog),\n      afterOpened: dialog.afterOpened.bind(dialog),\n      beforeClosed: dialog.beforeClosed.bind(dialog),\n      backdropClick: dialog.backdropClick.bind(dialog),\n      getState: dialog.getState.bind(dialog),\n      keydownEvents: dialog.keydownEvents.bind(dialog),\n      updateSize: dialog.updateSize.bind(dialog),\n      updatePosition: dialog.updatePosition.bind(dialog),\n      addPanelClass: dialog.addPanelClass.bind(dialog),\n      removePanelClass: dialog.removePanelClass.bind(dialog),\n      afterComponentMounted: () => _afterComponentMounted.asObservable(),\n    };\n\n    effect(\n      () => {\n        if (dialog.componentInstance.createdComponent()) {\n          result.componentRef = dialog.componentInstance.createdComponent();\n          result.componentInstance =\n            dialog.componentInstance.createdComponent()?.instance;\n          _afterComponentMounted.next(result);\n        }\n      },\n      {\n        injector: this._injector,\n      },\n    );\n\n    return result;\n  }\n}\n"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c3-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-dialog/services/c3-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  Injectable,\n  Injector,\n  effect,\n  inject,\n} from '@angular/core';\nimport {\n  MatDialog,\n  MatDialogConfig,\n  MatDialogContainer,\n  MatDialogRef,\n  MatDialogState,\n} from '@angular/material/dialog';\nimport {\n  ConfirmConfig,\n  ConfirmDialogComponent,\n} from '../components/c3-dialog-confirm.component';\nimport {\n  PromptConfig,\n  C3PromptDialogComponent,\n} from '../components/c3-dialog-prompt.component';\nimport { ComponentType } from '@angular/cdk/portal';\nimport 'reflect-metadata';\nimport { C3DialogEmbedChildComponent } from '../components/c3-dialog-embed-child.component';\nimport { Observable, Subject } from 'rxjs';\nimport {\n  AlertConfig,\n  C3AlertDialogComponent,\n} from '../components/c3-dialog-alert.component';\n\nexport type C3CreateDialogFromComponentConfig<C> = MatDialogConfig<\n  Partial<Record<keyof C, unknown>>\n> & {\n  component: ComponentType<C>;\n  toolbar?: {\n    title: string;\n    closeBtn?: boolean;\n    closeColor?: string;\n    color?: string;\n  };\n};\n\nexport type C3CreateDialogFromComponentResult<C> = {\n  _containerInstance: MatDialogContainer;\n  rootComponentRef: ComponentRef<C3DialogEmbedChildComponent<C>> | null;\n  rootComponentInstance: C3DialogEmbedChildComponent<C>;\n  componentRef: ComponentRef<C> | null;\n  componentInstance: C | undefined;\n  id: string;\n  disableClose: boolean;\n  close: (dialogResult?: C) => void;\n  afterClosed: () => Observable<C | null>;\n  afterOpened: () => Observable<void>;\n  beforeClosed: () => Observable<C | null>;\n  backdropClick: () => Observable<MouseEvent>;\n  getState: () => MatDialogState;\n  keydownEvents: () => Observable<KeyboardEvent>;\n  updateSize: () => void;\n  updatePosition: () => void;\n  addPanelClass: (className: string) => void;\n  removePanelClass: (className: string) => void;\n  afterComponentMounted: () => Observable<C3CreateDialogFromComponentResult<C>>;\n};\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class C3DialogService {\n  readonly #dialog = inject(MatDialog);\n  private readonly _injector = inject(Injector);\n\n  /**\n   * Opens a confirm dialog and returns a promise that resolves to a boolean indicating whether the user accepted or rejected the confirmation.\n   *\n   * @param {ConfirmConfig} data Configuration options for the confirm dialog. See ConfirmConfig below.\n   * @returns {C3ExtendedPromise<boolean>} A promise that resolves to `true` if the user accepted the confirmation, and `false` otherwise.\n   */\n  public confirm(data: ConfirmConfig) {\n    const dialogRef = this.#dialog.open(ConfirmDialogComponent, {\n      width: data.width || '250px',\n      data: {\n        text: data.text,\n        reject: {\n          color:\n            data.reject && data.reject.color ? data.reject.color : undefined,\n          text: (data.reject && data.reject.text) || 'Annuler',\n        },\n        accept: {\n          color: (data.accept && data.accept.color) || 'primary',\n          text: (data.accept && data.accept.text) || 'Accepter',\n        },\n      },\n    });\n\n    return new Promise<boolean>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          resolve(value);\n        },\n        error: reject,\n      });\n    });\n  }\n\n  /**\n   * Opens a prompt dialog and returns a promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   *\n   * @param {PromptConfig} data Configuration options for the prompt dialog. See PromptConfig below.\n   * @returns {C3ExtendedPromise<false | T>} A promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   */\n  public prompt(data: PromptConfig): Promise<false | string> {\n    const dialogRef = this.#dialog.open<C3PromptDialogComponent, any, string>(\n      C3PromptDialogComponent,\n      {\n        width: data.width || '250px',\n        maxWidth: data.maxWidth || '100vw',\n        data: {\n          text: data.text,\n          defaultValue: data.defaultValue,\n          placeholder: data.placeholder,\n          multiline: data.multiline,\n          validators: data.validators,\n          required: data.required,\n          reject: {\n            color:\n              data.reject && data.reject.color ? data.reject.color : undefined,\n            text: (data.reject && data.reject.text) || 'Annuler',\n          },\n          accept: {\n            color: (data.accept && data.accept.color) || 'primary',\n            text: (data.accept && data.accept.text) || 'Accepter',\n          },\n        },\n      }\n    );\n\n    return new Promise<string | false>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          if (value === undefined) {\n            resolve(false);\n          } else {\n            resolve(value);\n          }\n        },\n        error: reject,\n      });\n    });\n  }\n\n  /**\n   * Opens a dialog with the provided component and inputs.\n   * @param {C3CreateDialogFromComponentConfig<C>} config Configuration options for the dialog. See MatDialogConfig below.\n   * @returns {MatDialogRef<C> & {component: ComponentRef<C> | undefined}} The dialog reference.\n   */\n  createDialogFromComponent<C>({\n    component,\n    toolbar,\n    data,\n    ...config\n  }: C3CreateDialogFromComponentConfig<C>) {\n    if (!component) throw new Error('No component provided');\n\n    const dialog = this.#dialog.open(C3DialogEmbedChildComponent<C>, {\n      ...config,\n      data: {\n        component,\n        toolbar,\n        inputs: data,\n      },\n    });\n\n    return this.createC3DialogResult(dialog);\n  }\n\n  public alert(text: string, data?: AlertConfig) {\n    const dialogRef = this.#dialog.open(C3AlertDialogComponent, {\n      data: {\n        ...data,\n        text,\n      },\n    });\n\n    return dialogRef.afterClosed();\n  }\n\n  private createC3DialogResult<C>(\n    dialog: MatDialogRef<C3DialogEmbedChildComponent<C>>\n  ) {\n    const _afterComponentMounted = new Subject<\n      C3CreateDialogFromComponentResult<C>\n    >();\n\n    const result: C3CreateDialogFromComponentResult<C> = {\n      _containerInstance: dialog._containerInstance,\n      rootComponentRef: dialog.componentRef,\n      rootComponentInstance: dialog.componentInstance,\n      componentRef: dialog.componentInstance.createdComponent(),\n      componentInstance: dialog.componentInstance.createdComponent()?.instance,\n      id: dialog.id,\n      disableClose: dialog.disableClose || false,\n      close: dialog.close.bind(dialog),\n      afterClosed: dialog.afterClosed.bind(dialog),\n      afterOpened: dialog.afterOpened.bind(dialog),\n      beforeClosed: dialog.beforeClosed.bind(dialog),\n      backdropClick: dialog.backdropClick.bind(dialog),\n      getState: dialog.getState.bind(dialog),\n      keydownEvents: dialog.keydownEvents.bind(dialog),\n      updateSize: dialog.updateSize.bind(dialog),\n      updatePosition: dialog.updatePosition.bind(dialog),\n      addPanelClass: dialog.addPanelClass.bind(dialog),\n      removePanelClass: dialog.removePanelClass.bind(dialog),\n      afterComponentMounted: () => _afterComponentMounted.asObservable(),\n    };\n\n    effect(\n      () => {\n        if (dialog.componentInstance.createdComponent()) {\n          result.componentRef = dialog.componentInstance.createdComponent();\n          result.componentInstance =\n            dialog.componentInstance.createdComponent()?.instance;\n          _afterComponentMounted.next(result);\n        }\n      },\n      {\n        injector: this._injector,\n      }\n    );\n\n    return result;\n  }\n}\n"]}
@@ -39,10 +39,10 @@ export class C3FileDisplayCardComponent {
39
39
  return file ? this.displayFn()(file) : '';
40
40
  }
41
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
42
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayCardComponent, isStandalone: true, selector: "c3-file-display-card", inputs: { fileObjectUrl: { classPropertyName: "fileObjectUrl", publicName: "fileObjectUrl", isSignal: true, isRequired: true, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, ngImport: i0, template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayCardComponent, isStandalone: true, selector: "c3-file-display-card", inputs: { fileObjectUrl: { classPropertyName: "fileObjectUrl", publicName: "fileObjectUrl", isSignal: true, isRequired: true, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, ngImport: i0, template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block;width:fit-content}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
43
43
  }
44
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayCardComponent, decorators: [{
45
45
  type: Component,
46
- args: [{ selector: 'c3-file-display-card', standalone: true, imports: [CommonModule, MatButtonModule, MatIconModule], template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"] }]
46
+ args: [{ selector: 'c3-file-display-card', standalone: true, imports: [CommonModule, MatButtonModule, MatIconModule], template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block;width:fit-content}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"] }]
47
47
  }] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1jYXJkL2MzLWZpbGUtZGlzcGxheS1jYXJkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktY2FyZC9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBV3ZELE1BQU0sT0FBTywwQkFBMEI7SUFQdkM7UUFRa0Isa0JBQWEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUszQyxDQUFDO1FBQ1ksY0FBUyxHQUFHLEtBQUssQ0FDL0IsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQ3BCLENBQUM7UUFFYyxjQUFTLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQ2xDLFNBQUksR0FBRyxLQUFLLENBQWlCLElBQUksQ0FBQyxDQUFDO1FBQ25DLGFBQVEsR0FBRyxNQUFNLEVBQUUsQ0FBQztLQTBCckM7SUF4QkMsV0FBVztRQUNULE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNsQyxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDdEIsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUM7Z0JBQUUsT0FBTyxPQUFPLENBQUM7WUFDbEQsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUM7Z0JBQUUsT0FBTyxhQUFhLENBQUM7WUFDOUQsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUM7Z0JBQUUsT0FBTyxPQUFPLENBQUM7UUFDcEQsQ0FBQztRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFFRCxnQkFBZ0I7UUFDZCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDbEMsT0FBTyxJQUFJLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3hELENBQUM7SUFFRCxXQUFXO1FBQ1QsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQ2xDLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRUQsY0FBYztRQUNaLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNsQyxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDNUMsQ0FBQzs4R0F0Q1UsMEJBQTBCO2tHQUExQiwwQkFBMEIsMm9CQ2hCdkMsbWdDQW1DQSwwcEJEdkJZLFlBQVksbUZBQUUsZUFBZSwySUFBRSxhQUFhOzsyRkFJM0MsMEJBQTBCO2tCQVB0QyxTQUFTOytCQUNFLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpbGVNZXRhZGF0YSB9IGZyb20gJy4uLy4uL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLW1ldGFkYXRhJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5cbmV4cG9ydCB0eXBlIEMzRmlsZUNhcmRTaXplID0gJzE2JyB8ICczMicgfCAnNjQnIHwgJzEyOCcgfCAnMjU2JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYzMtZmlsZS1kaXNwbGF5LWNhcmQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVEaXNwbGF5Q2FyZENvbXBvbmVudCB7XG4gIHB1YmxpYyByZWFkb25seSBmaWxlT2JqZWN0VXJsID0gaW5wdXQucmVxdWlyZWQ8XG4gICAgfCAoRmlsZU1ldGFkYXRhICYge1xuICAgICAgICBvYmplY3RVcmw/OiBPYnNlcnZhYmxlPHN0cmluZz47XG4gICAgICB9KVxuICAgIHwgbnVsbFxuICA+KCk7XG4gIHB1YmxpYyByZWFkb25seSBkaXNwbGF5Rm4gPSBpbnB1dDwoZmlsZTogRmlsZU1ldGFkYXRhKSA9PiBzdHJpbmc+KFxuICAgIChmaWxlKSA9PiBmaWxlLm5hbWVcbiAgKTtcblxuICBwdWJsaWMgcmVhZG9ubHkgZGVsZXRhYmxlID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICBwdWJsaWMgcmVhZG9ubHkgc2l6ZSA9IGlucHV0PEMzRmlsZUNhcmRTaXplPignMzInKTtcbiAgcHVibGljIHJlYWRvbmx5IG9uRGVsZXRlID0gb3V0cHV0KCk7XG5cbiAgZ2V0RmlsZVR5cGUoKTogc3RyaW5nIHtcbiAgICBjb25zdCBmaWxlID0gdGhpcy5maWxlT2JqZWN0VXJsKCk7XG4gICAgaWYgKGZpbGUgJiYgZmlsZS50eXBlKSB7XG4gICAgICBpZiAoZmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2ltYWdlJykpIHJldHVybiAnaW1hZ2UnO1xuICAgICAgaWYgKGZpbGUudHlwZS5zdGFydHNXaXRoKCdhcHBsaWNhdGlvbicpKSByZXR1cm4gJ2FwcGxpY2F0aW9uJztcbiAgICAgIGlmIChmaWxlLnR5cGUuc3RhcnRzV2l0aCgndmlkZW8nKSkgcmV0dXJuICd2aWRlbyc7XG4gICAgfVxuICAgIHJldHVybiAndW5rbm93bic7XG4gIH1cblxuICBnZXRGaWxlT2JqZWN0VXJsKCk6IE9ic2VydmFibGU8c3RyaW5nPiB8IG51bGwge1xuICAgIGNvbnN0IGZpbGUgPSB0aGlzLmZpbGVPYmplY3RVcmwoKTtcbiAgICByZXR1cm4gZmlsZSAmJiBmaWxlLm9iamVjdFVybCA/IGZpbGUub2JqZWN0VXJsIDogbnVsbDtcbiAgfVxuXG4gIGdldEZpbGVOYW1lKCk6IHN0cmluZyB7XG4gICAgY29uc3QgZmlsZSA9IHRoaXMuZmlsZU9iamVjdFVybCgpO1xuICAgIHJldHVybiBmaWxlID8gdGhpcy5kaXNwbGF5Rm4oKShmaWxlKSA6ICcnO1xuICB9XG5cbiAgZ2V0RGlzcGxheU5hbWUoKTogc3RyaW5nIHtcbiAgICBjb25zdCBmaWxlID0gdGhpcy5maWxlT2JqZWN0VXJsKCk7XG4gICAgcmV0dXJuIGZpbGUgPyB0aGlzLmRpc3BsYXlGbigpKGZpbGUpIDogJyc7XG4gIH1cbn1cbiIsIjxidXR0b25cbiAgY2xhc3M9XCJmaWxlLWNhcmQgYm9yZGVyXCJcbiAgW2NsYXNzLnNpemUtMTZdPVwic2l6ZSgpID09PSAnMTYnXCJcbiAgW2NsYXNzLnNpemUtMzJdPVwic2l6ZSgpID09PSAnMzInXCJcbiAgW2NsYXNzLnNpemUtNjRdPVwic2l6ZSgpID09PSAnNjQnXCJcbiAgW2NsYXNzLnNpemUtMTI4XT1cInNpemUoKSA9PT0gJzEyOCdcIlxuICBbY2xhc3Muc2l6ZS0yNTZdPVwic2l6ZSgpID09PSAnMjU2J1wiXG4+XG4gIEBpZihkZWxldGFibGUoKSkge1xuICAgIDxkaXYgY2xhc3M9XCJhY3Rpb25zXCI+XG4gICAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiBjb2xvcj1cInJlZFwiIChjbGljayk9XCJvbkRlbGV0ZS5lbWl0KClcIj5cbiAgICAgICAgPG1hdC1pY29uPmRlbGV0ZTwvbWF0LWljb24+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgfSBAaWYoZmlsZU9iamVjdFVybCgpKSB7XG4gICAgQHN3aXRjaCAoZ2V0RmlsZVR5cGUoKSkgeyBAY2FzZSAoJ2ltYWdlJykge1xuICAgICAgPGltZ1xuICAgICAgICBjbGFzcz1cImgtZnVsbCB3LWZ1bGwgb2JqZWN0LWNvdmVyXCJcbiAgICAgICAgW3NyY109XCIoZ2V0RmlsZU9iamVjdFVybCgpIHwgYXN5bmMpIHx8ICcvZGVmYXVsdC1pbWFnZS5zdmcnXCJcbiAgICAgICAgW2FsdF09XCJnZXRGaWxlTmFtZSgpXCJcbiAgICAgIC8+XG4gICAgICB9IEBjYXNlICgnYXBwbGljYXRpb24nKSB7XG4gICAgICA8bWF0LWljb24+IGZpbGUtcGRmLWJveCA8L21hdC1pY29uPlxuICAgICAgfSBAY2FzZSAoJ3ZpZGVvJykge1xuICAgICAgPG1hdC1pY29uPiB2aWRlbyA8L21hdC1pY29uPlxuICAgICAgfVxuICAgIH1cblxuICAgIDxkaXYgY2xhc3M9XCJpbmZvcm1hdGlvbnMgZmxleCBqdXN0aWZ5LWJldHdlZW4gaXRlbXMtY2VudGVyXCI+XG4gICAgICA8c3BhbiBjbGFzcz1cInRleHQteHMgdGV4dC13aGl0ZVwiPlxuICAgICAgICB7eyBnZXREaXNwbGF5TmFtZSgpIH19XG4gICAgICA8L3NwYW4+XG4gICAgPC9kaXY+XG4gIH1cbjwvYnV0dG9uPlxuIl19
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1jYXJkL2MzLWZpbGUtZGlzcGxheS1jYXJkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktY2FyZC9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBV3ZELE1BQU0sT0FBTywwQkFBMEI7SUFQdkM7UUFRa0Isa0JBQWEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUszQyxDQUFDO1FBQ1ksY0FBUyxHQUFHLEtBQUssQ0FDL0IsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQ3BCLENBQUM7UUFFYyxjQUFTLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQ2xDLFNBQUksR0FBRyxLQUFLLENBQWlCLElBQUksQ0FBQyxDQUFDO1FBQ25DLGFBQVEsR0FBRyxNQUFNLEVBQUUsQ0FBQztLQTBCckM7SUF4QkMsV0FBVztRQUNULE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNsQyxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDdEIsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUM7Z0JBQUUsT0FBTyxPQUFPLENBQUM7WUFDbEQsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUM7Z0JBQUUsT0FBTyxhQUFhLENBQUM7WUFDOUQsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUM7Z0JBQUUsT0FBTyxPQUFPLENBQUM7UUFDcEQsQ0FBQztRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFFRCxnQkFBZ0I7UUFDZCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDbEMsT0FBTyxJQUFJLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3hELENBQUM7SUFFRCxXQUFXO1FBQ1QsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQ2xDLE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRUQsY0FBYztRQUNaLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNsQyxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDNUMsQ0FBQzs4R0F0Q1UsMEJBQTBCO2tHQUExQiwwQkFBMEIsMm9CQ2hCdkMsbWdDQW1DQSw0cUJEdkJZLFlBQVksbUZBQUUsZUFBZSwySUFBRSxhQUFhOzsyRkFJM0MsMEJBQTBCO2tCQVB0QyxTQUFTOytCQUNFLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpbGVNZXRhZGF0YSB9IGZyb20gJy4uLy4uL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLW1ldGFkYXRhJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5cbmV4cG9ydCB0eXBlIEMzRmlsZUNhcmRTaXplID0gJzE2JyB8ICczMicgfCAnNjQnIHwgJzEyOCcgfCAnMjU2JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYzMtZmlsZS1kaXNwbGF5LWNhcmQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVEaXNwbGF5Q2FyZENvbXBvbmVudCB7XG4gIHB1YmxpYyByZWFkb25seSBmaWxlT2JqZWN0VXJsID0gaW5wdXQucmVxdWlyZWQ8XG4gICAgfCAoRmlsZU1ldGFkYXRhICYge1xuICAgICAgICBvYmplY3RVcmw/OiBPYnNlcnZhYmxlPHN0cmluZz47XG4gICAgICB9KVxuICAgIHwgbnVsbFxuICA+KCk7XG4gIHB1YmxpYyByZWFkb25seSBkaXNwbGF5Rm4gPSBpbnB1dDwoZmlsZTogRmlsZU1ldGFkYXRhKSA9PiBzdHJpbmc+KFxuICAgIChmaWxlKSA9PiBmaWxlLm5hbWVcbiAgKTtcblxuICBwdWJsaWMgcmVhZG9ubHkgZGVsZXRhYmxlID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICBwdWJsaWMgcmVhZG9ubHkgc2l6ZSA9IGlucHV0PEMzRmlsZUNhcmRTaXplPignMzInKTtcbiAgcHVibGljIHJlYWRvbmx5IG9uRGVsZXRlID0gb3V0cHV0KCk7XG5cbiAgZ2V0RmlsZVR5cGUoKTogc3RyaW5nIHtcbiAgICBjb25zdCBmaWxlID0gdGhpcy5maWxlT2JqZWN0VXJsKCk7XG4gICAgaWYgKGZpbGUgJiYgZmlsZS50eXBlKSB7XG4gICAgICBpZiAoZmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2ltYWdlJykpIHJldHVybiAnaW1hZ2UnO1xuICAgICAgaWYgKGZpbGUudHlwZS5zdGFydHNXaXRoKCdhcHBsaWNhdGlvbicpKSByZXR1cm4gJ2FwcGxpY2F0aW9uJztcbiAgICAgIGlmIChmaWxlLnR5cGUuc3RhcnRzV2l0aCgndmlkZW8nKSkgcmV0dXJuICd2aWRlbyc7XG4gICAgfVxuICAgIHJldHVybiAndW5rbm93bic7XG4gIH1cblxuICBnZXRGaWxlT2JqZWN0VXJsKCk6IE9ic2VydmFibGU8c3RyaW5nPiB8IG51bGwge1xuICAgIGNvbnN0IGZpbGUgPSB0aGlzLmZpbGVPYmplY3RVcmwoKTtcbiAgICByZXR1cm4gZmlsZSAmJiBmaWxlLm9iamVjdFVybCA/IGZpbGUub2JqZWN0VXJsIDogbnVsbDtcbiAgfVxuXG4gIGdldEZpbGVOYW1lKCk6IHN0cmluZyB7XG4gICAgY29uc3QgZmlsZSA9IHRoaXMuZmlsZU9iamVjdFVybCgpO1xuICAgIHJldHVybiBmaWxlID8gdGhpcy5kaXNwbGF5Rm4oKShmaWxlKSA6ICcnO1xuICB9XG5cbiAgZ2V0RGlzcGxheU5hbWUoKTogc3RyaW5nIHtcbiAgICBjb25zdCBmaWxlID0gdGhpcy5maWxlT2JqZWN0VXJsKCk7XG4gICAgcmV0dXJuIGZpbGUgPyB0aGlzLmRpc3BsYXlGbigpKGZpbGUpIDogJyc7XG4gIH1cbn1cbiIsIjxidXR0b25cbiAgY2xhc3M9XCJmaWxlLWNhcmQgYm9yZGVyXCJcbiAgW2NsYXNzLnNpemUtMTZdPVwic2l6ZSgpID09PSAnMTYnXCJcbiAgW2NsYXNzLnNpemUtMzJdPVwic2l6ZSgpID09PSAnMzInXCJcbiAgW2NsYXNzLnNpemUtNjRdPVwic2l6ZSgpID09PSAnNjQnXCJcbiAgW2NsYXNzLnNpemUtMTI4XT1cInNpemUoKSA9PT0gJzEyOCdcIlxuICBbY2xhc3Muc2l6ZS0yNTZdPVwic2l6ZSgpID09PSAnMjU2J1wiXG4+XG4gIEBpZihkZWxldGFibGUoKSkge1xuICAgIDxkaXYgY2xhc3M9XCJhY3Rpb25zXCI+XG4gICAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiBjb2xvcj1cInJlZFwiIChjbGljayk9XCJvbkRlbGV0ZS5lbWl0KClcIj5cbiAgICAgICAgPG1hdC1pY29uPmRlbGV0ZTwvbWF0LWljb24+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgfSBAaWYoZmlsZU9iamVjdFVybCgpKSB7XG4gICAgQHN3aXRjaCAoZ2V0RmlsZVR5cGUoKSkgeyBAY2FzZSAoJ2ltYWdlJykge1xuICAgICAgPGltZ1xuICAgICAgICBjbGFzcz1cImgtZnVsbCB3LWZ1bGwgb2JqZWN0LWNvdmVyXCJcbiAgICAgICAgW3NyY109XCIoZ2V0RmlsZU9iamVjdFVybCgpIHwgYXN5bmMpIHx8ICcvZGVmYXVsdC1pbWFnZS5zdmcnXCJcbiAgICAgICAgW2FsdF09XCJnZXRGaWxlTmFtZSgpXCJcbiAgICAgIC8+XG4gICAgICB9IEBjYXNlICgnYXBwbGljYXRpb24nKSB7XG4gICAgICA8bWF0LWljb24+IGZpbGUtcGRmLWJveCA8L21hdC1pY29uPlxuICAgICAgfSBAY2FzZSAoJ3ZpZGVvJykge1xuICAgICAgPG1hdC1pY29uPiB2aWRlbyA8L21hdC1pY29uPlxuICAgICAgfVxuICAgIH1cblxuICAgIDxkaXYgY2xhc3M9XCJpbmZvcm1hdGlvbnMgZmxleCBqdXN0aWZ5LWJldHdlZW4gaXRlbXMtY2VudGVyXCI+XG4gICAgICA8c3BhbiBjbGFzcz1cInRleHQteHMgdGV4dC13aGl0ZVwiPlxuICAgICAgICB7eyBnZXREaXNwbGF5TmFtZSgpIH19XG4gICAgICA8L3NwYW4+XG4gICAgPC9kaXY+XG4gIH1cbjwvYnV0dG9uPlxuIl19
@@ -37,10 +37,10 @@ export class C3FileDisplayGridComponent {
37
37
  this.dialog()?.openDialog();
38
38
  }
39
39
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayGridComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
40
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayGridComponent, isStandalone: true, selector: "c3-file-display-grid", inputs: { files: { classPropertyName: "files", publicName: "files", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null }, cardSize: { classPropertyName: "cardSize", publicName: "cardSize", isSignal: true, isRequired: false, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, viewQueries: [{ propertyName: "dialog", first: true, predicate: C3FileViewerDialogComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: C3FileDisplayCardComponent, selector: "c3-file-display-card", inputs: ["fileObjectUrl", "displayFn", "deletable", "size"], outputs: ["onDelete"] }, { kind: "ngmodule", type: C3FileViewerModule }, { kind: "component", type: i1.C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: ["fileViewer", "dialogConfig"] }] }); }
40
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayGridComponent, isStandalone: true, selector: "c3-file-display-grid", inputs: { files: { classPropertyName: "files", publicName: "files", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null }, cardSize: { classPropertyName: "cardSize", publicName: "cardSize", isSignal: true, isRequired: false, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, viewQueries: [{ propertyName: "dialog", first: true, predicate: C3FileViewerDialogComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:flex;flex-flow:wrap;gap:1rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: C3FileDisplayCardComponent, selector: "c3-file-display-card", inputs: ["fileObjectUrl", "displayFn", "deletable", "size"], outputs: ["onDelete"] }, { kind: "ngmodule", type: C3FileViewerModule }, { kind: "component", type: i1.C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: ["fileViewer", "dialogConfig"] }] }); }
41
41
  }
42
42
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayGridComponent, decorators: [{
43
43
  type: Component,
44
- args: [{ selector: 'c3-file-display-grid', standalone: true, imports: [CommonModule, C3FileDisplayCardComponent, C3FileViewerModule], template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:10px}\n"] }]
44
+ args: [{ selector: 'c3-file-display-grid', standalone: true, imports: [CommonModule, C3FileDisplayCardComponent, C3FileViewerModule], template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:flex;flex-flow:wrap;gap:1rem}\n"] }]
45
45
  }], ctorParameters: () => [] });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWdyaWQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1ncmlkL2MzLWZpbGUtZGlzcGxheS1ncmlkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktZ3JpZC9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEVBQ04sU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFFTCwwQkFBMEIsR0FDM0IsTUFBTSx3REFBd0QsQ0FBQztBQUNoRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNoRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDdkUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2xELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDhGQUE4RixDQUFDOzs7QUFVM0ksTUFBTSxPQUFPLDBCQUEwQjtJQXNCckM7UUFyQmdCLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQU1uQyxDQUFDO1FBQ1ksV0FBTSxHQUFHLEtBQUssRUFBc0IsQ0FBQztRQUNyQyxhQUFRLEdBQUcsS0FBSyxDQUFpQixJQUFJLENBQUMsQ0FBQztRQUN2QyxjQUFTLEdBQUcsS0FBSyxDQUUvQixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRVAsY0FBUyxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNsQyxhQUFRLEdBQUcsTUFBTSxFQUFnQixDQUFDO1FBQ2xDLFdBQU0sR0FBRyxTQUFTLENBQUMsMkJBQTJCLENBQUMsQ0FBQztRQUV6RCxlQUFVLEdBQUcsSUFBSSxZQUFZLENBQUM7WUFDbkMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUM7U0FDM0IsQ0FBQyxDQUFDO1FBR0QsTUFBTSxDQUNKLEdBQUcsRUFBRTtZQUNILElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN2QyxDQUFDLEVBQ0Q7WUFDRSxpQkFBaUIsRUFBRSxJQUFJO1NBQ3hCLENBQ0YsQ0FBQztRQUVGLE1BQU0sQ0FDSixHQUFHLEVBQUU7WUFDSCxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7Z0JBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRyxDQUFDO1FBQzdELENBQUMsRUFDRDtZQUNFLGlCQUFpQixFQUFFLElBQUk7U0FDeEIsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVELFVBQVUsQ0FBQyxNQUFrQixFQUFFLEtBQWE7UUFDMUMsTUFBTSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztRQUNyQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsVUFBVSxFQUFFLENBQUM7SUFDOUIsQ0FBQzs4R0E5Q1UsMEJBQTBCO2tHQUExQiwwQkFBMEIsa3lCQWdCRiwyQkFBMkIsZ0VDM0NoRSwyWUFZQSxnTURXWSxZQUFZLCtCQUFFLDBCQUEwQixvSkFBRSxrQkFBa0I7OzJGQUkzRCwwQkFBMEI7a0JBUHRDLFNBQVM7K0JBQ0Usc0JBQXNCLGNBQ3BCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSwwQkFBMEIsRUFBRSxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBDb21wb25lbnQsXG4gIGVmZmVjdCxcbiAgaW5qZWN0LFxuICBpbnB1dCxcbiAgb3V0cHV0LFxuICB2aWV3Q2hpbGQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmlsZU1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtbWV0YWRhdGEnO1xuaW1wb3J0IHtcbiAgQzNGaWxlQ2FyZFNpemUsXG4gIEMzRmlsZURpc3BsYXlDYXJkQ29tcG9uZW50LFxufSBmcm9tICcuLi9jMy1maWxlLWRpc3BsYXktY2FyZC9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyTW9kdWxlIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIubW9kdWxlJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlciB9IGZyb20gJy4uLy4uL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLXZpZXdlcic7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtZGlzcGxheS1ncmlkJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQzNGaWxlRGlzcGxheUNhcmRDb21wb25lbnQsIEMzRmlsZVZpZXdlck1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIEMzRmlsZURpc3BsYXlHcmlkQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGZpbGVzID0gaW5wdXQucmVxdWlyZWQ8XG4gICAgQXJyYXk8XG4gICAgICBGaWxlTWV0YWRhdGEgJiB7XG4gICAgICAgIGxvY2F0aW9uOiBzdHJpbmc7XG4gICAgICB9XG4gICAgPlxuICA+KCk7XG4gIHB1YmxpYyByZWFkb25seSBjb25maWcgPSBpbnB1dDxDM0ZpbGVWaWV3ZXJDb25maWc+KCk7XG4gIHB1YmxpYyByZWFkb25seSBjYXJkU2l6ZSA9IGlucHV0PEMzRmlsZUNhcmRTaXplPignMzInKTtcbiAgcHVibGljIHJlYWRvbmx5IGRpc3BsYXlGbiA9IGlucHV0PFxuICAgIChmaWxlOiBGaWxlTWV0YWRhdGEgJiB7IGxvY2F0aW9uOiBzdHJpbmcgfSkgPT4gc3RyaW5nXG4gID4oKGZpbGUpID0+IGZpbGUubmFtZSk7XG5cbiAgcHVibGljIHJlYWRvbmx5IGRlbGV0YWJsZSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcHVibGljIHJlYWRvbmx5IG9uRGVsZXRlID0gb3V0cHV0PEZpbGVNZXRhZGF0YT4oKTtcbiAgcHVibGljIHJlYWRvbmx5IGRpYWxvZyA9IHZpZXdDaGlsZChDM0ZpbGVWaWV3ZXJEaWFsb2dDb21wb25lbnQpO1xuXG4gIHB1YmxpYyBmaWxlVmlld2VyID0gbmV3IEMzRmlsZVZpZXdlcih7XG4gICAgY2xpZW50OiBpbmplY3QoSHR0cENsaWVudCksXG4gIH0pO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGVmZmVjdChcbiAgICAgICgpID0+IHtcbiAgICAgICAgdGhpcy5maWxlVmlld2VyLmZpbGVzID0gdGhpcy5maWxlcygpO1xuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgYWxsb3dTaWduYWxXcml0ZXM6IHRydWUsXG4gICAgICB9XG4gICAgKTtcblxuICAgIGVmZmVjdChcbiAgICAgICgpID0+IHtcbiAgICAgICAgaWYgKHRoaXMuY29uZmlnKCkpIHRoaXMuZmlsZVZpZXdlci5jb25maWcgPSB0aGlzLmNvbmZpZygpITtcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGFsbG93U2lnbmFsV3JpdGVzOiB0cnVlLFxuICAgICAgfVxuICAgICk7XG4gIH1cblxuICBvcGVuRGlhbG9nKCRldmVudDogTW91c2VFdmVudCwgaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0aGlzLmZpbGVWaWV3ZXIuY3VycmVudEluZGV4ID0gaW5kZXg7XG4gICAgdGhpcy5kaWFsb2coKT8ub3BlbkRpYWxvZygpO1xuICB9XG59XG4iLCI8YzMtZmlsZS12aWV3ZXItZGlhbG9nIFtmaWxlVmlld2VyXT1cImZpbGVWaWV3ZXJcIj5cbiAgPGRpdiBjbGFzcz1cImMzLWZpbGUtZGlzcGxheS1ncmlkXCI+XG4gICAgQGZvciAoZmlsZSBvZiBmaWxlcygpOyB0cmFjayAkaW5kZXgpIHtcbiAgICA8YzMtZmlsZS1kaXNwbGF5LWNhcmRcbiAgICAgIFtmaWxlT2JqZWN0VXJsXT1cImZpbGVWaWV3ZXIuZmlsZXNPYmplY3RVcmxbJGluZGV4XVwiXG4gICAgICBbc2l6ZV09XCJjYXJkU2l6ZSgpXCJcbiAgICAgIChjbGljayk9XCJvcGVuRGlhbG9nKCRldmVudCwgJGluZGV4KVwiXG4gICAgICAob25EZWxldGUpPVwib25EZWxldGUuZW1pdChmaWxlKVwiXG4gICAgLz5cbiAgICB9XG4gIDwvZGl2PlxuPC9jMy1maWxlLXZpZXdlci1kaWFsb2c+XG4iXX0=
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWdyaWQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1ncmlkL2MzLWZpbGUtZGlzcGxheS1ncmlkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktZ3JpZC9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEVBQ04sU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFFTCwwQkFBMEIsR0FDM0IsTUFBTSx3REFBd0QsQ0FBQztBQUNoRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNoRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDdkUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2xELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDhGQUE4RixDQUFDOzs7QUFVM0ksTUFBTSxPQUFPLDBCQUEwQjtJQXNCckM7UUFyQmdCLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQU1uQyxDQUFDO1FBQ1ksV0FBTSxHQUFHLEtBQUssRUFBc0IsQ0FBQztRQUNyQyxhQUFRLEdBQUcsS0FBSyxDQUFpQixJQUFJLENBQUMsQ0FBQztRQUN2QyxjQUFTLEdBQUcsS0FBSyxDQUUvQixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRVAsY0FBUyxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNsQyxhQUFRLEdBQUcsTUFBTSxFQUFnQixDQUFDO1FBQ2xDLFdBQU0sR0FBRyxTQUFTLENBQUMsMkJBQTJCLENBQUMsQ0FBQztRQUV6RCxlQUFVLEdBQUcsSUFBSSxZQUFZLENBQUM7WUFDbkMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUM7U0FDM0IsQ0FBQyxDQUFDO1FBR0QsTUFBTSxDQUNKLEdBQUcsRUFBRTtZQUNILElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN2QyxDQUFDLEVBQ0Q7WUFDRSxpQkFBaUIsRUFBRSxJQUFJO1NBQ3hCLENBQ0YsQ0FBQztRQUVGLE1BQU0sQ0FDSixHQUFHLEVBQUU7WUFDSCxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7Z0JBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRyxDQUFDO1FBQzdELENBQUMsRUFDRDtZQUNFLGlCQUFpQixFQUFFLElBQUk7U0FDeEIsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVELFVBQVUsQ0FBQyxNQUFrQixFQUFFLEtBQWE7UUFDMUMsTUFBTSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztRQUNyQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsVUFBVSxFQUFFLENBQUM7SUFDOUIsQ0FBQzs4R0E5Q1UsMEJBQTBCO2tHQUExQiwwQkFBMEIsa3lCQWdCRiwyQkFBMkIsZ0VDM0NoRSwyWUFZQSxnSkRXWSxZQUFZLCtCQUFFLDBCQUEwQixvSkFBRSxrQkFBa0I7OzJGQUkzRCwwQkFBMEI7a0JBUHRDLFNBQVM7K0JBQ0Usc0JBQXNCLGNBQ3BCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSwwQkFBMEIsRUFBRSxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBDb21wb25lbnQsXG4gIGVmZmVjdCxcbiAgaW5qZWN0LFxuICBpbnB1dCxcbiAgb3V0cHV0LFxuICB2aWV3Q2hpbGQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmlsZU1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtbWV0YWRhdGEnO1xuaW1wb3J0IHtcbiAgQzNGaWxlQ2FyZFNpemUsXG4gIEMzRmlsZURpc3BsYXlDYXJkQ29tcG9uZW50LFxufSBmcm9tICcuLi9jMy1maWxlLWRpc3BsYXktY2FyZC9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyTW9kdWxlIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIubW9kdWxlJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlciB9IGZyb20gJy4uLy4uL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLXZpZXdlcic7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtZGlzcGxheS1ncmlkJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQzNGaWxlRGlzcGxheUNhcmRDb21wb25lbnQsIEMzRmlsZVZpZXdlck1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIEMzRmlsZURpc3BsYXlHcmlkQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGZpbGVzID0gaW5wdXQucmVxdWlyZWQ8XG4gICAgQXJyYXk8XG4gICAgICBGaWxlTWV0YWRhdGEgJiB7XG4gICAgICAgIGxvY2F0aW9uOiBzdHJpbmc7XG4gICAgICB9XG4gICAgPlxuICA+KCk7XG4gIHB1YmxpYyByZWFkb25seSBjb25maWcgPSBpbnB1dDxDM0ZpbGVWaWV3ZXJDb25maWc+KCk7XG4gIHB1YmxpYyByZWFkb25seSBjYXJkU2l6ZSA9IGlucHV0PEMzRmlsZUNhcmRTaXplPignMzInKTtcbiAgcHVibGljIHJlYWRvbmx5IGRpc3BsYXlGbiA9IGlucHV0PFxuICAgIChmaWxlOiBGaWxlTWV0YWRhdGEgJiB7IGxvY2F0aW9uOiBzdHJpbmcgfSkgPT4gc3RyaW5nXG4gID4oKGZpbGUpID0+IGZpbGUubmFtZSk7XG5cbiAgcHVibGljIHJlYWRvbmx5IGRlbGV0YWJsZSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcHVibGljIHJlYWRvbmx5IG9uRGVsZXRlID0gb3V0cHV0PEZpbGVNZXRhZGF0YT4oKTtcbiAgcHVibGljIHJlYWRvbmx5IGRpYWxvZyA9IHZpZXdDaGlsZChDM0ZpbGVWaWV3ZXJEaWFsb2dDb21wb25lbnQpO1xuXG4gIHB1YmxpYyBmaWxlVmlld2VyID0gbmV3IEMzRmlsZVZpZXdlcih7XG4gICAgY2xpZW50OiBpbmplY3QoSHR0cENsaWVudCksXG4gIH0pO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGVmZmVjdChcbiAgICAgICgpID0+IHtcbiAgICAgICAgdGhpcy5maWxlVmlld2VyLmZpbGVzID0gdGhpcy5maWxlcygpO1xuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgYWxsb3dTaWduYWxXcml0ZXM6IHRydWUsXG4gICAgICB9XG4gICAgKTtcblxuICAgIGVmZmVjdChcbiAgICAgICgpID0+IHtcbiAgICAgICAgaWYgKHRoaXMuY29uZmlnKCkpIHRoaXMuZmlsZVZpZXdlci5jb25maWcgPSB0aGlzLmNvbmZpZygpITtcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGFsbG93U2lnbmFsV3JpdGVzOiB0cnVlLFxuICAgICAgfVxuICAgICk7XG4gIH1cblxuICBvcGVuRGlhbG9nKCRldmVudDogTW91c2VFdmVudCwgaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0aGlzLmZpbGVWaWV3ZXIuY3VycmVudEluZGV4ID0gaW5kZXg7XG4gICAgdGhpcy5kaWFsb2coKT8ub3BlbkRpYWxvZygpO1xuICB9XG59XG4iLCI8YzMtZmlsZS12aWV3ZXItZGlhbG9nIFtmaWxlVmlld2VyXT1cImZpbGVWaWV3ZXJcIj5cbiAgPGRpdiBjbGFzcz1cImMzLWZpbGUtZGlzcGxheS1ncmlkXCI+XG4gICAgQGZvciAoZmlsZSBvZiBmaWxlcygpOyB0cmFjayAkaW5kZXgpIHtcbiAgICA8YzMtZmlsZS1kaXNwbGF5LWNhcmRcbiAgICAgIFtmaWxlT2JqZWN0VXJsXT1cImZpbGVWaWV3ZXIuZmlsZXNPYmplY3RVcmxbJGluZGV4XVwiXG4gICAgICBbc2l6ZV09XCJjYXJkU2l6ZSgpXCJcbiAgICAgIChjbGljayk9XCJvcGVuRGlhbG9nKCRldmVudCwgJGluZGV4KVwiXG4gICAgICAob25EZWxldGUpPVwib25EZWxldGUuZW1pdChmaWxlKVwiXG4gICAgLz5cbiAgICB9XG4gIDwvZGl2PlxuPC9jMy1maWxlLXZpZXdlci1kaWFsb2c+XG4iXX0=
@@ -11,13 +11,13 @@ export class C3TraceCardComponent {
11
11
  return this.align() === 'right';
12
12
  }
13
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3TraceCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: C3TraceCardComponent, selector: "c3-trace-card", host: { properties: { "class.align-left": "this.alignLeft", "class.align-right": "this.alignRight" }, classAttribute: "c3-trace-card" }, ngImport: i0, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:#e0e0e0 solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:#e0e0e0}\n"], encapsulation: i0.ViewEncapsulation.None }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: C3TraceCardComponent, selector: "c3-trace-card", host: { properties: { "class.align-left": "this.alignLeft", "class.align-right": "this.alignRight" }, classAttribute: "c3-trace-card" }, ngImport: i0, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{--c3-trace-card-border-color: rgba(0, 0, 0, .12);display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:var(--c3-trace-card-border-color) solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:var(--c3-trace-card-border-color)}\n"], encapsulation: i0.ViewEncapsulation.None }); }
15
15
  }
16
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3TraceCardComponent, decorators: [{
17
17
  type: Component,
18
18
  args: [{ selector: 'c3-trace-card', encapsulation: ViewEncapsulation.None, host: {
19
19
  class: 'c3-trace-card',
20
- }, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:#e0e0e0 solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:#e0e0e0}\n"] }]
20
+ }, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{--c3-trace-card-border-color: rgba(0, 0, 0, .12);display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:var(--c3-trace-card-border-color) solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:var(--c3-trace-card-border-color)}\n"] }]
21
21
  }], propDecorators: { alignLeft: [{
22
22
  type: HostBinding,
23
23
  args: ['class.align-left']
@@ -432,6 +432,46 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
432
432
  args: ['target', { read: ViewContainerRef }]
433
433
  }] } });
434
434
 
435
+ class C3AlertDialogComponent {
436
+ constructor(dialogRef, data) {
437
+ this.dialogRef = dialogRef;
438
+ this.data = data;
439
+ }
440
+ onNoClick() {
441
+ this.dialogRef.close();
442
+ }
443
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3AlertDialogComponent, deps: [{ token: i1$2.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
444
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: C3AlertDialogComponent, selector: "AlertDialogComponent", ngImport: i0, template: `
445
+ <mat-dialog-content>
446
+ <div [innerHtml]="data.text"></div>
447
+ </mat-dialog-content>
448
+ <mat-dialog-actions>
449
+ <button mat-button [mat-dialog-close]="true">
450
+ {{ data.acceptText || 'ok' }}
451
+ </button>
452
+ </mat-dialog-actions>
453
+ `, isInline: true, dependencies: [{ kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1$2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1$2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] }); }
454
+ }
455
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3AlertDialogComponent, decorators: [{
456
+ type: Component,
457
+ args: [{
458
+ selector: 'AlertDialogComponent',
459
+ template: `
460
+ <mat-dialog-content>
461
+ <div [innerHtml]="data.text"></div>
462
+ </mat-dialog-content>
463
+ <mat-dialog-actions>
464
+ <button mat-button [mat-dialog-close]="true">
465
+ {{ data.acceptText || 'ok' }}
466
+ </button>
467
+ </mat-dialog-actions>
468
+ `,
469
+ }]
470
+ }], ctorParameters: () => [{ type: i1$2.MatDialogRef }, { type: undefined, decorators: [{
471
+ type: Inject,
472
+ args: [MAT_DIALOG_DATA]
473
+ }] }] });
474
+
435
475
  class C3DialogService {
436
476
  constructor() {
437
477
  this.#dialog = inject(MatDialog);
@@ -527,6 +567,15 @@ class C3DialogService {
527
567
  });
528
568
  return this.createC3DialogResult(dialog);
529
569
  }
570
+ alert(text, data) {
571
+ const dialogRef = this.#dialog.open(C3AlertDialogComponent, {
572
+ data: {
573
+ ...data,
574
+ text,
575
+ },
576
+ });
577
+ return dialogRef.afterClosed();
578
+ }
530
579
  createC3DialogResult(dialog) {
531
580
  const _afterComponentMounted = new Subject();
532
581
  const result = {
@@ -574,7 +623,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
574
623
 
575
624
  class C3DialogModule {
576
625
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3DialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
577
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.1", ngImport: i0, type: C3DialogModule, declarations: [ConfirmDialogComponent,
626
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.1", ngImport: i0, type: C3DialogModule, declarations: [C3AlertDialogComponent,
627
+ ConfirmDialogComponent,
578
628
  C3PromptDialogComponent,
579
629
  C3DialogEmbedChildComponent], imports: [CommonModule,
580
630
  FormsModule,
@@ -599,6 +649,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
599
649
  type: NgModule,
600
650
  args: [{
601
651
  declarations: [
652
+ C3AlertDialogComponent,
602
653
  ConfirmDialogComponent,
603
654
  C3PromptDialogComponent,
604
655
  C3DialogEmbedChildComponent,
@@ -1231,11 +1282,11 @@ class C3FileDisplayCardComponent {
1231
1282
  return file ? this.displayFn()(file) : '';
1232
1283
  }
1233
1284
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1234
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayCardComponent, isStandalone: true, selector: "c3-file-display-card", inputs: { fileObjectUrl: { classPropertyName: "fileObjectUrl", publicName: "fileObjectUrl", isSignal: true, isRequired: true, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, ngImport: i0, template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
1285
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayCardComponent, isStandalone: true, selector: "c3-file-display-card", inputs: { fileObjectUrl: { classPropertyName: "fileObjectUrl", publicName: "fileObjectUrl", isSignal: true, isRequired: true, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, ngImport: i0, template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block;width:fit-content}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
1235
1286
  }
1236
1287
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayCardComponent, decorators: [{
1237
1288
  type: Component,
1238
- args: [{ selector: 'c3-file-display-card', standalone: true, imports: [CommonModule, MatButtonModule, MatIconModule], template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"] }]
1289
+ args: [{ selector: 'c3-file-display-card', standalone: true, imports: [CommonModule, MatButtonModule, MatIconModule], template: "<button\n class=\"file-card border\"\n [class.size-16]=\"size() === '16'\"\n [class.size-32]=\"size() === '32'\"\n [class.size-64]=\"size() === '64'\"\n [class.size-128]=\"size() === '128'\"\n [class.size-256]=\"size() === '256'\"\n>\n @if(deletable()) {\n <div class=\"actions\">\n <button mat-icon-button color=\"red\" (click)=\"onDelete.emit()\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n } @if(fileObjectUrl()) {\n @switch (getFileType()) { @case ('image') {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(getFileObjectUrl() | async) || '/default-image.svg'\"\n [alt]=\"getFileName()\"\n />\n } @case ('application') {\n <mat-icon> file-pdf-box </mat-icon>\n } @case ('video') {\n <mat-icon> video </mat-icon>\n }\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ getDisplayName() }}\n </span>\n </div>\n }\n</button>\n", styles: [":host{display:block;width:fit-content}:host .file-card{position:relative;border-radius:4px;border:1px solid #e0e0e0;overflow:hidden}:host .file-card .actions{position:absolute;top:-21px;right:-21px;z-index:1;display:none}:host .file-card img{border-radius:4px}:host .file-card:hover .actions{display:block}:host .file-card .informations{position:absolute;bottom:0;left:0;z-index:1;width:100%;background:#00000080;padding:0 4px}:host .size-16{height:4rem;width:4rem}:host .size-32{height:8rem;width:8rem}:host .size-64{height:16rem;width:16rem}:host .size-128{height:32rem;width:32rem}:host .size-256{height:64rem;width:64rem}\n"] }]
1239
1290
  }] });
1240
1291
 
1241
1292
  class C3FileDisplayGridComponent {
@@ -1268,11 +1319,11 @@ class C3FileDisplayGridComponent {
1268
1319
  this.dialog()?.openDialog();
1269
1320
  }
1270
1321
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayGridComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1271
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayGridComponent, isStandalone: true, selector: "c3-file-display-grid", inputs: { files: { classPropertyName: "files", publicName: "files", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null }, cardSize: { classPropertyName: "cardSize", publicName: "cardSize", isSignal: true, isRequired: false, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, viewQueries: [{ propertyName: "dialog", first: true, predicate: C3FileViewerDialogComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: C3FileDisplayCardComponent, selector: "c3-file-display-card", inputs: ["fileObjectUrl", "displayFn", "deletable", "size"], outputs: ["onDelete"] }, { kind: "ngmodule", type: C3FileViewerModule }, { kind: "component", type: C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: ["fileViewer", "dialogConfig"] }] }); }
1322
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.1", type: C3FileDisplayGridComponent, isStandalone: true, selector: "c3-file-display-grid", inputs: { files: { classPropertyName: "files", publicName: "files", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null }, cardSize: { classPropertyName: "cardSize", publicName: "cardSize", isSignal: true, isRequired: false, transformFunction: null }, displayFn: { classPropertyName: "displayFn", publicName: "displayFn", isSignal: true, isRequired: false, transformFunction: null }, deletable: { classPropertyName: "deletable", publicName: "deletable", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onDelete: "onDelete" }, viewQueries: [{ propertyName: "dialog", first: true, predicate: C3FileViewerDialogComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:flex;flex-flow:wrap;gap:1rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: C3FileDisplayCardComponent, selector: "c3-file-display-card", inputs: ["fileObjectUrl", "displayFn", "deletable", "size"], outputs: ["onDelete"] }, { kind: "ngmodule", type: C3FileViewerModule }, { kind: "component", type: C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: ["fileViewer", "dialogConfig"] }] }); }
1272
1323
  }
1273
1324
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3FileDisplayGridComponent, decorators: [{
1274
1325
  type: Component,
1275
- args: [{ selector: 'c3-file-display-grid', standalone: true, imports: [CommonModule, C3FileDisplayCardComponent, C3FileViewerModule], template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:10px}\n"] }]
1326
+ args: [{ selector: 'c3-file-display-grid', standalone: true, imports: [CommonModule, C3FileDisplayCardComponent, C3FileViewerModule], template: "<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"c3-file-display-grid\">\n @for (file of files(); track $index) {\n <c3-file-display-card\n [fileObjectUrl]=\"fileViewer.filesObjectUrl[$index]\"\n [size]=\"cardSize()\"\n (click)=\"openDialog($event, $index)\"\n (onDelete)=\"onDelete.emit(file)\"\n />\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:block}:host .c3-file-display-grid{display:flex;flex-flow:wrap;gap:1rem}\n"] }]
1276
1327
  }], ctorParameters: () => [] });
1277
1328
 
1278
1329
  class C3FileDisplayIconComponent {
@@ -1695,13 +1746,13 @@ class C3TraceCardComponent {
1695
1746
  return this.align() === 'right';
1696
1747
  }
1697
1748
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3TraceCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1698
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: C3TraceCardComponent, selector: "c3-trace-card", host: { properties: { "class.align-left": "this.alignLeft", "class.align-right": "this.alignRight" }, classAttribute: "c3-trace-card" }, ngImport: i0, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:#e0e0e0 solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:#e0e0e0}\n"], encapsulation: i0.ViewEncapsulation.None }); }
1749
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: C3TraceCardComponent, selector: "c3-trace-card", host: { properties: { "class.align-left": "this.alignLeft", "class.align-right": "this.alignRight" }, classAttribute: "c3-trace-card" }, ngImport: i0, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{--c3-trace-card-border-color: rgba(0, 0, 0, .12);display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:var(--c3-trace-card-border-color) solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:var(--c3-trace-card-border-color)}\n"], encapsulation: i0.ViewEncapsulation.None }); }
1699
1750
  }
1700
1751
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: C3TraceCardComponent, decorators: [{
1701
1752
  type: Component,
1702
1753
  args: [{ selector: 'c3-trace-card', encapsulation: ViewEncapsulation.None, host: {
1703
1754
  class: 'c3-trace-card',
1704
- }, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:#e0e0e0 solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:#e0e0e0}\n"] }]
1755
+ }, template: "<div class=\"content\">\n <div class=\"horizontal-line\"></div>\n <ng-content select=\"c3-trace-card-content\"></ng-content>\n</div>\n\n<ng-content select=\"c3-trace-card-title\"></ng-content>\n\n", styles: [".c3-trace-card{--c3-trace-card-border-color: rgba(0, 0, 0, .12);display:flex;flex-direction:row;justify-content:space-between;align-items:start;font-size:14px}.c3-trace-card.align-right{flex-direction:row-reverse}.c3-trace-card c3-trace-card-title{padding:.5rem 1rem;font-size:1.5rem;line-height:2rem;border:var(--c3-trace-card-border-color) solid 1px;border-radius:1rem;box-shadow:0 2px 1px -1px #0003,0 1px 1px #00000024,0 1px 3px #0000001f}.c3-trace-card .content{display:flex;flex-direction:column;flex-grow:1}.c3-trace-card .content .horizontal-line{margin-top:25px;height:1px;background-color:var(--c3-trace-card-border-color)}\n"] }]
1705
1756
  }], propDecorators: { alignLeft: [{
1706
1757
  type: HostBinding,
1707
1758
  args: ['class.align-left']