@eui/ecl 18.0.0-next.21 → 18.0.0-next.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/docs/components/EclAccordionItemComponent.html +1 -1
  2. package/docs/components/EclGalleryComponent.html +25 -142
  3. package/docs/components/EclGalleryFooterComponent.html +1 -1
  4. package/docs/components/EclGalleryItemComponent.html +2 -90
  5. package/docs/components/EclInpageNavigationComponent.html +102 -1
  6. package/docs/components/EclInpageNavigationItemComponent.html +1 -1
  7. package/docs/components/EclMenuComponent.html +1 -1
  8. package/docs/components/EclMenuItemComponent.html +1 -1
  9. package/docs/components/EclMenuMegaComponent.html +0 -24
  10. package/docs/components/EclMenuMegaItemComponent.html +66 -2
  11. package/docs/dependencies.html +1 -1
  12. package/docs/directives/EclLinkDirective.html +3 -3
  13. package/docs/index.html +1 -1
  14. package/docs/js/menu-wc.js +3 -6
  15. package/docs/js/menu-wc_es5.js +1 -1
  16. package/docs/js/search/search_index.js +2 -2
  17. package/esm2022/lib/components/ecl-accordion/ecl-accordion-item.component.mjs +4 -5
  18. package/esm2022/lib/components/ecl-breadcrumb/ecl-breadcrumb-segment.component.mjs +1 -1
  19. package/esm2022/lib/components/ecl-gallery/ecl-gallery-footer.component.mjs +5 -6
  20. package/esm2022/lib/components/ecl-gallery/ecl-gallery-item.component.mjs +8 -27
  21. package/esm2022/lib/components/ecl-gallery/ecl-gallery.component.mjs +18 -76
  22. package/esm2022/lib/components/ecl-icon/ecl-icon.component.mjs +2 -2
  23. package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation-item.component.mjs +3 -3
  24. package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.mjs +33 -15
  25. package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.module.mjs +5 -5
  26. package/esm2022/lib/components/ecl-link/ecl-link.directive.mjs +5 -5
  27. package/esm2022/lib/components/ecl-list/ecl-description-list-definition/ecl-description-list-definition.component.mjs +1 -1
  28. package/esm2022/lib/components/ecl-menu/ecl-menu/ecl-menu-item.component.mjs +3 -3
  29. package/esm2022/lib/components/ecl-menu/ecl-menu/ecl-menu.component.mjs +9 -12
  30. package/esm2022/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega-item.component.mjs +37 -19
  31. package/esm2022/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega.component.mjs +4 -16
  32. package/esm2022/lib/components/ecl-pagination/ecl-pagination-item.component.mjs +1 -1
  33. package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ec/ecl-site-footer-fixed-content.mjs +1 -1
  34. package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/eu/ecl-site-footer-fixed-content.mjs +1 -1
  35. package/esm2022/lib/components/ecl-site-header/ecl-site-header.component.mjs +1 -1
  36. package/esm2022/lib/components/ecl-site-header/language/ecl-site-header-language-popover.component.mjs +1 -1
  37. package/esm2022/lib/components/ecl-social-media-follow/ecl-social-media-follow-item.component.mjs +1 -1
  38. package/esm2022/lib/components/ecl-social-media-share/ecl-social-media-share-item.component.mjs +1 -1
  39. package/esm2022/lib/components/ecl-tabs/ecl-tab.component.mjs +1 -1
  40. package/fesm2022/eui-ecl.mjs +854 -889
  41. package/fesm2022/eui-ecl.mjs.map +4 -4
  42. package/lib/components/ecl-gallery/ecl-gallery-item.component.d.ts +4 -10
  43. package/lib/components/ecl-gallery/ecl-gallery-item.component.d.ts.map +1 -1
  44. package/lib/components/ecl-gallery/ecl-gallery.component.d.ts +15 -38
  45. package/lib/components/ecl-gallery/ecl-gallery.component.d.ts.map +1 -1
  46. package/lib/components/ecl-icon/ecl-icon.component.d.ts.map +1 -1
  47. package/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.d.ts +10 -2
  48. package/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.d.ts.map +1 -1
  49. package/lib/components/ecl-link/ecl-link.directive.d.ts +3 -3
  50. package/lib/components/ecl-link/ecl-link.directive.d.ts.map +1 -1
  51. package/lib/components/ecl-menu/ecl-menu/ecl-menu.component.d.ts +2 -1
  52. package/lib/components/ecl-menu/ecl-menu/ecl-menu.component.d.ts.map +1 -1
  53. package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega-item.component.d.ts +11 -5
  54. package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega-item.component.d.ts.map +1 -1
  55. package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega.component.d.ts +1 -5
  56. package/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega.component.d.ts.map +1 -1
  57. package/package.json +1 -1
  58. package/docs/classes/EclGalleryDownloadEvent.html +0 -382
@@ -1,13 +1,11 @@
1
- import { __decorate } from "tslib";
2
- import { Component, Input, Output, ContentChildren, EventEmitter, HostListener, ViewChild, HostBinding, ContentChild, } from '@angular/core';
3
- import { EclGalleryItemComponent } from './ecl-gallery-item.component';
1
+ import { Breakpoints } from '@angular/cdk/layout';
2
+ import { Component, ContentChild, ContentChildren, EventEmitter, HostBinding, HostListener, Input, Output, ViewChild, booleanAttribute, numberAttribute, } from '@angular/core';
4
3
  import { Subject, delay } from 'rxjs';
5
- import { EclBaseEvent } from '../../model/ecl-base.event';
6
4
  import { takeUntil } from 'rxjs/operators';
5
+ import { EclBaseEvent } from '../../model/ecl-base.event';
7
6
  import { ECLBaseDirective } from '../ecl-base.directive';
8
- import { Breakpoints } from '@angular/cdk/layout';
9
- import { coerceBoolean, coerceNumber } from '@eui/base';
10
7
  import { EclGalleryFooterComponent } from './ecl-gallery-footer.component';
8
+ import { EclGalleryItemComponent } from './ecl-gallery-item.component';
11
9
  import * as i0 from "@angular/core";
12
10
  import * as i1 from "@angular/cdk/layout";
13
11
  import * as i2 from "@angular/common";
@@ -21,16 +19,6 @@ export class EclGalleryShowEvent extends EclBaseEvent {
21
19
  }
22
20
  export class EclGalleryHideEvent extends EclBaseEvent {
23
21
  }
24
- /**
25
- * @deprecated
26
- * The name 'EclGalleryDownloadEvent' is deprecated and should be removed as of version 18.
27
- */
28
- export class EclGalleryDownloadEvent extends EclBaseEvent {
29
- constructor(galleryItem) {
30
- super();
31
- this.galleryItem = galleryItem;
32
- }
33
- }
34
22
  export class EclGalleryFullScreenEvent extends EclBaseEvent {
35
23
  constructor(galleryItem) {
36
24
  super();
@@ -56,28 +44,13 @@ export class EclGalleryComponent extends ECLBaseDirective {
56
44
  constructor(cdkBreakpointObserver) {
57
45
  super();
58
46
  this.cdkBreakpointObserver = cdkBreakpointObserver;
59
- /**
60
- * @deprecated
61
- * The name 'isDownloadable' is deprecated and should be removed as of version 18.
62
- */
63
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
64
- this.isDownloadable = true;
65
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
66
47
  this.isOpenInFullScreenPossible = true;
67
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
68
48
  this.isShareable = true;
69
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
70
49
  this.isFullWidth = false;
71
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
72
50
  this.isNoOverlay = false;
73
51
  // eslint-disable-next-line @angular-eslint/no-output-native
74
52
  this.show = new EventEmitter();
75
53
  this.hide = new EventEmitter();
76
- /**
77
- * @deprecated
78
- * The name 'download' is deprecated and should be removed as of version 18.
79
- */
80
- this.download = new EventEmitter();
81
54
  this.openFullScreen = new EventEmitter();
82
55
  this.share = new EventEmitter();
83
56
  this.itemSwitch = new EventEmitter();
@@ -110,13 +83,6 @@ export class EclGalleryComponent extends ECLBaseDirective {
110
83
  this.isDialogVisible = false;
111
84
  this.hide.next(new EclGalleryHideEvent());
112
85
  }
113
- /**
114
- * @deprecated
115
- * The name 'onDownload' is deprecated and should be removed as of version 18.
116
- */
117
- onDownload(evt) {
118
- this.download.next(new EclGalleryDownloadEvent(this.item));
119
- }
120
86
  onFullScreenOpen(evt) {
121
87
  this.openFullScreen.next(new EclGalleryFullScreenEvent(this.item));
122
88
  }
@@ -162,13 +128,6 @@ export class EclGalleryComponent extends ECLBaseDirective {
162
128
  this.destroy$.next(true);
163
129
  this.destroy$.unsubscribe();
164
130
  }
165
- /**
166
- * @deprecated
167
- * The name 'canBeDownloaded' is deprecated and should be removed as of version 18.
168
- */
169
- canBeDownloaded() {
170
- return this.isDownloadable && this.item?.isDownloadable;
171
- }
172
131
  canBeOpenInFullScreen() {
173
132
  return this.isOpenInFullScreenPossible && this.item?.isOpenInFullScreenPossible;
174
133
  }
@@ -288,47 +247,30 @@ export class EclGalleryComponent extends ECLBaseDirective {
288
247
  return this.galleryItems.filter((item, cnt) => cnt < this.maxVisibleItems);
289
248
  }
290
249
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclGalleryComponent, deps: [{ token: i1.BreakpointObserver }], target: i0.ɵɵFactoryTarget.Component }); }
291
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.3", type: EclGalleryComponent, selector: "ecl-gallery", inputs: { isDownloadable: "isDownloadable", isOpenInFullScreenPossible: "isOpenInFullScreenPossible", isShareable: "isShareable", isFullWidth: "isFullWidth", isNoOverlay: "isNoOverlay", maxVisibleItems: "maxVisibleItems" }, outputs: { show: "show", hide: "hide", download: "download", openFullScreen: "openFullScreen", share: "share", itemSwitch: "itemSwitch" }, host: { listeners: { "document:keydown.escape": "onEscapeKeydownHandler($event)", "window:resize": "iframeResize($event)" }, properties: { "class": "this.cssClasses", "attr.role": "this.role" } }, queries: [{ propertyName: "galleryFooter", first: true, predicate: EclGalleryFooterComponent, descendants: true }, { propertyName: "galleryItems", predicate: EclGalleryItemComponent }], viewQueries: [{ propertyName: "videoChild", first: true, predicate: ["video"], descendants: true }, { propertyName: "imageChild", first: true, predicate: ["image"], descendants: true }, { propertyName: "externalVideoChild", first: true, predicate: ["externalVideo"], descendants: true }, { propertyName: "overlayChild", first: true, predicate: ["overlay"], descendants: true }, { propertyName: "headerChild", first: true, predicate: ["header"], descendants: true }, { propertyName: "footerChild", first: true, predicate: ["footer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ul class=\"ecl-gallery__list\">\n <ng-content></ng-content>\n</ul>\n\n<ng-content select=\"ecl-gallery-footer\"></ng-content>\n\n<dialog\n #overlay\n [attr.open]=\"isDialogVisible || null\"\n class=\"ecl-gallery__overlay\"\n [attr.aria-label]=\"'ecl.gallery.FULL-SIZE-DISPLAY' | translate\">\n <header #header class=\"ecl-gallery__close\">\n <button (click)=\"onClose($event)\" eclButton class=\"ecl-gallery__close-button\" variant=\"ghost\">\n <span eclButtonLabel>\n {{ 'ecl.common.CLOSE' | translate }}\n </span>\n <ecl-icon icon=\"close-filled\" eclSize=\"s\"></ecl-icon>\n </button>\n </header>\n <section class=\"ecl-gallery__slider\">\n <div class=\"ecl-gallery__slider-media-container\">\n <div #externalVideo class=\"ecl-gallery__slider-embed\" *ngIf=\"item?.isExternalVideo\">\n <iframe\n [src]=\"item?.getUrlExternalVideo()\"\n [style.width.px]=\"getIframeWidth()\"\n [style.height.px]=\"getIframeHeight()\"\n frameborder=\"0\">\n </iframe>\n </div>\n <picture #image *ngIf=\"item?.isImage\" class=\"ecl-picture ecl-gallery__picture ecl-gallery__slider-image\">\n <img [attr.alt]=\"item?.label || null\" [src]=\"item?.src\" />\n </picture>\n <video\n #video\n *ngIf=\"item?.isVideo\"\n controls=\"controls\"\n class=\"ecl-gallery__slider-video\"\n [attr.poster]=\"item.mediaChild?.poster\">\n <source *ngFor=\"let item of item.mediaChild?.sources\" [attr.src]=\"item.src\" [attr.type]=\"item.type\" />\n <track\n *ngFor=\"let item of item.mediaChild?.tracks\"\n [attr.src]=\"item\"\n [attr.kind]=\"item.kind\"\n [attr.srcLang]=\"item.srcLang\"\n [attr.label]=\"item.label\" />\n </video>\n </div>\n </section>\n <footer #footer class=\"ecl-gallery__detail\">\n <div class=\"ecl-container\">\n <div class=\"ecl-gallery__detail-actions\">\n <!-- @deprecated [download]=\"item?.src\" -->\n <a\n *ngIf=\"canBeDownloaded()\"\n eclLink\n variant=\"standalone\"\n class=\"ecl-gallery__download\"\n [href]=\"item?.getDownloadLink()\"\n [download]=\"item?.src\"\n target=\"_blank\"\n (click)=\"onDownload($event)\">\n <span eclLinkLabel>{{ 'ecl.gallery.VIEW-ORIGINAL' | translate }}</span>\n <ecl-icon icon=\"fullscreen\" transform=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n <a *ngIf=\"canBeShared()\" eclLink variant=\"standalone\" class=\"ecl-gallery__share\" href=\"\" (click)=\"onShare($event)\">\n <span eclLinkLabel>{{ 'ecl.common.SHARE' | translate }}</span>\n <ecl-icon icon=\"share\" transform=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n </div>\n\n <div *ngIf=\"item?.description\" class=\"ecl-gallery__detail-description\">{{ item?.description }}</div>\n\n <div *ngIf=\"item?.meta\" class=\"ecl-gallery__detail-meta\">{{ item?.meta }}</div>\n\n <div class=\"ecl-gallery__pager\">\n <button eclButton class=\"ecl-gallery__slider-previous\" variant=\"ghost\" (click)=\"onPrevious($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-270\"></ecl-icon>\n <span eclButtonLabel class=\"ecl-u-sr-only\">\n {{ 'ecl.common.PREVIOUS' | translate }}\n </span>\n </button>\n <div class=\"ecl-gallery__detail-counter\">\n <span>{{ itemIndex }}</span> {{ 'ecl.common.OF' | translate }} <span>{{ itemsCount }}</span>\n </div>\n <button eclButton class=\"ecl-gallery__slider-next\" variant=\"ghost\" (click)=\"onNext($event)\">\n <span eclButtonLabel class=\"ecl-u-sr-only\">\n {{ 'ecl.common.NEXT' | translate }}\n </span>\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-90\"></ecl-icon>\n </button>\n </div>\n </div>\n </footer>\n</dialog>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EclButtonComponent, selector: "button[eclButton], button[ecl-button], a[eclButton]", inputs: ["isIconOnly", "variant", "containerStyleClass"] }, { kind: "directive", type: i4.EclButtonLabelDirective, selector: "[eclButtonLabel]" }, { kind: "component", type: i5.EclIconComponent, selector: "ecl-icon", inputs: ["iconSet", "icon", "size", "color", "transform", "ariaLabelledby", "role", "ariaHidden", "focusable"] }, { kind: "directive", type: i6.EclLinkDirective, selector: "[eclLink]", inputs: ["isInverted", "isHiddenLabel", "isNoVisited", "variant"] }, { kind: "directive", type: i7.EclLinkLabelDirective, selector: "[eclLinkLabel]" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
250
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-next.3", type: EclGalleryComponent, selector: "ecl-gallery", inputs: { isOpenInFullScreenPossible: ["isOpenInFullScreenPossible", "isOpenInFullScreenPossible", booleanAttribute], isShareable: ["isShareable", "isShareable", booleanAttribute], isFullWidth: ["isFullWidth", "isFullWidth", booleanAttribute], isNoOverlay: ["isNoOverlay", "isNoOverlay", booleanAttribute], maxVisibleItems: ["maxVisibleItems", "maxVisibleItems", numberAttribute] }, outputs: { show: "show", hide: "hide", openFullScreen: "openFullScreen", share: "share", itemSwitch: "itemSwitch" }, host: { listeners: { "document:keydown.escape": "onEscapeKeydownHandler($event)", "window:resize": "iframeResize($event)" }, properties: { "class": "this.cssClasses", "attr.role": "this.role" } }, queries: [{ propertyName: "galleryFooter", first: true, predicate: EclGalleryFooterComponent, descendants: true }, { propertyName: "galleryItems", predicate: EclGalleryItemComponent }], viewQueries: [{ propertyName: "videoChild", first: true, predicate: ["video"], descendants: true }, { propertyName: "imageChild", first: true, predicate: ["image"], descendants: true }, { propertyName: "externalVideoChild", first: true, predicate: ["externalVideo"], descendants: true }, { propertyName: "overlayChild", first: true, predicate: ["overlay"], descendants: true }, { propertyName: "headerChild", first: true, predicate: ["header"], descendants: true }, { propertyName: "footerChild", first: true, predicate: ["footer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ul class=\"ecl-gallery__list\">\n <ng-content></ng-content>\n</ul>\n\n<ng-content select=\"ecl-gallery-footer\"></ng-content>\n\n<dialog #overlay [attr.open]=\"isDialogVisible || null\" class=\"ecl-gallery__overlay\"\n [attr.aria-label]=\"'ecl.gallery.FULL-SIZE-DISPLAY' | translate\">\n <header #header class=\"ecl-gallery__close\">\n <button (click)=\"onClose($event)\" eclButton class=\"ecl-gallery__close-button\" isIconOnly variant=\"ghost\">\n <span eclButtonLabel>\n {{ 'ecl.common.CLOSE' | translate }}\n </span>\n <ecl-icon icon=\"close\" size=\"m\"></ecl-icon>\n </button>\n </header>\n <section class=\"ecl-gallery__slider\">\n <div class=\"ecl-gallery__slider-media-container\">\n @if(item?.isExternalVideo) {\n <div #externalVideo class=\"ecl-gallery__slider-embed\">\n <iframe [src]=\"item?.getUrlExternalVideo()\" [style.width.px]=\"getIframeWidth()\"\n [style.height.px]=\"getIframeHeight()\" frameborder=\"0\">\n </iframe>\n </div>\n }\n @if(item?.isImage) {\n <picture #image class=\"ecl-picture ecl-gallery__picture ecl-gallery__slider-image\">\n <img [attr.alt]=\"item?.label || null\" [src]=\"item?.src\" />\n </picture>\n }\n @if(item?.isVideo) {\n <video #video controls=\"controls\" class=\"ecl-gallery__slider-video\"\n [attr.poster]=\"item.mediaChild?.poster\">\n @for (el of item.mediaChild?.sources; track el.src) {\n <source [attr.src]=\"el.src\" [attr.type]=\"el.type\" />\n }\n @for (elem of item.mediaChild?.tracks; track elem.src) {\n <track [attr.src]=\"elem.src\" [attr.kind]=\"elem.kind\"\n [attr.srcLang]=\"elem.srcLang\" [attr.label]=\"elem.label\" />\n }\n </video>\n }\n </div>\n </section>\n <footer #footer class=\"ecl-gallery__detail\">\n <div class=\"ecl-container\">\n <div class=\"ecl-gallery__pager\">\n <button eclButton class=\"ecl-gallery__slider-previous\" variant=\"tertiary\" isIconOnly\n (click)=\"onPrevious($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-270\"></ecl-icon>\n <span eclButtonLabel>\n {{ 'ecl.common.PREVIOUS' | translate }}\n </span>\n </button>\n <div class=\"ecl-gallery__detail-counter\">\n <span>{{ itemIndex }}</span> {{ 'ecl.common.OF' | translate }} <span>{{ itemsCount }}</span>\n </div>\n <button eclButton class=\"ecl-gallery__slider-next\" variant=\"tertiary\" isIconOnly\n (click)=\"onNext($event)\">\n <span eclButtonLabel>\n {{ 'ecl.common.NEXT' | translate }}\n </span>\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-90\"></ecl-icon>\n </button>\n </div>\n <div class=\"ecl-gallery__detail-actions\">\n @if(canBeOpenInFullScreen()) {\n <a eclLink variant=\"standalone\" class=\"ecl-gallery__download\" [href]=\"item?.getDownloadLink()\"\n target=\"_blank\" (click)=\"onFullScreenOpen($event)\" isInverted>\n <span eclLinkLabel>{{ 'ecl.gallery.VIEW-ORIGINAL' | translate }}</span>\n <ecl-icon icon=\"fullscreen\" size=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n }\n @if(canBeShared()) {\n <a eclLink variant=\"standalone\" isInverted class=\"ecl-gallery__share\" href=\"\" (click)=\"onShare($event)\">\n <span eclLinkLabel>{{ 'ecl.common.SHARE' | translate }}</span>\n <ecl-icon icon=\"share\" size=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n }\n </div>\n @if(item?.description) {\n <div *ngIf=\"item?.description\" class=\"ecl-gallery__detail-description\">{{ item?.description }}</div>\n }\n @if(item?.meta) {\n <div *ngIf=\"item?.meta\" class=\"ecl-gallery__detail-meta\">{{ item?.meta }}</div>\n }\n </div>\n </footer>\n</dialog>", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EclButtonComponent, selector: "button[eclButton], button[ecl-button], a[eclButton]", inputs: ["isIconOnly", "variant", "containerStyleClass"] }, { kind: "directive", type: i4.EclButtonLabelDirective, selector: "[eclButtonLabel]" }, { kind: "component", type: i5.EclIconComponent, selector: "ecl-icon", inputs: ["iconSet", "icon", "size", "color", "transform", "ariaLabelledby", "role", "ariaHidden", "focusable"] }, { kind: "directive", type: i6.EclLinkDirective, selector: "[eclLink]", inputs: ["isInverted", "isIconOnly", "isNoVisited", "variant"] }, { kind: "directive", type: i7.EclLinkLabelDirective, selector: "[eclLinkLabel]" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
292
251
  }
293
- __decorate([
294
- coerceBoolean
295
- ], EclGalleryComponent.prototype, "isDownloadable", void 0);
296
- __decorate([
297
- coerceBoolean
298
- ], EclGalleryComponent.prototype, "isOpenInFullScreenPossible", void 0);
299
- __decorate([
300
- coerceBoolean
301
- ], EclGalleryComponent.prototype, "isShareable", void 0);
302
- __decorate([
303
- coerceBoolean
304
- ], EclGalleryComponent.prototype, "isFullWidth", void 0);
305
- __decorate([
306
- coerceBoolean
307
- ], EclGalleryComponent.prototype, "isNoOverlay", void 0);
308
- __decorate([
309
- coerceNumber
310
- ], EclGalleryComponent.prototype, "maxVisibleItems", void 0);
311
252
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclGalleryComponent, decorators: [{
312
253
  type: Component,
313
- args: [{ selector: 'ecl-gallery', template: "<ul class=\"ecl-gallery__list\">\n <ng-content></ng-content>\n</ul>\n\n<ng-content select=\"ecl-gallery-footer\"></ng-content>\n\n<dialog\n #overlay\n [attr.open]=\"isDialogVisible || null\"\n class=\"ecl-gallery__overlay\"\n [attr.aria-label]=\"'ecl.gallery.FULL-SIZE-DISPLAY' | translate\">\n <header #header class=\"ecl-gallery__close\">\n <button (click)=\"onClose($event)\" eclButton class=\"ecl-gallery__close-button\" variant=\"ghost\">\n <span eclButtonLabel>\n {{ 'ecl.common.CLOSE' | translate }}\n </span>\n <ecl-icon icon=\"close-filled\" eclSize=\"s\"></ecl-icon>\n </button>\n </header>\n <section class=\"ecl-gallery__slider\">\n <div class=\"ecl-gallery__slider-media-container\">\n <div #externalVideo class=\"ecl-gallery__slider-embed\" *ngIf=\"item?.isExternalVideo\">\n <iframe\n [src]=\"item?.getUrlExternalVideo()\"\n [style.width.px]=\"getIframeWidth()\"\n [style.height.px]=\"getIframeHeight()\"\n frameborder=\"0\">\n </iframe>\n </div>\n <picture #image *ngIf=\"item?.isImage\" class=\"ecl-picture ecl-gallery__picture ecl-gallery__slider-image\">\n <img [attr.alt]=\"item?.label || null\" [src]=\"item?.src\" />\n </picture>\n <video\n #video\n *ngIf=\"item?.isVideo\"\n controls=\"controls\"\n class=\"ecl-gallery__slider-video\"\n [attr.poster]=\"item.mediaChild?.poster\">\n <source *ngFor=\"let item of item.mediaChild?.sources\" [attr.src]=\"item.src\" [attr.type]=\"item.type\" />\n <track\n *ngFor=\"let item of item.mediaChild?.tracks\"\n [attr.src]=\"item\"\n [attr.kind]=\"item.kind\"\n [attr.srcLang]=\"item.srcLang\"\n [attr.label]=\"item.label\" />\n </video>\n </div>\n </section>\n <footer #footer class=\"ecl-gallery__detail\">\n <div class=\"ecl-container\">\n <div class=\"ecl-gallery__detail-actions\">\n <!-- @deprecated [download]=\"item?.src\" -->\n <a\n *ngIf=\"canBeDownloaded()\"\n eclLink\n variant=\"standalone\"\n class=\"ecl-gallery__download\"\n [href]=\"item?.getDownloadLink()\"\n [download]=\"item?.src\"\n target=\"_blank\"\n (click)=\"onDownload($event)\">\n <span eclLinkLabel>{{ 'ecl.gallery.VIEW-ORIGINAL' | translate }}</span>\n <ecl-icon icon=\"fullscreen\" transform=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n <a *ngIf=\"canBeShared()\" eclLink variant=\"standalone\" class=\"ecl-gallery__share\" href=\"\" (click)=\"onShare($event)\">\n <span eclLinkLabel>{{ 'ecl.common.SHARE' | translate }}</span>\n <ecl-icon icon=\"share\" transform=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n </div>\n\n <div *ngIf=\"item?.description\" class=\"ecl-gallery__detail-description\">{{ item?.description }}</div>\n\n <div *ngIf=\"item?.meta\" class=\"ecl-gallery__detail-meta\">{{ item?.meta }}</div>\n\n <div class=\"ecl-gallery__pager\">\n <button eclButton class=\"ecl-gallery__slider-previous\" variant=\"ghost\" (click)=\"onPrevious($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-270\"></ecl-icon>\n <span eclButtonLabel class=\"ecl-u-sr-only\">\n {{ 'ecl.common.PREVIOUS' | translate }}\n </span>\n </button>\n <div class=\"ecl-gallery__detail-counter\">\n <span>{{ itemIndex }}</span> {{ 'ecl.common.OF' | translate }} <span>{{ itemsCount }}</span>\n </div>\n <button eclButton class=\"ecl-gallery__slider-next\" variant=\"ghost\" (click)=\"onNext($event)\">\n <span eclButtonLabel class=\"ecl-u-sr-only\">\n {{ 'ecl.common.NEXT' | translate }}\n </span>\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-90\"></ecl-icon>\n </button>\n </div>\n </div>\n </footer>\n</dialog>\n", styles: [":host{display:block}\n"] }]
314
- }], ctorParameters: () => [{ type: i1.BreakpointObserver }], propDecorators: { isDownloadable: [{
315
- type: Input
316
- }], isOpenInFullScreenPossible: [{
317
- type: Input
254
+ args: [{ selector: 'ecl-gallery', template: "<ul class=\"ecl-gallery__list\">\n <ng-content></ng-content>\n</ul>\n\n<ng-content select=\"ecl-gallery-footer\"></ng-content>\n\n<dialog #overlay [attr.open]=\"isDialogVisible || null\" class=\"ecl-gallery__overlay\"\n [attr.aria-label]=\"'ecl.gallery.FULL-SIZE-DISPLAY' | translate\">\n <header #header class=\"ecl-gallery__close\">\n <button (click)=\"onClose($event)\" eclButton class=\"ecl-gallery__close-button\" isIconOnly variant=\"ghost\">\n <span eclButtonLabel>\n {{ 'ecl.common.CLOSE' | translate }}\n </span>\n <ecl-icon icon=\"close\" size=\"m\"></ecl-icon>\n </button>\n </header>\n <section class=\"ecl-gallery__slider\">\n <div class=\"ecl-gallery__slider-media-container\">\n @if(item?.isExternalVideo) {\n <div #externalVideo class=\"ecl-gallery__slider-embed\">\n <iframe [src]=\"item?.getUrlExternalVideo()\" [style.width.px]=\"getIframeWidth()\"\n [style.height.px]=\"getIframeHeight()\" frameborder=\"0\">\n </iframe>\n </div>\n }\n @if(item?.isImage) {\n <picture #image class=\"ecl-picture ecl-gallery__picture ecl-gallery__slider-image\">\n <img [attr.alt]=\"item?.label || null\" [src]=\"item?.src\" />\n </picture>\n }\n @if(item?.isVideo) {\n <video #video controls=\"controls\" class=\"ecl-gallery__slider-video\"\n [attr.poster]=\"item.mediaChild?.poster\">\n @for (el of item.mediaChild?.sources; track el.src) {\n <source [attr.src]=\"el.src\" [attr.type]=\"el.type\" />\n }\n @for (elem of item.mediaChild?.tracks; track elem.src) {\n <track [attr.src]=\"elem.src\" [attr.kind]=\"elem.kind\"\n [attr.srcLang]=\"elem.srcLang\" [attr.label]=\"elem.label\" />\n }\n </video>\n }\n </div>\n </section>\n <footer #footer class=\"ecl-gallery__detail\">\n <div class=\"ecl-container\">\n <div class=\"ecl-gallery__pager\">\n <button eclButton class=\"ecl-gallery__slider-previous\" variant=\"tertiary\" isIconOnly\n (click)=\"onPrevious($event)\">\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-270\"></ecl-icon>\n <span eclButtonLabel>\n {{ 'ecl.common.PREVIOUS' | translate }}\n </span>\n </button>\n <div class=\"ecl-gallery__detail-counter\">\n <span>{{ itemIndex }}</span> {{ 'ecl.common.OF' | translate }} <span>{{ itemsCount }}</span>\n </div>\n <button eclButton class=\"ecl-gallery__slider-next\" variant=\"tertiary\" isIconOnly\n (click)=\"onNext($event)\">\n <span eclButtonLabel>\n {{ 'ecl.common.NEXT' | translate }}\n </span>\n <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-90\"></ecl-icon>\n </button>\n </div>\n <div class=\"ecl-gallery__detail-actions\">\n @if(canBeOpenInFullScreen()) {\n <a eclLink variant=\"standalone\" class=\"ecl-gallery__download\" [href]=\"item?.getDownloadLink()\"\n target=\"_blank\" (click)=\"onFullScreenOpen($event)\" isInverted>\n <span eclLinkLabel>{{ 'ecl.gallery.VIEW-ORIGINAL' | translate }}</span>\n <ecl-icon icon=\"fullscreen\" size=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n }\n @if(canBeShared()) {\n <a eclLink variant=\"standalone\" isInverted class=\"ecl-gallery__share\" href=\"\" (click)=\"onShare($event)\">\n <span eclLinkLabel>{{ 'ecl.common.SHARE' | translate }}</span>\n <ecl-icon icon=\"share\" size=\"fluid\" focusable=\"false\"></ecl-icon>\n </a>\n }\n </div>\n @if(item?.description) {\n <div *ngIf=\"item?.description\" class=\"ecl-gallery__detail-description\">{{ item?.description }}</div>\n }\n @if(item?.meta) {\n <div *ngIf=\"item?.meta\" class=\"ecl-gallery__detail-meta\">{{ item?.meta }}</div>\n }\n </div>\n </footer>\n</dialog>", styles: [":host{display:block}\n"] }]
255
+ }], ctorParameters: () => [{ type: i1.BreakpointObserver }], propDecorators: { isOpenInFullScreenPossible: [{
256
+ type: Input,
257
+ args: [{ transform: booleanAttribute }]
318
258
  }], isShareable: [{
319
- type: Input
259
+ type: Input,
260
+ args: [{ transform: booleanAttribute }]
320
261
  }], isFullWidth: [{
321
- type: Input
262
+ type: Input,
263
+ args: [{ transform: booleanAttribute }]
322
264
  }], isNoOverlay: [{
323
- type: Input
265
+ type: Input,
266
+ args: [{ transform: booleanAttribute }]
324
267
  }], maxVisibleItems: [{
325
- type: Input
268
+ type: Input,
269
+ args: [{ transform: numberAttribute }]
326
270
  }], show: [{
327
271
  type: Output
328
272
  }], hide: [{
329
273
  type: Output
330
- }], download: [{
331
- type: Output
332
274
  }], openFullScreen: [{
333
275
  type: Output
334
276
  }], share: [{
@@ -372,4 +314,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
372
314
  type: HostListener,
373
315
  args: ['window:resize', ['$event']]
374
316
  }] } });
375
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-gallery.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-gallery/ecl-gallery.component.ts","../../../../../src/lib/components/ecl-gallery/ecl-gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    Output,\n    ContentChildren,\n    QueryList,\n    EventEmitter,\n    AfterContentInit,\n    OnDestroy,\n    HostListener,\n    ViewChild,\n    ElementRef,\n    HostBinding,\n    OnInit,\n    ContentChild,\n} from '@angular/core';\nimport { EclGalleryItemComponent } from './ecl-gallery-item.component';\nimport { EclGalleryItem } from '../../model/ecl-gallery-item.model';\nimport { Subject, delay } from 'rxjs';\nimport { EclBaseEvent } from '../../model/ecl-base.event';\nimport { takeUntil } from 'rxjs/operators';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\nimport { coerceBoolean, coerceNumber } from '@eui/base';\nimport { EclGalleryFooterComponent } from './ecl-gallery-footer.component';\n\nexport class EclGalleryShowEvent extends EclBaseEvent {}\nexport class EclGalleryHideEvent extends EclBaseEvent {}\n/**\n * @deprecated\n * The name 'EclGalleryDownloadEvent' is deprecated and should be removed as of version 18.\n */\nexport class EclGalleryDownloadEvent extends EclBaseEvent {\n    constructor(public galleryItem: EclGalleryItem) {\n        super();\n    }\n}\nexport class EclGalleryFullScreenEvent extends EclBaseEvent {\n    constructor(public galleryItem: EclGalleryItem) {\n        super();\n    }\n}\nexport class EclGalleryShareEvent extends EclBaseEvent {\n    constructor(public galleryItem: EclGalleryItem) {\n        super();\n    }\n}\n\nexport class EclGalleryItemEvent extends EclBaseEvent {\n    constructor(public galleryItem: EclGalleryItem) {\n        super();\n    }\n}\n\n@Component({\n    selector: 'ecl-gallery',\n    templateUrl: './ecl-gallery.component.html',\n    styles: [\n        `\n            :host {\n                display: block;\n            }\n        `,\n    ],\n})\nexport class EclGalleryComponent extends ECLBaseDirective implements AfterContentInit, OnDestroy, OnInit {\n    /**\n     * @deprecated\n     * The name 'isDownloadable' is deprecated and should be removed as of version 18.\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @coerceBoolean @Input() isDownloadable: boolean | any = true;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @coerceBoolean @Input() isOpenInFullScreenPossible: boolean | any = true;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @coerceBoolean @Input() isShareable: boolean | any = true;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @coerceBoolean @Input() isFullWidth: boolean | any = false;\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @coerceBoolean @Input() isNoOverlay: boolean | any = false;\n    @coerceNumber @Input() maxVisibleItems: number;\n\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() show = new EventEmitter<EclGalleryShowEvent>();\n    @Output() hide = new EventEmitter<EclGalleryHideEvent>();\n    /**\n     * @deprecated\n     * The name 'download' is deprecated and should be removed as of version 18.\n     */\n    @Output() download = new EventEmitter<EclGalleryDownloadEvent>();\n    @Output() openFullScreen = new EventEmitter<EclGalleryFullScreenEvent>();\n    @Output() share = new EventEmitter<EclGalleryShareEvent>();\n    @Output() itemSwitch = new EventEmitter<EclGalleryItemEvent>();\n    @ContentChildren(EclGalleryItemComponent) galleryItems: QueryList<EclGalleryItemComponent>;\n    @ContentChild(EclGalleryFooterComponent) galleryFooter: EclGalleryFooterComponent;\n    @ViewChild('video') videoChild: ElementRef;\n    @ViewChild('image') imageChild: ElementRef;\n    @ViewChild('externalVideo') externalVideoChild: ElementRef;\n    @ViewChild('overlay') overlayChild: ElementRef;\n    @ViewChild('header') headerChild: ElementRef;\n    @ViewChild('footer') footerChild: ElementRef;\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-gallery'), this.isFullWidth ? 'ecl-gallery--full-width' : ''].join(' ').trim();\n    }\n    @HostBinding('attr.role') role = 'region';\n\n    isDialogVisible = false;\n    isMobile = false;\n    itemsCount: number;\n    itemIndex: number;\n    item: EclGalleryItemComponent;\n    private iframeWidth: number;\n    private iframeHeight: number;\n    private BREAKPOINT_CHANGES_TIMEOUT = 500;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n    private visibleItems: number;\n    private MAX_VISIBLE_ITEMS_MOBILE = 3;\n    private RESOLUTION_16_9_PROPOTION = 16 / 9;\n    private RESOLUTION_4_3_PROPOTION = 4 / 3;\n\n    constructor(private cdkBreakpointObserver: BreakpointObserver) {\n        super();\n    }\n\n    onPrevious(evt: MouseEvent): void {\n        this.item = this.findPreviousItem(this.galleryItems.toArray(), this.item);\n\n        this.itemIndex = this.findItemIndex(this.galleryItems.toArray(), this.item);\n\n        this.itemSwitch.next(new EclGalleryItemEvent(this.item));\n    }\n\n    onNext(evt: MouseEvent): void {\n        this.item = this.findNextItem(this.galleryItems.toArray(), this.item);\n        this.itemIndex = this.findItemIndex(this.galleryItems.toArray(), this.item);\n\n        this.itemSwitch.next(new EclGalleryItemEvent(this.item));\n    }\n\n    onClose(evt: MouseEvent): void {\n        this.item = null;\n        this.itemIndex = -1;\n        this.isDialogVisible = false;\n        this.hide.next(new EclGalleryHideEvent());\n    }\n\n    @HostListener('document:keydown.escape', ['$event'])\n    onEscapeKeydownHandler(event: KeyboardEvent): void {\n        this.isDialogVisible = false;\n        this.hide.next(new EclGalleryHideEvent());\n    }\n    /**\n     * @deprecated\n     * The name 'onDownload' is deprecated and should be removed as of version 18.\n     */\n    onDownload(evt: MouseEvent): void {\n        this.download.next(new EclGalleryDownloadEvent(this.item));\n    }\n\n    onFullScreenOpen(evt: MouseEvent): void {\n        this.openFullScreen.next(new EclGalleryFullScreenEvent(this.item));\n    }\n\n    onShare(evt: MouseEvent): void {\n        this.share.next(new EclGalleryShareEvent(this.item));\n        evt.preventDefault();\n    }\n\n    ngOnInit(): void {\n        this.observeBreakpointChanges();\n    }\n\n    ngAfterContentInit(): void {\n        this.itemsCount = this.galleryItems.length;\n        this.visibleItems = this.maxVisibleItems ? this.maxVisibleItems : this.itemsCount;\n        this.galleryFooter.itemsCount = this.itemsCount;\n        this.galleryFooter.isShowToggleBtn = this.hasHiddenGaleryItems();\n        this.galleryFooter.toggleItems.pipe(takeUntil(this.destroy$)).subscribe((evt) => {\n            if (evt.expandAll) {\n                this.showAllItems();\n            } else {\n                this.collapseItems();\n            }\n        });\n\n        if (!this.isNoOverlay) {\n            this.galleryItems.forEach((item) => {\n                item.itemClick.pipe(takeUntil(this.destroy$)).subscribe((_) => {\n                    this.isDialogVisible = true;\n                    this.item = item;\n                    this.itemIndex = this.findItemIndex(this.galleryItems.toArray(), item);\n                    this.show.next(new EclGalleryShowEvent());\n                    setTimeout(() => this.setIframeDimensions());\n                });\n            });\n        } else {\n            this.galleryItems.forEach((item) => (item.isNoOverlay = true));\n        }\n\n        if (this.hasHiddenGaleryItems()) {\n            this.collapseItems();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n    /**\n     * @deprecated\n     * The name 'canBeDownloaded' is deprecated and should be removed as of version 18.\n     */\n    canBeDownloaded(): boolean {\n        return this.isDownloadable && this.item?.isDownloadable;\n    }\n\n    canBeOpenInFullScreen(): boolean {\n        return this.isOpenInFullScreenPossible && this.item?.isOpenInFullScreenPossible;\n    }\n\n    canBeShared(): boolean {\n        return this.isShareable && this.item?.isShareable;\n    }\n\n    getIframeWidth(): number {\n        return this.iframeWidth;\n    }\n\n    getIframeHeight(): number {\n        return this.iframeHeight;\n    }\n\n    setIframeDimensions(): void {\n        const { width, height } = this.getCalculatedIframeDimensions();\n        this.iframeWidth = width;\n        this.iframeHeight = height;\n    }\n\n    @HostListener('window:resize', ['$event'])\n    private iframeResize(): void {\n        this.setIframeDimensions();\n    }\n\n    private getCalculatedIframeDimensions(): { width: number; height: number } {\n        let width = window.innerWidth;\n        let height =\n            this.overlayChild.nativeElement.clientHeight -\n            this.headerChild.nativeElement.clientHeight -\n            this.footerChild.nativeElement.clientHeight;\n        if (width > height) {\n            const scaledHeight = height * this.RESOLUTION_16_9_PROPOTION;\n            if (scaledHeight > width) {\n                width = width * 0.95;\n            } else {\n                width = scaledHeight;\n            }\n        } else {\n            const scaledWith = width * this.RESOLUTION_4_3_PROPOTION;\n            if (scaledWith > height) {\n                height = height * 0.95;\n            } else {\n                height = scaledWith;\n            }\n        }\n        return {\n            width,\n            height,\n        };\n    }\n\n    private findItemIndex(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): number {\n        return items.findIndex((it) => it === item) + 1;\n    }\n\n    private findPreviousItem(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): EclGalleryItemComponent {\n        const index = this.findPreviousItemIndex(items, item);\n        return items[index];\n    }\n\n    private findNextItem(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): EclGalleryItemComponent {\n        const index = this.findNextItemIndex(items, item);\n        return items[index];\n    }\n\n    private findPreviousItemIndex(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): number {\n        const currentIndex = items.findIndex((it) => it === item);\n        return currentIndex === 0 ? items.length - 1 : currentIndex - 1;\n    }\n\n    private findNextItemIndex(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): number {\n        const currentIndex = items.findIndex((it) => it === item);\n        return currentIndex >= items.length - 1 ? 0 : currentIndex + 1;\n    }\n\n    private observeBreakpointChanges(): void {\n        this.cdkBreakpointObserver\n            .observe([Breakpoints.Handset, Breakpoints.Tablet])\n            .pipe(takeUntil(this.destroy$), delay(this.BREAKPOINT_CHANGES_TIMEOUT))\n            .subscribe((result) => {\n                this.isMobile = result.matches;\n                if (this.isMobile) {\n                    this.manageItemsMobile();\n                } else {\n                    this.manageItemsDesktop();\n                }\n            });\n    }\n\n    private manageItemsMobile(): void {\n        this.maxVisibleItems = this.MAX_VISIBLE_ITEMS_MOBILE;\n        this.collapseItems();\n        this.galleryFooter.isShowToggleBtn = this.hasHiddenGaleryItems();\n    }\n\n    private manageItemsDesktop(): void {\n        this.maxVisibleItems = this.visibleItems;\n        this.getVisibleItems().forEach((elem) => this.showGaleryItem(elem));\n        this.collapseItems();\n        this.galleryFooter.isShowToggleBtn = this.hasHiddenGaleryItems();\n    }\n\n    private hasHiddenGaleryItems(): boolean {\n        if (this.maxVisibleItems && this.itemsCount > 0 && this.maxVisibleItems < this.itemsCount) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    private collapseItems(): void {\n        this.getHiddenItems().forEach((elem) => this.hideGaleryItem(elem));\n    }\n\n    private showAllItems(): void {\n        this.getHiddenItems().forEach((elem) => this.showGaleryItem(elem));\n    }\n\n    private hideGaleryItem(item: EclGalleryItemComponent): void {\n        item.isHidden = true;\n    }\n\n    private showGaleryItem(item: EclGalleryItemComponent): void {\n        item.isHidden = false;\n    }\n\n    private getHiddenItems(): EclGalleryItemComponent[] {\n        return this.galleryItems.filter((item, cnt) => cnt >= this.maxVisibleItems);\n    }\n    private getVisibleItems(): EclGalleryItemComponent[] {\n        return this.galleryItems.filter((item, cnt) => cnt < this.maxVisibleItems);\n    }\n}\n","<ul class=\"ecl-gallery__list\">\n    <ng-content></ng-content>\n</ul>\n\n<ng-content select=\"ecl-gallery-footer\"></ng-content>\n\n<dialog\n    #overlay\n    [attr.open]=\"isDialogVisible || null\"\n    class=\"ecl-gallery__overlay\"\n    [attr.aria-label]=\"'ecl.gallery.FULL-SIZE-DISPLAY' | translate\">\n    <header #header class=\"ecl-gallery__close\">\n        <button (click)=\"onClose($event)\" eclButton class=\"ecl-gallery__close-button\" variant=\"ghost\">\n            <span eclButtonLabel>\n                {{ 'ecl.common.CLOSE' | translate }}\n            </span>\n            <ecl-icon icon=\"close-filled\" eclSize=\"s\"></ecl-icon>\n        </button>\n    </header>\n    <section class=\"ecl-gallery__slider\">\n        <div class=\"ecl-gallery__slider-media-container\">\n            <div #externalVideo class=\"ecl-gallery__slider-embed\" *ngIf=\"item?.isExternalVideo\">\n                <iframe\n                    [src]=\"item?.getUrlExternalVideo()\"\n                    [style.width.px]=\"getIframeWidth()\"\n                    [style.height.px]=\"getIframeHeight()\"\n                    frameborder=\"0\">\n                </iframe>\n            </div>\n            <picture #image *ngIf=\"item?.isImage\" class=\"ecl-picture ecl-gallery__picture ecl-gallery__slider-image\">\n                <img [attr.alt]=\"item?.label || null\" [src]=\"item?.src\" />\n            </picture>\n            <video\n                #video\n                *ngIf=\"item?.isVideo\"\n                controls=\"controls\"\n                class=\"ecl-gallery__slider-video\"\n                [attr.poster]=\"item.mediaChild?.poster\">\n                <source *ngFor=\"let item of item.mediaChild?.sources\" [attr.src]=\"item.src\" [attr.type]=\"item.type\" />\n                <track\n                    *ngFor=\"let item of item.mediaChild?.tracks\"\n                    [attr.src]=\"item\"\n                    [attr.kind]=\"item.kind\"\n                    [attr.srcLang]=\"item.srcLang\"\n                    [attr.label]=\"item.label\" />\n            </video>\n        </div>\n    </section>\n    <footer #footer class=\"ecl-gallery__detail\">\n        <div class=\"ecl-container\">\n            <div class=\"ecl-gallery__detail-actions\">\n                <!-- @deprecated [download]=\"item?.src\" -->\n                <a\n                    *ngIf=\"canBeDownloaded()\"\n                    eclLink\n                    variant=\"standalone\"\n                    class=\"ecl-gallery__download\"\n                    [href]=\"item?.getDownloadLink()\"\n                    [download]=\"item?.src\"\n                    target=\"_blank\"\n                    (click)=\"onDownload($event)\">\n                    <span eclLinkLabel>{{ 'ecl.gallery.VIEW-ORIGINAL' | translate }}</span>\n                    <ecl-icon icon=\"fullscreen\" transform=\"fluid\" focusable=\"false\"></ecl-icon>\n                </a>\n                <a *ngIf=\"canBeShared()\" eclLink variant=\"standalone\" class=\"ecl-gallery__share\" href=\"\" (click)=\"onShare($event)\">\n                    <span eclLinkLabel>{{ 'ecl.common.SHARE' | translate }}</span>\n                    <ecl-icon icon=\"share\" transform=\"fluid\" focusable=\"false\"></ecl-icon>\n                </a>\n            </div>\n\n            <div *ngIf=\"item?.description\" class=\"ecl-gallery__detail-description\">{{ item?.description }}</div>\n\n            <div *ngIf=\"item?.meta\" class=\"ecl-gallery__detail-meta\">{{ item?.meta }}</div>\n\n            <div class=\"ecl-gallery__pager\">\n                <button eclButton class=\"ecl-gallery__slider-previous\" variant=\"ghost\" (click)=\"onPrevious($event)\">\n                    <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-270\"></ecl-icon>\n                    <span eclButtonLabel class=\"ecl-u-sr-only\">\n                        {{ 'ecl.common.PREVIOUS' | translate }}\n                    </span>\n                </button>\n                <div class=\"ecl-gallery__detail-counter\">\n                    <span>{{ itemIndex }}</span> {{ 'ecl.common.OF' | translate }} <span>{{ itemsCount }}</span>\n                </div>\n                <button eclButton class=\"ecl-gallery__slider-next\" variant=\"ghost\" (click)=\"onNext($event)\">\n                    <span eclButtonLabel class=\"ecl-u-sr-only\">\n                        {{ 'ecl.common.NEXT' | translate }}\n                    </span>\n                    <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-90\"></ecl-icon>\n                </button>\n            </div>\n        </div>\n    </footer>\n</dialog>\n"]}
317
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-gallery.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-gallery/ecl-gallery.component.ts","../../../../../src/lib/components/ecl-gallery/ecl-gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\nimport {\n    AfterContentInit,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewChild,\n    booleanAttribute,\n    numberAttribute,\n} from '@angular/core';\nimport { Subject, delay } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { EclBaseEvent } from '../../model/ecl-base.event';\nimport { EclGalleryItem } from '../../model/ecl-gallery-item.model';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclGalleryFooterComponent } from './ecl-gallery-footer.component';\nimport { EclGalleryItemComponent } from './ecl-gallery-item.component';\n\nexport class EclGalleryShowEvent extends EclBaseEvent {}\nexport class EclGalleryHideEvent extends EclBaseEvent {}\nexport class EclGalleryFullScreenEvent extends EclBaseEvent {\n    constructor(public galleryItem: EclGalleryItem) {\n        super();\n    }\n}\nexport class EclGalleryShareEvent extends EclBaseEvent {\n    constructor(public galleryItem: EclGalleryItem) {\n        super();\n    }\n}\n\nexport class EclGalleryItemEvent extends EclBaseEvent {\n    constructor(public galleryItem: EclGalleryItem) {\n        super();\n    }\n}\n\n@Component({\n    selector: 'ecl-gallery',\n    templateUrl: './ecl-gallery.component.html',\n    styles: [\n        `\n            :host {\n                display: block;\n            }\n        `,\n    ],\n})\nexport class EclGalleryComponent extends ECLBaseDirective implements AfterContentInit, OnDestroy, OnInit {\n\n    @Input({ transform: booleanAttribute }) isOpenInFullScreenPossible = true;\n    @Input({ transform: booleanAttribute }) isShareable = true;\n    @Input({ transform: booleanAttribute }) isFullWidth = false;\n    @Input({ transform: booleanAttribute }) isNoOverlay = false;\n    @Input({ transform: numberAttribute }) maxVisibleItems: number;\n\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() show = new EventEmitter<EclGalleryShowEvent>();\n    @Output() hide = new EventEmitter<EclGalleryHideEvent>();\n    @Output() openFullScreen = new EventEmitter<EclGalleryFullScreenEvent>();\n    @Output() share = new EventEmitter<EclGalleryShareEvent>();\n    @Output() itemSwitch = new EventEmitter<EclGalleryItemEvent>();\n    @ContentChildren(EclGalleryItemComponent) galleryItems: QueryList<EclGalleryItemComponent>;\n    @ContentChild(EclGalleryFooterComponent) galleryFooter: EclGalleryFooterComponent;\n    @ViewChild('video') videoChild: ElementRef;\n    @ViewChild('image') imageChild: ElementRef;\n    @ViewChild('externalVideo') externalVideoChild: ElementRef;\n    @ViewChild('overlay') overlayChild: ElementRef;\n    @ViewChild('header') headerChild: ElementRef;\n    @ViewChild('footer') footerChild: ElementRef;\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-gallery'), this.isFullWidth ? 'ecl-gallery--full-width' : ''].join(' ').trim();\n    }\n    @HostBinding('attr.role') role = 'region';\n\n    isDialogVisible = false;\n    isMobile = false;\n    itemsCount: number;\n    itemIndex: number;\n    item: EclGalleryItemComponent;\n    private iframeWidth: number;\n    private iframeHeight: number;\n    private BREAKPOINT_CHANGES_TIMEOUT = 500;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n    private visibleItems: number;\n    private MAX_VISIBLE_ITEMS_MOBILE = 3;\n    private RESOLUTION_16_9_PROPOTION = 16 / 9;\n    private RESOLUTION_4_3_PROPOTION = 4 / 3;\n\n    constructor(private cdkBreakpointObserver: BreakpointObserver) {\n        super();\n    }\n\n    onPrevious(evt: MouseEvent): void {\n        this.item = this.findPreviousItem(this.galleryItems.toArray(), this.item);\n\n        this.itemIndex = this.findItemIndex(this.galleryItems.toArray(), this.item);\n\n        this.itemSwitch.next(new EclGalleryItemEvent(this.item));\n    }\n\n    onNext(evt: MouseEvent): void {\n        this.item = this.findNextItem(this.galleryItems.toArray(), this.item);\n        this.itemIndex = this.findItemIndex(this.galleryItems.toArray(), this.item);\n\n        this.itemSwitch.next(new EclGalleryItemEvent(this.item));\n    }\n\n    onClose(evt: MouseEvent): void {\n        this.item = null;\n        this.itemIndex = -1;\n        this.isDialogVisible = false;\n        this.hide.next(new EclGalleryHideEvent());\n    }\n\n    @HostListener('document:keydown.escape', ['$event'])\n    onEscapeKeydownHandler(event: KeyboardEvent): void {\n        this.isDialogVisible = false;\n        this.hide.next(new EclGalleryHideEvent());\n    }\n\n    onFullScreenOpen(evt: MouseEvent): void {\n        this.openFullScreen.next(new EclGalleryFullScreenEvent(this.item));\n    }\n\n    onShare(evt: MouseEvent): void {\n        this.share.next(new EclGalleryShareEvent(this.item));\n        evt.preventDefault();\n    }\n\n    ngOnInit(): void {\n        this.observeBreakpointChanges();\n    }\n\n    ngAfterContentInit(): void {\n        this.itemsCount = this.galleryItems.length;\n        this.visibleItems = this.maxVisibleItems ? this.maxVisibleItems : this.itemsCount;\n        this.galleryFooter.itemsCount = this.itemsCount;\n        this.galleryFooter.isShowToggleBtn = this.hasHiddenGaleryItems();\n        this.galleryFooter.toggleItems.pipe(takeUntil(this.destroy$)).subscribe((evt) => {\n            if (evt.expandAll) {\n                this.showAllItems();\n            } else {\n                this.collapseItems();\n            }\n        });\n\n        if (!this.isNoOverlay) {\n            this.galleryItems.forEach((item) => {\n                item.itemClick.pipe(takeUntil(this.destroy$)).subscribe((_) => {\n                    this.isDialogVisible = true;\n                    this.item = item;\n                    this.itemIndex = this.findItemIndex(this.galleryItems.toArray(), item);\n                    this.show.next(new EclGalleryShowEvent());\n                    setTimeout(() => this.setIframeDimensions());\n                });\n            });\n        } else {\n            this.galleryItems.forEach((item) => (item.isNoOverlay = true));\n        }\n\n        if (this.hasHiddenGaleryItems()) {\n            this.collapseItems();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    canBeOpenInFullScreen(): boolean {\n        return this.isOpenInFullScreenPossible && this.item?.isOpenInFullScreenPossible;\n    }\n\n    canBeShared(): boolean {\n        return this.isShareable && this.item?.isShareable;\n    }\n\n    getIframeWidth(): number {\n        return this.iframeWidth;\n    }\n\n    getIframeHeight(): number {\n        return this.iframeHeight;\n    }\n\n    setIframeDimensions(): void {\n        const { width, height } = this.getCalculatedIframeDimensions();\n        this.iframeWidth = width;\n        this.iframeHeight = height;\n    }\n\n    @HostListener('window:resize', ['$event'])\n    iframeResize(): void {\n        this.setIframeDimensions();\n    }\n\n    private getCalculatedIframeDimensions(): { width: number; height: number } {\n        let width = window.innerWidth;\n        let height =\n            this.overlayChild.nativeElement.clientHeight -\n            this.headerChild.nativeElement.clientHeight -\n            this.footerChild.nativeElement.clientHeight;\n        if (width > height) {\n            const scaledHeight = height * this.RESOLUTION_16_9_PROPOTION;\n            if (scaledHeight > width) {\n                width = width * 0.95;\n            } else {\n                width = scaledHeight;\n            }\n        } else {\n            const scaledWith = width * this.RESOLUTION_4_3_PROPOTION;\n            if (scaledWith > height) {\n                height = height * 0.95;\n            } else {\n                height = scaledWith;\n            }\n        }\n        return {\n            width,\n            height,\n        };\n    }\n\n    private findItemIndex(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): number {\n        return items.findIndex((it) => it === item) + 1;\n    }\n\n    private findPreviousItem(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): EclGalleryItemComponent {\n        const index = this.findPreviousItemIndex(items, item);\n        return items[index];\n    }\n\n    private findNextItem(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): EclGalleryItemComponent {\n        const index = this.findNextItemIndex(items, item);\n        return items[index];\n    }\n\n    private findPreviousItemIndex(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): number {\n        const currentIndex = items.findIndex((it) => it === item);\n        return currentIndex === 0 ? items.length - 1 : currentIndex - 1;\n    }\n\n    private findNextItemIndex(items: Array<EclGalleryItemComponent>, item: EclGalleryItemComponent): number {\n        const currentIndex = items.findIndex((it) => it === item);\n        return currentIndex >= items.length - 1 ? 0 : currentIndex + 1;\n    }\n\n    private observeBreakpointChanges(): void {\n        this.cdkBreakpointObserver\n            .observe([Breakpoints.Handset, Breakpoints.Tablet])\n            .pipe(takeUntil(this.destroy$), delay(this.BREAKPOINT_CHANGES_TIMEOUT))\n            .subscribe((result) => {\n                this.isMobile = result.matches;\n                if (this.isMobile) {\n                    this.manageItemsMobile();\n                } else {\n                    this.manageItemsDesktop();\n                }\n            });\n    }\n\n    private manageItemsMobile(): void {\n        this.maxVisibleItems = this.MAX_VISIBLE_ITEMS_MOBILE;\n        this.collapseItems();\n        this.galleryFooter.isShowToggleBtn = this.hasHiddenGaleryItems();\n    }\n\n    private manageItemsDesktop(): void {\n        this.maxVisibleItems = this.visibleItems;\n        this.getVisibleItems().forEach((elem) => this.showGaleryItem(elem));\n        this.collapseItems();\n        this.galleryFooter.isShowToggleBtn = this.hasHiddenGaleryItems();\n    }\n\n    private hasHiddenGaleryItems(): boolean {\n        if (this.maxVisibleItems && this.itemsCount > 0 && this.maxVisibleItems < this.itemsCount) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    private collapseItems(): void {\n        this.getHiddenItems().forEach((elem) => this.hideGaleryItem(elem));\n    }\n\n    private showAllItems(): void {\n        this.getHiddenItems().forEach((elem) => this.showGaleryItem(elem));\n    }\n\n    private hideGaleryItem(item: EclGalleryItemComponent): void {\n        item.isHidden = true;\n    }\n\n    private showGaleryItem(item: EclGalleryItemComponent): void {\n        item.isHidden = false;\n    }\n\n    private getHiddenItems(): EclGalleryItemComponent[] {\n        return this.galleryItems.filter((item, cnt) => cnt >= this.maxVisibleItems);\n    }\n    private getVisibleItems(): EclGalleryItemComponent[] {\n        return this.galleryItems.filter((item, cnt) => cnt < this.maxVisibleItems);\n    }\n}\n","<ul class=\"ecl-gallery__list\">\n    <ng-content></ng-content>\n</ul>\n\n<ng-content select=\"ecl-gallery-footer\"></ng-content>\n\n<dialog #overlay [attr.open]=\"isDialogVisible || null\" class=\"ecl-gallery__overlay\"\n    [attr.aria-label]=\"'ecl.gallery.FULL-SIZE-DISPLAY' | translate\">\n    <header #header class=\"ecl-gallery__close\">\n        <button (click)=\"onClose($event)\" eclButton class=\"ecl-gallery__close-button\" isIconOnly variant=\"ghost\">\n            <span eclButtonLabel>\n                {{ 'ecl.common.CLOSE' | translate }}\n            </span>\n            <ecl-icon icon=\"close\" size=\"m\"></ecl-icon>\n        </button>\n    </header>\n    <section class=\"ecl-gallery__slider\">\n        <div class=\"ecl-gallery__slider-media-container\">\n            @if(item?.isExternalVideo) {\n            <div #externalVideo class=\"ecl-gallery__slider-embed\">\n                <iframe [src]=\"item?.getUrlExternalVideo()\" [style.width.px]=\"getIframeWidth()\"\n                    [style.height.px]=\"getIframeHeight()\" frameborder=\"0\">\n                </iframe>\n            </div>\n            }\n            @if(item?.isImage) {\n            <picture #image class=\"ecl-picture ecl-gallery__picture ecl-gallery__slider-image\">\n                <img [attr.alt]=\"item?.label || null\" [src]=\"item?.src\" />\n            </picture>\n            }\n            @if(item?.isVideo) {\n            <video #video controls=\"controls\" class=\"ecl-gallery__slider-video\"\n                [attr.poster]=\"item.mediaChild?.poster\">\n                @for (el of item.mediaChild?.sources; track el.src) {\n                <source [attr.src]=\"el.src\" [attr.type]=\"el.type\" />\n                }\n                @for (elem of item.mediaChild?.tracks; track elem.src) {\n                <track [attr.src]=\"elem.src\" [attr.kind]=\"elem.kind\"\n                    [attr.srcLang]=\"elem.srcLang\" [attr.label]=\"elem.label\" />\n                }\n            </video>\n            }\n        </div>\n    </section>\n    <footer #footer class=\"ecl-gallery__detail\">\n        <div class=\"ecl-container\">\n            <div class=\"ecl-gallery__pager\">\n                <button eclButton class=\"ecl-gallery__slider-previous\" variant=\"tertiary\" isIconOnly\n                    (click)=\"onPrevious($event)\">\n                    <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-270\"></ecl-icon>\n                    <span eclButtonLabel>\n                        {{ 'ecl.common.PREVIOUS' | translate }}\n                    </span>\n                </button>\n                <div class=\"ecl-gallery__detail-counter\">\n                    <span>{{ itemIndex }}</span> {{ 'ecl.common.OF' | translate }} <span>{{ itemsCount }}</span>\n                </div>\n                <button eclButton class=\"ecl-gallery__slider-next\" variant=\"tertiary\" isIconOnly\n                    (click)=\"onNext($event)\">\n                    <span eclButtonLabel>\n                        {{ 'ecl.common.NEXT' | translate }}\n                    </span>\n                    <ecl-icon icon=\"corner-arrow\" size=\"m\" transform=\"rotate-90\"></ecl-icon>\n                </button>\n            </div>\n            <div class=\"ecl-gallery__detail-actions\">\n                @if(canBeOpenInFullScreen()) {\n                <a eclLink variant=\"standalone\" class=\"ecl-gallery__download\" [href]=\"item?.getDownloadLink()\"\n                    target=\"_blank\" (click)=\"onFullScreenOpen($event)\" isInverted>\n                    <span eclLinkLabel>{{ 'ecl.gallery.VIEW-ORIGINAL' | translate }}</span>\n                    <ecl-icon icon=\"fullscreen\" size=\"fluid\" focusable=\"false\"></ecl-icon>\n                </a>\n                }\n                @if(canBeShared()) {\n                <a eclLink variant=\"standalone\" isInverted class=\"ecl-gallery__share\" href=\"\" (click)=\"onShare($event)\">\n                    <span eclLinkLabel>{{ 'ecl.common.SHARE' | translate }}</span>\n                    <ecl-icon icon=\"share\" size=\"fluid\" focusable=\"false\"></ecl-icon>\n                </a>\n                }\n            </div>\n            @if(item?.description) {\n            <div *ngIf=\"item?.description\" class=\"ecl-gallery__detail-description\">{{ item?.description }}</div>\n            }\n            @if(item?.meta) {\n            <div *ngIf=\"item?.meta\" class=\"ecl-gallery__detail-meta\">{{ item?.meta }}</div>\n            }\n        </div>\n    </footer>\n</dialog>"]}
@@ -40,7 +40,7 @@ export class EclIconComponent extends ECLBaseDirective {
40
40
  if (this.svgEl) {
41
41
  const hostParentEl = this.svgEl.nativeElement.parentElement;
42
42
  if (hostParentEl) {
43
- hostParentEl.removeChild(this.svgEl);
43
+ hostParentEl.removeChild(this.svgEl.nativeElement);
44
44
  }
45
45
  }
46
46
  }
@@ -110,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
110
110
  type: ViewChild,
111
111
  args: ['svg']
112
112
  }] } });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-icon.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-icon/ecl-icon.component.ts","../../../../../src/lib/components/ecl-icon/ecl-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit, Component, ElementRef,\n    HostBinding, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewChild, booleanAttribute,\n} from '@angular/core';\nimport { Observable, of, switchMap } from 'rxjs';\nimport { EclThemeService } from '../../services';\nimport { ECLBaseDirective } from '../ecl-base.directive';\n\n@Component({\n    selector: 'ecl-icon',\n    templateUrl: './ecl-icon.component.html',\n})\nexport class EclIconComponent extends ECLBaseDirective implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n    @Input() iconSet: 'default' | 'social' | 'social-media' | 'flag' | string = 'default';\n    @Input() icon: string;\n    @Input() size: '2xs' | 'xs' | 's' | 'm' | 'l' | 'xl' | '2xl' | 'fluid' | string = 'xs';\n    @Input() color: 'inverted' | 'primary' | null = null;\n    @Input() transform: string;\n    @Input() ariaLabelledby: string;\n    @Input() role: string;\n    @Input({ transform: booleanAttribute }) ariaHidden = true;\n    @Input({ transform: booleanAttribute }) focusable = false;\n\n    @HostBinding('class.ecl-u-bg-dark')\n    get isColorInverted(): boolean {\n        return this.color === 'inverted';\n    }\n\n    @ViewChild('svg') svgEl: ElementRef;\n\n    iconUrl$: Observable<string>;\n\n    constructor(\n        public el: ElementRef,\n        private renderer: Renderer2,\n        private eclThemeService: EclThemeService,\n    ) {\n        super();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['icon']) {\n            this.initiateIconUrl();\n        }\n    }\n\n    ngOnInit(): void {\n        this.initiateIconUrl();\n    }\n\n    ngAfterViewInit(): void {\n        const hostEl: HTMLElement = this.el.nativeElement;\n        const hostParentEl = hostEl.parentElement;\n\n        if (hostParentEl != null) {\n            this.renderer.setStyle(hostEl, 'display', 'none');\n            hostEl.after(this.svgEl.nativeElement);\n        }\n    }\n\n    ngOnDestroy(): void {\n        try {\n            if (this.svgEl) {\n                const hostParentEl = this.svgEl.nativeElement.parentElement;\n                if (hostParentEl) {\n                    hostParentEl.removeChild(this.svgEl);\n                }\n            }\n        } catch (e) {\n            /* empty */\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    getClasses(): { [x: string]: any } {\n        const hostClasses = this.el.nativeElement.classList.toString();\n        return {\n            [super.getCssClasses('ecl-icon')]: true,\n            [`ecl-icon--${this.size}`]: this.size,\n            [`ecl-icon--${this.transform}`]: this.transform,\n            [`ecl-icon--${this.color}`]: this.color,\n            [hostClasses]: true,\n        };\n    }\n\n    private initiateIconUrl(): void {\n        this.iconUrl$ = this.eclThemeService.theme$.pipe(\n            switchMap((theme) => {\n                switch (this.iconSet) {\n                    case 'default':\n                        return of(`assets/images/ecl/${theme}/icons/sprites/icons.svg#${this.icon}`);\n                    case 'social':\n                        return of(`assets/images/ecl/${theme}/social-icons/sprites/icons-social.svg#${this.icon}`);\n                    case 'social-media':\n                        return of(`assets/images/ecl/${theme}/icons-social-media/sprites/icons-social-media.svg#${this.icon}`);\n                    case 'flag':\n                        return of(`assets/images/ecl/${theme}/icons-flag/sprites/icons-flag.svg#${this.icon}`);\n                    case 'flag-non-members':\n                        return of(`assets/images/ecl/${theme}/icons-flag/sprites/icons-flag-non-members.svg#${this.icon}`);\n                    default:\n                        return of(`${this.iconSet}#${this.icon}`);\n                }\n            }),\n        );\n    }\n}\n","<svg\n    #svg\n    [ngClass]=\"getClasses()\"\n    [attr.aria-hidden]=\"ariaHidden\"\n    [attr.aria-labelledby]=\"ariaLabelledby || null\"\n    [attr.role]=\"role || null\"\n    [attr.focusable]=\"focusable\">\n    <use [attr.xlink:href]=\"iconUrl$ | async\"></use>\n    <ng-content></ng-content>\n</svg>\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-icon.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-icon/ecl-icon.component.ts","../../../../../src/lib/components/ecl-icon/ecl-icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit, Component, ElementRef,\n    HostBinding, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewChild, booleanAttribute,\n} from '@angular/core';\nimport { Observable, of, switchMap } from 'rxjs';\nimport { EclThemeService } from '../../services';\nimport { ECLBaseDirective } from '../ecl-base.directive';\n\n@Component({\n    selector: 'ecl-icon',\n    templateUrl: './ecl-icon.component.html',\n})\nexport class EclIconComponent extends ECLBaseDirective implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n    @Input() iconSet: 'default' | 'social' | 'social-media' | 'flag' | string = 'default';\n    @Input() icon: string;\n    @Input() size: '2xs' | 'xs' | 's' | 'm' | 'l' | 'xl' | '2xl' | 'fluid' | string = 'xs';\n    @Input() color: 'inverted' | 'primary' | null = null;\n    @Input() transform: string;\n    @Input() ariaLabelledby: string;\n    @Input() role: string;\n    @Input({ transform: booleanAttribute }) ariaHidden = true;\n    @Input({ transform: booleanAttribute }) focusable = false;\n\n    @HostBinding('class.ecl-u-bg-dark')\n    get isColorInverted(): boolean {\n        return this.color === 'inverted';\n    }\n\n    @ViewChild('svg') svgEl: ElementRef;\n\n    iconUrl$: Observable<string>;\n\n    constructor(\n        public el: ElementRef,\n        private renderer: Renderer2,\n        private eclThemeService: EclThemeService,\n    ) {\n        super();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['icon']) {\n            this.initiateIconUrl();\n        }\n    }\n\n    ngOnInit(): void {\n        this.initiateIconUrl();\n    }\n\n    ngAfterViewInit(): void {\n        const hostEl: HTMLElement = this.el.nativeElement;\n        const hostParentEl = hostEl.parentElement;\n\n        if (hostParentEl != null) {\n            this.renderer.setStyle(hostEl, 'display', 'none');\n            hostEl.after(this.svgEl.nativeElement);\n        }\n    }\n\n    ngOnDestroy(): void {\n        try {\n            if (this.svgEl) {\n                const hostParentEl = this.svgEl.nativeElement.parentElement;\n                if (hostParentEl) {\n                    hostParentEl.removeChild(this.svgEl.nativeElement);\n                }\n            }\n        } catch (e) {\n            /* empty */\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    getClasses(): { [x: string]: any } {\n        const hostClasses = this.el.nativeElement.classList.toString();\n        return {\n            [super.getCssClasses('ecl-icon')]: true,\n            [`ecl-icon--${this.size}`]: this.size,\n            [`ecl-icon--${this.transform}`]: this.transform,\n            [`ecl-icon--${this.color}`]: this.color,\n            [hostClasses]: true,\n        };\n    }\n\n    private initiateIconUrl(): void {\n        this.iconUrl$ = this.eclThemeService.theme$.pipe(\n            switchMap((theme) => {\n                switch (this.iconSet) {\n                    case 'default':\n                        return of(`assets/images/ecl/${theme}/icons/sprites/icons.svg#${this.icon}`);\n                    case 'social':\n                        return of(`assets/images/ecl/${theme}/social-icons/sprites/icons-social.svg#${this.icon}`);\n                    case 'social-media':\n                        return of(`assets/images/ecl/${theme}/icons-social-media/sprites/icons-social-media.svg#${this.icon}`);\n                    case 'flag':\n                        return of(`assets/images/ecl/${theme}/icons-flag/sprites/icons-flag.svg#${this.icon}`);\n                    case 'flag-non-members':\n                        return of(`assets/images/ecl/${theme}/icons-flag/sprites/icons-flag-non-members.svg#${this.icon}`);\n                    default:\n                        return of(`${this.iconSet}#${this.icon}`);\n                }\n            }),\n        );\n    }\n}\n","<svg\n    #svg\n    [ngClass]=\"getClasses()\"\n    [attr.aria-hidden]=\"ariaHidden\"\n    [attr.aria-labelledby]=\"ariaLabelledby || null\"\n    [attr.role]=\"role || null\"\n    [attr.focusable]=\"focusable\">\n    <use [attr.xlink:href]=\"iconUrl$ | async\"></use>\n    <ng-content></ng-content>\n</svg>\n"]}
@@ -24,11 +24,11 @@ export class EclInpageNavigationItemComponent extends ECLBaseDirective {
24
24
  return document.querySelector(`#${this.sectionId}`);
25
25
  }
26
26
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclInpageNavigationItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
27
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.3", type: EclInpageNavigationItemComponent, selector: "ecl-inpage-navigation-item", inputs: { label: "label", sectionId: "sectionId", isActive: "isActive" }, outputs: { itemClick: "itemClick" }, host: { properties: { "class.ecl-inpage-navigation__item": "this.cmpClass", "class.ecl-inpage-navigation__item--active": "this.isActive" } }, usesInheritance: true, ngImport: i0, template: "<a eclLink (click)=\"onItemClick($event)\" variant=\"standalone\" href=\"#\" class=\"ecl-inpage-navigation__link\">\n {{ label }}\n</a>\n", styles: [":host{display:list-item}\n"], dependencies: [{ kind: "directive", type: i1.EclLinkDirective, selector: "[eclLink]", inputs: ["isInverted", "isHiddenLabel", "isNoVisited", "variant"] }] }); }
27
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.3", type: EclInpageNavigationItemComponent, selector: "ecl-inpage-navigation-item", inputs: { label: "label", sectionId: "sectionId", isActive: "isActive" }, outputs: { itemClick: "itemClick" }, host: { properties: { "class.ecl-inpage-navigation__item": "this.cmpClass", "class.ecl-inpage-navigation__item--active": "this.isActive" } }, usesInheritance: true, ngImport: i0, template: "<a eclLink (click)=\"onItemClick($event)\" href=\"#\" class=\"ecl-inpage-navigation__link\">\n {{ label }}\n</a>\n", styles: [":host{display:list-item}\n"], dependencies: [{ kind: "directive", type: i1.EclLinkDirective, selector: "[eclLink]", inputs: ["isInverted", "isIconOnly", "isNoVisited", "variant"] }] }); }
28
28
  }
29
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclInpageNavigationItemComponent, decorators: [{
30
30
  type: Component,
31
- args: [{ selector: 'ecl-inpage-navigation-item', template: "<a eclLink (click)=\"onItemClick($event)\" variant=\"standalone\" href=\"#\" class=\"ecl-inpage-navigation__link\">\n {{ label }}\n</a>\n", styles: [":host{display:list-item}\n"] }]
31
+ args: [{ selector: 'ecl-inpage-navigation-item', template: "<a eclLink (click)=\"onItemClick($event)\" href=\"#\" class=\"ecl-inpage-navigation__link\">\n {{ label }}\n</a>\n", styles: [":host{display:list-item}\n"] }]
32
32
  }], propDecorators: { cmpClass: [{
33
33
  type: HostBinding,
34
34
  args: ['class.ecl-inpage-navigation__item']
@@ -44,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
44
44
  }], itemClick: [{
45
45
  type: Output
46
46
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNsLWlucGFnZS1uYXZpZ2F0aW9uLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2VjbC1pbnBhZ2UtbmF2aWdhdGlvbi9lY2wtaW5wYWdlLW5hdmlnYXRpb24taXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZWNsLWlucGFnZS1uYXZpZ2F0aW9uL2VjbC1pbnBhZ2UtbmF2aWdhdGlvbi1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7O0FBRTFELE1BQU0sT0FBTyxpQ0FBa0MsU0FBUSxZQUFZO0lBQy9ELFlBQW1CLGdCQUF3QjtRQUN2QyxLQUFLLEVBQUUsQ0FBQztRQURPLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBUTtJQUUzQyxDQUFDO0NBQ0o7QUFhRCxNQUFNLE9BQU8sZ0NBQWlDLFNBQVEsZ0JBQWdCO0lBWHRFOztRQVlzRCxhQUFRLEdBQUcsSUFBSSxDQUFDO1FBTXhELGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBcUMsQ0FBQztLQVkvRTtJQVZHLFdBQVcsQ0FBQyxHQUFlO1FBQ3ZCLE1BQU0sS0FBSyxHQUFHLElBQUksaUNBQWlDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3BFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTNCLEdBQUcsQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBSSxjQUFjO1FBQ2QsT0FBTyxRQUFRLENBQUMsYUFBYSxDQUFDLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUM7SUFDeEQsQ0FBQzt3SUFsQlEsZ0NBQWdDOzRIQUFoQyxnQ0FBZ0Msc1ZDckI3Qyw4SUFHQTs7a0dEa0JhLGdDQUFnQztrQkFYNUMsU0FBUzsrQkFDSSw0QkFBNEI7OEJBV1ksUUFBUTtzQkFBekQsV0FBVzt1QkFBQyxtQ0FBbUM7Z0JBRXZDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUM2RCxRQUFRO3NCQUExRSxLQUFLOztzQkFBSSxXQUFXO3VCQUFDLDJDQUEyQztnQkFFdkQsU0FBUztzQkFBbEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRUNMQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4uL2VjbC1iYXNlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBFY2xCYXNlRXZlbnQgfSBmcm9tICcuLi8uLi9tb2RlbC9lY2wtYmFzZS5ldmVudCc7XG5cbmV4cG9ydCBjbGFzcyBFY2xJbnBhZ2VOYXZpZ2F0aW9uSXRlbUNsaWNrRXZlbnQgZXh0ZW5kcyBFY2xCYXNlRXZlbnQge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBzZWN0aW9uRWxlbWVudElkOiBzdHJpbmcpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG59XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZWNsLWlucGFnZS1uYXZpZ2F0aW9uLWl0ZW0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9lY2wtaW5wYWdlLW5hdmlnYXRpb24taXRlbS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVzOiBbXG4gICAgICAgIGBcbiAgICAgICAgICAgIDpob3N0IHtcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBsaXN0LWl0ZW07XG4gICAgICAgICAgICB9XG4gICAgICAgIGAsXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRWNsSW5wYWdlTmF2aWdhdGlvbkl0ZW1Db21wb25lbnQgZXh0ZW5kcyBFQ0xCYXNlRGlyZWN0aXZlIHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmVjbC1pbnBhZ2UtbmF2aWdhdGlvbl9faXRlbScpIGNtcENsYXNzID0gdHJ1ZTtcblxuICAgIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmc7XG4gICAgQElucHV0KCkgc2VjdGlvbklkOiBzdHJpbmc7XG4gICAgQElucHV0KCkgQEhvc3RCaW5kaW5nKCdjbGFzcy5lY2wtaW5wYWdlLW5hdmlnYXRpb25fX2l0ZW0tLWFjdGl2ZScpIGlzQWN0aXZlOiBib29sZWFuO1xuXG4gICAgQE91dHB1dCgpIGl0ZW1DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8RWNsSW5wYWdlTmF2aWdhdGlvbkl0ZW1DbGlja0V2ZW50PigpO1xuXG4gICAgb25JdGVtQ2xpY2soZXZ0OiBNb3VzZUV2ZW50KTogdm9pZCB7XG4gICAgICAgIGNvbnN0IGV2ZW50ID0gbmV3IEVjbElucGFnZU5hdmlnYXRpb25JdGVtQ2xpY2tFdmVudCh0aGlzLnNlY3Rpb25JZCk7XG4gICAgICAgIHRoaXMuaXRlbUNsaWNrLm5leHQoZXZlbnQpO1xuXG4gICAgICAgIGV2dC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIH1cblxuICAgIGdldCBzZWN0aW9uRWxlbWVudCgpOiBIVE1MRWxlbWVudCB7XG4gICAgICAgIHJldHVybiBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKGAjJHt0aGlzLnNlY3Rpb25JZH1gKTtcbiAgICB9XG59XG4iLCI8YSBlY2xMaW5rIChjbGljayk9XCJvbkl0ZW1DbGljaygkZXZlbnQpXCIgdmFyaWFudD1cInN0YW5kYWxvbmVcIiBocmVmPVwiI1wiIGNsYXNzPVwiZWNsLWlucGFnZS1uYXZpZ2F0aW9uX19saW5rXCI+XG4gICAge3sgbGFiZWwgfX1cbjwvYT5cbiJdfQ==
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNsLWlucGFnZS1uYXZpZ2F0aW9uLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2VjbC1pbnBhZ2UtbmF2aWdhdGlvbi9lY2wtaW5wYWdlLW5hdmlnYXRpb24taXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZWNsLWlucGFnZS1uYXZpZ2F0aW9uL2VjbC1pbnBhZ2UtbmF2aWdhdGlvbi1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7O0FBRTFELE1BQU0sT0FBTyxpQ0FBa0MsU0FBUSxZQUFZO0lBQy9ELFlBQW1CLGdCQUF3QjtRQUN2QyxLQUFLLEVBQUUsQ0FBQztRQURPLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBUTtJQUUzQyxDQUFDO0NBQ0o7QUFhRCxNQUFNLE9BQU8sZ0NBQWlDLFNBQVEsZ0JBQWdCO0lBWHRFOztRQVlzRCxhQUFRLEdBQUcsSUFBSSxDQUFDO1FBTXhELGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBcUMsQ0FBQztLQVkvRTtJQVZHLFdBQVcsQ0FBQyxHQUFlO1FBQ3ZCLE1BQU0sS0FBSyxHQUFHLElBQUksaUNBQWlDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3BFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTNCLEdBQUcsQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBSSxjQUFjO1FBQ2QsT0FBTyxRQUFRLENBQUMsYUFBYSxDQUFDLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUM7SUFDeEQsQ0FBQzt3SUFsQlEsZ0NBQWdDOzRIQUFoQyxnQ0FBZ0Msc1ZDckI3Qyx1SEFHQTs7a0dEa0JhLGdDQUFnQztrQkFYNUMsU0FBUzsrQkFDSSw0QkFBNEI7OEJBV1ksUUFBUTtzQkFBekQsV0FBVzt1QkFBQyxtQ0FBbUM7Z0JBRXZDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUM2RCxRQUFRO3NCQUExRSxLQUFLOztzQkFBSSxXQUFXO3VCQUFDLDJDQUEyQztnQkFFdkQsU0FBUztzQkFBbEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRUNMQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4uL2VjbC1iYXNlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBFY2xCYXNlRXZlbnQgfSBmcm9tICcuLi8uLi9tb2RlbC9lY2wtYmFzZS5ldmVudCc7XG5cbmV4cG9ydCBjbGFzcyBFY2xJbnBhZ2VOYXZpZ2F0aW9uSXRlbUNsaWNrRXZlbnQgZXh0ZW5kcyBFY2xCYXNlRXZlbnQge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBzZWN0aW9uRWxlbWVudElkOiBzdHJpbmcpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG59XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZWNsLWlucGFnZS1uYXZpZ2F0aW9uLWl0ZW0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9lY2wtaW5wYWdlLW5hdmlnYXRpb24taXRlbS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVzOiBbXG4gICAgICAgIGBcbiAgICAgICAgICAgIDpob3N0IHtcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBsaXN0LWl0ZW07XG4gICAgICAgICAgICB9XG4gICAgICAgIGAsXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRWNsSW5wYWdlTmF2aWdhdGlvbkl0ZW1Db21wb25lbnQgZXh0ZW5kcyBFQ0xCYXNlRGlyZWN0aXZlIHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLmVjbC1pbnBhZ2UtbmF2aWdhdGlvbl9faXRlbScpIGNtcENsYXNzID0gdHJ1ZTtcblxuICAgIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmc7XG4gICAgQElucHV0KCkgc2VjdGlvbklkOiBzdHJpbmc7XG4gICAgQElucHV0KCkgQEhvc3RCaW5kaW5nKCdjbGFzcy5lY2wtaW5wYWdlLW5hdmlnYXRpb25fX2l0ZW0tLWFjdGl2ZScpIGlzQWN0aXZlOiBib29sZWFuO1xuXG4gICAgQE91dHB1dCgpIGl0ZW1DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8RWNsSW5wYWdlTmF2aWdhdGlvbkl0ZW1DbGlja0V2ZW50PigpO1xuXG4gICAgb25JdGVtQ2xpY2soZXZ0OiBNb3VzZUV2ZW50KTogdm9pZCB7XG4gICAgICAgIGNvbnN0IGV2ZW50ID0gbmV3IEVjbElucGFnZU5hdmlnYXRpb25JdGVtQ2xpY2tFdmVudCh0aGlzLnNlY3Rpb25JZCk7XG4gICAgICAgIHRoaXMuaXRlbUNsaWNrLm5leHQoZXZlbnQpO1xuXG4gICAgICAgIGV2dC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIH1cblxuICAgIGdldCBzZWN0aW9uRWxlbWVudCgpOiBIVE1MRWxlbWVudCB7XG4gICAgICAgIHJldHVybiBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKGAjJHt0aGlzLnNlY3Rpb25JZH1gKTtcbiAgICB9XG59XG4iLCI8YSBlY2xMaW5rIChjbGljayk9XCJvbkl0ZW1DbGljaygkZXZlbnQpXCIgaHJlZj1cIiNcIiBjbGFzcz1cImVjbC1pbnBhZ2UtbmF2aWdhdGlvbl9fbGlua1wiPlxuICAgIHt7IGxhYmVsIH19XG48L2E+XG4iXX0=