1 | import * as i0 from '@angular/core';
|
---|
2 | import { Component, ChangeDetectionStrategy, ViewEncapsulation, Input, NgModule } from '@angular/core';
|
---|
3 | import * as i1 from '@angular/common';
|
---|
4 | import { CommonModule } from '@angular/common';
|
---|
5 | import { DomHandler } from 'primeng/dom';
|
---|
6 |
|
---|
7 | class Lightbox {
|
---|
8 | constructor(el, renderer, cd) {
|
---|
9 | this.el = el;
|
---|
10 | this.renderer = renderer;
|
---|
11 | this.cd = cd;
|
---|
12 | this.type = 'image';
|
---|
13 | this.effectDuration = '500ms';
|
---|
14 | this.autoZIndex = true;
|
---|
15 | this.baseZIndex = 0;
|
---|
16 | this.closeOnEscape = true;
|
---|
17 | }
|
---|
18 | onImageClick(event, image, i, content) {
|
---|
19 | this.index = i;
|
---|
20 | this.loading = true;
|
---|
21 | content.style.width = 32 + 'px';
|
---|
22 | content.style.height = 32 + 'px';
|
---|
23 | this.preventDocumentClickListener = true;
|
---|
24 | this.show();
|
---|
25 | this.displayImage(image);
|
---|
26 | event.preventDefault();
|
---|
27 | }
|
---|
28 | ngAfterViewInit() {
|
---|
29 | this.panel = DomHandler.findSingle(this.el.nativeElement, '.ui-lightbox ');
|
---|
30 | if (this.appendTo) {
|
---|
31 | if (this.appendTo === 'body')
|
---|
32 | document.body.appendChild(this.panel);
|
---|
33 | else
|
---|
34 | DomHandler.appendChild(this.panel, this.appendTo);
|
---|
35 | }
|
---|
36 | }
|
---|
37 | onLinkClick(event, content) {
|
---|
38 | this.preventDocumentClickListener = true;
|
---|
39 | this.show();
|
---|
40 | event.preventDefault();
|
---|
41 | }
|
---|
42 | displayImage(image) {
|
---|
43 | setTimeout(() => {
|
---|
44 | this.cd.markForCheck();
|
---|
45 | this.currentImage = image;
|
---|
46 | this.captionText = image.title;
|
---|
47 | this.center();
|
---|
48 | }, 1000);
|
---|
49 | }
|
---|
50 | show() {
|
---|
51 | this.mask = document.createElement('div');
|
---|
52 | DomHandler.addMultipleClasses(this.mask, 'ui-widget-overlay ui-dialog-mask');
|
---|
53 | document.body.appendChild(this.mask);
|
---|
54 | if (this.autoZIndex) {
|
---|
55 | this.zindex = this.baseZIndex + (++DomHandler.zindex);
|
---|
56 | }
|
---|
57 | this.mask.style.zIndex = this.zindex - 1;
|
---|
58 | this.center();
|
---|
59 | this.visible = true;
|
---|
60 | this.bindGlobalListeners();
|
---|
61 | }
|
---|
62 | hide(event) {
|
---|
63 | this.captionText = null;
|
---|
64 | this.index = null;
|
---|
65 | this.currentImage = null;
|
---|
66 | this.visible = false;
|
---|
67 | if (this.mask) {
|
---|
68 | document.body.removeChild(this.mask);
|
---|
69 | this.mask = null;
|
---|
70 | }
|
---|
71 | this.unbindGlobalListeners();
|
---|
72 | event.preventDefault();
|
---|
73 | }
|
---|
74 | center() {
|
---|
75 | let elementWidth = DomHandler.getOuterWidth(this.panel);
|
---|
76 | let elementHeight = DomHandler.getOuterHeight(this.panel);
|
---|
77 | if (elementWidth == 0 && elementHeight == 0) {
|
---|
78 | this.panel.style.visibility = 'hidden';
|
---|
79 | this.panel.style.display = 'block';
|
---|
80 | elementWidth = DomHandler.getOuterWidth(this.panel);
|
---|
81 | elementHeight = DomHandler.getOuterHeight(this.panel);
|
---|
82 | this.panel.style.display = 'none';
|
---|
83 | this.panel.style.visibility = 'visible';
|
---|
84 | }
|
---|
85 | }
|
---|
86 | onImageLoad(event, content) {
|
---|
87 | let image = event.target;
|
---|
88 | image.style.visibility = 'hidden';
|
---|
89 | image.style.display = 'block';
|
---|
90 | let imageWidth = DomHandler.getOuterWidth(image);
|
---|
91 | let imageHeight = DomHandler.getOuterHeight(image);
|
---|
92 | image.style.display = 'none';
|
---|
93 | image.style.visibility = 'visible';
|
---|
94 | content.style.width = imageWidth + 'px';
|
---|
95 | content.style.height = imageHeight + 'px';
|
---|
96 | this.panel.style.left = parseInt(this.panel.style.left) + (DomHandler.getOuterWidth(this.panel) - imageWidth) / 2 + 'px';
|
---|
97 | this.panel.style.top = parseInt(this.panel.style.top) + (DomHandler.getOuterHeight(this.panel) - imageHeight) / 2 + 'px';
|
---|
98 | setTimeout(() => {
|
---|
99 | this.cd.markForCheck();
|
---|
100 | DomHandler.fadeIn(image, 500);
|
---|
101 | image.style.display = 'block';
|
---|
102 | //this.captionText = this.currentImage.title;
|
---|
103 | this.loading = false;
|
---|
104 | }, parseInt(this.effectDuration));
|
---|
105 | }
|
---|
106 | prev(placeholder) {
|
---|
107 | this.captionText = null;
|
---|
108 | this.loading = true;
|
---|
109 | placeholder.style.display = 'none';
|
---|
110 | if (this.index > 0) {
|
---|
111 | this.displayImage(this.images[--this.index]);
|
---|
112 | }
|
---|
113 | }
|
---|
114 | next(placeholder) {
|
---|
115 | this.captionText = null;
|
---|
116 | this.loading = true;
|
---|
117 | placeholder.style.display = 'none';
|
---|
118 | if (this.index <= (this.images.length - 1)) {
|
---|
119 | this.displayImage(this.images[++this.index]);
|
---|
120 | }
|
---|
121 | }
|
---|
122 | bindGlobalListeners() {
|
---|
123 | const documentTarget = this.el ? this.el.nativeElement.ownerDocument : 'document';
|
---|
124 | this.documentClickListener = this.renderer.listen(documentTarget, 'click', (event) => {
|
---|
125 | if (!this.preventDocumentClickListener && this.visible) {
|
---|
126 | this.hide(event);
|
---|
127 | }
|
---|
128 | this.preventDocumentClickListener = false;
|
---|
129 | this.cd.markForCheck();
|
---|
130 | });
|
---|
131 | if (this.closeOnEscape && !this.documentEscapeListener) {
|
---|
132 | this.documentEscapeListener = this.renderer.listen(documentTarget, 'keydown', (event) => {
|
---|
133 | if (event.which == 27) {
|
---|
134 | if (parseInt(this.panel.style.zIndex) === (DomHandler.zindex + this.baseZIndex)) {
|
---|
135 | this.hide(event);
|
---|
136 | }
|
---|
137 | }
|
---|
138 | });
|
---|
139 | }
|
---|
140 | }
|
---|
141 | unbindGlobalListeners() {
|
---|
142 | if (this.documentEscapeListener) {
|
---|
143 | this.documentEscapeListener();
|
---|
144 | this.documentEscapeListener = null;
|
---|
145 | }
|
---|
146 | if (this.documentClickListener) {
|
---|
147 | this.documentClickListener();
|
---|
148 | this.documentClickListener = null;
|
---|
149 | }
|
---|
150 | }
|
---|
151 | get leftVisible() {
|
---|
152 | return this.images && this.images.length && this.index != 0 && !this.loading;
|
---|
153 | }
|
---|
154 | get rightVisible() {
|
---|
155 | return this.images && this.images.length && this.index < (this.images.length - 1) && !this.loading;
|
---|
156 | }
|
---|
157 | ngOnDestroy() {
|
---|
158 | this.unbindGlobalListeners();
|
---|
159 | if (this.appendTo) {
|
---|
160 | this.el.nativeElement.appendChild(this.panel);
|
---|
161 | }
|
---|
162 | }
|
---|
163 | }
|
---|
164 | Lightbox.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Lightbox, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
---|
165 | Lightbox.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.0", type: Lightbox, selector: "p-lightbox", inputs: { images: "images", type: "type", style: "style", styleClass: "styleClass", appendTo: "appendTo", easing: "easing", effectDuration: "effectDuration", autoZIndex: "autoZIndex", baseZIndex: "baseZIndex", closeOnEscape: "closeOnEscape" }, host: { classAttribute: "p-element" }, ngImport: i0, template: `
|
---|
166 | <div [ngStyle]="style" [class]="styleClass" *ngIf="(type == 'image')">
|
---|
167 | <a *ngFor="let image of images; let i = index;" [href]="image.source" (click)="onImageClick($event,image,i,content)">
|
---|
168 | <img [src]="image.thumbnail" [title]="image.title" [alt]="image.alt">
|
---|
169 | </a>
|
---|
170 | </div>
|
---|
171 | <span [ngStyle]="style" [class]="styleClass" *ngIf="(type == 'content')" (click)="onLinkClick($event,content)">
|
---|
172 | <ng-content select="a"></ng-content>
|
---|
173 | </span>
|
---|
174 | <div class="ui-lightbox ui-widget ui-corner-all ui-shadow" [style.display]="visible ? 'block' : 'none'" [style.zIndex]="zindex"
|
---|
175 | [ngClass]="{'ui-lightbox-loading': loading}"
|
---|
176 | [style.transitionProperty]="'all'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing" (click)="preventDocumentClickListener=true">
|
---|
177 | <div class="ui-lightbox-content-wrapper">
|
---|
178 | <a class="ui-state-default ui-lightbox-nav-left ui-corner-right" [style.zIndex]="zindex + 1" (click)="prev(img)"
|
---|
179 | [ngClass]="{'ui-helper-hidden':!leftVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-left"></span></a>
|
---|
180 | <div #content class="ui-lightbox-content ui-corner-all"
|
---|
181 | [style.transitionProperty]="'width,height'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing">
|
---|
182 | <img #img [src]="currentImage ? currentImage.source||'' : ''" (load)="onImageLoad($event,content)" style="display:none">
|
---|
183 | <ng-content></ng-content>
|
---|
184 | </div>
|
---|
185 | <a class="ui-state-default ui-lightbox-nav-right ui-corner-left ui-helper-hidden" [style.zIndex]="zindex + 1" (click)="next(img)"
|
---|
186 | [ngClass]="{'ui-helper-hidden':!rightVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-right"></span></a>
|
---|
187 | </div>
|
---|
188 | <div class="ui-lightbox-caption ui-widget-header" [style.display]="captionText ? 'block' : 'none'">
|
---|
189 | <span class="ui-lightbox-caption-text">{{captionText}}</span><a class="ui-lightbox-close ui-corner-all" tabindex="0" (click)="hide($event)" (keydown.enter)="hide($event)"><span class="pi pi-times"></span></a>
|
---|
190 | <div style="clear:both"></div>
|
---|
191 | </div>
|
---|
192 | </div>
|
---|
193 | `, isInline: true, styles: [".ui-lightbox{position:fixed;display:none;top:50%;left:50%;transform:translate(-50%) translateY(-50%)}.ui-lightbox-content-wrapper{position:relative}.ui-lightbox-content{position:relative;margin:0;padding:0;background-color:#000}.ui-lightbox-nav-right,.ui-lightbox-nav-left{position:absolute;top:50%;cursor:pointer}.ui-lightbox-nav-left{left:0}.ui-lightbox-nav-right{right:0}.ui-lightbox-loading .ui-lightbox-content{background:url() #000000 center center no-repeat}.ui-lightbox-caption{padding:.2em .4em;display:none}.ui-lightbox-caption-text{margin:.3em 0 .1em;float:left}.ui-lightbox-close{float:right;margin:0;padding:.125em}.ui-lightbox-close.ui-state-hover{padding:0}.ui-lightbox-nav-left,.ui-lightbox-nav-right{opacity:.5}.ui-lightbox-nav-left:hover,.ui-lightbox-nav-right:hover{opacity:1}\n", ".p-dialog-mask{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;pointer-events:none}.p-dialog-mask.p-component-overlay{pointer-events:auto}.p-dialog{display:flex;flex-direction:column;pointer-events:auto;max-height:90%;transform:scale(1);position:relative}.p-dialog-content{overflow-y:auto;flex-grow:1}.p-dialog-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.p-dialog-footer{flex-shrink:0}.p-dialog .p-dialog-header-icons{display:flex;align-items:center}.p-dialog .p-dialog-header-icon{display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.p-fluid .p-dialog-footer .p-button{width:auto}.p-dialog-top .p-dialog,.p-dialog-bottom .p-dialog,.p-dialog-left .p-dialog,.p-dialog-right .p-dialog,.p-dialog-top-left .p-dialog,.p-dialog-top-right .p-dialog,.p-dialog-bottom-left .p-dialog,.p-dialog-bottom-right .p-dialog{margin:.75rem;transform:translate(0)}.p-dialog-maximized{transition:none;transform:none;width:100vw!important;height:100vh!important;top:0px!important;left:0px!important;max-height:100%;height:100%}.p-dialog-maximized .p-dialog-content{flex-grow:1}.p-dialog-left{justify-content:flex-start}.p-dialog-right{justify-content:flex-end}.p-dialog-top{align-items:flex-start}.p-dialog-top-left{justify-content:flex-start;align-items:flex-start}.p-dialog-top-right{justify-content:flex-end;align-items:flex-start}.p-dialog-bottom{align-items:flex-end}.p-dialog-bottom-left{justify-content:flex-start;align-items:flex-end}.p-dialog-bottom-right{justify-content:flex-end;align-items:flex-end}.p-dialog .p-resizable-handle{position:absolute;font-size:.1px;display:block;cursor:se-resize;width:12px;height:12px;right:1px;bottom:1px}.p-confirm-dialog .p-dialog-content{display:flex;align-items:center}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
---|
194 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Lightbox, decorators: [{
|
---|
195 | type: Component,
|
---|
196 | args: [{ selector: 'p-lightbox', template: `
|
---|
197 | <div [ngStyle]="style" [class]="styleClass" *ngIf="(type == 'image')">
|
---|
198 | <a *ngFor="let image of images; let i = index;" [href]="image.source" (click)="onImageClick($event,image,i,content)">
|
---|
199 | <img [src]="image.thumbnail" [title]="image.title" [alt]="image.alt">
|
---|
200 | </a>
|
---|
201 | </div>
|
---|
202 | <span [ngStyle]="style" [class]="styleClass" *ngIf="(type == 'content')" (click)="onLinkClick($event,content)">
|
---|
203 | <ng-content select="a"></ng-content>
|
---|
204 | </span>
|
---|
205 | <div class="ui-lightbox ui-widget ui-corner-all ui-shadow" [style.display]="visible ? 'block' : 'none'" [style.zIndex]="zindex"
|
---|
206 | [ngClass]="{'ui-lightbox-loading': loading}"
|
---|
207 | [style.transitionProperty]="'all'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing" (click)="preventDocumentClickListener=true">
|
---|
208 | <div class="ui-lightbox-content-wrapper">
|
---|
209 | <a class="ui-state-default ui-lightbox-nav-left ui-corner-right" [style.zIndex]="zindex + 1" (click)="prev(img)"
|
---|
210 | [ngClass]="{'ui-helper-hidden':!leftVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-left"></span></a>
|
---|
211 | <div #content class="ui-lightbox-content ui-corner-all"
|
---|
212 | [style.transitionProperty]="'width,height'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing">
|
---|
213 | <img #img [src]="currentImage ? currentImage.source||'' : ''" (load)="onImageLoad($event,content)" style="display:none">
|
---|
214 | <ng-content></ng-content>
|
---|
215 | </div>
|
---|
216 | <a class="ui-state-default ui-lightbox-nav-right ui-corner-left ui-helper-hidden" [style.zIndex]="zindex + 1" (click)="next(img)"
|
---|
217 | [ngClass]="{'ui-helper-hidden':!rightVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-right"></span></a>
|
---|
218 | </div>
|
---|
219 | <div class="ui-lightbox-caption ui-widget-header" [style.display]="captionText ? 'block' : 'none'">
|
---|
220 | <span class="ui-lightbox-caption-text">{{captionText}}</span><a class="ui-lightbox-close ui-corner-all" tabindex="0" (click)="hide($event)" (keydown.enter)="hide($event)"><span class="pi pi-times"></span></a>
|
---|
221 | <div style="clear:both"></div>
|
---|
222 | </div>
|
---|
223 | </div>
|
---|
224 | `, changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, host: {
|
---|
225 | 'class': 'p-element'
|
---|
226 | }, styles: [".ui-lightbox{position:fixed;display:none;top:50%;left:50%;transform:translate(-50%) translateY(-50%)}.ui-lightbox-content-wrapper{position:relative}.ui-lightbox-content{position:relative;margin:0;padding:0;background-color:#000}.ui-lightbox-nav-right,.ui-lightbox-nav-left{position:absolute;top:50%;cursor:pointer}.ui-lightbox-nav-left{left:0}.ui-lightbox-nav-right{right:0}.ui-lightbox-loading .ui-lightbox-content{background:url() #000000 center center no-repeat}.ui-lightbox-caption{padding:.2em .4em;display:none}.ui-lightbox-caption-text{margin:.3em 0 .1em;float:left}.ui-lightbox-close{float:right;margin:0;padding:.125em}.ui-lightbox-close.ui-state-hover{padding:0}.ui-lightbox-nav-left,.ui-lightbox-nav-right{opacity:.5}.ui-lightbox-nav-left:hover,.ui-lightbox-nav-right:hover{opacity:1}\n", ".p-dialog-mask{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;pointer-events:none}.p-dialog-mask.p-component-overlay{pointer-events:auto}.p-dialog{display:flex;flex-direction:column;pointer-events:auto;max-height:90%;transform:scale(1);position:relative}.p-dialog-content{overflow-y:auto;flex-grow:1}.p-dialog-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.p-dialog-footer{flex-shrink:0}.p-dialog .p-dialog-header-icons{display:flex;align-items:center}.p-dialog .p-dialog-header-icon{display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.p-fluid .p-dialog-footer .p-button{width:auto}.p-dialog-top .p-dialog,.p-dialog-bottom .p-dialog,.p-dialog-left .p-dialog,.p-dialog-right .p-dialog,.p-dialog-top-left .p-dialog,.p-dialog-top-right .p-dialog,.p-dialog-bottom-left .p-dialog,.p-dialog-bottom-right .p-dialog{margin:.75rem;transform:translate(0)}.p-dialog-maximized{transition:none;transform:none;width:100vw!important;height:100vh!important;top:0px!important;left:0px!important;max-height:100%;height:100%}.p-dialog-maximized .p-dialog-content{flex-grow:1}.p-dialog-left{justify-content:flex-start}.p-dialog-right{justify-content:flex-end}.p-dialog-top{align-items:flex-start}.p-dialog-top-left{justify-content:flex-start;align-items:flex-start}.p-dialog-top-right{justify-content:flex-end;align-items:flex-start}.p-dialog-bottom{align-items:flex-end}.p-dialog-bottom-left{justify-content:flex-start;align-items:flex-end}.p-dialog-bottom-right{justify-content:flex-end;align-items:flex-end}.p-dialog .p-resizable-handle{position:absolute;font-size:.1px;display:block;cursor:se-resize;width:12px;height:12px;right:1px;bottom:1px}.p-confirm-dialog .p-dialog-content{display:flex;align-items:center}\n"] }]
|
---|
227 | }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { images: [{
|
---|
228 | type: Input
|
---|
229 | }], type: [{
|
---|
230 | type: Input
|
---|
231 | }], style: [{
|
---|
232 | type: Input
|
---|
233 | }], styleClass: [{
|
---|
234 | type: Input
|
---|
235 | }], appendTo: [{
|
---|
236 | type: Input
|
---|
237 | }], easing: [{
|
---|
238 | type: Input
|
---|
239 | }], effectDuration: [{
|
---|
240 | type: Input
|
---|
241 | }], autoZIndex: [{
|
---|
242 | type: Input
|
---|
243 | }], baseZIndex: [{
|
---|
244 | type: Input
|
---|
245 | }], closeOnEscape: [{
|
---|
246 | type: Input
|
---|
247 | }] } });
|
---|
248 | class LightboxModule {
|
---|
249 | }
|
---|
250 | LightboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: LightboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
---|
251 | LightboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: LightboxModule, declarations: [Lightbox], imports: [CommonModule], exports: [Lightbox] });
|
---|
252 | LightboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: LightboxModule, imports: [[CommonModule]] });
|
---|
253 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: LightboxModule, decorators: [{
|
---|
254 | type: NgModule,
|
---|
255 | args: [{
|
---|
256 | imports: [CommonModule],
|
---|
257 | exports: [Lightbox],
|
---|
258 | declarations: [Lightbox]
|
---|
259 | }]
|
---|
260 | }] });
|
---|
261 |
|
---|
262 | /**
|
---|
263 | * Generated bundle index. Do not edit.
|
---|
264 | */
|
---|
265 |
|
---|
266 | export { Lightbox, LightboxModule };
|
---|