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)

520 lines 34.7 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 */ var SlickCarouselComponent = /** @class */ (function () { /** * Constructor */ function SlickCarouselComponent(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 */ /** * On component destroy * @return {?} */ SlickCarouselComponent.prototype.ngOnDestroy = /** * On component destroy * @return {?} */ function () { this.unslick(); }; /** * @return {?} */ SlickCarouselComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { this.ngAfterViewChecked(); }; /** * On component view checked */ /** * On component view checked * @return {?} */ SlickCarouselComponent.prototype.ngAfterViewChecked = /** * On component view checked * @return {?} */ function () { var _this = this; if (isPlatformServer(this.platformId)) { return; } if (this._addedSlides.length > 0 || this._removedSlides.length > 0) { /** @type {?} */ var 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 {?} */ function (slickItem) { _this.slides.push(slickItem); _this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickAdd', slickItem.el.nativeElement); })); })); this._addedSlides = []; this._removedSlides.forEach((/** * @param {?} slickItem * @return {?} */ function (slickItem) { /** @type {?} */ var idx = _this.slides.indexOf(slickItem); _this.slides = _this.slides.filter((/** * @param {?} s * @return {?} */ function (s) { return s !== slickItem; })); _this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickRemove', idx); })); })); this._removedSlides = []; } } }; /** * init slick */ /** * init slick * @return {?} */ SlickCarouselComponent.prototype.initSlick = /** * init slick * @return {?} */ function () { var _this = this; this.slides = this._addedSlides; this._addedSlides = []; this._removedSlides = []; this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance = jQuery(_this.el.nativeElement); _this.$instance.on('init', (/** * @param {?} event * @param {?} slick * @return {?} */ function (event, slick) { _this.zone.run((/** * @return {?} */ function () { _this.init.emit({ event: event, slick: slick }); })); })); _this.$instance.slick(_this.config); _this.zone.run((/** * @return {?} */ function () { 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 {?} */ function (event, slick, currentSlide) { _this.zone.run((/** * @return {?} */ function () { _this.afterChange.emit({ event: event, slick: slick, currentSlide: 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 {?} */ function (event, slick, currentSlide, nextSlide) { _this.zone.run((/** * @return {?} */ function () { _this.beforeChange.emit({ event: event, slick: slick, currentSlide: currentSlide, nextSlide: nextSlide }); _this.currentIndex = nextSlide; })); })); _this.$instance.on('breakpoint', (/** * @param {?} event * @param {?} slick * @param {?} breakpoint * @return {?} */ function (event, slick, breakpoint) { _this.zone.run((/** * @return {?} */ function () { _this.breakpoint.emit({ event: event, slick: slick, breakpoint: breakpoint }); })); })); _this.$instance.on('destroy', (/** * @param {?} event * @param {?} slick * @return {?} */ function (event, slick) { _this.zone.run((/** * @return {?} */ function () { _this.destroy.emit({ event: event, slick: slick }); _this.initialized = false; })); })); })); }; /** * @param {?} slickItem * @return {?} */ SlickCarouselComponent.prototype.addSlide = /** * @param {?} slickItem * @return {?} */ function (slickItem) { this._addedSlides.push(slickItem); }; /** * @param {?} slickItem * @return {?} */ SlickCarouselComponent.prototype.removeSlide = /** * @param {?} slickItem * @return {?} */ function (slickItem) { this._removedSlides.push(slickItem); }; /** * Slick Method */ /** * Slick Method * @param {?} index * @return {?} */ SlickCarouselComponent.prototype.slickGoTo = /** * Slick Method * @param {?} index * @return {?} */ function (index) { var _this = this; this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickGoTo', index); })); }; /** * @return {?} */ SlickCarouselComponent.prototype.slickNext = /** * @return {?} */ function () { var _this = this; this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickNext'); })); }; /** * @return {?} */ SlickCarouselComponent.prototype.slickPrev = /** * @return {?} */ function () { var _this = this; this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickPrev'); })); }; /** * @return {?} */ SlickCarouselComponent.prototype.slickPause = /** * @return {?} */ function () { var _this = this; this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickPause'); })); }; /** * @return {?} */ SlickCarouselComponent.prototype.slickPlay = /** * @return {?} */ function () { var _this = this; this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickPlay'); })); }; /** * @return {?} */ SlickCarouselComponent.prototype.unslick = /** * @return {?} */ function () { var _this = this; if (this.$instance) { this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('unslick'); })); this.$instance = undefined; } this.initialized = false; }; /** * @param {?} changes * @return {?} */ SlickCarouselComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { var _this = this; if (this.initialized) { /** @type {?} */ var config = changes['config']; if (config.previousValue !== config.currentValue && config.currentValue !== undefined) { /** @type {?} */ var refresh_1 = config.currentValue['refresh']; /** @type {?} */ var newOptions_1 = Object.assign({}, config.currentValue); delete newOptions_1['refresh']; this.zone.runOutsideAngular((/** * @return {?} */ function () { _this.$instance.slick('slickSetOption', newOptions_1, refresh_1); })); } } }; SlickCarouselComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-slick-carousel', exportAs: 'slick-carousel', providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return SlickCarouselComponent; })), multi: true }], template: '<ng-content></ng-content>' }] } ]; /** @nocollapse */ SlickCarouselComponent.ctorParameters = function () { return [ { 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 }] }; return SlickCarouselComponent; }()); export { SlickCarouselComponent }; 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; } var SlickItemDirective = /** @class */ (function () { function SlickItemDirective(el, platformId, carousel) { this.el = el; this.platformId = platformId; this.carousel = carousel; } /** * @return {?} */ SlickItemDirective.prototype.ngOnInit = /** * @return {?} */ function () { if (isPlatformBrowser(this.platformId)) { this.carousel.addSlide(this); } }; /** * @return {?} */ SlickItemDirective.prototype.ngOnDestroy = /** * @return {?} */ function () { if (isPlatformBrowser(this.platformId)) { this.carousel.removeSlide(this); } }; SlickItemDirective.decorators = [ { type: Directive, args: [{ selector: '[ngxSlickItem]', },] } ]; /** @nocollapse */ SlickItemDirective.ctorParameters = function () { return [ { type: ElementRef }, { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }, { type: SlickCarouselComponent, decorators: [{ type: Host }] } ]; }; return SlickItemDirective; }()); export { SlickItemDirective }; 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"]}