@eui/ecl 18.0.0-next.21 → 18.0.0-next.22
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/EclGalleryComponent.html +25 -142
- package/docs/components/EclGalleryFooterComponent.html +1 -1
- package/docs/components/EclGalleryItemComponent.html +2 -90
- package/docs/components/EclInpageNavigationComponent.html +102 -1
- package/docs/components/EclInpageNavigationItemComponent.html +1 -1
- package/docs/dependencies.html +1 -1
- package/docs/index.html +1 -1
- package/docs/js/menu-wc.js +3 -6
- package/docs/js/menu-wc_es5.js +1 -1
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/ecl-gallery/ecl-gallery-footer.component.mjs +5 -6
- package/esm2022/lib/components/ecl-gallery/ecl-gallery-item.component.mjs +8 -27
- package/esm2022/lib/components/ecl-gallery/ecl-gallery.component.mjs +18 -76
- package/esm2022/lib/components/ecl-icon/ecl-icon.component.mjs +2 -2
- package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.mjs +33 -15
- package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.module.mjs +5 -5
- package/esm2022/lib/components/ecl-link/ecl-link.directive.mjs +2 -2
- package/fesm2022/eui-ecl.mjs +564 -629
- package/fesm2022/eui-ecl.mjs.map +4 -4
- package/lib/components/ecl-gallery/ecl-gallery-item.component.d.ts +4 -10
- package/lib/components/ecl-gallery/ecl-gallery-item.component.d.ts.map +1 -1
- package/lib/components/ecl-gallery/ecl-gallery.component.d.ts +15 -38
- package/lib/components/ecl-gallery/ecl-gallery.component.d.ts.map +1 -1
- package/lib/components/ecl-icon/ecl-icon.component.d.ts.map +1 -1
- package/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.d.ts +10 -2
- package/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.d.ts.map +1 -1
- package/lib/components/ecl-link/ecl-link.directive.d.ts.map +1 -1
- package/package.json +1 -1
- package/docs/classes/EclGalleryDownloadEvent.html +0 -382
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { Component, EventEmitter, Output } from '@angular/core';
|
|
2
2
|
import { EclBaseEvent } from '../../model';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
-
import * as i2 from "
|
|
6
|
-
import * as i3 from "@ngx-translate/core";
|
|
4
|
+
import * as i1 from "../ecl-button/ecl-button.component";
|
|
5
|
+
import * as i2 from "@ngx-translate/core";
|
|
7
6
|
export class EclGalleryToggleItemsEvent extends EclBaseEvent {
|
|
8
7
|
constructor(expandAll) {
|
|
9
8
|
super();
|
|
@@ -39,12 +38,12 @@ export class EclGalleryFooterComponent {
|
|
|
39
38
|
this.toggleItems.next(new EclGalleryToggleItemsEvent(this.isExpanded));
|
|
40
39
|
}
|
|
41
40
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclGalleryFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
41
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-next.3", type: EclGalleryFooterComponent, selector: "ecl-gallery-footer", outputs: { toggleItems: "toggleItems" }, ngImport: i0, template: "<div class=\"ecl-gallery__footer\">\n <div class=\"ecl-gallery__info\">\n <div class=\"ecl-gallery__info-total\">\n <strong>{{ itemsCount }}</strong>{{ 'ecl.gallery.MEDIA-FILES-COUNT' | translate }}\n </div>\n @if(isShowToggleBtn) {\n @if(!isExpanded) {\n <button eclButton variant=\"ghost\" class=\"ecl-gallery__view-all\" (click)=\"onToggle()\">\n {{ 'ecl.gallery.VIEW-ALL' | translate }}\n </button>\n } @else {\n <button eclButton variant=\"ghost\" class=\"ecl-gallery__view-all\" (click)=\"onToggle()\">\n {{ 'ecl.common.COLLAPSE' | translate }}\n </button>\n }\n }\n </div>\n <hr class=\"ecl-gallery__footer-divider\" />\n <div class=\"ecl-gallery__footer-link\">\n <ng-content></ng-content>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i1.EclButtonComponent, selector: "button[eclButton], button[ecl-button], a[eclButton]", inputs: ["isIconOnly", "variant", "containerStyleClass"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
|
43
42
|
}
|
|
44
43
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclGalleryFooterComponent, decorators: [{
|
|
45
44
|
type: Component,
|
|
46
|
-
args: [{ selector: 'ecl-gallery-footer', template: "<div class=\"ecl-gallery__footer\">\n <div class=\"ecl-gallery__info\">\n <
|
|
45
|
+
args: [{ selector: 'ecl-gallery-footer', template: "<div class=\"ecl-gallery__footer\">\n <div class=\"ecl-gallery__info\">\n <div class=\"ecl-gallery__info-total\">\n <strong>{{ itemsCount }}</strong>{{ 'ecl.gallery.MEDIA-FILES-COUNT' | translate }}\n </div>\n @if(isShowToggleBtn) {\n @if(!isExpanded) {\n <button eclButton variant=\"ghost\" class=\"ecl-gallery__view-all\" (click)=\"onToggle()\">\n {{ 'ecl.gallery.VIEW-ALL' | translate }}\n </button>\n } @else {\n <button eclButton variant=\"ghost\" class=\"ecl-gallery__view-all\" (click)=\"onToggle()\">\n {{ 'ecl.common.COLLAPSE' | translate }}\n </button>\n }\n }\n </div>\n <hr class=\"ecl-gallery__footer-divider\" />\n <div class=\"ecl-gallery__footer-link\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
|
|
47
46
|
}], propDecorators: { toggleItems: [{
|
|
48
47
|
type: Output
|
|
49
48
|
}] } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNsLWdhbGxlcnktZm9vdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9lY2wtZ2FsbGVyeS9lY2wtZ2FsbGVyeS1mb290ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2VjbC1nYWxsZXJ5L2VjbC1nYWxsZXJ5LWZvb3Rlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGFBQWEsQ0FBQzs7OztBQUUzQyxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsWUFBWTtJQUN4RCxZQUFtQixTQUFrQjtRQUNqQyxLQUFLLEVBQUUsQ0FBQztRQURPLGNBQVMsR0FBVCxTQUFTLENBQVM7SUFFckMsQ0FBQztDQUNKO0FBS0QsTUFBTSxPQUFPLHlCQUF5QjtJQUp0QztRQUtjLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQThCLENBQUM7UUF3Qi9ELGdCQUFXLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLHFCQUFnQixHQUFHLEtBQUssQ0FBQztLQU1wQztJQTdCRyxJQUFJLFVBQVU7UUFDVixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDNUIsQ0FBQztJQUNELElBQUksVUFBVSxDQUFDLEtBQWM7UUFDekIsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQUksVUFBVTtRQUNWLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUM1QixDQUFDO0lBQ0QsSUFBSSxVQUFVLENBQUMsS0FBYTtRQUN4QixJQUFJLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQztJQUM3QixDQUFDO0lBRUQsSUFBSSxlQUFlO1FBQ2YsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7SUFDakMsQ0FBQztJQUNELElBQUksZUFBZSxDQUFDLEtBQWM7UUFDOUIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLEtBQUssQ0FBQztJQUNsQyxDQUFDO0lBTUQsUUFBUTtRQUNKLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksMEJBQTBCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDM0UsQ0FBQzt3SUEvQlEseUJBQXlCOzRIQUF6Qix5QkFBeUIsbUdDWnRDLHMzQkFzQkE7O2tHRFZhLHlCQUF5QjtrQkFKckMsU0FBUzsrQkFDSSxvQkFBb0I7OEJBSXBCLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBFY2xCYXNlRXZlbnQgfSBmcm9tICcuLi8uLi9tb2RlbCc7XG5cbmV4cG9ydCBjbGFzcyBFY2xHYWxsZXJ5VG9nZ2xlSXRlbXNFdmVudCBleHRlbmRzIEVjbEJhc2VFdmVudCB7XG4gICAgY29uc3RydWN0b3IocHVibGljIGV4cGFuZEFsbDogYm9vbGVhbikge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cbn1cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZWNsLWdhbGxlcnktZm9vdGVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZWNsLWdhbGxlcnktZm9vdGVyLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgRWNsR2FsbGVyeUZvb3RlckNvbXBvbmVudCB7XG4gICAgQE91dHB1dCgpIHRvZ2dsZUl0ZW1zID0gbmV3IEV2ZW50RW1pdHRlcjxFY2xHYWxsZXJ5VG9nZ2xlSXRlbXNFdmVudD4oKTtcblxuICAgIGdldCBpc0V4cGFuZGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5faXNFeHBhbmRlZDtcbiAgICB9XG4gICAgc2V0IGlzRXhwYW5kZWQodmFsdWU6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5faXNFeHBhbmRlZCA9IHZhbHVlO1xuICAgIH1cblxuICAgIGdldCBpdGVtc0NvdW50KCk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiB0aGlzLl9pdGVtc0NvdW50O1xuICAgIH1cbiAgICBzZXQgaXRlbXNDb3VudCh2YWx1ZTogbnVtYmVyKSB7XG4gICAgICAgIHRoaXMuX2l0ZW1zQ291bnQgPSB2YWx1ZTtcbiAgICB9XG5cbiAgICBnZXQgaXNTaG93VG9nZ2xlQnRuKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5faXNTaG93VG9nZ2xlQnRuO1xuICAgIH1cbiAgICBzZXQgaXNTaG93VG9nZ2xlQnRuKHZhbHVlOiBib29sZWFuKSB7XG4gICAgICAgIHRoaXMuX2lzU2hvd1RvZ2dsZUJ0biA9IHZhbHVlO1xuICAgIH1cblxuICAgIHByaXZhdGUgX2l0ZW1zQ291bnQ6IG51bWJlcjtcbiAgICBwcml2YXRlIF9pc0V4cGFuZGVkID0gZmFsc2U7XG4gICAgcHJpdmF0ZSBfaXNTaG93VG9nZ2xlQnRuID0gZmFsc2U7XG5cbiAgICBvblRvZ2dsZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5faXNFeHBhbmRlZCA9ICF0aGlzLl9pc0V4cGFuZGVkO1xuICAgICAgICB0aGlzLnRvZ2dsZUl0ZW1zLm5leHQobmV3IEVjbEdhbGxlcnlUb2dnbGVJdGVtc0V2ZW50KHRoaXMuaXNFeHBhbmRlZCkpO1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJlY2wtZ2FsbGVyeV9fZm9vdGVyXCI+XG4gICAgPGRpdiBjbGFzcz1cImVjbC1nYWxsZXJ5X19pbmZvXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJlY2wtZ2FsbGVyeV9faW5mby10b3RhbFwiPlxuICAgICAgICAgICAgPHN0cm9uZz57eyBpdGVtc0NvdW50IH19PC9zdHJvbmc+e3sgJ2VjbC5nYWxsZXJ5Lk1FRElBLUZJTEVTLUNPVU5UJyB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgQGlmKGlzU2hvd1RvZ2dsZUJ0bikge1xuICAgICAgICAgICAgQGlmKCFpc0V4cGFuZGVkKSB7XG4gICAgICAgICAgICA8YnV0dG9uIGVjbEJ1dHRvbiB2YXJpYW50PVwiZ2hvc3RcIiBjbGFzcz1cImVjbC1nYWxsZXJ5X192aWV3LWFsbFwiIChjbGljayk9XCJvblRvZ2dsZSgpXCI+XG4gICAgICAgICAgICAgICAge3sgJ2VjbC5nYWxsZXJ5LlZJRVctQUxMJyB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgICAgICB9IEBlbHNlIHtcbiAgICAgICAgICAgIDxidXR0b24gZWNsQnV0dG9uIHZhcmlhbnQ9XCJnaG9zdFwiIGNsYXNzPVwiZWNsLWdhbGxlcnlfX3ZpZXctYWxsXCIgKGNsaWNrKT1cIm9uVG9nZ2xlKClcIj5cbiAgICAgICAgICAgICAgICB7eyAnZWNsLmNvbW1vbi5DT0xMQVBTRScgfCB0cmFuc2xhdGUgfX1cbiAgICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgPC9kaXY+XG4gICAgPGhyIGNsYXNzPVwiZWNsLWdhbGxlcnlfX2Zvb3Rlci1kaXZpZGVyXCIgLz5cbiAgICA8ZGl2IGNsYXNzPVwiZWNsLWdhbGxlcnlfX2Zvb3Rlci1saW5rXCI+XG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Component, ContentChild, EventEmitter, HostBinding, HostListener, Input, Output } from '@angular/core';
|
|
3
|
-
import { coerceBoolean } from '@eui/base';
|
|
1
|
+
import { Component, ContentChild, EventEmitter, HostBinding, HostListener, Input, Output, booleanAttribute, } from '@angular/core';
|
|
4
2
|
import { EclBaseEvent } from '../../model/ecl-base.event';
|
|
5
3
|
import { ECLBaseDirective } from '../ecl-base.directive';
|
|
6
|
-
import { EclGalleryMediaDirective
|
|
4
|
+
import { EclGalleryMediaDirective } from './ecl-gallery-media.directive';
|
|
7
5
|
import * as i0 from "@angular/core";
|
|
8
6
|
import * as i1 from "@angular/platform-browser";
|
|
9
|
-
import * as i2 from "
|
|
10
|
-
import * as i3 from "../ecl-icon/ecl-icon.component";
|
|
7
|
+
import * as i2 from "../ecl-icon/ecl-icon.component";
|
|
11
8
|
export class EclGalleryItemClickEvent extends EclBaseEvent {
|
|
12
9
|
}
|
|
13
10
|
export class EclGalleryItemComponent extends ECLBaseDirective {
|
|
@@ -18,7 +15,6 @@ export class EclGalleryItemComponent extends ECLBaseDirective {
|
|
|
18
15
|
super();
|
|
19
16
|
this.domSanitizer = domSanitizer;
|
|
20
17
|
this.el = el;
|
|
21
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
22
18
|
this.isShareable = true;
|
|
23
19
|
this.mediaType = 'image';
|
|
24
20
|
this.itemClick = new EventEmitter();
|
|
@@ -57,30 +53,18 @@ export class EclGalleryItemComponent extends ECLBaseDirective {
|
|
|
57
53
|
get isExternalVideo() {
|
|
58
54
|
return this.mediaType === 'externalVideo';
|
|
59
55
|
}
|
|
60
|
-
/**
|
|
61
|
-
* @deprecated
|
|
62
|
-
* The name 'isDownloadable' is deprecated and should be removed as of version 18.
|
|
63
|
-
*/
|
|
64
|
-
get isDownloadable() {
|
|
65
|
-
return this.mediaType !== 'externalVideo';
|
|
66
|
-
}
|
|
67
56
|
get isOpenInFullScreenPossible() {
|
|
68
57
|
return this.mediaType !== 'externalVideo';
|
|
69
58
|
}
|
|
70
|
-
get hasPictureChild() {
|
|
71
|
-
return !!this.pictureChild;
|
|
72
|
-
}
|
|
73
59
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclGalleryItemComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
74
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
60
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-next.3", type: EclGalleryItemComponent, selector: "ecl-gallery-item", inputs: { isShareable: ["isShareable", "isShareable", booleanAttribute], mediaType: "mediaType", src: "src", label: "label", meta: "meta", description: "description", icon: "icon" }, outputs: { itemClick: "itemClick" }, host: { listeners: { "click": "onItemClick($event)" }, properties: { "class": "this.cssClasses", "attr.role": "this.role" } }, queries: [{ propertyName: "mediaChild", first: true, predicate: EclGalleryMediaDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<a [href]=\"src\" class=\"ecl-gallery__item-link\" [attr.aria-label]=\"label\" [class.ecl-gallery__item__link--frozen]=\"isNoOverlay\">\n <figure class=\"ecl-gallery__image-container\">\n @if(mediaType !== 'image') {\n <div class=\"ecl-gallery__item-icon-wrapper\">\n <ecl-icon isInverted class=\"ecl-gallery__item-icon ecl-icon--inverted\" icon=\"play-filled\" size=\"l\"></ecl-icon>\n </div>\n }\n <ng-content select=\"[eclGalleryPicture], [eclGalleryMedia], [eclGalleryImage]\"></ng-content>\n <figcaption class=\"ecl-gallery__description\">\n {{ description }}\n @if(icon) {\n <ecl-icon class=\"ecl-gallery__description-icon\" [icon]=\"icon\"></ecl-icon>\n }\n <span class=\"ecl-gallery__meta\">\n {{ meta }}\n </span>\n </figcaption>\n </figure>\n</a>", styles: [".ecl-gallery__description{width:100%}\n"], dependencies: [{ kind: "component", type: i2.EclIconComponent, selector: "ecl-icon", inputs: ["iconSet", "icon", "size", "color", "transform", "ariaLabelledby", "role", "ariaHidden", "focusable"] }] }); }
|
|
75
61
|
}
|
|
76
|
-
__decorate([
|
|
77
|
-
coerceBoolean
|
|
78
|
-
], EclGalleryItemComponent.prototype, "isShareable", void 0);
|
|
79
62
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3", ngImport: i0, type: EclGalleryItemComponent, decorators: [{
|
|
80
63
|
type: Component,
|
|
81
|
-
args: [{ selector: 'ecl-gallery-item', template: "<a [href]=\"src\" class=\"ecl-gallery__item-link\" [attr.aria-label]=\"label\" [class.ecl-gallery__item__link--frozen]=\"isNoOverlay\">\n <figure class=\"ecl-gallery__image-container\">\n
|
|
64
|
+
args: [{ selector: 'ecl-gallery-item', template: "<a [href]=\"src\" class=\"ecl-gallery__item-link\" [attr.aria-label]=\"label\" [class.ecl-gallery__item__link--frozen]=\"isNoOverlay\">\n <figure class=\"ecl-gallery__image-container\">\n @if(mediaType !== 'image') {\n <div class=\"ecl-gallery__item-icon-wrapper\">\n <ecl-icon isInverted class=\"ecl-gallery__item-icon ecl-icon--inverted\" icon=\"play-filled\" size=\"l\"></ecl-icon>\n </div>\n }\n <ng-content select=\"[eclGalleryPicture], [eclGalleryMedia], [eclGalleryImage]\"></ng-content>\n <figcaption class=\"ecl-gallery__description\">\n {{ description }}\n @if(icon) {\n <ecl-icon class=\"ecl-gallery__description-icon\" [icon]=\"icon\"></ecl-icon>\n }\n <span class=\"ecl-gallery__meta\">\n {{ meta }}\n </span>\n </figcaption>\n </figure>\n</a>", styles: [".ecl-gallery__description{width:100%}\n"] }]
|
|
82
65
|
}], ctorParameters: () => [{ type: i1.DomSanitizer }, { type: i0.ElementRef }], propDecorators: { isShareable: [{
|
|
83
|
-
type: Input
|
|
66
|
+
type: Input,
|
|
67
|
+
args: [{ transform: booleanAttribute }]
|
|
84
68
|
}], mediaType: [{
|
|
85
69
|
type: Input
|
|
86
70
|
}], src: [{
|
|
@@ -95,9 +79,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
|
|
|
95
79
|
type: Input
|
|
96
80
|
}], itemClick: [{
|
|
97
81
|
type: Output
|
|
98
|
-
}], pictureChild: [{
|
|
99
|
-
type: ContentChild,
|
|
100
|
-
args: [EclGalleryPictureDirective]
|
|
101
82
|
}], mediaChild: [{
|
|
102
83
|
type: ContentChild,
|
|
103
84
|
args: [EclGalleryMediaDirective]
|
|
@@ -111,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.3",
|
|
|
111
92
|
type: HostListener,
|
|
112
93
|
args: ['click', ['$event']]
|
|
113
94
|
}] } });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-gallery-item.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-gallery/ecl-gallery-item.component.ts","../../../../../src/lib/components/ecl-gallery/ecl-gallery-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, ElementRef, EventEmitter, HostBinding, HostListener, Input, OnInit, Output } from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { coerceBoolean } from '@eui/base';\nimport { EclBaseEvent } from '../../model/ecl-base.event';\nimport { EclGalleryItem } from '../../model/ecl-gallery-item.model';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclGalleryMediaDirective, EclGalleryPictureDirective } from './ecl-gallery-media.directive';\n\nexport class EclGalleryItemClickEvent extends EclBaseEvent {}\n\n@Component({\n    selector: 'ecl-gallery-item',\n    templateUrl: './ecl-gallery-item.component.html',\n    styles: [\n        `\n            .ecl-gallery__description {\n                width: 100%;\n            }\n        `,\n    ],\n})\nexport class EclGalleryItemComponent extends ECLBaseDirective implements EclGalleryItem, OnInit {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @coerceBoolean @Input() isShareable: boolean | any = true;\n    @Input() mediaType: 'image' | 'video' | 'externalVideo' = 'image';\n    @Input() src: string;\n    @Input() label: string;\n    @Input() meta: string;\n    @Input() description: string;\n    @Input() icon: string;\n    @Output() itemClick = new EventEmitter<EclGalleryItemClickEvent>();\n    @ContentChild(EclGalleryPictureDirective) pictureChild: EclGalleryPictureDirective;\n    @ContentChild(EclGalleryMediaDirective) mediaChild: EclGalleryMediaDirective;\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-gallery__item'), this._isHidden ? 'ecl-gallery__item--hidden' : ''].join(' ').trim();\n    }\n    @HostBinding('attr.role') role = 'listitem';\n\n    private _isNoOverlay = false;\n    private _isHidden = false;\n    private externalVideoUrl: SafeResourceUrl;\n\n    constructor(\n        private domSanitizer: DomSanitizer,\n        public el: ElementRef,\n    ) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.externalVideoUrl = this.domSanitizer.bypassSecurityTrustResourceUrl(this.src);\n    }\n\n    set isHidden(value: boolean) {\n        this._isHidden = value;\n    }\n\n    @HostListener('click', ['$event'])\n    onItemClick(evt: MouseEvent): void {\n        this.itemClick.next(new EclGalleryItemClickEvent());\n        evt.preventDefault();\n    }\n\n    getDownloadLink(): string {\n        return this.src;\n    }\n\n    getUrlExternalVideo(): SafeResourceUrl {\n        return this.externalVideoUrl;\n    }\n\n    get isNoOverlay(): boolean {\n        return this._isNoOverlay;\n    }\n\n    set isNoOverlay(value: boolean) {\n        this._isNoOverlay = value;\n    }\n\n    get isImage(): boolean {\n        return this.mediaType === 'image';\n    }\n\n    get isVideo(): boolean {\n        return this.mediaType === 'video';\n    }\n\n    get isExternalVideo(): boolean {\n        return this.mediaType === 'externalVideo';\n    }\n    /**\n     * @deprecated\n     * The name 'isDownloadable' is deprecated and should be removed as of version 18.\n     */\n    get isDownloadable(): boolean {\n        return this.mediaType !== 'externalVideo';\n    }\n\n    get isOpenInFullScreenPossible(): boolean {\n        return this.mediaType !== 'externalVideo';\n    }\n\n    get hasPictureChild(): boolean {\n        return !!this.pictureChild;\n    }\n}\n","<a [href]=\"src\" class=\"ecl-gallery__item-link\" [attr.aria-label]=\"label\" [class.ecl-gallery__item__link--frozen]=\"isNoOverlay\">\n    <figure class=\"ecl-gallery__image-container\">\n        <div *ngIf=\"mediaType !== 'image'\" class=\"ecl-gallery__item-icon-wrapper\">\n            <ecl-icon isInverted class=\"ecl-gallery__item-icon\" icon=\"play-filled\" size=\"l\"></ecl-icon>\n        </div>\n        <!-- TODO: Remove this code in 18 version -->\n        <ng-container *ngIf=\"hasPictureChild\">\n            <ng-content select=\"[eclGalleryPicture]\"></ng-content>\n        </ng-container>\n        <ng-container *ngIf=\"!hasPictureChild\">\n            <picture *ngIf=\"isImage || isExternalVideo\" class=\"ecl-picture ecl-gallery__picture\">\n                <ng-content *ngTemplateOutlet=\"galleryMedia\"></ng-content>\n            </picture>\n            <ng-container *ngIf=\"isVideo\"><ng-content *ngTemplateOutlet=\"galleryMedia\"></ng-content></ng-container>\n        </ng-container>\n        <!-- TODO: Remove the above code in 18 version -->\n        <figcaption class=\"ecl-gallery__description\">\n            {{ description }}\n            <ecl-icon *ngIf=\"icon\" class=\"ecl-gallery__description-icon\" [icon]=\"icon\"></ecl-icon>\n            <span class=\"ecl-gallery__meta\">\n                {{ meta }}\n            </span>\n        </figcaption>\n    </figure>\n</a>\n<ng-template #galleryMedia>\n    <ng-content select=\"[eclGalleryMedia], [eclGalleryImage]\"></ng-content>\n</ng-template>\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-gallery-item.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-gallery/ecl-gallery-item.component.ts","../../../../../src/lib/components/ecl-gallery/ecl-gallery-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component, ContentChild, ElementRef, EventEmitter, HostBinding, HostListener, Input, OnInit, Output,\n    booleanAttribute,\n} from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { EclBaseEvent } from '../../model/ecl-base.event';\nimport { EclGalleryItem } from '../../model/ecl-gallery-item.model';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclGalleryMediaDirective } from './ecl-gallery-media.directive';\n\nexport class EclGalleryItemClickEvent extends EclBaseEvent {}\n\n@Component({\n    selector: 'ecl-gallery-item',\n    templateUrl: './ecl-gallery-item.component.html',\n    styles: [\n        `\n            .ecl-gallery__description {\n                width: 100%;\n            }\n        `,\n    ],\n})\nexport class EclGalleryItemComponent extends ECLBaseDirective implements EclGalleryItem, OnInit {\n    @Input({ transform: booleanAttribute }) isShareable = true;\n    @Input() mediaType: 'image' | 'video' | 'externalVideo' = 'image';\n    @Input() src: string;\n    @Input() label: string;\n    @Input() meta: string;\n    @Input() description: string;\n    @Input() icon: string;\n    @Output() itemClick = new EventEmitter<EclGalleryItemClickEvent>();\n    @ContentChild(EclGalleryMediaDirective) mediaChild: EclGalleryMediaDirective;\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-gallery__item'), this._isHidden ? 'ecl-gallery__item--hidden' : ''].join(' ').trim();\n    }\n    @HostBinding('attr.role') role = 'listitem';\n\n    private _isNoOverlay = false;\n    private _isHidden = false;\n    private externalVideoUrl: SafeResourceUrl;\n\n    constructor(\n        private domSanitizer: DomSanitizer,\n        public el: ElementRef,\n    ) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.externalVideoUrl = this.domSanitizer.bypassSecurityTrustResourceUrl(this.src);\n    }\n\n    set isHidden(value: boolean) {\n        this._isHidden = value;\n    }\n\n    @HostListener('click', ['$event'])\n    onItemClick(evt: MouseEvent): void {\n        this.itemClick.next(new EclGalleryItemClickEvent());\n        evt.preventDefault();\n    }\n\n    getDownloadLink(): string {\n        return this.src;\n    }\n\n    getUrlExternalVideo(): SafeResourceUrl {\n        return this.externalVideoUrl;\n    }\n\n    get isNoOverlay(): boolean {\n        return this._isNoOverlay;\n    }\n\n    set isNoOverlay(value: boolean) {\n        this._isNoOverlay = value;\n    }\n\n    get isImage(): boolean {\n        return this.mediaType === 'image';\n    }\n\n    get isVideo(): boolean {\n        return this.mediaType === 'video';\n    }\n\n    get isExternalVideo(): boolean {\n        return this.mediaType === 'externalVideo';\n    }\n\n    get isOpenInFullScreenPossible(): boolean {\n        return this.mediaType !== 'externalVideo';\n    }\n}\n","<a [href]=\"src\" class=\"ecl-gallery__item-link\" [attr.aria-label]=\"label\" [class.ecl-gallery__item__link--frozen]=\"isNoOverlay\">\n    <figure class=\"ecl-gallery__image-container\">\n        @if(mediaType !== 'image') {\n        <div class=\"ecl-gallery__item-icon-wrapper\">\n            <ecl-icon isInverted class=\"ecl-gallery__item-icon ecl-icon--inverted\" icon=\"play-filled\" size=\"l\"></ecl-icon>\n        </div>\n        }\n        <ng-content select=\"[eclGalleryPicture], [eclGalleryMedia], [eclGalleryImage]\"></ng-content>\n        <figcaption class=\"ecl-gallery__description\">\n            {{ description }}\n            @if(icon) {\n            <ecl-icon class=\"ecl-gallery__description-icon\" [icon]=\"icon\"></ecl-icon>\n            }\n            <span class=\"ecl-gallery__meta\">\n                {{ meta }}\n            </span>\n        </figcaption>\n    </figure>\n</a>"]}
|
|
@@ -1,13 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Component,
|
|
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: "
|
|
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", "isHiddenLabel", "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
|
|
314
|
-
}], ctorParameters: () => [{ type: i1.BreakpointObserver }], propDecorators: {
|
|
315
|
-
type: Input
|
|
316
|
-
|
|
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>"]}
|