@eui/mobile-core 17.2.0-snapshot-1716535851440 → 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/EuimChipSelectorComponent.html +1 -1
- package/docs/components/EuimHelpSupportComponent.html +326 -8
- package/docs/components/EuimPdfViewerComponent.html +22 -2
- package/docs/dependencies.html +5 -5
- package/docs/index.html +1 -1
- package/docs/interfaces/Contact.html +90 -0
- package/docs/interfaces/HelpAndSupportItem.html +311 -0
- package/docs/interfaces/Item.html +671 -0
- package/docs/interfaces/Material.html +90 -0
- package/docs/js/menu-wc.js +12 -6
- package/docs/js/menu-wc_es5.js +11 -11
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/euim-about/euim-about.module.mjs +7 -3
- package/esm2022/lib/components/euim-about/euim-help-support/euim-help-support.component.mjs +66 -23
- 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 +134 -46
- package/fesm2022/eui-mobile-core.mjs.map +1 -1
- package/lib/components/euim-about/euim-about.module.d.ts +2 -1
- package/lib/components/euim-about/euim-about.module.d.ts.map +1 -1
- package/lib/components/euim-about/euim-help-support/euim-help-support.component.d.ts +39 -3
- package/lib/components/euim-about/euim-help-support/euim-help-support.component.d.ts.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
|
@@ -11,6 +11,7 @@ import { EuimChangelogComponent } from './euim-changelog/euim-changelog.componen
|
|
|
11
11
|
import { EuimHelpSupportComponent } from './euim-help-support/euim-help-support.component';
|
|
12
12
|
import { EuimOpenSourceLicencesComponent } from './euim-opensource-licences/euim-opensource-licences.component';
|
|
13
13
|
import { EuimAboutContentLoadingComponent } from './euim-about-content-loading/euim-about-content-loading.component';
|
|
14
|
+
import { RouterModule } from '@angular/router';
|
|
14
15
|
import { EuimLabelModule } from '../atoms/euim-label';
|
|
15
16
|
import { PinchZoomModule } from '@mapaxe/ngx-pinch-zoom';
|
|
16
17
|
import { TranslateModule } from '@ngx-translate/core';
|
|
@@ -37,7 +38,8 @@ export class EuimAboutModule {
|
|
|
37
38
|
EuimAvatarIconModule,
|
|
38
39
|
EuimAlertMessageModule,
|
|
39
40
|
PinchZoomModule,
|
|
40
|
-
TranslateModule
|
|
41
|
+
TranslateModule,
|
|
42
|
+
RouterModule], exports: [EuimAboutComponent,
|
|
41
43
|
EuimChangelogComponent,
|
|
42
44
|
EuimOpenSourceLicencesComponent,
|
|
43
45
|
EuimHelpSupportComponent,
|
|
@@ -51,7 +53,8 @@ export class EuimAboutModule {
|
|
|
51
53
|
EuimAvatarIconModule,
|
|
52
54
|
EuimAlertMessageModule,
|
|
53
55
|
PinchZoomModule,
|
|
54
|
-
TranslateModule
|
|
56
|
+
TranslateModule,
|
|
57
|
+
RouterModule] }); }
|
|
55
58
|
}
|
|
56
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimAboutModule, decorators: [{
|
|
57
60
|
type: NgModule,
|
|
@@ -67,6 +70,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
67
70
|
EuimAlertMessageModule,
|
|
68
71
|
PinchZoomModule,
|
|
69
72
|
TranslateModule,
|
|
73
|
+
RouterModule,
|
|
70
74
|
],
|
|
71
75
|
exports: [
|
|
72
76
|
...COMPONENTS,
|
|
@@ -76,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
76
80
|
],
|
|
77
81
|
}]
|
|
78
82
|
}] });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1hYm91dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZXVpbS1hYm91dC9ldWltLWFib3V0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzNELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBQ2hILE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLG1FQUFtRSxDQUFDO0FBQ3JILE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFFdEQsTUFBTSxVQUFVLEdBQUc7SUFDZixrQkFBa0I7SUFDbEIsc0JBQXNCO0lBQ3RCLCtCQUErQjtJQUMvQix3QkFBd0I7SUFDeEIsZ0NBQWdDO0NBQ25DLENBQUM7QUF3QkYsTUFBTSxPQUFPLGVBQWU7aUlBQWYsZUFBZTtrSUFBZixlQUFlLGlCQTdCeEIsa0JBQWtCO1lBQ2xCLHNCQUFzQjtZQUN0QiwrQkFBK0I7WUFDL0Isd0JBQXdCO1lBQ3hCLGdDQUFnQyxhQU01QixZQUFZO1lBQ1osV0FBVztZQUNYLFlBQVk7WUFDWiwwQkFBMEI7WUFDMUIsdUJBQXVCO1lBQ3ZCLGVBQWU7WUFDZixvQkFBb0I7WUFDcEIsc0JBQXNCO1lBQ3RCLGVBQWU7WUFDZixlQUFlO1lBQ2YsWUFBWSxhQXBCaEIsa0JBQWtCO1lBQ2xCLHNCQUFzQjtZQUN0QiwrQkFBK0I7WUFDL0Isd0JBQXdCO1lBQ3hCLGdDQUFnQztrSUF5QnZCLGVBQWUsWUFuQnBCLFlBQVk7WUFDWixXQUFXO1lBQ1gsWUFBWTtZQUNaLDBCQUEwQjtZQUMxQix1QkFBdUI7WUFDdkIsZUFBZTtZQUNmLG9CQUFvQjtZQUNwQixzQkFBc0I7WUFDdEIsZUFBZTtZQUNmLGVBQWU7WUFDZixZQUFZOzsyRkFTUCxlQUFlO2tCQXRCM0IsUUFBUTttQkFBQztvQkFFTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixXQUFXO3dCQUNYLFlBQVk7d0JBQ1osMEJBQTBCO3dCQUMxQix1QkFBdUI7d0JBQ3ZCLGVBQWU7d0JBQ2Ysb0JBQW9CO3dCQUNwQixzQkFBc0I7d0JBQ3RCLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixZQUFZO3FCQUNmO29CQUNELE9BQU8sRUFBRTt3QkFDTCxHQUFHLFVBQVU7cUJBQ2hCO29CQUNELFlBQVksRUFBRTt3QkFDVixHQUFHLFVBQVU7cUJBQ2hCO2lCQUNIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcbmltcG9ydCB7IFFSQ29kZU1vZHVsZSB9IGZyb20gJ2FuZ3VsYXJ4LXFyY29kZSc7XG5pbXBvcnQgeyBFdWltVG9vbGJhckNvbXBvbmVudE1vZHVsZSB9IGZyb20gJy4uL2xheW91dC9ldWltLXRvb2xiYXInO1xuaW1wb3J0IHsgRXVpbUhlYWRlckRldGFpbHNNb2R1bGUgfSBmcm9tICcuLi9sYXlvdXQvZXVpbS1oZWFkZXItZGV0YWlscyc7XG5pbXBvcnQgeyBFdWltQXZhdGFySWNvbk1vZHVsZSB9IGZyb20gJy4uL2V1aW0tYXZhdGFyLWljb24nO1xuaW1wb3J0IHsgRXVpbUFsZXJ0TWVzc2FnZU1vZHVsZSB9IGZyb20gJy4uL2V1aW0tYWxlcnQtbWVzc2FnZSc7XG5pbXBvcnQgeyBFdWltQWJvdXRDb21wb25lbnQgfSBmcm9tICcuL2V1aW0tYWJvdXQuY29tcG9uZW50JztcbmltcG9ydCB7IEV1aW1DaGFuZ2Vsb2dDb21wb25lbnQgfSBmcm9tICcuL2V1aW0tY2hhbmdlbG9nL2V1aW0tY2hhbmdlbG9nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFdWltSGVscFN1cHBvcnRDb21wb25lbnQgfSBmcm9tICcuL2V1aW0taGVscC1zdXBwb3J0L2V1aW0taGVscC1zdXBwb3J0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFdWltT3BlblNvdXJjZUxpY2VuY2VzQ29tcG9uZW50IH0gZnJvbSAnLi9ldWltLW9wZW5zb3VyY2UtbGljZW5jZXMvZXVpbS1vcGVuc291cmNlLWxpY2VuY2VzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFdWltQWJvdXRDb250ZW50TG9hZGluZ0NvbXBvbmVudCB9IGZyb20gJy4vZXVpbS1hYm91dC1jb250ZW50LWxvYWRpbmcvZXVpbS1hYm91dC1jb250ZW50LWxvYWRpbmcuY29tcG9uZW50JztcbmltcG9ydCB7IFJvdXRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbmltcG9ydCB7IEV1aW1MYWJlbE1vZHVsZSB9IGZyb20gJy4uL2F0b21zL2V1aW0tbGFiZWwnO1xuaW1wb3J0IHsgUGluY2hab29tTW9kdWxlIH0gZnJvbSAnQG1hcGF4ZS9uZ3gtcGluY2gtem9vbSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcblxuY29uc3QgQ09NUE9ORU5UUyA9IFtcbiAgICBFdWltQWJvdXRDb21wb25lbnQsXG4gICAgRXVpbUNoYW5nZWxvZ0NvbXBvbmVudCxcbiAgICBFdWltT3BlblNvdXJjZUxpY2VuY2VzQ29tcG9uZW50LFxuICAgIEV1aW1IZWxwU3VwcG9ydENvbXBvbmVudCxcbiAgICBFdWltQWJvdXRDb250ZW50TG9hZGluZ0NvbXBvbmVudCxcbl07XG5cbkBOZ01vZHVsZSh7XG5cbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgSW9uaWNNb2R1bGUsXG4gICAgICAgIFFSQ29kZU1vZHVsZSxcbiAgICAgICAgRXVpbVRvb2xiYXJDb21wb25lbnRNb2R1bGUsXG4gICAgICAgIEV1aW1IZWFkZXJEZXRhaWxzTW9kdWxlLFxuICAgICAgICBFdWltTGFiZWxNb2R1bGUsXG4gICAgICAgIEV1aW1BdmF0YXJJY29uTW9kdWxlLFxuICAgICAgICBFdWltQWxlcnRNZXNzYWdlTW9kdWxlLFxuICAgICAgICBQaW5jaFpvb21Nb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICAgICAgUm91dGVyTW9kdWxlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICAuLi5DT01QT05FTlRTLFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIC4uLkNPTVBPTkVOVFMsXG4gICAgXSxcbiB9KVxuZXhwb3J0IGNsYXNzIEV1aW1BYm91dE1vZHVsZSB7XG59XG5cbiJdfQ==
|
|
@@ -1,49 +1,92 @@
|
|
|
1
1
|
import { Component, Input, HostBinding, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@
|
|
4
|
-
import * as i2 from "
|
|
5
|
-
import * as i3 from "
|
|
6
|
-
import * as i4 from "../../
|
|
7
|
-
import * as i5 from "../../euim-
|
|
8
|
-
import * as i6 from "../../euim-
|
|
9
|
-
import * as i7 from "
|
|
3
|
+
import * as i1 from "@angular/router";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "@ionic/angular";
|
|
6
|
+
import * as i4 from "../../layout/euim-toolbar/euim-toolbar.component";
|
|
7
|
+
import * as i5 from "../../layout/euim-toolbar/euim-toolbar-title/euim-toolbar-title.component";
|
|
8
|
+
import * as i6 from "../../atoms/euim-label/euim-label.component";
|
|
9
|
+
import * as i7 from "../../euim-avatar-icon/euim-avatar-icon.component";
|
|
10
|
+
import * as i8 from "../../euim-alert-message/euim-alert-messsage.component";
|
|
11
|
+
import * as i9 from "@ngx-translate/core";
|
|
10
12
|
export class EuimHelpSupportComponent {
|
|
11
|
-
constructor() {
|
|
13
|
+
constructor(router) {
|
|
14
|
+
this.router = router;
|
|
15
|
+
/**
|
|
16
|
+
* @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead
|
|
17
|
+
*/
|
|
12
18
|
this.helpContacts = { contacts: [] };
|
|
19
|
+
/**
|
|
20
|
+
* @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead
|
|
21
|
+
*/
|
|
13
22
|
this.supportMaterials = { materials: [] };
|
|
23
|
+
/**
|
|
24
|
+
* @deprecated will be removed in eUI Mobile v18
|
|
25
|
+
*/
|
|
14
26
|
this.alertInfos = {};
|
|
27
|
+
this.helpAndSupportItems = [];
|
|
15
28
|
this.className = 'euim-help-support';
|
|
16
29
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
return 'mailto:' + linkTitle;
|
|
23
|
-
default:
|
|
24
|
-
return linkTitle;
|
|
30
|
+
onItemClick(item, linkType, linkTitle) {
|
|
31
|
+
if (item?.routerLink) {
|
|
32
|
+
this.router.navigate([item.routerLink], {
|
|
33
|
+
fragment: item.fragment && !item.link ? item.fragment : null,
|
|
34
|
+
});
|
|
25
35
|
}
|
|
36
|
+
else {
|
|
37
|
+
window.open(this.getLink(item, linkType, linkTitle), this.setTargetAttribute(item, linkType));
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
isLinkSharp(item) {
|
|
41
|
+
return item?.endIcon === 'link-sharp';
|
|
42
|
+
}
|
|
43
|
+
getLinkClass(item) {
|
|
44
|
+
return this.isLinkSharp(item) ? 'euim-help-support__contact-link euim-help-support__contact-link--no-underlined' : 'euim-help-support__contact-link';
|
|
26
45
|
}
|
|
27
|
-
|
|
28
|
-
if (
|
|
46
|
+
getLink(item, linkType, linkTitle) {
|
|
47
|
+
if (linkTitle && linkType === 'mail') {
|
|
48
|
+
return 'mailto:' + linkTitle;
|
|
49
|
+
}
|
|
50
|
+
if (linkTitle && linkType === 'call') {
|
|
51
|
+
return 'tel:' + linkTitle;
|
|
52
|
+
}
|
|
53
|
+
if (linkTitle) {
|
|
54
|
+
return linkTitle;
|
|
55
|
+
}
|
|
56
|
+
if (item) {
|
|
57
|
+
if (item.phone) {
|
|
58
|
+
return 'tel:' + item.phone;
|
|
59
|
+
}
|
|
60
|
+
if (item.mail) {
|
|
61
|
+
return 'mailto:' + item.mail;
|
|
62
|
+
}
|
|
63
|
+
if (item.link) {
|
|
64
|
+
return item.link;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
setTargetAttribute(item, linkType) {
|
|
69
|
+
if (item?.phone || item?.mail || linkType === 'call' || linkType === 'mail') {
|
|
29
70
|
return '_self';
|
|
30
71
|
}
|
|
31
72
|
return '_blank';
|
|
32
73
|
}
|
|
33
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimHelpSupportComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: EuimHelpSupportComponent, selector: "euim-help-support", inputs: { helpContacts: "helpContacts", supportMaterials: "supportMaterials", alertInfos: "alertInfos" }, host: { properties: { "class": "this.className" } }, ngImport: i0, template: "<ion-header>\n <ion-toolbar color=\"primary\">\n <euim-toolbar>\n <euim-toolbar-title>{{'euim.about.help.support' | translate }}</euim-toolbar-title>\n </euim-toolbar>\n </ion-toolbar>\n
|
|
74
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimHelpSupportComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
75
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: EuimHelpSupportComponent, selector: "euim-help-support", inputs: { helpContacts: "helpContacts", supportMaterials: "supportMaterials", alertInfos: "alertInfos", helpAndSupportItems: "helpAndSupportItems" }, host: { properties: { "class": "this.className" } }, ngImport: i0, template: "<ion-header>\n <ion-toolbar color=\"primary\">\n <euim-toolbar>\n <euim-toolbar-title>{{'euim.about.help.support' | translate }}</euim-toolbar-title>\n </euim-toolbar>\n </ion-toolbar>\n @if (alertInfos.title) {\n <euim-alert-message color=\"primary\">\n <ion-icon name=\"person-circle\" slotStart></ion-icon>\n {{ alertInfos.title }}\n\n @if (alertInfos.btnLink) {\n <ion-button [href]=\"alertInfos.btnLink\" slotEnd size=\"small\" fill=\"outline\">\n <strong>{{ alertInfos.btnTitle }}</strong>\n </ion-button>\n }\n </euim-alert-message>\n }\n <ng-content select=\"[headerSection]\"></ng-content>\n</ion-header>\n\n@if (helpAndSupportItems.length > 0 || helpContacts.contacts.length > 0 || supportMaterials.materials.length > 0) {\n <ion-list>\n @for (helpSupportItem of helpAndSupportItems; track $index;) {\n @if (helpSupportItem.sectionTitle) {\n <ion-item-divider>\n <ion-label>{{ helpSupportItem.sectionTitle }}</ion-label>\n </ion-item-divider>\n }\n\n @for (item of helpSupportItem.items; track item;) {\n\n <ion-item [lines]=\"item.hasBottomLine ? 'insert' : 'none'\" (click)=\"onItemClick(item, undefined, undefined)\">\n @if (item.startIcon) {\n <euim-avatar-icon fill=\"solid\" slot=\"start\">\n <ion-icon [name]=\"item.startIcon\"></ion-icon>\n </euim-avatar-icon>\n }\n @if (item.title || item.subtitle) {\n <ion-label>\n @if (item.title) {\n <a [ngClass]=\"getLinkClass(item)\">\n @if (!isLinkSharp(item)) {\n <div class=\"euim-help-support__title\">{{ item.title }}</div>\n }\n @if (isLinkSharp(item)) {\n <div euimLabel euimLabelTitle>{{ item.title }}</div>\n }\n </a>\n }\n @if (item.subtitle) {\n <div euimLabel euimLabelSubTitle>\n {{ item.subtitle }}\n </div>\n }\n </ion-label>\n }\n @if (item.endIcon) {\n <ion-buttons>\n <ion-button fill=\"clear\">\n <ion-icon [name]=\"item.endIcon\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n </ion-item>\n }\n }\n @if (helpContacts.contacts.length > 0) {\n @if (helpContacts.sectionTitle) {\n <ion-item-divider>\n <ion-label>{{ helpContacts.sectionTitle }}</ion-label>\n </ion-item-divider>\n }\n @for (contact of helpContacts.contacts; track contact; let isLast = $last) {\n <ion-item [lines]=\"isLast ? 'none' : ''\" (click)=\"onItemClick(undefined, contact.linkType, contact.linkTitle)\">\n @if (contact.icon) {\n <euim-avatar-icon fill=\"solid\" slot=\"start\">\n <ion-icon [name]=\"contact.icon\"></ion-icon>\n </euim-avatar-icon>\n }\n @if (contact.linkTitle || contact.subtitle) {\n <ion-label>\n @if (contact.linkTitle) {\n <a class=\"euim-help-support__contact-link\">\n <div class=\"euim-help-support__title\">{{contact.linkTitle}}</div>\n </a>\n }\n @if (contact.subtitle) {\n <div euimLabel euimLabelSubTitle>{{contact.subtitle}}</div>\n }\n </ion-label>\n }\n </ion-item>\n }\n }\n\n @if (supportMaterials.materials.length > 0) {\n @if (supportMaterials.sectionTitle) {\n <ion-item-divider>\n <ion-label>{{ supportMaterials.sectionTitle }}</ion-label>\n </ion-item-divider>\n }\n @for (material of supportMaterials.materials; track material) {\n <ion-item lines=\"none\" (click)=\"onItemClick(material, undefined, undefined)\">\n @if (material.icon) {\n <euim-avatar-icon fill=\"solid\" slot=\"start\">\n <ion-icon [name]=\"material.icon\"></ion-icon>\n </euim-avatar-icon>\n }\n <ion-label>\n @if (material.title) {\n <div euimLabel euimLabelTitle>{{material.title}}</div>\n }\n @if (material.subtitle) {\n <div euimLabel euimLabelSubTitle>{{material.subtitle}}</div>\n }\n </ion-label>\n <ion-buttons>\n <ion-button fill=\"clear\" >\n <ion-icon name=\"link-sharp\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n </ion-item>\n }\n }\n </ion-list>\n}\n<ng-content></ng-content>\n\n\n", styles: [".euim-help-support__title{font:normal normal 400 1rem/1.25rem var(--eui-base-font-family)}.euim-help-support__contact-link--no-underlined{text-decoration:none}.euim-help-support ion-item{position:relative;cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.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: i3.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i3.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i3.IonItemDivider, selector: "ion-item-divider", inputs: ["color", "mode", "sticky"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: i3.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: i4.EuimToolbarComponent, selector: "euim-toolbar", inputs: ["hasBackButton", "backButtonDefaultHref", "hasSidebarTrigger", "hasLanguageSelector"], outputs: ["backButtonClick"] }, { kind: "component", type: i5.EuimToolbarTitleComponent, selector: "euim-toolbar-title" }, { kind: "component", type: i6.EuimLabelComponent, selector: "div[euimLabel], p[euimLabel], span[euimLabel], euim-label", inputs: ["euimLabelTruncateWithLines", "euimLabelTitle", "euimLabelSubTitle", "euimLabelMeta", "euimLabelTruncate"] }, { kind: "component", type: i7.EuimAvatarIconComponent, selector: "euim-avatar-icon", inputs: ["color", "size", "fill", "variant", "borderColor"] }, { kind: "component", type: i8.EuimAlertMessageComponent, selector: "euim-alert-message", inputs: ["euimLabelTruncate", "hasIcon", "isCloseable"], outputs: ["euimClose"] }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
35
76
|
}
|
|
36
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimHelpSupportComponent, decorators: [{
|
|
37
78
|
type: Component,
|
|
38
|
-
args: [{ selector: 'euim-help-support', encapsulation: ViewEncapsulation.None, template: "<ion-header>\n <ion-toolbar color=\"primary\">\n <euim-toolbar>\n <euim-toolbar-title>{{'euim.about.help.support' | translate }}</euim-toolbar-title>\n </euim-toolbar>\n </ion-toolbar>\n
|
|
39
|
-
}], propDecorators: { helpContacts: [{
|
|
79
|
+
args: [{ selector: 'euim-help-support', encapsulation: ViewEncapsulation.None, template: "<ion-header>\n <ion-toolbar color=\"primary\">\n <euim-toolbar>\n <euim-toolbar-title>{{'euim.about.help.support' | translate }}</euim-toolbar-title>\n </euim-toolbar>\n </ion-toolbar>\n @if (alertInfos.title) {\n <euim-alert-message color=\"primary\">\n <ion-icon name=\"person-circle\" slotStart></ion-icon>\n {{ alertInfos.title }}\n\n @if (alertInfos.btnLink) {\n <ion-button [href]=\"alertInfos.btnLink\" slotEnd size=\"small\" fill=\"outline\">\n <strong>{{ alertInfos.btnTitle }}</strong>\n </ion-button>\n }\n </euim-alert-message>\n }\n <ng-content select=\"[headerSection]\"></ng-content>\n</ion-header>\n\n@if (helpAndSupportItems.length > 0 || helpContacts.contacts.length > 0 || supportMaterials.materials.length > 0) {\n <ion-list>\n @for (helpSupportItem of helpAndSupportItems; track $index;) {\n @if (helpSupportItem.sectionTitle) {\n <ion-item-divider>\n <ion-label>{{ helpSupportItem.sectionTitle }}</ion-label>\n </ion-item-divider>\n }\n\n @for (item of helpSupportItem.items; track item;) {\n\n <ion-item [lines]=\"item.hasBottomLine ? 'insert' : 'none'\" (click)=\"onItemClick(item, undefined, undefined)\">\n @if (item.startIcon) {\n <euim-avatar-icon fill=\"solid\" slot=\"start\">\n <ion-icon [name]=\"item.startIcon\"></ion-icon>\n </euim-avatar-icon>\n }\n @if (item.title || item.subtitle) {\n <ion-label>\n @if (item.title) {\n <a [ngClass]=\"getLinkClass(item)\">\n @if (!isLinkSharp(item)) {\n <div class=\"euim-help-support__title\">{{ item.title }}</div>\n }\n @if (isLinkSharp(item)) {\n <div euimLabel euimLabelTitle>{{ item.title }}</div>\n }\n </a>\n }\n @if (item.subtitle) {\n <div euimLabel euimLabelSubTitle>\n {{ item.subtitle }}\n </div>\n }\n </ion-label>\n }\n @if (item.endIcon) {\n <ion-buttons>\n <ion-button fill=\"clear\">\n <ion-icon [name]=\"item.endIcon\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n </ion-item>\n }\n }\n @if (helpContacts.contacts.length > 0) {\n @if (helpContacts.sectionTitle) {\n <ion-item-divider>\n <ion-label>{{ helpContacts.sectionTitle }}</ion-label>\n </ion-item-divider>\n }\n @for (contact of helpContacts.contacts; track contact; let isLast = $last) {\n <ion-item [lines]=\"isLast ? 'none' : ''\" (click)=\"onItemClick(undefined, contact.linkType, contact.linkTitle)\">\n @if (contact.icon) {\n <euim-avatar-icon fill=\"solid\" slot=\"start\">\n <ion-icon [name]=\"contact.icon\"></ion-icon>\n </euim-avatar-icon>\n }\n @if (contact.linkTitle || contact.subtitle) {\n <ion-label>\n @if (contact.linkTitle) {\n <a class=\"euim-help-support__contact-link\">\n <div class=\"euim-help-support__title\">{{contact.linkTitle}}</div>\n </a>\n }\n @if (contact.subtitle) {\n <div euimLabel euimLabelSubTitle>{{contact.subtitle}}</div>\n }\n </ion-label>\n }\n </ion-item>\n }\n }\n\n @if (supportMaterials.materials.length > 0) {\n @if (supportMaterials.sectionTitle) {\n <ion-item-divider>\n <ion-label>{{ supportMaterials.sectionTitle }}</ion-label>\n </ion-item-divider>\n }\n @for (material of supportMaterials.materials; track material) {\n <ion-item lines=\"none\" (click)=\"onItemClick(material, undefined, undefined)\">\n @if (material.icon) {\n <euim-avatar-icon fill=\"solid\" slot=\"start\">\n <ion-icon [name]=\"material.icon\"></ion-icon>\n </euim-avatar-icon>\n }\n <ion-label>\n @if (material.title) {\n <div euimLabel euimLabelTitle>{{material.title}}</div>\n }\n @if (material.subtitle) {\n <div euimLabel euimLabelSubTitle>{{material.subtitle}}</div>\n }\n </ion-label>\n <ion-buttons>\n <ion-button fill=\"clear\" >\n <ion-icon name=\"link-sharp\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n </ion-item>\n }\n }\n </ion-list>\n}\n<ng-content></ng-content>\n\n\n", styles: [".euim-help-support__title{font:normal normal 400 1rem/1.25rem var(--eui-base-font-family)}.euim-help-support__contact-link--no-underlined{text-decoration:none}.euim-help-support ion-item{position:relative;cursor:pointer}\n"] }]
|
|
80
|
+
}], ctorParameters: () => [{ type: i1.Router }], propDecorators: { helpContacts: [{
|
|
40
81
|
type: Input
|
|
41
82
|
}], supportMaterials: [{
|
|
42
83
|
type: Input
|
|
43
84
|
}], alertInfos: [{
|
|
44
85
|
type: Input
|
|
86
|
+
}], helpAndSupportItems: [{
|
|
87
|
+
type: Input
|
|
45
88
|
}], className: [{
|
|
46
89
|
type: HostBinding,
|
|
47
90
|
args: ['class']
|
|
48
91
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1oZWxwLXN1cHBvcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tYWJvdXQvZXVpbS1oZWxwLXN1cHBvcnQvZXVpbS1oZWxwLXN1cHBvcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tYWJvdXQvZXVpbS1oZWxwLXN1cHBvcnQvZXVpbS1oZWxwLXN1cHBvcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7QUFRakYsTUFBTSxPQUFPLHdCQUF3QjtJQU5yQztRQU9XLGlCQUFZLEdBQWlCLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxDQUFDO1FBQzlDLHFCQUFnQixHQUFxQixFQUFFLFNBQVMsRUFBRSxFQUFFLEVBQUUsQ0FBQztRQUN2RCxlQUFVLEdBQWUsRUFBRSxDQUFBO1FBRWQsY0FBUyxHQUFHLG1CQUFtQixDQUFDO0tBcUJ2RDtJQW5CQyxPQUFPLENBQUMsUUFBUSxFQUFFLFNBQVM7UUFDekIsUUFBUSxRQUFRLEVBQUU7WUFDaEIsS0FBSyxNQUFNO2dCQUNULE9BQU8sTUFBTSxHQUFHLFNBQVMsQ0FBQztZQUM1QixLQUFLLE1BQU07Z0JBQ1QsT0FBTyxTQUFTLEdBQUcsU0FBUyxDQUFDO1lBQy9CO2dCQUNFLE9BQU8sU0FBUyxDQUFDO1NBQ3BCO0lBQ0gsQ0FBQztJQUVELGtCQUFrQixDQUFDLFFBQVE7UUFDekIsSUFBSSxRQUFRLEtBQUssTUFBTSxJQUFJLFFBQVEsS0FBSyxNQUFNLEVBQUU7WUFDOUMsT0FBTyxPQUFPLENBQUM7U0FDaEI7UUFFRCxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDO2lJQXhCVSx3QkFBd0I7cUhBQXhCLHdCQUF3Qix3TkNSckMseS9FQW9FQTs7MkZENURhLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDSSxtQkFBbUIsaUJBR2QsaUJBQWlCLENBQUMsSUFBSTs4QkFHOUIsWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFFZ0IsU0FBUztzQkFBOUIsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgSG9zdEJpbmRpbmcsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXVpbS1oZWxwLXN1cHBvcnQnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldWltLWhlbHAtc3VwcG9ydC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc3R5bGVzL19pbmRleC5zY3NzJ10sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbUhlbHBTdXBwb3J0Q29tcG9uZW50IHtcbiAgQElucHV0KCkgaGVscENvbnRhY3RzOiBIZWxwQ29udGFjdHMgPSB7IGNvbnRhY3RzOiBbXSB9O1xuICBASW5wdXQoKSBzdXBwb3J0TWF0ZXJpYWxzOiBTdXBwb3J0TWF0ZXJpYWxzID0geyBtYXRlcmlhbHM6IFtdIH07XG4gIEBJbnB1dCgpIGFsZXJ0SW5mb3M6IEFsZXJ0SW5mb3MgPSB7fVxuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKSBjbGFzc05hbWUgPSAnZXVpbS1oZWxwLXN1cHBvcnQnO1xuXG4gIGdldExpbmsobGlua1R5cGUsIGxpbmtUaXRsZSk6IHN0cmluZyB7XG4gICAgc3dpdGNoIChsaW5rVHlwZSkge1xuICAgICAgY2FzZSAnY2FsbCc6XG4gICAgICAgIHJldHVybiAndGVsOicgKyBsaW5rVGl0bGU7XG4gICAgICBjYXNlICdtYWlsJzpcbiAgICAgICAgcmV0dXJuICdtYWlsdG86JyArIGxpbmtUaXRsZTtcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiBsaW5rVGl0bGU7XG4gICAgfVxuICB9XG5cbiAgc2V0VGFyZ2V0QXR0cmlidXRlKGxpbmtUeXBlKTogc3RyaW5nIHtcbiAgICBpZiAobGlua1R5cGUgPT09ICdjYWxsJyB8fCBsaW5rVHlwZSA9PT0gJ21haWwnKSB7XG4gICAgICByZXR1cm4gJ19zZWxmJztcbiAgICB9XG5cbiAgICByZXR1cm4gJ19ibGFuayc7XG4gIH1cblxufVxuXG5pbnRlcmZhY2UgQWxlcnRJbmZvcyB7XG4gIGljb24/OiBzdHJpbmc7XG4gIHRpdGxlPzogc3RyaW5nO1xuICBidG5MaW5rPzogc3RyaW5nO1xuICBidG5UaXRsZT86IHN0cmluZztcbn1cblxuaW50ZXJmYWNlIENvbnRhY3Qge1xuICBsaW5rVGl0bGU6IHN0cmluZztcbiAgbGlua1R5cGU/OiBzdHJpbmc7XG4gIGxpbms/OiBzdHJpbmc7XG4gIHN1YnRpdGxlPzogc3RyaW5nO1xuICBpY29uPzogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgSGVscENvbnRhY3RzIHtcbiAgc2VjdGlvblRpdGxlPzogc3RyaW5nO1xuICBjb250YWN0czogQ29udGFjdFtdO1xufVxuXG5pbnRlcmZhY2UgTWF0ZXJpYWwge1xuICB0aXRsZTogc3RyaW5nO1xuICBzdWJ0aXRsZT86IHN0cmluZztcbiAgbGluaz86IHN0cmluZztcbiAgaWNvbj86IHN0cmluZztcbn1cblxuaW50ZXJmYWNlIFN1cHBvcnRNYXRlcmlhbHMge1xuICBzZWN0aW9uVGl0bGU/OiBzdHJpbmc7XG4gIG1hdGVyaWFsczogTWF0ZXJpYWxbXTtcbn1cbiIsIjxpb24taGVhZGVyPlxuICA8aW9uLXRvb2xiYXIgY29sb3I9XCJwcmltYXJ5XCI+XG4gICAgPGV1aW0tdG9vbGJhcj5cbiAgICAgIDxldWltLXRvb2xiYXItdGl0bGU+e3snZXVpbS5hYm91dC5oZWxwLnN1cHBvcnQnIHwgdHJhbnNsYXRlIH19PC9ldWltLXRvb2xiYXItdGl0bGU+XG4gICAgPC9ldWltLXRvb2xiYXI+XG4gIDwvaW9uLXRvb2xiYXI+XG4gIEBpZiAoYWxlcnRJbmZvcykge1xuICAgIDxldWltLWFsZXJ0LW1lc3NhZ2UgY29sb3I9XCJwcmltYXJ5XCI+XG4gICAgICA8aW9uLWljb24gbmFtZT1cInBlcnNvbi1jaXJjbGVcIiBzbG90U3RhcnQ+PC9pb24taWNvbj5cbiAgICAgIHt7IGFsZXJ0SW5mb3MudGl0bGUgfX1cblxuICAgICAgQGlmIChhbGVydEluZm9zLmJ0bkxpbmspIHtcbiAgICAgICAgPGlvbi1idXR0b24gW2hyZWZdPVwiYWxlcnRJbmZvcy5idG5MaW5rXCIgc2xvdEVuZCBzaXplPVwic21hbGxcIiBmaWxsPVwib3V0bGluZVwiPlxuICAgICAgICAgIDxzdHJvbmc+e3sgYWxlcnRJbmZvcy5idG5UaXRsZSB9fTwvc3Ryb25nPlxuICAgICAgICA8L2lvbi1idXR0b24+XG4gICAgICB9XG4gICAgPC9ldWltLWFsZXJ0LW1lc3NhZ2U+XG4gIH1cbjwvaW9uLWhlYWRlcj5cblxuQGlmIChoZWxwQ29udGFjdHMuY29udGFjdHMubGVuZ3RoID4gMCB8fCBzdXBwb3J0TWF0ZXJpYWxzLm1hdGVyaWFscy5sZW5ndGggPiAwKSB7XG4gIDxpb24tbGlzdD5cbiAgICBAaWYgKGhlbHBDb250YWN0cy5jb250YWN0cy5sZW5ndGggPiAwKSB7XG4gICAgICA8aW9uLWl0ZW0tZGl2aWRlcj5cbiAgICAgICAgPGlvbi1sYWJlbD57eyBoZWxwQ29udGFjdHMuc2VjdGlvblRpdGxlIH19PC9pb24tbGFiZWw+XG4gICAgICA8L2lvbi1pdGVtLWRpdmlkZXI+XG4gICAgICBAZm9yIChjb250YWN0IG9mIGhlbHBDb250YWN0cy5jb250YWN0czsgdHJhY2sgY29udGFjdDsgbGV0IGlzTGFzdCA9ICRsYXN0KSB7XG4gICAgICA8aW9uLWl0ZW0gW2xpbmVzXT1cImlzTGFzdCA/ICdub25lJyA6ICcnXCI+XG4gICAgICAgIDxldWltLWF2YXRhci1pY29uICBmaWxsPVwic29saWRcIiBzbG90PVwic3RhcnRcIj5cbiAgICAgICAgICA8aW9uLWljb24gW25hbWVdPVwiY29udGFjdC5pY29uXCI+PC9pb24taWNvbj5cbiAgICAgICAgPC9ldWltLWF2YXRhci1pY29uPlxuICAgICAgICA8aW9uLWxhYmVsPlxuICAgICAgICAgICAgPGEgY2xhc3M9XCJldWltLWhlbHAtc3VwcG9ydF9fY29udGFjdC1saW5rXCIgW3RhcmdldF09XCJzZXRUYXJnZXRBdHRyaWJ1dGUoY29udGFjdC5saW5rVHlwZSlcIiBbaHJlZl09XCJjb250YWN0LmxpbmsgPyBjb250YWN0LmxpbmsgOiBnZXRMaW5rKGNvbnRhY3QubGlua1R5cGUsIGNvbnRhY3QubGlua1RpdGxlKVwiPlxuICAgICAgICAgICAgICA8ZGl2IGV1aW1MYWJlbCBldWltTGFiZWxUaXRsZT57e2NvbnRhY3QubGlua1RpdGxlfX08L2Rpdj5cbiAgICAgICAgICAgIDwvYT5cblxuICAgICAgICAgICAgPGRpdiBldWltTGFiZWwgZXVpbUxhYmVsU3ViVGl0bGU+e3tjb250YWN0LnN1YnRpdGxlfX08L2Rpdj5cbiAgICAgICAgICA8L2lvbi1sYWJlbD5cbiAgICAgICAgPC9pb24taXRlbT5cbiAgICAgICAgfVxuICAgIH1cblxuICAgIEBpZiAoc3VwcG9ydE1hdGVyaWFscy5tYXRlcmlhbHMubGVuZ3RoID4gMCkge1xuICAgICAgPGlvbi1pdGVtLWRpdmlkZXI+XG4gICAgICAgIDxpb24tbGFiZWw+e3sgc3VwcG9ydE1hdGVyaWFscy5zZWN0aW9uVGl0bGUgfX08L2lvbi1sYWJlbD5cbiAgICAgIDwvaW9uLWl0ZW0tZGl2aWRlcj5cbiAgICAgIEBmb3IgKG1hdGVyaWFsIG9mIHN1cHBvcnRNYXRlcmlhbHMubWF0ZXJpYWxzOyB0cmFjayBtYXRlcmlhbCkge1xuICAgICAgICA8aW9uLWl0ZW0gbGluZXM9XCJub25lXCI+XG4gICAgICAgICAgPGV1aW0tYXZhdGFyLWljb24gIGZpbGw9XCJzb2xpZFwiIHNsb3Q9XCJzdGFydFwiPlxuICAgICAgICAgICAgPGlvbi1pY29uIFtuYW1lXT1cIm1hdGVyaWFsLmljb25cIj48L2lvbi1pY29uPlxuICAgICAgICAgIDwvZXVpbS1hdmF0YXItaWNvbj5cbiAgICAgICAgICA8aW9uLWxhYmVsPlxuICAgICAgICAgICAgPGRpdiBldWltTGFiZWwgZXVpbUxhYmVsVGl0bGU+e3ttYXRlcmlhbC50aXRsZX19PC9kaXY+XG4gICAgICAgICAgICA8ZGl2IGV1aW1MYWJlbCBldWltTGFiZWxTdWJUaXRsZT57e21hdGVyaWFsLnN1YnRpdGxlfX08L2Rpdj5cbiAgICAgICAgICA8L2lvbi1sYWJlbD5cbiAgICAgICAgICA8aW9uLWJ1dHRvbnM+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiB0YXJnZXQ9XCJfYmxhbmtcIiBbaHJlZl09XCJtYXRlcmlhbC5saW5rXCIgZmlsbD1cImNsZWFyXCIgPlxuICAgICAgICAgICAgICA8aW9uLWljb24gbmFtZT1cImxpbmstc2hhcnBcIiBzbG90PVwiaWNvbi1vbmx5XCI+PC9pb24taWNvbj5cbiAgICAgICAgICAgIDwvaW9uLWJ1dHRvbj5cbiAgICAgICAgICA8L2lvbi1idXR0b25zPlxuICAgICAgICA8L2lvbi1pdGVtPlxuICAgICAgfVxuICAgIH1cbiAgPC9pb24tbGlzdD5cbn1cbjxuZy1jb250ZW50PjwvbmctY29udGVudD5cblxuXG4iXX0=
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-help-support.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/euim-about/euim-help-support/euim-help-support.component.ts","../../../../../../src/lib/components/euim-about/euim-help-support/euim-help-support.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;AASjF,MAAM,OAAO,wBAAwB;IAiBjC,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAhBlC;;WAEG;QACM,iBAAY,GAAiB,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;QACvD;;WAEG;QACM,qBAAgB,GAAqB,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;QAChE;;WAEG;QACM,eAAU,GAAe,EAAE,CAAA;QAC3B,wBAAmB,GAAwB,EAAE,CAAC;QAEjC,cAAS,GAAG,mBAAmB,CAAC;IAEjB,CAAC;IAEtC,WAAW,CAAC,IAAU,EAAE,QAAgB,EAAE,SAAiB;QACvD,IAAI,IAAI,EAAE,UAAU,EAAE;YAClB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;gBACpC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI;aAC/D,CAAC,CAAC;SACN;aAAM;YACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,QAAQ,EAAE,SAAS,CAAC,EAAE,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;SACjG;IACL,CAAC;IAED,WAAW,CAAC,IAAU;QAClB,OAAO,IAAI,EAAE,OAAO,KAAK,YAAY,CAAC;IAC1C,CAAC;IAED,YAAY,CAAC,IAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,gFAAgF,CAAC,CAAC,CAAC,iCAAiC,CAAC;IACzJ,CAAC;IAED,OAAO,CAAC,IAAW,EAAE,QAAiB,EAAE,SAAkB;QAEtD,IAAI,SAAS,IAAI,QAAQ,KAAK,MAAM,EAAE;YAClC,OAAO,SAAS,GAAG,SAAS,CAAC;SAChC;QAED,IAAI,SAAS,IAAI,QAAQ,KAAK,MAAM,EAAE;YAClC,OAAO,MAAM,GAAG,SAAS,CAAC;SAC7B;QAED,IAAI,SAAS,EAAE;YACX,OAAO,SAAS,CAAC;SACpB;QAED,IAAI,IAAI,EAAE;YACN,IAAI,IAAI,CAAC,KAAK,EAAE;gBACZ,OAAO,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC;aAC9B;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;gBACX,OAAO,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;aAChC;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;gBACX,OAAO,IAAI,CAAC,IAAI,CAAC;aACpB;SACJ;IACL,CAAC;IAED,kBAAkB,CAAC,IAAW,EAAE,QAAiB;QAE7C,IAAI,IAAI,EAAE,KAAK,IAAI,IAAI,EAAE,IAAI,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,MAAM,EAAE;YAC3E,OAAO,OAAO,CAAC;SAChB;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;iIAzEQ,wBAAwB;qHAAxB,wBAAwB,oQCTrC,y6KAkIA;;2FDzHa,wBAAwB;kBANpC,SAAS;+BACI,mBAAmB,iBAGd,iBAAiB,CAAC,IAAI;2EAM5B,YAAY;sBAApB,KAAK;gBAIG,gBAAgB;sBAAxB,KAAK;gBAIG,UAAU;sBAAlB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAEgB,SAAS;sBAA9B,WAAW;uBAAC,OAAO","sourcesContent":["import { Component, Input, HostBinding, ViewEncapsulation } from '@angular/core';\nimport { Router } from '@angular/router';\n\n@Component({\n    selector: 'euim-help-support',\n    templateUrl: './euim-help-support.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuimHelpSupportComponent {\n    /**\n     * @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead\n     */\n    @Input() helpContacts: HelpContacts = { contacts: [] };\n    /**\n     * @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead\n     */\n    @Input() supportMaterials: SupportMaterials = { materials: [] };\n    /**\n     * @deprecated will be removed in eUI Mobile v18\n     */\n    @Input() alertInfos: AlertInfos = {}\n    @Input() helpAndSupportItems:HelpAndSupportItem[] = [];\n\n    @HostBinding('class') className = 'euim-help-support';\n\n    constructor(private router: Router) {}\n\n    onItemClick(item: Item, linkType: string, linkTitle: string): void {\n        if (item?.routerLink) {\n            this.router.navigate([item.routerLink], {\n                fragment: item.fragment && !item.link ? item.fragment : null,\n            });\n        } else {\n            window.open(this.getLink(item, linkType, linkTitle), this.setTargetAttribute(item, linkType));\n        }\n    }\n\n    isLinkSharp(item: Item): boolean {\n        return item?.endIcon === 'link-sharp';\n    }\n\n    getLinkClass(item: Item): string {\n        return this.isLinkSharp(item) ? 'euim-help-support__contact-link euim-help-support__contact-link--no-underlined' : 'euim-help-support__contact-link';\n    }\n\n    getLink(item?: Item, linkType?: string, linkTitle?: string): string {\n\n        if (linkTitle && linkType === 'mail') {\n            return 'mailto:' + linkTitle;\n        }\n\n        if (linkTitle && linkType === 'call') {\n            return 'tel:' + linkTitle;\n        }\n\n        if (linkTitle) {\n            return linkTitle;\n        }\n\n        if (item) {\n            if (item.phone) {\n                return 'tel:' + item.phone;\n            }\n\n            if (item.mail) {\n                return 'mailto:' + item.mail;\n            }\n\n            if (item.link) {\n                return item.link;\n            }\n        }\n    }\n\n    setTargetAttribute(item?: Item, linkType?: string): string {\n\n        if (item?.phone || item?.mail || linkType === 'call' || linkType === 'mail') {\n          return '_self';\n        }\n\n        return '_blank';\n    }\n}\n\ninterface AlertInfos {\n    icon?: string;\n    title?: string;\n    btnLink?: string;\n    btnTitle?: string;\n}\n\ninterface Contact {\n    linkTitle: string;\n    linkType?: string;\n    link?: string;\n    subtitle?: string;\n    icon?: string;\n    routerLink?: string;\n    fragment?: string;\n}\n\ninterface HelpContacts {\n    sectionTitle?: string;\n    contacts: Contact[];\n}\n\ninterface Material {\n    title: string;\n    subtitle?: string;\n    link?: string;\n    icon?: string;\n    routerLink?: string;\n    fragment?: string;\n}\n\ninterface SupportMaterials {\n    sectionTitle?: string;\n    materials: Material[];\n}\ninterface Item {\n  title: string;\n  link?: string;\n  phone?: string;\n  mail?: string;\n  routerLink?: string;\n  fragment?: string;\n  subtitle?: string;\n  startIcon?: string;\n  endIcon?: string;\n  hasBottomLine?: boolean;\n}\n\ninterface HelpAndSupportItem {\n  sectionTitle?: string;\n  items: Item[];\n}\n","<ion-header>\n  <ion-toolbar color=\"primary\">\n    <euim-toolbar>\n      <euim-toolbar-title>{{'euim.about.help.support' | translate }}</euim-toolbar-title>\n    </euim-toolbar>\n  </ion-toolbar>\n    @if (alertInfos.title) {\n        <euim-alert-message color=\"primary\">\n            <ion-icon name=\"person-circle\" slotStart></ion-icon>\n            {{ alertInfos.title }}\n\n            @if (alertInfos.btnLink) {\n                <ion-button [href]=\"alertInfos.btnLink\" slotEnd size=\"small\" fill=\"outline\">\n                    <strong>{{ alertInfos.btnTitle }}</strong>\n                </ion-button>\n            }\n        </euim-alert-message>\n    }\n    <ng-content select=\"[headerSection]\"></ng-content>\n</ion-header>\n\n@if (helpAndSupportItems.length > 0 || helpContacts.contacts.length > 0 || supportMaterials.materials.length > 0) {\n  <ion-list>\n      @for (helpSupportItem of helpAndSupportItems; track $index;) {\n          @if (helpSupportItem.sectionTitle) {\n              <ion-item-divider>\n                <ion-label>{{ helpSupportItem.sectionTitle }}</ion-label>\n              </ion-item-divider>\n          }\n\n        @for (item of helpSupportItem.items; track item;) {\n\n            <ion-item [lines]=\"item.hasBottomLine ? 'insert' : 'none'\" (click)=\"onItemClick(item, undefined, undefined)\">\n                @if (item.startIcon) {\n                    <euim-avatar-icon fill=\"solid\" slot=\"start\">\n                        <ion-icon [name]=\"item.startIcon\"></ion-icon>\n                    </euim-avatar-icon>\n                }\n                @if (item.title || item.subtitle) {\n                    <ion-label>\n                        @if (item.title) {\n                            <a [ngClass]=\"getLinkClass(item)\">\n                                @if (!isLinkSharp(item)) {\n                                <div class=\"euim-help-support__title\">{{ item.title }}</div>\n                                }\n                                @if (isLinkSharp(item)) {\n                                <div euimLabel euimLabelTitle>{{ item.title }}</div>\n                                }\n                            </a>\n                        }\n                        @if (item.subtitle) {\n                            <div euimLabel euimLabelSubTitle>\n                                {{ item.subtitle }}\n                            </div>\n                        }\n                    </ion-label>\n                }\n                @if (item.endIcon) {\n                    <ion-buttons>\n                        <ion-button fill=\"clear\">\n                            <ion-icon [name]=\"item.endIcon\" slot=\"icon-only\"></ion-icon>\n                        </ion-button>\n                    </ion-buttons>\n                }\n            </ion-item>\n        }\n      }\n      @if (helpContacts.contacts.length > 0) {\n          @if (helpContacts.sectionTitle) {\n          <ion-item-divider>\n              <ion-label>{{ helpContacts.sectionTitle }}</ion-label>\n          </ion-item-divider>\n          }\n          @for (contact of helpContacts.contacts; track contact; let isLast = $last) {\n              <ion-item [lines]=\"isLast ? 'none' : ''\" (click)=\"onItemClick(undefined, contact.linkType, contact.linkTitle)\">\n                  @if (contact.icon) {\n                  <euim-avatar-icon  fill=\"solid\" slot=\"start\">\n                      <ion-icon [name]=\"contact.icon\"></ion-icon>\n                  </euim-avatar-icon>\n                  }\n                  @if (contact.linkTitle || contact.subtitle) {\n                  <ion-label>\n                      @if (contact.linkTitle) {\n                      <a class=\"euim-help-support__contact-link\">\n                          <div class=\"euim-help-support__title\">{{contact.linkTitle}}</div>\n                      </a>\n                      }\n                      @if (contact.subtitle) {\n                      <div euimLabel euimLabelSubTitle>{{contact.subtitle}}</div>\n                      }\n                  </ion-label>\n                  }\n              </ion-item>\n          }\n      }\n\n      @if (supportMaterials.materials.length > 0) {\n          @if (supportMaterials.sectionTitle) {\n          <ion-item-divider>\n              <ion-label>{{ supportMaterials.sectionTitle }}</ion-label>\n          </ion-item-divider>\n          }\n          @for (material of supportMaterials.materials; track material) {\n              <ion-item lines=\"none\" (click)=\"onItemClick(material, undefined, undefined)\">\n                  @if (material.icon) {\n                  <euim-avatar-icon  fill=\"solid\" slot=\"start\">\n                      <ion-icon [name]=\"material.icon\"></ion-icon>\n                  </euim-avatar-icon>\n                  }\n                  <ion-label>\n                      @if (material.title) {\n                      <div euimLabel euimLabelTitle>{{material.title}}</div>\n                      }\n                      @if (material.subtitle) {\n                      <div euimLabel euimLabelSubTitle>{{material.subtitle}}</div>\n                      }\n                  </ion-label>\n                  <ion-buttons>\n                      <ion-button fill=\"clear\" >\n                          <ion-icon name=\"link-sharp\" slot=\"icon-only\"></ion-icon>\n                      </ion-button>\n                  </ion-buttons>\n              </ion-item>\n          }\n      }\n  </ion-list>\n}\n<ng-content></ng-content>\n\n\n"]}
|
|
@@ -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
|