ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
513 lines • 41.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, NgZone, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';
import { fromEvent, Subscription } from 'rxjs';
import { debounceTime } from 'rxjs/operators';
import { InputBoolean, InputNumber } from '../core/util/convert';
import { NzCarouselContentDirective } from './nz-carousel-content.directive';
var NzCarouselComponent = /** @class */ (function () {
function NzCarouselComponent(elementRef, renderer, cdr, ngZone) {
this.elementRef = elementRef;
this.renderer = renderer;
this.cdr = cdr;
this.ngZone = ngZone;
this.nzTransitionSpeed = 500; // Not exposed.
this.nzEffect = 'scrollx';
this.nzEnableSwipe = true;
this.nzDots = true;
this.nzVertical = false;
this.nzAutoPlay = false;
this.nzAutoPlaySpeed = 3000; // Should be nzAutoPlayDuration, but changing this is breaking.
// Should be nzAutoPlayDuration, but changing this is breaking.
this.nzAfterChange = new EventEmitter();
this.nzBeforeChange = new EventEmitter();
this.activeIndex = 0;
this.transform = 'translate3d(0px, 0px, 0px)';
this.el = this.elementRef.nativeElement;
this.subs_ = new Subscription();
renderer.addClass(elementRef.nativeElement, 'ant-carousel');
}
Object.defineProperty(NzCarouselComponent.prototype, "nextIndex", {
get: /**
* @return {?}
*/
function () {
return this.activeIndex < this.slideContents.length - 1 ? (this.activeIndex + 1) : 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzCarouselComponent.prototype, "prevIndex", {
get: /**
* @return {?}
*/
function () {
return this.activeIndex > 0 ? (this.activeIndex - 1) : (this.slideContents.length - 1);
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NzCarouselComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
if (this.slideContents && this.slideContents.length) {
this.slideContents.first.isActive = true;
}
};
/**
* @return {?}
*/
NzCarouselComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
// Re-render when content changes.
this.subs_.add(this.slideContents.changes.subscribe((/**
* @return {?}
*/
function () {
_this.renderContent();
})));
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () {
_this.subs_.add(fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe((/**
* @return {?}
*/
function () {
_this.renderContent();
_this.setTransition();
})));
}));
// When used in modals (drawers maybe too), it should render itself asynchronously.
// Refer to https://github.com/NG-ZORRO/ng-zorro-antd/issues/2387
Promise.resolve().then((/**
* @return {?}
*/
function () {
_this.renderContent();
}));
};
/**
* @param {?} changes
* @return {?}
*/
NzCarouselComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.nzAutoPlay || changes.nzAutoPlaySpeed) {
this.setUpNextScroll();
}
if (changes.nzEffect) {
this.updateMode();
}
};
/**
* @return {?}
*/
NzCarouselComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.subs_.unsubscribe();
this.clearTimeout();
};
/**
* @param {?} index
* @return {?}
*/
NzCarouselComponent.prototype.setContentActive = /**
* @param {?} index
* @return {?}
*/
function (index) {
var _this = this;
if (this.slideContents && this.slideContents.length) {
this.nzBeforeChange.emit({ from: this.slideContents.toArray().findIndex((/**
* @param {?} slide
* @return {?}
*/
function (slide) { return slide.isActive; })), to: index });
this.activeIndex = index;
this.setTransition();
this.slideContents.forEach((/**
* @param {?} slide
* @param {?} i
* @return {?}
*/
function (slide, i) { return slide.isActive = index === i; }));
this.setUpNextScroll();
this.cdr.markForCheck();
// Should trigger the following when animation is done. The transition takes 0.5 seconds according to the CSS.
setTimeout((/**
* @return {?}
*/
function () { return _this.nzAfterChange.emit(index); }), this.nzTransitionSpeed);
}
};
/**
* @private
* @return {?}
*/
NzCarouselComponent.prototype.setTransition = /**
* @private
* @return {?}
*/
function () {
this.transform = this.nzEffect === 'fade'
? 'translate3d(0px, 0px, 0px)'
: this.nzVertical
// `Scrollx` mode.
? "translate3d(0px, " + -this.activeIndex * this.el.offsetHeight + "px, 0px)"
: "translate3d(" + -this.activeIndex * this.el.offsetWidth + "px, 0px, 0px)";
if (this.slickTrack) {
this.renderer.setStyle(this.slickTrack.nativeElement, 'transform', this.transform);
}
};
/**
* @return {?}
*/
NzCarouselComponent.prototype.next = /**
* @return {?}
*/
function () {
this.setContentActive(this.nextIndex);
};
/**
* @return {?}
*/
NzCarouselComponent.prototype.pre = /**
* @return {?}
*/
function () {
this.setContentActive(this.prevIndex);
};
/**
* @param {?} index
* @return {?}
*/
NzCarouselComponent.prototype.goTo = /**
* @param {?} index
* @return {?}
*/
function (index) {
if (index >= 0 && index <= this.slideContents.length - 1) {
this.setContentActive(index);
}
};
/**
* @param {?} e
* @return {?}
*/
NzCarouselComponent.prototype.onKeyDown = /**
* @param {?} e
* @return {?}
*/
function (e) {
if (e.keyCode === LEFT_ARROW) { // Left
this.pre();
e.preventDefault();
}
else if (e.keyCode === RIGHT_ARROW) { // Right
this.next();
e.preventDefault();
}
};
/**
* @param {?=} action
* @return {?}
*/
NzCarouselComponent.prototype.swipe = /**
* @param {?=} action
* @return {?}
*/
function (action) {
if (action === void 0) { action = 'swipeleft'; }
if (!this.nzEnableSwipe) {
return;
}
if (action === 'swipeleft') {
this.next();
}
if (action === 'swiperight') {
this.pre();
}
};
/* tslint:disable-next-line:no-any */
/* tslint:disable-next-line:no-any */
/**
* @param {?} e
* @return {?}
*/
NzCarouselComponent.prototype.swipeInProgress = /* tslint:disable-next-line:no-any */
/**
* @param {?} e
* @return {?}
*/
function (e) {
if (this.nzEffect === 'scrollx') {
/** @type {?} */
var final = e.isFinal;
/** @type {?} */
var scrollWidth = final ? 0 : e.deltaX * 1.2;
/** @type {?} */
var totalWidth = this.el.offsetWidth;
if (this.nzVertical) {
/** @type {?} */
var totalHeight = this.el.offsetHeight;
/** @type {?} */
var scrollPercent = scrollWidth / totalWidth;
/** @type {?} */
var scrollHeight = scrollPercent * totalHeight;
this.transform = "translate3d(0px, " + (-this.activeIndex * totalHeight + scrollHeight) + "px, 0px)";
}
else {
this.transform = "translate3d(" + (-this.activeIndex * totalWidth + scrollWidth) + "px, 0px, 0px)";
}
if (this.slickTrack) {
this.renderer.setStyle(this.slickTrack.nativeElement, 'transform', this.transform);
}
}
if (e.isFinal) {
this.setUpNextScroll();
}
else {
this.clearTimeout();
}
};
/**
* @return {?}
*/
NzCarouselComponent.prototype.clearTimeout = /**
* @return {?}
*/
function () {
if (this.transitionAction) {
clearTimeout(this.transitionAction);
this.transitionAction = null;
}
};
/**
* Make a carousel scroll to `this.nextIndex` after `this.nzAutoPlaySpeed` milliseconds.
*/
/**
* Make a carousel scroll to `this.nextIndex` after `this.nzAutoPlaySpeed` milliseconds.
* @private
* @return {?}
*/
NzCarouselComponent.prototype.setUpNextScroll = /**
* Make a carousel scroll to `this.nextIndex` after `this.nzAutoPlaySpeed` milliseconds.
* @private
* @return {?}
*/
function () {
var _this = this;
this.clearTimeout();
if (this.nzAutoPlay && this.nzAutoPlaySpeed > 0) {
this.transitionAction = setTimeout((/**
* @return {?}
*/
function () {
_this.setContentActive(_this.nextIndex);
}), this.nzAutoPlaySpeed);
}
};
/**
* @private
* @return {?}
*/
NzCarouselComponent.prototype.updateMode = /**
* @private
* @return {?}
*/
function () {
if (this.slideContents && this.slideContents.length) {
this.renderContent();
this.setContentActive(0);
}
};
/**
* @private
* @return {?}
*/
NzCarouselComponent.prototype.renderContent = /**
* @private
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var slickTrackElement = this.slickTrack.nativeElement;
/** @type {?} */
var slickListElement = this.slickList.nativeElement;
if (this.slideContents && this.slideContents.length) {
this.slideContents.forEach((/**
* @param {?} content
* @param {?} i
* @return {?}
*/
function (content, i) {
content.width = _this.el.offsetWidth;
if (_this.nzEffect === 'fade') {
content.fadeMode = true;
if (_this.nzVertical) {
content.top = -i * _this.el.offsetHeight;
}
else {
content.left = -i * content.width;
}
}
else {
content.fadeMode = false;
content.left = null;
content.top = null;
}
}));
if (this.nzVertical) {
this.renderer.removeStyle(slickTrackElement, 'width');
this.renderer.removeStyle(slickListElement, 'width');
this.renderer.setStyle(slickListElement, 'height', this.slideContents.first.el.offsetHeight + "px");
this.renderer.setStyle(slickTrackElement, 'height', this.slideContents.length * this.el.offsetHeight + "px");
}
else {
this.renderer.removeStyle(slickTrackElement, 'height');
this.renderer.removeStyle(slickListElement, 'height');
this.renderer.removeStyle(slickTrackElement, 'width'); // This is necessary to prevent carousel items to overflow.
this.renderer.setStyle(slickTrackElement, 'width', this.slideContents.length * this.el.offsetWidth + "px");
}
this.setUpNextScroll();
this.cdr.markForCheck();
}
};
NzCarouselComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
selector: 'nz-carousel',
preserveWhitespaces: false,
template: "<div class=\"slick-initialized slick-slider\" [class.slick-vertical]=\"nzVertical\">\n <div\n class=\"slick-list\"\n #slickList\n tabindex=\"-1\"\n (keydown)=\"onKeyDown($event)\"\n (swipeleft)=\"swipe('swipeleft')\"\n (swiperight)=\"swipe('swiperight')\"\n (pan)=\"swipeInProgress($event);\">\n <div class=\"slick-track\" #slickTrack>\n <ng-content></ng-content>\n </div>\n </div>\n <ul class=\"slick-dots\" *ngIf=\"nzDots\">\n <li *ngFor=\"let content of slideContents; let i = index\" [class.slick-active]=\"content.isActive\" (click)=\"goTo(i)\">\n <ng-template [ngTemplateOutlet]=\"nzDotRender || renderDotTemplate\" [ngTemplateOutletContext]=\"{ $implicit: i }\"></ng-template>\n </li>\n </ul>\n</div>\n\n<ng-template #renderDotTemplate let-index>\n <button>{{index + 1}}</button>\n</ng-template>\n",
host: {
'[class.ant-carousel-vertical]': 'nzVertical'
},
styles: ["\n nz-carousel {\n display: block;\n position: relative;\n overflow: hidden;\n width: 100%;\n height: 100%;\n }\n\n .slick-dots {\n display: block;\n }\n\n .slick-track {\n opacity: 1;\n transition: all 0.5s ease;\n }\n\n .slick-slide {\n transition: opacity 500ms ease;\n }\n "]
}] }
];
/** @nocollapse */
NzCarouselComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 },
{ type: ChangeDetectorRef },
{ type: NgZone }
]; };
NzCarouselComponent.propDecorators = {
slideContents: [{ type: ContentChildren, args: [NzCarouselContentDirective,] }],
slickList: [{ type: ViewChild, args: ['slickList',] }],
slickTrack: [{ type: ViewChild, args: ['slickTrack',] }],
nzTransitionSpeed: [{ type: Input }],
nzDotRender: [{ type: Input }],
nzEffect: [{ type: Input }],
nzEnableSwipe: [{ type: Input }],
nzDots: [{ type: Input }],
nzVertical: [{ type: Input }],
nzAutoPlay: [{ type: Input }],
nzAutoPlaySpeed: [{ type: Input }],
nzAfterChange: [{ type: Output }],
nzBeforeChange: [{ type: Output }]
};
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzCarouselComponent.prototype, "nzEnableSwipe", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Boolean)
], NzCarouselComponent.prototype, "nzDots", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Boolean)
], NzCarouselComponent.prototype, "nzVertical", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzCarouselComponent.prototype, "nzAutoPlay", void 0);
tslib_1.__decorate([
InputNumber(),
tslib_1.__metadata("design:type", Object)
], NzCarouselComponent.prototype, "nzAutoPlaySpeed", void 0);
return NzCarouselComponent;
}());
export { NzCarouselComponent };
if (false) {
/** @type {?} */
NzCarouselComponent.prototype.slideContents;
/** @type {?} */
NzCarouselComponent.prototype.slickList;
/** @type {?} */
NzCarouselComponent.prototype.slickTrack;
/** @type {?} */
NzCarouselComponent.prototype.nzTransitionSpeed;
/** @type {?} */
NzCarouselComponent.prototype.nzDotRender;
/** @type {?} */
NzCarouselComponent.prototype.nzEffect;
/** @type {?} */
NzCarouselComponent.prototype.nzEnableSwipe;
/** @type {?} */
NzCarouselComponent.prototype.nzDots;
/** @type {?} */
NzCarouselComponent.prototype.nzVertical;
/** @type {?} */
NzCarouselComponent.prototype.nzAutoPlay;
/** @type {?} */
NzCarouselComponent.prototype.nzAutoPlaySpeed;
/** @type {?} */
NzCarouselComponent.prototype.nzAfterChange;
/** @type {?} */
NzCarouselComponent.prototype.nzBeforeChange;
/** @type {?} */
NzCarouselComponent.prototype.activeIndex;
/** @type {?} */
NzCarouselComponent.prototype.transform;
/** @type {?} */
NzCarouselComponent.prototype.transitionAction;
/**
* @type {?}
* @private
*/
NzCarouselComponent.prototype.el;
/**
* @type {?}
* @private
*/
NzCarouselComponent.prototype.subs_;
/** @type {?} */
NzCarouselComponent.prototype.elementRef;
/**
* @type {?}
* @private
*/
NzCarouselComponent.prototype.renderer;
/**
* @type {?}
* @private
*/
NzCarouselComponent.prototype.cdr;
/**
* @type {?}
* @private
*/
NzCarouselComponent.prototype.ngZone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-carousel.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["carousel/nz-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { fromEvent, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { InputBoolean, InputNumber } from '../core/util/convert';\nimport { NzCarouselContentDirective } from './nz-carousel-content.directive';\n\nexport type NzCarouselEffects = 'fade' | 'scrollx';\n\nexport type SwipeDirection = 'swipeleft' | 'swiperight';\n\n@Component({\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  encapsulation      : ViewEncapsulation.None,\n  selector           : 'nz-carousel',\n  preserveWhitespaces: false,\n  templateUrl        : './nz-carousel.component.html',\n  host               : {\n    '[class.ant-carousel-vertical]': 'nzVertical'\n  },\n  styles             : [\n      `\n      nz-carousel {\n        display: block;\n        position: relative;\n        overflow: hidden;\n        width: 100%;\n        height: 100%;\n      }\n\n      .slick-dots {\n        display: block;\n      }\n\n      .slick-track {\n        opacity: 1;\n        transition: all 0.5s ease;\n      }\n\n      .slick-slide {\n        transition: opacity 500ms ease;\n      }\n    `\n  ]\n})\nexport class NzCarouselComponent implements AfterViewInit, AfterContentInit, OnDestroy, OnChanges {\n  @ContentChildren(NzCarouselContentDirective) slideContents: QueryList<NzCarouselContentDirective>;\n  @ViewChild('slickList') slickList: ElementRef;\n  @ViewChild('slickTrack') slickTrack: ElementRef;\n\n  @Input() nzTransitionSpeed = 500; // Not exposed.\n  @Input() nzDotRender: TemplateRef<{ $implicit: number }>;\n  @Input() nzEffect: NzCarouselEffects = 'scrollx';\n  @Input() @InputBoolean() nzEnableSwipe = true;\n  @Input() @InputBoolean() nzDots: boolean = true;\n  @Input() @InputBoolean() nzVertical: boolean = false;\n  @Input() @InputBoolean() nzAutoPlay = false;\n  @Input() @InputNumber() nzAutoPlaySpeed = 3000; // Should be nzAutoPlayDuration, but changing this is breaking.\n\n  @Output() readonly nzAfterChange: EventEmitter<number> = new EventEmitter();\n  @Output() readonly nzBeforeChange: EventEmitter<{ from: number; to: number }> = new EventEmitter();\n\n  activeIndex = 0;\n  transform = 'translate3d(0px, 0px, 0px)';\n  transitionAction: number;\n\n  private el = this.elementRef.nativeElement;\n  private subs_ = new Subscription();\n\n  get nextIndex(): number {\n    return this.activeIndex < this.slideContents.length - 1 ? (this.activeIndex + 1) : 0;\n  }\n\n  get prevIndex(): number {\n    return this.activeIndex > 0 ? (this.activeIndex - 1) : (this.slideContents.length - 1);\n  }\n\n  constructor(public elementRef: ElementRef, private renderer: Renderer2, private cdr: ChangeDetectorRef, private ngZone: NgZone) {\n    renderer.addClass(elementRef.nativeElement, 'ant-carousel');\n  }\n\n  ngAfterContentInit(): void {\n    if (this.slideContents && this.slideContents.length) {\n      this.slideContents.first.isActive = true;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    // Re-render when content changes.\n    this.subs_.add(this.slideContents.changes.subscribe(() => {\n      this.renderContent();\n    }));\n\n    this.ngZone.runOutsideAngular(() => {\n      this.subs_.add(fromEvent(window, 'resize').pipe(debounceTime(50)).subscribe(() => {\n        this.renderContent();\n        this.setTransition();\n      }));\n    });\n\n    // When used in modals (drawers maybe too), it should render itself asynchronously.\n    // Refer to https://github.com/NG-ZORRO/ng-zorro-antd/issues/2387\n    Promise.resolve().then(() => {\n      this.renderContent();\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzAutoPlay || changes.nzAutoPlaySpeed) {\n      this.setUpNextScroll();\n    }\n    if (changes.nzEffect) {\n      this.updateMode();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subs_.unsubscribe();\n    this.clearTimeout();\n  }\n\n  setContentActive(index: number): void {\n    if (this.slideContents && this.slideContents.length) {\n      this.nzBeforeChange.emit({ from: this.slideContents.toArray().findIndex(slide => slide.isActive), to: index });\n      this.activeIndex = index;\n      this.setTransition();\n      this.slideContents.forEach((slide, i) => slide.isActive = index === i);\n      this.setUpNextScroll();\n      this.cdr.markForCheck();\n      // Should trigger the following when animation is done. The transition takes 0.5 seconds according to the CSS.\n      setTimeout(() => this.nzAfterChange.emit(index), this.nzTransitionSpeed);\n    }\n  }\n\n  private setTransition(): void {\n    this.transform = this.nzEffect === 'fade'\n      ? 'translate3d(0px, 0px, 0px)'\n      : this.nzVertical\n        // `Scrollx` mode.\n        ? `translate3d(0px, ${-this.activeIndex * this.el.offsetHeight}px, 0px)`\n        : `translate3d(${-this.activeIndex * this.el.offsetWidth}px, 0px, 0px)`;\n    if (this.slickTrack) {\n      this.renderer.setStyle(this.slickTrack.nativeElement, 'transform', this.transform);\n    }\n  }\n\n  next(): void {\n    this.setContentActive(this.nextIndex);\n  }\n\n  pre(): void {\n    this.setContentActive(this.prevIndex);\n  }\n\n  goTo(index: number): void {\n    if (index >= 0 && index <= this.slideContents.length - 1) {\n      this.setContentActive(index);\n    }\n  }\n\n  onKeyDown(e: KeyboardEvent): void {\n    if (e.keyCode === LEFT_ARROW) { // Left\n      this.pre();\n      e.preventDefault();\n    } else if (e.keyCode === RIGHT_ARROW) { // Right\n      this.next();\n      e.preventDefault();\n    }\n  }\n\n  swipe(action: SwipeDirection = 'swipeleft'): void {\n    if (!this.nzEnableSwipe) {\n      return;\n    }\n    if (action === 'swipeleft') {\n      this.next();\n    }\n    if (action === 'swiperight') {\n      this.pre();\n    }\n  }\n\n  /* tslint:disable-next-line:no-any */\n  swipeInProgress(e: any): void {\n    if (this.nzEffect === 'scrollx') {\n      const final = e.isFinal;\n      const scrollWidth = final ? 0 : e.deltaX * 1.2;\n      const totalWidth = this.el.offsetWidth;\n      if (this.nzVertical) {\n        const totalHeight = this.el.offsetHeight;\n        const scrollPercent = scrollWidth / totalWidth;\n        const scrollHeight = scrollPercent * totalHeight;\n        this.transform = `translate3d(0px, ${-this.activeIndex * totalHeight + scrollHeight}px, 0px)`;\n      } else {\n        this.transform = `translate3d(${-this.activeIndex * totalWidth + scrollWidth}px, 0px, 0px)`;\n      }\n      if (this.slickTrack) {\n        this.renderer.setStyle(this.slickTrack.nativeElement, 'transform', this.transform);\n      }\n    }\n    if (e.isFinal) {\n      this.setUpNextScroll();\n    } else {\n      this.clearTimeout();\n    }\n  }\n\n  clearTimeout(): void {\n    if (this.transitionAction) {\n      clearTimeout(this.transitionAction);\n      this.transitionAction = null;\n    }\n  }\n\n  /**\n   * Make a carousel scroll to `this.nextIndex` after `this.nzAutoPlaySpeed` milliseconds.\n   */\n  private setUpNextScroll(): void {\n    this.clearTimeout();\n    if (this.nzAutoPlay && this.nzAutoPlaySpeed > 0) {\n      this.transitionAction = setTimeout(() => {\n        this.setContentActive(this.nextIndex);\n      }, this.nzAutoPlaySpeed);\n    }\n  }\n\n  private updateMode(): void {\n    if (this.slideContents && this.slideContents.length) {\n      this.renderContent();\n      this.setContentActive(0);\n    }\n  }\n\n  private renderContent(): void {\n    const slickTrackElement = this.slickTrack.nativeElement;\n    const slickListElement = this.slickList.nativeElement;\n    if (this.slideContents && this.slideContents.length) {\n      this.slideContents.forEach((content, i) => {\n        content.width = this.el.offsetWidth;\n        if (this.nzEffect === 'fade') {\n          content.fadeMode = true;\n          if (this.nzVertical) {\n            content.top = -i * this.el.offsetHeight;\n          } else {\n            content.left = -i * content.width;\n          }\n        } else {\n          content.fadeMode = false;\n          content.left = null;\n          content.top = null;\n        }\n      });\n      if (this.nzVertical) {\n        this.renderer.removeStyle(slickTrackElement, 'width');\n        this.renderer.removeStyle(slickListElement, 'width');\n        this.renderer.setStyle(slickListElement, 'height', `${this.slideContents.first.el.offsetHeight}px`);\n        this.renderer.setStyle(slickTrackElement, 'height', `${this.slideContents.length * this.el.offsetHeight}px`);\n      } else {\n        this.renderer.removeStyle(slickTrackElement, 'height');\n        this.renderer.removeStyle(slickListElement, 'height');\n        this.renderer.removeStyle(slickTrackElement, 'width'); // This is necessary to prevent carousel items to overflow.\n        this.renderer.setStyle(slickTrackElement, 'width', `${this.slideContents.length * this.el.offsetWidth}px`);\n      }\n      this.setUpNextScroll();\n      this.cdr.markForCheck();\n    }\n  }\n}\n"]}