c3-components 0.1.2 → 0.2.1

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.
Files changed (23) hide show
  1. package/esm2022/lib/c3-file-displayer/c3-file-display-card/c3-file-display-card.component.mjs +26 -0
  2. package/esm2022/lib/c3-file-displayer/c3-file-display-grid/c3-file-display-grid.component.mjs +44 -0
  3. package/esm2022/lib/c3-file-displayer/c3-file-display-icon/c3-file-display-icon.component.mjs +56 -0
  4. package/esm2022/lib/c3-file-displayer/c3-file-display-list/c3-file-display-list.component.mjs +60 -0
  5. package/esm2022/lib/c3-file-displayer/c3-file-displayer.module.mjs +43 -0
  6. package/esm2022/lib/c3-file-viewer/models/file-viewer.mjs +7 -7
  7. package/esm2022/public-api.mjs +9 -2
  8. package/fesm2022/c3-components.mjs +194 -29
  9. package/fesm2022/c3-components.mjs.map +1 -1
  10. package/lib/c3-file-displayer/c3-file-display-card/c3-file-display-card.component.d.ts +14 -0
  11. package/lib/c3-file-displayer/c3-file-display-card/c3-file-display-card.component.scss +34 -0
  12. package/lib/c3-file-displayer/c3-file-display-grid/c3-file-display-grid.component.d.ts +19 -0
  13. package/lib/c3-file-displayer/c3-file-display-grid/c3-file-display-grid.component.scss +9 -0
  14. package/lib/c3-file-displayer/c3-file-display-icon/c3-file-display-icon.component.d.ts +8 -0
  15. package/lib/c3-file-displayer/c3-file-display-icon/c3-file-display-icon.component.scss +19 -0
  16. package/lib/c3-file-displayer/c3-file-display-list/c3-file-display-list.component.d.ts +19 -0
  17. package/lib/c3-file-displayer/c3-file-display-list/c3-file-display-list.component.scss +64 -0
  18. package/lib/c3-file-displayer/c3-file-displayer.module.d.ts +11 -0
  19. package/lib/c3-file-viewer/models/file-viewer.d.ts +5 -2
  20. package/package.json +1 -1
  21. package/public-api.d.ts +8 -1
  22. package/esm2022/lib/c3-signals/c3-signal.mjs +0 -24
  23. package/lib/c3-signals/c3-signal.d.ts +0 -11
@@ -0,0 +1,26 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, effect, input, output } from '@angular/core';
3
+ import { MatButtonModule } from '@angular/material/button';
4
+ import { MatIconModule } from '@angular/material/icon';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "@angular/material/button";
8
+ import * as i3 from "@angular/material/icon";
9
+ export class C3FileDisplayCardComponent {
10
+ constructor() {
11
+ this.fileObjectUrl = input.required();
12
+ this.deletable = input(false);
13
+ this.size = input('32');
14
+ this.onDelete = output();
15
+ effect(() => {
16
+ console.log('fileObjectUrl', this.fileObjectUrl());
17
+ });
18
+ }
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
20
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: C3FileDisplayCardComponent, isStandalone: true, selector: "c3-file-display-card", inputs: { fileObjectUrl: { classPropertyName: "fileObjectUrl", publicName: "fileObjectUrl", isSignal: true, isRequired: true, 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()) { @if(fileObjectUrl()!.type.startsWith('image')) {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(fileObjectUrl()!.objectUrl | async) || '/default-image.svg'\"\n [alt]=\"fileObjectUrl()!.name\"\n />\n } @else if (fileObjectUrl()!.type.startsWith('application')) {\n <mat-icon> file-pdf-box </mat-icon>\n } @else if (fileObjectUrl()!.type.startsWith('video')) {\n <mat-icon> video </mat-icon>\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ fileObjectUrl()!.name }}\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:auto}: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}\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"] }] }); }
21
+ }
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayCardComponent, decorators: [{
23
+ type: Component,
24
+ 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()) { @if(fileObjectUrl()!.type.startsWith('image')) {\n <img\n class=\"h-full w-full object-cover\"\n [src]=\"(fileObjectUrl()!.objectUrl | async) || '/default-image.svg'\"\n [alt]=\"fileObjectUrl()!.name\"\n />\n } @else if (fileObjectUrl()!.type.startsWith('application')) {\n <mat-icon> file-pdf-box </mat-icon>\n } @else if (fileObjectUrl()!.type.startsWith('video')) {\n <mat-icon> video </mat-icon>\n }\n\n <div class=\"informations flex justify-between items-center\">\n <span class=\"text-xs text-white\">\n {{ fileObjectUrl()!.name }}\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:auto}: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}\n"] }]
25
+ }], ctorParameters: () => [] });
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1jYXJkL2MzLWZpbGUtZGlzcGxheS1jYXJkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktY2FyZC9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7OztBQVN2RCxNQUFNLE9BQU8sMEJBQTBCO0lBWXJDO1FBWGdCLGtCQUFhLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFLM0MsQ0FBQztRQUVZLGNBQVMsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDbEMsU0FBSSxHQUFHLEtBQUssQ0FBcUMsSUFBSSxDQUFDLENBQUM7UUFDdkQsYUFBUSxHQUFHLE1BQU0sRUFBRSxDQUFDO1FBR2xDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDVixPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQztRQUNyRCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7OEdBaEJVLDBCQUEwQjtrR0FBMUIsMEJBQTBCLHVnQkNkdkMsK2hDQWlDQSxrZER2QlksWUFBWSxtRkFBRSxlQUFlLDJJQUFFLGFBQWE7OzJGQUkzQywwQkFBMEI7a0JBUHRDLFNBQVM7K0JBQ0Usc0JBQXNCLGNBQ3BCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgZWZmZWN0LCBpbnB1dCwgb3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWxlTWV0YWRhdGEgfSBmcm9tICcuLi8uLi9jMy1maWxlLXZpZXdlci9tb2RlbHMvZmlsZS1tZXRhZGF0YSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjMy1maWxlLWRpc3BsYXktY2FyZCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdEJ1dHRvbk1vZHVsZSwgTWF0SWNvbk1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIEMzRmlsZURpc3BsYXlDYXJkQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGZpbGVPYmplY3RVcmwgPSBpbnB1dC5yZXF1aXJlZDxcbiAgICB8IChGaWxlTWV0YWRhdGEgJiB7XG4gICAgICAgIG9iamVjdFVybD86IE9ic2VydmFibGU8c3RyaW5nPjtcbiAgICAgIH0pXG4gICAgfCBudWxsXG4gID4oKTtcblxuICBwdWJsaWMgcmVhZG9ubHkgZGVsZXRhYmxlID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICBwdWJsaWMgcmVhZG9ubHkgc2l6ZSA9IGlucHV0PCcxNicgfCAnMzInIHwgJzY0JyB8ICcxMjgnIHwgJzI1Nic+KCczMicpO1xuICBwdWJsaWMgcmVhZG9ubHkgb25EZWxldGUgPSBvdXRwdXQoKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBlZmZlY3QoKCkgPT4ge1xuICAgICAgY29uc29sZS5sb2coJ2ZpbGVPYmplY3RVcmwnLCB0aGlzLmZpbGVPYmplY3RVcmwoKSk7XG4gICAgfSk7XG4gIH1cbn1cbiIsIjxidXR0b25cbiAgY2xhc3M9XCJmaWxlLWNhcmQgYm9yZGVyXCJcbiAgW2NsYXNzLnNpemUtMTZdPVwic2l6ZSgpID09PSAnMTYnXCJcbiAgW2NsYXNzLnNpemUtMzJdPVwic2l6ZSgpID09PSAnMzInXCJcbiAgW2NsYXNzLnNpemUtNjRdPVwic2l6ZSgpID09PSAnNjQnXCJcbiAgW2NsYXNzLnNpemUtMTI4XT1cInNpemUoKSA9PT0gJzEyOCdcIlxuICBbY2xhc3Muc2l6ZS0yNTZdPVwic2l6ZSgpID09PSAnMjU2J1wiXG4+XG4gIEBpZihkZWxldGFibGUoKSkge1xuICA8ZGl2IGNsYXNzPVwiYWN0aW9uc1wiPlxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIGNvbG9yPVwicmVkXCIgKGNsaWNrKT1cIm9uRGVsZXRlLmVtaXQoKVwiPlxuICAgICAgPG1hdC1pY29uPmRlbGV0ZTwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG4gIDwvZGl2PlxuICB9IEBpZihmaWxlT2JqZWN0VXJsKCkpIHsgQGlmKGZpbGVPYmplY3RVcmwoKSEudHlwZS5zdGFydHNXaXRoKCdpbWFnZScpKSB7XG4gIDxpbWdcbiAgICBjbGFzcz1cImgtZnVsbCB3LWZ1bGwgb2JqZWN0LWNvdmVyXCJcbiAgICBbc3JjXT1cIihmaWxlT2JqZWN0VXJsKCkhLm9iamVjdFVybCB8IGFzeW5jKSB8fCAnL2RlZmF1bHQtaW1hZ2Uuc3ZnJ1wiXG4gICAgW2FsdF09XCJmaWxlT2JqZWN0VXJsKCkhLm5hbWVcIlxuICAvPlxuICB9IEBlbHNlIGlmIChmaWxlT2JqZWN0VXJsKCkhLnR5cGUuc3RhcnRzV2l0aCgnYXBwbGljYXRpb24nKSkge1xuICA8bWF0LWljb24+IGZpbGUtcGRmLWJveCA8L21hdC1pY29uPlxuICB9IEBlbHNlIGlmIChmaWxlT2JqZWN0VXJsKCkhLnR5cGUuc3RhcnRzV2l0aCgndmlkZW8nKSkge1xuICA8bWF0LWljb24+IHZpZGVvIDwvbWF0LWljb24+XG4gIH1cblxuICA8ZGl2IGNsYXNzPVwiaW5mb3JtYXRpb25zIGZsZXgganVzdGlmeS1iZXR3ZWVuIGl0ZW1zLWNlbnRlclwiPlxuICAgIDxzcGFuIGNsYXNzPVwidGV4dC14cyB0ZXh0LXdoaXRlXCI+XG4gICAgICB7eyBmaWxlT2JqZWN0VXJsKCkhLm5hbWUgfX1cbiAgICA8L3NwYW4+XG4gIDwvZGl2PlxuICB9XG48L2J1dHRvbj5cbiJdfQ==
@@ -0,0 +1,44 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, effect, inject, input, output, viewChild, } from '@angular/core';
3
+ import { C3FileDisplayCardComponent } from '../c3-file-display-card/c3-file-display-card.component';
4
+ import { C3FileViewerModule } from '../../c3-file-viewer/c3-file-viewer.module';
5
+ import { C3FileViewer } from '../../c3-file-viewer/models/file-viewer';
6
+ import { HttpClient } from '@angular/common/http';
7
+ import { C3FileViewerDialogComponent } from '../../c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "../../c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component";
10
+ export class C3FileDisplayGridComponent {
11
+ constructor() {
12
+ this.files = input.required();
13
+ this.config = input();
14
+ this.deletable = input(false);
15
+ this.onDelete = output();
16
+ this.dialog = viewChild(C3FileViewerDialogComponent);
17
+ this.fileViewer = new C3FileViewer({
18
+ client: inject(HttpClient),
19
+ });
20
+ effect(() => {
21
+ this.fileViewer.files = this.files();
22
+ }, {
23
+ allowSignalWrites: true,
24
+ });
25
+ effect(() => {
26
+ if (this.config())
27
+ this.fileViewer.config = this.config();
28
+ }, {
29
+ allowSignalWrites: true,
30
+ });
31
+ }
32
+ openDialog($event, index) {
33
+ $event.stopPropagation();
34
+ this.fileViewer.currentIndex = index;
35
+ this.dialog()?.openDialog();
36
+ }
37
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayGridComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
38
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.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 }, 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 (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", "deletable", "size"], outputs: ["onDelete"] }, { kind: "ngmodule", type: C3FileViewerModule }, { kind: "component", type: i1.C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: ["fileViewer", "dialogConfig"] }] }); }
39
+ }
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayGridComponent, decorators: [{
41
+ type: Component,
42
+ 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 (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"] }]
43
+ }], ctorParameters: () => [] });
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWdyaWQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1ncmlkL2MzLWZpbGUtZGlzcGxheS1ncmlkLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktZ3JpZC9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEVBQ04sU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUN2RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEZBQThGLENBQUM7OztBQVUzSSxNQUFNLE9BQU8sMEJBQTBCO0lBa0JyQztRQWpCZ0IsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBTW5DLENBQUM7UUFDWSxXQUFNLEdBQUcsS0FBSyxFQUFzQixDQUFDO1FBRXJDLGNBQVMsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDbEMsYUFBUSxHQUFHLE1BQU0sRUFBZ0IsQ0FBQztRQUNsQyxXQUFNLEdBQUcsU0FBUyxDQUFDLDJCQUEyQixDQUFDLENBQUM7UUFFekQsZUFBVSxHQUFHLElBQUksWUFBWSxDQUFDO1lBQ25DLE1BQU0sRUFBRSxNQUFNLENBQUMsVUFBVSxDQUFDO1NBQzNCLENBQUMsQ0FBQztRQUdELE1BQU0sQ0FDSixHQUFHLEVBQUU7WUFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDdkMsQ0FBQyxFQUNEO1lBQ0UsaUJBQWlCLEVBQUUsSUFBSTtTQUN4QixDQUNGLENBQUM7UUFFRixNQUFNLENBQ0osR0FBRyxFQUFFO1lBQ0gsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO2dCQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUcsQ0FBQztRQUM3RCxDQUFDLEVBQ0Q7WUFDRSxpQkFBaUIsRUFBRSxJQUFJO1NBQ3hCLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRCxVQUFVLENBQUMsTUFBa0IsRUFBRSxLQUFhO1FBQzFDLE1BQU0sQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN6QixJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7UUFDckMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDO0lBQzlCLENBQUM7OEdBMUNVLDBCQUEwQjtrR0FBMUIsMEJBQTBCLDZoQkFZRiwyQkFBMkIsZ0VDcENoRSw4V0FXQSxnTURTWSxZQUFZLCtCQUFFLDBCQUEwQix1SUFBRSxrQkFBa0I7OzJGQUkzRCwwQkFBMEI7a0JBUHRDLFNBQVM7K0JBQ0Usc0JBQXNCLGNBQ3BCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSwwQkFBMEIsRUFBRSxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBDb21wb25lbnQsXG4gIGVmZmVjdCxcbiAgaW5qZWN0LFxuICBpbnB1dCxcbiAgb3V0cHV0LFxuICB2aWV3Q2hpbGQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmlsZU1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtbWV0YWRhdGEnO1xuaW1wb3J0IHsgQzNGaWxlRGlzcGxheUNhcmRDb21wb25lbnQgfSBmcm9tICcuLi9jMy1maWxlLWRpc3BsYXktY2FyZC9jMy1maWxlLWRpc3BsYXktY2FyZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyTW9kdWxlIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIubW9kdWxlJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlciB9IGZyb20gJy4uLy4uL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLXZpZXdlcic7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtZGlzcGxheS1ncmlkJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQzNGaWxlRGlzcGxheUNhcmRDb21wb25lbnQsIEMzRmlsZVZpZXdlck1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIEMzRmlsZURpc3BsYXlHcmlkQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGZpbGVzID0gaW5wdXQucmVxdWlyZWQ8XG4gICAgQXJyYXk8XG4gICAgICBGaWxlTWV0YWRhdGEgJiB7XG4gICAgICAgIGxvY2F0aW9uOiBzdHJpbmc7XG4gICAgICB9XG4gICAgPlxuICA+KCk7XG4gIHB1YmxpYyByZWFkb25seSBjb25maWcgPSBpbnB1dDxDM0ZpbGVWaWV3ZXJDb25maWc+KCk7XG5cbiAgcHVibGljIHJlYWRvbmx5IGRlbGV0YWJsZSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcHVibGljIHJlYWRvbmx5IG9uRGVsZXRlID0gb3V0cHV0PEZpbGVNZXRhZGF0YT4oKTtcbiAgcHVibGljIHJlYWRvbmx5IGRpYWxvZyA9IHZpZXdDaGlsZChDM0ZpbGVWaWV3ZXJEaWFsb2dDb21wb25lbnQpO1xuXG4gIHB1YmxpYyBmaWxlVmlld2VyID0gbmV3IEMzRmlsZVZpZXdlcih7XG4gICAgY2xpZW50OiBpbmplY3QoSHR0cENsaWVudCksXG4gIH0pO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGVmZmVjdChcbiAgICAgICgpID0+IHtcbiAgICAgICAgdGhpcy5maWxlVmlld2VyLmZpbGVzID0gdGhpcy5maWxlcygpO1xuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgYWxsb3dTaWduYWxXcml0ZXM6IHRydWUsXG4gICAgICB9XG4gICAgKTtcblxuICAgIGVmZmVjdChcbiAgICAgICgpID0+IHtcbiAgICAgICAgaWYgKHRoaXMuY29uZmlnKCkpIHRoaXMuZmlsZVZpZXdlci5jb25maWcgPSB0aGlzLmNvbmZpZygpITtcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGFsbG93U2lnbmFsV3JpdGVzOiB0cnVlLFxuICAgICAgfVxuICAgICk7XG4gIH1cblxuICBvcGVuRGlhbG9nKCRldmVudDogTW91c2VFdmVudCwgaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0aGlzLmZpbGVWaWV3ZXIuY3VycmVudEluZGV4ID0gaW5kZXg7XG4gICAgdGhpcy5kaWFsb2coKT8ub3BlbkRpYWxvZygpO1xuICB9XG59XG4iLCI8YzMtZmlsZS12aWV3ZXItZGlhbG9nIFtmaWxlVmlld2VyXT1cImZpbGVWaWV3ZXJcIj5cbiAgPGRpdiBjbGFzcz1cImMzLWZpbGUtZGlzcGxheS1ncmlkXCI+XG4gICAgQGZvciAoZmlsZSBvZiBmaWxlcygpOyB0cmFjayAkaW5kZXgpIHtcbiAgICA8YzMtZmlsZS1kaXNwbGF5LWNhcmRcbiAgICAgIFtmaWxlT2JqZWN0VXJsXT1cImZpbGVWaWV3ZXIuZmlsZXNPYmplY3RVcmxbJGluZGV4XVwiXG4gICAgICAoY2xpY2spPVwib3BlbkRpYWxvZygkZXZlbnQsICRpbmRleClcIlxuICAgICAgKG9uRGVsZXRlKT1cIm9uRGVsZXRlLmVtaXQoZmlsZSlcIlxuICAgIC8+XG4gICAgfVxuICA8L2Rpdj5cbjwvYzMtZmlsZS12aWV3ZXItZGlhbG9nPlxuIl19
@@ -0,0 +1,56 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, computed, input } from '@angular/core';
3
+ import { MatIconModule } from '@angular/material/icon';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@angular/material/icon";
7
+ export class C3FileDisplayIconComponent {
8
+ constructor() {
9
+ this.fileType = input.required();
10
+ this.displayedIcon = computed(() => {
11
+ switch (this.fileType()) {
12
+ case 'image/webp':
13
+ case 'image/png':
14
+ case 'image/jpeg':
15
+ case 'image/jpg':
16
+ return 'image';
17
+ case 'video/mp4':
18
+ case 'video/webm':
19
+ return 'play_circle';
20
+ case 'application/pdf':
21
+ return 'picture_as_pdf';
22
+ case 'application/msword':
23
+ case 'application/vnd.openxmlformats-officedocument.wordprocessingml.document':
24
+ return 'description';
25
+ default:
26
+ return 'content_copy';
27
+ }
28
+ });
29
+ this.color = computed(() => {
30
+ switch (this.fileType()) {
31
+ case 'image/webp':
32
+ case 'image/png':
33
+ case 'image/jpeg':
34
+ case 'image/jpg':
35
+ return 'text-primary';
36
+ case 'video/mp4':
37
+ case 'video/webm':
38
+ return 'text-secondary';
39
+ case 'application/pdf':
40
+ return 'text-error';
41
+ case 'application/msword':
42
+ case 'application/vnd.openxmlformats-officedocument.wordprocessingml.document':
43
+ return 'text-success';
44
+ default:
45
+ return 'text-gray';
46
+ }
47
+ });
48
+ }
49
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
50
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.1", type: C3FileDisplayIconComponent, isStandalone: true, selector: "c3-file-display-icon", inputs: { fileType: { classPropertyName: "fileType", publicName: "fileType", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<mat-icon [ngClass]=\"color()\">{{ displayedIcon() }}</mat-icon>\n", styles: [":host{display:block}:host .text-primary{color:var(--primary-color)}:host .text-secondary{color:var(--secondary-color)}:host .text-success{color:var(--success-color)}:host .text-gray{color:var(--gray-color)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
51
+ }
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayIconComponent, decorators: [{
53
+ type: Component,
54
+ args: [{ selector: 'c3-file-display-icon', standalone: true, imports: [CommonModule, MatIconModule], template: "<mat-icon [ngClass]=\"color()\">{{ displayedIcon() }}</mat-icon>\n", styles: [":host{display:block}:host .text-primary{color:var(--primary-color)}:host .text-secondary{color:var(--secondary-color)}:host .text-success{color:var(--success-color)}:host .text-gray{color:var(--gray-color)}\n"] }]
55
+ }] });
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWljb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1pY29uL2MzLWZpbGUtZGlzcGxheS1pY29uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktaWNvbi9jMy1maWxlLWRpc3BsYXktaWNvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7OztBQVN2RCxNQUFNLE9BQU8sMEJBQTBCO0lBUHZDO1FBUWtCLGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFFcEMsa0JBQWEsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQzVDLFFBQVEsSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUM7Z0JBQ3hCLEtBQUssWUFBWSxDQUFDO2dCQUNsQixLQUFLLFdBQVcsQ0FBQztnQkFDakIsS0FBSyxZQUFZLENBQUM7Z0JBQ2xCLEtBQUssV0FBVztvQkFDZCxPQUFPLE9BQU8sQ0FBQztnQkFDakIsS0FBSyxXQUFXLENBQUM7Z0JBQ2pCLEtBQUssWUFBWTtvQkFDZixPQUFPLGFBQWEsQ0FBQztnQkFDdkIsS0FBSyxpQkFBaUI7b0JBQ3BCLE9BQU8sZ0JBQWdCLENBQUM7Z0JBQzFCLEtBQUssb0JBQW9CLENBQUM7Z0JBQzFCLEtBQUsseUVBQXlFO29CQUM1RSxPQUFPLGFBQWEsQ0FBQztnQkFDdkI7b0JBQ0UsT0FBTyxjQUFjLENBQUM7WUFDMUIsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO1FBRWEsVUFBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDcEMsUUFBUSxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQztnQkFDeEIsS0FBSyxZQUFZLENBQUM7Z0JBQ2xCLEtBQUssV0FBVyxDQUFDO2dCQUNqQixLQUFLLFlBQVksQ0FBQztnQkFDbEIsS0FBSyxXQUFXO29CQUNkLE9BQU8sY0FBYyxDQUFDO2dCQUN4QixLQUFLLFdBQVcsQ0FBQztnQkFDakIsS0FBSyxZQUFZO29CQUNmLE9BQU8sZ0JBQWdCLENBQUM7Z0JBQzFCLEtBQUssaUJBQWlCO29CQUNwQixPQUFPLFlBQVksQ0FBQztnQkFDdEIsS0FBSyxvQkFBb0IsQ0FBQztnQkFDMUIsS0FBSyx5RUFBeUU7b0JBQzVFLE9BQU8sY0FBYyxDQUFDO2dCQUN4QjtvQkFDRSxPQUFPLFdBQVcsQ0FBQztZQUN2QixDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7S0FDSjs4R0ExQ1ksMEJBQTBCO2tHQUExQiwwQkFBMEIsNE5DWHZDLG9FQUNBLHlRRE1ZLFlBQVksNEhBQUUsYUFBYTs7MkZBSTFCLDBCQUEwQjtrQkFQdEMsU0FBUzsrQkFDRSxzQkFBc0IsY0FDcEIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIGNvbXB1dGVkLCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjMy1maWxlLWRpc3BsYXktaWNvbicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdEljb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWljb24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWljb24uY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVEaXNwbGF5SWNvbkNvbXBvbmVudCB7XG4gIHB1YmxpYyByZWFkb25seSBmaWxlVHlwZSA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcblxuICBwdWJsaWMgcmVhZG9ubHkgZGlzcGxheWVkSWNvbiA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBzd2l0Y2ggKHRoaXMuZmlsZVR5cGUoKSkge1xuICAgICAgY2FzZSAnaW1hZ2Uvd2VicCc6XG4gICAgICBjYXNlICdpbWFnZS9wbmcnOlxuICAgICAgY2FzZSAnaW1hZ2UvanBlZyc6XG4gICAgICBjYXNlICdpbWFnZS9qcGcnOlxuICAgICAgICByZXR1cm4gJ2ltYWdlJztcbiAgICAgIGNhc2UgJ3ZpZGVvL21wNCc6XG4gICAgICBjYXNlICd2aWRlby93ZWJtJzpcbiAgICAgICAgcmV0dXJuICdwbGF5X2NpcmNsZSc7XG4gICAgICBjYXNlICdhcHBsaWNhdGlvbi9wZGYnOlxuICAgICAgICByZXR1cm4gJ3BpY3R1cmVfYXNfcGRmJztcbiAgICAgIGNhc2UgJ2FwcGxpY2F0aW9uL21zd29yZCc6XG4gICAgICBjYXNlICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQud29yZHByb2Nlc3NpbmdtbC5kb2N1bWVudCc6XG4gICAgICAgIHJldHVybiAnZGVzY3JpcHRpb24nO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuICdjb250ZW50X2NvcHknO1xuICAgIH1cbiAgfSk7XG5cbiAgcHVibGljIHJlYWRvbmx5IGNvbG9yID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIHN3aXRjaCAodGhpcy5maWxlVHlwZSgpKSB7XG4gICAgICBjYXNlICdpbWFnZS93ZWJwJzpcbiAgICAgIGNhc2UgJ2ltYWdlL3BuZyc6XG4gICAgICBjYXNlICdpbWFnZS9qcGVnJzpcbiAgICAgIGNhc2UgJ2ltYWdlL2pwZyc6XG4gICAgICAgIHJldHVybiAndGV4dC1wcmltYXJ5JztcbiAgICAgIGNhc2UgJ3ZpZGVvL21wNCc6XG4gICAgICBjYXNlICd2aWRlby93ZWJtJzpcbiAgICAgICAgcmV0dXJuICd0ZXh0LXNlY29uZGFyeSc7XG4gICAgICBjYXNlICdhcHBsaWNhdGlvbi9wZGYnOlxuICAgICAgICByZXR1cm4gJ3RleHQtZXJyb3InO1xuICAgICAgY2FzZSAnYXBwbGljYXRpb24vbXN3b3JkJzpcbiAgICAgIGNhc2UgJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC53b3JkcHJvY2Vzc2luZ21sLmRvY3VtZW50JzpcbiAgICAgICAgcmV0dXJuICd0ZXh0LXN1Y2Nlc3MnO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuICd0ZXh0LWdyYXknO1xuICAgIH1cbiAgfSk7XG59XG4iLCI8bWF0LWljb24gW25nQ2xhc3NdPVwiY29sb3IoKVwiPnt7IGRpc3BsYXllZEljb24oKSB9fTwvbWF0LWljb24+XG4iXX0=
@@ -0,0 +1,60 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { HttpClient } from '@angular/common/http';
3
+ import { Component, effect, inject, input, output, viewChild, } from '@angular/core';
4
+ import { C3FileViewerDialogComponent } from '../../c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component';
5
+ import { C3FileViewer } from '../../c3-file-viewer/models/file-viewer';
6
+ import { MatIconModule } from '@angular/material/icon';
7
+ import { C3FileViewerModule } from '../../c3-file-viewer/c3-file-viewer.module';
8
+ import { C3FileDisplayIconComponent } from '../c3-file-display-icon/c3-file-display-icon.component';
9
+ import { MatNativeDateModule } from '@angular/material/core';
10
+ import { MatMenuModule } from '@angular/material/menu';
11
+ import { MatButtonModule } from '@angular/material/button';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "../../c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component";
14
+ import * as i2 from "@angular/common";
15
+ import * as i3 from "@angular/material/button";
16
+ import * as i4 from "@angular/material/icon";
17
+ import * as i5 from "@angular/material/menu";
18
+ export class C3FileDisplayListComponent {
19
+ constructor() {
20
+ this.files = input.required();
21
+ this.config = input();
22
+ this.deletable = input(false);
23
+ this.onDelete = output();
24
+ this.dialog = viewChild(C3FileViewerDialogComponent);
25
+ this.fileViewer = new C3FileViewer({
26
+ client: inject(HttpClient),
27
+ });
28
+ effect(() => {
29
+ this.fileViewer.files = this.files();
30
+ }, {
31
+ allowSignalWrites: true,
32
+ });
33
+ effect(() => {
34
+ if (this.config())
35
+ this.fileViewer.config = this.config();
36
+ }, {
37
+ allowSignalWrites: true,
38
+ });
39
+ }
40
+ openDialog($event, index) {
41
+ $event.stopPropagation();
42
+ this.fileViewer.currentIndex = index;
43
+ this.dialog()?.openDialog();
44
+ }
45
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
46
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.1", type: C3FileDisplayListComponent, isStandalone: true, selector: "c3-file-display-list", inputs: { files: { classPropertyName: "files", publicName: "files", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", 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: "<!-- header -->\n<div class=\"header\">\n <div class=\"title full\">\n <span>Nom</span>\n </div>\n <div class=\"title\">\n <span>Date d'ajout</span>\n </div>\n <div class=\"icon\">\n <mat-icon>more_vert</mat-icon>\n </div>\n</div>\n<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"file-display-list\">\n @for (file of files(); track $index) {\n <button>\n <div class=\"icon\">\n <c3-file-display-icon [fileType]=\"file.type\" />\n </div>\n <div class=\"name\">\n <span>{{ file.name }}</span>\n </div>\n <div class=\"date-label\">\n <span>{{\n file.lastModified ? (file.lastModified | date : \"medium\") : \"-\"\n }}</span>\n </div>\n <button mat-icon-button>\n <mat-icon>more_vert</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item (click)=\"openDialog($event, $index)\">\n Ouvrir\n </button>\n @if (deletable()) {\n <button mat-menu-item (click)=\"onDelete.emit(file)\">Supprimer</button>\n }\n </mat-menu>\n </button>\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:flex;flex-direction:column;margin:.5rem}:host .header{display:flex;align-items:center;padding:0 .5rem;border-bottom:1px solid var(--mat-divider-color)}:host .header .title{flex-basis:304px;width:304px;font-size:1.5rem;font-weight:700}:host .header .title.full{flex:auto}:host .header .icon{flex-basis:40px;width:40px}:host .file-display-list{display:flex;flex-direction:column}:host .file-display-list>button{display:flex;flex-direction:row;height:3rem;align-items:center;border-bottom:1px solid var(--mat-divider-color);background-color:var(--mdc-protected-button-container-color);text-align:start;padding:0 .5rem}:host .file-display-list>button:hover{background-color:var(--background-hover)}:host .file-display-list>button .icon{flex-basis:56px;width:56px}:host .file-display-list>button .name{flex:auto;flex-basis:304px;width:304px}:host .file-display-list>button .date-label{flex-basis:304px;width:304px}\n"], dependencies: [{ kind: "ngmodule", type: C3FileViewerModule }, { kind: "component", type: i1.C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: ["fileViewer", "dialogConfig"] }, { kind: "component", type: C3FileDisplayIconComponent, selector: "c3-file-display-icon", inputs: ["fileType"] }, { kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.DatePipe, name: "date" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatNativeDateModule }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i5.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }] }); }
47
+ }
48
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayListComponent, decorators: [{
49
+ type: Component,
50
+ args: [{ selector: 'c3-file-display-list', standalone: true, imports: [
51
+ C3FileViewerModule,
52
+ C3FileDisplayIconComponent,
53
+ CommonModule,
54
+ MatButtonModule,
55
+ MatIconModule,
56
+ MatNativeDateModule,
57
+ MatMenuModule,
58
+ ], template: "<!-- header -->\n<div class=\"header\">\n <div class=\"title full\">\n <span>Nom</span>\n </div>\n <div class=\"title\">\n <span>Date d'ajout</span>\n </div>\n <div class=\"icon\">\n <mat-icon>more_vert</mat-icon>\n </div>\n</div>\n<c3-file-viewer-dialog [fileViewer]=\"fileViewer\">\n <div class=\"file-display-list\">\n @for (file of files(); track $index) {\n <button>\n <div class=\"icon\">\n <c3-file-display-icon [fileType]=\"file.type\" />\n </div>\n <div class=\"name\">\n <span>{{ file.name }}</span>\n </div>\n <div class=\"date-label\">\n <span>{{\n file.lastModified ? (file.lastModified | date : \"medium\") : \"-\"\n }}</span>\n </div>\n <button mat-icon-button>\n <mat-icon>more_vert</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item (click)=\"openDialog($event, $index)\">\n Ouvrir\n </button>\n @if (deletable()) {\n <button mat-menu-item (click)=\"onDelete.emit(file)\">Supprimer</button>\n }\n </mat-menu>\n </button>\n }\n </div>\n</c3-file-viewer-dialog>\n", styles: [":host{display:flex;flex-direction:column;margin:.5rem}:host .header{display:flex;align-items:center;padding:0 .5rem;border-bottom:1px solid var(--mat-divider-color)}:host .header .title{flex-basis:304px;width:304px;font-size:1.5rem;font-weight:700}:host .header .title.full{flex:auto}:host .header .icon{flex-basis:40px;width:40px}:host .file-display-list{display:flex;flex-direction:column}:host .file-display-list>button{display:flex;flex-direction:row;height:3rem;align-items:center;border-bottom:1px solid var(--mat-divider-color);background-color:var(--mdc-protected-button-container-color);text-align:start;padding:0 .5rem}:host .file-display-list>button:hover{background-color:var(--background-hover)}:host .file-display-list>button .icon{flex-basis:56px;width:56px}:host .file-display-list>button .name{flex:auto;flex-basis:304px;width:304px}:host .file-display-list>button .date-label{flex-basis:304px;width:304px}\n"] }]
59
+ }], ctorParameters: () => [] });
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5LWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1saXN0L2MzLWZpbGUtZGlzcGxheS1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktbGlzdC9jMy1maWxlLWRpc3BsYXktbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2xELE9BQU8sRUFDTCxTQUFTLEVBQ1QsTUFBTSxFQUNOLE1BQU0sRUFDTixLQUFLLEVBQ0wsTUFBTSxFQUNOLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSw4RkFBOEYsQ0FBQztBQUUzSSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFdkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7Ozs7QUFpQjNELE1BQU0sT0FBTywwQkFBMEI7SUFrQnJDO1FBakJnQixVQUFLLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFNbkMsQ0FBQztRQUNZLFdBQU0sR0FBRyxLQUFLLEVBQXNCLENBQUM7UUFFckMsY0FBUyxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNsQyxhQUFRLEdBQUcsTUFBTSxFQUFnQixDQUFDO1FBQ2xDLFdBQU0sR0FBRyxTQUFTLENBQUMsMkJBQTJCLENBQUMsQ0FBQztRQUV6RCxlQUFVLEdBQUcsSUFBSSxZQUFZLENBQUM7WUFDbkMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUM7U0FDM0IsQ0FBQyxDQUFDO1FBR0QsTUFBTSxDQUNKLEdBQUcsRUFBRTtZQUNILElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN2QyxDQUFDLEVBQ0Q7WUFDRSxpQkFBaUIsRUFBRSxJQUFJO1NBQ3hCLENBQ0YsQ0FBQztRQUVGLE1BQU0sQ0FDSixHQUFHLEVBQUU7WUFDSCxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7Z0JBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRyxDQUFDO1FBQzdELENBQUMsRUFDRDtZQUNFLGlCQUFpQixFQUFFLElBQUk7U0FDeEIsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVELFVBQVUsQ0FBQyxNQUFrQixFQUFFLEtBQWE7UUFDMUMsTUFBTSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztRQUNyQyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsVUFBVSxFQUFFLENBQUM7SUFDOUIsQ0FBQzs4R0ExQ1UsMEJBQTBCO2tHQUExQiwwQkFBMEIsNmhCQVlGLDJCQUEyQixnRUNoRGhFLHNwQ0EwQ0EsczlCRGpCSSxrQkFBa0IsdUtBQ2xCLDBCQUEwQixzRkFDMUIsWUFBWSxpRkFDWixlQUFlLDJJQUNmLGFBQWEsbUxBQ2IsbUJBQW1CLDhCQUNuQixhQUFhOzsyRkFLSiwwQkFBMEI7a0JBZnRDLFNBQVM7K0JBQ0Usc0JBQXNCLGNBQ3BCLElBQUksV0FDUDt3QkFDUCxrQkFBa0I7d0JBQ2xCLDBCQUEwQjt3QkFDMUIsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixhQUFhO3FCQUNkIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQge1xuICBDb21wb25lbnQsXG4gIGVmZmVjdCxcbiAgaW5qZWN0LFxuICBpbnB1dCxcbiAgb3V0cHV0LFxuICB2aWV3Q2hpbGQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmlsZU1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtbWV0YWRhdGEnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtdmlld2VyJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlckNvbmZpZyB9IGZyb20gJy4uLy4uL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLXZpZXdlci1jb25maWcubW9kZWwnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyTW9kdWxlIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIubW9kdWxlJztcbmltcG9ydCB7IEMzRmlsZURpc3BsYXlJY29uQ29tcG9uZW50IH0gZnJvbSAnLi4vYzMtZmlsZS1kaXNwbGF5LWljb24vYzMtZmlsZS1kaXNwbGF5LWljb24uY29tcG9uZW50JztcbmltcG9ydCB7IE1hdE5hdGl2ZURhdGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtZGlzcGxheS1saXN0JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIEMzRmlsZVZpZXdlck1vZHVsZSxcbiAgICBDM0ZpbGVEaXNwbGF5SWNvbkNvbXBvbmVudCxcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0TmF0aXZlRGF0ZU1vZHVsZSxcbiAgICBNYXRNZW51TW9kdWxlLFxuICBdLFxuICB0ZW1wbGF0ZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWxpc3QuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vYzMtZmlsZS1kaXNwbGF5LWxpc3QuY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVEaXNwbGF5TGlzdENvbXBvbmVudCB7XG4gIHB1YmxpYyByZWFkb25seSBmaWxlcyA9IGlucHV0LnJlcXVpcmVkPFxuICAgIEFycmF5PFxuICAgICAgRmlsZU1ldGFkYXRhICYge1xuICAgICAgICBsb2NhdGlvbjogc3RyaW5nO1xuICAgICAgfVxuICAgID5cbiAgPigpO1xuICBwdWJsaWMgcmVhZG9ubHkgY29uZmlnID0gaW5wdXQ8QzNGaWxlVmlld2VyQ29uZmlnPigpO1xuXG4gIHB1YmxpYyByZWFkb25seSBkZWxldGFibGUgPSBpbnB1dDxib29sZWFuPihmYWxzZSk7XG4gIHB1YmxpYyByZWFkb25seSBvbkRlbGV0ZSA9IG91dHB1dDxGaWxlTWV0YWRhdGE+KCk7XG4gIHB1YmxpYyByZWFkb25seSBkaWFsb2cgPSB2aWV3Q2hpbGQoQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50KTtcblxuICBwdWJsaWMgZmlsZVZpZXdlciA9IG5ldyBDM0ZpbGVWaWV3ZXIoe1xuICAgIGNsaWVudDogaW5qZWN0KEh0dHBDbGllbnQpLFxuICB9KTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBlZmZlY3QoXG4gICAgICAoKSA9PiB7XG4gICAgICAgIHRoaXMuZmlsZVZpZXdlci5maWxlcyA9IHRoaXMuZmlsZXMoKTtcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGFsbG93U2lnbmFsV3JpdGVzOiB0cnVlLFxuICAgICAgfVxuICAgICk7XG5cbiAgICBlZmZlY3QoXG4gICAgICAoKSA9PiB7XG4gICAgICAgIGlmICh0aGlzLmNvbmZpZygpKSB0aGlzLmZpbGVWaWV3ZXIuY29uZmlnID0gdGhpcy5jb25maWcoKSE7XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBhbGxvd1NpZ25hbFdyaXRlczogdHJ1ZSxcbiAgICAgIH1cbiAgICApO1xuICB9XG5cbiAgb3BlbkRpYWxvZygkZXZlbnQ6IE1vdXNlRXZlbnQsIGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAkZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgdGhpcy5maWxlVmlld2VyLmN1cnJlbnRJbmRleCA9IGluZGV4O1xuICAgIHRoaXMuZGlhbG9nKCk/Lm9wZW5EaWFsb2coKTtcbiAgfVxufVxuIiwiPCEtLSBoZWFkZXIgLS0+XG48ZGl2IGNsYXNzPVwiaGVhZGVyXCI+XG4gIDxkaXYgY2xhc3M9XCJ0aXRsZSBmdWxsXCI+XG4gICAgPHNwYW4+Tm9tPC9zcGFuPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cInRpdGxlXCI+XG4gICAgPHNwYW4+RGF0ZSBkJ2Fqb3V0PC9zcGFuPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImljb25cIj5cbiAgICA8bWF0LWljb24+bW9yZV92ZXJ0PC9tYXQtaWNvbj5cbiAgPC9kaXY+XG48L2Rpdj5cbjxjMy1maWxlLXZpZXdlci1kaWFsb2cgW2ZpbGVWaWV3ZXJdPVwiZmlsZVZpZXdlclwiPlxuICA8ZGl2IGNsYXNzPVwiZmlsZS1kaXNwbGF5LWxpc3RcIj5cbiAgICBAZm9yIChmaWxlIG9mIGZpbGVzKCk7IHRyYWNrICRpbmRleCkge1xuICAgIDxidXR0b24+XG4gICAgICA8ZGl2IGNsYXNzPVwiaWNvblwiPlxuICAgICAgICA8YzMtZmlsZS1kaXNwbGF5LWljb24gW2ZpbGVUeXBlXT1cImZpbGUudHlwZVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJuYW1lXCI+XG4gICAgICAgIDxzcGFuPnt7IGZpbGUubmFtZSB9fTwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImRhdGUtbGFiZWxcIj5cbiAgICAgICAgPHNwYW4+e3tcbiAgICAgICAgICBmaWxlLmxhc3RNb2RpZmllZCA/IChmaWxlLmxhc3RNb2RpZmllZCB8IGRhdGUgOiBcIm1lZGl1bVwiKSA6IFwiLVwiXG4gICAgICAgIH19PC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbj5cbiAgICAgICAgPG1hdC1pY29uPm1vcmVfdmVydDwvbWF0LWljb24+XG4gICAgICA8L2J1dHRvbj5cbiAgICAgIDxtYXQtbWVudSAjbWVudT1cIm1hdE1lbnVcIj5cbiAgICAgICAgPGJ1dHRvbiBtYXQtbWVudS1pdGVtIChjbGljayk9XCJvcGVuRGlhbG9nKCRldmVudCwgJGluZGV4KVwiPlxuICAgICAgICAgIE91dnJpclxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgQGlmIChkZWxldGFibGUoKSkge1xuICAgICAgICA8YnV0dG9uIG1hdC1tZW51LWl0ZW0gKGNsaWNrKT1cIm9uRGVsZXRlLmVtaXQoZmlsZSlcIj5TdXBwcmltZXI8L2J1dHRvbj5cbiAgICAgICAgfVxuICAgICAgPC9tYXQtbWVudT5cbiAgICA8L2J1dHRvbj5cbiAgICB9XG4gIDwvZGl2PlxuPC9jMy1maWxlLXZpZXdlci1kaWFsb2c+XG4iXX0=
@@ -0,0 +1,43 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { C3FileDisplayGridComponent } from './c3-file-display-grid/c3-file-display-grid.component';
4
+ import { C3FileDisplayListComponent } from './c3-file-display-list/c3-file-display-list.component';
5
+ import { C3FileDisplayCardComponent } from './c3-file-display-card/c3-file-display-card.component';
6
+ import { C3FileDisplayIconComponent } from './c3-file-display-icon/c3-file-display-icon.component';
7
+ import * as i0 from "@angular/core";
8
+ export class C3FileDisplayerModule {
9
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
10
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayerModule, imports: [CommonModule,
11
+ C3FileDisplayGridComponent,
12
+ C3FileDisplayListComponent,
13
+ C3FileDisplayCardComponent,
14
+ C3FileDisplayIconComponent], exports: [C3FileDisplayGridComponent,
15
+ C3FileDisplayListComponent,
16
+ C3FileDisplayCardComponent,
17
+ C3FileDisplayIconComponent] }); }
18
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayerModule, imports: [CommonModule,
19
+ C3FileDisplayGridComponent,
20
+ C3FileDisplayListComponent,
21
+ C3FileDisplayCardComponent,
22
+ C3FileDisplayIconComponent] }); }
23
+ }
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3FileDisplayerModule, decorators: [{
25
+ type: NgModule,
26
+ args: [{
27
+ declarations: [],
28
+ imports: [
29
+ CommonModule,
30
+ C3FileDisplayGridComponent,
31
+ C3FileDisplayListComponent,
32
+ C3FileDisplayCardComponent,
33
+ C3FileDisplayIconComponent,
34
+ ],
35
+ exports: [
36
+ C3FileDisplayGridComponent,
37
+ C3FileDisplayListComponent,
38
+ C3FileDisplayCardComponent,
39
+ C3FileDisplayIconComponent,
40
+ ],
41
+ }]
42
+ }] });
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS1kaXNwbGF5ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheWVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUNuRyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUNuRyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUNuRyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQzs7QUFrQm5HLE1BQU0sT0FBTyxxQkFBcUI7OEdBQXJCLHFCQUFxQjsrR0FBckIscUJBQXFCLFlBYjlCLFlBQVk7WUFDWiwwQkFBMEI7WUFDMUIsMEJBQTBCO1lBQzFCLDBCQUEwQjtZQUMxQiwwQkFBMEIsYUFHMUIsMEJBQTBCO1lBQzFCLDBCQUEwQjtZQUMxQiwwQkFBMEI7WUFDMUIsMEJBQTBCOytHQUdqQixxQkFBcUIsWUFiOUIsWUFBWTtZQUNaLDBCQUEwQjtZQUMxQiwwQkFBMEI7WUFDMUIsMEJBQTBCO1lBQzFCLDBCQUEwQjs7MkZBU2pCLHFCQUFxQjtrQkFoQmpDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLDBCQUEwQjt3QkFDMUIsMEJBQTBCO3dCQUMxQiwwQkFBMEI7d0JBQzFCLDBCQUEwQjtxQkFDM0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDBCQUEwQjt3QkFDMUIsMEJBQTBCO3dCQUMxQiwwQkFBMEI7d0JBQzFCLDBCQUEwQjtxQkFDM0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEMzRmlsZURpc3BsYXlHcmlkQ29tcG9uZW50IH0gZnJvbSAnLi9jMy1maWxlLWRpc3BsYXktZ3JpZC9jMy1maWxlLWRpc3BsYXktZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlRGlzcGxheUxpc3RDb21wb25lbnQgfSBmcm9tICcuL2MzLWZpbGUtZGlzcGxheS1saXN0L2MzLWZpbGUtZGlzcGxheS1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDM0ZpbGVEaXNwbGF5Q2FyZENvbXBvbmVudCB9IGZyb20gJy4vYzMtZmlsZS1kaXNwbGF5LWNhcmQvYzMtZmlsZS1kaXNwbGF5LWNhcmQuY29tcG9uZW50JztcbmltcG9ydCB7IEMzRmlsZURpc3BsYXlJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9jMy1maWxlLWRpc3BsYXktaWNvbi9jMy1maWxlLWRpc3BsYXktaWNvbi5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEMzRmlsZURpc3BsYXlHcmlkQ29tcG9uZW50LFxuICAgIEMzRmlsZURpc3BsYXlMaXN0Q29tcG9uZW50LFxuICAgIEMzRmlsZURpc3BsYXlDYXJkQ29tcG9uZW50LFxuICAgIEMzRmlsZURpc3BsYXlJY29uQ29tcG9uZW50LFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgQzNGaWxlRGlzcGxheUdyaWRDb21wb25lbnQsXG4gICAgQzNGaWxlRGlzcGxheUxpc3RDb21wb25lbnQsXG4gICAgQzNGaWxlRGlzcGxheUNhcmRDb21wb25lbnQsXG4gICAgQzNGaWxlRGlzcGxheUljb25Db21wb25lbnQsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEMzRmlsZURpc3BsYXllck1vZHVsZSB7fVxuIl19
@@ -1,8 +1,6 @@
1
1
  import { BehaviorSubject, map, tap } from 'rxjs';
2
2
  import { DEFAULT_CONFIG } from '../consts/default.config';
3
- import { HttpClient } from '@angular/common/http';
4
3
  import { CustomFileEvent } from './custom-file-event.model';
5
- import { inject } from '@angular/core';
6
4
  export class C3FileViewer {
7
5
  get config() {
8
6
  return this._config;
@@ -19,16 +17,17 @@ export class C3FileViewer {
19
17
  this.currentIndex = 0;
20
18
  this.index$.next(this.currentIndex);
21
19
  this.filesObjectUrl = value.map((file) => {
20
+ const objectUrl = file.objectUrl || this.createObjectURL(file);
22
21
  return {
23
22
  ...file,
24
- objectUrl: file.objectUrl || this.createObjectURL(file),
23
+ objectUrl,
25
24
  };
26
25
  });
27
26
  }
28
27
  get files() {
29
28
  return this._files;
30
29
  }
31
- constructor({ config, files, }) {
30
+ constructor({ config, files, client, }) {
32
31
  this._config = DEFAULT_CONFIG;
33
32
  this.config$ = new BehaviorSubject(DEFAULT_CONFIG);
34
33
  this.fullscreen$ = new BehaviorSubject(false);
@@ -62,6 +61,8 @@ export class C3FileViewer {
62
61
  this.config = config;
63
62
  if (files)
64
63
  this.files = files;
64
+ if (client)
65
+ this.client = client.get.bind(client);
65
66
  this.config$.subscribe((config) => {
66
67
  const { minHeight, maxHeight, minWidth, maxWidth, height, width } = config;
67
68
  this.style.minHeight = this.valueToCss(minHeight);
@@ -79,8 +80,7 @@ export class C3FileViewer {
79
80
  return this.getFile(file.location).pipe(map((response) => URL.createObjectURL(response)), tap(() => this.onLoad(file)));
80
81
  }
81
82
  getFile(location) {
82
- const client = this.config.customClient ||
83
- inject(HttpClient).get.bind(inject(HttpClient));
83
+ const client = this.config.customClient || this.client;
84
84
  if (!client) {
85
85
  throw new Error('No http client provided. Please provide a custom client or import HttpClientModule');
86
86
  }
@@ -203,4 +203,4 @@ export class C3FileViewer {
203
203
  return result;
204
204
  }
205
205
  }
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-viewer.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-file-viewer/models/file-viewer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAc,GAAG,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAE1D,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAE5D,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,MAAM,OAAO,YAAY;IAEvB,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,IAAI,MAAM,CAAC,KAAyB;QAClC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QACvD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAUD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAChD,CAAC;IAiBD,IAAW,KAAK,CAAC,KAAqB;QACpC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAEpC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACvC,OAAO;gBACL,GAAG,IAAI;gBACP,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;aACxD,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAiBD,YAAY,EACV,MAAM,EACN,KAAK,GAIN;QA3EO,YAAO,GAAuB,cAAc,CAAC;QAS9C,YAAO,GAAG,IAAI,eAAe,CAAqB,cAAc,CAAC,CAAC;QAElE,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAElD,gBAAW,GAAG,IAAI,eAAe,CAAM,IAAI,CAAC,CAAC;QAC7C,WAAM,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QACxC,YAAO,GAAY,IAAI,CAAC;QACxB,iBAAY,GAAW,CAAC,CAAC;QAMzB,UAAK,GAAG;YACb,SAAS,EAAE,EAAE;YACb,WAAW,EAAE,EAAE;YACf,UAAU,EAAE,EAAE;YACd,eAAe,EAAE,EAAE;YACnB,SAAS,EAAE,MAAM;YACjB,SAAS,EAAE,MAAM;YACjB,MAAM,EAAE,MAAM;YACd,QAAQ,EAAE,MAAM;YAChB,QAAQ,EAAE,MAAM;YAChB,KAAK,EAAE,MAAM;SACd,CAAC;QACK,gBAAW,GAAG,MAAM,CAAC;QACrB,YAAO,GAAG,KAAK,CAAC;QAmBf,WAAM,GAAmB,EAAE,CAAC;QAE7B,mBAAc,GAIjB,EAAE,CAAC;QAEC,UAAK,GAAG,CAAC,CAAC;QACV,aAAQ,GAAG,CAAC,CAAC;QACb,eAAU,GAAG,CAAC,CAAC;QACf,eAAU,GAAG,CAAC,CAAC;QACf,UAAK,GAAW,CAAC,CAAC;QAClB,UAAK,GAAW,CAAC,CAAC;QASxB,IAAI,MAAM;YAAE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACjC,IAAI,KAAK;YAAE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAE9B,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAChC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,GAC/D,MAAM,CAAC;YACT,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YAClD,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YAC1C,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YAClD,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAChD,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAChD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YAE3C,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,IAAkB;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACvB,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CACrC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,EAChD,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAC7B,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,QAAgB;QACtB,MAAM,MAAM,GACV,IAAI,CAAC,MAAM,CAAC,YAAY;YACxB,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QAClD,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CACb,oFAAoF,CACrF,CAAC;QACJ,CAAC;QAED,OAAO,MAAM,CAAC,QAAQ,EAAE;YACtB,YAAY,EAAE,MAAM;SACrB,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,KAAiC;QAC7C,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC;gBAAE,IAAI,CAAC,YAAY,EAAE,CAAC;;gBAC1C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACpC,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IAED,SAAS,CAAC,KAAiC;QACzC,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;gBAAE,IAAI,CAAC,YAAY,EAAE,CAAC;;gBAC9D,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACpC,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,CAAC,CAAC;QAChD,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,CAAC,EAAE,CAAC;YAC/C,IAAI,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,CAAC,CAAC;QAClD,CAAC;QACD,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,UAAU,CAAC,GAAe;QACxB,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YAC1B,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YAChD,OAAO,KAAK,CAAC;QACf,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,sBAAsB;QACpB,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,IAAkB;QACvB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,WAAW,CAAC,IAAkB;QAC5B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,aAAa,CAAC,IAAkB;QAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED,UAAU,CAAC,GAAc;QACvB,IAAI,CAAC,UAAU,IAAI,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5C,IAAI,CAAC,UAAU,IAAI,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5C,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;QACzB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,WAAW,CAAC,GAAc;QACxB,IAAI,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,YAAY,IAAI,GAAG,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;YACpE,MAAM,MAAM,GAAG,GAAG,CAAC,MAAwB,CAAC;YAC5C,MAAM,kBAAkB,GAAG,MAAM,CAAC,kBAAoC,CAAC;YAEvE,IAAI,kBAAkB;gBACpB,GAAG,CAAC,YAAY,CAAC,YAAY,CAAC,kBAAkB,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5D,CAAC;QACD,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;IAC3B,CAAC;IAED,gBAAgB;QACd,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,eAAe,CAAC,CAAC;QACxC,IAAI,eAAe;YAAE,IAAI,CAAC,KAAK,EAAE,CAAC;IACpC,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;QAClB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEO,WAAW,CAAC,KAAU;QAC5B,OAAO,CACL,KAAK,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,uBAAuB,IAAI,IAAI,CAAC,OAAO,CAAC,CACvE,CAAC;IACJ,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,aAAa,IAAI,CAAC,UAAU,OAAO,IAAI,CAAC,UAAU,cAAc,IAAI,CAAC,QAAQ,cAAc,IAAI,CAAC,KAAK,GAAG,CAAC;QAChI,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QAC9C,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QAClD,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;IAC/C,CAAC;IAEO,UAAU,CAAC,KAAkC;QACnD,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IAC7E,CAAC;IAEO,WAAW,CACjB,aAAiC,EACjC,cAAkC;QAElC,IAAI,MAAM,GAAuB,EAAE,GAAG,aAAa,EAAE,CAAC;QACtD,IAAI,cAAc,EAAE,CAAC;YACnB,MAAM,GAAG,EAAE,GAAG,aAAa,EAAE,GAAG,cAAc,EAAE,CAAC;YAEjD,IAAI,cAAc,CAAC,QAAQ,EAAE,CAAC;gBAC5B,MAAM,CAAC,QAAQ,GAAG;oBAChB,GAAG,aAAa,CAAC,QAAQ;oBACzB,GAAG,cAAc,CAAC,QAAQ;iBAC3B,CAAC;YACJ,CAAC;QACH,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;CACF","sourcesContent":["import { BehaviorSubject, Observable, map, tap } from 'rxjs';\nimport { DEFAULT_CONFIG } from '../consts/default.config';\nimport { C3FileViewerConfig } from './file-viewer-config.model';\nimport { HttpClient } from '@angular/common/http';\nimport { CustomFileEvent } from './custom-file-event.model';\nimport { FileMetadata } from './file-metadata';\nimport { inject } from '@angular/core';\n\nexport class C3FileViewer {\n  private _config: C3FileViewerConfig = DEFAULT_CONFIG;\n  get config(): C3FileViewerConfig {\n    return this._config;\n  }\n\n  set config(value: C3FileViewerConfig) {\n    this._config = this.mergeConfig(DEFAULT_CONFIG, value);\n    this.config$.next(this._config);\n  }\n  public config$ = new BehaviorSubject<C3FileViewerConfig>(DEFAULT_CONFIG);\n\n  public fullscreen$ = new BehaviorSubject<Boolean>(false);\n\n  public customFile$ = new BehaviorSubject<any>(null);\n  public index$ = new BehaviorSubject<number>(0);\n  public loading: boolean = true;\n  public currentIndex: number = 0;\n\n  get currentFile(): FileMetadata {\n    return this.filesObjectUrl[this.currentIndex];\n  }\n\n  public style = {\n    transform: '',\n    msTransform: '',\n    oTransform: '',\n    webkitTransform: '',\n    minHeight: 'auto',\n    maxHeight: 'auto',\n    height: 'auto',\n    minWidth: 'auto',\n    maxWidth: 'auto',\n    width: 'auto',\n  };\n  public styleHeight = '100%';\n  public hovered = false;\n\n  public set files(value: FileMetadata[]) {\n    this._files = value;\n    this.currentIndex = 0;\n    this.index$.next(this.currentIndex);\n\n    this.filesObjectUrl = value.map((file) => {\n      return {\n        ...file,\n        objectUrl: file.objectUrl || this.createObjectURL(file),\n      };\n    });\n  }\n\n  public get files(): FileMetadata[] {\n    return this._files;\n  }\n\n  private _files: FileMetadata[] = [];\n\n  public filesObjectUrl: Array<\n    FileMetadata & {\n      objectUrl?: Observable<string>;\n    }\n  > = [];\n\n  private scale = 1;\n  private rotation = 0;\n  private translateX = 0;\n  private translateY = 0;\n  private prevX: number = 0;\n  private prevY: number = 0;\n\n  constructor({\n    config,\n    files,\n  }: {\n    config?: C3FileViewerConfig;\n    files?: FileMetadata[];\n  }) {\n    if (config) this.config = config;\n    if (files) this.files = files;\n\n    this.config$.subscribe((config) => {\n      const { minHeight, maxHeight, minWidth, maxWidth, height, width } =\n        config;\n      this.style.minHeight = this.valueToCss(minHeight);\n      this.style.height = this.valueToCss(height);\n      this.style.width = this.valueToCss(width);\n      this.style.maxHeight = this.valueToCss(maxHeight);\n      this.style.minWidth = this.valueToCss(minWidth);\n      this.style.maxWidth = this.valueToCss(maxWidth);\n      this.styleHeight = this.valueToCss(height);\n\n      this.updateStyle();\n    });\n  }\n\n  createObjectURL(file: FileMetadata) {\n    this.onLoadStart(file);\n    return this.getFile(file.location).pipe(\n      map((response) => URL.createObjectURL(response)),\n      tap(() => this.onLoad(file))\n    );\n  }\n\n  getFile(location: string) {\n    const client =\n      this.config.customClient ||\n      inject(HttpClient).get.bind(inject(HttpClient));\n    if (!client) {\n      throw new Error(\n        'No http client provided. Please provide a custom client or import HttpClientModule'\n      );\n    }\n\n    return client(location, {\n      responseType: 'blob',\n    });\n  }\n\n  previousImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex > 0) this.currentIndex--;\n      else this.currentIndex = this.files.length - 1;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  nextImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex < this.files.length - 1) this.currentIndex++;\n      else this.currentIndex = 0;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  zoomIn() {\n    this.scale *= 1 + (this.config.zoomFactor || 0);\n    this.updateStyle();\n  }\n\n  zoomOut() {\n    if (this.scale > (this.config.zoomFactor || 0)) {\n      this.scale /= 1 + (this.config.zoomFactor || 0);\n    }\n    this.updateStyle();\n  }\n\n  scrollZoom(evt: WheelEvent) {\n    if (this.config.wheelZoom) {\n      evt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  rotateClockwise() {\n    this.rotation += 90;\n    this.updateStyle();\n  }\n\n  rotateCounterClockwise() {\n    this.rotation -= 90;\n    this.updateStyle();\n  }\n\n  onLoad(file: FileMetadata) {\n    this.loading = false;\n  }\n\n  onLoadStart(file: FileMetadata) {\n    this.loading = true;\n  }\n\n  imageNotFound(file: FileMetadata) {\n    this.loading = false;\n    this.customFile$.next(new CustomFileEvent('imageNotFound', file.location));\n  }\n\n  onDragOver(evt: DragEvent) {\n    this.translateX += evt.clientX - this.prevX;\n    this.translateY += evt.clientY - this.prevY;\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n    this.updateStyle();\n  }\n\n  onDragStart(evt: DragEvent) {\n    if (evt.target && evt.dataTransfer && evt.dataTransfer.setDragImage) {\n      const target = evt.target as HTMLDivElement;\n      const nextElementSibling = target.nextElementSibling as HTMLDivElement;\n\n      if (nextElementSibling)\n        evt.dataTransfer.setDragImage(nextElementSibling, 0, 0);\n    }\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n  }\n\n  toggleFullscreen() {\n    const fullScreenValue = this.fullscreen$.getValue();\n    this.fullscreen$.next(!fullScreenValue);\n    if (fullScreenValue) this.reset();\n  }\n\n  reset() {\n    this.scale = 1;\n    this.rotation = 0;\n    this.translateX = 0;\n    this.translateY = 0;\n    this.updateStyle();\n  }\n\n  private canNavigate(event: any) {\n    return (\n      event == null || (this.config.allowKeyboardNavigation && this.hovered)\n    );\n  }\n\n  private updateStyle() {\n    this.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n    this.style.msTransform = this.style.transform;\n    this.style.webkitTransform = this.style.transform;\n    this.style.oTransform = this.style.transform;\n  }\n\n  private valueToCss(value: number | string | undefined) {\n    return value ? (typeof value === 'string' ? value : value + 'px') : 'auto';\n  }\n\n  private mergeConfig(\n    defaultValues: C3FileViewerConfig,\n    overrideValues: C3FileViewerConfig\n  ): C3FileViewerConfig {\n    let result: C3FileViewerConfig = { ...defaultValues };\n    if (overrideValues) {\n      result = { ...defaultValues, ...overrideValues };\n\n      if (overrideValues.btnIcons) {\n        result.btnIcons = {\n          ...defaultValues.btnIcons,\n          ...overrideValues.btnIcons,\n        };\n      }\n    }\n    return result;\n  }\n}\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-viewer.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-file-viewer/models/file-viewer.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Observable, map, tap } from 'rxjs';\nimport { DEFAULT_CONFIG } from '../consts/default.config';\nimport { C3FileViewerConfig } from './file-viewer-config.model';\nimport { HttpClient } from '@angular/common/http';\nimport { CustomFileEvent } from './custom-file-event.model';\nimport { FileMetadata } from './file-metadata';\n\nexport class C3FileViewer {\n  private _config: C3FileViewerConfig = DEFAULT_CONFIG;\n  private client: HttpClient['get'] | undefined;\n  get config(): C3FileViewerConfig {\n    return this._config;\n  }\n\n  set config(value: C3FileViewerConfig) {\n    this._config = this.mergeConfig(DEFAULT_CONFIG, value);\n    this.config$.next(this._config);\n  }\n  public config$ = new BehaviorSubject<C3FileViewerConfig>(DEFAULT_CONFIG);\n\n  public fullscreen$ = new BehaviorSubject<Boolean>(false);\n\n  public customFile$ = new BehaviorSubject<any>(null);\n  public index$ = new BehaviorSubject<number>(0);\n  public loading: boolean = true;\n  public currentIndex: number = 0;\n\n  get currentFile(): FileMetadata {\n    return this.filesObjectUrl[this.currentIndex];\n  }\n\n  public style = {\n    transform: '',\n    msTransform: '',\n    oTransform: '',\n    webkitTransform: '',\n    minHeight: 'auto',\n    maxHeight: 'auto',\n    height: 'auto',\n    minWidth: 'auto',\n    maxWidth: 'auto',\n    width: 'auto',\n  };\n  public styleHeight = '100%';\n  public hovered = false;\n\n  public set files(value: FileMetadata[]) {\n    this._files = value;\n    this.currentIndex = 0;\n    this.index$.next(this.currentIndex);\n\n    this.filesObjectUrl = value.map((file) => {\n      const objectUrl = file.objectUrl || this.createObjectURL(file);\n      return {\n        ...file,\n        objectUrl,\n      };\n    });\n  }\n\n  public get files(): FileMetadata[] {\n    return this._files;\n  }\n\n  private _files: FileMetadata[] = [];\n\n  public filesObjectUrl: Array<\n    FileMetadata & {\n      objectUrl: Observable<string>;\n    }\n  > = [];\n\n  private scale = 1;\n  private rotation = 0;\n  private translateX = 0;\n  private translateY = 0;\n  private prevX: number = 0;\n  private prevY: number = 0;\n\n  constructor({\n    config,\n    files,\n    client,\n  }: {\n    config?: C3FileViewerConfig;\n    files?: FileMetadata[];\n    client: HttpClient;\n  }) {\n    if (config) this.config = config;\n    if (files) this.files = files;\n    if (client) this.client = client.get.bind(client);\n\n    this.config$.subscribe((config) => {\n      const { minHeight, maxHeight, minWidth, maxWidth, height, width } =\n        config;\n      this.style.minHeight = this.valueToCss(minHeight);\n      this.style.height = this.valueToCss(height);\n      this.style.width = this.valueToCss(width);\n      this.style.maxHeight = this.valueToCss(maxHeight);\n      this.style.minWidth = this.valueToCss(minWidth);\n      this.style.maxWidth = this.valueToCss(maxWidth);\n      this.styleHeight = this.valueToCss(height);\n\n      this.updateStyle();\n    });\n  }\n\n  createObjectURL(file: FileMetadata) {\n    this.onLoadStart(file);\n    return this.getFile(file.location).pipe(\n      map((response) => URL.createObjectURL(response)),\n      tap(() => this.onLoad(file))\n    );\n  }\n\n  getFile(location: string) {\n    const client = this.config.customClient || this.client;\n    if (!client) {\n      throw new Error(\n        'No http client provided. Please provide a custom client or import HttpClientModule'\n      );\n    }\n\n    return client(location, {\n      responseType: 'blob',\n    });\n  }\n\n  previousImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex > 0) this.currentIndex--;\n      else this.currentIndex = this.files.length - 1;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  nextImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex < this.files.length - 1) this.currentIndex++;\n      else this.currentIndex = 0;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  zoomIn() {\n    this.scale *= 1 + (this.config.zoomFactor || 0);\n    this.updateStyle();\n  }\n\n  zoomOut() {\n    if (this.scale > (this.config.zoomFactor || 0)) {\n      this.scale /= 1 + (this.config.zoomFactor || 0);\n    }\n    this.updateStyle();\n  }\n\n  scrollZoom(evt: WheelEvent) {\n    if (this.config.wheelZoom) {\n      evt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  rotateClockwise() {\n    this.rotation += 90;\n    this.updateStyle();\n  }\n\n  rotateCounterClockwise() {\n    this.rotation -= 90;\n    this.updateStyle();\n  }\n\n  onLoad(file: FileMetadata) {\n    this.loading = false;\n  }\n\n  onLoadStart(file: FileMetadata) {\n    this.loading = true;\n  }\n\n  imageNotFound(file: FileMetadata) {\n    this.loading = false;\n    this.customFile$.next(new CustomFileEvent('imageNotFound', file.location));\n  }\n\n  onDragOver(evt: DragEvent) {\n    this.translateX += evt.clientX - this.prevX;\n    this.translateY += evt.clientY - this.prevY;\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n    this.updateStyle();\n  }\n\n  onDragStart(evt: DragEvent) {\n    if (evt.target && evt.dataTransfer && evt.dataTransfer.setDragImage) {\n      const target = evt.target as HTMLDivElement;\n      const nextElementSibling = target.nextElementSibling as HTMLDivElement;\n\n      if (nextElementSibling)\n        evt.dataTransfer.setDragImage(nextElementSibling, 0, 0);\n    }\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n  }\n\n  toggleFullscreen() {\n    const fullScreenValue = this.fullscreen$.getValue();\n    this.fullscreen$.next(!fullScreenValue);\n    if (fullScreenValue) this.reset();\n  }\n\n  reset() {\n    this.scale = 1;\n    this.rotation = 0;\n    this.translateX = 0;\n    this.translateY = 0;\n    this.updateStyle();\n  }\n\n  private canNavigate(event: any) {\n    return (\n      event == null || (this.config.allowKeyboardNavigation && this.hovered)\n    );\n  }\n\n  private updateStyle() {\n    this.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n    this.style.msTransform = this.style.transform;\n    this.style.webkitTransform = this.style.transform;\n    this.style.oTransform = this.style.transform;\n  }\n\n  private valueToCss(value: number | string | undefined) {\n    return value ? (typeof value === 'string' ? value : value + 'px') : 'auto';\n  }\n\n  private mergeConfig(\n    defaultValues: C3FileViewerConfig,\n    overrideValues: C3FileViewerConfig\n  ): C3FileViewerConfig {\n    let result: C3FileViewerConfig = { ...defaultValues };\n    if (overrideValues) {\n      result = { ...defaultValues, ...overrideValues };\n\n      if (overrideValues.btnIcons) {\n        result.btnIcons = {\n          ...defaultValues.btnIcons,\n          ...overrideValues.btnIcons,\n        };\n      }\n    }\n    return result;\n  }\n}\n"]}
@@ -28,6 +28,14 @@ export * from './lib/c3-file-viewer/models/file-viewer-config.model';
28
28
  export * from './lib/c3-file-viewer/models/file-viewer';
29
29
  export * from './lib/c3-file-viewer/models/file-metadata';
30
30
  export * from './lib/c3-file-viewer/c3-file-viewer.module';
31
+ /**
32
+ * File Displayer
33
+ */
34
+ export * from './lib/c3-file-displayer/c3-file-displayer.module';
35
+ export * from './lib/c3-file-displayer/c3-file-display-list/c3-file-display-list.component';
36
+ export * from './lib/c3-file-displayer/c3-file-display-icon/c3-file-display-icon.component';
37
+ export * from './lib/c3-file-displayer/c3-file-display-grid/c3-file-display-grid.component';
38
+ export * from './lib/c3-file-displayer/c3-file-display-card/c3-file-display-card.component';
31
39
  /**
32
40
  * Safe Url
33
41
  */
@@ -50,5 +58,4 @@ export * from './lib/c3-select-on-focus/c3-select-on-focus.directive';
50
58
  * Toggle Signal
51
59
  */
52
60
  export * from './lib/c3-signals/c3-boolean-signal';
53
- export * from './lib/c3-signals/c3-signal';
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBRXhEOztHQUVHO0FBQ0gsY0FBYyxvREFBb0QsQ0FBQztBQUNuRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0NBQXNDLENBQUM7QUFFckQ7O0dBRUc7QUFDSCxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsa0NBQWtDLENBQUM7QUFFakQ7O0dBRUc7QUFDSCxjQUFjLGdGQUFnRixDQUFDO0FBQy9GLGNBQWMsOEZBQThGLENBQUM7QUFDN0csY0FBYyxvRkFBb0YsQ0FBQztBQUNuRyxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw0Q0FBNEMsQ0FBQztBQUUzRDs7R0FFRztBQUNILGNBQWMsMENBQTBDLENBQUM7QUFFekQ7O0dBRUc7QUFDSCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsbUVBQW1FLENBQUM7QUFDbEYsY0FBYyxpRkFBaUYsQ0FBQztBQUVoRzs7R0FFRztBQUNILGNBQWMsaURBQWlELENBQUM7QUFFaEU7O0dBRUc7QUFDSCxjQUFjLHVEQUF1RCxDQUFDO0FBRXRFOztHQUVHO0FBQ0gsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjMy1jb21wb25lbnRzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2h0dHAuY2xpZW50JztcblxuLyoqXG4gKiBEcm9wZG93blxuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1kcm9wZG93bi9jb21wb25lbnRzL2MzLWRyb3Bkb3duLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1kcm9wZG93bi9kaXJlY3RpdmVzL2MzLWRyb3Bkb3duLnRyaWdnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZHJvcGRvd24vYzMtZHJvcGRvd24ubW9kdWxlJztcblxuLyoqXG4gKiBEaWFsb2dcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZGlhbG9nL2NvbXBvbmVudHMvYzMtZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9jb21wb25lbnRzL2MzLWRpYWxvZy1wcm9tcHQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9jb21wb25lbnRzL2MzLWRpYWxvZy1lbWJlZC1jaGlsZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZGlhbG9nL3NlcnZpY2VzL2MzLWRpYWxvZy5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9jMy1kaWFsb2cubW9kdWxlJztcblxuLyoqXG4gKiBGaWxlIFZpZXdlclxuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci9jMy1maWxlLXZpZXdlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1maWxlLXZpZXdlci9kaXJlY3RpdmVzL2Z1bGwtc2NyZWVuLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1maWxlLXZpZXdlci9tb2RlbHMvY3VzdG9tLWZpbGUtZXZlbnQubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1maWxlLXZpZXdlci9tb2RlbHMvZmlsZS12aWV3ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtbWV0YWRhdGEnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIubW9kdWxlJztcblxuLyoqXG4gKiBTYWZlIFVybFxuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1zYWZlLXVybC9waXBlcy9jMy1zYWZlLXVybC5waXBlJztcblxuLyoqXG4gKiBFeHBhbnNpb25cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZXhwYW5zaW9uL2MzLWV4cGFuc2lvbi5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZXhwYW5zaW9uL2NvbXBvbmVudHMvYzMtZXhwYW5zaW9uL2MzLWV4cGFuc2lvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZXhwYW5zaW9uL2NvbXBvbmVudHMvYzMtZXhwYW5zaW9uLWhlYWRlci9jMy1leHBhbnNpb24taGVhZGVyLmNvbXBvbmVudCc7XG5cbi8qKlxuICogQXV0byBBbmltYXRlXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWF1dG8tYW5pbWF0ZS9jMy1hdXRvLWFuaW1hdGUuZGlyZWN0aXZlJztcblxuLyoqXG4gKiBTZWxlY3Qgb24gRm9jdXNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtc2VsZWN0LW9uLWZvY3VzL2MzLXNlbGVjdC1vbi1mb2N1cy5kaXJlY3RpdmUnO1xuXG4vKipcbiAqIFRvZ2dsZSBTaWduYWxcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtc2lnbmFscy9jMy1ib29sZWFuLXNpZ25hbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1zaWduYWxzL2MzLXNpZ25hbCc7XG4iXX0=
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBRXhEOztHQUVHO0FBQ0gsY0FBYyxvREFBb0QsQ0FBQztBQUNuRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0NBQXNDLENBQUM7QUFFckQ7O0dBRUc7QUFDSCxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsa0NBQWtDLENBQUM7QUFFakQ7O0dBRUc7QUFDSCxjQUFjLGdGQUFnRixDQUFDO0FBQy9GLGNBQWMsOEZBQThGLENBQUM7QUFDN0csY0FBYyxvRkFBb0YsQ0FBQztBQUNuRyxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw0Q0FBNEMsQ0FBQztBQUUzRDs7R0FFRztBQUNILGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyw2RUFBNkUsQ0FBQztBQUM1RixjQUFjLDZFQUE2RSxDQUFDO0FBQzVGLGNBQWMsNkVBQTZFLENBQUM7QUFDNUYsY0FBYyw2RUFBNkUsQ0FBQztBQUU1Rjs7R0FFRztBQUNILGNBQWMsMENBQTBDLENBQUM7QUFFekQ7O0dBRUc7QUFDSCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsbUVBQW1FLENBQUM7QUFDbEYsY0FBYyxpRkFBaUYsQ0FBQztBQUVoRzs7R0FFRztBQUNILGNBQWMsaURBQWlELENBQUM7QUFFaEU7O0dBRUc7QUFDSCxjQUFjLHVEQUF1RCxDQUFDO0FBRXRFOztHQUVHO0FBQ0gsY0FBYyxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYzMtY29tcG9uZW50c1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL21vZGVscy9odHRwLmNsaWVudCc7XG5cbi8qKlxuICogRHJvcGRvd25cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZHJvcGRvd24vY29tcG9uZW50cy9jMy1kcm9wZG93bi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZHJvcGRvd24vZGlyZWN0aXZlcy9jMy1kcm9wZG93bi50cmlnZ2VyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRyb3Bkb3duL2MzLWRyb3Bkb3duLm1vZHVsZSc7XG5cbi8qKlxuICogRGlhbG9nXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9jb21wb25lbnRzL2MzLWRpYWxvZy1jb25maXJtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1kaWFsb2cvY29tcG9uZW50cy9jMy1kaWFsb2ctcHJvbXB0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1kaWFsb2cvY29tcG9uZW50cy9jMy1kaWFsb2ctZW1iZWQtY2hpbGQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9zZXJ2aWNlcy9jMy1kaWFsb2cuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1kaWFsb2cvYzMtZGlhbG9nLm1vZHVsZSc7XG5cbi8qKlxuICogRmlsZSBWaWV3ZXJcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvcHVibGljL2MzLWZpbGUtdmlld2VyLWRpYWxvZy9jMy1maWxlLXZpZXdlci1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvcHVibGljL2MzLWZpbGUtdmlld2VyLWRpYWxvZy9jMy1maWxlLXZpZXdlci1kaWFsb2cnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvZGlyZWN0aXZlcy9mdWxsLXNjcmVlbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2N1c3RvbS1maWxlLWV2ZW50Lm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLXZpZXdlci1jb25maWcubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtdmlld2VyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLW1ldGFkYXRhJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLm1vZHVsZSc7XG5cbi8qKlxuICogRmlsZSBEaXNwbGF5ZXJcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS1kaXNwbGF5ZXIvYzMtZmlsZS1kaXNwbGF5ZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1saXN0L2MzLWZpbGUtZGlzcGxheS1saXN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1maWxlLWRpc3BsYXllci9jMy1maWxlLWRpc3BsYXktaWNvbi9jMy1maWxlLWRpc3BsYXktaWNvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS1kaXNwbGF5ZXIvYzMtZmlsZS1kaXNwbGF5LWdyaWQvYzMtZmlsZS1kaXNwbGF5LWdyaWQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtZGlzcGxheWVyL2MzLWZpbGUtZGlzcGxheS1jYXJkL2MzLWZpbGUtZGlzcGxheS1jYXJkLmNvbXBvbmVudCc7XG5cbi8qKlxuICogU2FmZSBVcmxcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtc2FmZS11cmwvcGlwZXMvYzMtc2FmZS11cmwucGlwZSc7XG5cbi8qKlxuICogRXhwYW5zaW9uXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWV4cGFuc2lvbi9jMy1leHBhbnNpb24ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWV4cGFuc2lvbi9jb21wb25lbnRzL2MzLWV4cGFuc2lvbi9jMy1leHBhbnNpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWV4cGFuc2lvbi9jb21wb25lbnRzL2MzLWV4cGFuc2lvbi1oZWFkZXIvYzMtZXhwYW5zaW9uLWhlYWRlci5jb21wb25lbnQnO1xuXG4vKipcbiAqIEF1dG8gQW5pbWF0ZVxuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1hdXRvLWFuaW1hdGUvYzMtYXV0by1hbmltYXRlLmRpcmVjdGl2ZSc7XG5cbi8qKlxuICogU2VsZWN0IG9uIEZvY3VzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLXNlbGVjdC1vbi1mb2N1cy9jMy1zZWxlY3Qtb24tZm9jdXMuZGlyZWN0aXZlJztcblxuLyoqXG4gKiBUb2dnbGUgU2lnbmFsXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLXNpZ25hbHMvYzMtYm9vbGVhbi1zaWduYWwnO1xuIl19