ngx-owl-carousel-o
Version:
Angular powered owl-carousel
69 lines • 11.6 kB
JavaScript
import * as tslib_1 from "tslib";
import { Injectable } from '@angular/core';
import { merge } from 'rxjs';
import { CarouselService } from './carousel.service';
import { tap } from 'rxjs/operators';
let LazyLoadService = class LazyLoadService {
constructor(carouselService) {
this.carouselService = carouselService;
this.spyDataStreams();
}
ngOnDestroy() {
this.lazyLoadSubscription.unsubscribe();
}
/**
* Defines Observables which service must observe
*/
spyDataStreams() {
const initializedCarousel$ = this.carouselService.getInitializedState().pipe(tap(() => {
const isLazyLoad = this.carouselService.settings && !this.carouselService.settings.lazyLoad;
this.carouselService.slidesData.forEach(item => item.load = isLazyLoad ? true : false);
}));
const changeSettings$ = this.carouselService.getChangeState();
const resizedCarousel$ = this.carouselService.getResizedState();
const lazyLoadMerge$ = merge(initializedCarousel$, changeSettings$, resizedCarousel$).pipe(tap(data => this._defineLazyLoadSlides(data)));
this.lazyLoadSubscription = lazyLoadMerge$.subscribe(() => { });
}
_defineLazyLoadSlides(data) {
if (!this.carouselService.settings || !this.carouselService.settings.lazyLoad) {
return;
}
if ((data.property && data.property.name === 'position') || data === 'initialized' || data === "resized") {
const settings = this.carouselService.settings, clones = this.carouselService.clones().length;
let n = (settings.center && Math.ceil(settings.items / 2) || settings.items), i = ((settings.center && n * -1) || 0), position = (data.property && data.property.value !== undefined ? data.property.value : this.carouselService.current()) + i;
// load = $.proxy(function(i, v) { this.load(v) }, this);
//TODO: Need documentation for this new option
if (settings.lazyLoadEager > 0) {
n += settings.lazyLoadEager;
// If the carousel is looping also preload images that are to the "left"
if (settings.loop) {
position -= settings.lazyLoadEager;
n++;
}
}
while (i++ < n) {
this._load(clones / 2 + this.carouselService.relative(position));
if (clones) {
this.carouselService.clones(this.carouselService.relative(position)).forEach(value => this._load(value));
}
position++;
}
}
}
/**
* Loads all resources of an item at the specified position.
* @param position - The absolute position of the item.
*/
_load(position) {
if (this.carouselService.slidesData[position].load) {
return;
}
this.carouselService.slidesData[position].load = true;
}
};
LazyLoadService = tslib_1.__decorate([
Injectable(),
tslib_1.__metadata("design:paramtypes", [CarouselService])
], LazyLoadService);
export { LazyLoadService };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazyload.service.js","sourceRoot":"ng://ngx-owl-carousel-o/","sources":["lib/services/lazyload.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\r\nimport { Subscription, Observable, merge } from 'rxjs';\r\nimport { CarouselService } from './carousel.service';\r\nimport { tap } from 'rxjs/operators';\r\n\r\n@Injectable()\r\nexport class LazyLoadService implements OnDestroy {\r\n  /**\r\n   * Subscrioption to merge Observable  from CarouselService\r\n   */\r\n  lazyLoadSubscription: Subscription;\r\n\r\n  constructor(private carouselService: CarouselService) {\r\n    this.spyDataStreams();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.lazyLoadSubscription.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Defines Observables which service must observe\r\n   */\r\n  spyDataStreams() {\r\n    const initializedCarousel$: Observable<string> = this.carouselService.getInitializedState().pipe(\r\n      tap(() => {\r\n        const isLazyLoad = this.carouselService.settings && !this.carouselService.settings.lazyLoad;\r\n        this.carouselService.slidesData.forEach(item => item.load = isLazyLoad ? true : false);\r\n      })\r\n    );\r\n\r\n    const changeSettings$: Observable<any> = this.carouselService.getChangeState();\r\n\r\n    const resizedCarousel$: Observable<string> = this.carouselService.getResizedState();\r\n\r\n\r\n    const lazyLoadMerge$: Observable<string | any> = merge(initializedCarousel$, changeSettings$, resizedCarousel$).pipe(\r\n      tap(data => this._defineLazyLoadSlides(data)),\r\n      // tap(() => this.carouselService.sendChanges())\r\n    );\r\n    this.lazyLoadSubscription = lazyLoadMerge$.subscribe(\r\n      () => {}\r\n    );\r\n  }\r\n\r\n  private _defineLazyLoadSlides(data: any) {\r\n    if (!this.carouselService.settings || !this.carouselService.settings.lazyLoad) {\r\n      return;\r\n    }\r\n\r\n    if ((data.property && data.property.name === 'position') || data === 'initialized' || data === \"resized\") {\r\n      const settings = this.carouselService.settings,\r\n            clones = this.carouselService.clones().length;\r\n      let n = (settings.center && Math.ceil(settings.items / 2) || settings.items),\r\n          i = ((settings.center && n * -1) || 0),\r\n          position = (data.property && data.property.value !== undefined ? data.property.value : this.carouselService.current()) + i;\r\n        // load = $.proxy(function(i, v) { this.load(v) }, this);\r\n      //TODO: Need documentation for this new option\r\n      if (settings.lazyLoadEager > 0) {\r\n        n += settings.lazyLoadEager;\r\n        // If the carousel is looping also preload images that are to the \"left\"\r\n        if (settings.loop) {\r\n          position -= settings.lazyLoadEager;\r\n          n++;\r\n        }\r\n      }\r\n\r\n      while (i++ < n) {\r\n        this._load(clones / 2 + this.carouselService.relative(position));\r\n        if (clones) {\r\n          this.carouselService.clones(this.carouselService.relative(position)).forEach(value => this._load(value));\r\n\r\n        }\r\n        position++;\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n\t * Loads all resources of an item at the specified position.\r\n\t * @param position - The absolute position of the item.\r\n\t */\r\n  private _load(position: number) {\r\n    if (this.carouselService.slidesData[position].load) {\r\n      return;\r\n    }\r\n\r\n    this.carouselService.slidesData[position].load = true;\r\n  }\r\n}\r\n"]}