UNPKG

ngx-slick-carousel

Version:

[![npm version](https://badge.fury.io/js/ngx-slick-carousel.svg)](https://badge.fury.io/js/ngx-slick-carousel) [![Build Status](https://travis-ci.com/leo6104/ngx-slick-carousel.svg?branch=master)](https://travis-ci.com/leo6104/ngx-slick-carousel)

450 lines 32 kB
/** * @fileoverview added by tsickle * Generated from: slick.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { isPlatformBrowser, isPlatformServer } from '@angular/common'; import { Component, Directive, ElementRef, EventEmitter, forwardRef, Host, Inject, Input, NgZone, Output, PLATFORM_ID } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; /** * Slick component */ export class SlickCarouselComponent { /** * Constructor * @param {?} el * @param {?} zone * @param {?} platformId */ constructor(el, zone, platformId) { this.el = el; this.zone = zone; this.platformId = platformId; this.afterChange = new EventEmitter(); this.beforeChange = new EventEmitter(); this.breakpoint = new EventEmitter(); this.destroy = new EventEmitter(); this.init = new EventEmitter(); // access from parent component can be a problem with change detection timing. Please use afterChange output this.currentIndex = 0; this.slides = []; this.initialized = false; this._removedSlides = []; this._addedSlides = []; } /** * On component destroy * @return {?} */ ngOnDestroy() { this.unslick(); } /** * @return {?} */ ngAfterViewInit() { this.ngAfterViewChecked(); } /** * On component view checked * @return {?} */ ngAfterViewChecked() { if (isPlatformServer(this.platformId)) { return; } if (this._addedSlides.length > 0 || this._removedSlides.length > 0) { /** @type {?} */ const nextSlidesLength = this.slides.length - this._removedSlides.length + this._addedSlides.length; if (!this.initialized) { if (nextSlidesLength > 0) { this.initSlick(); } // if nextSlidesLength is zere, do nothing } else if (nextSlidesLength === 0) { // unslick case this.unslick(); } else { this._addedSlides.forEach((/** * @param {?} slickItem * @return {?} */ slickItem => { this.slides.push(slickItem); this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickAdd', slickItem.el.nativeElement); })); })); this._addedSlides = []; this._removedSlides.forEach((/** * @param {?} slickItem * @return {?} */ slickItem => { /** @type {?} */ const idx = this.slides.indexOf(slickItem); this.slides = this.slides.filter((/** * @param {?} s * @return {?} */ s => s !== slickItem)); this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickRemove', idx); })); })); this._removedSlides = []; } } } /** * init slick * @return {?} */ initSlick() { this.slides = this._addedSlides; this._addedSlides = []; this._removedSlides = []; this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance = jQuery(this.el.nativeElement); this.$instance.on('init', (/** * @param {?} event * @param {?} slick * @return {?} */ (event, slick) => { this.zone.run((/** * @return {?} */ () => { this.init.emit({ event, slick }); })); })); this.$instance.slick(this.config); this.zone.run((/** * @return {?} */ () => { var _a; this.initialized = true; this.currentIndex = ((_a = this.config) === null || _a === void 0 ? void 0 : _a.initialSlide) || 0; })); this.$instance.on('afterChange', (/** * @param {?} event * @param {?} slick * @param {?} currentSlide * @return {?} */ (event, slick, currentSlide) => { this.zone.run((/** * @return {?} */ () => { this.afterChange.emit({ event, slick, currentSlide, first: currentSlide === 0, last: slick.$slides.length === currentSlide + slick.options.slidesToScroll }); this.currentIndex = currentSlide; })); })); this.$instance.on('beforeChange', (/** * @param {?} event * @param {?} slick * @param {?} currentSlide * @param {?} nextSlide * @return {?} */ (event, slick, currentSlide, nextSlide) => { this.zone.run((/** * @return {?} */ () => { this.beforeChange.emit({ event, slick, currentSlide, nextSlide }); this.currentIndex = nextSlide; })); })); this.$instance.on('breakpoint', (/** * @param {?} event * @param {?} slick * @param {?} breakpoint * @return {?} */ (event, slick, breakpoint) => { this.zone.run((/** * @return {?} */ () => { this.breakpoint.emit({ event, slick, breakpoint }); })); })); this.$instance.on('destroy', (/** * @param {?} event * @param {?} slick * @return {?} */ (event, slick) => { this.zone.run((/** * @return {?} */ () => { this.destroy.emit({ event, slick }); this.initialized = false; })); })); })); } /** * @param {?} slickItem * @return {?} */ addSlide(slickItem) { this._addedSlides.push(slickItem); } /** * @param {?} slickItem * @return {?} */ removeSlide(slickItem) { this._removedSlides.push(slickItem); } /** * Slick Method * @param {?} index * @return {?} */ slickGoTo(index) { this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickGoTo', index); })); } /** * @return {?} */ slickNext() { this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickNext'); })); } /** * @return {?} */ slickPrev() { this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickPrev'); })); } /** * @return {?} */ slickPause() { this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickPause'); })); } /** * @return {?} */ slickPlay() { this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickPlay'); })); } /** * @return {?} */ unslick() { if (this.$instance) { this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('unslick'); })); this.$instance = undefined; } this.initialized = false; } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (this.initialized) { /** @type {?} */ const config = changes['config']; if (config.previousValue !== config.currentValue && config.currentValue !== undefined) { /** @type {?} */ const refresh = config.currentValue['refresh']; /** @type {?} */ const newOptions = Object.assign({}, config.currentValue); delete newOptions['refresh']; this.zone.runOutsideAngular((/** * @return {?} */ () => { this.$instance.slick('slickSetOption', newOptions, refresh); })); } } } } SlickCarouselComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-slick-carousel', exportAs: 'slick-carousel', providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => SlickCarouselComponent)), multi: true }], template: '<ng-content></ng-content>' }] } ]; /** @nocollapse */ SlickCarouselComponent.ctorParameters = () => [ { type: ElementRef }, { type: NgZone }, { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] } ]; SlickCarouselComponent.propDecorators = { config: [{ type: Input }], afterChange: [{ type: Output }], beforeChange: [{ type: Output }], breakpoint: [{ type: Output }], destroy: [{ type: Output }], init: [{ type: Output }] }; if (false) { /** @type {?} */ SlickCarouselComponent.prototype.config; /** @type {?} */ SlickCarouselComponent.prototype.afterChange; /** @type {?} */ SlickCarouselComponent.prototype.beforeChange; /** @type {?} */ SlickCarouselComponent.prototype.breakpoint; /** @type {?} */ SlickCarouselComponent.prototype.destroy; /** @type {?} */ SlickCarouselComponent.prototype.init; /** @type {?} */ SlickCarouselComponent.prototype.$instance; /** * @type {?} * @private */ SlickCarouselComponent.prototype.currentIndex; /** @type {?} */ SlickCarouselComponent.prototype.slides; /** @type {?} */ SlickCarouselComponent.prototype.initialized; /** * @type {?} * @private */ SlickCarouselComponent.prototype._removedSlides; /** * @type {?} * @private */ SlickCarouselComponent.prototype._addedSlides; /** * @type {?} * @private */ SlickCarouselComponent.prototype.el; /** * @type {?} * @private */ SlickCarouselComponent.prototype.zone; /** * @type {?} * @private */ SlickCarouselComponent.prototype.platformId; } export class SlickItemDirective { /** * @param {?} el * @param {?} platformId * @param {?} carousel */ constructor(el, platformId, carousel) { this.el = el; this.platformId = platformId; this.carousel = carousel; } /** * @return {?} */ ngOnInit() { if (isPlatformBrowser(this.platformId)) { this.carousel.addSlide(this); } } /** * @return {?} */ ngOnDestroy() { if (isPlatformBrowser(this.platformId)) { this.carousel.removeSlide(this); } } } SlickItemDirective.decorators = [ { type: Directive, args: [{ selector: '[ngxSlickItem]', },] } ]; /** @nocollapse */ SlickItemDirective.ctorParameters = () => [ { type: ElementRef }, { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }, { type: SlickCarouselComponent, decorators: [{ type: Host }] } ]; if (false) { /** @type {?} */ SlickItemDirective.prototype.el; /** * @type {?} * @private */ SlickItemDirective.prototype.platformId; /** * @type {?} * @private */ SlickItemDirective.prototype.carousel; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick.component.js","sourceRoot":"ng://ngx-slick-carousel/","sources":["slick.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser, isPlatformServer } from '@angular/common';\nimport {\n  AfterViewChecked,\n  AfterViewInit,\n  Component,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Host,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  PLATFORM_ID,\n  SimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\ndeclare const jQuery: any;\n\n/**\n * Slick component\n */\n@Component({\n  selector: 'ngx-slick-carousel',\n  exportAs: 'slick-carousel',\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => SlickCarouselComponent),\n    multi: true\n  }],\n  template: '<ng-content></ng-content>',\n})\nexport class SlickCarouselComponent implements OnDestroy, OnChanges, AfterViewInit, AfterViewChecked {\n\n    @Input() config: any;\n    @Output() afterChange: EventEmitter<{ event: any, slick: any, currentSlide: number, first: boolean, last: boolean }> = new EventEmitter();\n    @Output() beforeChange: EventEmitter<{ event: any, slick: any, currentSlide: number, nextSlide: number }> = new EventEmitter();\n    @Output() breakpoint: EventEmitter<{ event: any, slick: any, breakpoint: any }> = new EventEmitter();\n    @Output() destroy: EventEmitter<{ event: any, slick: any }> = new EventEmitter();\n    @Output() init: EventEmitter<{ event: any, slick: any }> = new EventEmitter();\n\n  public $instance: any;\n\n  // access from parent component can be a problem with change detection timing. Please use afterChange output\n  private currentIndex = 0;\n\n  public slides: any[] = [];\n  public initialized = false;\n  private _removedSlides: SlickItemDirective[] = [];\n  private _addedSlides: SlickItemDirective[] = [];\n\n  /**\n   * Constructor\n   */\n  constructor(private el: ElementRef,\n              private zone: NgZone,\n              @Inject(PLATFORM_ID) private platformId: string) {\n  }\n\n  /**\n   * On component destroy\n   */\n  ngOnDestroy() {\n    this.unslick();\n  }\n\n  ngAfterViewInit(): void {\n    this.ngAfterViewChecked();\n  }\n\n  /**\n   * On component view checked\n   */\n  ngAfterViewChecked() {\n    if (isPlatformServer(this.platformId)) {\n      return;\n    }\n    if (this._addedSlides.length > 0 || this._removedSlides.length > 0) {\n      const nextSlidesLength = this.slides.length - this._removedSlides.length + this._addedSlides.length;\n      if (!this.initialized) {\n        if (nextSlidesLength > 0) {\n          this.initSlick();\n        }\n        // if nextSlidesLength is zere, do nothing\n      } else if (nextSlidesLength === 0) { // unslick case\n        this.unslick();\n      } else {\n        this._addedSlides.forEach(slickItem => {\n          this.slides.push(slickItem);\n          this.zone.runOutsideAngular(() => {\n            this.$instance.slick('slickAdd', slickItem.el.nativeElement);\n          });\n        });\n        this._addedSlides = [];\n\n        this._removedSlides.forEach(slickItem => {\n          const idx = this.slides.indexOf(slickItem);\n          this.slides = this.slides.filter(s => s !== slickItem);\n          this.zone.runOutsideAngular(() => {\n            this.$instance.slick('slickRemove', idx);\n          });\n        });\n        this._removedSlides = [];\n      }\n    }\n  }\n\n  /**\n   * init slick\n   */\n  initSlick() {\n    this.slides = this._addedSlides;\n    this._addedSlides = [];\n    this._removedSlides = [];\n    this.zone.runOutsideAngular(() => {\n      this.$instance = jQuery(this.el.nativeElement);\n\n      this.$instance.on('init', (event, slick) => {\n        this.zone.run(() => {\n          this.init.emit({ event, slick });\n        });\n      });\n\n      this.$instance.slick(this.config);\n\n      this.zone.run(() => {\n        this.initialized = true;\n\n        this.currentIndex = this.config?.initialSlide || 0;\n      });\n\n            this.$instance.on('afterChange', (event, slick, currentSlide) => {\n                this.zone.run(() => {\n                    this.afterChange.emit({\n                        event,\n                        slick,\n                        currentSlide,\n                        first: currentSlide === 0,\n                        last: slick.$slides.length === currentSlide + slick.options.slidesToScroll\n                    });\n                    this.currentIndex = currentSlide;\n                });\n            });\n\n      this.$instance.on('beforeChange', (event, slick, currentSlide, nextSlide) => {\n        this.zone.run(() => {\n          this.beforeChange.emit({ event, slick, currentSlide, nextSlide });\n          this.currentIndex = nextSlide;\n        });\n      });\n\n      this.$instance.on('breakpoint', (event, slick, breakpoint) => {\n        this.zone.run(() => {\n          this.breakpoint.emit({ event, slick, breakpoint });\n        });\n      });\n\n      this.$instance.on('destroy', (event, slick) => {\n        this.zone.run(() => {\n          this.destroy.emit({ event, slick });\n          this.initialized = false;\n        });\n      });\n    });\n  }\n\n  addSlide(slickItem: SlickItemDirective) {\n    this._addedSlides.push(slickItem);\n  }\n\n  removeSlide(slickItem: SlickItemDirective) {\n    this._removedSlides.push(slickItem);\n  }\n\n  /**\n   * Slick Method\n   */\n  public slickGoTo(index: number) {\n    this.zone.runOutsideAngular(() => {\n      this.$instance.slick('slickGoTo', index);\n    });\n  }\n\n  public slickNext() {\n    this.zone.runOutsideAngular(() => {\n      this.$instance.slick('slickNext');\n    });\n  }\n\n  public slickPrev() {\n    this.zone.runOutsideAngular(() => {\n      this.$instance.slick('slickPrev');\n    });\n  }\n\n  public slickPause() {\n    this.zone.runOutsideAngular(() => {\n      this.$instance.slick('slickPause');\n    });\n  }\n\n  public slickPlay() {\n    this.zone.runOutsideAngular(() => {\n      this.$instance.slick('slickPlay');\n    });\n  }\n\n  public unslick() {\n    if (this.$instance) {\n      this.zone.runOutsideAngular(() => {\n        this.$instance.slick('unslick');\n      });\n      this.$instance = undefined;\n    }\n    this.initialized = false;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.initialized) {\n      const config = changes['config'];\n      if (config.previousValue !== config.currentValue && config.currentValue !== undefined) {\n        const refresh = config.currentValue['refresh'];\n        const newOptions = Object.assign({}, config.currentValue);\n        delete newOptions['refresh'];\n\n        this.zone.runOutsideAngular(() => {\n          this.$instance.slick('slickSetOption', newOptions, refresh);\n        });\n      }\n    }\n  }\n\n}\n\n@Directive({\n  selector: '[ngxSlickItem]',\n})\nexport class SlickItemDirective implements OnInit, OnDestroy {\n  constructor(public el: ElementRef,\n              @Inject(PLATFORM_ID) private platformId: string,\n              @Host() private carousel: SlickCarouselComponent) {\n  }\n\n  ngOnInit() {\n    if (isPlatformBrowser(this.platformId)) {\n      this.carousel.addSlide(this);\n    }\n  }\n\n  ngOnDestroy() {\n    if (isPlatformBrowser(this.platformId)) {\n      this.carousel.removeSlide(this);\n    }\n  }\n}\n"]}