ngx-slick-carousel
Version:
[](https://badge.fury.io/js/ngx-slick-carousel) [](https://travis-ci.com/leo6104/ngx-slick-carousel)
520 lines • 34.7 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
*/
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":";;;;;AAAA,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACtE,OAAO,EAGL,SAAS,EACT,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,IAAI,EACJ,MAAM,EACN,KAAK,EACL,MAAM,EAIN,MAAM,EACN,WAAW,EAEZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;;AAOnD;IA6BE;;OAEG;IACH,gCAAoB,EAAc,EACd,IAAY,EACS,UAAkB;QAFvC,OAAE,GAAF,EAAE,CAAY;QACd,SAAI,GAAJ,IAAI,CAAQ;QACS,eAAU,GAAV,UAAU,CAAQ;QArB/C,gBAAW,GAAkG,IAAI,YAAY,EAAE,CAAC;QAChI,iBAAY,GAAsF,IAAI,YAAY,EAAE,CAAC;QACrH,eAAU,GAA8D,IAAI,YAAY,EAAE,CAAC;QAC3F,YAAO,GAA6C,IAAI,YAAY,EAAE,CAAC;QACvE,SAAI,GAA6C,IAAI,YAAY,EAAE,CAAC;;QAKxE,iBAAY,GAAG,CAAC,CAAC;QAElB,WAAM,GAAU,EAAE,CAAC;QACnB,gBAAW,GAAG,KAAK,CAAC;QACnB,mBAAc,GAAyB,EAAE,CAAC;QAC1C,iBAAY,GAAyB,EAAE,CAAC;IAQhD,CAAC;IAED;;OAEG;;;;;IACH,4CAAW;;;;IAAX;QACE,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;;;;IAED,gDAAe;;;IAAf;QACE,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED;;OAEG;;;;;IACH,mDAAkB;;;;IAAlB;QAAA,iBAgCC;QA/BC,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACrC,OAAO;SACR;QACD,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;;gBAC5D,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM;YACnG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;gBACrB,IAAI,gBAAgB,GAAG,CAAC,EAAE;oBACxB,IAAI,CAAC,SAAS,EAAE,CAAC;iBAClB;gBACD,0CAA0C;aAC3C;iBAAM,IAAI,gBAAgB,KAAK,CAAC,EAAE,EAAE,eAAe;gBAClD,IAAI,CAAC,OAAO,EAAE,CAAC;aAChB;iBAAM;gBACL,IAAI,CAAC,YAAY,CAAC,OAAO;;;;gBAAC,UAAA,SAAS;oBACjC,KAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;oBAC5B,KAAI,CAAC,IAAI,CAAC,iBAAiB;;;oBAAC;wBAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,EAAE,SAAS,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;oBAC/D,CAAC,EAAC,CAAC;gBACL,CAAC,EAAC,CAAC;gBACH,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;gBAEvB,IAAI,CAAC,cAAc,CAAC,OAAO;;;;gBAAC,UAAA,SAAS;;wBAC7B,GAAG,GAAG,KAAI,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC;oBAC1C,KAAI,CAAC,MAAM,GAAG,KAAI,CAAC,MAAM,CAAC,MAAM;;;;oBAAC,UAAA,CAAC,IAAI,OAAA,CAAC,KAAK,SAAS,EAAf,CAAe,EAAC,CAAC;oBACvD,KAAI,CAAC,IAAI,CAAC,iBAAiB;;;oBAAC;wBAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;oBAC3C,CAAC,EAAC,CAAC;gBACL,CAAC,EAAC,CAAC;gBACH,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;aAC1B;SACF;IACH,CAAC;IAED;;OAEG;;;;;IACH,0CAAS;;;;IAAT;QAAA,iBAsDC;QArDC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;QAAC;YAC1B,KAAI,CAAC,SAAS,GAAG,MAAM,CAAC,KAAI,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;YAE/C,KAAI,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM;;;;;YAAE,UAAC,KAAK,EAAE,KAAK;gBACrC,KAAI,CAAC,IAAI,CAAC,GAAG;;;gBAAC;oBACZ,KAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,OAAA,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC;gBACnC,CAAC,EAAC,CAAC;YACL,CAAC,EAAC,CAAC;YAEH,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAI,CAAC,MAAM,CAAC,CAAC;YAElC,KAAI,CAAC,IAAI,CAAC,GAAG;;;YAAC;;gBACZ,KAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBAExB,KAAI,CAAC,YAAY,GAAG,OAAA,KAAI,CAAC,MAAM,0CAAE,YAAY,KAAI,CAAC,CAAC;YACrD,CAAC,EAAC,CAAC;YAEG,KAAI,CAAC,SAAS,CAAC,EAAE,CAAC,aAAa;;;;;;YAAE,UAAC,KAAK,EAAE,KAAK,EAAE,YAAY;gBACxD,KAAI,CAAC,IAAI,CAAC,GAAG;;;gBAAC;oBACV,KAAI,CAAC,WAAW,CAAC,IAAI,CAAC;wBAClB,KAAK,OAAA;wBACL,KAAK,OAAA;wBACL,YAAY,cAAA;wBACZ,KAAK,EAAE,YAAY,KAAK,CAAC;wBACzB,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,MAAM,KAAK,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,cAAc;qBAC7E,CAAC,CAAC;oBACH,KAAI,CAAC,YAAY,GAAG,YAAY,CAAC;gBACrC,CAAC,EAAC,CAAC;YACP,CAAC,EAAC,CAAC;YAET,KAAI,CAAC,SAAS,CAAC,EAAE,CAAC,cAAc;;;;;;;YAAE,UAAC,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,SAAS;gBACtE,KAAI,CAAC,IAAI,CAAC,GAAG;;;gBAAC;oBACZ,KAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,KAAK,OAAA,EAAE,KAAK,OAAA,EAAE,YAAY,cAAA,EAAE,SAAS,WAAA,EAAE,CAAC,CAAC;oBAClE,KAAI,CAAC,YAAY,GAAG,SAAS,CAAC;gBAChC,CAAC,EAAC,CAAC;YACL,CAAC,EAAC,CAAC;YAEH,KAAI,CAAC,SAAS,CAAC,EAAE,CAAC,YAAY;;;;;;YAAE,UAAC,KAAK,EAAE,KAAK,EAAE,UAAU;gBACvD,KAAI,CAAC,IAAI,CAAC,GAAG;;;gBAAC;oBACZ,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,KAAK,OAAA,EAAE,KAAK,OAAA,EAAE,UAAU,YAAA,EAAE,CAAC,CAAC;gBACrD,CAAC,EAAC,CAAC;YACL,CAAC,EAAC,CAAC;YAEH,KAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS;;;;;YAAE,UAAC,KAAK,EAAE,KAAK;gBACxC,KAAI,CAAC,IAAI,CAAC,GAAG;;;gBAAC;oBACZ,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,OAAA,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC;oBACpC,KAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBAC3B,CAAC,EAAC,CAAC;YACL,CAAC,EAAC,CAAC;QACL,CAAC,EAAC,CAAC;IACL,CAAC;;;;;IAED,yCAAQ;;;;IAAR,UAAS,SAA6B;QACpC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC;;;;;IAED,4CAAW;;;;IAAX,UAAY,SAA6B;QACvC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED;;OAEG;;;;;;IACI,0CAAS;;;;;IAAhB,UAAiB,KAAa;QAA9B,iBAIC;QAHC,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;QAAC;YAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;QAC3C,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAEM,0CAAS;;;IAAhB;QAAA,iBAIC;QAHC,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;QAAC;YAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QACpC,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAEM,0CAAS;;;IAAhB;QAAA,iBAIC;QAHC,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;QAAC;YAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QACpC,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAEM,2CAAU;;;IAAjB;QAAA,iBAIC;QAHC,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;QAAC;YAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACrC,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAEM,0CAAS;;;IAAhB;QAAA,iBAIC;QAHC,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;QAAC;YAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QACpC,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAEM,wCAAO;;;IAAd;QAAA,iBAQC;QAPC,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;YAAC;gBAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAClC,CAAC,EAAC,CAAC;YACH,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;SAC5B;QACD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;;;;;IAED,4CAAW;;;;IAAX,UAAY,OAAsB;QAAlC,iBAaC;QAZC,IAAI,IAAI,CAAC,WAAW,EAAE;;gBACd,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;YAChC,IAAI,MAAM,CAAC,aAAa,KAAK,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,YAAY,KAAK,SAAS,EAAE;;oBAC/E,SAAO,GAAG,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC;;oBACxC,YAAU,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,YAAY,CAAC;gBACzD,OAAO,YAAU,CAAC,SAAS,CAAC,CAAC;gBAE7B,IAAI,CAAC,IAAI,CAAC,iBAAiB;;;gBAAC;oBAC1B,KAAI,CAAC,SAAS,CAAC,KAAK,CAAC,gBAAgB,EAAE,YAAU,EAAE,SAAO,CAAC,CAAC;gBAC9D,CAAC,EAAC,CAAC;aACJ;SACF;IACH,CAAC;;gBAhNF,SAAS,SAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,QAAQ,EAAE,gBAAgB;oBAC1B,SAAS,EAAE,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU;;;4BAAC,cAAM,OAAA,sBAAsB,EAAtB,CAAsB,EAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ,CAAC;oBACF,QAAQ,EAAE,2BAA2B;iBACtC;;;;gBA9BC,UAAU;gBAMV,MAAM;6CAiDO,MAAM,SAAC,WAAW;;;yBAtB5B,KAAK;8BACL,MAAM;+BACN,MAAM;6BACN,MAAM;0BACN,MAAM;uBACN,MAAM;;IAiMX,6BAAC;CAAA,AAlND,IAkNC;SAxMY,sBAAsB;;;IAE/B,wCAAqB;;IACrB,6CAA0I;;IAC1I,8CAA+H;;IAC/H,4CAAqG;;IACrG,yCAAiF;;IACjF,sCAA8E;;IAEhF,2CAAsB;;;;;IAGtB,8CAAyB;;IAEzB,wCAA0B;;IAC1B,6CAA2B;;;;;IAC3B,gDAAkD;;;;;IAClD,8CAAgD;;;;;IAKpC,oCAAsB;;;;;IACtB,sCAAoB;;;;;IACpB,4CAA+C;;AAkL7D;IAIE,4BAAmB,EAAc,EACQ,UAAkB,EAC/B,QAAgC;QAFzC,OAAE,GAAF,EAAE,CAAY;QACQ,eAAU,GAAV,UAAU,CAAQ;QAC/B,aAAQ,GAAR,QAAQ,CAAwB;IAC5D,CAAC;;;;IAED,qCAAQ;;;IAAR;QACE,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACtC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SAC9B;IACH,CAAC;;;;IAED,wCAAW;;;IAAX;QACE,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACtC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;SACjC;IACH,CAAC;;gBAnBF,SAAS,SAAC;oBACT,QAAQ,EAAE,gBAAgB;iBAC3B;;;;gBA3OC,UAAU;6CA8OG,MAAM,SAAC,WAAW;gBACO,sBAAsB,uBAA/C,IAAI;;IAcnB,yBAAC;CAAA,AApBD,IAoBC;SAjBY,kBAAkB;;;IACjB,gCAAqB;;;;;IACrB,wCAA+C;;;;;IAC/C,sCAAgD","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"]}