c3-components 0.0.1 → 0.0.3
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/README.md +67 -13
- 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 +51 -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-dialog/c3-file-viewer-dialog.mjs +20 -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/components/public/c3-file-viewer/c3-file-viewer.component.mjs +86 -0
- package/esm2020/lib/c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component.mjs +34 -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 +206 -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 +34 -0
- package/fesm2015/c3-components.mjs +1055 -0
- package/fesm2015/c3-components.mjs.map +1 -0
- package/fesm2020/c3-components.mjs +1053 -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 +18 -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-dialog/c3-file-viewer-dialog.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/components/public/c3-file-viewer/c3-file-viewer.component.d.ts +25 -0
- package/lib/c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.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 +65 -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 +5 -4
- package/public-api.d.ts +30 -0
- package/src/lib/c3-file/c3-input-file/components/c3-input-file/c3-input-file.component.scss +3 -0
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { Directive, forwardRef, Input, HostListener, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { OverlayConfig, } from '@angular/cdk/overlay';
|
|
4
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
5
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
6
|
+
import { merge, Subject, Subscription, takeUntil } from 'rxjs';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
9
|
+
export const MAT_DROPDOWN_VALUE_ACCESSOR = {
|
|
10
|
+
provide: NG_VALUE_ACCESSOR,
|
|
11
|
+
useExisting: forwardRef(() => C3DropdownTrigger),
|
|
12
|
+
multi: true,
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* @description The C3DropdownTrigger directive is used to display or hide a dropdown menu
|
|
16
|
+
* C3DropdownComponent when an item is clicked.
|
|
17
|
+
* @selector [c3Dropdown]
|
|
18
|
+
* @exportAs c3DropdownTrigger
|
|
19
|
+
* @input c3Dropdown - A reference to an instance of C3DropdownComponent.
|
|
20
|
+
* @input c3DropdownDisabled - A boolean indicating whether the directive should be disabled.
|
|
21
|
+
* @input c3DropdownClass - A string, an array of strings, a set of strings or a
|
|
22
|
+
* object representing the CSS classes to be applied to the dropdown menu.
|
|
23
|
+
*/
|
|
24
|
+
export class C3DropdownTrigger {
|
|
25
|
+
/** Whether the dropdown is disabled. */
|
|
26
|
+
get dropdownDisabled() {
|
|
27
|
+
return this._dropdownDisabled;
|
|
28
|
+
}
|
|
29
|
+
set dropdownDisabled(value) {
|
|
30
|
+
this._dropdownDisabled = coerceBooleanProperty(value);
|
|
31
|
+
}
|
|
32
|
+
constructor(_element, _overlay, _viewContainerRef) {
|
|
33
|
+
this._element = _element;
|
|
34
|
+
this._overlay = _overlay;
|
|
35
|
+
this._viewContainerRef = _viewContainerRef;
|
|
36
|
+
this._closingActionsSubscription = Subscription.EMPTY;
|
|
37
|
+
this._destroyed = new Subject();
|
|
38
|
+
this._dropdownClass = '';
|
|
39
|
+
this._dropdownDisabled = false;
|
|
40
|
+
/** Classes to be passed to the dropdown menu. Supports the same syntax as `ngClass`. */
|
|
41
|
+
this.dropdownClass = '';
|
|
42
|
+
}
|
|
43
|
+
onClick() {
|
|
44
|
+
this.show();
|
|
45
|
+
}
|
|
46
|
+
ngOnChanges(changes) {
|
|
47
|
+
if (changes['dropdownClass'] && this.dropdown) {
|
|
48
|
+
this.dropdown.dropdownClass = this._dropdownClass;
|
|
49
|
+
this.dropdown._markForCheck();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
ngOnDestroy() {
|
|
53
|
+
this._destroyed.next();
|
|
54
|
+
this._destroyed.complete();
|
|
55
|
+
this._closingActionsSubscription.unsubscribe();
|
|
56
|
+
this.close();
|
|
57
|
+
}
|
|
58
|
+
show() {
|
|
59
|
+
if (!this.dropdown)
|
|
60
|
+
return;
|
|
61
|
+
const overlayRef = this._overlay.create(this._getOverlayConfig());
|
|
62
|
+
const portal = new TemplatePortal(this.dropdown.template, this._viewContainerRef);
|
|
63
|
+
overlayRef.attach(portal);
|
|
64
|
+
this.overlayRef = overlayRef;
|
|
65
|
+
this._closingActionsSubscription = this._menuClosingActions().subscribe(() => this.close());
|
|
66
|
+
}
|
|
67
|
+
close() {
|
|
68
|
+
if (this.overlayRef && this.overlayRef.hasAttached())
|
|
69
|
+
this.overlayRef.detach();
|
|
70
|
+
}
|
|
71
|
+
_getOverlayConfig() {
|
|
72
|
+
const belowPosition = {
|
|
73
|
+
originX: 'start',
|
|
74
|
+
originY: 'bottom',
|
|
75
|
+
overlayX: 'start',
|
|
76
|
+
overlayY: 'top',
|
|
77
|
+
};
|
|
78
|
+
const abovePosition = {
|
|
79
|
+
originX: 'start',
|
|
80
|
+
originY: 'top',
|
|
81
|
+
overlayX: 'start',
|
|
82
|
+
overlayY: 'bottom',
|
|
83
|
+
// The overlay edge connected to the trigger should have squared corners, while
|
|
84
|
+
// the opposite end has rounded corners. We apply a CSS class to swap the
|
|
85
|
+
// border-radius based on the overlay position.
|
|
86
|
+
panelClass: 'mat-autocomplete-panel-above',
|
|
87
|
+
};
|
|
88
|
+
const positionStrategy = this._overlay
|
|
89
|
+
.position()
|
|
90
|
+
.flexibleConnectedTo(this._element)
|
|
91
|
+
.withLockedPosition()
|
|
92
|
+
.withPositions([belowPosition, abovePosition]);
|
|
93
|
+
return new OverlayConfig({
|
|
94
|
+
positionStrategy,
|
|
95
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
96
|
+
hasBackdrop: true,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
/** Returns a stream that emits whenever an action that should close the menu occurs. */
|
|
100
|
+
_menuClosingActions() {
|
|
101
|
+
const backdrop = this.overlayRef.backdropClick();
|
|
102
|
+
const detachments = this.overlayRef.detachments();
|
|
103
|
+
return merge(backdrop, detachments).pipe(takeUntil(this._destroyed));
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
C3DropdownTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3DropdownTrigger, deps: [{ token: i0.ElementRef }, { token: i1.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
107
|
+
C3DropdownTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.8", type: C3DropdownTrigger, selector: "[c3Dropdown]", inputs: { dropdown: ["c3Dropdown", "dropdown"], dropdownDisabled: ["c3DropdownDisabled", "dropdownDisabled"], dropdownClass: ["c3DropdownClass", "dropdownClass"] }, host: { listeners: { "click": "onClick()" } }, providers: [MAT_DROPDOWN_VALUE_ACCESSOR], exportAs: ["c3DropdownTrigger"], usesOnChanges: true, ngImport: i0 });
|
|
108
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3DropdownTrigger, decorators: [{
|
|
109
|
+
type: Directive,
|
|
110
|
+
args: [{
|
|
111
|
+
selector: '[c3Dropdown]',
|
|
112
|
+
exportAs: 'c3DropdownTrigger',
|
|
113
|
+
providers: [MAT_DROPDOWN_VALUE_ACCESSOR],
|
|
114
|
+
}]
|
|
115
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.Overlay }, { type: i0.ViewContainerRef }]; }, propDecorators: { dropdown: [{
|
|
116
|
+
type: Input,
|
|
117
|
+
args: ['c3Dropdown']
|
|
118
|
+
}], dropdownDisabled: [{
|
|
119
|
+
type: Input,
|
|
120
|
+
args: ['c3DropdownDisabled']
|
|
121
|
+
}], dropdownClass: [{
|
|
122
|
+
type: Input,
|
|
123
|
+
args: ['c3DropdownClass']
|
|
124
|
+
}], onClick: [{
|
|
125
|
+
type: HostListener,
|
|
126
|
+
args: ['click']
|
|
127
|
+
}] } });
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c3-dropdown.trigger.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-dropdown/directives/c3-dropdown.trigger.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EAGV,KAAK,EAEL,YAAY,GAGb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAGL,aAAa,GAEd,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;AAE/D,MAAM,CAAC,MAAM,2BAA2B,GAAQ;IAC9C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;IAChD,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF;;;;;;;;;GASG;AAMH,MAAM,OAAO,iBAAiB;IAiB5B,wCAAwC;IACxC,IACI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,gBAAgB,CAAC,KAAc;QACjC,IAAI,CAAC,iBAAiB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IAMD,YACU,QAAiC,EACjC,QAAiB,EACjB,iBAAmC;QAFnC,aAAQ,GAAR,QAAQ,CAAyB;QACjC,aAAQ,GAAR,QAAQ,CAAS;QACjB,sBAAiB,GAAjB,iBAAiB,CAAkB;QA/BrC,gCAA2B,GAAiB,YAAY,CAAC,KAAK,CAAC;QAC/D,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEjC,mBAAc,GAIO,EAAE,CAAC;QAExB,sBAAiB,GAAY,KAAK,CAAC;QAe3C,wFAAwF;QAExF,kBAAa,GAA6D,EAAE,CAAC;IAM1E,CAAC;IAGJ,OAAO;QACL,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,eAAe,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC7C,IAAI,CAAC,QAAQ,CAAC,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC;YAClD,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;SAC/B;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;QAC/C,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAEM,IAAI;QACT,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAE3B,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QAClE,MAAM,MAAM,GAAG,IAAI,cAAc,CAC/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,EACtB,IAAI,CAAC,iBAAiB,CACvB,CAAC;QACF,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAE1B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAE7B,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC,SAAS,CACrE,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CACnB,CAAC;IACJ,CAAC;IAEM,KAAK;QACV,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE;YAClD,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;IAC7B,CAAC;IAEO,iBAAiB;QACvB,MAAM,aAAa,GAAsB;YACvC,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,QAAQ;YACjB,QAAQ,EAAE,OAAO;YACjB,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,MAAM,aAAa,GAAsB;YACvC,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,OAAO;YACjB,QAAQ,EAAE,QAAQ;YAElB,+EAA+E;YAC/E,yEAAyE;YACzE,+CAA+C;YAC/C,UAAU,EAAE,8BAA8B;SAC3C,CAAC;QAEF,MAAM,gBAAgB,GAAG,IAAI,CAAC,QAAQ;aACnC,QAAQ,EAAE;aACV,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC;aAClC,kBAAkB,EAAE;aACpB,aAAa,CAAC,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC,CAAC;QAEjD,OAAO,IAAI,aAAa,CAAC;YACvB,gBAAgB;YAChB,aAAa,EAAE,kCAAkC;YACjD,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC;IACL,CAAC;IAED,wFAAwF;IAChF,mBAAmB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAW,CAAC,aAAa,EAAE,CAAC;QAClD,MAAM,WAAW,GAAG,IAAI,CAAC,UAAW,CAAC,WAAW,EAAE,CAAC;QAEnD,OAAO,KAAK,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;IACvE,CAAC;;8GAnHU,iBAAiB;kGAAjB,iBAAiB,2PAFjB,CAAC,2BAA2B,CAAC;2FAE7B,iBAAiB;kBAL7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,QAAQ,EAAE,mBAAmB;oBAC7B,SAAS,EAAE,CAAC,2BAA2B,CAAC;iBACzC;sJAgBC,QAAQ;sBADP,KAAK;uBAAC,YAAY;gBAKf,gBAAgB;sBADnB,KAAK;uBAAC,oBAAoB;gBAU3B,aAAa;sBADZ,KAAK;uBAAC,iBAAiB;gBAUxB,OAAO;sBADN,YAAY;uBAAC,OAAO","sourcesContent":["import {\n  Directive,\n  forwardRef,\n  ElementRef,\n  ViewContainerRef,\n  Input,\n  OnDestroy,\n  HostListener,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport {\n  Overlay,\n  OverlayRef,\n  OverlayConfig,\n  ConnectedPosition,\n} from '@angular/cdk/overlay';\nimport { C3DropdownComponent } from '../components/c3-dropdown.component';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { merge, Subject, Subscription, takeUntil } from 'rxjs';\n\nexport const MAT_DROPDOWN_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => C3DropdownTrigger),\n  multi: true,\n};\n\n/**\n * @description The C3DropdownTrigger directive is used to display or hide a dropdown menu\n * C3DropdownComponent when an item is clicked.\n * @selector [c3Dropdown]\n * @exportAs c3DropdownTrigger\n * @input c3Dropdown - A reference to an instance of C3DropdownComponent.\n * @input c3DropdownDisabled - A boolean indicating whether the directive should be disabled.\n * @input c3DropdownClass - A string, an array of strings, a set of strings or a\n * object representing the CSS classes to be applied to the dropdown menu.\n */\n@Directive({\n  selector: '[c3Dropdown]',\n  exportAs: 'c3DropdownTrigger',\n  providers: [MAT_DROPDOWN_VALUE_ACCESSOR],\n})\nexport class C3DropdownTrigger implements OnChanges, OnDestroy {\n  private overlayRef?: OverlayRef | null;\n  private _closingActionsSubscription: Subscription = Subscription.EMPTY;\n  private _destroyed = new Subject<void>();\n\n  private _dropdownClass:\n    | string\n    | string[]\n    | Set<string>\n    | { [key: string]: any } = '';\n\n  private _dropdownDisabled: boolean = false;\n\n  /** The dropdown menu instance */\n  @Input('c3Dropdown')\n  dropdown?: C3DropdownComponent;\n\n  /** Whether the dropdown is disabled. */\n  @Input('c3DropdownDisabled')\n  get dropdownDisabled(): boolean {\n    return this._dropdownDisabled;\n  }\n  set dropdownDisabled(value: boolean) {\n    this._dropdownDisabled = coerceBooleanProperty(value);\n  }\n\n  /** Classes to be passed to the dropdown menu. Supports the same syntax as `ngClass`. */\n  @Input('c3DropdownClass')\n  dropdownClass: string | string[] | Set<string> | { [key: string]: any } = '';\n\n  constructor(\n    private _element: ElementRef<HTMLElement>,\n    private _overlay: Overlay,\n    private _viewContainerRef: ViewContainerRef\n  ) {}\n\n  @HostListener('click')\n  onClick() {\n    this.show();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['dropdownClass'] && this.dropdown) {\n      this.dropdown.dropdownClass = this._dropdownClass;\n      this.dropdown._markForCheck();\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroyed.next();\n    this._destroyed.complete();\n    this._closingActionsSubscription.unsubscribe();\n    this.close();\n  }\n\n  public show(): void {\n    if (!this.dropdown) return;\n\n    const overlayRef = this._overlay.create(this._getOverlayConfig());\n    const portal = new TemplatePortal(\n      this.dropdown.template,\n      this._viewContainerRef\n    );\n    overlayRef.attach(portal);\n\n    this.overlayRef = overlayRef;\n\n    this._closingActionsSubscription = this._menuClosingActions().subscribe(\n      () => this.close()\n    );\n  }\n\n  public close(): void {\n    if (this.overlayRef && this.overlayRef.hasAttached())\n      this.overlayRef.detach();\n  }\n\n  private _getOverlayConfig(): OverlayConfig {\n    const belowPosition: ConnectedPosition = {\n      originX: 'start',\n      originY: 'bottom',\n      overlayX: 'start',\n      overlayY: 'top',\n    };\n    const abovePosition: ConnectedPosition = {\n      originX: 'start',\n      originY: 'top',\n      overlayX: 'start',\n      overlayY: 'bottom',\n\n      // The overlay edge connected to the trigger should have squared corners, while\n      // the opposite end has rounded corners. We apply a CSS class to swap the\n      // border-radius based on the overlay position.\n      panelClass: 'mat-autocomplete-panel-above',\n    };\n\n    const positionStrategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this._element)\n      .withLockedPosition()\n      .withPositions([belowPosition, abovePosition]);\n\n    return new OverlayConfig({\n      positionStrategy,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      hasBackdrop: true,\n    });\n  }\n\n  /** Returns a stream that emits whenever an action that should close the menu occurs. */\n  private _menuClosingActions() {\n    const backdrop = this.overlayRef!.backdropClick();\n    const detachments = this.overlayRef!.detachments();\n\n    return merge(backdrop, detachments).pipe(takeUntil(this._destroyed));\n  }\n}\n"]}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { FullScreenDirective } from './directives/full-screen.directive';
|
|
3
|
+
import { C3FileViewerComponent } from './components/public/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 { C3FileViewerDialogComponent } from './components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component';
|
|
12
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
13
|
+
import { C3FileViewerDialog } from './components/c3-file-viewer-dialog/c3-file-viewer-dialog';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
export class C3FileViewerModule {
|
|
16
|
+
}
|
|
17
|
+
C3FileViewerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
18
|
+
C3FileViewerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, declarations: [FullScreenDirective,
|
|
19
|
+
C3FileViewerComponent,
|
|
20
|
+
C3FileViewerActionsComponent,
|
|
21
|
+
C3FileViewerImageComponent,
|
|
22
|
+
C3FileViewerPdfComponent,
|
|
23
|
+
C3FileViewerVideoComponent,
|
|
24
|
+
C3FileViewerDialogComponent,
|
|
25
|
+
C3FileViewerDialog], imports: [CommonModule, HttpClientModule, C3SafeUrlPipe, MatDialogModule], exports: [FullScreenDirective,
|
|
26
|
+
C3FileViewerComponent,
|
|
27
|
+
C3FileViewerDialogComponent] });
|
|
28
|
+
C3FileViewerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, imports: [CommonModule, HttpClientModule, MatDialogModule] });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, decorators: [{
|
|
30
|
+
type: NgModule,
|
|
31
|
+
args: [{
|
|
32
|
+
providers: [],
|
|
33
|
+
declarations: [
|
|
34
|
+
FullScreenDirective,
|
|
35
|
+
C3FileViewerComponent,
|
|
36
|
+
C3FileViewerActionsComponent,
|
|
37
|
+
C3FileViewerImageComponent,
|
|
38
|
+
C3FileViewerPdfComponent,
|
|
39
|
+
C3FileViewerVideoComponent,
|
|
40
|
+
C3FileViewerDialogComponent,
|
|
41
|
+
C3FileViewerDialog,
|
|
42
|
+
],
|
|
43
|
+
imports: [CommonModule, HttpClientModule, C3SafeUrlPipe, MatDialogModule],
|
|
44
|
+
exports: [
|
|
45
|
+
FullScreenDirective,
|
|
46
|
+
C3FileViewerComponent,
|
|
47
|
+
C3FileViewerDialogComponent,
|
|
48
|
+
],
|
|
49
|
+
}]
|
|
50
|
+
}] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQztBQUNwSCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUM5RyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQztBQUN4RyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUM5RyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkVBQTJFLENBQUM7QUFDeEgsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBEQUEwRCxDQUFDOztBQXFCOUYsTUFBTSxPQUFPLGtCQUFrQjs7K0dBQWxCLGtCQUFrQjtnSEFBbEIsa0JBQWtCLGlCQWhCM0IsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQiw0QkFBNEI7UUFDNUIsMEJBQTBCO1FBQzFCLHdCQUF3QjtRQUN4QiwwQkFBMEI7UUFDMUIsMkJBQTJCO1FBQzNCLGtCQUFrQixhQUVWLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsZUFBZSxhQUV0RSxtQkFBbUI7UUFDbkIscUJBQXFCO1FBQ3JCLDJCQUEyQjtnSEFHbEIsa0JBQWtCLFlBUG5CLFlBQVksRUFBRSxnQkFBZ0IsRUFBaUIsZUFBZTsyRkFPN0Qsa0JBQWtCO2tCQW5COUIsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUUsRUFBRTtvQkFDYixZQUFZLEVBQUU7d0JBQ1osbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLDRCQUE0Qjt3QkFDNUIsMEJBQTBCO3dCQUMxQix3QkFBd0I7d0JBQ3hCLDBCQUEwQjt3QkFDMUIsMkJBQTJCO3dCQUMzQixrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsZUFBZSxDQUFDO29CQUN6RSxPQUFPLEVBQUU7d0JBQ1AsbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLDJCQUEyQjtxQkFDNUI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRnVsbFNjcmVlbkRpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9mdWxsLXNjcmVlbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci9jMy1maWxlLXZpZXdlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlckFjdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItYWN0aW9ucy9jMy1maWxlLXZpZXdlci1hY3Rpb25zLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDM0ZpbGVWaWV3ZXJJbWFnZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1maWxlLXZpZXdlci1pbWFnZS9jMy1maWxlLXZpZXdlci1pbWFnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyUGRmQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLXBkZi9jMy1maWxlLXZpZXdlci1wZGYuY29tcG9uZW50JztcbmltcG9ydCB7IEMzRmlsZVZpZXdlclZpZGVvQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLXZpZGVvL2MzLWZpbGUtdmlld2VyLXZpZGVvLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgQzNTYWZlVXJsUGlwZSB9IGZyb20gJy4uLy4uL3B1YmxpYy1hcGknO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci1kaWFsb2cvYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nIH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLWRpYWxvZy9jMy1maWxlLXZpZXdlci1kaWFsb2cnO1xuXG5ATmdNb2R1bGUoe1xuICBwcm92aWRlcnM6IFtdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBGdWxsU2NyZWVuRGlyZWN0aXZlLFxuICAgIEMzRmlsZVZpZXdlckNvbXBvbmVudCxcbiAgICBDM0ZpbGVWaWV3ZXJBY3Rpb25zQ29tcG9uZW50LFxuICAgIEMzRmlsZVZpZXdlckltYWdlQ29tcG9uZW50LFxuICAgIEMzRmlsZVZpZXdlclBkZkNvbXBvbmVudCxcbiAgICBDM0ZpbGVWaWV3ZXJWaWRlb0NvbXBvbmVudCxcbiAgICBDM0ZpbGVWaWV3ZXJEaWFsb2dDb21wb25lbnQsXG4gICAgQzNGaWxlVmlld2VyRGlhbG9nLFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBIdHRwQ2xpZW50TW9kdWxlLCBDM1NhZmVVcmxQaXBlLCBNYXREaWFsb2dNb2R1bGVdLFxuICBleHBvcnRzOiBbXG4gICAgRnVsbFNjcmVlbkRpcmVjdGl2ZSxcbiAgICBDM0ZpbGVWaWV3ZXJDb21wb25lbnQsXG4gICAgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJNb2R1bGUge31cbiJdfQ==
|
|
@@ -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, Inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../public/c3-file-viewer/c3-file-viewer.component";
|
|
5
|
+
import * as i2 from "../../models/file-viewer";
|
|
6
|
+
export class C3FileViewerDialog {
|
|
7
|
+
constructor(fileViewer) {
|
|
8
|
+
this.fileViewer = fileViewer;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
C3FileViewerDialog.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialog, deps: [{ token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
C3FileViewerDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerDialog, selector: "ng-component", ngImport: i0, template: "<c3-file-viewer [fileViewer]=\"fileViewer\" [screenHeightOccupied]=\"0\" />\n", styles: [""], dependencies: [{ kind: "component", type: i1.C3FileViewerComponent, selector: "c3-file-viewer", inputs: ["screenHeightOccupied", "fileViewer"], outputs: ["indexChange", "configChange", "customFileEvent"] }] });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialog, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{ template: "<c3-file-viewer [fileViewer]=\"fileViewer\" [screenHeightOccupied]=\"0\" />\n" }]
|
|
16
|
+
}], ctorParameters: function () { return [{ type: i2.C3FileViewer, decorators: [{
|
|
17
|
+
type: Inject,
|
|
18
|
+
args: [MAT_DIALOG_DATA]
|
|
19
|
+
}] }]; } });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXItZGlhbG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLWRpYWxvZy9jMy1maWxlLXZpZXdlci1kaWFsb2cuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7QUFPM0QsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixZQUE0QyxVQUF3QjtRQUF4QixlQUFVLEdBQVYsVUFBVSxDQUFjO0lBQUcsQ0FBQzs7K0dBRDdELGtCQUFrQixrQkFDVCxlQUFlO21HQUR4QixrQkFBa0Isb0RDUi9CLCtFQUNBOzJGRE9hLGtCQUFrQjtrQkFKOUIsU0FBUzs7OzBCQUtLLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNQVRfRElBTE9HX0RBVEEgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2ZpbGUtdmlld2VyJztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLXZpZXdlci1kaWFsb2cuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQzNGaWxlVmlld2VyRGlhbG9nIHtcbiAgY29uc3RydWN0b3IoQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBmaWxlVmlld2VyOiBDM0ZpbGVWaWV3ZXIpIHt9XG59XG4iLCI8YzMtZmlsZS12aWV3ZXIgW2ZpbGVWaWV3ZXJdPVwiZmlsZVZpZXdlclwiIFtzY3JlZW5IZWlnaHRPY2N1cGllZF09XCIwXCIgLz5cbiJdfQ==
|
|
@@ -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
|
package/esm2020/lib/c3-file-viewer/components/public/c3-file-viewer/c3-file-viewer.component.mjs
ADDED
|
@@ -0,0 +1,86 @@
|
|
|
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
|
+
this.defineStyleHeight();
|
|
20
|
+
this.fileViewer.customFile$.subscribe((event) => {
|
|
21
|
+
this.customFileEvent.emit(event);
|
|
22
|
+
});
|
|
23
|
+
this.fileViewer.index$.subscribe((index) => {
|
|
24
|
+
this.indexChange.emit(index);
|
|
25
|
+
});
|
|
26
|
+
this.fileViewer.config$.subscribe((config) => {
|
|
27
|
+
this.configChange.emit(config);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
onMouseOver() {
|
|
31
|
+
this.fileViewer.hovered = true;
|
|
32
|
+
}
|
|
33
|
+
onMouseLeave() {
|
|
34
|
+
this.fileViewer.hovered = false;
|
|
35
|
+
}
|
|
36
|
+
ngOnChanges(changes) {
|
|
37
|
+
if (changes['screenHeightOccupied'] && this.fileViewer)
|
|
38
|
+
this.defineStyleHeight();
|
|
39
|
+
}
|
|
40
|
+
next(event) {
|
|
41
|
+
this.fileViewer.nextImage(event);
|
|
42
|
+
}
|
|
43
|
+
previous(event) {
|
|
44
|
+
this.fileViewer.previousImage(event);
|
|
45
|
+
}
|
|
46
|
+
defineStyleHeight() {
|
|
47
|
+
this.fileViewer.styleHeight =
|
|
48
|
+
'calc(100% - ' + this.screenHeightOccupied + 'px)';
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
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 });
|
|
52
|
+
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 });
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerComponent, decorators: [{
|
|
54
|
+
type: Component,
|
|
55
|
+
args: [{ selector: 'c3-file-viewer', encapsulation: ViewEncapsulation.None, host: {
|
|
56
|
+
class: 'c3-file-viewer',
|
|
57
|
+
}, 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" }]
|
|
58
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
59
|
+
type: Optional
|
|
60
|
+
}, {
|
|
61
|
+
type: Inject,
|
|
62
|
+
args: ['config']
|
|
63
|
+
}] }, { type: i1.HttpClient }]; }, propDecorators: { screenHeightOccupied: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}], fileViewer: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], indexChange: [{
|
|
68
|
+
type: Output
|
|
69
|
+
}], configChange: [{
|
|
70
|
+
type: Output
|
|
71
|
+
}], customFileEvent: [{
|
|
72
|
+
type: Output
|
|
73
|
+
}], onMouseOver: [{
|
|
74
|
+
type: HostListener,
|
|
75
|
+
args: ['mouseover']
|
|
76
|
+
}], onMouseLeave: [{
|
|
77
|
+
type: HostListener,
|
|
78
|
+
args: ['mouseleave']
|
|
79
|
+
}], next: [{
|
|
80
|
+
type: HostListener,
|
|
81
|
+
args: ['window:keyup.ArrowRight', ['$event']]
|
|
82
|
+
}], previous: [{
|
|
83
|
+
type: HostListener,
|
|
84
|
+
args: ['window:keyup.ArrowLeft', ['$event']]
|
|
85
|
+
}] } });
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvcHVibGljL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci9jMy1maWxlLXZpZXdlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFFTCxRQUFRLEVBQ1IsTUFBTSxFQUVOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7Ozs7Ozs7O0FBZXZCLE1BQU0sT0FBTyxxQkFBcUI7SUFnQmhDLFlBQ3VDLFlBQWdDLEVBQzlELEtBQWlCO1FBRGEsaUJBQVksR0FBWixZQUFZLENBQW9CO1FBQzlELFVBQUssR0FBTCxLQUFLLENBQVk7UUFWbkIsZ0JBQVcsR0FBeUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUd2RCxpQkFBWSxHQUFxQyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBR3BFLG9CQUFlLEdBQWtDLElBQUksWUFBWSxFQUFFLENBQUM7SUFLeEUsQ0FBQztJQUVKLFFBQVE7UUFDTixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUV6QixJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUM5QyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNuQyxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ3pDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7WUFDM0MsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBR0QsV0FBVztRQUNULElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztJQUNqQyxDQUFDO0lBR0QsWUFBWTtRQUNWLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUNsQyxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksT0FBTyxDQUFDLHNCQUFzQixDQUFDLElBQUksSUFBSSxDQUFDLFVBQVU7WUFDcEQsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUdELElBQUksQ0FBQyxLQUFvQjtRQUN2QixJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBR0QsUUFBUSxDQUFDLEtBQW9CO1FBQzNCLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7SUFFRCxpQkFBaUI7UUFDZixJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVc7WUFDekIsY0FBYyxHQUFHLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7SUFDdkQsQ0FBQzs7a0hBakVVLHFCQUFxQixrQkFpQlYsUUFBUTtzR0FqQm5CLHFCQUFxQiw0ZEMxQmxDLGdoQ0FnQ0E7MkZETmEscUJBQXFCO2tCQVRqQyxTQUFTOytCQUNFLGdCQUFnQixpQkFHWCxpQkFBaUIsQ0FBQyxJQUFJLFFBQy9CO3dCQUNKLEtBQUssRUFBRSxnQkFBZ0I7cUJBQ3hCOzswQkFtQkUsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxRQUFRO3FFQWZ2QixvQkFBb0I7c0JBRDFCLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxXQUFXO3NCQURqQixNQUFNO2dCQUlBLFlBQVk7c0JBRGxCLE1BQU07Z0JBSUEsZUFBZTtzQkFEckIsTUFBTTtnQkF5QlAsV0FBVztzQkFEVixZQUFZO3VCQUFDLFdBQVc7Z0JBTXpCLFlBQVk7c0JBRFgsWUFBWTt1QkFBQyxZQUFZO2dCQVcxQixJQUFJO3NCQURILFlBQVk7dUJBQUMseUJBQXlCLEVBQUUsQ0FBQyxRQUFRLENBQUM7Z0JBTW5ELFFBQVE7c0JBRFAsWUFBWTt1QkFBQyx3QkFBd0IsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBIb3N0TGlzdGVuZXIsXG4gIEluamVjdCxcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgT3B0aW9uYWwsXG4gIE91dHB1dCxcbiAgU2ltcGxlQ2hhbmdlcyxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL2ZpbGUtdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5pbXBvcnQgeyBDdXN0b21GaWxlRXZlbnQgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvY3VzdG9tLWZpbGUtZXZlbnQubW9kZWwnO1xuaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlciB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9maWxlLXZpZXdlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtdmlld2VyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2MzLWZpbGUtdmlld2VyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnYzMtZmlsZS12aWV3ZXInLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgc2NyZWVuSGVpZ2h0T2NjdXBpZWQ/OiAwOyAvLyBJbiBQeFxuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBmaWxlVmlld2VyITogQzNGaWxlVmlld2VyO1xuXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgaW5kZXhDaGFuZ2U6IEV2ZW50RW1pdHRlcjxudW1iZXI+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgY29uZmlnQ2hhbmdlOiBFdmVudEVtaXR0ZXI8QzNGaWxlVmlld2VyQ29uZmlnPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBAT3V0cHV0KClcbiAgcHVibGljIGN1c3RvbUZpbGVFdmVudDogRXZlbnRFbWl0dGVyPEN1c3RvbUZpbGVFdmVudD4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdCgnY29uZmlnJykgcHVibGljIG1vZHVsZUNvbmZpZzogQzNGaWxlVmlld2VyQ29uZmlnLFxuICAgIHB1YmxpYyBfaHR0cDogSHR0cENsaWVudFxuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5kZWZpbmVTdHlsZUhlaWdodCgpO1xuXG4gICAgdGhpcy5maWxlVmlld2VyLmN1c3RvbUZpbGUkLnN1YnNjcmliZSgoZXZlbnQpID0+IHtcbiAgICAgIHRoaXMuY3VzdG9tRmlsZUV2ZW50LmVtaXQoZXZlbnQpO1xuICAgIH0pO1xuXG4gICAgdGhpcy5maWxlVmlld2VyLmluZGV4JC5zdWJzY3JpYmUoKGluZGV4KSA9PiB7XG4gICAgICB0aGlzLmluZGV4Q2hhbmdlLmVtaXQoaW5kZXgpO1xuICAgIH0pO1xuXG4gICAgdGhpcy5maWxlVmlld2VyLmNvbmZpZyQuc3Vic2NyaWJlKChjb25maWcpID0+IHtcbiAgICAgIHRoaXMuY29uZmlnQ2hhbmdlLmVtaXQoY29uZmlnKTtcbiAgICB9KTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlb3ZlcicpXG4gIG9uTW91c2VPdmVyKCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5ob3ZlcmVkID0gdHJ1ZTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnKVxuICBvbk1vdXNlTGVhdmUoKSB7XG4gICAgdGhpcy5maWxlVmlld2VyLmhvdmVyZWQgPSBmYWxzZTtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcbiAgICBpZiAoY2hhbmdlc1snc2NyZWVuSGVpZ2h0T2NjdXBpZWQnXSAmJiB0aGlzLmZpbGVWaWV3ZXIpXG4gICAgICB0aGlzLmRlZmluZVN0eWxlSGVpZ2h0KCk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCd3aW5kb3c6a2V5dXAuQXJyb3dSaWdodCcsIFsnJGV2ZW50J10pXG4gIG5leHQoZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcbiAgICB0aGlzLmZpbGVWaWV3ZXIubmV4dEltYWdlKGV2ZW50KTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzprZXl1cC5BcnJvd0xlZnQnLCBbJyRldmVudCddKVxuICBwcmV2aW91cyhldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5wcmV2aW91c0ltYWdlKGV2ZW50KTtcbiAgfVxuXG4gIGRlZmluZVN0eWxlSGVpZ2h0KCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5zdHlsZUhlaWdodCA9XG4gICAgICAnY2FsYygxMDAlIC0gJyArIHRoaXMuc2NyZWVuSGVpZ2h0T2NjdXBpZWQgKyAncHgpJztcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cImNvbnRhaW5lclwiXG4gICpuZ0lmPVwiZmlsZVZpZXdlclwiXG4gIFtjMy1mdWxsLXNjcmVlbl09XCJmaWxlVmlld2VyLmZ1bGxzY3JlZW4kIHwgYXN5bmNcIlxuICBbc3R5bGUuaGVpZ2h0XT1cImZpbGVWaWV3ZXIuc3R5bGVIZWlnaHRcIlxuICBbc3R5bGUuYmFja2dyb3VuZENvbG9yXT1cImZpbGVWaWV3ZXIuY29uZmlnLmNvbnRhaW5lckJhY2tncm91bmRDb2xvclwiXG4gICh3aGVlbCk9XCJmaWxlVmlld2VyLnNjcm9sbFpvb20oJGV2ZW50KVwiXG4gIChkcmFnb3Zlcik9XCJmaWxlVmlld2VyLm9uRHJhZ092ZXIoJGV2ZW50KVwiXG4+XG4gIDxjMy1maWxlLXZpZXdlci1pbWFnZVxuICAgICpuZ0lmPVwiZmlsZVZpZXdlci5jdXJyZW50RmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2ltYWdlJylcIlxuICAgIFtmaWxlVmlld2VyXT1cImZpbGVWaWV3ZXJcIlxuICAgIFtzdHlsZV09XCJmaWxlVmlld2VyLnN0eWxlXCJcbiAgICAoZHJhZ3N0YXJ0KT1cImZpbGVWaWV3ZXIub25EcmFnU3RhcnQoJGV2ZW50KVwiXG4gIC8+XG5cbiAgPGMzLWZpbGUtdmlld2VyLXZpZGVvXG4gICAgKm5nSWY9XCJmaWxlVmlld2VyLmN1cnJlbnRGaWxlLnR5cGUuc3RhcnRzV2l0aCgndmlkZW8nKVwiXG4gIC8+XG5cbiAgPGMzLWZpbGUtdmlld2VyLXBkZlxuICAgICpuZ0lmPVwiZmlsZVZpZXdlci5jdXJyZW50RmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2FwcGxpY2F0aW9uL3BkZicpXCJcbiAgICBbZmlsZVZpZXdlcl09XCJmaWxlVmlld2VyXCJcbiAgLz5cbiAgPCEtLSBEaXYgYmVsb3cgd2lsbCBiZSB1c2VkIHRvIGhpZGUgdGhlICdnaG9zdCcgaW1hZ2Ugd2hlbiBkcmFnZ2luZyAtLT5cbiAgPGRpdj48L2Rpdj5cbiAgPGRpdiBjbGFzcz1cInNwaW5uZXItY29udGFpbmVyXCIgKm5nSWY9XCJmaWxlVmlld2VyLmxvYWRpbmdcIj5cbiAgICA8ZGl2IGNsYXNzPVwic3Bpbm5lclwiPjwvZGl2PlxuICA8L2Rpdj5cblxuICA8YzMtZmlsZS12aWV3ZXItYWN0aW9ucyBbZmlsZVZpZXdlcl09XCJmaWxlVmlld2VyXCIgLz5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Component, HostListener, Input } from '@angular/core';
|
|
2
|
+
import { C3FileViewerDialog } from '../../c3-file-viewer-dialog/c3-file-viewer-dialog';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/material/dialog";
|
|
5
|
+
export class C3FileViewerDialogComponent {
|
|
6
|
+
constructor(_dialog) {
|
|
7
|
+
this._dialog = _dialog;
|
|
8
|
+
this.dialogConfig = {
|
|
9
|
+
panelClass: 'c3-file-viewer-dialog',
|
|
10
|
+
width: '80%',
|
|
11
|
+
height: '80%',
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
openDialog() {
|
|
15
|
+
this._dialog.open(C3FileViewerDialog, {
|
|
16
|
+
data: this.fileViewer,
|
|
17
|
+
...this.dialogConfig,
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
C3FileViewerDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialogComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
C3FileViewerDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: { fileViewer: "fileViewer", dialogConfig: "dialogConfig" }, host: { listeners: { "click": "openDialog()" } }, ngImport: i0, template: "<ng-content></ng-content>\n", styles: [""] });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialogComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'c3-file-viewer-dialog', template: "<ng-content></ng-content>\n" }]
|
|
26
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }]; }, propDecorators: { fileViewer: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], dialogConfig: [{
|
|
29
|
+
type: Input
|
|
30
|
+
}], openDialog: [{
|
|
31
|
+
type: HostListener,
|
|
32
|
+
args: ['click']
|
|
33
|
+
}] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci1kaWFsb2cvYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci1kaWFsb2cvYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFVLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQU92RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBT3ZGLE1BQU0sT0FBTywyQkFBMkI7SUFXdEMsWUFBb0IsT0FBa0I7UUFBbEIsWUFBTyxHQUFQLE9BQU8sQ0FBVztRQU4vQixpQkFBWSxHQUE2QjtZQUM5QyxVQUFVLEVBQUUsdUJBQXVCO1lBQ25DLEtBQUssRUFBRSxLQUFLO1lBQ1osTUFBTSxFQUFFLEtBQUs7U0FDZCxDQUFDO0lBRXVDLENBQUM7SUFHMUMsVUFBVTtRQUNSLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFO1lBQ3BDLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVTtZQUNyQixHQUFHLElBQUksQ0FBQyxZQUFZO1NBQ3JCLENBQUMsQ0FBQztJQUNMLENBQUM7O3dIQW5CVSwyQkFBMkI7NEdBQTNCLDJCQUEyQixtTENkeEMsNkJBQ0E7MkZEYWEsMkJBQTJCO2tCQUx2QyxTQUFTOytCQUNFLHVCQUF1QjtnR0FNMUIsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxZQUFZO3NCQURsQixLQUFLO2dCQVVOLFVBQVU7c0JBRFQsWUFBWTt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0TGlzdGVuZXIsIEluamVjdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIE1BVF9ESUFMT0dfREFUQSxcbiAgTWF0RGlhbG9nLFxuICBNYXREaWFsb2dDb25maWcsXG59IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBDM0ZpbGVWaWV3ZXIgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvZmlsZS12aWV3ZXInO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtdmlld2VyLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLXZpZXdlci1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jMy1maWxlLXZpZXdlci1kaWFsb2cuY29tcG9uZW50LmNzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJEaWFsb2dDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgZmlsZVZpZXdlciE6IEMzRmlsZVZpZXdlcjtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgZGlhbG9nQ29uZmlnOiBQYXJ0aWFsPE1hdERpYWxvZ0NvbmZpZz4gPSB7XG4gICAgcGFuZWxDbGFzczogJ2MzLWZpbGUtdmlld2VyLWRpYWxvZycsXG4gICAgd2lkdGg6ICc4MCUnLFxuICAgIGhlaWdodDogJzgwJScsXG4gIH07XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfZGlhbG9nOiBNYXREaWFsb2cpIHt9XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snKVxuICBvcGVuRGlhbG9nKCkge1xuICAgIHRoaXMuX2RpYWxvZy5vcGVuKEMzRmlsZVZpZXdlckRpYWxvZywge1xuICAgICAgZGF0YTogdGhpcy5maWxlVmlld2VyLFxuICAgICAgLi4udGhpcy5kaWFsb2dDb25maWcsXG4gICAgfSk7XG4gIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
|
@@ -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==
|