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.
Files changed (64) hide show
  1. package/README.md +67 -13
  2. package/esm2020/c3-components.mjs +5 -0
  3. package/esm2020/lib/c3-dialog/c3-dialog.module.mjs +56 -0
  4. package/esm2020/lib/c3-dialog/components/c3-dialog-confirm.component.mjs +52 -0
  5. package/esm2020/lib/c3-dialog/components/c3-dialog-embed-child.component.mjs +32 -0
  6. package/esm2020/lib/c3-dialog/components/c3-dialog-prompt.component.mjs +95 -0
  7. package/esm2020/lib/c3-dialog/services/c3-dialog.service.mjs +79 -0
  8. package/esm2020/lib/c3-dropdown/c3-dropdown.module.mjs +20 -0
  9. package/esm2020/lib/c3-dropdown/components/c3-dropdown.component.mjs +45 -0
  10. package/esm2020/lib/c3-dropdown/directives/c3-dropdown.trigger.mjs +128 -0
  11. package/esm2020/lib/c3-file-viewer/c3-file-viewer.module.mjs +51 -0
  12. package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-actions/c3-file-viewer-actions.component.mjs +17 -0
  13. package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-dialog/c3-file-viewer-dialog.mjs +20 -0
  14. package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-image/c3-file-viewer-image.component.mjs +20 -0
  15. package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-pdf/c3-file-viewer-pdf.component.mjs +23 -0
  16. package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-video/c3-file-viewer-video.component.mjs +32 -0
  17. package/esm2020/lib/c3-file-viewer/components/public/c3-file-viewer/c3-file-viewer.component.mjs +86 -0
  18. package/esm2020/lib/c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component.mjs +34 -0
  19. package/esm2020/lib/c3-file-viewer/consts/default.config.mjs +40 -0
  20. package/esm2020/lib/c3-file-viewer/directives/full-screen.directive.mjs +66 -0
  21. package/esm2020/lib/c3-file-viewer/models/custom-file-event.model.mjs +7 -0
  22. package/esm2020/lib/c3-file-viewer/models/file-metadata.mjs +2 -0
  23. package/esm2020/lib/c3-file-viewer/models/file-viewer-config.model.mjs +2 -0
  24. package/esm2020/lib/c3-file-viewer/models/file-viewer.mjs +206 -0
  25. package/esm2020/lib/c3-file-viewer/models/http.client.mjs +2 -0
  26. package/esm2020/lib/c3-safe-url/pipes/c3-safe-url.pipe.mjs +21 -0
  27. package/esm2020/public-api.mjs +34 -0
  28. package/fesm2015/c3-components.mjs +1055 -0
  29. package/fesm2015/c3-components.mjs.map +1 -0
  30. package/fesm2020/c3-components.mjs +1053 -0
  31. package/fesm2020/c3-components.mjs.map +1 -0
  32. package/index.d.ts +5 -0
  33. package/lib/c3-dialog/c3-dialog.module.d.ts +16 -0
  34. package/lib/c3-dialog/components/c3-dialog-confirm.component.d.ts +23 -0
  35. package/lib/c3-dialog/components/c3-dialog-embed-child.component.d.ts +18 -0
  36. package/lib/c3-dialog/components/c3-dialog-prompt.component.d.ts +31 -0
  37. package/lib/c3-dialog/services/c3-dialog.service.d.ts +19 -0
  38. package/lib/c3-dropdown/c3-dropdown.module.d.ts +10 -0
  39. package/lib/c3-dropdown/components/c3-dropdown.component.d.ts +15 -0
  40. package/lib/c3-dropdown/directives/c3-dropdown.trigger.d.ts +45 -0
  41. package/lib/c3-dropdown/styles/_c3-dropdown.sass +22 -0
  42. package/lib/c3-file-viewer/c3-file-viewer.module.d.ts +18 -0
  43. package/lib/c3-file-viewer/components/c3-file-viewer-actions/c3-file-viewer-actions.component.d.ts +8 -0
  44. package/lib/c3-file-viewer/components/c3-file-viewer-dialog/c3-file-viewer-dialog.d.ts +8 -0
  45. package/lib/c3-file-viewer/components/c3-file-viewer-image/c3-file-viewer-image.component.d.ts +9 -0
  46. package/lib/c3-file-viewer/components/c3-file-viewer-pdf/c3-file-viewer-pdf.component.d.ts +9 -0
  47. package/lib/c3-file-viewer/components/c3-file-viewer-video/c3-file-viewer-video.component.d.ts +12 -0
  48. package/lib/c3-file-viewer/components/public/c3-file-viewer/c3-file-viewer.component.d.ts +25 -0
  49. package/lib/c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component.d.ts +12 -0
  50. package/lib/c3-file-viewer/consts/default.config.d.ts +2 -0
  51. package/lib/c3-file-viewer/directives/full-screen.directive.d.ts +12 -0
  52. package/lib/c3-file-viewer/models/custom-file-event.model.d.ts +5 -0
  53. package/lib/c3-file-viewer/models/file-metadata.d.ts +12 -0
  54. package/lib/c3-file-viewer/models/file-viewer-config.model.d.ts +48 -0
  55. package/lib/c3-file-viewer/models/file-viewer.d.ts +65 -0
  56. package/lib/c3-file-viewer/models/http.client.d.ts +14 -0
  57. package/lib/c3-file-viewer/styles/_c3-file-viewer.sass +116 -0
  58. package/lib/c3-safe-url/pipes/c3-safe-url.pipe.d.ts +10 -0
  59. package/lib/c3-styles/_c3-core.sass +8 -0
  60. package/lib/c3-styles/_c3-root-variables.sass +107 -0
  61. package/lib/c3-styles/_utils.sass +27 -0
  62. package/package.json +5 -4
  63. package/public-api.d.ts +30 -0
  64. 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
@@ -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,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==