import { Injectable, Inject } from '@angular/core'; import { merge, of } from 'rxjs'; import { tap, switchMap, first, filter } from 'rxjs/operators'; import { WINDOW } from './window-ref.service'; import { DOCUMENT } from './document-ref.service'; import * as i0 from "@angular/core"; import * as i1 from "./carousel.service"; class AutoplayService { carouselService; ngZone; /** * Subscrioption to merge Observables from CarouselService */ autoplaySubscription; /** * The autoplay timeout. */ _timeout = null; /** * Indicates whenever the autoplay is paused. */ _paused = false; /** * Shows whether the code (the plugin) changed the option 'AutoplayTimeout' for own needs */ _isArtificialAutoplayTimeout; /** * Shows whether the autoplay is paused for unlimited time by the developer. * Use to prevent autoplaying in case of firing `mouseleave` by adding layers to `` like `mat-menu` does */ _isAutoplayStopped = false; get isAutoplayStopped() { return this._isAutoplayStopped; } set isAutoplayStopped(value) { this._isAutoplayStopped = value; } winRef; docRef; constructor(carouselService, winRef, docRef, ngZone) { this.carouselService = carouselService; this.ngZone = ngZone; this.winRef = winRef; this.docRef = docRef; this.spyDataStreams(); } ngOnDestroy() { this.autoplaySubscription.unsubscribe(); } /** * Defines Observables which service must observe */ spyDataStreams() { const initializedCarousel$ = this.carouselService.getInitializedState().pipe(tap(() => { if (this.carouselService.settings.autoplay) { this.play(); } })); const changedSettings$ = this.carouselService.getChangedState().pipe(tap(data => { this._handleChangeObservable(data); })); const resized$ = this.carouselService.getResizedState().pipe(tap(() => { if (this.carouselService.settings.autoplay && !this._isAutoplayStopped) { this.play(); } else { this.stop(); } })); // original Autoplay Plugin has listeners on play.owl.core and stop.owl.core events. // They are triggered by Video Plugin const autoplayMerge$ = merge(initializedCarousel$, changedSettings$, resized$); this.autoplaySubscription = autoplayMerge$.subscribe(() => { }); } /** * Starts the autoplay. * @param timeout The interval before the next animation starts. * @param speed The animation speed for the animations. */ play(timeout, speed) { if (this._paused) { this._paused = false; this._setAutoPlayInterval(this.carouselService.settings.autoplayMouseleaveTimeout); } if (this.carouselService.is('rotating')) { return; } this.carouselService.enter('rotating'); this._setAutoPlayInterval(); } ; /** * Gets a new timeout * @param timeout - The interval before the next animation starts. * @param speed - The animation speed for the animations. * @return */ _getNextTimeout(timeout, speed) { if (this._timeout) { this.winRef.clearTimeout(this._timeout); } this._isArtificialAutoplayTimeout = timeout ? true : false; return this.ngZone.runOutsideAngular(() => { return this.winRef.setTimeout(() => { this.ngZone.run(() => { if (this._paused || this.carouselService.is('busy') || this.carouselService.is('interacting') || this.docRef.hidden) { return; } this.carouselService.next(speed || this.carouselService.settings.autoplaySpeed); }); }, timeout || this.carouselService.settings.autoplayTimeout); }); } ; /** * Sets autoplay in motion. */ _setAutoPlayInterval(timeout) { this._timeout = this._getNextTimeout(timeout); } ; /** * Stops the autoplay. */ stop() { if (!this.carouselService.is('rotating')) { return; } this._paused = true; this.winRef.clearTimeout(this._timeout); this.carouselService.leave('rotating'); } ; /** * Stops the autoplay. */ pause() { if (!this.carouselService.is('rotating')) { return; } this._paused = true; } ; /** * Manages by autoplaying according to data passed by _changedSettingsCarousel$ Obsarvable * @param data object with current position of carousel and type of change */ _handleChangeObservable(data) { if (data.property.name === 'settings') { if (this.carouselService.settings.autoplay) { this.play(); } else { this.stop(); } } else if (data.property.name === 'position') { //console.log('play?', e); if (this.carouselService.settings.autoplay) { this._setAutoPlayInterval(); } } } /** * Starts autoplaying of the carousel in the case when user leaves the carousel before it starts translateing (moving) */ _playAfterTranslated() { of('translated').pipe(switchMap(data => this.carouselService.getTranslatedState()), first(), filter(() => this._isArtificialAutoplayTimeout), tap(() => this._setAutoPlayInterval())).subscribe(() => { }); } /** * Starts pausing */ startPausing() { if (this.carouselService.settings.autoplayHoverPause && this.carouselService.is('rotating')) { this.pause(); } } /** * Starts playing after mouse leaves carousel */ startPlayingMouseLeave() { if (this.carouselService.settings.autoplayHoverPause && this.carouselService.is('rotating')) { this.play(); this._playAfterTranslated(); } } /** * Starts playing after touch ends */ startPlayingTouchEnd() { if (this.carouselService.settings.autoplayHoverPause && this.carouselService.is('rotating')) { this.play(); this._playAfterTranslated(); } } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AutoplayService, deps: [{ token: i1.CarouselService }, { token: WINDOW }, { token: DOCUMENT }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable }); static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AutoplayService }); } export { AutoplayService }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AutoplayService, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.CarouselService }, { type: undefined, decorators: [{ type: Inject, args: [WINDOW] }] }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: i0.NgZone }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autoplay.service.js","sourceRoot":"","sources":["../../../../libs/ngx-owl-carousel-o/src/lib/services/autoplay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, OnDestroy, NgZone } from '@angular/core';\nimport { Subscription, Observable, merge, of } from 'rxjs';\nimport { tap, switchMap, first, filter } from 'rxjs/operators';\n\nimport { CarouselService } from './carousel.service';\nimport { WINDOW } from './window-ref.service';\nimport { DOCUMENT } from './document-ref.service';\n\n@Injectable()\nexport class AutoplayService implements OnDestroy{\n  /**\n   * Subscrioption to merge Observables from CarouselService\n   */\n  autoplaySubscription: Subscription;\n\n  /**\n   * The autoplay timeout.\n   */\n  private _timeout: number = null;\n\n  /**\n   * Indicates whenever the autoplay is paused.\n   */\n  private _paused = false;\n\n  /**\n   * Shows whether the code (the plugin) changed the option 'AutoplayTimeout' for own needs\n   */\n  private _isArtificialAutoplayTimeout: boolean;\n\n  /**\n   * Shows whether the autoplay is paused for unlimited time by the developer.\n   * Use to prevent autoplaying in case of firing `mouseleave` by adding layers to `<body>` like `mat-menu` does\n   */\n  private _isAutoplayStopped = false;\n  get isAutoplayStopped() {\n    return this._isAutoplayStopped;\n  }\n  set isAutoplayStopped(value) {\n    this._isAutoplayStopped = value;\n  }\n\n  private winRef: Window;\n  private docRef: Document;\n\n\n  constructor(private carouselService: CarouselService,\n              @Inject(WINDOW) winRef: any,\n              @Inject(DOCUMENT) docRef: any,\n              private ngZone: NgZone\n  ) {\n    this.winRef = winRef as Window;\n    this.docRef = docRef as Document;\n    this.spyDataStreams();\n  }\n\n  ngOnDestroy() {\n    this.autoplaySubscription.unsubscribe();\n  }\n\n  /**\n   * Defines Observables which service must observe\n   */\n  spyDataStreams() {\n    const initializedCarousel$: Observable<string> = this.carouselService.getInitializedState().pipe(\n      tap(() => {\n        if (this.carouselService.settings.autoplay) {\n          this.play();\n\t\t\t\t}\n      })\n    );\n\n    const changedSettings$: Observable<any> = this.carouselService.getChangedState().pipe(\n      tap(data => {\n        this._handleChangeObservable(data);\n      })\n    );\n\n    const resized$: Observable<any> = this.carouselService.getResizedState().pipe(\n      tap(() => {\n        if (this.carouselService.settings.autoplay && !this._isAutoplayStopped) {\n          this.play();\n\t\t\t\t} else {\n          this.stop();\n        }\n      })\n    )\n\n    // original Autoplay Plugin has listeners on play.owl.core and stop.owl.core events.\n    // They are triggered by Video Plugin\n\n    const autoplayMerge$: Observable<string> = merge(initializedCarousel$, changedSettings$, resized$);\n    this.autoplaySubscription = autoplayMerge$.subscribe(\n      () => {}\n    );\n  }\n\n  /**\n\t * Starts the autoplay.\n\t * @param timeout The interval before the next animation starts.\n\t * @param speed The animation speed for the animations.\n\t */\n\tplay(timeout?: number, speed?: number) {\n    if (this._paused) {\n\t\t\tthis._paused = false;\n\t\t\tthis._setAutoPlayInterval(this.carouselService.settings.autoplayMouseleaveTimeout);\n    }\n\n\t\tif (this.carouselService.is('rotating')) {\n\t\t\treturn;\n\t\t}\n\n    this.carouselService.enter('rotating');\n\n\t\tthis._setAutoPlayInterval();\n  };\n\n  /**\n\t * Gets a new timeout\n\t * @param timeout - The interval before the next animation starts.\n\t * @param speed - The animation speed for the animations.\n\t * @return\n\t */\n\tprivate _getNextTimeout(timeout?: number, speed?: number): number {\n\t\tif ( this._timeout ) {\n\t\t\tthis.winRef.clearTimeout(this._timeout);\n    }\n\n    this._isArtificialAutoplayTimeout = timeout ? true : false;\n\n\t\treturn this.ngZone.runOutsideAngular(() => {\n      return this.winRef.setTimeout(() =>{\n        this.ngZone.run(() => {\n          if (this._paused || this.carouselService.is('busy') || this.carouselService.is('interacting') || this.docRef.hidden) {\n            return;\n          }\n          this.carouselService.next(speed || this.carouselService.settings.autoplaySpeed);\n        });\n      }, timeout || this.carouselService.settings.autoplayTimeout);\n    });\n\n  };\n\n  /**\n\t * Sets autoplay in motion.\n\t */\n  private _setAutoPlayInterval(timeout?: number) {\n\t\tthis._timeout = this._getNextTimeout(timeout);\n\t};\n\n\t/**\n\t * Stops the autoplay.\n\t */\n\tstop() {\n\t\tif (!this.carouselService.is('rotating')) {\n\t\t\treturn;\n\t\t}\n    this._paused = true;\n\n\t\tthis.winRef.clearTimeout(this._timeout);\n\t\tthis.carouselService.leave('rotating');\n  };\n\n  /**\n\t * Stops the autoplay.\n\t */\n\tpause() {\n\t\tif (!this.carouselService.is('rotating')) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis._paused = true;\n  };\n\n  /**\n   * Manages by autoplaying according to data passed by _changedSettingsCarousel$ Obsarvable\n   * @param data object with current position of carousel and type of change\n   */\n  private _handleChangeObservable(data: any) {\n    if (data.property.name === 'settings') {\n      if (this.carouselService.settings.autoplay) {\n        this.play();\n      } else {\n        this.stop();\n      }\n    } else if (data.property.name === 'position') {\n      //console.log('play?', e);\n      if (this.carouselService.settings.autoplay) {\n        this._setAutoPlayInterval();\n      }\n    }\n  }\n\n  /**\n   * Starts autoplaying of the carousel in the case when user leaves the carousel before it starts translateing (moving)\n   */\n  private _playAfterTranslated() {\n    of('translated').pipe(\n      switchMap(data => this.carouselService.getTranslatedState()),\n      first(),\n      filter(() => this._isArtificialAutoplayTimeout),\n      tap(() => this._setAutoPlayInterval())\n    ).subscribe(() => { });\n  }\n\n  /**\n   * Starts pausing\n   */\n  startPausing() {\n    if (this.carouselService.settings.autoplayHoverPause && this.carouselService.is('rotating')) {\n      this.pause();\n    }\n  }\n\n  /**\n   * Starts playing after mouse leaves carousel\n   */\n  startPlayingMouseLeave() {\n    if (this.carouselService.settings.autoplayHoverPause && this.carouselService.is('rotating')) {\n      this.play();\n      this._playAfterTranslated();\n    }\n  }\n\n  /**\n   * Starts playing after touch ends\n   */\n  startPlayingTouchEnd() {\n    if (this.carouselService.settings.autoplayHoverPause && this.carouselService.is('rotating')) {\n      this.play();\n      this._playAfterTranslated();\n    }\n  }\n}\n"]}