ngx-slick-carousel
Version:
[](https://badge.fury.io/js/ngx-slick-carousel) [](https://travis-ci.com/leo6104/ngx-slick-carousel)
450 lines • 32 kB
JavaScript
/**
* @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"]}