Skip to content

Commit

Permalink
fix(carousel): fix interval
Browse files Browse the repository at this point in the history
  • Loading branch information
alyleui committed Jun 13, 2018
1 parent d7d1058 commit 126e420
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 50 deletions.
2 changes: 1 addition & 1 deletion src/lib/carousel/carousel.html
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
(slideend)="slideEvent && onDragEnd($event)"
#slideContainer
>
<div [className]="classes.slide" [style.left]="positionLeft">
<div [className]="classes.slide" [style.left]="_positionLeft">
<ng-content></ng-content>
</div>
<div class="lycarousel-slide">
Expand Down
63 changes: 14 additions & 49 deletions src/lib/carousel/carousel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,18 +47,14 @@ export enum CarouselMode {
preserveWhitespaces: false
})
export class LyCarousel implements OnInit, AfterViewInit, OnDestroy {
public data: any;
public value: any;
public _selectedIndex: any;
public _fnInterval: any;
public nullImg = '';
private _intervalFn;
@ViewChild('slideContainer') slideContainer: ElementRef;
@ContentChildren(forwardRef(() => LyCarouselItem)) lyItems: QueryList<LyCarouselItem>;
@Input() mode: CarouselMode = CarouselMode.default;
@Input() interval = 7000;
positionLeft: string | number;
_itemSelect = 0;
_positionLeft: string | number;
@Input() selectedIndex = 0;
selectedElement: HTMLElement;
classes = {
Expand Down Expand Up @@ -206,54 +202,26 @@ export class LyCarousel implements OnInit, AfterViewInit, OnDestroy {
}

ngOnInit() {
this._resetInterval();
if (!this.slideEvent) {
this.slideEvent = false;
}
if (Platform.isBrowser) {
this._resetInterval();
}
}

private _onPan(x) {
this.positionLeft = this.sanitizerStyle(`calc(${-100 * this.selectedIndex }% + ${x}px)`) as any;
// console.log(`calc(${-100 * this.selectedIndex }% + ${event.deltaX}px)`);
this._positionLeft = this.sanitizerStyle(`calc(${-100 * this.selectedIndex }% + ${x}px)`) as any;
}
private sanitizerStyle(val: any): SafeStyle {
return this.sanitizer.bypassSecurityTrustStyle(val);
}

public ngOnDestroy() {
if (isPlatformBrowser(this.platformId)) {
clearInterval(this._fnInterval);
}
}
public _intervalCarousel(value: any = '+') {
if (isPlatformBrowser(this.platformId)) {
if (value === '+') {
this._itemSelect++;
this._itemSelect = (this._itemSelect === (this.lyItems.length) ? 0 : this._itemSelect);
// console.log(this._itemSelect, this.lyItems.length);
} else if (value === '-') {
this._itemSelect--;
this._itemSelect = (this._itemSelect <= -1 ? (this.lyItems.length - 1) : this._itemSelect--);
// console.log('--',this._itemSelect, this.lyItems.length);
} else {
this._itemSelect = value;
}
const intrval$ = {
interval$: setInterval(() => {
this._itemSelect++;
this._itemSelect = (this._itemSelect === (this.lyItems.length) ? 0 : this._itemSelect++);
// console.log('interval state', this._itemSelect);
// this.setActiveItem();
}, this.interval)
};
clearInterval(this._fnInterval);
this._fnInterval = intrval$.interval$;
// this.setActiveItem();
this.stop();
}
}
resetInterval() {

}

_markForCheck() {
this.cd.markForCheck();
Expand All @@ -263,19 +231,12 @@ export class LyCarousel implements OnInit, AfterViewInit, OnDestroy {
this.renderer.addClass(this.slideContainer.nativeElement, this.classes.slideContainer);
if (isPlatformBrowser(this.platformId)) {
this.renderer.addClass(this.slideContainer.nativeElement, this.classes.slideAnim);
this._intervalCarousel(0);
this.lyItems.changes.subscribe((carousel: LyCarouselItem) => {
this._itemSelect = 0;
this._intervalCarousel(0);
// this.setActiveItem();
this.cd.markForCheck();
});
}
}
select(val: number, notResetInterval?: boolean) {
this.selectedIndex = val;
if (this.mode === CarouselMode.default) {
this.positionLeft = `${-100 * val}%`;
this._positionLeft = `${-100 * val}%`;
}
if (!notResetInterval) {
this._resetInterval();
Expand All @@ -292,14 +253,18 @@ export class LyCarousel implements OnInit, AfterViewInit, OnDestroy {
this.select(next > len ? 0 : next, notResetInterval);
}
private _resetInterval() {
if (this._intervalFn) {
clearInterval(this._intervalFn);
}
this.stop();
this._intervalFn = setInterval(() => {
this.next(true);
this.cd.markForCheck();
}, this.interval);
}

stop() {
if (this._intervalFn) {
clearInterval(this._intervalFn);
}
}
}

@Directive({
Expand Down

0 comments on commit 126e420

Please sign in to comment.