@eui/mobile-core 17.2.0-snapshot-1716538151901 → 17.2.0-snapshot-1716885030476
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/docs/components/EuimPdfViewerComponent.html +22 -2
- package/docs/dependencies.html +5 -5
- package/docs/js/menu-wc.js +3 -3
- package/docs/js/menu-wc_es5.js +11 -11
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.mjs +71 -29
- package/esm2022/lib/components/euim-pdf-viewer/euim-pdf-viewer.module.mjs +7 -3
- package/fesm2022/eui-mobile-core.mjs +73 -29
- package/fesm2022/eui-mobile-core.mjs.map +1 -1
- package/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.d.ts +26 -3
- package/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.d.ts.map +1 -1
- package/lib/components/euim-pdf-viewer/euim-pdf-viewer.module.d.ts +2 -1
- package/lib/components/euim-pdf-viewer/euim-pdf-viewer.module.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,18 +1,24 @@
|
|
|
1
1
|
import { Component, Input, ViewEncapsulation, ViewChild } from '@angular/core';
|
|
2
|
+
import { Subject, throwError } from 'rxjs';
|
|
3
|
+
import { map, switchMap, catchError, startWith } from 'rxjs/operators';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
5
|
import * as i1 from "@ionic/angular";
|
|
4
|
-
import * as i2 from "
|
|
5
|
-
import * as i3 from "
|
|
6
|
-
import * as i4 from "
|
|
7
|
-
import * as i5 from "../euim-spinner/euim-spinner
|
|
8
|
-
import * as i6 from "
|
|
6
|
+
import * as i2 from "@angular/common/http";
|
|
7
|
+
import * as i3 from "ng2-pdf-viewer";
|
|
8
|
+
import * as i4 from "@mapaxe/ngx-pinch-zoom";
|
|
9
|
+
import * as i5 from "../euim-spinner/euim-spinner.component";
|
|
10
|
+
import * as i6 from "../euim-spinner/euim-spinner-message/euim-spinner-message.component";
|
|
11
|
+
import * as i7 from "@ngx-translate/core";
|
|
9
12
|
export class EuimPdfViewerComponent {
|
|
10
|
-
constructor(alertService) {
|
|
13
|
+
constructor(alertService, http) {
|
|
11
14
|
this.alertService = alertService;
|
|
15
|
+
this.http = http;
|
|
12
16
|
this.page = 1;
|
|
13
17
|
this.zoom = 1;
|
|
14
18
|
this.loading = true;
|
|
15
19
|
this.errorMessage = '';
|
|
20
|
+
this.pdfNumPages = 1;
|
|
21
|
+
this.urlChange$ = new Subject();
|
|
16
22
|
this.showDefaultError = true;
|
|
17
23
|
setTimeout(() => {
|
|
18
24
|
if (this.showDefaultError) {
|
|
@@ -21,6 +27,29 @@ export class EuimPdfViewerComponent {
|
|
|
21
27
|
}
|
|
22
28
|
}, 15000);
|
|
23
29
|
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
// subscribe and cancel previous subscription (if any) for fetching data while URL changes
|
|
32
|
+
this.subscription = this.urlChange$.pipe(startWith(this.url), switchMap((url) => this.getPDFData(url))).subscribe({
|
|
33
|
+
next: (data) => {
|
|
34
|
+
this.data = data;
|
|
35
|
+
this.showDefaultError = false;
|
|
36
|
+
this.loading = false;
|
|
37
|
+
},
|
|
38
|
+
error: () => {
|
|
39
|
+
this.onError();
|
|
40
|
+
this.data = null;
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
ngOnChanges(changes) {
|
|
45
|
+
if (changes['url']) {
|
|
46
|
+
this.loading = true;
|
|
47
|
+
this.urlChange$.next(changes['url'].currentValue);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
ngOnDestroy() {
|
|
51
|
+
this.subscription.unsubscribe();
|
|
52
|
+
}
|
|
24
53
|
zoomChange(event) {
|
|
25
54
|
this.eventResult = event;
|
|
26
55
|
this.zoom = this.eventResult.scale;
|
|
@@ -29,6 +58,7 @@ export class EuimPdfViewerComponent {
|
|
|
29
58
|
this.showDefaultError = false;
|
|
30
59
|
this.loading = false;
|
|
31
60
|
this.pdf = pdf;
|
|
61
|
+
this.pdfNumPages = this.pdf.numPages;
|
|
32
62
|
}
|
|
33
63
|
onError() {
|
|
34
64
|
this.showDefaultError = false;
|
|
@@ -36,16 +66,8 @@ export class EuimPdfViewerComponent {
|
|
|
36
66
|
this.errorMessage = 'File could not be loaded.';
|
|
37
67
|
}
|
|
38
68
|
onDownload() {
|
|
39
|
-
this.pdf
|
|
40
|
-
|
|
41
|
-
type: 'application/pdf',
|
|
42
|
-
});
|
|
43
|
-
const url = URL.createObjectURL(blob);
|
|
44
|
-
this.openLink(url);
|
|
45
|
-
// Remove the link when done
|
|
46
|
-
setTimeout(() => {
|
|
47
|
-
window.URL.revokeObjectURL(url);
|
|
48
|
-
}, 5000);
|
|
69
|
+
this.pdf?.getData().then((u8) => {
|
|
70
|
+
this.downloadFile(u8, 'file.pdf');
|
|
49
71
|
});
|
|
50
72
|
}
|
|
51
73
|
onZoomIn() {
|
|
@@ -59,9 +81,6 @@ export class EuimPdfViewerComponent {
|
|
|
59
81
|
onResetZoom() {
|
|
60
82
|
this.pinch.resetZoom();
|
|
61
83
|
}
|
|
62
|
-
// async onDismissModal() {
|
|
63
|
-
// await this.modalCtrl.dismiss();
|
|
64
|
-
// }
|
|
65
84
|
nextPage() {
|
|
66
85
|
if (this.page < this.pdf.numPages) {
|
|
67
86
|
this.page++;
|
|
@@ -72,23 +91,46 @@ export class EuimPdfViewerComponent {
|
|
|
72
91
|
this.page--;
|
|
73
92
|
}
|
|
74
93
|
}
|
|
75
|
-
|
|
94
|
+
/**
|
|
95
|
+
* Download file from the given data and filename using Blob.
|
|
96
|
+
* It generates an anchor link and clicks on it to download the file.
|
|
97
|
+
* @param data
|
|
98
|
+
* @param filename
|
|
99
|
+
* @private
|
|
100
|
+
*/
|
|
101
|
+
downloadFile(data, filename) {
|
|
102
|
+
const blob = new Blob([data.buffer], { type: 'application/pdf' });
|
|
103
|
+
const url = window.URL.createObjectURL(blob);
|
|
76
104
|
const a = document.createElement('a');
|
|
77
|
-
document.body.appendChild(a);
|
|
78
|
-
a.style.display = 'none';
|
|
79
105
|
a.href = url;
|
|
80
|
-
a.download =
|
|
106
|
+
a.download = filename;
|
|
107
|
+
document.body.appendChild(a);
|
|
81
108
|
a.click();
|
|
82
|
-
|
|
109
|
+
setTimeout(() => {
|
|
110
|
+
window.URL.revokeObjectURL(url);
|
|
111
|
+
}, 5000);
|
|
83
112
|
document.body.removeChild(a);
|
|
84
113
|
}
|
|
85
|
-
/**
|
|
86
|
-
|
|
114
|
+
/**
|
|
115
|
+
* Fetch PDF data from the given URL and return as Uint8Array.
|
|
116
|
+
* @param url
|
|
117
|
+
* @private
|
|
118
|
+
*/
|
|
119
|
+
getPDFData(url) {
|
|
120
|
+
return this.http.get(url, { responseType: 'arraybuffer' })
|
|
121
|
+
// transform ArrayBuffer to Uint8Array
|
|
122
|
+
.pipe(map((data) => new Uint8Array(data)), catchError(err => {
|
|
123
|
+
this.onError();
|
|
124
|
+
return throwError(() => err);
|
|
125
|
+
}));
|
|
126
|
+
}
|
|
127
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerComponent, deps: [{ token: i1.AlertController }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
128
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: EuimPdfViewerComponent, selector: "euim-pdf-viewer", inputs: { url: "url", page: "page" }, viewQueries: [{ propertyName: "pinch", first: true, predicate: ["pinch"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "@if (loading || errorMessage) {\n<div>\n @if (loading) {\n <euim-spinner>\n <div euimSpinnerMessage>Loading PDF...</div>\n </euim-spinner>\n }\n @if (errorMessage) {\n <div>{{errorMessage}}</div>\n }\n</div>\n}\n\n<pinch-zoom [limit-zoom]=\"4\" [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n <div style=\"display: block;width: 100%; height: 500px\">\n <pdf-viewer [src]=\"data\"\n [original-size]=\"false\"\n [zoom-scale]=\"'page-height'\"\n (after-load-complete)=\"onLoaded($event)\"\n (error)=\"onError()\"\n [(page)]=\"page\"\n [stick-to-page]=\"false\"\n [show-all]=\"false\"\n [render-text]=\"true\"\n style=\"width: 100%; height: 100%\">\n </pdf-viewer>\n </div>\n</pinch-zoom>\n\n<ion-footer>\n <ion-toolbar color=\"primary\" class=\"euim-pdf-viewer__footer\">\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"onDownload()\" [disabled]=\"!pdf || !data\">\n <ion-icon name=\"download-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-buttons class=\"euim-pdf-viewer__footer-zoom-container\">\n <ion-button (click)=\"onZoomOut()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n <ion-icon name=\"remove-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n <ion-button (click)=\"onResetZoom()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n {{'euim.pdf-viewer.reset.zoom' | translate }}\n </ion-button>\n <ion-button (click)=\"onZoomIn()\" [disabled]=\"zoom === 4 || !pdf || !data\">\n <ion-icon name=\"add-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n\n\n <ion-button (click)=\"prevPage()\" [disabled]=\"page === 1 || !pdf || !data\">\n {{'euim.stepper.previous' | translate }}\n </ion-button>\n {{page}}\n <ion-button (click)=\"nextPage()\" [disabled]=\"page === pdfNumPages || !pdf || !data\">\n {{'euim.stepper.next' | translate }}\n </ion-button>\n\n </ion-buttons>\n </ion-toolbar>\n</ion-footer>\n", styles: [".euim-pdf-viewer__footer-zoom-container{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}\n"], dependencies: [{ kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i1.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i1.IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i1.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i1.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: i3.PdfViewerComponent, selector: "pdf-viewer", inputs: ["src", "c-maps-url", "page", "render-text", "render-text-mode", "original-size", "show-all", "stick-to-page", "zoom", "zoom-scale", "rotation", "external-link-target", "autoresize", "fit-to-page", "show-borders"], outputs: ["after-load-complete", "page-rendered", "pages-initialized", "text-layer-rendered", "error", "on-progress", "pageChange"] }, { kind: "component", type: i4.PinchZoomComponent, selector: "pinch-zoom, [pinch-zoom]", inputs: ["properties", "transition-duration", "transitionDuration", "double-tap", "doubleTap", "double-tap-scale", "doubleTapScale", "auto-zoom-out", "autoZoomOut", "limit-zoom", "limitZoom", "disabled", "disablePan", "overflow", "zoomControlScale", "disableZoomControl", "backgroundColor", "limitPan", "minPanScale", "minScale", "listeners", "wheel", "autoHeight", "stepZoomFactor", "wheelZoomFactor", "draggableImage"], outputs: ["onZoomChange"], exportAs: ["pinchZoom"] }, { kind: "component", type: i5.EuimSpinnerComponent, selector: "euim-spinner" }, { kind: "component", type: i6.EuimSpinnerMessageComponent, selector: "[euimSpinnerMessage]" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
87
129
|
}
|
|
88
130
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerComponent, decorators: [{
|
|
89
131
|
type: Component,
|
|
90
|
-
args: [{ selector: 'euim-pdf-viewer', encapsulation: ViewEncapsulation.None, template: "@if (loading || errorMessage) {\n<div>\n @if (loading) {\n <euim-spinner>\n <div euimSpinnerMessage>Loading PDF...</div>\n </euim-spinner>\n }\n @if (errorMessage) {\n <div>{{errorMessage}}</div>\n }\n</div>\n}\n\n<pinch-zoom [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n <div style=\"display: block;width: 100%; height: 500px\">\n <pdf-viewer [src]=\"
|
|
91
|
-
}], ctorParameters: () => [{ type: i1.AlertController }], propDecorators: { url: [{
|
|
132
|
+
args: [{ selector: 'euim-pdf-viewer', encapsulation: ViewEncapsulation.None, template: "@if (loading || errorMessage) {\n<div>\n @if (loading) {\n <euim-spinner>\n <div euimSpinnerMessage>Loading PDF...</div>\n </euim-spinner>\n }\n @if (errorMessage) {\n <div>{{errorMessage}}</div>\n }\n</div>\n}\n\n<pinch-zoom [limit-zoom]=\"4\" [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n <div style=\"display: block;width: 100%; height: 500px\">\n <pdf-viewer [src]=\"data\"\n [original-size]=\"false\"\n [zoom-scale]=\"'page-height'\"\n (after-load-complete)=\"onLoaded($event)\"\n (error)=\"onError()\"\n [(page)]=\"page\"\n [stick-to-page]=\"false\"\n [show-all]=\"false\"\n [render-text]=\"true\"\n style=\"width: 100%; height: 100%\">\n </pdf-viewer>\n </div>\n</pinch-zoom>\n\n<ion-footer>\n <ion-toolbar color=\"primary\" class=\"euim-pdf-viewer__footer\">\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"onDownload()\" [disabled]=\"!pdf || !data\">\n <ion-icon name=\"download-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-buttons class=\"euim-pdf-viewer__footer-zoom-container\">\n <ion-button (click)=\"onZoomOut()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n <ion-icon name=\"remove-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n <ion-button (click)=\"onResetZoom()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n {{'euim.pdf-viewer.reset.zoom' | translate }}\n </ion-button>\n <ion-button (click)=\"onZoomIn()\" [disabled]=\"zoom === 4 || !pdf || !data\">\n <ion-icon name=\"add-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n\n\n <ion-button (click)=\"prevPage()\" [disabled]=\"page === 1 || !pdf || !data\">\n {{'euim.stepper.previous' | translate }}\n </ion-button>\n {{page}}\n <ion-button (click)=\"nextPage()\" [disabled]=\"page === pdfNumPages || !pdf || !data\">\n {{'euim.stepper.next' | translate }}\n </ion-button>\n\n </ion-buttons>\n </ion-toolbar>\n</ion-footer>\n", styles: [".euim-pdf-viewer__footer-zoom-container{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}\n"] }]
|
|
133
|
+
}], ctorParameters: () => [{ type: i1.AlertController }, { type: i2.HttpClient }], propDecorators: { url: [{
|
|
92
134
|
type: Input
|
|
93
135
|
}], page: [{
|
|
94
136
|
type: Input
|
|
@@ -96,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
96
138
|
type: ViewChild,
|
|
97
139
|
args: ['pinch', { static: true }]
|
|
98
140
|
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-pdf-viewer.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.ts","../../../../../src/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewEncapsulation, ViewChild } from '@angular/core';\nimport { PDFDocumentProxy } from 'ng2-pdf-viewer';\nimport { AlertController } from '@ionic/angular';\nimport { PinchZoomComponent, ZoomEvent } from '@mapaxe/ngx-pinch-zoom';\n\n@Component({\n    selector: 'euim-pdf-viewer',\n    styleUrls: ['./styles/_index.scss'],\n    templateUrl: './euim-pdf-viewer.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuimPdfViewerComponent {\n    @Input() url: string;\n    @Input() page  = 1;\n\n    @ViewChild('pinch', { static: true }) pinch!: PinchZoomComponent;\n\n    zoom = 1;\n    loading = true;\n    errorMessage = '';\n    pdf: PDFDocumentProxy;\n    eventResult?: ZoomEvent;\n\n    private showDefaultError: boolean;\n\n    constructor(private alertService: AlertController) {\n\n        this.showDefaultError = true;\n        setTimeout(() => {\n            if (this.showDefaultError) {\n                this.loading = false;\n                this.alertService.create({ header: 'PDF could not be loaded.' }).then();\n            }\n        }, 15000);\n    }\n\n    zoomChange(event: ZoomEvent): void {\n        this.eventResult = event;\n        this.zoom = this.eventResult.scale;\n    }\n\n    onLoaded(pdf: PDFDocumentProxy): void {\n        this.showDefaultError = false;\n        this.loading = false;\n        this.pdf = pdf;\n    }\n\n    onError(): void {\n        this.showDefaultError = false;\n        this.loading = false;\n        this.errorMessage = 'File could not be loaded.';\n    }\n\n    onDownload(): void {\n        this.pdf.getData().then((u8) => {\n            const blob = new Blob([u8.buffer], {\n                type: 'application/pdf',\n            });\n\n            const url = URL.createObjectURL(blob);\n            this.openLink(url);\n            // Remove the link when done\n            setTimeout(() => {\n                window.URL.revokeObjectURL(url);\n            }, 5000);\n        });\n    }\n\n    onZoomIn(): void {\n        this.pinch.zoomIn();\n    }\n\n    onZoomOut(): void {\n        if (this.zoom > 1) {\n            this.pinch.zoomOut();\n        }\n    }\n\n    onResetZoom(): void {\n        this.pinch.resetZoom();\n    }\n\n    // async onDismissModal() {\n    //     await this.modalCtrl.dismiss();\n    // }\n\n    nextPage(): void {\n        if (this.page < this.pdf.numPages) {\n            this.page++;\n        }\n    }\n\n    prevPage():void {\n        if (this.page > 1) {\n            this.page--;\n        }\n    }\n\n    private openLink(url: string): void {\n        const a = document.createElement('a');\n\n        document.body.appendChild(a);\n        a.style.display = 'none';\n        a.href = url;\n        a.download = 'PDF_File.pdf';\n        a.click();\n        // Remove the link when done\n        document.body.removeChild(a);\n    }\n}\n","@if (loading || errorMessage) {\n<div>\n  @if (loading) {\n    <euim-spinner>\n      <div euimSpinnerMessage>Loading PDF...</div>\n    </euim-spinner>\n  }\n  @if (errorMessage) {\n    <div>{{errorMessage}}</div>\n  }\n</div>\n}\n\n<pinch-zoom [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n    <div style=\"display: block;width: 100%; height: 500px\">\n        <pdf-viewer [src]=\"url\"\n                    [zoom]=\"zoom\"\n                    [original-size]=\"true\"\n                    [autoresize]=\"false\"\n                    (after-load-complete)=\"onLoaded($event)\"\n                    (error)=\"onError()\"\n                    [page]=\"page\"\n                    style=\"width: 100%; height: 100%\">\n        </pdf-viewer>\n    </div>\n</pinch-zoom>\n\n<ion-footer>\n  <ion-toolbar color=\"primary\" class=\"euim-pdf-viewer__footer\">\n    <ion-buttons slot=\"start\">\n      <ion-button (click)=\"onDownload()\" [disabled]=\"!pdf\">\n        <ion-icon name=\"download-outline\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n    </ion-buttons>\n    <ion-buttons class=\"euim-pdf-viewer__footer-zoom-container\">\n      <ion-button (click)=\"onZoomOut()\" [disabled]=\"zoom === 1\">\n        <ion-icon name=\"remove-circle-outline\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n      <ion-button (click)=\"onResetZoom()\">\n          {{'euim.pdf-viewer.reset.zoom' | translate }}\n      </ion-button>\n      <ion-button (click)=\"onZoomIn()\">\n        <ion-icon name=\"add-circle-outline\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n\n\n      <ion-button (click)=\"prevPage()\">\n          {{'euim.stepper.previous' | translate }}\n      </ion-button>\n      {{page}}\n      <ion-button (click)=\"nextPage()\">\n          {{'euim.stepper.next' | translate }}\n      </ion-button>\n\n    </ion-buttons>\n  </ion-toolbar>\n</ion-footer>\n"]}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-pdf-viewer.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.ts","../../../../../src/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SimpleChanges, OnChanges, OnDestroy, Component, Input, ViewEncapsulation, ViewChild, OnInit } from '@angular/core';\nimport { PDFDocumentProxy } from 'ng2-pdf-viewer';\nimport { AlertController } from '@ionic/angular';\nimport { PinchZoomComponent, ZoomEvent } from '@mapaxe/ngx-pinch-zoom';\nimport { HttpClient } from '@angular/common/http';\nimport { Observable, Subject, Subscription, throwError } from 'rxjs';\nimport { map, switchMap, catchError, startWith } from 'rxjs/operators';\n\n@Component({\n    selector: 'euim-pdf-viewer',\n    styleUrls: ['./styles/_index.scss'],\n    templateUrl: './euim-pdf-viewer.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuimPdfViewerComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() url: string;\n    @Input() page  = 1;\n\n    @ViewChild('pinch', { static: true }) pinch!: PinchZoomComponent;\n\n    zoom = 1;\n    loading = true;\n    errorMessage = '';\n    pdf: PDFDocumentProxy;\n    eventResult?: ZoomEvent;\n    protected pdfNumPages = 1;\n    protected data: Uint8Array;\n\n    private showDefaultError: boolean;\n    private urlChange$ = new Subject<string>();\n    private subscription: Subscription;\n\n    constructor(private alertService: AlertController, private http: HttpClient) {\n\n        this.showDefaultError = true;\n        setTimeout(() => {\n            if (this.showDefaultError) {\n                this.loading = false;\n                this.alertService.create({ header: 'PDF could not be loaded.' }).then();\n            }\n        }, 15000);\n    }\n\n    ngOnInit(): void {\n        // subscribe and cancel previous subscription (if any) for fetching data while URL changes\n        this.subscription = this.urlChange$.pipe(\n            startWith(this.url),\n            switchMap((url) => this.getPDFData(url)),\n        ).subscribe({\n            next: (data: Uint8Array) => {\n                this.data = data;\n                this.showDefaultError = false;\n                this.loading = false;\n            },\n            error: () => {\n                this.onError();\n                this.data = null;\n            },\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if(changes['url']) {\n            this.loading = true;\n            this.urlChange$.next(changes['url'].currentValue);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.subscription.unsubscribe();\n    }\n\n    zoomChange(event: ZoomEvent): void {\n        this.eventResult = event;\n        this.zoom = this.eventResult.scale;\n    }\n\n    onLoaded(pdf: PDFDocumentProxy): void {\n        this.showDefaultError = false;\n        this.loading = false;\n        this.pdf = pdf;\n        this.pdfNumPages = this.pdf.numPages;\n    }\n\n    onError(): void {\n        this.showDefaultError = false;\n        this.loading = false;\n        this.errorMessage = 'File could not be loaded.';\n    }\n\n    onDownload(): void {\n        this.pdf?.getData().then((u8) => {\n            this.downloadFile(u8, 'file.pdf');\n        });\n    }\n\n    onZoomIn(): void {\n        this.pinch.zoomIn();\n    }\n\n    onZoomOut(): void {\n        if (this.zoom > 1) {\n            this.pinch.zoomOut();\n        }\n    }\n\n    onResetZoom(): void {\n        this.pinch.resetZoom();\n    }\n\n    nextPage(): void {\n        if (this.page < this.pdf.numPages) {\n            this.page++;\n        }\n    }\n\n    prevPage():void {\n        if (this.page > 1) {\n            this.page--;\n        }\n    }\n\n    /**\n     * Download file from the given data and filename using Blob.\n     * It generates an anchor link and clicks on it to download the file.\n     * @param data\n     * @param filename\n     * @private\n     */\n    private downloadFile(data: Uint8Array, filename: string): void {\n        const blob = new Blob([data.buffer], { type: 'application/pdf' });\n        const url = window.URL.createObjectURL(blob);\n        const a = document.createElement('a');\n        a.href = url;\n        a.download = filename;\n        document.body.appendChild(a);\n        a.click();\n        setTimeout(() => {\n            window.URL.revokeObjectURL(url);\n        }, 5000);\n        document.body.removeChild(a);\n    }\n\n    /**\n     * Fetch PDF data from the given URL and return as Uint8Array.\n     * @param url\n     * @private\n     */\n    private getPDFData(url: string): Observable<Uint8Array> {\n        return this.http.get(url, { responseType: 'arraybuffer' })\n            // transform ArrayBuffer to Uint8Array\n            .pipe(\n                map((data: ArrayBuffer) => new Uint8Array(data)),\n                catchError(err => {\n                    this.onError();\n                    return throwError(() => err);\n                }),\n            );\n    }\n}\n","@if (loading || errorMessage) {\n<div>\n  @if (loading) {\n    <euim-spinner>\n      <div euimSpinnerMessage>Loading PDF...</div>\n    </euim-spinner>\n  }\n  @if (errorMessage) {\n    <div>{{errorMessage}}</div>\n  }\n</div>\n}\n\n<pinch-zoom [limit-zoom]=\"4\" [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n    <div style=\"display: block;width: 100%; height: 500px\">\n        <pdf-viewer [src]=\"data\"\n                    [original-size]=\"false\"\n                    [zoom-scale]=\"'page-height'\"\n                    (after-load-complete)=\"onLoaded($event)\"\n                    (error)=\"onError()\"\n                    [(page)]=\"page\"\n                    [stick-to-page]=\"false\"\n                    [show-all]=\"false\"\n                    [render-text]=\"true\"\n                    style=\"width: 100%; height: 100%\">\n        </pdf-viewer>\n    </div>\n</pinch-zoom>\n\n<ion-footer>\n  <ion-toolbar color=\"primary\" class=\"euim-pdf-viewer__footer\">\n    <ion-buttons slot=\"start\">\n      <ion-button (click)=\"onDownload()\" [disabled]=\"!pdf || !data\">\n        <ion-icon name=\"download-outline\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n    </ion-buttons>\n    <ion-buttons class=\"euim-pdf-viewer__footer-zoom-container\">\n      <ion-button (click)=\"onZoomOut()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n        <ion-icon name=\"remove-circle-outline\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n      <ion-button (click)=\"onResetZoom()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n          {{'euim.pdf-viewer.reset.zoom' | translate }}\n      </ion-button>\n      <ion-button (click)=\"onZoomIn()\" [disabled]=\"zoom === 4 || !pdf || !data\">\n        <ion-icon name=\"add-circle-outline\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n\n\n      <ion-button (click)=\"prevPage()\" [disabled]=\"page === 1 || !pdf || !data\">\n          {{'euim.stepper.previous' | translate }}\n      </ion-button>\n      {{page}}\n      <ion-button (click)=\"nextPage()\" [disabled]=\"page === pdfNumPages || !pdf || !data\">\n          {{'euim.stepper.next' | translate }}\n      </ion-button>\n\n    </ion-buttons>\n  </ion-toolbar>\n</ion-footer>\n"]}
|
|
@@ -6,6 +6,7 @@ import { PdfViewerModule } from 'ng2-pdf-viewer';
|
|
|
6
6
|
import { PinchZoomModule } from '@mapaxe/ngx-pinch-zoom';
|
|
7
7
|
import { EuimSpinnerComponentModule } from '../euim-spinner';
|
|
8
8
|
import { TranslateModule } from '@ngx-translate/core';
|
|
9
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
const COMPONENTS = [
|
|
11
12
|
EuimPdfViewerComponent,
|
|
@@ -17,13 +18,15 @@ export class EuimPdfViewerModule {
|
|
|
17
18
|
PdfViewerModule,
|
|
18
19
|
PinchZoomModule,
|
|
19
20
|
EuimSpinnerComponentModule,
|
|
20
|
-
TranslateModule
|
|
21
|
+
TranslateModule,
|
|
22
|
+
HttpClientModule], exports: [EuimPdfViewerComponent] }); }
|
|
21
23
|
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerModule, imports: [CommonModule,
|
|
22
24
|
IonicModule,
|
|
23
25
|
PdfViewerModule,
|
|
24
26
|
PinchZoomModule,
|
|
25
27
|
EuimSpinnerComponentModule,
|
|
26
|
-
TranslateModule
|
|
28
|
+
TranslateModule,
|
|
29
|
+
HttpClientModule] }); }
|
|
27
30
|
}
|
|
28
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerModule, decorators: [{
|
|
29
32
|
type: NgModule,
|
|
@@ -35,6 +38,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
35
38
|
PinchZoomModule,
|
|
36
39
|
EuimSpinnerComponentModule,
|
|
37
40
|
TranslateModule,
|
|
41
|
+
HttpClientModule,
|
|
38
42
|
],
|
|
39
43
|
exports: [
|
|
40
44
|
...COMPONENTS,
|
|
@@ -44,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
44
48
|
],
|
|
45
49
|
}]
|
|
46
50
|
}] });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1wZGYtdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9ldWltLXBkZi12aWV3ZXIvZXVpbS1wZGYtdmlld2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUNyRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBRXhELE1BQU0sVUFBVSxHQUFHO0lBQ2Ysc0JBQXNCO0NBQ3pCLENBQUM7QUFvQkYsTUFBTSxPQUFPLG1CQUFtQjtpSUFBbkIsbUJBQW1CO2tJQUFuQixtQkFBbUIsaUJBckI1QixzQkFBc0IsYUFNbEIsWUFBWTtZQUNaLFdBQVc7WUFDWCxlQUFlO1lBQ2YsZUFBZTtZQUNmLDBCQUEwQjtZQUMxQixlQUFlO1lBQ2YsZ0JBQWdCLGFBWnBCLHNCQUFzQjtrSUFxQmIsbUJBQW1CLFlBZnhCLFlBQVk7WUFDWixXQUFXO1lBQ1gsZUFBZTtZQUNmLGVBQWU7WUFDZiwwQkFBMEI7WUFDMUIsZUFBZTtZQUNmLGdCQUFnQjs7MkZBU1gsbUJBQW1CO2tCQWxCL0IsUUFBUTttQkFBQztvQkFFTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZiwwQkFBMEI7d0JBQzFCLGVBQWU7d0JBQ2YsZ0JBQWdCO3FCQUNuQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ0wsR0FBRyxVQUFVO3FCQUNoQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1YsR0FBRyxVQUFVO3FCQUNoQjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRXVpbVBkZlZpZXdlckNvbXBvbmVudCB9IGZyb20gJy4vZXVpbS1wZGYtdmlld2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcbmltcG9ydCB7IFBkZlZpZXdlck1vZHVsZSB9IGZyb20gJ25nMi1wZGYtdmlld2VyJztcbmltcG9ydCB7IFBpbmNoWm9vbU1vZHVsZSB9IGZyb20gJ0BtYXBheGUvbmd4LXBpbmNoLXpvb20nO1xuaW1wb3J0IHsgRXVpbVNwaW5uZXJDb21wb25lbnRNb2R1bGUgfSBmcm9tICcuLi9ldWltLXNwaW5uZXInO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuXG5jb25zdCBDT01QT05FTlRTID0gW1xuICAgIEV1aW1QZGZWaWV3ZXJDb21wb25lbnQsXG5dO1xuXG5ATmdNb2R1bGUoe1xuXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIElvbmljTW9kdWxlLFxuICAgICAgICBQZGZWaWV3ZXJNb2R1bGUsXG4gICAgICAgIFBpbmNoWm9vbU1vZHVsZSxcbiAgICAgICAgRXVpbVNwaW5uZXJDb21wb25lbnRNb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICAgICAgSHR0cENsaWVudE1vZHVsZSxcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtcbiAgICAgICAgLi4uQ09NUE9ORU5UUyxcbiAgICBdLFxuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICAuLi5DT01QT05FTlRTLFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIEV1aW1QZGZWaWV3ZXJNb2R1bGUge1xufVxuIl19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export * from '@eui/base';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
3
|
import { Injectable, booleanAttribute, Directive, Input, Component, ViewEncapsulation, ChangeDetectionStrategy, HostBinding, NgModule, EventEmitter, Output, ContentChildren, ViewChild, HostListener, ContentChild } from '@angular/core';
|
|
4
|
-
import { BehaviorSubject, Subject } from 'rxjs';
|
|
4
|
+
import { BehaviorSubject, Subject, throwError } from 'rxjs';
|
|
5
5
|
import * as i2$1 from '@angular/common';
|
|
6
6
|
import { CommonModule } from '@angular/common';
|
|
7
7
|
import * as i1 from '@ionic/angular';
|
|
@@ -9,14 +9,16 @@ import { IonicModule } from '@ionic/angular';
|
|
|
9
9
|
import { EclLanguageService, EclDefaultLanguageService } from '@eui/ecl';
|
|
10
10
|
import * as i2 from '@eui/core';
|
|
11
11
|
import { EuiEuLanguages } from '@eui/core';
|
|
12
|
-
import { takeUntil, distinctUntilKeyChanged } from 'rxjs/operators';
|
|
12
|
+
import { takeUntil, distinctUntilKeyChanged, startWith, switchMap, map, catchError } from 'rxjs/operators';
|
|
13
13
|
import * as i1$1 from '@ngx-translate/core';
|
|
14
14
|
import { TranslateModule } from '@ngx-translate/core';
|
|
15
15
|
import * as i1$2 from '@angular/router';
|
|
16
16
|
import { NavigationEnd, RouterModule } from '@angular/router';
|
|
17
|
-
import * as i2$2 from '
|
|
17
|
+
import * as i2$2 from '@angular/common/http';
|
|
18
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
19
|
+
import * as i3 from 'ng2-pdf-viewer';
|
|
18
20
|
import { PdfViewerModule } from 'ng2-pdf-viewer';
|
|
19
|
-
import * as
|
|
21
|
+
import * as i4 from '@mapaxe/ngx-pinch-zoom';
|
|
20
22
|
import { PinchZoomModule } from '@mapaxe/ngx-pinch-zoom';
|
|
21
23
|
import * as i2$3 from 'angularx-qrcode';
|
|
22
24
|
import { QRCodeModule } from 'angularx-qrcode';
|
|
@@ -3046,12 +3048,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
3046
3048
|
}] });
|
|
3047
3049
|
|
|
3048
3050
|
class EuimPdfViewerComponent {
|
|
3049
|
-
constructor(alertService) {
|
|
3051
|
+
constructor(alertService, http) {
|
|
3050
3052
|
this.alertService = alertService;
|
|
3053
|
+
this.http = http;
|
|
3051
3054
|
this.page = 1;
|
|
3052
3055
|
this.zoom = 1;
|
|
3053
3056
|
this.loading = true;
|
|
3054
3057
|
this.errorMessage = '';
|
|
3058
|
+
this.pdfNumPages = 1;
|
|
3059
|
+
this.urlChange$ = new Subject();
|
|
3055
3060
|
this.showDefaultError = true;
|
|
3056
3061
|
setTimeout(() => {
|
|
3057
3062
|
if (this.showDefaultError) {
|
|
@@ -3060,6 +3065,29 @@ class EuimPdfViewerComponent {
|
|
|
3060
3065
|
}
|
|
3061
3066
|
}, 15000);
|
|
3062
3067
|
}
|
|
3068
|
+
ngOnInit() {
|
|
3069
|
+
// subscribe and cancel previous subscription (if any) for fetching data while URL changes
|
|
3070
|
+
this.subscription = this.urlChange$.pipe(startWith(this.url), switchMap((url) => this.getPDFData(url))).subscribe({
|
|
3071
|
+
next: (data) => {
|
|
3072
|
+
this.data = data;
|
|
3073
|
+
this.showDefaultError = false;
|
|
3074
|
+
this.loading = false;
|
|
3075
|
+
},
|
|
3076
|
+
error: () => {
|
|
3077
|
+
this.onError();
|
|
3078
|
+
this.data = null;
|
|
3079
|
+
},
|
|
3080
|
+
});
|
|
3081
|
+
}
|
|
3082
|
+
ngOnChanges(changes) {
|
|
3083
|
+
if (changes['url']) {
|
|
3084
|
+
this.loading = true;
|
|
3085
|
+
this.urlChange$.next(changes['url'].currentValue);
|
|
3086
|
+
}
|
|
3087
|
+
}
|
|
3088
|
+
ngOnDestroy() {
|
|
3089
|
+
this.subscription.unsubscribe();
|
|
3090
|
+
}
|
|
3063
3091
|
zoomChange(event) {
|
|
3064
3092
|
this.eventResult = event;
|
|
3065
3093
|
this.zoom = this.eventResult.scale;
|
|
@@ -3068,6 +3096,7 @@ class EuimPdfViewerComponent {
|
|
|
3068
3096
|
this.showDefaultError = false;
|
|
3069
3097
|
this.loading = false;
|
|
3070
3098
|
this.pdf = pdf;
|
|
3099
|
+
this.pdfNumPages = this.pdf.numPages;
|
|
3071
3100
|
}
|
|
3072
3101
|
onError() {
|
|
3073
3102
|
this.showDefaultError = false;
|
|
@@ -3075,16 +3104,8 @@ class EuimPdfViewerComponent {
|
|
|
3075
3104
|
this.errorMessage = 'File could not be loaded.';
|
|
3076
3105
|
}
|
|
3077
3106
|
onDownload() {
|
|
3078
|
-
this.pdf
|
|
3079
|
-
|
|
3080
|
-
type: 'application/pdf',
|
|
3081
|
-
});
|
|
3082
|
-
const url = URL.createObjectURL(blob);
|
|
3083
|
-
this.openLink(url);
|
|
3084
|
-
// Remove the link when done
|
|
3085
|
-
setTimeout(() => {
|
|
3086
|
-
window.URL.revokeObjectURL(url);
|
|
3087
|
-
}, 5000);
|
|
3107
|
+
this.pdf?.getData().then((u8) => {
|
|
3108
|
+
this.downloadFile(u8, 'file.pdf');
|
|
3088
3109
|
});
|
|
3089
3110
|
}
|
|
3090
3111
|
onZoomIn() {
|
|
@@ -3098,9 +3119,6 @@ class EuimPdfViewerComponent {
|
|
|
3098
3119
|
onResetZoom() {
|
|
3099
3120
|
this.pinch.resetZoom();
|
|
3100
3121
|
}
|
|
3101
|
-
// async onDismissModal() {
|
|
3102
|
-
// await this.modalCtrl.dismiss();
|
|
3103
|
-
// }
|
|
3104
3122
|
nextPage() {
|
|
3105
3123
|
if (this.page < this.pdf.numPages) {
|
|
3106
3124
|
this.page++;
|
|
@@ -3111,23 +3129,46 @@ class EuimPdfViewerComponent {
|
|
|
3111
3129
|
this.page--;
|
|
3112
3130
|
}
|
|
3113
3131
|
}
|
|
3114
|
-
|
|
3132
|
+
/**
|
|
3133
|
+
* Download file from the given data and filename using Blob.
|
|
3134
|
+
* It generates an anchor link and clicks on it to download the file.
|
|
3135
|
+
* @param data
|
|
3136
|
+
* @param filename
|
|
3137
|
+
* @private
|
|
3138
|
+
*/
|
|
3139
|
+
downloadFile(data, filename) {
|
|
3140
|
+
const blob = new Blob([data.buffer], { type: 'application/pdf' });
|
|
3141
|
+
const url = window.URL.createObjectURL(blob);
|
|
3115
3142
|
const a = document.createElement('a');
|
|
3116
|
-
document.body.appendChild(a);
|
|
3117
|
-
a.style.display = 'none';
|
|
3118
3143
|
a.href = url;
|
|
3119
|
-
a.download =
|
|
3144
|
+
a.download = filename;
|
|
3145
|
+
document.body.appendChild(a);
|
|
3120
3146
|
a.click();
|
|
3121
|
-
|
|
3147
|
+
setTimeout(() => {
|
|
3148
|
+
window.URL.revokeObjectURL(url);
|
|
3149
|
+
}, 5000);
|
|
3122
3150
|
document.body.removeChild(a);
|
|
3123
3151
|
}
|
|
3124
|
-
/**
|
|
3125
|
-
|
|
3152
|
+
/**
|
|
3153
|
+
* Fetch PDF data from the given URL and return as Uint8Array.
|
|
3154
|
+
* @param url
|
|
3155
|
+
* @private
|
|
3156
|
+
*/
|
|
3157
|
+
getPDFData(url) {
|
|
3158
|
+
return this.http.get(url, { responseType: 'arraybuffer' })
|
|
3159
|
+
// transform ArrayBuffer to Uint8Array
|
|
3160
|
+
.pipe(map((data) => new Uint8Array(data)), catchError(err => {
|
|
3161
|
+
this.onError();
|
|
3162
|
+
return throwError(() => err);
|
|
3163
|
+
}));
|
|
3164
|
+
}
|
|
3165
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerComponent, deps: [{ token: i1.AlertController }, { token: i2$2.HttpClient }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3166
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: EuimPdfViewerComponent, selector: "euim-pdf-viewer", inputs: { url: "url", page: "page" }, viewQueries: [{ propertyName: "pinch", first: true, predicate: ["pinch"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "@if (loading || errorMessage) {\n<div>\n @if (loading) {\n <euim-spinner>\n <div euimSpinnerMessage>Loading PDF...</div>\n </euim-spinner>\n }\n @if (errorMessage) {\n <div>{{errorMessage}}</div>\n }\n</div>\n}\n\n<pinch-zoom [limit-zoom]=\"4\" [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n <div style=\"display: block;width: 100%; height: 500px\">\n <pdf-viewer [src]=\"data\"\n [original-size]=\"false\"\n [zoom-scale]=\"'page-height'\"\n (after-load-complete)=\"onLoaded($event)\"\n (error)=\"onError()\"\n [(page)]=\"page\"\n [stick-to-page]=\"false\"\n [show-all]=\"false\"\n [render-text]=\"true\"\n style=\"width: 100%; height: 100%\">\n </pdf-viewer>\n </div>\n</pinch-zoom>\n\n<ion-footer>\n <ion-toolbar color=\"primary\" class=\"euim-pdf-viewer__footer\">\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"onDownload()\" [disabled]=\"!pdf || !data\">\n <ion-icon name=\"download-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-buttons class=\"euim-pdf-viewer__footer-zoom-container\">\n <ion-button (click)=\"onZoomOut()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n <ion-icon name=\"remove-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n <ion-button (click)=\"onResetZoom()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n {{'euim.pdf-viewer.reset.zoom' | translate }}\n </ion-button>\n <ion-button (click)=\"onZoomIn()\" [disabled]=\"zoom === 4 || !pdf || !data\">\n <ion-icon name=\"add-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n\n\n <ion-button (click)=\"prevPage()\" [disabled]=\"page === 1 || !pdf || !data\">\n {{'euim.stepper.previous' | translate }}\n </ion-button>\n {{page}}\n <ion-button (click)=\"nextPage()\" [disabled]=\"page === pdfNumPages || !pdf || !data\">\n {{'euim.stepper.next' | translate }}\n </ion-button>\n\n </ion-buttons>\n </ion-toolbar>\n</ion-footer>\n", styles: [".euim-pdf-viewer__footer-zoom-container{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}\n"], dependencies: [{ kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i1.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i1.IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i1.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i1.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: i3.PdfViewerComponent, selector: "pdf-viewer", inputs: ["src", "c-maps-url", "page", "render-text", "render-text-mode", "original-size", "show-all", "stick-to-page", "zoom", "zoom-scale", "rotation", "external-link-target", "autoresize", "fit-to-page", "show-borders"], outputs: ["after-load-complete", "page-rendered", "pages-initialized", "text-layer-rendered", "error", "on-progress", "pageChange"] }, { kind: "component", type: i4.PinchZoomComponent, selector: "pinch-zoom, [pinch-zoom]", inputs: ["properties", "transition-duration", "transitionDuration", "double-tap", "doubleTap", "double-tap-scale", "doubleTapScale", "auto-zoom-out", "autoZoomOut", "limit-zoom", "limitZoom", "disabled", "disablePan", "overflow", "zoomControlScale", "disableZoomControl", "backgroundColor", "limitPan", "minPanScale", "minScale", "listeners", "wheel", "autoHeight", "stepZoomFactor", "wheelZoomFactor", "draggableImage"], outputs: ["onZoomChange"], exportAs: ["pinchZoom"] }, { kind: "component", type: EuimSpinnerComponent, selector: "euim-spinner" }, { kind: "component", type: EuimSpinnerMessageComponent, selector: "[euimSpinnerMessage]" }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
3126
3167
|
}
|
|
3127
3168
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerComponent, decorators: [{
|
|
3128
3169
|
type: Component,
|
|
3129
|
-
args: [{ selector: 'euim-pdf-viewer', encapsulation: ViewEncapsulation.None, template: "@if (loading || errorMessage) {\n<div>\n @if (loading) {\n <euim-spinner>\n <div euimSpinnerMessage>Loading PDF...</div>\n </euim-spinner>\n }\n @if (errorMessage) {\n <div>{{errorMessage}}</div>\n }\n</div>\n}\n\n<pinch-zoom [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n <div style=\"display: block;width: 100%; height: 500px\">\n <pdf-viewer [src]=\"
|
|
3130
|
-
}], ctorParameters: () => [{ type: i1.AlertController }], propDecorators: { url: [{
|
|
3170
|
+
args: [{ selector: 'euim-pdf-viewer', encapsulation: ViewEncapsulation.None, template: "@if (loading || errorMessage) {\n<div>\n @if (loading) {\n <euim-spinner>\n <div euimSpinnerMessage>Loading PDF...</div>\n </euim-spinner>\n }\n @if (errorMessage) {\n <div>{{errorMessage}}</div>\n }\n</div>\n}\n\n<pinch-zoom [limit-zoom]=\"4\" [transition-duration]=\"50\" [zoomControlScale]=\"0.5\" (onZoomChange)=\"zoomChange($event)\" [wheelZoomFactor]=\"0.5\" [stepZoomFactor]=\"0.5\" #pinch>\n <div style=\"display: block;width: 100%; height: 500px\">\n <pdf-viewer [src]=\"data\"\n [original-size]=\"false\"\n [zoom-scale]=\"'page-height'\"\n (after-load-complete)=\"onLoaded($event)\"\n (error)=\"onError()\"\n [(page)]=\"page\"\n [stick-to-page]=\"false\"\n [show-all]=\"false\"\n [render-text]=\"true\"\n style=\"width: 100%; height: 100%\">\n </pdf-viewer>\n </div>\n</pinch-zoom>\n\n<ion-footer>\n <ion-toolbar color=\"primary\" class=\"euim-pdf-viewer__footer\">\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"onDownload()\" [disabled]=\"!pdf || !data\">\n <ion-icon name=\"download-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-buttons class=\"euim-pdf-viewer__footer-zoom-container\">\n <ion-button (click)=\"onZoomOut()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n <ion-icon name=\"remove-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n <ion-button (click)=\"onResetZoom()\" [disabled]=\"zoom === 1 || !pdf || !data\">\n {{'euim.pdf-viewer.reset.zoom' | translate }}\n </ion-button>\n <ion-button (click)=\"onZoomIn()\" [disabled]=\"zoom === 4 || !pdf || !data\">\n <ion-icon name=\"add-circle-outline\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n\n\n <ion-button (click)=\"prevPage()\" [disabled]=\"page === 1 || !pdf || !data\">\n {{'euim.stepper.previous' | translate }}\n </ion-button>\n {{page}}\n <ion-button (click)=\"nextPage()\" [disabled]=\"page === pdfNumPages || !pdf || !data\">\n {{'euim.stepper.next' | translate }}\n </ion-button>\n\n </ion-buttons>\n </ion-toolbar>\n</ion-footer>\n", styles: [".euim-pdf-viewer__footer-zoom-container{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}\n"] }]
|
|
3171
|
+
}], ctorParameters: () => [{ type: i1.AlertController }, { type: i2$2.HttpClient }], propDecorators: { url: [{
|
|
3131
3172
|
type: Input
|
|
3132
3173
|
}], page: [{
|
|
3133
3174
|
type: Input
|
|
@@ -3146,13 +3187,15 @@ class EuimPdfViewerModule {
|
|
|
3146
3187
|
PdfViewerModule,
|
|
3147
3188
|
PinchZoomModule,
|
|
3148
3189
|
EuimSpinnerComponentModule,
|
|
3149
|
-
TranslateModule
|
|
3190
|
+
TranslateModule,
|
|
3191
|
+
HttpClientModule], exports: [EuimPdfViewerComponent] }); }
|
|
3150
3192
|
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerModule, imports: [CommonModule,
|
|
3151
3193
|
IonicModule,
|
|
3152
3194
|
PdfViewerModule,
|
|
3153
3195
|
PinchZoomModule,
|
|
3154
3196
|
EuimSpinnerComponentModule,
|
|
3155
|
-
TranslateModule
|
|
3197
|
+
TranslateModule,
|
|
3198
|
+
HttpClientModule] }); }
|
|
3156
3199
|
}
|
|
3157
3200
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimPdfViewerModule, decorators: [{
|
|
3158
3201
|
type: NgModule,
|
|
@@ -3164,6 +3207,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
3164
3207
|
PinchZoomModule,
|
|
3165
3208
|
EuimSpinnerComponentModule,
|
|
3166
3209
|
TranslateModule,
|
|
3210
|
+
HttpClientModule,
|
|
3167
3211
|
],
|
|
3168
3212
|
exports: [
|
|
3169
3213
|
...COMPONENTS$1,
|