ngx-doc-viewer 2.0.2 → 2.1.0-RC.0

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 (46) hide show
  1. package/README.md +151 -151
  2. package/esm2020/index.mjs +4 -0
  3. package/esm2020/lib/document-viewer.component.mjs +188 -0
  4. package/esm2020/lib/document-viewer.module.mjs +18 -0
  5. package/esm2020/ngx-doc-viewer.mjs +5 -0
  6. package/fesm2015/ngx-doc-viewer.mjs +211 -0
  7. package/fesm2015/ngx-doc-viewer.mjs.map +1 -0
  8. package/fesm2020/ngx-doc-viewer.mjs +208 -0
  9. package/fesm2020/ngx-doc-viewer.mjs.map +1 -0
  10. package/{ngx-doc-viewer/src/index.d.ts → index.d.ts} +1 -2
  11. package/{ngx-doc-viewer/src/lib → lib}/document-viewer.component.d.ts +7 -4
  12. package/lib/document-viewer.module.d.ts +8 -0
  13. package/ngx-doc-viewer.d.ts +2 -1
  14. package/package.json +29 -15
  15. package/bundles/ngx-doc-viewer.umd.js +0 -730
  16. package/bundles/ngx-doc-viewer.umd.js.map +0 -1
  17. package/bundles/ngx-doc-viewer.umd.min.js +0 -16
  18. package/bundles/ngx-doc-viewer.umd.min.js.map +0 -1
  19. package/esm2015/helper.js +0 -202
  20. package/esm2015/helper.js.map +0 -1
  21. package/esm2015/helper.metadata.json +0 -1
  22. package/esm2015/model.js +0 -14
  23. package/esm2015/model.js.map +0 -1
  24. package/esm2015/model.metadata.json +0 -1
  25. package/esm2015/ngx-doc-viewer/src/index.js +0 -5
  26. package/esm2015/ngx-doc-viewer/src/index.js.map +0 -1
  27. package/esm2015/ngx-doc-viewer/src/index.metadata.json +0 -1
  28. package/esm2015/ngx-doc-viewer/src/lib/document-viewer.component.js +0 -178
  29. package/esm2015/ngx-doc-viewer/src/lib/document-viewer.component.js.map +0 -1
  30. package/esm2015/ngx-doc-viewer/src/lib/document-viewer.component.metadata.json +0 -1
  31. package/esm2015/ngx-doc-viewer/src/lib/document-viewer.module.js +0 -13
  32. package/esm2015/ngx-doc-viewer/src/lib/document-viewer.module.js.map +0 -1
  33. package/esm2015/ngx-doc-viewer/src/lib/document-viewer.module.metadata.json +0 -1
  34. package/esm2015/ngx-doc-viewer-wrapper.js +0 -2
  35. package/esm2015/ngx-doc-viewer-wrapper.js.map +0 -1
  36. package/esm2015/ngx-doc-viewer-wrapper.metadata.json +0 -1
  37. package/esm2015/ngx-doc-viewer.js +0 -5
  38. package/esm2015/ngx-doc-viewer.js.map +0 -1
  39. package/esm2015/ngx-doc-viewer.metadata.json +0 -1
  40. package/fesm2015/ngx-doc-viewer.js +0 -406
  41. package/fesm2015/ngx-doc-viewer.js.map +0 -1
  42. package/helper.d.ts +0 -24
  43. package/model.d.ts +0 -17
  44. package/ngx-doc-viewer/src/lib/document-viewer.module.d.ts +0 -2
  45. package/ngx-doc-viewer-wrapper.d.ts +0 -1
  46. package/ngx-doc-viewer.metadata.json +0 -1
package/README.md CHANGED
@@ -1,151 +1,151 @@
1
- # ngx-doc-viewer
2
-
3
- This component can be used to show several different document types in an Angular app.
4
-
5
- Documents that are publicly available can be shown in an iframe using the google or office document viewer.
6
-
7
- Pdf files and word document that are not publicly available can be shown using the mammoth viewer or pdf viewer by passing an objectUrl.
8
-
9
- <a href="https://angular-doc-viewer.firebaseapp.com/">View demo</a>
10
-
11
- <a href="https://github.com/Marcelh1983/document-viewer/blob/main/libs/ngx-doc-viewer/changelog.md">Changes</a>
12
-
13
- ### Install the NPM Module
14
-
15
- ```sh
16
- npm install ngx-doc-viewer --save
17
- ```
18
-
19
- ### Usage
20
-
21
- #### 1. Import `NgxDocViewerModule`
22
-
23
- ```ts
24
- @NgModule({
25
- imports: [NgxDocViewerModule],
26
- })
27
- export class AppModule {}
28
- ```
29
-
30
- #### 2. Add DocViewer to component:
31
-
32
- ```html
33
- <ngx-doc-viewer
34
- [url]="doc"
35
- viewer="google"
36
- style="width:100%;height:50vh;"
37
- ></ngx-doc-viewer>
38
- ```
39
-
40
- To
41
-
42
- #### API:
43
-
44
- Input:
45
-
46
- - url: document url.
47
- - viewer: google (default), office, mammoth, pdf or url
48
- - viewerUrl: only for viewer: 'url'; location of the document renderer. Only use this option for other viewers then google or office.
49
- - queryParams, e.g. to set language. for google: hl=[lang] e.g. hl=nl
50
- - disableContent: 'none' | 'all' | 'popout' | 'popout-hide' = 'none':
51
- - none: no overlay
52
- - all: adds an overlay to the whole iframe, which makes nothing in the document clickable/selectable
53
- - popout: adds an overlay over googles popout button or office popout and menu which disables just this button/menu but keeps giving the possibility to select text. The popout button is still visible (for google during a few seconds) but not clickable.
54
- - popout-hide: see popup, instead of an transparent overlay a white one. This really hides the button but you'll see a white block while loading for the google viewer.
55
- - overrideLocalhost: documents from the assets folder are not publicly available and therefor won't show in an external viewer (google, office). If the site is already published to public server, then pass that url and if will replace localhost by the other url. Like: overrideLocalhost="https://angular-doc-viewer.firebaseapp.com/"
56
-
57
- There are some issues loading document in the google viewer. See: https://stackoverflow.com/questions/40414039/google-docs-viewer-returning-204-responses-no-longer-working-alternatives. If loading pdf's and Word documents, seems to work now with this hack let me know via a Github issue.
58
-
59
- - googleCheckContentLoaded = true | If true it will check by interval if the content is loaded.
60
- - googleCheckInterval = 3000 | The interval in milliseconds that is checked whether the iframe is loaded.
61
- - googleMaxChecks = 5 | max number of retries
62
- Output:
63
-
64
- - loaded: google only, notifies when iframe is loaded. Can be used to show progress while loading
65
-
66
- ### File type support
67
-
68
- #### office viewer
69
-
70
- .ppt, .pptx, .doc, .docx, .xls and .xlsx
71
-
72
- #### google viewer
73
-
74
- Only files under 25 MB can be previewed with the Google Drive viewer.
75
-
76
- Google Drive viewer helps you preview over 15 different file types, listed below:
77
-
78
- - Text files (.TXT)
79
- - Markup/Code (.CSS, .HTML, .PHP, .C, .CPP, .H, .HPP, .JS)
80
- - Microsoft Word (.DOC and .DOCX)
81
- - Microsoft Excel (.XLS and .XLSX)
82
- - Microsoft PowerPoint (.PPT and .PPTX)
83
- - Adobe Portable Document Format (.PDF)
84
- - Apple Pages (.PAGES)
85
- - Adobe Illustrator (.AI)
86
- - Adobe Photoshop (.PSD)
87
- - Tagged Image File Format (.TIFF)
88
- - Autodesk AutoCad (.DXF)
89
- - Scalable Vector Graphics (.SVG)
90
- - PostScript (.EPS, .PS)
91
- - TrueType (.TTF)
92
- - XML Paper Specification (.XPS)
93
- - Archive file types (.ZIP and .RAR)
94
-
95
- <a href="https://gist.githubusercontent.com/tzmartin/1cf85dc3d975f94cfddc04bc0dd399be/raw/d4263c8faf7b68f4bbfd33b386ec33ed2bc11e7d/embedded-file-viewer.md">Source</a>
96
-
97
- #### url
98
-
99
- For another external document viewers that should be loaded in an iframe.
100
-
101
- For Google Drive
102
-
103
- ```html
104
- <ngx-doc-viewer
105
- [url]="https://drive.google.com/file/d/0B5ImRpiNhCfGZDVhMGEyYmUtZTdmMy00YWEyLWEyMTQtN2E2YzM3MDg3MTZh/preview"
106
- viewer="url"
107
- style="width:100%;height:50vh;"
108
- >
109
- </ngx-doc-viewer>
110
- ```
111
-
112
- For the Google Viewer or any other viewer where there is a base url and a parameter for the documentUrl:
113
-
114
- ```html
115
- <ngx-doc-viewer
116
- [viewerUrl]="https://docs.google.com/gview?url=%URL%&embedded=true"
117
- [url]="https://file-examples.com/wp-content/uploads/2017/02/file-sample_100kB.doc"
118
- viewer="url"
119
- style="width:100%;height:50vh;"
120
- >
121
- </ngx-doc-viewer>
122
- ```
123
-
124
- ### pdf
125
-
126
- .pdf
127
-
128
- NOTE: PDF's are shown in the embed tag. Browser support is not guaranteed. If you need to be sure the pdf renders on all browsers you better use PDF.js
129
-
130
- ### mammoth
131
-
132
- .docx
133
-
134
- To use mammoth, also add:
135
-
136
- ```sh
137
- npm install mammoth --save
138
- ```
139
-
140
- and make sure mammoth.browser.min.js is loaded. For the angular/cli you would add the following in angular.json:
141
-
142
- ```json
143
- "scripts": [
144
- "node_modules/mammoth/mammoth.browser.min.js"
145
- ]
146
- ```
147
-
148
- ## My other packages
149
-
150
- - ngx-event-handler: advance event handling like click-outside with serval options: [npm](https://www.npmjs.com/package/ngx-event-handler) | [github](https://github.com/Marcelh1983/angular-event-handler) | [demo](https://stackblitz.com/edit/ngx-event-handler)
151
- - ngx-edit-inline: basic inline edit component: [npm](https://www.npmjs.com/package/ngx-edit-inline) | [github](https://github.com/Marcelh1983/angular-inline-edit) | [demo](https://ngx-edit-inline.firebaseapp.com/)
1
+ # ngx-doc-viewer
2
+
3
+ This component can be used to show several different document types in an Angular app.
4
+
5
+ Documents that are publicly available can be shown in an iframe using the google or office document viewer.
6
+
7
+ Pdf files and word document that are not publicly available can be shown using the mammoth viewer or pdf viewer by passing an objectUrl.
8
+
9
+ <a href="https://angular-doc-viewer.firebaseapp.com/">View demo</a>
10
+
11
+ <a href="https://github.com/Marcelh1983/document-viewer/blob/main/packages/ngx-doc-viewer/changelog.md">Changes</a>
12
+
13
+ ### Install the NPM Module
14
+
15
+ ```sh
16
+ npm install ngx-doc-viewer --save
17
+ ```
18
+
19
+ ### Usage
20
+
21
+ #### 1. Import `NgxDocViewerModule`
22
+
23
+ ```ts
24
+ @NgModule({
25
+ imports: [NgxDocViewerModule],
26
+ })
27
+ export class AppModule {}
28
+ ```
29
+
30
+ #### 2. Add DocViewer to component:
31
+
32
+ ```html
33
+ <ngx-doc-viewer
34
+ [url]="doc"
35
+ viewer="google"
36
+ style="width:100%;height:50vh;"
37
+ ></ngx-doc-viewer>
38
+ ```
39
+
40
+ To
41
+
42
+ #### API:
43
+
44
+ Input:
45
+
46
+ - url: document url.
47
+ - viewer: google (default), office, mammoth, pdf or url
48
+ - viewerUrl: only for viewer: 'url'; location of the document renderer. Only use this option for other viewers then google or office.
49
+ - queryParams, e.g. to set language. for google: hl=[lang] e.g. hl=nl
50
+ - disableContent: 'none' | 'all' | 'popout' | 'popout-hide' = 'none':
51
+ - none: no overlay
52
+ - all: adds an overlay to the whole iframe, which makes nothing in the document clickable/selectable
53
+ - popout: adds an overlay over googles popout button or office popout and menu which disables just this button/menu but keeps giving the possibility to select text. The popout button is still visible (for google during a few seconds) but not clickable.
54
+ - popout-hide: see popup, instead of an transparent overlay a white one. This really hides the button but you'll see a white block while loading for the google viewer.
55
+ - overrideLocalhost: documents from the assets folder are not publicly available and therefor won't show in an external viewer (google, office). If the site is already published to public server, then pass that url and if will replace localhost by the other url. Like: overrideLocalhost="https://angular-doc-viewer.firebaseapp.com/"
56
+
57
+ There are some issues loading document in the google viewer. See: https://stackoverflow.com/questions/40414039/google-docs-viewer-returning-204-responses-no-longer-working-alternatives. If loading pdf's and Word documents, seems to work now with this hack let me know via a Github issue.
58
+
59
+ - googleCheckContentLoaded = true | If true it will check by interval if the content is loaded.
60
+ - googleCheckInterval = 3000 | The interval in milliseconds that is checked whether the iframe is loaded.
61
+ - googleMaxChecks = 5 | max number of retries
62
+ Output:
63
+
64
+ - loaded: google only, notifies when iframe is loaded. Can be used to show progress while loading
65
+
66
+ ### File type support
67
+
68
+ #### office viewer
69
+
70
+ .ppt, .pptx, .doc, .docx, .xls and .xlsx
71
+
72
+ #### google viewer
73
+
74
+ Only files under 25 MB can be previewed with the Google Drive viewer.
75
+
76
+ Google Drive viewer helps you preview over 15 different file types, listed below:
77
+
78
+ - Text files (.TXT)
79
+ - Markup/Code (.CSS, .HTML, .PHP, .C, .CPP, .H, .HPP, .JS)
80
+ - Microsoft Word (.DOC and .DOCX)
81
+ - Microsoft Excel (.XLS and .XLSX)
82
+ - Microsoft PowerPoint (.PPT and .PPTX)
83
+ - Adobe Portable Document Format (.PDF)
84
+ - Apple Pages (.PAGES)
85
+ - Adobe Illustrator (.AI)
86
+ - Adobe Photoshop (.PSD)
87
+ - Tagged Image File Format (.TIFF)
88
+ - Autodesk AutoCad (.DXF)
89
+ - Scalable Vector Graphics (.SVG)
90
+ - PostScript (.EPS, .PS)
91
+ - TrueType (.TTF)
92
+ - XML Paper Specification (.XPS)
93
+ - Archive file types (.ZIP and .RAR)
94
+
95
+ <a href="https://gist.githubusercontent.com/tzmartin/1cf85dc3d975f94cfddc04bc0dd399be/raw/d4263c8faf7b68f4bbfd33b386ec33ed2bc11e7d/embedded-file-viewer.md">Source</a>
96
+
97
+ #### url
98
+
99
+ For another external document viewers that should be loaded in an iframe.
100
+
101
+ For Google Drive
102
+
103
+ ```html
104
+ <ngx-doc-viewer
105
+ [url]="'https://drive.google.com/file/d/0B5ImRpiNhCfGZDVhMGEyYmUtZTdmMy00YWEyLWEyMTQtN2E2YzM3MDg3MTZh/preview'"
106
+ viewer="url"
107
+ style="width:100%;height:50vh;"
108
+ >
109
+ </ngx-doc-viewer>
110
+ ```
111
+
112
+ For the Google Viewer or any other viewer where there is a base url and a parameter for the documentUrl:
113
+
114
+ ```html
115
+ <ngx-doc-viewer
116
+ [viewerUrl]="https://docs.google.com/gview?url=%URL%&embedded=true"
117
+ [url]="https://file-examples.com/wp-content/uploads/2017/02/file-sample_100kB.doc"
118
+ viewer="url"
119
+ style="width:100%;height:50vh;"
120
+ >
121
+ </ngx-doc-viewer>
122
+ ```
123
+
124
+ ### pdf
125
+
126
+ .pdf
127
+
128
+ NOTE: PDF's are shown in the embed tag. Browser support is not guaranteed. If you need to be sure the pdf renders on all browsers you better use PDF.js
129
+
130
+ ### mammoth
131
+
132
+ .docx
133
+
134
+ To use mammoth, also add:
135
+
136
+ ```sh
137
+ npm install mammoth --save
138
+ ```
139
+
140
+ and make sure mammoth.browser.min.js is loaded. For the angular/cli you would add the following in angular.json:
141
+
142
+ ```json
143
+ "scripts": [
144
+ "node_modules/mammoth/mammoth.browser.min.js"
145
+ ]
146
+ ```
147
+
148
+ ## My other packages
149
+
150
+ - ngx-event-handler: advance event handling like click-outside with serval options: [npm](https://www.npmjs.com/package/ngx-event-handler) | [github](https://github.com/Marcelh1983/angular-event-handler) | [demo](https://stackblitz.com/edit/ngx-event-handler)
151
+ - ngx-edit-inline: basic inline edit component: [npm](https://www.npmjs.com/package/ngx-edit-inline) | [github](https://github.com/Marcelh1983/angular-inline-edit) | [demo](https://ngx-edit-inline.firebaseapp.com/)
@@ -0,0 +1,4 @@
1
+ export * from './lib/document-viewer.module';
2
+ export * from './lib/document-viewer.component';
3
+ export * from 'docviewhelper';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9uZ3gtZG9jLXZpZXdlci9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZG9jdW1lbnQtdmlld2VyLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RvY3VtZW50LXZpZXdlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICdkb2N2aWV3aGVscGVyJzsiXX0=
@@ -0,0 +1,188 @@
1
+ import { Component, Input, NgZone, Output, ViewChildren, QueryList, } from '@angular/core';
2
+ import { DomSanitizer } from '@angular/platform-browser';
3
+ import { EventEmitter } from '@angular/core';
4
+ // eslint-disable-next-line @nrwl/nx/enforce-module-boundaries
5
+ import { getDocxToHtml, getViewerDetails, googleCheckSubscription, iframeIsLoaded, isLocalFile, replaceLocalUrl } from 'docviewhelper';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/platform-browser";
8
+ import * as i2 from "@angular/common";
9
+ export class NgxDocViewerComponent {
10
+ constructor(domSanitizer, ngZone) {
11
+ this.domSanitizer = domSanitizer;
12
+ this.ngZone = ngZone;
13
+ this.loaded = new EventEmitter();
14
+ this.url = '';
15
+ this.queryParams = '';
16
+ this.viewerUrl = '';
17
+ this.googleCheckInterval = 3000;
18
+ this.googleMaxChecks = 5;
19
+ this.disableContent = 'none';
20
+ this.googleCheckContentLoaded = true;
21
+ this.viewer = 'google';
22
+ this.overrideLocalhost = '';
23
+ this.iframes = undefined;
24
+ this.fullUrl = undefined;
25
+ this.externalViewer = false;
26
+ this.docHtml = '';
27
+ this.configuredViewer = 'google';
28
+ this.checkIFrameSubscription = undefined;
29
+ this.shouldCheckIframe = false;
30
+ }
31
+ ngAfterViewInit() {
32
+ if (this.shouldCheckIframe) {
33
+ const iframe = this.iframes?.first
34
+ ?.nativeElement;
35
+ if (iframe) {
36
+ this.shouldCheckIframe = false;
37
+ this.reloadIframe(iframe);
38
+ }
39
+ }
40
+ }
41
+ ngOnDestroy() {
42
+ if (this.checkIFrameSubscription) {
43
+ this.checkIFrameSubscription.unsubscribe();
44
+ }
45
+ }
46
+ async ngOnChanges(changes) {
47
+ if (changes &&
48
+ changes['viewer'] &&
49
+ (changes['viewer'].isFirstChange ||
50
+ changes['viewer'].currentValue !== changes['viewer'].previousValue)) {
51
+ if (this.viewer !== 'google' &&
52
+ this.viewer !== 'office' &&
53
+ this.viewer !== 'mammoth' &&
54
+ this.viewer !== 'pdf' &&
55
+ this.viewer !== 'url') {
56
+ console.error(`Unsupported viewer: '${this.viewer}'. Supported viewers: google, office, mammoth and pdf`);
57
+ }
58
+ this.configuredViewer = this.viewer;
59
+ }
60
+ if ((changes['url'] && changes['url'].currentValue !== changes['url'].previousValue) ||
61
+ (changes['viewer'] &&
62
+ changes['viewer'].currentValue !== changes['viewer'].previousValue) ||
63
+ (changes['viewerUrl'] &&
64
+ changes['viewerUrl'].currentValue !== changes['viewerUrl'].previousValue)) {
65
+ let viewerDetails = getViewerDetails(this.url, this.configuredViewer, this.queryParams, this.viewerUrl);
66
+ this.externalViewer = viewerDetails.externalViewer;
67
+ if (viewerDetails.externalViewer && this.overrideLocalhost && isLocalFile(this.url)) {
68
+ const newUrl = replaceLocalUrl(this.url, this.overrideLocalhost);
69
+ viewerDetails = getViewerDetails(newUrl, this.configuredViewer, this.queryParams, this.viewerUrl);
70
+ }
71
+ this.docHtml = '';
72
+ if (this.checkIFrameSubscription) {
73
+ this.checkIFrameSubscription.unsubscribe();
74
+ }
75
+ if (!this.url) {
76
+ this.fullUrl = undefined;
77
+ }
78
+ else if (viewerDetails.externalViewer ||
79
+ this.configuredViewer === 'url') {
80
+ this.fullUrl = this.domSanitizer.bypassSecurityTrustResourceUrl(viewerDetails.url);
81
+ // see:
82
+ // https://stackoverflow.com/questions/40414039/google-docs-viewer-returning-204-responses-no-longer-working-alternatives
83
+ // hack to reload iframe if it's not loaded.
84
+ // would maybe be better to use view.officeapps.live.com but seems not to work with sas token.
85
+ if (this.configuredViewer === 'google' &&
86
+ this.googleCheckContentLoaded) {
87
+ this.ngZone.runOutsideAngular(() => {
88
+ // if it's not loaded after the googleIntervalCheck, then open load again.
89
+ const iframe = this.iframes?.first
90
+ ?.nativeElement;
91
+ if (iframe) {
92
+ this.reloadIframe(iframe);
93
+ }
94
+ else {
95
+ this.shouldCheckIframe = true;
96
+ }
97
+ });
98
+ }
99
+ }
100
+ else if (this.configuredViewer === 'mammoth') {
101
+ this.docHtml = await getDocxToHtml(this.url);
102
+ }
103
+ }
104
+ }
105
+ reloadIframe(iframe) {
106
+ this.checkIFrameSubscription = googleCheckSubscription();
107
+ this.checkIFrameSubscription.subscribe(iframe, this.googleCheckInterval, this.googleMaxChecks);
108
+ }
109
+ iframeLoaded() {
110
+ const iframe = this.iframes?.first
111
+ ?.nativeElement;
112
+ if (iframe && iframeIsLoaded(iframe)) {
113
+ this.loaded.emit(undefined);
114
+ if (this.checkIFrameSubscription) {
115
+ this.checkIFrameSubscription.unsubscribe();
116
+ }
117
+ }
118
+ }
119
+ }
120
+ NgxDocViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxDocViewerComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
121
+ NgxDocViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: NgxDocViewerComponent, selector: "ngx-doc-viewer", inputs: { url: "url", queryParams: "queryParams", viewerUrl: "viewerUrl", googleCheckInterval: "googleCheckInterval", googleMaxChecks: "googleMaxChecks", disableContent: "disableContent", googleCheckContentLoaded: "googleCheckContentLoaded", viewer: "viewer", overrideLocalhost: "overrideLocalhost" }, outputs: { loaded: "loaded" }, viewQueries: [{ propertyName: "iframes", predicate: ["iframe"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"!externalViewer\">\r\n <div *ngIf=\"configuredViewer !== 'pdf'\" [innerHtml]=\"docHtml\"></div>\r\n <object\r\n *ngIf=\"fullUrl && configuredViewer === 'pdf'\"\r\n [data]=\"fullUrl\"\r\n type=\"application/pdf\"\r\n width=\"100%\"\r\n height=\"100%\"\r\n >\r\n <p>\r\n Your browser does not support PDFs.\r\n <a [href]=\"fullUrl\">Download the PDF</a>.\r\n </p>\r\n </object>\r\n</ng-container>\r\n<ng-container *ngIf=\"externalViewer\">\r\n <iframe\r\n (load)=\"iframeLoaded()\"\r\n *ngIf=\"fullUrl && disableContent === 'none'\"\r\n #iframe\r\n id=\"iframe-doc-viewer\"\r\n frameBorder=\"0\"\r\n [src]=\"fullUrl\"\r\n ></iframe>\r\n <div class=\"container\" *ngIf=\"disableContent !== 'none'\">\r\n <div\r\n [class.overlay-full]=\"disableContent === 'all'\"\r\n [class.overlay-popout-google]=\"\r\n configuredViewer === 'google' &&\r\n (disableContent === 'popout' || disableContent === 'popout-hide')\r\n \"\r\n [class.overlay-popout-office]=\"\r\n configuredViewer === 'office' &&\r\n (disableContent === 'popout' || disableContent === 'popout-hide')\r\n \"\r\n [style.background-color]=\"\r\n disableContent === 'popout-hide' ? '#fff' : 'transparent'\r\n \"\r\n ></div>\r\n <iframe\r\n (load)=\"iframeLoaded()\"\r\n *ngIf=\"fullUrl\"\r\n #iframe\r\n id=\"iframe\"\r\n frameBorder=\"0\"\r\n [src]=\"fullUrl\"\r\n ></iframe>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{display:block}.container{width:100%;height:100%;position:relative}.overlay-popout-google{width:40px;height:40px;right:26px;top:11.5px;position:absolute;z-index:1000}.overlay-popout-office{width:100px;height:20px;right:0;bottom:0;position:absolute;z-index:1000}.overlay-full{width:100%;height:100%;right:0;top:0;position:absolute;z-index:1000}iframe{width:100%;height:100%}\n"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
122
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxDocViewerComponent, decorators: [{
123
+ type: Component,
124
+ args: [{ selector: 'ngx-doc-viewer', styles: [
125
+ `
126
+ :host {
127
+ display: block;
128
+ }
129
+ .container {
130
+ width: 100%;
131
+ height: 100%;
132
+ position: relative;
133
+ }
134
+ .overlay-popout-google {
135
+ width: 40px;
136
+ height: 40px;
137
+ right: 26px;
138
+ top: 11.5px;
139
+ position: absolute;
140
+ z-index: 1000;
141
+ }
142
+ .overlay-popout-office {
143
+ width: 100px;
144
+ height: 20px;
145
+ right: 0;
146
+ bottom: 0;
147
+ position: absolute;
148
+ z-index: 1000;
149
+ }
150
+ .overlay-full {
151
+ width: 100%;
152
+ height: 100%;
153
+ right: 0;
154
+ top: 0;
155
+ position: absolute;
156
+ z-index: 1000;
157
+ }
158
+ iframe {
159
+ width: 100%;
160
+ height: 100%;
161
+ }
162
+ `,
163
+ ], template: "<ng-container *ngIf=\"!externalViewer\">\r\n <div *ngIf=\"configuredViewer !== 'pdf'\" [innerHtml]=\"docHtml\"></div>\r\n <object\r\n *ngIf=\"fullUrl && configuredViewer === 'pdf'\"\r\n [data]=\"fullUrl\"\r\n type=\"application/pdf\"\r\n width=\"100%\"\r\n height=\"100%\"\r\n >\r\n <p>\r\n Your browser does not support PDFs.\r\n <a [href]=\"fullUrl\">Download the PDF</a>.\r\n </p>\r\n </object>\r\n</ng-container>\r\n<ng-container *ngIf=\"externalViewer\">\r\n <iframe\r\n (load)=\"iframeLoaded()\"\r\n *ngIf=\"fullUrl && disableContent === 'none'\"\r\n #iframe\r\n id=\"iframe-doc-viewer\"\r\n frameBorder=\"0\"\r\n [src]=\"fullUrl\"\r\n ></iframe>\r\n <div class=\"container\" *ngIf=\"disableContent !== 'none'\">\r\n <div\r\n [class.overlay-full]=\"disableContent === 'all'\"\r\n [class.overlay-popout-google]=\"\r\n configuredViewer === 'google' &&\r\n (disableContent === 'popout' || disableContent === 'popout-hide')\r\n \"\r\n [class.overlay-popout-office]=\"\r\n configuredViewer === 'office' &&\r\n (disableContent === 'popout' || disableContent === 'popout-hide')\r\n \"\r\n [style.background-color]=\"\r\n disableContent === 'popout-hide' ? '#fff' : 'transparent'\r\n \"\r\n ></div>\r\n <iframe\r\n (load)=\"iframeLoaded()\"\r\n *ngIf=\"fullUrl\"\r\n #iframe\r\n id=\"iframe\"\r\n frameBorder=\"0\"\r\n [src]=\"fullUrl\"\r\n ></iframe>\r\n </div>\r\n</ng-container>\r\n" }]
164
+ }], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i0.NgZone }]; }, propDecorators: { loaded: [{
165
+ type: Output
166
+ }], url: [{
167
+ type: Input
168
+ }], queryParams: [{
169
+ type: Input
170
+ }], viewerUrl: [{
171
+ type: Input
172
+ }], googleCheckInterval: [{
173
+ type: Input
174
+ }], googleMaxChecks: [{
175
+ type: Input
176
+ }], disableContent: [{
177
+ type: Input
178
+ }], googleCheckContentLoaded: [{
179
+ type: Input
180
+ }], viewer: [{
181
+ type: Input
182
+ }], overrideLocalhost: [{
183
+ type: Input
184
+ }], iframes: [{
185
+ type: ViewChildren,
186
+ args: ['iframe']
187
+ }] } });
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-viewer.component.js","sourceRoot":"","sources":["../../../../../packages/ngx-doc-viewer/src/lib/document-viewer.component.ts","../../../../../packages/ngx-doc-viewer/src/lib/document-viewer.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EAIN,MAAM,EACN,YAAY,EACZ,SAAS,GAGV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAmB,MAAM,2BAA2B,CAAC;AAC1E,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,8DAA8D;AAC9D,OAAO,EACL,aAAa,EACb,gBAAgB,EAChB,uBAAuB,EACvB,cAAc,EACd,WAAW,EACX,eAAe,EAEhB,MAAM,eAAe,CAAC;;;;AAiDvB,MAAM,OAAO,qBAAqB;IAoBhC,YAAoB,YAA0B,EAAU,MAAc;QAAlD,iBAAY,GAAZ,YAAY,CAAc;QAAU,WAAM,GAAN,MAAM,CAAQ;QAnB5D,WAAM,GAAuB,IAAI,YAAY,EAAE,CAAC;QACjD,QAAG,GAAG,EAAE,CAAC;QACT,gBAAW,GAAG,EAAE,CAAC;QACjB,cAAS,GAAG,EAAE,CAAC;QACf,wBAAmB,GAAG,IAAI,CAAC;QAC3B,oBAAe,GAAG,CAAC,CAAC;QACpB,mBAAc,GAA8C,MAAM,CAAC;QACnE,6BAAwB,GAAG,IAAI,CAAC;QAChC,WAAM,GAAe,QAAQ,CAAC;QAC9B,sBAAiB,GAAG,EAAE,CAAC;QACR,YAAO,GAA2B,SAAS,CAAC;QAE7D,YAAO,GAAqB,SAAS,CAAC;QACtC,mBAAc,GAAG,KAAK,CAAC;QACvB,YAAO,GAAG,EAAE,CAAC;QACb,qBAAgB,GAAe,QAAQ,CAAC;QACvC,4BAAuB,GAAoB,SAAS,CAAC;QACrD,sBAAiB,GAAG,KAAK,CAAC;IAEwC,CAAC;IAE3E,eAAe;QACb,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,KAAK;gBAChC,EAAE,aAAkC,CAAC;YACvC,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;aAC3B;SACF;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,uBAAuB,EAAE;YAChC,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;SAC5C;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAsB;QACtC,IACE,OAAO;YACP,OAAO,CAAC,QAAQ,CAAC;YACjB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa;gBAC9B,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,EACrE;YACA,IACE,IAAI,CAAC,MAAM,KAAK,QAAQ;gBACxB,IAAI,CAAC,MAAM,KAAK,QAAQ;gBACxB,IAAI,CAAC,MAAM,KAAK,SAAS;gBACzB,IAAI,CAAC,MAAM,KAAK,KAAK;gBACrB,IAAI,CAAC,MAAM,KAAK,KAAK,EACrB;gBACA,OAAO,CAAC,KAAK,CACX,wBAAwB,IAAI,CAAC,MAAM,uDAAuD,CAC3F,CAAC;aACH;YACD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC;SACrC;QAED,IACE,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC;YAChF,CAAC,OAAO,CAAC,QAAQ,CAAC;gBAChB,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC;YACrE,CAAC,OAAO,CAAC,WAAW,CAAC;gBACnB,OAAO,CAAC,WAAW,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,WAAW,CAAC,CAAC,aAAa,CAAC,EAC3E;YACA,IAAI,aAAa,GAAG,gBAAgB,CAClC,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,SAAS,CACf,CAAC;YACF,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC,cAAc,CAAC;YACnD,IAAI,aAAa,CAAC,cAAc,IAAI,IAAI,CAAC,iBAAiB,IAAI,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;gBACnF,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;gBACjE,aAAa,GAAG,gBAAgB,CAC9B,MAAM,EACN,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,SAAS,CACf,CAAC;aACH;YACD,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,IAAI,IAAI,CAAC,uBAAuB,EAAE;gBAChC,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;aAC5C;YACD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;gBACb,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;aAC1B;iBAAM,IACL,aAAa,CAAC,cAAc;gBAC5B,IAAI,CAAC,gBAAgB,KAAK,KAAK,EAC/B;gBACA,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,8BAA8B,CAC7D,aAAa,CAAC,GAAG,CAClB,CAAC;gBACF,OAAO;gBACP,yHAAyH;gBACzH,4CAA4C;gBAC5C,8FAA8F;gBAC9F,IACE,IAAI,CAAC,gBAAgB,KAAK,QAAQ;oBAClC,IAAI,CAAC,wBAAwB,EAC7B;oBACA,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;wBACjC,0EAA0E;wBAC1E,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,KAAK;4BAChC,EAAE,aAAkC,CAAC;wBACvC,IAAI,MAAM,EAAE;4BACV,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;yBAC3B;6BAAM;4BACL,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;yBAC/B;oBACH,CAAC,CAAC,CAAC;iBACJ;aACF;iBAAM,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE;gBAC9C,IAAI,CAAC,OAAO,GAAG,MAAM,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAC9C;SACF;IACH,CAAC;IAEO,YAAY,CAAC,MAAyB;QAC5C,IAAI,CAAC,uBAAuB,GAAG,uBAAuB,EAAE,CAAC;QACzD,IAAI,CAAC,uBAAuB,CAAC,SAAS,CACpC,MAAM,EACN,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,eAAe,CACrB,CAAC;IACJ,CAAC;IAED,YAAY;QACV,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,KAAK;YAChC,EAAE,aAAkC,CAAC;QACvC,IAAI,MAAM,IAAI,cAAc,CAAC,MAAM,CAAC,EAAE;YACpC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC5B,IAAI,IAAI,CAAC,uBAAuB,EAAE;gBAChC,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,CAAC;aAC5C;SACF;IACH,CAAC;;kHA3IU,qBAAqB;sGAArB,qBAAqB,8eCzElC,khDAiDA;2FDwBa,qBAAqB;kBA7CjC,SAAS;+BAEE,gBAAgB,UAElB;wBACN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAqCC;qBACF;wHAGS,MAAM;sBAAf,MAAM;gBACE,GAAG;sBAAX,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACkB,OAAO;sBAA9B,YAAY;uBAAC,QAAQ","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  Output,\r\n  ViewChildren,\r\n  QueryList,\r\n  ElementRef,\r\n  AfterViewInit,\r\n} from '@angular/core';\r\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\r\nimport { EventEmitter } from '@angular/core';\r\n// eslint-disable-next-line @nrwl/nx/enforce-module-boundaries\r\nimport {\r\n  getDocxToHtml,\r\n  getViewerDetails,\r\n  googleCheckSubscription,\r\n  iframeIsLoaded,\r\n  isLocalFile,\r\n  replaceLocalUrl,\r\n  IFrameReloader\r\n} from 'docviewhelper';\r\n\r\n// eslint-disable-next-line @typescript-eslint/naming-convention\r\nexport type viewerType = 'google' | 'office' | 'mammoth' | 'pdf' | 'url';\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'ngx-doc-viewer',\r\n  templateUrl: 'document-viewer.component.html',\r\n  styles: [\r\n    `\r\n      :host {\r\n        display: block;\r\n      }\r\n      .container {\r\n        width: 100%;\r\n        height: 100%;\r\n        position: relative;\r\n      }\r\n      .overlay-popout-google {\r\n        width: 40px;\r\n        height: 40px;\r\n        right: 26px;\r\n        top: 11.5px;\r\n        position: absolute;\r\n        z-index: 1000;\r\n      }\r\n      .overlay-popout-office {\r\n        width: 100px;\r\n        height: 20px;\r\n        right: 0;\r\n        bottom: 0;\r\n        position: absolute;\r\n        z-index: 1000;\r\n      }\r\n      .overlay-full {\r\n        width: 100%;\r\n        height: 100%;\r\n        right: 0;\r\n        top: 0;\r\n        position: absolute;\r\n        z-index: 1000;\r\n      }\r\n      iframe {\r\n        width: 100%;\r\n        height: 100%;\r\n      }\r\n    `,\r\n  ],\r\n})\r\nexport class NgxDocViewerComponent implements OnChanges, OnDestroy, AfterViewInit {\r\n  @Output() loaded: EventEmitter<void> = new EventEmitter();\r\n  @Input() url = '';\r\n  @Input() queryParams = '';\r\n  @Input() viewerUrl = '';\r\n  @Input() googleCheckInterval = 3000;\r\n  @Input() googleMaxChecks = 5;\r\n  @Input() disableContent: 'none' | 'all' | 'popout' | 'popout-hide' = 'none';\r\n  @Input() googleCheckContentLoaded = true;\r\n  @Input() viewer: viewerType = 'google';\r\n  @Input() overrideLocalhost = '';\r\n  @ViewChildren('iframe') iframes?: QueryList<ElementRef> = undefined;\r\n\r\n  public fullUrl?: SafeResourceUrl = undefined;\r\n  public externalViewer = false;\r\n  public docHtml = '';\r\n  public configuredViewer: viewerType = 'google';\r\n  private checkIFrameSubscription?: IFrameReloader = undefined;\r\n  private shouldCheckIframe = false;\r\n\r\n  constructor(private domSanitizer: DomSanitizer, private ngZone: NgZone) { }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.shouldCheckIframe) {\r\n      const iframe = this.iframes?.first\r\n        ?.nativeElement as HTMLIFrameElement;\r\n      if (iframe) {\r\n        this.shouldCheckIframe = false;\r\n        this.reloadIframe(iframe);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.checkIFrameSubscription) {\r\n      this.checkIFrameSubscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n  async ngOnChanges(changes: SimpleChanges): Promise<void> {\r\n    if (\r\n      changes &&\r\n      changes['viewer'] &&\r\n      (changes['viewer'].isFirstChange ||\r\n        changes['viewer'].currentValue !== changes['viewer'].previousValue)\r\n    ) {\r\n      if (\r\n        this.viewer !== 'google' &&\r\n        this.viewer !== 'office' &&\r\n        this.viewer !== 'mammoth' &&\r\n        this.viewer !== 'pdf' &&\r\n        this.viewer !== 'url'\r\n      ) {\r\n        console.error(\r\n          `Unsupported viewer: '${this.viewer}'. Supported viewers: google, office, mammoth and pdf`\r\n        );\r\n      }\r\n      this.configuredViewer = this.viewer;\r\n    }\r\n\r\n    if (\r\n      (changes['url'] && changes['url'].currentValue !== changes['url'].previousValue) ||\r\n      (changes['viewer'] &&\r\n        changes['viewer'].currentValue !== changes['viewer'].previousValue) ||\r\n      (changes['viewerUrl'] &&\r\n        changes['viewerUrl'].currentValue !== changes['viewerUrl'].previousValue)\r\n    ) {\r\n      let viewerDetails = getViewerDetails(\r\n        this.url,\r\n        this.configuredViewer,\r\n        this.queryParams,\r\n        this.viewerUrl\r\n      );\r\n      this.externalViewer = viewerDetails.externalViewer;\r\n      if (viewerDetails.externalViewer && this.overrideLocalhost && isLocalFile(this.url)) {\r\n        const newUrl = replaceLocalUrl(this.url, this.overrideLocalhost);\r\n        viewerDetails = getViewerDetails(\r\n          newUrl,\r\n          this.configuredViewer,\r\n          this.queryParams,\r\n          this.viewerUrl\r\n        );\r\n      }\r\n      this.docHtml = '';\r\n      if (this.checkIFrameSubscription) {\r\n        this.checkIFrameSubscription.unsubscribe();\r\n      }\r\n      if (!this.url) {\r\n        this.fullUrl = undefined;\r\n      } else if (\r\n        viewerDetails.externalViewer ||\r\n        this.configuredViewer === 'url'\r\n      ) {\r\n        this.fullUrl = this.domSanitizer.bypassSecurityTrustResourceUrl(\r\n          viewerDetails.url\r\n        );\r\n        // see:\r\n        // https://stackoverflow.com/questions/40414039/google-docs-viewer-returning-204-responses-no-longer-working-alternatives\r\n        // hack to reload iframe if it's not loaded.\r\n        // would maybe be better to use view.officeapps.live.com but seems not to work with sas token.\r\n        if (\r\n          this.configuredViewer === 'google' &&\r\n          this.googleCheckContentLoaded\r\n        ) {\r\n          this.ngZone.runOutsideAngular(() => {\r\n            // if it's not loaded after the googleIntervalCheck, then open load again.\r\n            const iframe = this.iframes?.first\r\n              ?.nativeElement as HTMLIFrameElement;\r\n            if (iframe) {\r\n              this.reloadIframe(iframe);\r\n            } else {\r\n              this.shouldCheckIframe = true;\r\n            }\r\n          });\r\n        }\r\n      } else if (this.configuredViewer === 'mammoth') {\r\n        this.docHtml = await getDocxToHtml(this.url);\r\n      }\r\n    }\r\n  }\r\n\r\n  private reloadIframe(iframe: HTMLIFrameElement) {\r\n    this.checkIFrameSubscription = googleCheckSubscription();\r\n    this.checkIFrameSubscription.subscribe(\r\n      iframe,\r\n      this.googleCheckInterval,\r\n      this.googleMaxChecks\r\n    );\r\n  }\r\n\r\n  iframeLoaded() {\r\n    const iframe = this.iframes?.first\r\n      ?.nativeElement as HTMLIFrameElement;\r\n    if (iframe && iframeIsLoaded(iframe)) {\r\n      this.loaded.emit(undefined);\r\n      if (this.checkIFrameSubscription) {\r\n        this.checkIFrameSubscription.unsubscribe();\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ng-container *ngIf=\"!externalViewer\">\r\n  <div *ngIf=\"configuredViewer !== 'pdf'\" [innerHtml]=\"docHtml\"></div>\r\n  <object\r\n    *ngIf=\"fullUrl && configuredViewer === 'pdf'\"\r\n    [data]=\"fullUrl\"\r\n    type=\"application/pdf\"\r\n    width=\"100%\"\r\n    height=\"100%\"\r\n  >\r\n    <p>\r\n      Your browser does not support PDFs.\r\n      <a [href]=\"fullUrl\">Download the PDF</a>.\r\n    </p>\r\n  </object>\r\n</ng-container>\r\n<ng-container *ngIf=\"externalViewer\">\r\n  <iframe\r\n    (load)=\"iframeLoaded()\"\r\n    *ngIf=\"fullUrl && disableContent === 'none'\"\r\n    #iframe\r\n    id=\"iframe-doc-viewer\"\r\n    frameBorder=\"0\"\r\n    [src]=\"fullUrl\"\r\n  ></iframe>\r\n  <div class=\"container\" *ngIf=\"disableContent !== 'none'\">\r\n    <div\r\n      [class.overlay-full]=\"disableContent === 'all'\"\r\n      [class.overlay-popout-google]=\"\r\n        configuredViewer === 'google' &&\r\n        (disableContent === 'popout' || disableContent === 'popout-hide')\r\n      \"\r\n      [class.overlay-popout-office]=\"\r\n        configuredViewer === 'office' &&\r\n        (disableContent === 'popout' || disableContent === 'popout-hide')\r\n      \"\r\n      [style.background-color]=\"\r\n        disableContent === 'popout-hide' ? '#fff' : 'transparent'\r\n      \"\r\n    ></div>\r\n    <iframe\r\n      (load)=\"iframeLoaded()\"\r\n      *ngIf=\"fullUrl\"\r\n      #iframe\r\n      id=\"iframe\"\r\n      frameBorder=\"0\"\r\n      [src]=\"fullUrl\"\r\n    ></iframe>\r\n  </div>\r\n</ng-container>\r\n"]}
@@ -0,0 +1,18 @@
1
+ import { NgxDocViewerComponent } from './document-viewer.component';
2
+ import { NgModule } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import * as i0 from "@angular/core";
5
+ export class NgxDocViewerModule {
6
+ }
7
+ NgxDocViewerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxDocViewerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
+ NgxDocViewerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxDocViewerModule, declarations: [NgxDocViewerComponent], imports: [CommonModule], exports: [NgxDocViewerComponent] });
9
+ NgxDocViewerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxDocViewerModule, imports: [[CommonModule]] });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: NgxDocViewerModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ imports: [CommonModule],
14
+ declarations: [NgxDocViewerComponent],
15
+ exports: [NgxDocViewerComponent],
16
+ }]
17
+ }] });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jdW1lbnQtdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL25neC1kb2Mtdmlld2VyL3NyYy9saWIvZG9jdW1lbnQtdmlld2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFPL0MsTUFBTSxPQUFPLGtCQUFrQjs7K0dBQWxCLGtCQUFrQjtnSEFBbEIsa0JBQWtCLGlCQUhkLHFCQUFxQixhQUQxQixZQUFZLGFBRVoscUJBQXFCO2dIQUVwQixrQkFBa0IsWUFKcEIsQ0FBQyxZQUFZLENBQUM7MkZBSVosa0JBQWtCO2tCQUw5QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsWUFBWSxFQUFFLENBQUMscUJBQXFCLENBQUM7b0JBQ3JDLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5neERvY1ZpZXdlckNvbXBvbmVudCB9IGZyb20gJy4vZG9jdW1lbnQtdmlld2VyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gIGRlY2xhcmF0aW9uczogW05neERvY1ZpZXdlckNvbXBvbmVudF0sXHJcbiAgZXhwb3J0czogW05neERvY1ZpZXdlckNvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOZ3hEb2NWaWV3ZXJNb2R1bGUge31cclxuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRvYy12aWV3ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9uZ3gtZG9jLXZpZXdlci9zcmMvbmd4LWRvYy12aWV3ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=