c3-components 0.0.0-watch → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/c3-components.mjs +5 -0
- package/esm2020/lib/c3-dialog/c3-dialog.module.mjs +56 -0
- package/esm2020/lib/c3-dialog/components/c3-dialog-confirm.component.mjs +52 -0
- package/esm2020/lib/c3-dialog/components/c3-dialog-embed-child.component.mjs +32 -0
- package/esm2020/lib/c3-dialog/components/c3-dialog-prompt.component.mjs +95 -0
- package/esm2020/lib/c3-dialog/services/c3-dialog.service.mjs +79 -0
- package/esm2020/lib/c3-dropdown/c3-dropdown.module.mjs +20 -0
- package/esm2020/lib/c3-dropdown/components/c3-dropdown.component.mjs +45 -0
- package/esm2020/lib/c3-dropdown/directives/c3-dropdown.trigger.mjs +128 -0
- package/esm2020/lib/c3-file-viewer/c3-file-viewer.module.mjs +38 -0
- package/esm2020/lib/c3-file-viewer/components/c3-file-viewer/c3-file-viewer.component.mjs +84 -0
- package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-actions/c3-file-viewer-actions.component.mjs +17 -0
- package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-image/c3-file-viewer-image.component.mjs +20 -0
- package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-pdf/c3-file-viewer-pdf.component.mjs +23 -0
- package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-video/c3-file-viewer-video.component.mjs +32 -0
- package/esm2020/lib/c3-file-viewer/consts/default.config.mjs +40 -0
- package/esm2020/lib/c3-file-viewer/directives/full-screen.directive.mjs +66 -0
- package/esm2020/lib/c3-file-viewer/models/custom-file-event.model.mjs +7 -0
- package/esm2020/lib/c3-file-viewer/models/file-metadata.mjs +2 -0
- package/esm2020/lib/c3-file-viewer/models/file-viewer-config.model.mjs +2 -0
- package/esm2020/lib/c3-file-viewer/models/file-viewer.mjs +205 -0
- package/esm2020/lib/c3-file-viewer/models/http.client.mjs +2 -0
- package/esm2020/lib/c3-safe-url/pipes/c3-safe-url.pipe.mjs +21 -0
- package/esm2020/public-api.mjs +33 -0
- package/fesm2015/c3-components.mjs +1001 -0
- package/fesm2015/c3-components.mjs.map +1 -0
- package/fesm2020/c3-components.mjs +997 -0
- package/fesm2020/c3-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/c3-dialog/c3-dialog.module.d.ts +16 -0
- package/lib/c3-dialog/components/c3-dialog-confirm.component.d.ts +23 -0
- package/lib/c3-dialog/components/c3-dialog-embed-child.component.d.ts +18 -0
- package/lib/c3-dialog/components/c3-dialog-prompt.component.d.ts +31 -0
- package/lib/c3-dialog/services/c3-dialog.service.d.ts +19 -0
- package/lib/c3-dropdown/c3-dropdown.module.d.ts +10 -0
- package/lib/c3-dropdown/components/c3-dropdown.component.d.ts +15 -0
- package/lib/c3-dropdown/directives/c3-dropdown.trigger.d.ts +45 -0
- package/lib/c3-dropdown/styles/_c3-dropdown.sass +22 -0
- package/lib/c3-file-viewer/c3-file-viewer.module.d.ts +15 -0
- package/lib/c3-file-viewer/components/c3-file-viewer/c3-file-viewer.component.d.ts +24 -0
- package/lib/c3-file-viewer/components/c3-file-viewer-actions/c3-file-viewer-actions.component.d.ts +8 -0
- package/lib/c3-file-viewer/components/c3-file-viewer-image/c3-file-viewer-image.component.d.ts +9 -0
- package/lib/c3-file-viewer/components/c3-file-viewer-pdf/c3-file-viewer-pdf.component.d.ts +9 -0
- package/lib/c3-file-viewer/components/c3-file-viewer-video/c3-file-viewer-video.component.d.ts +12 -0
- package/lib/c3-file-viewer/consts/default.config.d.ts +2 -0
- package/lib/c3-file-viewer/directives/full-screen.directive.d.ts +12 -0
- package/lib/c3-file-viewer/models/custom-file-event.model.d.ts +5 -0
- package/lib/c3-file-viewer/models/file-metadata.d.ts +12 -0
- package/lib/c3-file-viewer/models/file-viewer-config.model.d.ts +48 -0
- package/lib/c3-file-viewer/models/file-viewer.d.ts +68 -0
- package/lib/c3-file-viewer/models/http.client.d.ts +14 -0
- package/lib/c3-file-viewer/styles/_c3-file-viewer.sass +116 -0
- package/lib/c3-safe-url/pipes/c3-safe-url.pipe.d.ts +10 -0
- package/lib/c3-styles/_c3-core.sass +8 -0
- package/lib/c3-styles/_c3-root-variables.sass +107 -0
- package/lib/c3-styles/_utils.sass +27 -0
- package/package.json +1 -4
- package/public-api.d.ts +29 -0
- package/src/lib/c3-file/c3-input-file/components/c3-input-file/c3-input-file.component.scss +3 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { FullScreenDirective } from './directives/full-screen.directive';
|
|
3
|
+
import { C3FileViewerComponent } from './components/c3-file-viewer/c3-file-viewer.component';
|
|
4
|
+
import { CommonModule } from '@angular/common';
|
|
5
|
+
import { C3FileViewerActionsComponent } from './components/c3-file-viewer-actions/c3-file-viewer-actions.component';
|
|
6
|
+
import { C3FileViewerImageComponent } from './components/c3-file-viewer-image/c3-file-viewer-image.component';
|
|
7
|
+
import { C3FileViewerPdfComponent } from './components/c3-file-viewer-pdf/c3-file-viewer-pdf.component';
|
|
8
|
+
import { C3FileViewerVideoComponent } from './components/c3-file-viewer-video/c3-file-viewer-video.component';
|
|
9
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
10
|
+
import { C3SafeUrlPipe } from '../../public-api';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
export class C3FileViewerModule {
|
|
13
|
+
}
|
|
14
|
+
C3FileViewerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
15
|
+
C3FileViewerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, declarations: [FullScreenDirective,
|
|
16
|
+
C3FileViewerComponent,
|
|
17
|
+
C3FileViewerActionsComponent,
|
|
18
|
+
C3FileViewerImageComponent,
|
|
19
|
+
C3FileViewerPdfComponent,
|
|
20
|
+
C3FileViewerVideoComponent], imports: [CommonModule, HttpClientModule, C3SafeUrlPipe], exports: [FullScreenDirective, C3FileViewerComponent] });
|
|
21
|
+
C3FileViewerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, imports: [CommonModule, HttpClientModule] });
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, decorators: [{
|
|
23
|
+
type: NgModule,
|
|
24
|
+
args: [{
|
|
25
|
+
providers: [],
|
|
26
|
+
declarations: [
|
|
27
|
+
FullScreenDirective,
|
|
28
|
+
C3FileViewerComponent,
|
|
29
|
+
C3FileViewerActionsComponent,
|
|
30
|
+
C3FileViewerImageComponent,
|
|
31
|
+
C3FileViewerPdfComponent,
|
|
32
|
+
C3FileViewerVideoComponent,
|
|
33
|
+
],
|
|
34
|
+
imports: [CommonModule, HttpClientModule, C3SafeUrlPipe],
|
|
35
|
+
exports: [FullScreenDirective, C3FileViewerComponent],
|
|
36
|
+
}]
|
|
37
|
+
}] });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzdGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQztBQUNwSCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUM5RyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQztBQUN4RyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUM5RyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7O0FBZWpELE1BQU0sT0FBTyxrQkFBa0I7OytHQUFsQixrQkFBa0I7Z0hBQWxCLGtCQUFrQixpQkFWM0IsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQiw0QkFBNEI7UUFDNUIsMEJBQTBCO1FBQzFCLHdCQUF3QjtRQUN4QiwwQkFBMEIsYUFFbEIsWUFBWSxFQUFFLGdCQUFnQixFQUFFLGFBQWEsYUFDN0MsbUJBQW1CLEVBQUUscUJBQXFCO2dIQUV6QyxrQkFBa0IsWUFIbkIsWUFBWSxFQUFFLGdCQUFnQjsyRkFHN0Isa0JBQWtCO2tCQWI5QixRQUFRO21CQUFDO29CQUNSLFNBQVMsRUFBRSxFQUFFO29CQUNiLFlBQVksRUFBRTt3QkFDWixtQkFBbUI7d0JBQ25CLHFCQUFxQjt3QkFDckIsNEJBQTRCO3dCQUM1QiwwQkFBMEI7d0JBQzFCLHdCQUF3Qjt3QkFDeEIsMEJBQTBCO3FCQUMzQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsYUFBYSxDQUFDO29CQUN4RCxPQUFPLEVBQUUsQ0FBQyxtQkFBbUIsRUFBRSxxQkFBcUIsQ0FBQztpQkFDdEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRnVsbFNjcmVlbkRpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9mdWxsLXNjcmVlbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQWN0aW9uc0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1maWxlLXZpZXdlci1hY3Rpb25zL2MzLWZpbGUtdmlld2VyLWFjdGlvbnMuY29tcG9uZW50JztcbmltcG9ydCB7IEMzRmlsZVZpZXdlckltYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLWltYWdlL2MzLWZpbGUtdmlld2VyLWltYWdlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDM0ZpbGVWaWV3ZXJQZGZDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItcGRmL2MzLWZpbGUtdmlld2VyLXBkZi5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyVmlkZW9Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItdmlkZW8vYzMtZmlsZS12aWV3ZXItdmlkZW8uY29tcG9uZW50JztcbmltcG9ydCB7IEh0dHBDbGllbnRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBDM1NhZmVVcmxQaXBlIH0gZnJvbSAnLi4vLi4vcHVibGljLWFwaSc7XG5cbkBOZ01vZHVsZSh7XG4gIHByb3ZpZGVyczogW10sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEZ1bGxTY3JlZW5EaXJlY3RpdmUsXG4gICAgQzNGaWxlVmlld2VyQ29tcG9uZW50LFxuICAgIEMzRmlsZVZpZXdlckFjdGlvbnNDb21wb25lbnQsXG4gICAgQzNGaWxlVmlld2VySW1hZ2VDb21wb25lbnQsXG4gICAgQzNGaWxlVmlld2VyUGRmQ29tcG9uZW50LFxuICAgIEMzRmlsZVZpZXdlclZpZGVvQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBIdHRwQ2xpZW50TW9kdWxlLCBDM1NhZmVVcmxQaXBlXSxcbiAgZXhwb3J0czogW0Z1bGxTY3JlZW5EaXJlY3RpdmUsIEMzRmlsZVZpZXdlckNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEMzRmlsZVZpZXdlck1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostListener, Inject, Input, Optional, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common/http";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "../../directives/full-screen.directive";
|
|
6
|
+
import * as i4 from "../c3-file-viewer-actions/c3-file-viewer-actions.component";
|
|
7
|
+
import * as i5 from "../c3-file-viewer-image/c3-file-viewer-image.component";
|
|
8
|
+
import * as i6 from "../c3-file-viewer-pdf/c3-file-viewer-pdf.component";
|
|
9
|
+
import * as i7 from "../c3-file-viewer-video/c3-file-viewer-video.component";
|
|
10
|
+
export class C3FileViewerComponent {
|
|
11
|
+
constructor(moduleConfig, _http) {
|
|
12
|
+
this.moduleConfig = moduleConfig;
|
|
13
|
+
this._http = _http;
|
|
14
|
+
this.indexChange = new EventEmitter();
|
|
15
|
+
this.configChange = new EventEmitter();
|
|
16
|
+
this.customFileEvent = new EventEmitter();
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
if (!this.fileViewer.http)
|
|
20
|
+
this.fileViewer.http = this._http;
|
|
21
|
+
this.fileViewer.customFile$.subscribe((event) => {
|
|
22
|
+
this.customFileEvent.emit(event);
|
|
23
|
+
});
|
|
24
|
+
this.fileViewer.index$.subscribe((index) => {
|
|
25
|
+
this.indexChange.emit(index);
|
|
26
|
+
});
|
|
27
|
+
this.fileViewer.config$.subscribe((config) => {
|
|
28
|
+
this.configChange.emit(config);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
onMouseOver() {
|
|
32
|
+
this.fileViewer.hovered = true;
|
|
33
|
+
}
|
|
34
|
+
onMouseLeave() {
|
|
35
|
+
this.fileViewer.hovered = false;
|
|
36
|
+
}
|
|
37
|
+
ngOnChanges(changes) {
|
|
38
|
+
if (changes['screenHeightOccupied'] && this.fileViewer)
|
|
39
|
+
this.fileViewer.styleHeight =
|
|
40
|
+
'calc(100% - ' + this.screenHeightOccupied + 'px)';
|
|
41
|
+
}
|
|
42
|
+
next(event) {
|
|
43
|
+
this.fileViewer.nextImage(event);
|
|
44
|
+
}
|
|
45
|
+
previous(event) {
|
|
46
|
+
this.fileViewer.previousImage(event);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
C3FileViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerComponent, deps: [{ token: 'config', optional: true }, { token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
+
C3FileViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerComponent, selector: "c3-file-viewer", inputs: { screenHeightOccupied: "screenHeightOccupied", fileViewer: "fileViewer" }, outputs: { indexChange: "indexChange", configChange: "configChange", customFileEvent: "customFileEvent" }, host: { listeners: { "mouseover": "onMouseOver()", "mouseleave": "onMouseLeave()", "window:keyup.ArrowRight": "next($event)", "window:keyup.ArrowLeft": "previous($event)" }, classAttribute: "c3-file-viewer" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"container\"\n *ngIf=\"fileViewer\"\n [c3-full-screen]=\"fileViewer.fullscreen$ | async\"\n [style.height]=\"fileViewer.styleHeight\"\n [style.backgroundColor]=\"fileViewer.config.containerBackgroundColor\"\n (wheel)=\"fileViewer.scrollZoom($event)\"\n (dragover)=\"fileViewer.onDragOver($event)\"\n>\n <c3-file-viewer-image\n *ngIf=\"fileViewer.currentFile.type.startsWith('image')\"\n [fileViewer]=\"fileViewer\"\n [style]=\"fileViewer.style\"\n (dragstart)=\"fileViewer.onDragStart($event)\"\n />\n\n <c3-file-viewer-video\n *ngIf=\"fileViewer.currentFile.type.startsWith('video')\"\n />\n\n <c3-file-viewer-pdf\n *ngIf=\"fileViewer.currentFile.type.startsWith('application/pdf')\"\n [fileViewer]=\"fileViewer\"\n />\n <!-- Div below will be used to hide the 'ghost' image when dragging -->\n <div></div>\n <div class=\"spinner-container\" *ngIf=\"fileViewer.loading\">\n <div class=\"spinner\"></div>\n </div>\n\n <c3-file-viewer-actions [fileViewer]=\"fileViewer\" />\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.FullScreenDirective, selector: "[C3FullScreen], [c3-full-screen]", inputs: ["c3Screenfull", "c3-full-screen"] }, { kind: "component", type: i4.C3FileViewerActionsComponent, selector: "c3-file-viewer-actions", inputs: ["fileViewer"] }, { kind: "component", type: i5.C3FileViewerImageComponent, selector: "c3-file-viewer-image, [c3-file-viewer-image]", inputs: ["fileViewer"], outputs: ["dragstart"] }, { kind: "component", type: i6.C3FileViewerPdfComponent, selector: "c3-file-viewer-pdf", inputs: ["fileViewer"], outputs: ["dragstart"] }, { kind: "component", type: i7.C3FileViewerVideoComponent, selector: "c3-file-viewer-video", inputs: ["file", "fileViewer"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None });
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerComponent, decorators: [{
|
|
52
|
+
type: Component,
|
|
53
|
+
args: [{ selector: 'c3-file-viewer', encapsulation: ViewEncapsulation.None, host: {
|
|
54
|
+
class: 'c3-file-viewer',
|
|
55
|
+
}, template: "<div\n class=\"container\"\n *ngIf=\"fileViewer\"\n [c3-full-screen]=\"fileViewer.fullscreen$ | async\"\n [style.height]=\"fileViewer.styleHeight\"\n [style.backgroundColor]=\"fileViewer.config.containerBackgroundColor\"\n (wheel)=\"fileViewer.scrollZoom($event)\"\n (dragover)=\"fileViewer.onDragOver($event)\"\n>\n <c3-file-viewer-image\n *ngIf=\"fileViewer.currentFile.type.startsWith('image')\"\n [fileViewer]=\"fileViewer\"\n [style]=\"fileViewer.style\"\n (dragstart)=\"fileViewer.onDragStart($event)\"\n />\n\n <c3-file-viewer-video\n *ngIf=\"fileViewer.currentFile.type.startsWith('video')\"\n />\n\n <c3-file-viewer-pdf\n *ngIf=\"fileViewer.currentFile.type.startsWith('application/pdf')\"\n [fileViewer]=\"fileViewer\"\n />\n <!-- Div below will be used to hide the 'ghost' image when dragging -->\n <div></div>\n <div class=\"spinner-container\" *ngIf=\"fileViewer.loading\">\n <div class=\"spinner\"></div>\n </div>\n\n <c3-file-viewer-actions [fileViewer]=\"fileViewer\" />\n</div>\n" }]
|
|
56
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
57
|
+
type: Optional
|
|
58
|
+
}, {
|
|
59
|
+
type: Inject,
|
|
60
|
+
args: ['config']
|
|
61
|
+
}] }, { type: i1.HttpClient }]; }, propDecorators: { screenHeightOccupied: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], fileViewer: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}], indexChange: [{
|
|
66
|
+
type: Output
|
|
67
|
+
}], configChange: [{
|
|
68
|
+
type: Output
|
|
69
|
+
}], customFileEvent: [{
|
|
70
|
+
type: Output
|
|
71
|
+
}], onMouseOver: [{
|
|
72
|
+
type: HostListener,
|
|
73
|
+
args: ['mouseover']
|
|
74
|
+
}], onMouseLeave: [{
|
|
75
|
+
type: HostListener,
|
|
76
|
+
args: ['mouseleave']
|
|
77
|
+
}], next: [{
|
|
78
|
+
type: HostListener,
|
|
79
|
+
args: ['window:keyup.ArrowRight', ['$event']]
|
|
80
|
+
}], previous: [{
|
|
81
|
+
type: HostListener,
|
|
82
|
+
args: ['window:keyup.ArrowLeft', ['$event']]
|
|
83
|
+
}] } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXIvYzMtZmlsZS12aWV3ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osWUFBWSxFQUNaLE1BQU0sRUFDTixLQUFLLEVBRUwsUUFBUSxFQUNSLE1BQU0sRUFFTixpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7OztBQWV2QixNQUFNLE9BQU8scUJBQXFCO0lBZ0JoQyxZQUN1QyxZQUFnQyxFQUM5RCxLQUFpQjtRQURhLGlCQUFZLEdBQVosWUFBWSxDQUFvQjtRQUM5RCxVQUFLLEdBQUwsS0FBSyxDQUFZO1FBVm5CLGdCQUFXLEdBQXlCLElBQUksWUFBWSxFQUFFLENBQUM7UUFHdkQsaUJBQVksR0FBcUMsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUdwRSxvQkFBZSxHQUFrQyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBS3hFLENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSTtZQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7UUFFN0QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDOUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbkMsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUN6QyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQixDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQzNDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2pDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUdELFdBQVc7UUFDVCxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7SUFDakMsQ0FBQztJQUdELFlBQVk7UUFDVixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDbEMsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLElBQUksQ0FBQyxVQUFVO1lBQ3BELElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVztnQkFDekIsY0FBYyxHQUFHLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7SUFDekQsQ0FBQztJQUdELElBQUksQ0FBQyxLQUFvQjtRQUN2QixJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBR0QsUUFBUSxDQUFDLEtBQW9CO1FBQzNCLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7O2tIQTdEVSxxQkFBcUIsa0JBaUJWLFFBQVE7c0dBakJuQixxQkFBcUIsNGRDMUJsQyxnaENBZ0NBOzJGRE5hLHFCQUFxQjtrQkFUakMsU0FBUzsrQkFDRSxnQkFBZ0IsaUJBR1gsaUJBQWlCLENBQUMsSUFBSSxRQUMvQjt3QkFDSixLQUFLLEVBQUUsZ0JBQWdCO3FCQUN4Qjs7MEJBbUJFLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsUUFBUTtxRUFmdkIsb0JBQW9CO3NCQUQxQixLQUFLO2dCQUlDLFVBQVU7c0JBRGhCLEtBQUs7Z0JBSUMsV0FBVztzQkFEakIsTUFBTTtnQkFJQSxZQUFZO3NCQURsQixNQUFNO2dCQUlBLGVBQWU7c0JBRHJCLE1BQU07Z0JBeUJQLFdBQVc7c0JBRFYsWUFBWTt1QkFBQyxXQUFXO2dCQU16QixZQUFZO3NCQURYLFlBQVk7dUJBQUMsWUFBWTtnQkFZMUIsSUFBSTtzQkFESCxZQUFZO3VCQUFDLHlCQUF5QixFQUFFLENBQUMsUUFBUSxDQUFDO2dCQU1uRCxRQUFRO3NCQURQLFlBQVk7dUJBQUMsd0JBQXdCLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSG9zdExpc3RlbmVyLFxuICBJbmplY3QsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIE9wdGlvbmFsLFxuICBPdXRwdXQsXG4gIFNpbXBsZUNoYW5nZXMsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlckNvbmZpZyB9IGZyb20gJy4uLy4uL21vZGVscy9maWxlLXZpZXdlci1jb25maWcubW9kZWwnO1xuaW1wb3J0IHsgQ3VzdG9tRmlsZUV2ZW50IH0gZnJvbSAnLi4vLi4vbW9kZWxzL2N1c3RvbS1maWxlLWV2ZW50Lm1vZGVsJztcbmltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBDM0ZpbGVWaWV3ZXIgfSBmcm9tICcuLi8uLi9tb2RlbHMvZmlsZS12aWV3ZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjMy1maWxlLXZpZXdlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLXZpZXdlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogW10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2MzLWZpbGUtdmlld2VyJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgQzNGaWxlVmlld2VyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgcHVibGljIHNjcmVlbkhlaWdodE9jY3VwaWVkPzogMDsgLy8gSW4gUHhcblxuICBASW5wdXQoKVxuICBwdWJsaWMgZmlsZVZpZXdlciE6IEMzRmlsZVZpZXdlcjtcblxuICBAT3V0cHV0KClcbiAgcHVibGljIGluZGV4Q2hhbmdlOiBFdmVudEVtaXR0ZXI8bnVtYmVyPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBAT3V0cHV0KClcbiAgcHVibGljIGNvbmZpZ0NoYW5nZTogRXZlbnRFbWl0dGVyPEMzRmlsZVZpZXdlckNvbmZpZz4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgQE91dHB1dCgpXG4gIHB1YmxpYyBjdXN0b21GaWxlRXZlbnQ6IEV2ZW50RW1pdHRlcjxDdXN0b21GaWxlRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBPcHRpb25hbCgpIEBJbmplY3QoJ2NvbmZpZycpIHB1YmxpYyBtb2R1bGVDb25maWc6IEMzRmlsZVZpZXdlckNvbmZpZyxcbiAgICBwdWJsaWMgX2h0dHA6IEh0dHBDbGllbnRcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIGlmICghdGhpcy5maWxlVmlld2VyLmh0dHApIHRoaXMuZmlsZVZpZXdlci5odHRwID0gdGhpcy5faHR0cDtcblxuICAgIHRoaXMuZmlsZVZpZXdlci5jdXN0b21GaWxlJC5zdWJzY3JpYmUoKGV2ZW50KSA9PiB7XG4gICAgICB0aGlzLmN1c3RvbUZpbGVFdmVudC5lbWl0KGV2ZW50KTtcbiAgICB9KTtcblxuICAgIHRoaXMuZmlsZVZpZXdlci5pbmRleCQuc3Vic2NyaWJlKChpbmRleCkgPT4ge1xuICAgICAgdGhpcy5pbmRleENoYW5nZS5lbWl0KGluZGV4KTtcbiAgICB9KTtcblxuICAgIHRoaXMuZmlsZVZpZXdlci5jb25maWckLnN1YnNjcmliZSgoY29uZmlnKSA9PiB7XG4gICAgICB0aGlzLmNvbmZpZ0NoYW5nZS5lbWl0KGNvbmZpZyk7XG4gICAgfSk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdtb3VzZW92ZXInKVxuICBvbk1vdXNlT3ZlcigpIHtcbiAgICB0aGlzLmZpbGVWaWV3ZXIuaG92ZXJlZCA9IHRydWU7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdtb3VzZWxlYXZlJylcbiAgb25Nb3VzZUxlYXZlKCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5ob3ZlcmVkID0gZmFsc2U7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgaWYgKGNoYW5nZXNbJ3NjcmVlbkhlaWdodE9jY3VwaWVkJ10gJiYgdGhpcy5maWxlVmlld2VyKVxuICAgICAgdGhpcy5maWxlVmlld2VyLnN0eWxlSGVpZ2h0ID1cbiAgICAgICAgJ2NhbGMoMTAwJSAtICcgKyB0aGlzLnNjcmVlbkhlaWdodE9jY3VwaWVkICsgJ3B4KSc7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCd3aW5kb3c6a2V5dXAuQXJyb3dSaWdodCcsIFsnJGV2ZW50J10pXG4gIG5leHQoZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcbiAgICB0aGlzLmZpbGVWaWV3ZXIubmV4dEltYWdlKGV2ZW50KTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzprZXl1cC5BcnJvd0xlZnQnLCBbJyRldmVudCddKVxuICBwcmV2aW91cyhldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5wcmV2aW91c0ltYWdlKGV2ZW50KTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cImNvbnRhaW5lclwiXG4gICpuZ0lmPVwiZmlsZVZpZXdlclwiXG4gIFtjMy1mdWxsLXNjcmVlbl09XCJmaWxlVmlld2VyLmZ1bGxzY3JlZW4kIHwgYXN5bmNcIlxuICBbc3R5bGUuaGVpZ2h0XT1cImZpbGVWaWV3ZXIuc3R5bGVIZWlnaHRcIlxuICBbc3R5bGUuYmFja2dyb3VuZENvbG9yXT1cImZpbGVWaWV3ZXIuY29uZmlnLmNvbnRhaW5lckJhY2tncm91bmRDb2xvclwiXG4gICh3aGVlbCk9XCJmaWxlVmlld2VyLnNjcm9sbFpvb20oJGV2ZW50KVwiXG4gIChkcmFnb3Zlcik9XCJmaWxlVmlld2VyLm9uRHJhZ092ZXIoJGV2ZW50KVwiXG4+XG4gIDxjMy1maWxlLXZpZXdlci1pbWFnZVxuICAgICpuZ0lmPVwiZmlsZVZpZXdlci5jdXJyZW50RmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2ltYWdlJylcIlxuICAgIFtmaWxlVmlld2VyXT1cImZpbGVWaWV3ZXJcIlxuICAgIFtzdHlsZV09XCJmaWxlVmlld2VyLnN0eWxlXCJcbiAgICAoZHJhZ3N0YXJ0KT1cImZpbGVWaWV3ZXIub25EcmFnU3RhcnQoJGV2ZW50KVwiXG4gIC8+XG5cbiAgPGMzLWZpbGUtdmlld2VyLXZpZGVvXG4gICAgKm5nSWY9XCJmaWxlVmlld2VyLmN1cnJlbnRGaWxlLnR5cGUuc3RhcnRzV2l0aCgndmlkZW8nKVwiXG4gIC8+XG5cbiAgPGMzLWZpbGUtdmlld2VyLXBkZlxuICAgICpuZ0lmPVwiZmlsZVZpZXdlci5jdXJyZW50RmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2FwcGxpY2F0aW9uL3BkZicpXCJcbiAgICBbZmlsZVZpZXdlcl09XCJmaWxlVmlld2VyXCJcbiAgLz5cbiAgPCEtLSBEaXYgYmVsb3cgd2lsbCBiZSB1c2VkIHRvIGhpZGUgdGhlICdnaG9zdCcgaW1hZ2Ugd2hlbiBkcmFnZ2luZyAtLT5cbiAgPGRpdj48L2Rpdj5cbiAgPGRpdiBjbGFzcz1cInNwaW5uZXItY29udGFpbmVyXCIgKm5nSWY9XCJmaWxlVmlld2VyLmxvYWRpbmdcIj5cbiAgICA8ZGl2IGNsYXNzPVwic3Bpbm5lclwiPjwvZGl2PlxuICA8L2Rpdj5cblxuICA8YzMtZmlsZS12aWV3ZXItYWN0aW9ucyBbZmlsZVZpZXdlcl09XCJmaWxlVmlld2VyXCIgLz5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class C3FileViewerActionsComponent {
|
|
5
|
+
get config() {
|
|
6
|
+
return this.fileViewer.config;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
C3FileViewerActionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerActionsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
+
C3FileViewerActionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerActionsComponent, selector: "c3-file-viewer-actions", inputs: { fileViewer: "fileViewer" }, ngImport: i0, template: "<div class=\"nav-button-container\">\n <button\n *ngIf=\"config.btnShow?.prev\"\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.previousImage($event)\"\n [disabled]=\"fileViewer.currentIndex === 0\"\n >\n <span\n *ngIf=\"config.btnIcons?.prev?.classes\"\n [class]=\"config.btnIcons?.prev?.classes\"\n ></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.prev?.text\"\n (click)=\"fileViewer.previousImage($event)\"\n >\n <span [class]=\"config.btnSubClass\">{{ config.btnIcons?.prev?.text }}</span>\n </a>\n <button\n *ngIf=\"config.btnShow?.next\"\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.nextImage($event)\"\n [disabled]=\"fileViewer.currentIndex === fileViewer.files.length - 1\"\n >\n <span\n *ngIf=\"config.btnIcons?.next?.classes\"\n [class]=\"config.btnIcons?.next?.classes\"\n ></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.next?.text\"\n (click)=\"fileViewer.nextImage($event)\"\n >\n <span [class]=\"config.btnSubClass\">{{ config.btnIcons?.next?.text }}</span>\n </a>\n</div>\n\n<!-- Button Container -->\n<div\n class=\"btn-container\"\n [class]=\"config.btnContainerClass\"\n *ngIf=\"fileViewer.currentFile.type.startsWith('image')\"\n>\n <!-- Rotate Counter Clockwise -->\n <ng-container *ngIf=\"config.btnShow?.rotateCounterClockwise\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.rotateCounterClockwise()\"\n *ngIf=\"config.btnIcons?.rotateCounterClockwise?.classes\"\n >\n <span [class]=\"config.btnIcons?.rotateCounterClockwise?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.rotateCounterClockwise?.text\"\n (click)=\"fileViewer.rotateCounterClockwise()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.rotateCounterClockwise?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Rotate Clockwise -->\n <ng-container *ngIf=\"config.btnShow?.rotateClockwise\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.rotateClockwise()\"\n *ngIf=\"config.btnIcons?.rotateClockwise?.classes\"\n >\n <span [class]=\"config.btnIcons?.rotateClockwise?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.rotateClockwise?.text\"\n (click)=\"fileViewer.rotateClockwise()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.rotateClockwise?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Zoom Out -->\n <ng-container *ngIf=\"config.btnShow?.zoomOut\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.zoomOut()\"\n *ngIf=\"config.btnIcons?.zoomOut?.classes\"\n >\n <span [class]=\"config.btnIcons?.zoomOut?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.zoomOut?.text\"\n (click)=\"fileViewer.zoomOut()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.zoomOut?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Zoom In -->\n <ng-container *ngIf=\"config.btnShow?.zoomIn\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.zoomIn()\"\n *ngIf=\"config.btnIcons?.zoomIn?.classes\"\n >\n <span [class]=\"config.btnIcons?.zoomIn?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.zoomIn?.text\"\n (click)=\"fileViewer.zoomIn()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.zoomIn?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Fullscreen -->\n <ng-container *ngIf=\"config.allowFullscreen\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.toggleFullscreen()\"\n *ngIf=\"config.btnIcons?.fullscreen?.classes\"\n >\n <span [class]=\"config.btnIcons?.fullscreen?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.fullscreen?.text\"\n (click)=\"fileViewer.toggleFullscreen()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.fullscreen?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Reset -->\n <ng-container *ngIf=\"config.btnShow?.reset\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.reset()\"\n *ngIf=\"config.btnIcons?.reset?.classes\"\n >\n <span [class]=\"config.btnIcons?.reset?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.reset?.text\"\n (click)=\"fileViewer.reset()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.reset?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Custom Buttons -->\n <ng-container *ngFor=\"let cBtn of config.customBtns\">\n <button *ngIf=\"cBtn.icon.classes\" type=\"button\" [class]=\"config.btnClass\">\n <span *ngIf=\"cBtn.icon.classes\" [class]=\"cBtn.icon.classes\"></span>\n </button>\n <ng-container *ngIf=\"cBtn.icon.text\">\n <a [class]=\"config.btnClass\" *ngIf=\"cBtn.icon.text\">\n <span [class]=\"config.btnSubClass\">{{ cBtn.icon.text }}</span>\n </a>\n </ng-container>\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerActionsComponent, decorators: [{
|
|
12
|
+
type: Component,
|
|
13
|
+
args: [{ selector: 'c3-file-viewer-actions', template: "<div class=\"nav-button-container\">\n <button\n *ngIf=\"config.btnShow?.prev\"\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.previousImage($event)\"\n [disabled]=\"fileViewer.currentIndex === 0\"\n >\n <span\n *ngIf=\"config.btnIcons?.prev?.classes\"\n [class]=\"config.btnIcons?.prev?.classes\"\n ></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.prev?.text\"\n (click)=\"fileViewer.previousImage($event)\"\n >\n <span [class]=\"config.btnSubClass\">{{ config.btnIcons?.prev?.text }}</span>\n </a>\n <button\n *ngIf=\"config.btnShow?.next\"\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.nextImage($event)\"\n [disabled]=\"fileViewer.currentIndex === fileViewer.files.length - 1\"\n >\n <span\n *ngIf=\"config.btnIcons?.next?.classes\"\n [class]=\"config.btnIcons?.next?.classes\"\n ></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.next?.text\"\n (click)=\"fileViewer.nextImage($event)\"\n >\n <span [class]=\"config.btnSubClass\">{{ config.btnIcons?.next?.text }}</span>\n </a>\n</div>\n\n<!-- Button Container -->\n<div\n class=\"btn-container\"\n [class]=\"config.btnContainerClass\"\n *ngIf=\"fileViewer.currentFile.type.startsWith('image')\"\n>\n <!-- Rotate Counter Clockwise -->\n <ng-container *ngIf=\"config.btnShow?.rotateCounterClockwise\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.rotateCounterClockwise()\"\n *ngIf=\"config.btnIcons?.rotateCounterClockwise?.classes\"\n >\n <span [class]=\"config.btnIcons?.rotateCounterClockwise?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.rotateCounterClockwise?.text\"\n (click)=\"fileViewer.rotateCounterClockwise()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.rotateCounterClockwise?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Rotate Clockwise -->\n <ng-container *ngIf=\"config.btnShow?.rotateClockwise\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.rotateClockwise()\"\n *ngIf=\"config.btnIcons?.rotateClockwise?.classes\"\n >\n <span [class]=\"config.btnIcons?.rotateClockwise?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.rotateClockwise?.text\"\n (click)=\"fileViewer.rotateClockwise()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.rotateClockwise?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Zoom Out -->\n <ng-container *ngIf=\"config.btnShow?.zoomOut\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.zoomOut()\"\n *ngIf=\"config.btnIcons?.zoomOut?.classes\"\n >\n <span [class]=\"config.btnIcons?.zoomOut?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.zoomOut?.text\"\n (click)=\"fileViewer.zoomOut()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.zoomOut?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Zoom In -->\n <ng-container *ngIf=\"config.btnShow?.zoomIn\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.zoomIn()\"\n *ngIf=\"config.btnIcons?.zoomIn?.classes\"\n >\n <span [class]=\"config.btnIcons?.zoomIn?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.zoomIn?.text\"\n (click)=\"fileViewer.zoomIn()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.zoomIn?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Fullscreen -->\n <ng-container *ngIf=\"config.allowFullscreen\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.toggleFullscreen()\"\n *ngIf=\"config.btnIcons?.fullscreen?.classes\"\n >\n <span [class]=\"config.btnIcons?.fullscreen?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.fullscreen?.text\"\n (click)=\"fileViewer.toggleFullscreen()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.fullscreen?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Reset -->\n <ng-container *ngIf=\"config.btnShow?.reset\">\n <button\n type=\"button\"\n [class]=\"config.btnClass\"\n (click)=\"fileViewer.reset()\"\n *ngIf=\"config.btnIcons?.reset?.classes\"\n >\n <span [class]=\"config.btnIcons?.reset?.classes\"></span>\n </button>\n <a\n [class]=\"config.btnClass\"\n *ngIf=\"config.btnIcons?.reset?.text\"\n (click)=\"fileViewer.reset()\"\n >\n <span [class]=\"config.btnSubClass\">{{\n config.btnIcons?.reset?.text\n }}</span>\n </a>\n </ng-container>\n\n <!-- Custom Buttons -->\n <ng-container *ngFor=\"let cBtn of config.customBtns\">\n <button *ngIf=\"cBtn.icon.classes\" type=\"button\" [class]=\"config.btnClass\">\n <span *ngIf=\"cBtn.icon.classes\" [class]=\"cBtn.icon.classes\"></span>\n </button>\n <ng-container *ngIf=\"cBtn.icon.text\">\n <a [class]=\"config.btnClass\" *ngIf=\"cBtn.icon.text\">\n <span [class]=\"config.btnSubClass\">{{ cBtn.icon.text }}</span>\n </a>\n </ng-container>\n </ng-container>\n</div>\n" }]
|
|
14
|
+
}], propDecorators: { fileViewer: [{
|
|
15
|
+
type: Input
|
|
16
|
+
}] } });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c3-file-viewer-actions.component.js","sourceRoot":"","sources":["../../../../../../../projects/c3-components/src/lib/c3-file-viewer/components/c3-file-viewer-actions/c3-file-viewer-actions.component.ts","../../../../../../../projects/c3-components/src/lib/c3-file-viewer/components/c3-file-viewer-actions/c3-file-viewer-actions.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAQ,KAAK,EAAE,MAAM,eAAe,CAAC;;;AAOvD,MAAM,OAAO,4BAA4B;IAIvC,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAChC,CAAC;;yHANU,4BAA4B;6GAA5B,4BAA4B,oGCPzC,shLAyLA;2FDlLa,4BAA4B;kBAJxC,SAAS;+BACE,wBAAwB;8BAKlC,UAAU;sBADT,KAAK","sourcesContent":["import { Component, Host, Input } from '@angular/core';\nimport { C3FileViewer } from '../../models/file-viewer';\n\n@Component({\n  selector: 'c3-file-viewer-actions',\n  templateUrl: './c3-file-viewer-actions.component.html',\n})\nexport class C3FileViewerActionsComponent {\n  @Input()\n  fileViewer!: C3FileViewer;\n\n  get config() {\n    return this.fileViewer.config;\n  }\n}\n","<div class=\"nav-button-container\">\n  <button\n    *ngIf=\"config.btnShow?.prev\"\n    type=\"button\"\n    [class]=\"config.btnClass\"\n    (click)=\"fileViewer.previousImage($event)\"\n    [disabled]=\"fileViewer.currentIndex === 0\"\n  >\n    <span\n      *ngIf=\"config.btnIcons?.prev?.classes\"\n      [class]=\"config.btnIcons?.prev?.classes\"\n    ></span>\n  </button>\n  <a\n    [class]=\"config.btnClass\"\n    *ngIf=\"config.btnIcons?.prev?.text\"\n    (click)=\"fileViewer.previousImage($event)\"\n  >\n    <span [class]=\"config.btnSubClass\">{{ config.btnIcons?.prev?.text }}</span>\n  </a>\n  <button\n    *ngIf=\"config.btnShow?.next\"\n    type=\"button\"\n    [class]=\"config.btnClass\"\n    (click)=\"fileViewer.nextImage($event)\"\n    [disabled]=\"fileViewer.currentIndex === fileViewer.files.length - 1\"\n  >\n    <span\n      *ngIf=\"config.btnIcons?.next?.classes\"\n      [class]=\"config.btnIcons?.next?.classes\"\n    ></span>\n  </button>\n  <a\n    [class]=\"config.btnClass\"\n    *ngIf=\"config.btnIcons?.next?.text\"\n    (click)=\"fileViewer.nextImage($event)\"\n  >\n    <span [class]=\"config.btnSubClass\">{{ config.btnIcons?.next?.text }}</span>\n  </a>\n</div>\n\n<!-- Button Container -->\n<div\n  class=\"btn-container\"\n  [class]=\"config.btnContainerClass\"\n  *ngIf=\"fileViewer.currentFile.type.startsWith('image')\"\n>\n  <!-- Rotate Counter Clockwise -->\n  <ng-container *ngIf=\"config.btnShow?.rotateCounterClockwise\">\n    <button\n      type=\"button\"\n      [class]=\"config.btnClass\"\n      (click)=\"fileViewer.rotateCounterClockwise()\"\n      *ngIf=\"config.btnIcons?.rotateCounterClockwise?.classes\"\n    >\n      <span [class]=\"config.btnIcons?.rotateCounterClockwise?.classes\"></span>\n    </button>\n    <a\n      [class]=\"config.btnClass\"\n      *ngIf=\"config.btnIcons?.rotateCounterClockwise?.text\"\n      (click)=\"fileViewer.rotateCounterClockwise()\"\n    >\n      <span [class]=\"config.btnSubClass\">{{\n        config.btnIcons?.rotateCounterClockwise?.text\n      }}</span>\n    </a>\n  </ng-container>\n\n  <!-- Rotate Clockwise -->\n  <ng-container *ngIf=\"config.btnShow?.rotateClockwise\">\n    <button\n      type=\"button\"\n      [class]=\"config.btnClass\"\n      (click)=\"fileViewer.rotateClockwise()\"\n      *ngIf=\"config.btnIcons?.rotateClockwise?.classes\"\n    >\n      <span [class]=\"config.btnIcons?.rotateClockwise?.classes\"></span>\n    </button>\n    <a\n      [class]=\"config.btnClass\"\n      *ngIf=\"config.btnIcons?.rotateClockwise?.text\"\n      (click)=\"fileViewer.rotateClockwise()\"\n    >\n      <span [class]=\"config.btnSubClass\">{{\n        config.btnIcons?.rotateClockwise?.text\n      }}</span>\n    </a>\n  </ng-container>\n\n  <!-- Zoom Out -->\n  <ng-container *ngIf=\"config.btnShow?.zoomOut\">\n    <button\n      type=\"button\"\n      [class]=\"config.btnClass\"\n      (click)=\"fileViewer.zoomOut()\"\n      *ngIf=\"config.btnIcons?.zoomOut?.classes\"\n    >\n      <span [class]=\"config.btnIcons?.zoomOut?.classes\"></span>\n    </button>\n    <a\n      [class]=\"config.btnClass\"\n      *ngIf=\"config.btnIcons?.zoomOut?.text\"\n      (click)=\"fileViewer.zoomOut()\"\n    >\n      <span [class]=\"config.btnSubClass\">{{\n        config.btnIcons?.zoomOut?.text\n      }}</span>\n    </a>\n  </ng-container>\n\n  <!-- Zoom In -->\n  <ng-container *ngIf=\"config.btnShow?.zoomIn\">\n    <button\n      type=\"button\"\n      [class]=\"config.btnClass\"\n      (click)=\"fileViewer.zoomIn()\"\n      *ngIf=\"config.btnIcons?.zoomIn?.classes\"\n    >\n      <span [class]=\"config.btnIcons?.zoomIn?.classes\"></span>\n    </button>\n    <a\n      [class]=\"config.btnClass\"\n      *ngIf=\"config.btnIcons?.zoomIn?.text\"\n      (click)=\"fileViewer.zoomIn()\"\n    >\n      <span [class]=\"config.btnSubClass\">{{\n        config.btnIcons?.zoomIn?.text\n      }}</span>\n    </a>\n  </ng-container>\n\n  <!-- Fullscreen -->\n  <ng-container *ngIf=\"config.allowFullscreen\">\n    <button\n      type=\"button\"\n      [class]=\"config.btnClass\"\n      (click)=\"fileViewer.toggleFullscreen()\"\n      *ngIf=\"config.btnIcons?.fullscreen?.classes\"\n    >\n      <span [class]=\"config.btnIcons?.fullscreen?.classes\"></span>\n    </button>\n    <a\n      [class]=\"config.btnClass\"\n      *ngIf=\"config.btnIcons?.fullscreen?.text\"\n      (click)=\"fileViewer.toggleFullscreen()\"\n    >\n      <span [class]=\"config.btnSubClass\">{{\n        config.btnIcons?.fullscreen?.text\n      }}</span>\n    </a>\n  </ng-container>\n\n  <!-- Reset -->\n  <ng-container *ngIf=\"config.btnShow?.reset\">\n    <button\n      type=\"button\"\n      [class]=\"config.btnClass\"\n      (click)=\"fileViewer.reset()\"\n      *ngIf=\"config.btnIcons?.reset?.classes\"\n    >\n      <span [class]=\"config.btnIcons?.reset?.classes\"></span>\n    </button>\n    <a\n      [class]=\"config.btnClass\"\n      *ngIf=\"config.btnIcons?.reset?.text\"\n      (click)=\"fileViewer.reset()\"\n    >\n      <span [class]=\"config.btnSubClass\">{{\n        config.btnIcons?.reset?.text\n      }}</span>\n    </a>\n  </ng-container>\n\n  <!-- Custom Buttons -->\n  <ng-container *ngFor=\"let cBtn of config.customBtns\">\n    <button *ngIf=\"cBtn.icon.classes\" type=\"button\" [class]=\"config.btnClass\">\n      <span *ngIf=\"cBtn.icon.classes\" [class]=\"cBtn.icon.classes\"></span>\n    </button>\n    <ng-container *ngIf=\"cBtn.icon.text\">\n      <a [class]=\"config.btnClass\" *ngIf=\"cBtn.icon.text\">\n        <span [class]=\"config.btnSubClass\">{{ cBtn.icon.text }}</span>\n      </a>\n    </ng-container>\n  </ng-container>\n</div>\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../../../c3-safe-url/pipes/c3-safe-url.pipe";
|
|
5
|
+
export class C3FileViewerImageComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.dragstart = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
C3FileViewerImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
11
|
+
C3FileViewerImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerImageComponent, selector: "c3-file-viewer-image, [c3-file-viewer-image]", inputs: { fileViewer: "fileViewer" }, outputs: { dragstart: "dragstart" }, ngImport: i0, template: "<img\n *ngIf=\"fileViewer.currentFile.objectUrl\"\n [src]=\"fileViewer.currentFile.objectUrl | async | c3SafeUrl\"\n [ngStyle]=\"fileViewer.style\"\n alt=\"Image not found...\"\n (dragstart)=\"dragstart.emit($event)\"\n/>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.C3SafeUrlPipe, name: "c3SafeUrl" }] });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerImageComponent, decorators: [{
|
|
13
|
+
type: Component,
|
|
14
|
+
args: [{ selector: 'c3-file-viewer-image, [c3-file-viewer-image]', template: "<img\n *ngIf=\"fileViewer.currentFile.objectUrl\"\n [src]=\"fileViewer.currentFile.objectUrl | async | c3SafeUrl\"\n [ngStyle]=\"fileViewer.style\"\n alt=\"Image not found...\"\n (dragstart)=\"dragstart.emit($event)\"\n/>\n" }]
|
|
15
|
+
}], propDecorators: { fileViewer: [{
|
|
16
|
+
type: Input
|
|
17
|
+
}], dragstart: [{
|
|
18
|
+
type: Output
|
|
19
|
+
}] } });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXItaW1hZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItaW1hZ2UvYzMtZmlsZS12aWV3ZXItaW1hZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItaW1hZ2UvYzMtZmlsZS12aWV3ZXItaW1hZ2UuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQU92RSxNQUFNLE9BQU8sMEJBQTBCO0lBSnZDO1FBU0UsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFhLENBQUM7S0FDM0M7O3VIQU5ZLDBCQUEwQjsyR0FBMUIsMEJBQTBCLCtKQ1B2QyxzT0FPQTsyRkRBYSwwQkFBMEI7a0JBSnRDLFNBQVM7K0JBQ0UsOENBQThDOzhCQUtqRCxVQUFVO3NCQURoQixLQUFLO2dCQUlOLFNBQVM7c0JBRFIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDM0ZpbGVWaWV3ZXIgfSBmcm9tICcuLi8uLi9tb2RlbHMvZmlsZS12aWV3ZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjMy1maWxlLXZpZXdlci1pbWFnZSwgW2MzLWZpbGUtdmlld2VyLWltYWdlXScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLXZpZXdlci1pbWFnZS5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIEMzRmlsZVZpZXdlckltYWdlQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgcHVibGljIGZpbGVWaWV3ZXIhOiBDM0ZpbGVWaWV3ZXI7XG5cbiAgQE91dHB1dCgpXG4gIGRyYWdzdGFydCA9IG5ldyBFdmVudEVtaXR0ZXI8RHJhZ0V2ZW50PigpO1xufVxuIiwiPGltZ1xuICAqbmdJZj1cImZpbGVWaWV3ZXIuY3VycmVudEZpbGUub2JqZWN0VXJsXCJcbiAgW3NyY109XCJmaWxlVmlld2VyLmN1cnJlbnRGaWxlLm9iamVjdFVybCB8IGFzeW5jIHwgYzNTYWZlVXJsXCJcbiAgW25nU3R5bGVdPVwiZmlsZVZpZXdlci5zdHlsZVwiXG4gIGFsdD1cIkltYWdlIG5vdCBmb3VuZC4uLlwiXG4gIChkcmFnc3RhcnQpPVwiZHJhZ3N0YXJ0LmVtaXQoJGV2ZW50KVwiXG4vPlxuIl19
|
package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-pdf/c3-file-viewer-pdf.component.mjs
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../../../c3-safe-url/pipes/c3-safe-url.pipe";
|
|
5
|
+
export class C3FileViewerPdfComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.dragstart = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
C3FileViewerPdfComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerPdfComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
11
|
+
C3FileViewerPdfComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerPdfComponent, selector: "c3-file-viewer-pdf", inputs: { fileViewer: "fileViewer" }, outputs: { dragstart: "dragstart" }, host: { styleAttribute: "display: block", classAttribute: "c3-file-viewer-pdf" }, ngImport: i0, template: "<!-- pdf viewer -->\n<embed\n type=\"application/pdf\"\n [src]=\"fileViewer.currentFile.objectUrl | async | c3SafeUrl\"\n [style.height]=\"'100%'\"\n [style.width]=\"'100%'\"\n/>\n", dependencies: [{ kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.C3SafeUrlPipe, name: "c3SafeUrl" }], encapsulation: i0.ViewEncapsulation.None });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerPdfComponent, decorators: [{
|
|
13
|
+
type: Component,
|
|
14
|
+
args: [{ selector: 'c3-file-viewer-pdf', encapsulation: ViewEncapsulation.None, host: {
|
|
15
|
+
style: 'display: block',
|
|
16
|
+
class: 'c3-file-viewer-pdf',
|
|
17
|
+
}, template: "<!-- pdf viewer -->\n<embed\n type=\"application/pdf\"\n [src]=\"fileViewer.currentFile.objectUrl | async | c3SafeUrl\"\n [style.height]=\"'100%'\"\n [style.width]=\"'100%'\"\n/>\n" }]
|
|
18
|
+
}], propDecorators: { fileViewer: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}], dragstart: [{
|
|
21
|
+
type: Output
|
|
22
|
+
}] } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXItcGRmLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLXBkZi9jMy1maWxlLXZpZXdlci1wZGYuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItcGRmL2MzLWZpbGUtdmlld2VyLXBkZi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBQ0wsTUFBTSxFQUNOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7OztBQVl2QixNQUFNLE9BQU8sd0JBQXdCO0lBVHJDO1FBY0UsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFhLENBQUM7S0FDM0M7O3FIQU5ZLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLHVOQ2xCckMsMExBT0E7MkZEV2Esd0JBQXdCO2tCQVRwQyxTQUFTOytCQUNFLG9CQUFvQixpQkFFZixpQkFBaUIsQ0FBQyxJQUFJLFFBQy9CO3dCQUNKLEtBQUssRUFBRSxnQkFBZ0I7d0JBQ3ZCLEtBQUssRUFBRSxvQkFBb0I7cUJBQzVCOzhCQUlNLFVBQVU7c0JBRGhCLEtBQUs7Z0JBSU4sU0FBUztzQkFEUixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlciB9IGZyb20gJy4uLy4uL21vZGVscy9maWxlLXZpZXdlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtdmlld2VyLXBkZicsXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLXZpZXdlci1wZGYuY29tcG9uZW50Lmh0bWwnLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBob3N0OiB7XG4gICAgc3R5bGU6ICdkaXNwbGF5OiBibG9jaycsXG4gICAgY2xhc3M6ICdjMy1maWxlLXZpZXdlci1wZGYnLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJQZGZDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgZmlsZVZpZXdlciE6IEMzRmlsZVZpZXdlcjtcblxuICBAT3V0cHV0KClcbiAgZHJhZ3N0YXJ0ID0gbmV3IEV2ZW50RW1pdHRlcjxEcmFnRXZlbnQ+KCk7XG59XG4iLCI8IS0tIHBkZiB2aWV3ZXIgLS0+XG48ZW1iZWRcbiAgdHlwZT1cImFwcGxpY2F0aW9uL3BkZlwiXG4gIFtzcmNdPVwiZmlsZVZpZXdlci5jdXJyZW50RmlsZS5vYmplY3RVcmwgfCBhc3luYyB8IGMzU2FmZVVybFwiXG4gIFtzdHlsZS5oZWlnaHRdPVwiJzEwMCUnXCJcbiAgW3N0eWxlLndpZHRoXT1cIicxMDAlJ1wiXG4vPlxuIl19
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Subject, filter, mergeMap, tap } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class C3FileViewerVideoComponent {
|
|
5
|
+
set _srcUpdated({ location }) {
|
|
6
|
+
this.src$.next(location);
|
|
7
|
+
}
|
|
8
|
+
constructor() {
|
|
9
|
+
this.src = '';
|
|
10
|
+
this.src$ = new Subject();
|
|
11
|
+
this.src$
|
|
12
|
+
.pipe(mergeMap((src) => this.fileViewer.getFile(src)), filter((blob) => blob.type.startsWith('application/pdf')), tap((blob) => (this.src = URL.createObjectURL(blob))))
|
|
13
|
+
.subscribe({
|
|
14
|
+
next: () => null,
|
|
15
|
+
error: (error) => {
|
|
16
|
+
console.log(error);
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
C3FileViewerVideoComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerVideoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
C3FileViewerVideoComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerVideoComponent, selector: "c3-file-viewer-video", inputs: { _srcUpdated: ["file", "_srcUpdated"], fileViewer: "fileViewer" }, ngImport: i0, template: "<video controls [src]=\"src\" crossorigin=\"*\"></video>\n" });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerVideoComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'c3-file-viewer-video', template: "<video controls [src]=\"src\" crossorigin=\"*\"></video>\n" }]
|
|
26
|
+
}], ctorParameters: function () { return []; }, propDecorators: { _srcUpdated: [{
|
|
27
|
+
type: Input,
|
|
28
|
+
args: ['file']
|
|
29
|
+
}], fileViewer: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}] } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXItdmlkZW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItdmlkZW8vYzMtZmlsZS12aWV3ZXItdmlkZW8uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItdmlkZW8vYzMtZmlsZS12aWV3ZXItdmlkZW8uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFPdEQsTUFBTSxPQUFPLDBCQUEwQjtJQUNyQyxJQUNJLFdBQVcsQ0FBQyxFQUFFLFFBQVEsRUFBZ0I7UUFDeEMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQU9EO1FBTkEsUUFBRyxHQUFHLEVBQUUsQ0FBQztRQUNELFNBQUksR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBTW5DLElBQUksQ0FBQyxJQUFJO2FBQ04sSUFBSSxDQUNILFFBQVEsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsRUFDL0MsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLEVBQ3pELEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUN0RDthQUNBLFNBQVMsQ0FBQztZQUNULElBQUksRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJO1lBQ2hCLEtBQUssRUFBRSxDQUFDLEtBQUssRUFBRSxFQUFFO2dCQUNmLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDckIsQ0FBQztTQUNGLENBQUMsQ0FBQztJQUNQLENBQUM7O3VIQXhCVSwwQkFBMEI7MkdBQTFCLDBCQUEwQix3SUNUdkMsNERBQ0E7MkZEUWEsMEJBQTBCO2tCQUp0QyxTQUFTOytCQUNFLHNCQUFzQjswRUFLNUIsV0FBVztzQkFEZCxLQUFLO3VCQUFDLE1BQU07Z0JBUU4sVUFBVTtzQkFEaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpbGVNZXRhZGF0YSB9IGZyb20gJy4uLy4uL21vZGVscy9maWxlLW1ldGFkYXRhJztcbmltcG9ydCB7IFN1YmplY3QsIGZpbHRlciwgbWVyZ2VNYXAsIHRhcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2ZpbGUtdmlld2VyJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYzMtZmlsZS12aWV3ZXItdmlkZW8nLFxuICB0ZW1wbGF0ZVVybDogJy4vYzMtZmlsZS12aWV3ZXItdmlkZW8uY29tcG9uZW50Lmh0bWwnLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJWaWRlb0NvbXBvbmVudCB7XG4gIEBJbnB1dCgnZmlsZScpXG4gIHNldCBfc3JjVXBkYXRlZCh7IGxvY2F0aW9uIH06IEZpbGVNZXRhZGF0YSkge1xuICAgIHRoaXMuc3JjJC5uZXh0KGxvY2F0aW9uKTtcbiAgfVxuICBzcmMgPSAnJztcbiAgcHJpdmF0ZSBzcmMkID0gbmV3IFN1YmplY3Q8c3RyaW5nPigpO1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBmaWxlVmlld2VyITogQzNGaWxlVmlld2VyO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuc3JjJFxuICAgICAgLnBpcGUoXG4gICAgICAgIG1lcmdlTWFwKChzcmMpID0+IHRoaXMuZmlsZVZpZXdlci5nZXRGaWxlKHNyYykpLFxuICAgICAgICBmaWx0ZXIoKGJsb2IpID0+IGJsb2IudHlwZS5zdGFydHNXaXRoKCdhcHBsaWNhdGlvbi9wZGYnKSksXG4gICAgICAgIHRhcCgoYmxvYikgPT4gKHRoaXMuc3JjID0gVVJMLmNyZWF0ZU9iamVjdFVSTChibG9iKSkpXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKHtcbiAgICAgICAgbmV4dDogKCkgPT4gbnVsbCxcbiAgICAgICAgZXJyb3I6IChlcnJvcikgPT4ge1xuICAgICAgICAgIGNvbnNvbGUubG9nKGVycm9yKTtcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICB9XG59XG4iLCI8dmlkZW8gY29udHJvbHMgW3NyY109XCJzcmNcIiBjcm9zc29yaWdpbj1cIipcIj48L3ZpZGVvPlxuIl19
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export const DEFAULT_CONFIG = {
|
|
2
|
+
btnContainerClass: 'btn-container',
|
|
3
|
+
btnClass: 'default',
|
|
4
|
+
btnSubClass: 'material-icons',
|
|
5
|
+
zoomFactor: 0.1,
|
|
6
|
+
containerBackgroundColor: '#00000000',
|
|
7
|
+
wheelZoom: false,
|
|
8
|
+
allowFullscreen: true,
|
|
9
|
+
allowKeyboardNavigation: true,
|
|
10
|
+
btnShow: {
|
|
11
|
+
zoomIn: true,
|
|
12
|
+
zoomOut: true,
|
|
13
|
+
rotateClockwise: true,
|
|
14
|
+
rotateCounterClockwise: true,
|
|
15
|
+
next: true,
|
|
16
|
+
prev: true,
|
|
17
|
+
reset: true,
|
|
18
|
+
},
|
|
19
|
+
btnIcons: {
|
|
20
|
+
zoomIn: {
|
|
21
|
+
text: 'zoom_in',
|
|
22
|
+
},
|
|
23
|
+
zoomOut: {
|
|
24
|
+
text: 'zoom_out',
|
|
25
|
+
},
|
|
26
|
+
rotateClockwise: {
|
|
27
|
+
text: 'rotate_right',
|
|
28
|
+
},
|
|
29
|
+
rotateCounterClockwise: {
|
|
30
|
+
text: 'rotate_left',
|
|
31
|
+
},
|
|
32
|
+
fullscreen: {
|
|
33
|
+
text: 'fullscreen',
|
|
34
|
+
},
|
|
35
|
+
reset: {
|
|
36
|
+
text: 'restore',
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jMy1jb21wb25lbnRzL3NyYy9saWIvYzMtZmlsZS12aWV3ZXIvY29uc3RzL2RlZmF1bHQuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBdUI7SUFDaEQsaUJBQWlCLEVBQUUsZUFBZTtJQUNsQyxRQUFRLEVBQUUsU0FBUztJQUNuQixXQUFXLEVBQUUsZ0JBQWdCO0lBQzdCLFVBQVUsRUFBRSxHQUFHO0lBQ2Ysd0JBQXdCLEVBQUUsV0FBVztJQUNyQyxTQUFTLEVBQUUsS0FBSztJQUNoQixlQUFlLEVBQUUsSUFBSTtJQUNyQix1QkFBdUIsRUFBRSxJQUFJO0lBQzdCLE9BQU8sRUFBRTtRQUNQLE1BQU0sRUFBRSxJQUFJO1FBQ1osT0FBTyxFQUFFLElBQUk7UUFDYixlQUFlLEVBQUUsSUFBSTtRQUNyQixzQkFBc0IsRUFBRSxJQUFJO1FBQzVCLElBQUksRUFBRSxJQUFJO1FBQ1YsSUFBSSxFQUFFLElBQUk7UUFDVixLQUFLLEVBQUUsSUFBSTtLQUNaO0lBQ0QsUUFBUSxFQUFFO1FBQ1IsTUFBTSxFQUFFO1lBQ04sSUFBSSxFQUFFLFNBQVM7U0FDaEI7UUFDRCxPQUFPLEVBQUU7WUFDUCxJQUFJLEVBQUUsVUFBVTtTQUNqQjtRQUNELGVBQWUsRUFBRTtZQUNmLElBQUksRUFBRSxjQUFjO1NBQ3JCO1FBQ0Qsc0JBQXNCLEVBQUU7WUFDdEIsSUFBSSxFQUFFLGFBQWE7U0FDcEI7UUFDRCxVQUFVLEVBQUU7WUFDVixJQUFJLEVBQUUsWUFBWTtTQUNuQjtRQUNELEtBQUssRUFBRTtZQUNMLElBQUksRUFBRSxTQUFTO1NBQ2hCO0tBQ0Y7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi4vbW9kZWxzL2ZpbGUtdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0NPTkZJRzogQzNGaWxlVmlld2VyQ29uZmlnID0ge1xuICBidG5Db250YWluZXJDbGFzczogJ2J0bi1jb250YWluZXInLFxuICBidG5DbGFzczogJ2RlZmF1bHQnLFxuICBidG5TdWJDbGFzczogJ21hdGVyaWFsLWljb25zJyxcbiAgem9vbUZhY3RvcjogMC4xLFxuICBjb250YWluZXJCYWNrZ3JvdW5kQ29sb3I6ICcjMDAwMDAwMDAnLFxuICB3aGVlbFpvb206IGZhbHNlLFxuICBhbGxvd0Z1bGxzY3JlZW46IHRydWUsXG4gIGFsbG93S2V5Ym9hcmROYXZpZ2F0aW9uOiB0cnVlLFxuICBidG5TaG93OiB7XG4gICAgem9vbUluOiB0cnVlLFxuICAgIHpvb21PdXQ6IHRydWUsXG4gICAgcm90YXRlQ2xvY2t3aXNlOiB0cnVlLFxuICAgIHJvdGF0ZUNvdW50ZXJDbG9ja3dpc2U6IHRydWUsXG4gICAgbmV4dDogdHJ1ZSxcbiAgICBwcmV2OiB0cnVlLFxuICAgIHJlc2V0OiB0cnVlLFxuICB9LFxuICBidG5JY29uczoge1xuICAgIHpvb21Jbjoge1xuICAgICAgdGV4dDogJ3pvb21faW4nLFxuICAgIH0sXG4gICAgem9vbU91dDoge1xuICAgICAgdGV4dDogJ3pvb21fb3V0JyxcbiAgICB9LFxuICAgIHJvdGF0ZUNsb2Nrd2lzZToge1xuICAgICAgdGV4dDogJ3JvdGF0ZV9yaWdodCcsXG4gICAgfSxcbiAgICByb3RhdGVDb3VudGVyQ2xvY2t3aXNlOiB7XG4gICAgICB0ZXh0OiAncm90YXRlX2xlZnQnLFxuICAgIH0sXG4gICAgZnVsbHNjcmVlbjoge1xuICAgICAgdGV4dDogJ2Z1bGxzY3JlZW4nLFxuICAgIH0sXG4gICAgcmVzZXQ6IHtcbiAgICAgIHRleHQ6ICdyZXN0b3JlJyxcbiAgICB9LFxuICB9LFxufTtcbiJdfQ==
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, debounceTime, filter, skip } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class FullScreenDirective {
|
|
5
|
+
set fullscreenState(value) {
|
|
6
|
+
this._fullscreenState.next(value?.valueOf() || false);
|
|
7
|
+
}
|
|
8
|
+
set fullscreenStateSetter(value) {
|
|
9
|
+
this.fullscreenState = value;
|
|
10
|
+
}
|
|
11
|
+
constructor(el) {
|
|
12
|
+
this.el = el;
|
|
13
|
+
this._fullscreenState = new BehaviorSubject(false);
|
|
14
|
+
this._fullscreenState
|
|
15
|
+
.pipe(filter((value) => value !== null), skip(2), debounceTime(100))
|
|
16
|
+
.subscribe(() => {
|
|
17
|
+
this.defineState();
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
defineState() {
|
|
21
|
+
if (this._fullscreenState.getValue()) {
|
|
22
|
+
const element = this.el.nativeElement;
|
|
23
|
+
const requestMethod = element.requestFullscreen ||
|
|
24
|
+
element.webkitRequestFullScreen ||
|
|
25
|
+
element.mozRequestFullScreen ||
|
|
26
|
+
element.msRequestFullScreen;
|
|
27
|
+
if (requestMethod) {
|
|
28
|
+
// Native full screen.
|
|
29
|
+
requestMethod.call(element);
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
console.log('FullScreen Request Method Not Supported on this browser.');
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
const element = document;
|
|
37
|
+
const requestMethod = element.cancelFullscreen ||
|
|
38
|
+
element.webkitExitFullscreen ||
|
|
39
|
+
element.webkitCancelFullScreen ||
|
|
40
|
+
element.mozCancelFullScreen ||
|
|
41
|
+
element.msExitFullScreen;
|
|
42
|
+
if (requestMethod) {
|
|
43
|
+
// Native Cancel full screen.
|
|
44
|
+
requestMethod.call(element);
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
console.log('FullScreen Cancel Request Method Not Supported on this browser.');
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
FullScreenDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: FullScreenDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
53
|
+
FullScreenDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.8", type: FullScreenDirective, selector: "[C3FullScreen], [c3-full-screen]", inputs: { fullscreenState: ["c3Screenfull", "fullscreenState"], fullscreenStateSetter: ["c3-full-screen", "fullscreenStateSetter"] }, ngImport: i0 });
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: FullScreenDirective, decorators: [{
|
|
55
|
+
type: Directive,
|
|
56
|
+
args: [{
|
|
57
|
+
selector: '[C3FullScreen], [c3-full-screen]',
|
|
58
|
+
}]
|
|
59
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { fullscreenState: [{
|
|
60
|
+
type: Input,
|
|
61
|
+
args: ['c3Screenfull']
|
|
62
|
+
}], fullscreenStateSetter: [{
|
|
63
|
+
type: Input,
|
|
64
|
+
args: ['c3-full-screen']
|
|
65
|
+
}] } });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVsbC1zY3JlZW4uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2RpcmVjdGl2ZXMvZnVsbC1zY3JlZW4uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBRSxlQUFlLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQWEsTUFBTSxNQUFNLENBQUM7O0FBSzlFLE1BQU0sT0FBTyxtQkFBbUI7SUFDOUIsSUFDSSxlQUFlLENBQUMsS0FBcUI7UUFDdkMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLElBQUksS0FBSyxDQUFDLENBQUM7SUFDeEQsQ0FBQztJQUVELElBQ0kscUJBQXFCLENBQUMsS0FBcUI7UUFDN0MsSUFBSSxDQUFDLGVBQWUsR0FBRyxLQUFLLENBQUM7SUFDL0IsQ0FBQztJQUlELFlBQW9CLEVBQWM7UUFBZCxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBRjFCLHFCQUFnQixHQUFHLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBR3BELElBQUksQ0FBQyxnQkFBZ0I7YUFDbEIsSUFBSSxDQUNILE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxLQUFLLElBQUksQ0FBQyxFQUNqQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQ1AsWUFBWSxDQUFDLEdBQUcsQ0FBQyxDQUNsQjthQUNBLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU8sV0FBVztRQUNqQixJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUNwQyxNQUFNLE9BQU8sR0FBUSxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztZQUUzQyxNQUFNLGFBQWEsR0FDakIsT0FBTyxDQUFDLGlCQUFpQjtnQkFDekIsT0FBTyxDQUFDLHVCQUF1QjtnQkFDL0IsT0FBTyxDQUFDLG9CQUFvQjtnQkFDNUIsT0FBTyxDQUFDLG1CQUFtQixDQUFDO1lBRTlCLElBQUksYUFBYSxFQUFFO2dCQUNqQixzQkFBc0I7Z0JBQ3RCLGFBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7YUFDN0I7aUJBQU07Z0JBQ0wsT0FBTyxDQUFDLEdBQUcsQ0FBQywwREFBMEQsQ0FBQyxDQUFDO2FBQ3pFO1NBQ0Y7YUFBTTtZQUNMLE1BQU0sT0FBTyxHQUFRLFFBQVEsQ0FBQztZQUU5QixNQUFNLGFBQWEsR0FDakIsT0FBTyxDQUFDLGdCQUFnQjtnQkFDeEIsT0FBTyxDQUFDLG9CQUFvQjtnQkFDNUIsT0FBTyxDQUFDLHNCQUFzQjtnQkFDOUIsT0FBTyxDQUFDLG1CQUFtQjtnQkFDM0IsT0FBTyxDQUFDLGdCQUFnQixDQUFDO1lBRTNCLElBQUksYUFBYSxFQUFFO2dCQUNqQiw2QkFBNkI7Z0JBQzdCLGFBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7YUFDN0I7aUJBQU07Z0JBQ0wsT0FBTyxDQUFDLEdBQUcsQ0FDVCxpRUFBaUUsQ0FDbEUsQ0FBQzthQUNIO1NBQ0Y7SUFDSCxDQUFDOztnSEE1RFUsbUJBQW1CO29HQUFuQixtQkFBbUI7MkZBQW5CLG1CQUFtQjtrQkFIL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0NBQWtDO2lCQUM3QztpR0FHSyxlQUFlO3NCQURsQixLQUFLO3VCQUFDLGNBQWM7Z0JBTWpCLHFCQUFxQjtzQkFEeEIsS0FBSzt1QkFBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIGRlYm91bmNlVGltZSwgZmlsdGVyLCBza2lwLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW0MzRnVsbFNjcmVlbl0sIFtjMy1mdWxsLXNjcmVlbl0nLFxufSlcbmV4cG9ydCBjbGFzcyBGdWxsU2NyZWVuRGlyZWN0aXZlIHtcbiAgQElucHV0KCdjM1NjcmVlbmZ1bGwnKVxuICBzZXQgZnVsbHNjcmVlblN0YXRlKHZhbHVlOiBCb29sZWFuIHwgbnVsbCkge1xuICAgIHRoaXMuX2Z1bGxzY3JlZW5TdGF0ZS5uZXh0KHZhbHVlPy52YWx1ZU9mKCkgfHwgZmFsc2UpO1xuICB9XG5cbiAgQElucHV0KCdjMy1mdWxsLXNjcmVlbicpXG4gIHNldCBmdWxsc2NyZWVuU3RhdGVTZXR0ZXIodmFsdWU6IEJvb2xlYW4gfCBudWxsKSB7XG4gICAgdGhpcy5mdWxsc2NyZWVuU3RhdGUgPSB2YWx1ZTtcbiAgfVxuXG4gIHByaXZhdGUgX2Z1bGxzY3JlZW5TdGF0ZSA9IG5ldyBCZWhhdmlvclN1YmplY3QoZmFsc2UpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHtcbiAgICB0aGlzLl9mdWxsc2NyZWVuU3RhdGVcbiAgICAgIC5waXBlKFxuICAgICAgICBmaWx0ZXIoKHZhbHVlKSA9PiB2YWx1ZSAhPT0gbnVsbCksXG4gICAgICAgIHNraXAoMiksXG4gICAgICAgIGRlYm91bmNlVGltZSgxMDApXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgdGhpcy5kZWZpbmVTdGF0ZSgpO1xuICAgICAgfSk7XG4gIH1cblxuICBwcml2YXRlIGRlZmluZVN0YXRlKCkge1xuICAgIGlmICh0aGlzLl9mdWxsc2NyZWVuU3RhdGUuZ2V0VmFsdWUoKSkge1xuICAgICAgY29uc3QgZWxlbWVudDogYW55ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50O1xuXG4gICAgICBjb25zdCByZXF1ZXN0TWV0aG9kID1cbiAgICAgICAgZWxlbWVudC5yZXF1ZXN0RnVsbHNjcmVlbiB8fFxuICAgICAgICBlbGVtZW50LndlYmtpdFJlcXVlc3RGdWxsU2NyZWVuIHx8XG4gICAgICAgIGVsZW1lbnQubW96UmVxdWVzdEZ1bGxTY3JlZW4gfHxcbiAgICAgICAgZWxlbWVudC5tc1JlcXVlc3RGdWxsU2NyZWVuO1xuXG4gICAgICBpZiAocmVxdWVzdE1ldGhvZCkge1xuICAgICAgICAvLyBOYXRpdmUgZnVsbCBzY3JlZW4uXG4gICAgICAgIHJlcXVlc3RNZXRob2QuY2FsbChlbGVtZW50KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnNvbGUubG9nKCdGdWxsU2NyZWVuIFJlcXVlc3QgTWV0aG9kIE5vdCBTdXBwb3J0ZWQgb24gdGhpcyBicm93c2VyLicpO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBlbGVtZW50OiBhbnkgPSBkb2N1bWVudDtcblxuICAgICAgY29uc3QgcmVxdWVzdE1ldGhvZCA9XG4gICAgICAgIGVsZW1lbnQuY2FuY2VsRnVsbHNjcmVlbiB8fFxuICAgICAgICBlbGVtZW50LndlYmtpdEV4aXRGdWxsc2NyZWVuIHx8XG4gICAgICAgIGVsZW1lbnQud2Via2l0Q2FuY2VsRnVsbFNjcmVlbiB8fFxuICAgICAgICBlbGVtZW50Lm1vekNhbmNlbEZ1bGxTY3JlZW4gfHxcbiAgICAgICAgZWxlbWVudC5tc0V4aXRGdWxsU2NyZWVuO1xuXG4gICAgICBpZiAocmVxdWVzdE1ldGhvZCkge1xuICAgICAgICAvLyBOYXRpdmUgQ2FuY2VsIGZ1bGwgc2NyZWVuLlxuICAgICAgICByZXF1ZXN0TWV0aG9kLmNhbGwoZWxlbWVudCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgICAnRnVsbFNjcmVlbiBDYW5jZWwgUmVxdWVzdCBNZXRob2QgTm90IFN1cHBvcnRlZCBvbiB0aGlzIGJyb3dzZXIuJ1xuICAgICAgICApO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export class CustomFileEvent {
|
|
2
|
+
constructor(name, fileUrl) {
|
|
3
|
+
this.name = name;
|
|
4
|
+
this.fileUrl = fileUrl;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWZpbGUtZXZlbnQubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jMy1jb21wb25lbnRzL3NyYy9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2N1c3RvbS1maWxlLWV2ZW50Lm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxlQUFlO0lBSTFCLFlBQVksSUFBWSxFQUFFLE9BQWU7UUFDdkMsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDekIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIEN1c3RvbUZpbGVFdmVudCB7XG4gIHB1YmxpYyBuYW1lOiBzdHJpbmc7XG4gIHB1YmxpYyBmaWxlVXJsOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IobmFtZTogc3RyaW5nLCBmaWxlVXJsOiBzdHJpbmcpIHtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICAgIHRoaXMuZmlsZVVybCA9IGZpbGVVcmw7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1tZXRhZGF0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9tb2RlbHMvZmlsZS1tZXRhZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEZpbGVNZXRhZGF0YSB7XG4gIG5hbWU6IHN0cmluZztcbiAgc2l6ZT86IG51bWJlcjtcbiAgdHlwZTogc3RyaW5nO1xuICBsYXN0TW9kaWZpZWQ/OiBEYXRlO1xuICBjcmVhdGVkPzogRGF0ZTtcbiAgZXh0ZW5zaW9uPzogc3RyaW5nO1xuICBsb2NhdGlvbjogc3RyaW5nO1xuICBvYmplY3RVcmw/OiBPYnNlcnZhYmxlPHN0cmluZz47XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55Pjtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS12aWV3ZXItY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLXZpZXdlci1jb25maWcubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQzNGaWxlVmlld2VyQ29uZmlnIHtcbiAgYnRuQ29udGFpbmVyQ2xhc3M/OiBzdHJpbmc7XG4gIGJ0bkNsYXNzPzogc3RyaW5nO1xuICBidG5TdWJDbGFzcz86IHN0cmluZztcbiAgem9vbUZhY3Rvcj86IG51bWJlcjtcbiAgY29udGFpbmVyQmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICB3aGVlbFpvb20/OiBib29sZWFuO1xuICBhbGxvd0Z1bGxzY3JlZW4/OiBib29sZWFuO1xuICBhbGxvd0tleWJvYXJkTmF2aWdhdGlvbj86IGJvb2xlYW47XG4gIGN1c3RvbUNsaWVudD86IEh0dHBDbGllbnRbJ2dldCddO1xuXG4gIG1pbkhlaWdodD86IG51bWJlciB8IHN0cmluZztcbiAgbWluV2lkdGg/OiBudW1iZXIgfCBzdHJpbmc7XG4gIHdpZHRoPzogbnVtYmVyIHwgc3RyaW5nO1xuICBtYXhIZWlnaHQ/OiBudW1iZXIgfCBzdHJpbmc7XG4gIGhlaWdodD86IG51bWJlciB8IHN0cmluZztcbiAgbWF4V2lkdGg/OiBudW1iZXIgfCBzdHJpbmc7XG5cbiAgYnRuU2hvdz86IHtcbiAgICB6b29tSW4/OiBib29sZWFuO1xuICAgIHpvb21PdXQ/OiBib29sZWFuO1xuICAgIHJvdGF0ZUNsb2Nrd2lzZT86IGJvb2xlYW47XG4gICAgcm90YXRlQ291bnRlckNsb2Nrd2lzZT86IGJvb2xlYW47XG4gICAgbmV4dD86IGJvb2xlYW47XG4gICAgcHJldj86IGJvb2xlYW47XG4gICAgcmVzZXQ/OiBib29sZWFuO1xuICB9O1xuXG4gIGJ0bkljb25zPzoge1xuICAgIHpvb21Jbj86IE11bHRpQnRuWydidG4nXTtcbiAgICB6b29tT3V0PzogTXVsdGlCdG5bJ2J0biddO1xuICAgIHJvdGF0ZUNsb2Nrd2lzZT86IE11bHRpQnRuWydidG4nXTtcbiAgICByb3RhdGVDb3VudGVyQ2xvY2t3aXNlPzogTXVsdGlCdG5bJ2J0biddO1xuICAgIG5leHQ/OiBNdWx0aUJ0blsnYnRuJ107XG4gICAgcHJldj86IE11bHRpQnRuWydidG4nXTtcbiAgICBmdWxsc2NyZWVuPzogTXVsdGlCdG5bJ2J0biddO1xuICAgIHJlc2V0PzogTXVsdGlCdG5bJ2J0biddO1xuICB9O1xuXG4gIGN1c3RvbUJ0bnM/OiBBcnJheTx7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGljb246IE11bHRpQnRuWydidG4nXTtcbiAgfT47XG59XG5cbmludGVyZmFjZSBNdWx0aUJ0biB7XG4gIGJ0bjoge1xuICAgIGNsYXNzZXM/OiBzdHJpbmc7XG4gICAgdGV4dD86IHN0cmluZztcbiAgfTtcbn1cbiJdfQ==
|