source: trip-planner-front/node_modules/primeng/esm2020/carousel/carousel.mjs@ bdd6491

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

adding photos

  • Property mode set to 100644
File size: 80.5 KB
Line 
1import { Component, Input, ViewChild, ContentChildren, NgModule, EventEmitter, Output, ContentChild, ChangeDetectionStrategy, ViewEncapsulation } from '@angular/core';
2import { PrimeTemplate, SharedModule, Header, Footer } from 'primeng/api';
3import { RippleModule } from 'primeng/ripple';
4import { CommonModule } from '@angular/common';
5import { UniqueComponentId } from 'primeng/utils';
6import * as i0 from "@angular/core";
7import * as i1 from "@angular/common";
8import * as i2 from "primeng/ripple";
9export class Carousel {
10 constructor(el, zone, cd) {
11 this.el = el;
12 this.zone = zone;
13 this.cd = cd;
14 this.orientation = "horizontal";
15 this.verticalViewPortHeight = "300px";
16 this.contentClass = "";
17 this.indicatorsContentClass = "";
18 this.indicatorStyleClass = "";
19 this.circular = false;
20 this.showIndicators = true;
21 this.showNavigators = true;
22 this.autoplayInterval = 0;
23 this.onPage = new EventEmitter();
24 this._numVisible = 1;
25 this._numScroll = 1;
26 this._oldNumScroll = 0;
27 this.prevState = {
28 numScroll: 0,
29 numVisible: 0,
30 value: []
31 };
32 this.defaultNumScroll = 1;
33 this.defaultNumVisible = 1;
34 this._page = 0;
35 this.isRemainingItemsAdded = false;
36 this.remainingItems = 0;
37 this.swipeThreshold = 20;
38 this.totalShiftedItems = this.page * this.numScroll * -1;
39 }
40 get page() {
41 return this._page;
42 }
43 set page(val) {
44 if (this.isCreated && val !== this._page) {
45 if (this.autoplayInterval) {
46 this.stopAutoplay();
47 this.allowAutoplay = false;
48 }
49 if (val > this._page && val <= (this.totalDots() - 1)) {
50 this.step(-1, val);
51 }
52 else if (val < this._page) {
53 this.step(1, val);
54 }
55 }
56 this._page = val;
57 }
58 get numVisible() {
59 return this._numVisible;
60 }
61 set numVisible(val) {
62 this._numVisible = val;
63 }
64 get numScroll() {
65 return this._numVisible;
66 }
67 set numScroll(val) {
68 this._numScroll = val;
69 }
70 get value() {
71 return this._value;
72 }
73 ;
74 set value(val) {
75 this._value = val;
76 }
77 ngOnChanges(simpleChange) {
78 if (simpleChange.value) {
79 if (this.circular && this._value) {
80 this.setCloneItems();
81 }
82 }
83 if (this.isCreated) {
84 if (simpleChange.numVisible) {
85 if (this.responsiveOptions) {
86 this.defaultNumVisible = this.numVisible;
87 }
88 if (this.isCircular()) {
89 this.setCloneItems();
90 }
91 this.createStyle();
92 this.calculatePosition();
93 }
94 if (simpleChange.numScroll) {
95 if (this.responsiveOptions) {
96 this.defaultNumScroll = this.numScroll;
97 }
98 }
99 }
100 }
101 ngAfterContentInit() {
102 this.id = UniqueComponentId();
103 this.allowAutoplay = !!this.autoplayInterval;
104 if (this.circular) {
105 this.setCloneItems();
106 }
107 if (this.responsiveOptions) {
108 this.defaultNumScroll = this._numScroll;
109 this.defaultNumVisible = this._numVisible;
110 }
111 this.createStyle();
112 this.calculatePosition();
113 if (this.responsiveOptions) {
114 this.bindDocumentListeners();
115 }
116 this.templates.forEach((item) => {
117 switch (item.getType()) {
118 case 'item':
119 this.itemTemplate = item.template;
120 break;
121 case 'header':
122 this.headerTemplate = item.template;
123 break;
124 case 'footer':
125 this.footerTemplate = item.template;
126 break;
127 default:
128 this.itemTemplate = item.template;
129 break;
130 }
131 });
132 }
133 ngAfterContentChecked() {
134 const isCircular = this.isCircular();
135 let totalShiftedItems = this.totalShiftedItems;
136 if (this.value && this.itemsContainer && (this.prevState.numScroll !== this._numScroll || this.prevState.numVisible !== this._numVisible || this.prevState.value.length !== this.value.length)) {
137 if (this.autoplayInterval) {
138 this.stopAutoplay();
139 }
140 this.remainingItems = (this.value.length - this._numVisible) % this._numScroll;
141 let page = this._page;
142 if (this.totalDots() !== 0 && page >= this.totalDots()) {
143 page = this.totalDots() - 1;
144 this._page = page;
145 this.onPage.emit({
146 page: this.page
147 });
148 }
149 totalShiftedItems = (page * this._numScroll) * -1;
150 if (isCircular) {
151 totalShiftedItems -= this._numVisible;
152 }
153 if (page === (this.totalDots() - 1) && this.remainingItems > 0) {
154 totalShiftedItems += (-1 * this.remainingItems) + this._numScroll;
155 this.isRemainingItemsAdded = true;
156 }
157 else {
158 this.isRemainingItemsAdded = false;
159 }
160 if (totalShiftedItems !== this.totalShiftedItems) {
161 this.totalShiftedItems = totalShiftedItems;
162 }
163 this._oldNumScroll = this._numScroll;
164 this.prevState.numScroll = this._numScroll;
165 this.prevState.numVisible = this._numVisible;
166 this.prevState.value = [...this._value];
167 if (this.totalDots() > 0 && this.itemsContainer.nativeElement) {
168 this.itemsContainer.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100 / this._numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100 / this._numVisible)}%, 0, 0)`;
169 }
170 this.isCreated = true;
171 if (this.autoplayInterval && this.isAutoplay()) {
172 this.startAutoplay();
173 }
174 }
175 if (isCircular) {
176 if (this.page === 0) {
177 totalShiftedItems = -1 * this._numVisible;
178 }
179 else if (totalShiftedItems === 0) {
180 totalShiftedItems = -1 * this.value.length;
181 if (this.remainingItems > 0) {
182 this.isRemainingItemsAdded = true;
183 }
184 }
185 if (totalShiftedItems !== this.totalShiftedItems) {
186 this.totalShiftedItems = totalShiftedItems;
187 }
188 }
189 }
190 createStyle() {
191 if (!this.carouselStyle) {
192 this.carouselStyle = document.createElement('style');
193 this.carouselStyle.type = 'text/css';
194 document.body.appendChild(this.carouselStyle);
195 }
196 let innerHTML = `
197 #${this.id} .p-carousel-item {
198 flex: 1 0 ${(100 / this.numVisible)}%
199 }
200 `;
201 if (this.responsiveOptions) {
202 this.responsiveOptions.sort((data1, data2) => {
203 const value1 = data1.breakpoint;
204 const value2 = data2.breakpoint;
205 let result = null;
206 if (value1 == null && value2 != null)
207 result = -1;
208 else if (value1 != null && value2 == null)
209 result = 1;
210 else if (value1 == null && value2 == null)
211 result = 0;
212 else if (typeof value1 === 'string' && typeof value2 === 'string')
213 result = value1.localeCompare(value2, undefined, { numeric: true });
214 else
215 result = (value1 < value2) ? -1 : (value1 > value2) ? 1 : 0;
216 return -1 * result;
217 });
218 for (let i = 0; i < this.responsiveOptions.length; i++) {
219 let res = this.responsiveOptions[i];
220 innerHTML += `
221 @media screen and (max-width: ${res.breakpoint}) {
222 #${this.id} .p-carousel-item {
223 flex: 1 0 ${(100 / res.numVisible)}%
224 }
225 }
226 `;
227 }
228 }
229 this.carouselStyle.innerHTML = innerHTML;
230 }
231 calculatePosition() {
232 if (this.responsiveOptions) {
233 let windowWidth = window.innerWidth;
234 let matchedResponsiveData = {
235 numVisible: this.defaultNumVisible,
236 numScroll: this.defaultNumScroll
237 };
238 for (let i = 0; i < this.responsiveOptions.length; i++) {
239 let res = this.responsiveOptions[i];
240 if (parseInt(res.breakpoint, 10) >= windowWidth) {
241 matchedResponsiveData = res;
242 }
243 }
244 if (this._numScroll !== matchedResponsiveData.numScroll) {
245 let page = this._page;
246 page = Math.floor((page * this._numScroll) / matchedResponsiveData.numScroll);
247 let totalShiftedItems = (matchedResponsiveData.numScroll * this.page) * -1;
248 if (this.isCircular()) {
249 totalShiftedItems -= matchedResponsiveData.numVisible;
250 }
251 this.totalShiftedItems = totalShiftedItems;
252 this._numScroll = matchedResponsiveData.numScroll;
253 this._page = page;
254 this.onPage.emit({
255 page: this.page
256 });
257 }
258 if (this._numVisible !== matchedResponsiveData.numVisible) {
259 this._numVisible = matchedResponsiveData.numVisible;
260 this.setCloneItems();
261 }
262 this.cd.markForCheck();
263 }
264 }
265 setCloneItems() {
266 this.clonedItemsForStarting = [];
267 this.clonedItemsForFinishing = [];
268 if (this.isCircular()) {
269 this.clonedItemsForStarting.push(...this.value.slice(-1 * this._numVisible));
270 this.clonedItemsForFinishing.push(...this.value.slice(0, this._numVisible));
271 }
272 }
273 firstIndex() {
274 return this.isCircular() ? (-1 * (this.totalShiftedItems + this.numVisible)) : (this.totalShiftedItems * -1);
275 }
276 lastIndex() {
277 return this.firstIndex() + this.numVisible - 1;
278 }
279 totalDots() {
280 return this.value ? Math.ceil((this.value.length - this._numVisible) / this._numScroll) + 1 : 0;
281 }
282 totalDotsArray() {
283 const totalDots = this.totalDots();
284 return totalDots <= 0 ? [] : Array(totalDots).fill(0);
285 }
286 isVertical() {
287 return this.orientation === 'vertical';
288 }
289 isCircular() {
290 return this.circular && this.value && this.value.length >= this.numVisible;
291 }
292 isAutoplay() {
293 return this.autoplayInterval && this.allowAutoplay;
294 }
295 isForwardNavDisabled() {
296 return this.isEmpty() || (this._page >= (this.totalDots() - 1) && !this.isCircular());
297 }
298 isBackwardNavDisabled() {
299 return this.isEmpty() || (this._page <= 0 && !this.isCircular());
300 }
301 isEmpty() {
302 return !this.value || this.value.length === 0;
303 }
304 navForward(e, index) {
305 if (this.isCircular() || this._page < (this.totalDots() - 1)) {
306 this.step(-1, index);
307 }
308 if (this.autoplayInterval) {
309 this.stopAutoplay();
310 this.allowAutoplay = false;
311 }
312 if (e && e.cancelable) {
313 e.preventDefault();
314 }
315 }
316 navBackward(e, index) {
317 if (this.isCircular() || this._page !== 0) {
318 this.step(1, index);
319 }
320 if (this.autoplayInterval) {
321 this.stopAutoplay();
322 this.allowAutoplay = false;
323 }
324 if (e && e.cancelable) {
325 e.preventDefault();
326 }
327 }
328 onDotClick(e, index) {
329 let page = this._page;
330 if (this.autoplayInterval) {
331 this.stopAutoplay();
332 this.allowAutoplay = false;
333 }
334 if (index > page) {
335 this.navForward(e, index);
336 }
337 else if (index < page) {
338 this.navBackward(e, index);
339 }
340 }
341 step(dir, page) {
342 let totalShiftedItems = this.totalShiftedItems;
343 const isCircular = this.isCircular();
344 if (page != null) {
345 totalShiftedItems = (this._numScroll * page) * -1;
346 if (isCircular) {
347 totalShiftedItems -= this._numVisible;
348 }
349 this.isRemainingItemsAdded = false;
350 }
351 else {
352 totalShiftedItems += (this._numScroll * dir);
353 if (this.isRemainingItemsAdded) {
354 totalShiftedItems += this.remainingItems - (this._numScroll * dir);
355 this.isRemainingItemsAdded = false;
356 }
357 let originalShiftedItems = isCircular ? (totalShiftedItems + this._numVisible) : totalShiftedItems;
358 page = Math.abs(Math.floor((originalShiftedItems / this._numScroll)));
359 }
360 if (isCircular && this.page === (this.totalDots() - 1) && dir === -1) {
361 totalShiftedItems = -1 * (this.value.length + this._numVisible);
362 page = 0;
363 }
364 else if (isCircular && this.page === 0 && dir === 1) {
365 totalShiftedItems = 0;
366 page = (this.totalDots() - 1);
367 }
368 else if (page === (this.totalDots() - 1) && this.remainingItems > 0) {
369 totalShiftedItems += ((this.remainingItems * -1) - (this._numScroll * dir));
370 this.isRemainingItemsAdded = true;
371 }
372 if (this.itemsContainer) {
373 this.itemsContainer.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100 / this._numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100 / this._numVisible)}%, 0, 0)`;
374 this.itemsContainer.nativeElement.style.transition = 'transform 500ms ease 0s';
375 }
376 this.totalShiftedItems = totalShiftedItems;
377 this._page = page;
378 this.onPage.emit({
379 page: this.page
380 });
381 }
382 startAutoplay() {
383 this.interval = setInterval(() => {
384 if (this.totalDots() > 0) {
385 if (this.page === (this.totalDots() - 1)) {
386 this.step(-1, 0);
387 }
388 else {
389 this.step(-1, this.page + 1);
390 }
391 }
392 }, this.autoplayInterval);
393 }
394 stopAutoplay() {
395 if (this.interval) {
396 clearInterval(this.interval);
397 }
398 }
399 onTransitionEnd() {
400 if (this.itemsContainer) {
401 this.itemsContainer.nativeElement.style.transition = '';
402 if ((this.page === 0 || this.page === (this.totalDots() - 1)) && this.isCircular()) {
403 this.itemsContainer.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${this.totalShiftedItems * (100 / this._numVisible)}%, 0)` : `translate3d(${this.totalShiftedItems * (100 / this._numVisible)}%, 0, 0)`;
404 }
405 }
406 }
407 onTouchStart(e) {
408 let touchobj = e.changedTouches[0];
409 this.startPos = {
410 x: touchobj.pageX,
411 y: touchobj.pageY
412 };
413 }
414 onTouchMove(e) {
415 if (e.cancelable) {
416 e.preventDefault();
417 }
418 }
419 onTouchEnd(e) {
420 let touchobj = e.changedTouches[0];
421 if (this.isVertical()) {
422 this.changePageOnTouch(e, (touchobj.pageY - this.startPos.y));
423 }
424 else {
425 this.changePageOnTouch(e, (touchobj.pageX - this.startPos.x));
426 }
427 }
428 changePageOnTouch(e, diff) {
429 if (Math.abs(diff) > this.swipeThreshold) {
430 if (diff < 0) {
431 this.navForward(e);
432 }
433 else {
434 this.navBackward(e);
435 }
436 }
437 }
438 bindDocumentListeners() {
439 if (!this.documentResizeListener) {
440 this.documentResizeListener = (e) => {
441 this.calculatePosition();
442 };
443 window.addEventListener('resize', this.documentResizeListener);
444 }
445 }
446 unbindDocumentListeners() {
447 if (this.documentResizeListener) {
448 window.removeEventListener('resize', this.documentResizeListener);
449 this.documentResizeListener = null;
450 }
451 }
452 ngOnDestroy() {
453 if (this.responsiveOptions) {
454 this.unbindDocumentListeners();
455 }
456 if (this.autoplayInterval) {
457 this.stopAutoplay();
458 }
459 }
460}
461Carousel.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Carousel, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
462Carousel.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.0", type: Carousel, selector: "p-carousel", inputs: { page: "page", numVisible: "numVisible", numScroll: "numScroll", responsiveOptions: "responsiveOptions", orientation: "orientation", verticalViewPortHeight: "verticalViewPortHeight", contentClass: "contentClass", indicatorsContentClass: "indicatorsContentClass", indicatorsContentStyle: "indicatorsContentStyle", indicatorStyleClass: "indicatorStyleClass", indicatorStyle: "indicatorStyle", value: "value", circular: "circular", showIndicators: "showIndicators", showNavigators: "showNavigators", autoplayInterval: "autoplayInterval", style: "style", styleClass: "styleClass" }, outputs: { onPage: "onPage" }, host: { classAttribute: "p-element" }, queries: [{ propertyName: "headerFacet", first: true, predicate: Header, descendants: true }, { propertyName: "footerFacet", first: true, predicate: Footer, descendants: true }, { propertyName: "templates", predicate: PrimeTemplate }], viewQueries: [{ propertyName: "itemsContainer", first: true, predicate: ["itemsContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
463 <div [attr.id]="id" [ngClass]="{'p-carousel p-component':true, 'p-carousel-vertical': isVertical(), 'p-carousel-horizontal': !isVertical()}" [ngStyle]="style" [class]="styleClass">
464 <div class="p-carousel-header" *ngIf="headerFacet || headerTemplate">
465 <ng-content select="p-header"></ng-content>
466 <ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
467 </div>
468 <div [class]="contentClass" [ngClass]="'p-carousel-content'">
469 <div class="p-carousel-container">
470 <button type="button" *ngIf="showNavigators" [ngClass]="{'p-carousel-prev p-link':true, 'p-disabled': isBackwardNavDisabled()}" [disabled]="isBackwardNavDisabled()" (click)="navBackward($event)" pRipple>
471 <span [ngClass]="{'p-carousel-prev-icon pi': true, 'pi-chevron-left': !isVertical(), 'pi-chevron-up': isVertical()}"></span>
472 </button>
473 <div class="p-carousel-items-content" [ngStyle]="{'height': isVertical() ? verticalViewPortHeight : 'auto'}">
474 <div #itemsContainer class="p-carousel-items-container" (transitionend)="onTransitionEnd()" (touchend)="onTouchEnd($event)" (touchstart)="onTouchStart($event)" (touchmove)="onTouchMove($event)">
475 <div *ngFor="let item of clonedItemsForStarting; let index = index" [ngClass]= "{'p-carousel-item p-carousel-item-cloned': true,
476 'p-carousel-item-active': (totalShiftedItems * -1) === (value.length),
477 'p-carousel-item-start': 0 === index,
478 'p-carousel-item-end': (clonedItemsForStarting.length - 1) === index}">
479 <ng-container *ngTemplateOutlet="itemTemplate; context: {$implicit: item}"></ng-container>
480 </div>
481 <div *ngFor="let item of value; let index = index" [ngClass]= "{'p-carousel-item': true,
482 'p-carousel-item-active': (firstIndex() <= index && lastIndex() >= index),
483 'p-carousel-item-start': firstIndex() === index,
484 'p-carousel-item-end': lastIndex() === index}">
485 <ng-container *ngTemplateOutlet="itemTemplate; context: {$implicit: item}"></ng-container>
486 </div>
487 <div *ngFor="let item of clonedItemsForFinishing; let index = index" [ngClass]= "{'p-carousel-item p-carousel-item-cloned': true,
488 'p-carousel-item-active': ((totalShiftedItems *-1) === numVisible),
489 'p-carousel-item-start': 0 === index,
490 'p-carousel-item-end': (clonedItemsForFinishing.length - 1) === index}">
491 <ng-container *ngTemplateOutlet="itemTemplate; context: {$implicit: item}"></ng-container>
492 </div>
493 </div>
494 </div>
495 <button type="button" *ngIf="showNavigators" [ngClass]="{'p-carousel-next p-link': true, 'p-disabled': isForwardNavDisabled()}" [disabled]="isForwardNavDisabled()" (click)="navForward($event)" pRipple>
496 <span [ngClass]="{'p-carousel-prev-icon pi': true, 'pi-chevron-right': !isVertical(), 'pi-chevron-down': isVertical()}"></span>
497 </button>
498 </div>
499 <ul [ngClass]="'p-carousel-indicators p-reset'" [class]="indicatorsContentClass" [ngStyle]="indicatorsContentStyle" *ngIf="showIndicators">
500 <li *ngFor="let totalDot of totalDotsArray(); let i = index" [ngClass]="{'p-carousel-indicator':true,'p-highlight': _page === i}">
501 <button type="button" [ngClass]="'p-link'" (click)="onDotClick($event, i)" [class]="indicatorStyleClass" [ngStyle]="indicatorStyle"></button>
502 </li>
503 </ul>
504 </div>
505 <div class="p-carousel-footer" *ngIf="footerFacet || footerTemplate">
506 <ng-content select="p-footer"></ng-content>
507 <ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
508 </div>
509 </div>
510 `, isInline: true, styles: [".p-carousel{display:flex;flex-direction:column}.p-carousel-content{display:flex;flex-direction:column;overflow:auto}.p-carousel-prev,.p-carousel-next{align-self:center;flex-grow:0;flex-shrink:0;display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.p-carousel-container{display:flex;flex-direction:row}.p-carousel-items-content{overflow:hidden;width:100%}.p-carousel-items-container{display:flex;flex-direction:row}.p-carousel-indicators{display:flex;flex-direction:row;justify-content:center;flex-wrap:wrap}.p-carousel-indicator>button{display:flex;align-items:center;justify-content:center}.p-carousel-vertical .p-carousel-container{flex-direction:column}.p-carousel-vertical .p-carousel-items-container{flex-direction:column;height:100%}.p-items-hidden .p-carousel-item{visibility:hidden}.p-items-hidden .p-carousel-item.p-carousel-item-active{visibility:visible}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.Ripple, selector: "[pRipple]" }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
511i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Carousel, decorators: [{
512 type: Component,
513 args: [{ selector: 'p-carousel', template: `
514 <div [attr.id]="id" [ngClass]="{'p-carousel p-component':true, 'p-carousel-vertical': isVertical(), 'p-carousel-horizontal': !isVertical()}" [ngStyle]="style" [class]="styleClass">
515 <div class="p-carousel-header" *ngIf="headerFacet || headerTemplate">
516 <ng-content select="p-header"></ng-content>
517 <ng-container *ngTemplateOutlet="headerTemplate"></ng-container>
518 </div>
519 <div [class]="contentClass" [ngClass]="'p-carousel-content'">
520 <div class="p-carousel-container">
521 <button type="button" *ngIf="showNavigators" [ngClass]="{'p-carousel-prev p-link':true, 'p-disabled': isBackwardNavDisabled()}" [disabled]="isBackwardNavDisabled()" (click)="navBackward($event)" pRipple>
522 <span [ngClass]="{'p-carousel-prev-icon pi': true, 'pi-chevron-left': !isVertical(), 'pi-chevron-up': isVertical()}"></span>
523 </button>
524 <div class="p-carousel-items-content" [ngStyle]="{'height': isVertical() ? verticalViewPortHeight : 'auto'}">
525 <div #itemsContainer class="p-carousel-items-container" (transitionend)="onTransitionEnd()" (touchend)="onTouchEnd($event)" (touchstart)="onTouchStart($event)" (touchmove)="onTouchMove($event)">
526 <div *ngFor="let item of clonedItemsForStarting; let index = index" [ngClass]= "{'p-carousel-item p-carousel-item-cloned': true,
527 'p-carousel-item-active': (totalShiftedItems * -1) === (value.length),
528 'p-carousel-item-start': 0 === index,
529 'p-carousel-item-end': (clonedItemsForStarting.length - 1) === index}">
530 <ng-container *ngTemplateOutlet="itemTemplate; context: {$implicit: item}"></ng-container>
531 </div>
532 <div *ngFor="let item of value; let index = index" [ngClass]= "{'p-carousel-item': true,
533 'p-carousel-item-active': (firstIndex() <= index && lastIndex() >= index),
534 'p-carousel-item-start': firstIndex() === index,
535 'p-carousel-item-end': lastIndex() === index}">
536 <ng-container *ngTemplateOutlet="itemTemplate; context: {$implicit: item}"></ng-container>
537 </div>
538 <div *ngFor="let item of clonedItemsForFinishing; let index = index" [ngClass]= "{'p-carousel-item p-carousel-item-cloned': true,
539 'p-carousel-item-active': ((totalShiftedItems *-1) === numVisible),
540 'p-carousel-item-start': 0 === index,
541 'p-carousel-item-end': (clonedItemsForFinishing.length - 1) === index}">
542 <ng-container *ngTemplateOutlet="itemTemplate; context: {$implicit: item}"></ng-container>
543 </div>
544 </div>
545 </div>
546 <button type="button" *ngIf="showNavigators" [ngClass]="{'p-carousel-next p-link': true, 'p-disabled': isForwardNavDisabled()}" [disabled]="isForwardNavDisabled()" (click)="navForward($event)" pRipple>
547 <span [ngClass]="{'p-carousel-prev-icon pi': true, 'pi-chevron-right': !isVertical(), 'pi-chevron-down': isVertical()}"></span>
548 </button>
549 </div>
550 <ul [ngClass]="'p-carousel-indicators p-reset'" [class]="indicatorsContentClass" [ngStyle]="indicatorsContentStyle" *ngIf="showIndicators">
551 <li *ngFor="let totalDot of totalDotsArray(); let i = index" [ngClass]="{'p-carousel-indicator':true,'p-highlight': _page === i}">
552 <button type="button" [ngClass]="'p-link'" (click)="onDotClick($event, i)" [class]="indicatorStyleClass" [ngStyle]="indicatorStyle"></button>
553 </li>
554 </ul>
555 </div>
556 <div class="p-carousel-footer" *ngIf="footerFacet || footerTemplate">
557 <ng-content select="p-footer"></ng-content>
558 <ng-container *ngTemplateOutlet="footerTemplate"></ng-container>
559 </div>
560 </div>
561 `, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
562 'class': 'p-element'
563 }, styles: [".p-carousel{display:flex;flex-direction:column}.p-carousel-content{display:flex;flex-direction:column;overflow:auto}.p-carousel-prev,.p-carousel-next{align-self:center;flex-grow:0;flex-shrink:0;display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.p-carousel-container{display:flex;flex-direction:row}.p-carousel-items-content{overflow:hidden;width:100%}.p-carousel-items-container{display:flex;flex-direction:row}.p-carousel-indicators{display:flex;flex-direction:row;justify-content:center;flex-wrap:wrap}.p-carousel-indicator>button{display:flex;align-items:center;justify-content:center}.p-carousel-vertical .p-carousel-container{flex-direction:column}.p-carousel-vertical .p-carousel-items-container{flex-direction:column;height:100%}.p-items-hidden .p-carousel-item{visibility:hidden}.p-items-hidden .p-carousel-item.p-carousel-item-active{visibility:visible}\n"] }]
564 }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { page: [{
565 type: Input
566 }], numVisible: [{
567 type: Input
568 }], numScroll: [{
569 type: Input
570 }], responsiveOptions: [{
571 type: Input
572 }], orientation: [{
573 type: Input
574 }], verticalViewPortHeight: [{
575 type: Input
576 }], contentClass: [{
577 type: Input
578 }], indicatorsContentClass: [{
579 type: Input
580 }], indicatorsContentStyle: [{
581 type: Input
582 }], indicatorStyleClass: [{
583 type: Input
584 }], indicatorStyle: [{
585 type: Input
586 }], value: [{
587 type: Input
588 }], circular: [{
589 type: Input
590 }], showIndicators: [{
591 type: Input
592 }], showNavigators: [{
593 type: Input
594 }], autoplayInterval: [{
595 type: Input
596 }], style: [{
597 type: Input
598 }], styleClass: [{
599 type: Input
600 }], onPage: [{
601 type: Output
602 }], itemsContainer: [{
603 type: ViewChild,
604 args: ['itemsContainer']
605 }], headerFacet: [{
606 type: ContentChild,
607 args: [Header]
608 }], footerFacet: [{
609 type: ContentChild,
610 args: [Footer]
611 }], templates: [{
612 type: ContentChildren,
613 args: [PrimeTemplate]
614 }] } });
615export class CarouselModule {
616}
617CarouselModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: CarouselModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
618CarouselModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: CarouselModule, declarations: [Carousel], imports: [CommonModule, SharedModule, RippleModule], exports: [CommonModule, Carousel, SharedModule] });
619CarouselModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: CarouselModule, imports: [[CommonModule, SharedModule, RippleModule], CommonModule, SharedModule] });
620i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: CarouselModule, decorators: [{
621 type: NgModule,
622 args: [{
623 imports: [CommonModule, SharedModule, RippleModule],
624 exports: [CommonModule, Carousel, SharedModule],
625 declarations: [Carousel]
626 }]
627 }] });
628//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.js","sourceRoot":"","sources":["../../../src/app/components/carousel/carousel.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ElementRef, ViewChild, AfterContentInit, TemplateRef, ContentChildren, QueryList, NgModule, NgZone, EventEmitter, Output, ContentChild, ChangeDetectionStrategy, ViewEncapsulation, ChangeDetectorRef, SimpleChanges } from '@angular/core';\nimport { PrimeTemplate, SharedModule, Header, Footer } from 'primeng/api';\nimport { RippleModule } from 'primeng/ripple';\nimport { CommonModule } from '@angular/common';\nimport { UniqueComponentId } from 'primeng/utils';\n\n@Component({\n\tselector: 'p-carousel',\n\ttemplate: `\n\t\t<div [attr.id]=\"id\" [ngClass]=\"{'p-carousel p-component':true, 'p-carousel-vertical': isVertical(), 'p-carousel-horizontal': !isVertical()}\" [ngStyle]=\"style\" [class]=\"styleClass\">\n\t\t\t<div class=\"p-carousel-header\" *ngIf=\"headerFacet || headerTemplate\">\n                <ng-content select=\"p-header\"></ng-content>\n                <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n\t\t\t</div>\n\t\t\t<div [class]=\"contentClass\" [ngClass]=\"'p-carousel-content'\">\n\t\t\t\t<div class=\"p-carousel-container\">\n\t\t\t\t\t<button type=\"button\" *ngIf=\"showNavigators\" [ngClass]=\"{'p-carousel-prev p-link':true, 'p-disabled': isBackwardNavDisabled()}\" [disabled]=\"isBackwardNavDisabled()\" (click)=\"navBackward($event)\" pRipple>\n\t\t\t\t\t\t<span [ngClass]=\"{'p-carousel-prev-icon pi': true, 'pi-chevron-left': !isVertical(), 'pi-chevron-up': isVertical()}\"></span>\n\t\t\t\t\t</button>\n\t\t\t\t\t<div class=\"p-carousel-items-content\" [ngStyle]=\"{'height': isVertical() ? verticalViewPortHeight : 'auto'}\">\n\t\t\t\t\t\t<div #itemsContainer class=\"p-carousel-items-container\" (transitionend)=\"onTransitionEnd()\" (touchend)=\"onTouchEnd($event)\" (touchstart)=\"onTouchStart($event)\" (touchmove)=\"onTouchMove($event)\">\n                            <div *ngFor=\"let item of clonedItemsForStarting; let index = index\" [ngClass]= \"{'p-carousel-item p-carousel-item-cloned': true,\n                                'p-carousel-item-active': (totalShiftedItems * -1) === (value.length),\n\t\t\t\t\t\t\t    'p-carousel-item-start': 0 === index,\n\t\t\t\t\t\t\t    'p-carousel-item-end': (clonedItemsForStarting.length - 1) === index}\">\n\t\t\t\t\t\t\t\t<ng-container *ngTemplateOutlet=\"itemTemplate; context: {$implicit: item}\"></ng-container>\n\t\t\t\t\t\t\t</div>\n                            <div *ngFor=\"let item of value; let index = index\" [ngClass]= \"{'p-carousel-item': true,\n                                'p-carousel-item-active': (firstIndex() <= index && lastIndex() >= index),\n\t\t\t\t\t\t\t    'p-carousel-item-start': firstIndex() === index,\n\t\t\t\t\t\t\t    'p-carousel-item-end': lastIndex() === index}\">\n\t\t\t\t\t\t\t\t<ng-container *ngTemplateOutlet=\"itemTemplate; context: {$implicit: item}\"></ng-container>\n\t\t\t\t\t\t\t</div>\n                            <div *ngFor=\"let item of clonedItemsForFinishing; let index = index\" [ngClass]= \"{'p-carousel-item p-carousel-item-cloned': true,\n                                'p-carousel-item-active': ((totalShiftedItems *-1) === numVisible),\n\t\t\t\t\t\t\t    'p-carousel-item-start': 0 === index,\n\t\t\t\t\t\t\t    'p-carousel-item-end': (clonedItemsForFinishing.length - 1) === index}\">\n\t\t\t\t\t\t\t\t<ng-container *ngTemplateOutlet=\"itemTemplate; context: {$implicit: item}\"></ng-container>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t\t<button type=\"button\" *ngIf=\"showNavigators\" [ngClass]=\"{'p-carousel-next p-link': true, 'p-disabled': isForwardNavDisabled()}\" [disabled]=\"isForwardNavDisabled()\" (click)=\"navForward($event)\" pRipple>\n\t\t\t\t\t\t<span [ngClass]=\"{'p-carousel-prev-icon pi': true, 'pi-chevron-right': !isVertical(), 'pi-chevron-down': isVertical()}\"></span>\n\t\t\t\t\t</button>\n\t\t\t\t</div>\n\t\t\t\t<ul [ngClass]=\"'p-carousel-indicators p-reset'\" [class]=\"indicatorsContentClass\" [ngStyle]=\"indicatorsContentStyle\" *ngIf=\"showIndicators\">\n\t\t\t\t\t<li *ngFor=\"let totalDot of totalDotsArray(); let i = index\" [ngClass]=\"{'p-carousel-indicator':true,'p-highlight': _page === i}\">\n\t\t\t\t\t\t<button type=\"button\" [ngClass]=\"'p-link'\" (click)=\"onDotClick($event, i)\" [class]=\"indicatorStyleClass\" [ngStyle]=\"indicatorStyle\"></button>\n\t\t\t\t\t</li>\n\t\t\t\t</ul>\n\t\t\t</div>\n\t\t\t<div class=\"p-carousel-footer\" *ngIf=\"footerFacet || footerTemplate\">\n                <ng-content select=\"p-footer\"></ng-content>\n                <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n\t\t\t</div>\n\t\t</div>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    styleUrls: ['./carousel.css'],\n    host: {\n        'class': 'p-element'\n    }\n})\nexport class Carousel implements AfterContentInit {\n\n\t@Input() get page():number {\n\t\treturn this._page;\n\t}\n\tset page(val:number) {\n\t\tif (this.isCreated && val !== this._page) {\n\t\t\tif (this.autoplayInterval) {\n\t\t\t\tthis.stopAutoplay();\n\t\t\t\tthis.allowAutoplay = false;\n\t\t\t}\n\n\t\t\tif (val > this._page && val <= (this.totalDots() - 1)) {\n\t\t\t\tthis.step(-1, val);\n\t\t\t}\n\t\t\telse if (val < this._page ) {\n\t\t\t\tthis.step(1, val);\n\t\t\t}\n\t\t}\n\n\t\tthis._page = val;\n\t}\n\n\t@Input() get numVisible():number {\n\t\treturn this._numVisible;\n\t}\n\tset numVisible(val:number) {\n\t\tthis._numVisible = val;\n\t}\n\n\t@Input() get numScroll():number {\n\t\treturn this._numVisible;\n\t}\n\tset numScroll(val:number) {\n\t\tthis._numScroll = val;\n\t}\n\n\t@Input() responsiveOptions: any[];\n\n\t@Input() orientation = \"horizontal\";\n\n\t@Input() verticalViewPortHeight = \"300px\";\n\n\t@Input() contentClass: string = \"\";\n\n\t@Input() indicatorsContentClass: string = \"\";\n\n\t@Input() indicatorsContentStyle: any;\n\n\t@Input() indicatorStyleClass: string = \"\";\n\n\t@Input() indicatorStyle: any;\n\n\t@Input() get value() :any[] {\n\t\treturn this._value;\n\t};\n\tset value(val) {\n\t\tthis._value = val;\n\t}\n\n\t@Input() circular: boolean = false;\n\n\t@Input() showIndicators: boolean = true;\n\n\t@Input() showNavigators: boolean = true;\n\n\t@Input() autoplayInterval:number = 0;\n\n\t@Input() style: any;\n\n\t@Input() styleClass: string;\n\n    @Output() onPage: EventEmitter<any> = new EventEmitter();\n\n\t@ViewChild('itemsContainer') itemsContainer: ElementRef;\n\n\t@ContentChild(Header) headerFacet;\n\n    @ContentChild(Footer) footerFacet;\n\n\t@ContentChildren(PrimeTemplate) templates: QueryList<any>;\n\n\t_numVisible: number = 1;\n\n\t_numScroll: number = 1;\n\n\t_oldNumScroll: number = 0;\n\n\tprevState: any = {\n\t\tnumScroll:0,\n\t\tnumVisible:0,\n\t\tvalue: []\n\t};\n\n\tdefaultNumScroll:number = 1;\n\n\tdefaultNumVisible:number = 1;\n\n\t_page: number = 0;\n\n\t_value: any[];\n\n\tcarouselStyle:any;\n\n\tid:string;\n\n\ttotalShiftedItems;\n\n\tisRemainingItemsAdded:boolean = false;\n\n\tanimationTimeout:any;\n\n\ttranslateTimeout:any;\n\n\tremainingItems: number = 0;\n\n\t_items: any[];\n\n\tstartPos: any;\n\n\tdocumentResizeListener: any;\n\n\tclonedItemsForStarting: any[];\n\n\tclonedItemsForFinishing: any[];\n\n\tallowAutoplay: boolean;\n\n\tinterval: any;\n\n\tisCreated: boolean;\n\n\tswipeThreshold: number = 20;\n\n    itemTemplate: TemplateRef<any>;\n\n    headerTemplate: TemplateRef<any>;\n\n    footerTemplate: TemplateRef<any>;\n\n\tconstructor(public el: ElementRef, public zone: NgZone, public cd: ChangeDetectorRef) {\n\t\tthis.totalShiftedItems = this.page * this.numScroll * -1;\n\t}\n\n\tngOnChanges(simpleChange: SimpleChanges) {\n\t\tif (simpleChange.value) {\n\t\t\tif (this.circular && this._value) {\n\t\t\t\tthis.setCloneItems();\n\t\t\t}\n\t\t}\n\n\t\tif (this.isCreated) {\n\n\t\t\tif (simpleChange.numVisible) {\n\t\t\t\tif (this.responsiveOptions) {\n\t\t\t\t\tthis.defaultNumVisible = this.numVisible;\n\t\t\t\t}\n\n\t\t\t\tif (this.isCircular()) {\n\t\t\t\t\tthis.setCloneItems();\n\t\t\t\t}\n\n\t\t\t\tthis.createStyle();\n\t\t\t\tthis.calculatePosition();\n\t\t\t}\n\n\t\t\tif (simpleChange.numScroll) {\n\t\t\t\tif (this.responsiveOptions) {\n\t\t\t\t\tthis.defaultNumScroll = this.numScroll;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tngAfterContentInit() {\n\t\tthis.id = UniqueComponentId();\n\t\tthis.allowAutoplay = !!this.autoplayInterval;\n\n\t\tif (this.circular) {\n\t\t\tthis.setCloneItems();\n\t\t}\n\n\t\tif (this.responsiveOptions) {\n\t\t\tthis.defaultNumScroll = this._numScroll;\n\t\t\tthis.defaultNumVisible = this._numVisible;\n\t\t}\n\n\t\tthis.createStyle();\n\t\tthis.calculatePosition();\n\n\t\tif (this.responsiveOptions) {\n\t\t\tthis.bindDocumentListeners();\n\t\t}\n\n\t\tthis.templates.forEach((item) => {\n\t\t\tswitch (item.getType()) {\n\t\t\t\tcase 'item':\n\t\t\t\t\tthis.itemTemplate = item.template;\n                break;\n\n                case 'header':\n                    this.headerTemplate = item.template;\n                break;\n\n                case 'footer':\n                    this.footerTemplate = item.template;\n                break;\n\n\t\t\t\tdefault:\n\t\t\t\t\tthis.itemTemplate = item.template;\n                break;\n\t\t\t}\n\t\t});\n\t}\n\n\tngAfterContentChecked() {\n\t\tconst isCircular = this.isCircular();\n\t\tlet totalShiftedItems = this.totalShiftedItems;\n\n\t\tif (this.value && this.itemsContainer && (this.prevState.numScroll !== this._numScroll || this.prevState.numVisible !== this._numVisible || this.prevState.value.length !== this.value.length)) {\n\t\t\tif (this.autoplayInterval) {\n\t\t\t\tthis.stopAutoplay();\n\t\t\t}\n\n\t\t\tthis.remainingItems = (this.value.length - this._numVisible) % this._numScroll;\n\n\t\t\tlet page = this._page;\n\t\t\tif (this.totalDots() !== 0 && page >= this.totalDots()) {\n                page = this.totalDots() - 1;\n\t\t\t\tthis._page = page;\n\t\t\t\tthis.onPage.emit({\n\t\t\t\t\tpage: this.page\n\t\t\t\t});\n\t\t\t}\n\n\t\t\ttotalShiftedItems = (page * this._numScroll) * -1;\n            if (isCircular) {\n                totalShiftedItems -= this._numVisible;\n            }\n\n\t\t\tif (page === (this.totalDots() - 1) && this.remainingItems > 0) {\n\t\t\t\ttotalShiftedItems += (-1 * this.remainingItems) + this._numScroll;\n\t\t\t\tthis.isRemainingItemsAdded = true;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis.isRemainingItemsAdded = false;\n\t\t\t}\n\n\t\t\tif (totalShiftedItems !== this.totalShiftedItems) {\n                this.totalShiftedItems = totalShiftedItems;\n            }\n\n\t\t\tthis._oldNumScroll = this._numScroll;\n\t\t\tthis.prevState.numScroll = this._numScroll;\n\t\t\tthis.prevState.numVisible = this._numVisible;\n\t\t\tthis.prevState.value = [...this._value];\n\n\t\t\tif (this.totalDots() > 0  && this.itemsContainer.nativeElement) {\n\t\t\t\tthis.itemsContainer.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100/ this._numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100/ this._numVisible)}%, 0, 0)`;\n\t\t\t}\n\n\t\t\tthis.isCreated = true;\n\n\t\t\tif (this.autoplayInterval && this.isAutoplay()) {\n\t\t\t\tthis.startAutoplay();\n\t\t\t}\n\t\t}\n\n\t\tif (isCircular) {\n            if (this.page === 0) {\n                totalShiftedItems = -1 * this._numVisible;\n            }\n            else if (totalShiftedItems === 0) {\n                totalShiftedItems = -1 * this.value.length;\n                if (this.remainingItems > 0) {\n                    this.isRemainingItemsAdded = true;\n                }\n            }\n\n            if (totalShiftedItems !== this.totalShiftedItems) {\n\t\t\t\tthis.totalShiftedItems = totalShiftedItems;\n            }\n\t\t}\n\t}\n\n\tcreateStyle() {\n\t\t\tif (!this.carouselStyle) {\n\t\t\t\tthis.carouselStyle = document.createElement('style');\n\t\t\t\tthis.carouselStyle.type = 'text/css';\n\t\t\t\tdocument.body.appendChild(this.carouselStyle);\n\t\t\t}\n\n\t\t\tlet innerHTML = `\n            #${this.id} .p-carousel-item {\n\t\t\t\tflex: 1 0 ${ (100/ this.numVisible) }%\n\t\t\t}\n        `;\n\n\t\t\tif (this.responsiveOptions) {\n\t\t\t\tthis.responsiveOptions.sort((data1, data2) => {\n\t\t\t\t\tconst value1 = data1.breakpoint;\n\t\t\t\t\tconst value2 = data2.breakpoint;\n\t\t\t\t\tlet result = null;\n\n\t\t\t\t\tif (value1 == null && value2 != null)\n\t\t\t\t\t\tresult = -1;\n\t\t\t\t\telse if (value1 != null && value2 == null)\n\t\t\t\t\t\tresult = 1;\n\t\t\t\t\telse if (value1 == null && value2 == null)\n\t\t\t\t\t\tresult = 0;\n\t\t\t\t\telse if (typeof value1 === 'string' && typeof value2 === 'string')\n\t\t\t\t\t\tresult = value1.localeCompare(value2, undefined, { numeric: true });\n\t\t\t\t\telse\n\t\t\t\t\t\tresult = (value1 < value2) ? -1 : (value1 > value2) ? 1 : 0;\n\n\t\t\t\t\treturn -1 * result;\n\t\t\t\t});\n\n\t\t\t\tfor (let i = 0; i < this.responsiveOptions.length; i++) {\n\t\t\t\t\tlet res = this.responsiveOptions[i];\n\n\t\t\t\t\tinnerHTML += `\n                    @media screen and (max-width: ${res.breakpoint}) {\n                        #${this.id} .p-carousel-item {\n                            flex: 1 0 ${ (100/ res.numVisible) }%\n                        }\n                    }\n                `\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.carouselStyle.innerHTML = innerHTML;\n\t\t}\n\n\tcalculatePosition() {\n\t\tif (this.responsiveOptions) {\n\t\t\tlet windowWidth = window.innerWidth;\n\t\t\tlet matchedResponsiveData = {\n\t\t\t\tnumVisible: this.defaultNumVisible,\n\t\t\t\tnumScroll: this.defaultNumScroll\n\t\t\t};\n\n\t\t\tfor (let i = 0; i < this.responsiveOptions.length; i++) {\n\t\t\t\tlet res = this.responsiveOptions[i];\n\n\t\t\t\tif (parseInt(res.breakpoint, 10) >= windowWidth) {\n\t\t\t\t\tmatchedResponsiveData = res;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (this._numScroll !== matchedResponsiveData.numScroll) {\n\t\t\t\tlet page = this._page;\n\t\t\t\tpage = Math.floor((page * this._numScroll) / matchedResponsiveData.numScroll);\n\n\t\t\t\tlet totalShiftedItems = (matchedResponsiveData.numScroll * this.page) * -1;\n\n\t\t\t\tif (this.isCircular()) {\n\t\t\t\t\ttotalShiftedItems -= matchedResponsiveData.numVisible;\n\t\t\t\t}\n\n\t\t\t\tthis.totalShiftedItems = totalShiftedItems;\n\t\t\t\tthis._numScroll = matchedResponsiveData.numScroll;\n\n\t\t\t\tthis._page = page;\n\t\t\t\tthis.onPage.emit({\n\t\t\t\t\tpage: this.page\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tif (this._numVisible !== matchedResponsiveData.numVisible) {\n\t\t\t\tthis._numVisible = matchedResponsiveData.numVisible;\n\t\t\t\tthis.setCloneItems();\n\t\t\t}\n\n\t\t\tthis.cd.markForCheck();\n\t\t}\n\t}\n\n\tsetCloneItems() {\n\t\tthis.clonedItemsForStarting = [];\n\t\tthis.clonedItemsForFinishing = [];\n\t\tif (this.isCircular()) {\n\t\t\tthis.clonedItemsForStarting.push(...this.value.slice(-1 * this._numVisible));\n\t\t\tthis.clonedItemsForFinishing.push(...this.value.slice(0, this._numVisible));\n\t\t}\n\t}\n\n\tfirstIndex() {\n\t\treturn this.isCircular() ? (-1 * (this.totalShiftedItems + this.numVisible)) : (this.totalShiftedItems * -1);\n\t}\n\n\tlastIndex() {\n\t\treturn this.firstIndex() + this.numVisible - 1;\n\t}\n\n\ttotalDots() {\n\t\treturn this.value ? Math.ceil((this.value.length - this._numVisible) / this._numScroll) + 1 : 0;\n\t}\n\n\ttotalDotsArray() {\n\t\tconst totalDots = this.totalDots();\n\t\treturn totalDots <= 0 ? [] : Array(totalDots).fill(0);\n\t}\n\n\tisVertical() {\n\t\treturn this.orientation === 'vertical';\n\t}\n\n\tisCircular() {\n\t\treturn this.circular && this.value && this.value.length >= this.numVisible;\n\t}\n\n\tisAutoplay() {\n\t\treturn this.autoplayInterval && this.allowAutoplay;\n\t}\n\n\tisForwardNavDisabled() {\n\t\treturn this.isEmpty() || (this._page >= (this.totalDots() - 1) && !this.isCircular());\n\t}\n\n\tisBackwardNavDisabled() {\n\t\treturn this.isEmpty() || (this._page <= 0  && !this.isCircular());\n\t}\n\n\tisEmpty() {\n\t\treturn !this.value || this.value.length === 0;\n\t}\n\n\tnavForward(e,index?) {\n\t\tif (this.isCircular() || this._page < (this.totalDots() - 1)) {\n\t\t\tthis.step(-1, index);\n\t\t}\n\n\t\tif (this.autoplayInterval) {\n\t\t\tthis.stopAutoplay();\n\t\t\tthis.allowAutoplay = false;\n\t\t}\n\n\t\tif (e && e.cancelable) {\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\tnavBackward(e,index?) {\n\t\tif (this.isCircular() || this._page !== 0) {\n\t\t\tthis.step(1, index);\n\t\t}\n\n\t\tif (this.autoplayInterval) {\n\t\t\tthis.stopAutoplay();\n\t\t\tthis.allowAutoplay = false;\n\t\t}\n\n\t\tif (e && e.cancelable) {\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\n\tonDotClick(e, index) {\n\t\tlet page = this._page;\n\n\t\tif (this.autoplayInterval) {\n\t\t\tthis.stopAutoplay();\n\t\t\tthis.allowAutoplay = false;\n\t\t}\n\n\t\tif (index > page) {\n\t\t\tthis.navForward(e, index);\n\t\t}\n\t\telse if (index < page) {\n\t\t\tthis.navBackward(e, index);\n\t\t}\n\t}\n\n\tstep(dir, page) {\n\t\tlet totalShiftedItems = this.totalShiftedItems;\n\t\tconst isCircular = this.isCircular();\n\n\t\tif (page != null) {\n\t\t\ttotalShiftedItems = (this._numScroll * page) * -1;\n\n\t\t\tif (isCircular) {\n\t\t\t\ttotalShiftedItems -= this._numVisible;\n\t\t\t}\n\n\t\t\tthis.isRemainingItemsAdded = false;\n\t\t}\n\t\telse {\n\t\t\ttotalShiftedItems += (this._numScroll * dir);\n\t\t\tif (this.isRemainingItemsAdded) {\n\t\t\t\ttotalShiftedItems += this.remainingItems - (this._numScroll * dir);\n\t\t\t\tthis.isRemainingItemsAdded = false;\n\t\t\t}\n\n\t\t\tlet originalShiftedItems = isCircular ? (totalShiftedItems + this._numVisible) : totalShiftedItems;\n\t\t\tpage = Math.abs(Math.floor((originalShiftedItems / this._numScroll)));\n\t\t}\n\n\t\tif (isCircular && this.page === (this.totalDots() - 1) && dir === -1) {\n\t\t\ttotalShiftedItems = -1 * (this.value.length + this._numVisible);\n\t\t\tpage = 0;\n\t\t}\n\t\telse if (isCircular && this.page === 0 && dir === 1) {\n\t\t\ttotalShiftedItems = 0;\n\t\t\tpage = (this.totalDots() - 1);\n\t\t}\n\t\telse if (page === (this.totalDots() - 1) && this.remainingItems > 0) {\n\t\t\ttotalShiftedItems += ((this.remainingItems * -1) - (this._numScroll * dir));\n\t\t\tthis.isRemainingItemsAdded = true;\n\t\t}\n\n\t\tif (this.itemsContainer) {\n\t\t\tthis.itemsContainer.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${totalShiftedItems * (100/ this._numVisible)}%, 0)` : `translate3d(${totalShiftedItems * (100/ this._numVisible)}%, 0, 0)`;\n\t\t\tthis.itemsContainer.nativeElement.style.transition = 'transform 500ms ease 0s';\n\t\t}\n\n\t\tthis.totalShiftedItems = totalShiftedItems;\n\t\tthis._page = page;\n\t\tthis.onPage.emit({\n\t\t\tpage: this.page\n\t\t});\n\t}\n\n\tstartAutoplay() {\n\t\tthis.interval = setInterval(() => {\n\t\t\tif (this.totalDots() > 0) {\n\t\t\t\tif (this.page === (this.totalDots() - 1)) {\n\t\t\t\t\tthis.step(-1, 0);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tthis.step(-1, this.page + 1);\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\tthis.autoplayInterval);\n\t}\n\n\tstopAutoplay() {\n\t\tif (this.interval) {\n\t\t\tclearInterval(this.interval);\n\t\t}\n\t}\n\n\tonTransitionEnd() {\n\t\tif (this.itemsContainer) {\n\t\t\tthis.itemsContainer.nativeElement.style.transition = '';\n\n\t\t\tif ((this.page === 0 || this.page === (this.totalDots() - 1)) && this.isCircular()) {\n\t\t\t\tthis.itemsContainer.nativeElement.style.transform = this.isVertical() ? `translate3d(0, ${this.totalShiftedItems * (100/ this._numVisible)}%, 0)` : `translate3d(${this.totalShiftedItems * (100/ this._numVisible)}%, 0, 0)`;\n\t\t\t}\n\t\t}\n\t}\n\n\tonTouchStart(e) {\n\t\tlet touchobj = e.changedTouches[0];\n\n\t\tthis.startPos = {\n\t\t\tx: touchobj.pageX,\n\t\t\ty: touchobj.pageY\n\t\t};\n\t}\n\n\tonTouchMove(e) {\n\t\tif (e.cancelable) {\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\tonTouchEnd(e) {\n\t\tlet touchobj = e.changedTouches[0];\n\n\t\tif (this.isVertical()) {\n\t\t\tthis.changePageOnTouch(e, (touchobj.pageY - this.startPos.y));\n\t\t}\n\t\telse {\n\t\t\tthis.changePageOnTouch(e, (touchobj.pageX - this.startPos.x));\n\t\t}\n\t}\n\n\tchangePageOnTouch(e, diff) {\n\t\tif (Math.abs(diff) > this.swipeThreshold) {\n\t\t\tif (diff < 0) {\n\t\t\t\tthis.navForward(e);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis.navBackward(e);\n\n\t\t\t}\n\t\t}\n\t}\n\n\tbindDocumentListeners() {\n\t\tif (!this.documentResizeListener) {\n\t\t\tthis.documentResizeListener = (e) => {\n\t\t\t\tthis.calculatePosition();\n\t\t\t};\n\n\t\t\twindow.addEventListener('resize', this.documentResizeListener);\n\t\t}\n\t}\n\n\tunbindDocumentListeners() {\n\t\tif (this.documentResizeListener) {\n\t\t\twindow.removeEventListener('resize', this.documentResizeListener);\n\t\t\tthis.documentResizeListener = null;\n\t\t}\n\t}\n\n\tngOnDestroy() {\n\t\tif (this.responsiveOptions) {\n\t\t\tthis.unbindDocumentListeners();\n\t\t}\n\t\tif (this.autoplayInterval) {\n\t\t\tthis.stopAutoplay();\n\t\t}\n    }\n\n}\n\n@NgModule({\n\timports: [CommonModule, SharedModule, RippleModule],\n\texports: [CommonModule, Carousel, SharedModule],\n\tdeclarations: [Carousel]\n})\nexport class CarouselModule { }\n"]}
Note: See TracBrowser for help on using the repository browser.