source: trip-planner-front/node_modules/primeng/fesm2020/primeng-lightbox.mjs@ 6fe77af

Last change on this file since 6fe77af was 59329aa, checked in by Ema <ema_spirova@…>, 3 years ago

adding photos

  • Property mode set to 100644
File size: 43.3 KB
Line 
1import * as i0 from '@angular/core';
2import { Component, ChangeDetectionStrategy, ViewEncapsulation, Input, NgModule } from '@angular/core';
3import * as i1 from '@angular/common';
4import { CommonModule } from '@angular/common';
5import { DomHandler } from 'primeng/dom';
6
7class 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}
164Lightbox.ɵ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 });
165Lightbox.ɵ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 });
194i0.ɵɵ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 }] } });
248class LightboxModule {
249}
250LightboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: LightboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
251LightboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: LightboxModule, declarations: [Lightbox], imports: [CommonModule], exports: [Lightbox] });
252LightboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: LightboxModule, imports: [[CommonModule]] });
253i0.ɵɵ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
266export { Lightbox, LightboxModule };
Note: See TracBrowser for help on using the repository browser.