UNPKG

ngx-slice-kit

Version:

[![npm version](https://badge.fury.io/js/ngx-slice-kit.svg)](https://badge.fury.io/js/ngx-slice-kit)

261 lines 45.4 kB
import { Component, ContentChildren, HostListener, Input, ViewChild } from '@angular/core'; import { SlideComponent } from './slide/slide.component'; import { fromEvent, interval } from 'rxjs'; import { filter, repeatWhen, takeUntil } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../dots/dots.component"; import * as i3 from "../../buttons/icon/icon.component"; import * as i4 from "../../buttons/button/button.component"; export class CarouselComponent { constructor(el, renderer) { this.el = el; this.renderer = renderer; this.dots = false; this.infinity = false; this.pauseByHover = false; this.arrows = true; this.slidesToScroll = 1; this.slidesToShow = 1; this.timeout = 5000; this.offset = 0; this.slidesArr = []; this.activeSlideIndex = 0; this.curCarouselPosition = 0; this.pagePenalty = 0; this.isGrabbed = false; this.isViewInit = false; } get dotsCount() { return Math.ceil(this.slidesArr.length / this.slidesToScroll); } windowResizeHandler() { if (this.carouselWrapper.nativeElement.offsetWidth !== this.carouselWrapperRects?.width) { this.updateSlider(); } } pointerUpHandler() { if (!this.isGrabbed) { return; } this.isGrabbed = false; if (this.scrollOffset < this.curCarouselPosition - 100) { this.move('forward'); } else if (this.scrollOffset > this.curCarouselPosition + 100) { this.move('back'); } else { this.animate(this.curCarouselPosition); } this.scrollOffset = 0; } pointerMoveHandler(event) { if (this.isGrabbed) { this.scrollOffset = this.curCarouselPosition + event.clientX - this.scrollStartX; this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.scrollOffset}px)`); } } animate(newPosition) { this.isScrolling = true; this.renderer.setStyle(this.carouselRow.nativeElement, 'transition', `400ms`); this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${newPosition}px)`); this.updatePosition(); if (this.activeSlideIndex + 1 > this.dotsCount) { this.activeSlideIndex = 0; setTimeout(() => { this.curCarouselPosition = -(this.slidesToScroll * this.slideWidth); this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.curCarouselPosition}px)`); this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect(); }, 500); } if (this.activeSlideIndex === -1) { this.activeSlideIndex = this.dotsCount - 1; setTimeout(() => { this.curCarouselPosition = -(this.slidesToScroll * this.slideWidth) * this.dotsCount; this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.curCarouselPosition}px)`); this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect(); }, 500); } } grab(event) { event.preventDefault(); this.isGrabbed = true; this.scrollStartX = event.clientX; } move(direction) { this.carouselWrapperRects = this.carouselWrapper.nativeElement.getBoundingClientRect(); const widthPenalty = (this.activeSlideIndex === 0 ? this.slideWidth * (this.dotsCount * this.slidesToScroll - this.slidesArr.length) : 0); if (this.isScrolling) { return; } switch (direction) { case 'back': this.curCarouselPosition += this.carouselRowRects.left + this.scrollStep > this.carouselWrapperRects.left ? this.carouselWrapperRects.left - this.carouselRowRects.left : this.scrollStep - widthPenalty; break; case 'forward': this.curCarouselPosition += this.carouselRowRects.right - this.scrollStep < this.carouselWrapperRects.right ? -(this.carouselRowRects.right - this.carouselWrapperRects.right) : -this.scrollStep; break; } const prevIndex = this.activeSlideIndex; this.activeSlideIndex = Math.ceil(Math.abs(this.curCarouselPosition + this.pagePenalty) / (this.scrollStep)) % (this.dotsCount + 1); if (prevIndex === 0 && this.activeSlideIndex === 1 && direction === 'back') { this.activeSlideIndex = -1; } this.animate(this.curCarouselPosition); } selectSlide(slideIndex) { this.activeSlideIndex = slideIndex; let notMultipleDif = 0; if (slideIndex + 1 === this.dotsCount) { notMultipleDif = (this.slidesArr.length % this.slidesToScroll) * this.slideWidth; } this.curCarouselPosition = -(this.activeSlideIndex * this.slideWidth * this.slidesToScroll - notMultipleDif) - this.pagePenalty; this.animate(this.curCarouselPosition); } updatePosition() { setTimeout(() => { this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect(); this.renderer.removeStyle(this.carouselRow.nativeElement, 'transition'); this.isScrolling = false; }, 500); } setSlideStyles() { this.slidesArr.forEach(slide => { if (this.offset) { this.renderer.setStyle(slide.el.nativeElement, 'padding', this.offset + 'px'); } this.renderer.setStyle(slide.el.nativeElement, 'width', this.slideWidth + 'px'); }); } checkSlidesToScroll() { if (this.slidesToScroll > this.slidesArr.length) { this.slidesToScroll = this.slidesArr.length; } } createClones() { this.lastPageClones = [...this.slidesArr].slice(-this.slidesToShow).map(this.cloneNode.bind(this)).reverse(); this.firstPageClones = [...this.slidesArr].slice(0, this.slidesToShow).map(this.cloneNode.bind(this)); } cloneNode(node) { const clone = node.el.nativeElement.cloneNode(true); this.renderer.addClass(clone, 'sdk-slide--clone'); return clone; } insertClones() { for (const clone of this.lastPageClones) { this.renderer.insertBefore(this.carouselRow.nativeElement, clone, this.carouselRow.nativeElement.firstChild); } for (const clone of this.firstPageClones) { this.renderer.appendChild(this.carouselRow.nativeElement, clone); } } removeClones() { for (const clone of this.firstPageClones) { this.renderer.removeChild(this.carouselRow.nativeElement, clone); } for (const clone of this.lastPageClones) { this.renderer.removeChild(this.carouselRow.nativeElement, clone); } } updateSlider() { this.carouselWrapperRects = this.carouselWrapper.nativeElement.getBoundingClientRect(); this.slideWidth = this.carouselWrapper.nativeElement.offsetWidth / this.slidesToShow; this.scrollStep = this.slidesToScroll * this.slideWidth; this.setSlideStyles(); this.checkSlidesToScroll(); if (this.infinity) { this.pagePenalty = this.scrollStep; if (this.firstPageClones || this.lastPageClones) { this.removeClones(); } this.createClones(); this.insertClones(); this.curCarouselPosition = -(this.slidesToScroll * this.slideWidth); this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.curCarouselPosition}px)`); this.updatePosition(); } this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect(); } ngOnInit() { this.sub = fromEvent(this.carouselRow.nativeElement, 'pointerdown').subscribe(pointerEvent => { this.grab(pointerEvent); }); } ngAfterContentInit() { this.slideWidth = this.carouselWrapper.nativeElement.offsetWidth / this.slidesToShow; this.slidesArr = this.carouselSlides.toArray(); } ngAfterViewInit() { const pointerEnter$ = fromEvent(this.el.nativeElement, 'pointerenter').pipe(filter(() => this.pauseByHover)); const pointerLeave$ = fromEvent(this.el.nativeElement, 'pointerleave'); const pointerLeave = pointerLeave$.subscribe(() => { this.pointerUpHandler(); }); this.isViewInit = true; this.updateSlider(); this.sub.add(pointerLeave); if (this.timeout) { const slideTimeout = interval(this.timeout) .pipe(takeUntil(pointerEnter$), repeatWhen(() => pointerLeave$)) .subscribe(() => { this.move('forward'); }); this.sub.add(slideTimeout); } } // ngOnChanges(changes): void { // if (this.isViewInit) { // if (changes.slidesToScroll || changes.slidesToShow) { // this.updateSlider(); // } // } // } ngOnDestroy() { this.sub?.unsubscribe(); } } CarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: CarouselComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); CarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: CarouselComponent, selector: "sdk-carousel", inputs: { dots: "dots", infinity: "infinity", pauseByHover: "pauseByHover", arrows: "arrows", slidesToScroll: "slidesToScroll", slidesToShow: "slidesToShow", timeout: "timeout", offset: "offset" }, host: { listeners: { "window:resize": "windowResizeHandler()", "pointerup": "pointerUpHandler()", "pointermove": "pointerMoveHandler($event)" } }, queries: [{ propertyName: "carouselSlides", predicate: SlideComponent }], viewQueries: [{ propertyName: "carouselWrapper", first: true, predicate: ["carouselWrapper"], descendants: true, static: true }, { propertyName: "carouselRow", first: true, predicate: ["carouselRow"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"sdk-carousel\">\n <div class=\"sdk-carousel__wrapper\" #carouselWrapper>\n <ng-container *ngIf=\"arrows\">\n <button sdk-round-button class=\"sdk-carousel__arrow sdk-carousel__arrow--left\" color=\"basic\"\n (click)=\"move('back')\">\n <sdk-icon icon=\"chevron_left\" [size]=\"24\"></sdk-icon>\n </button>\n <button sdk-round-button class=\"sdk-carousel__arrow sdk-carousel__arrow--right\" color=\"basic\"\n (click)=\"move('forward')\">\n <sdk-icon icon=\"chevron_right\" [size]=\"24\"></sdk-icon>\n </button>\n </ng-container>\n <div class=\"sdk-carousel__row\" #carouselRow draggable=\"false\">\n <ng-content select=\"sdk-slide\"></ng-content>\n </div>\n </div>\n <div class=\"sdk-carousel__dots\" *ngIf=\"dots\" [style.bottom.px]=\"-offset\">\n <sdk-dots [activeIndex]=\"activeSlideIndex\" [count]=\"dotsCount\" (selected)=\"selectSlide($event)\"></sdk-dots>\n </div>\n</div>\n", styles: [".sdk-carousel__wrapper{display:flex;position:relative;overflow:hidden}.sdk-carousel__arrow{position:absolute;height:44px;width:44px;background-color:var(--background-a100);box-shadow:0 0 4px #0000004d;transition:all .4s;z-index:1;top:calc(50% - 22px)}.sdk-carousel__arrow:hover{box-shadow:0 0 6px -3px #0000004d}.sdk-carousel__arrow:active{box-shadow:inset 0 0 4px 2px #0000004d}.sdk-carousel__arrow--right{right:2px}.sdk-carousel__arrow--left{left:2px}.sdk-carousel__dots{margin-top:12px;width:100%;display:flex;justify-content:center}.sdk-carousel__row{display:flex;position:relative;align-items:center;left:0}.sdk-carousel__row img{-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DotsComponent, selector: "sdk-dots", inputs: ["count", "activeIndex", "small"], outputs: ["selected"] }, { kind: "component", type: i3.IconComponent, selector: "sdk-icon", inputs: ["icon", "image", "inline", "size", "color"] }, { kind: "component", type: i4.ButtonComponent, selector: "[sdk-base-button], [sdk-flat-button], [sdk-raised-button], [sdk-stroked-button], [sdk-round-button], [sdk-icon-button]", inputs: ["color", "size", "small", "disabled"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: CarouselComponent, decorators: [{ type: Component, args: [{ selector: 'sdk-carousel', template: "<div class=\"sdk-carousel\">\n <div class=\"sdk-carousel__wrapper\" #carouselWrapper>\n <ng-container *ngIf=\"arrows\">\n <button sdk-round-button class=\"sdk-carousel__arrow sdk-carousel__arrow--left\" color=\"basic\"\n (click)=\"move('back')\">\n <sdk-icon icon=\"chevron_left\" [size]=\"24\"></sdk-icon>\n </button>\n <button sdk-round-button class=\"sdk-carousel__arrow sdk-carousel__arrow--right\" color=\"basic\"\n (click)=\"move('forward')\">\n <sdk-icon icon=\"chevron_right\" [size]=\"24\"></sdk-icon>\n </button>\n </ng-container>\n <div class=\"sdk-carousel__row\" #carouselRow draggable=\"false\">\n <ng-content select=\"sdk-slide\"></ng-content>\n </div>\n </div>\n <div class=\"sdk-carousel__dots\" *ngIf=\"dots\" [style.bottom.px]=\"-offset\">\n <sdk-dots [activeIndex]=\"activeSlideIndex\" [count]=\"dotsCount\" (selected)=\"selectSlide($event)\"></sdk-dots>\n </div>\n</div>\n", styles: [".sdk-carousel__wrapper{display:flex;position:relative;overflow:hidden}.sdk-carousel__arrow{position:absolute;height:44px;width:44px;background-color:var(--background-a100);box-shadow:0 0 4px #0000004d;transition:all .4s;z-index:1;top:calc(50% - 22px)}.sdk-carousel__arrow:hover{box-shadow:0 0 6px -3px #0000004d}.sdk-carousel__arrow:active{box-shadow:inset 0 0 4px 2px #0000004d}.sdk-carousel__arrow--right{right:2px}.sdk-carousel__arrow--left{left:2px}.sdk-carousel__dots{margin-top:12px;width:100%;display:flex;justify-content:center}.sdk-carousel__row{display:flex;position:relative;align-items:center;left:0}.sdk-carousel__row img{-webkit-user-select:none;user-select:none}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { carouselSlides: [{ type: ContentChildren, args: [SlideComponent] }], carouselWrapper: [{ type: ViewChild, args: ['carouselWrapper', { static: true }] }], carouselRow: [{ type: ViewChild, args: ['carouselRow', { static: true }] }], dots: [{ type: Input }], infinity: [{ type: Input }], pauseByHover: [{ type: Input }], arrows: [{ type: Input }], slidesToScroll: [{ type: Input }], slidesToShow: [{ type: Input }], timeout: [{ type: Input }], offset: [{ type: Input }], windowResizeHandler: [{ type: HostListener, args: ['window:resize'] }], pointerUpHandler: [{ type: HostListener, args: ['pointerup'] }], pointerMoveHandler: [{ type: HostListener, args: ['pointermove', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/layout/carousel/carousel.component.ts","../../../../../../libs/ngx-slice-kit/src/lib/layout/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    AfterViewInit,\n    Component,\n    ContentChildren,\n    ElementRef,\n    HostListener,\n    Input,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    Renderer2,\n    ViewChild\n} from '@angular/core';\nimport {SlideComponent} from './slide/slide.component';\nimport {fromEvent, interval, Subscription} from 'rxjs';\nimport {filter, repeatWhen, takeUntil} from 'rxjs/operators';\n\n@Component({\n    selector: 'sdk-carousel',\n    templateUrl: './carousel.component.html',\n    styleUrls: ['./carousel.component.scss'],\n})\nexport class CarouselComponent implements OnInit, AfterContentInit, AfterViewInit, OnDestroy {\n\n    @ContentChildren(SlideComponent) public carouselSlides: QueryList<SlideComponent>;\n\n    @ViewChild('carouselWrapper', {static: true}) public carouselWrapper: ElementRef;\n    @ViewChild('carouselRow', {static: true}) public carouselRow: ElementRef;\n\n    @Input() public dots: boolean = false;\n    @Input() public infinity: boolean = false;\n    @Input() public pauseByHover: boolean = false;\n    @Input() public arrows: boolean = true;\n    @Input() public slidesToScroll: number = 1;\n    @Input() public slidesToShow: number = 1;\n    @Input() public timeout: number = 5000;\n    @Input() public offset: number = 0;\n\n    public slidesArr: SlideComponent[] = [];\n    public firstPageClones: SlideComponent[];\n    public lastPageClones: SlideComponent[];\n\n    public activeSlideIndex: number = 0;\n    public curCarouselPosition: number = 0;\n    public pagePenalty: number = 0;\n    public slideWidth: number;\n    public scrollStep: number;\n    public scrollStartX: number;\n    public scrollOffset: number;\n\n    public isScrolling: boolean;\n    public isGrabbed: boolean = false;\n    public isViewInit: boolean = false;\n\n    public carouselWrapperRects: ClientRect;\n    public carouselRowRects: ClientRect;\n\n    public sub: Subscription;\n\n    public get dotsCount(): number {\n        return Math.ceil(this.slidesArr.length / this.slidesToScroll);\n    }\n\n    constructor(\n        private el: ElementRef,\n        private renderer: Renderer2,\n    ) {\n    }\n\n    @HostListener('window:resize')\n    public windowResizeHandler(): void {\n        if (this.carouselWrapper.nativeElement.offsetWidth !== this.carouselWrapperRects?.width) {\n            this.updateSlider();\n        }\n    }\n\n    @HostListener('pointerup')\n    public pointerUpHandler(): void {\n        if (!this.isGrabbed) {\n            return;\n        }\n\n        this.isGrabbed = false;\n\n        if (this.scrollOffset < this.curCarouselPosition - 100) {\n            this.move('forward');\n        } else if (this.scrollOffset > this.curCarouselPosition + 100) {\n            this.move('back');\n        } else {\n            this.animate(this.curCarouselPosition);\n        }\n        this.scrollOffset = 0;\n    }\n\n    @HostListener('pointermove', ['$event'])\n    public pointerMoveHandler(event: PointerEvent): void {\n        if (this.isGrabbed) {\n            this.scrollOffset = this.curCarouselPosition + event.clientX - this.scrollStartX;\n            this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.scrollOffset}px)`);\n        }\n    }\n\n    public animate(newPosition): void {\n        this.isScrolling = true;\n        this.renderer.setStyle(this.carouselRow.nativeElement, 'transition', `400ms`);\n        this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${newPosition}px)`);\n        this.updatePosition();\n\n        if (this.activeSlideIndex + 1 > this.dotsCount) {\n            this.activeSlideIndex = 0;\n            setTimeout(() => {\n                this.curCarouselPosition = -(this.slidesToScroll * this.slideWidth);\n                this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.curCarouselPosition}px)`);\n                this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect();\n            }, 500);\n        }\n\n        if (this.activeSlideIndex === -1) {\n            this.activeSlideIndex = this.dotsCount - 1;\n            setTimeout(() => {\n                this.curCarouselPosition = -(this.slidesToScroll * this.slideWidth) * this.dotsCount;\n                this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.curCarouselPosition}px)`);\n                this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect();\n            }, 500);\n        }\n    }\n\n    public grab(event: PointerEvent): void {\n        event.preventDefault();\n\n        this.isGrabbed = true;\n        this.scrollStartX = event.clientX;\n    }\n\n    public move(direction: 'forward' | 'back'): void {\n        this.carouselWrapperRects = this.carouselWrapper.nativeElement.getBoundingClientRect();\n        const widthPenalty = (this.activeSlideIndex === 0 ?\n            this.slideWidth * (this.dotsCount * this.slidesToScroll - this.slidesArr.length) : 0);\n\n        if (this.isScrolling) {\n            return;\n        }\n        switch (direction) {\n            case 'back':\n                this.curCarouselPosition += this.carouselRowRects.left + this.scrollStep > this.carouselWrapperRects.left ?\n                    this.carouselWrapperRects.left - this.carouselRowRects.left : this.scrollStep - widthPenalty;\n                break;\n            case 'forward':\n                this.curCarouselPosition += this.carouselRowRects.right - this.scrollStep < this.carouselWrapperRects.right ?\n                    -(this.carouselRowRects.right - this.carouselWrapperRects.right) : -this.scrollStep;\n                break;\n        }\n\n        const prevIndex = this.activeSlideIndex;\n        this.activeSlideIndex = Math.ceil(Math.abs(this.curCarouselPosition + this.pagePenalty) / (this.scrollStep)) % (this.dotsCount + 1);\n\n        if (prevIndex === 0 && this.activeSlideIndex === 1 && direction === 'back') {\n            this.activeSlideIndex = -1;\n        }\n\n        this.animate(this.curCarouselPosition);\n    }\n\n    public selectSlide(slideIndex: number): void {\n        this.activeSlideIndex = slideIndex;\n\n        let notMultipleDif = 0;\n        if (slideIndex + 1 === this.dotsCount) {\n            notMultipleDif = (this.slidesArr.length % this.slidesToScroll) * this.slideWidth;\n        }\n\n        this.curCarouselPosition = -(this.activeSlideIndex * this.slideWidth * this.slidesToScroll - notMultipleDif) - this.pagePenalty;\n        this.animate(this.curCarouselPosition);\n    }\n\n    public updatePosition(): void {\n        setTimeout(() => {\n            this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect();\n            this.renderer.removeStyle(this.carouselRow.nativeElement, 'transition');\n            this.isScrolling = false;\n        }, 500);\n    }\n\n    public setSlideStyles(): void {\n        this.slidesArr.forEach(slide => {\n            if (this.offset) {\n                this.renderer.setStyle(slide.el.nativeElement, 'padding', this.offset + 'px');\n            }\n            this.renderer.setStyle(slide.el.nativeElement, 'width', this.slideWidth + 'px');\n        });\n    }\n\n    public checkSlidesToScroll(): void {\n        if (this.slidesToScroll > this.slidesArr.length) {\n            this.slidesToScroll = this.slidesArr.length;\n        }\n    }\n\n    public createClones(): void {\n        this.lastPageClones = [...this.slidesArr].slice(-this.slidesToShow).map(this.cloneNode.bind(this)).reverse() as SlideComponent[];\n        this.firstPageClones = [...this.slidesArr].slice(0, this.slidesToShow).map(this.cloneNode.bind(this));\n    }\n\n    public cloneNode(node): HTMLElement {\n        const clone: HTMLElement = node.el.nativeElement.cloneNode(true);\n        this.renderer.addClass(clone, 'sdk-slide--clone');\n        return clone;\n    }\n\n    public insertClones(): void {\n        for (const clone of this.lastPageClones) {\n            this.renderer.insertBefore(this.carouselRow.nativeElement, clone, this.carouselRow.nativeElement.firstChild);\n        }\n        for (const clone of this.firstPageClones) {\n            this.renderer.appendChild(this.carouselRow.nativeElement, clone);\n        }\n    }\n\n    public removeClones(): void {\n        for (const clone of this.firstPageClones) {\n            this.renderer.removeChild(this.carouselRow.nativeElement, clone);\n        }\n        for (const clone of this.lastPageClones) {\n            this.renderer.removeChild(this.carouselRow.nativeElement, clone);\n        }\n    }\n\n    public updateSlider(): void {\n        this.carouselWrapperRects = this.carouselWrapper.nativeElement.getBoundingClientRect();\n        this.slideWidth = this.carouselWrapper.nativeElement.offsetWidth / this.slidesToShow;\n        this.scrollStep = this.slidesToScroll * this.slideWidth;\n\n        this.setSlideStyles();\n        this.checkSlidesToScroll();\n\n        if (this.infinity) {\n            this.pagePenalty = this.scrollStep;\n            if (this.firstPageClones || this.lastPageClones) {\n                this.removeClones();\n            }\n            this.createClones();\n            this.insertClones();\n\n            this.curCarouselPosition = -(this.slidesToScroll * this.slideWidth);\n            this.renderer.setStyle(this.carouselRow.nativeElement, 'transform', `translateX(${this.curCarouselPosition}px)`);\n            this.updatePosition();\n        }\n        this.carouselRowRects = this.carouselRow.nativeElement.getBoundingClientRect();\n    }\n\n    public ngOnInit(): void {\n        this.sub = fromEvent(this.carouselRow.nativeElement, 'pointerdown').subscribe(pointerEvent => {\n            this.grab(pointerEvent as PointerEvent);\n        });\n    }\n\n    public ngAfterContentInit(): void {\n        this.slideWidth = this.carouselWrapper.nativeElement.offsetWidth / this.slidesToShow;\n        this.slidesArr = this.carouselSlides.toArray();\n    }\n\n    public ngAfterViewInit(): void {\n        const pointerEnter$ = fromEvent(this.el.nativeElement, 'pointerenter').pipe(filter(() => this.pauseByHover));\n        const pointerLeave$ = fromEvent(this.el.nativeElement, 'pointerleave');\n        const pointerLeave = pointerLeave$.subscribe(() => {\n            this.pointerUpHandler();\n        });\n\n        this.isViewInit = true;\n        this.updateSlider();\n        this.sub.add(pointerLeave);\n\n        if (this.timeout) {\n            const slideTimeout = interval(this.timeout)\n                .pipe(\n                    takeUntil(pointerEnter$),\n                    repeatWhen(() => pointerLeave$)\n                )\n                .subscribe(() => {\n                    this.move('forward');\n                });\n\n            this.sub.add(slideTimeout);\n        }\n    }\n\n    // ngOnChanges(changes): void {\n    //     if (this.isViewInit) {\n    //         if (changes.slidesToScroll || changes.slidesToShow) {\n    //             this.updateSlider();\n    //         }\n    //     }\n    // }\n\n    public ngOnDestroy(): void {\n        this.sub?.unsubscribe();\n    }\n}\n","<div class=\"sdk-carousel\">\n    <div class=\"sdk-carousel__wrapper\" #carouselWrapper>\n        <ng-container *ngIf=\"arrows\">\n            <button sdk-round-button class=\"sdk-carousel__arrow sdk-carousel__arrow--left\" color=\"basic\"\n                    (click)=\"move('back')\">\n                <sdk-icon icon=\"chevron_left\" [size]=\"24\"></sdk-icon>\n            </button>\n            <button sdk-round-button class=\"sdk-carousel__arrow sdk-carousel__arrow--right\" color=\"basic\"\n                    (click)=\"move('forward')\">\n                <sdk-icon icon=\"chevron_right\" [size]=\"24\"></sdk-icon>\n            </button>\n        </ng-container>\n        <div class=\"sdk-carousel__row\" #carouselRow draggable=\"false\">\n            <ng-content select=\"sdk-slide\"></ng-content>\n        </div>\n    </div>\n    <div class=\"sdk-carousel__dots\" *ngIf=\"dots\" [style.bottom.px]=\"-offset\">\n        <sdk-dots [activeIndex]=\"activeSlideIndex\" [count]=\"dotsCount\" (selected)=\"selectSlide($event)\"></sdk-dots>\n    </div>\n</div>\n"]}