ngx-owl-carousel-o
Version:
Angular powered owl-carousel
290 lines • 39.9 kB
JavaScript
import * as tslib_1 from "tslib";
import { Injectable } from '@angular/core';
import { CarouselService } from './carousel.service';
import { merge } from 'rxjs';
import { tap, filter } from 'rxjs/operators';
var NavigationService = /** @class */ (function () {
function NavigationService(carouselService) {
this.carouselService = carouselService;
/**
* Indicates whether the plugin is initialized or not.
*/
this._initialized = false;
/**
* The current paging indexes.
*/
this._pages = [];
/**
* Data for navigation elements of the user interface.
*/
this._navData = {
disabled: false,
prev: {
disabled: false,
htmlText: ''
},
next: {
disabled: false,
htmlText: ''
},
};
/**
* Data for dot elements of the user interface.
*/
this._dotsData = {
disabled: false,
dots: []
};
this.spyDataStreams();
}
NavigationService.prototype.ngOnDestroy = function () {
this.navSubscription.unsubscribe();
};
/**
* Defines Observables which service must observe
*/
NavigationService.prototype.spyDataStreams = function () {
var _this = this;
var initializedCarousel$ = this.carouselService.getInitializedState().pipe(tap(function (state) {
_this.initialize();
_this._updateNavPages();
_this.draw();
_this.update();
_this.carouselService.sendChanges();
}));
// mostly changes in carouselService and carousel at all causes carouselService.to(). It moves stage right-left by its code and calling needed functions
// Thus this method by calling carouselService.current(position) notifies about changes
var changedSettings$ = this.carouselService.getChangedState().pipe(filter(function (data) { return data.property.name === 'position'; }), tap(function (data) {
_this.update();
// should be the call of the function written at the end of comment
// but the method carouselServive.to() has setTimeout(f, 0) which contains carouselServive.update() which calls sendChanges() method.
// carouselService.navData and carouselService.dotsData update earlier than carouselServive.update() gets called
// updates of carouselService.navData and carouselService.dotsData are being happening withing carouselService.current(position) method which calls next() of _changedSettingsCarousel$
// carouselService.current(position) is being calling earlier than carouselServive.update();
// this.carouselService.sendChanges();
}));
var refreshedCarousel$ = this.carouselService.getRefreshedState().pipe(tap(function () {
_this._updateNavPages();
_this.draw();
_this.update();
_this.carouselService.sendChanges();
}));
var navMerge$ = merge(initializedCarousel$, changedSettings$, refreshedCarousel$);
this.navSubscription = navMerge$.subscribe(function () { });
};
/**
* Initializes the layout of the plugin and extends the carousel.
*/
NavigationService.prototype.initialize = function () {
this._navData.disabled = true;
this._navData.prev.htmlText = this.carouselService.settings.navText[0];
this._navData.next.htmlText = this.carouselService.settings.navText[1];
this._dotsData.disabled = true;
this.carouselService.navData = this._navData;
this.carouselService.dotsData = this._dotsData;
};
/**
* Calculates internal states and updates prop _pages
*/
NavigationService.prototype._updateNavPages = function () {
var i, j, k;
var lower = this.carouselService.clones().length / 2, upper = lower + this.carouselService.items().length, maximum = this.carouselService.maximum(true), pages = [], settings = this.carouselService.settings;
var size = settings.center || settings.autoWidth || settings.dotsData
? 1 : settings.dotsEach || settings.items;
size = +size;
if (settings.slideBy !== 'page') {
settings.slideBy = Math.min(+settings.slideBy, settings.items);
}
if (settings.dots || settings.slideBy === 'page') {
for (i = lower, j = 0, k = 0; i < upper; i++) {
if (j >= size || j === 0) {
pages.push({
start: Math.min(maximum, i - lower),
end: i - lower + size - 1
});
if (Math.min(maximum, i - lower) === maximum) {
break;
}
j = 0, ++k;
}
j += this.carouselService.mergers(this.carouselService.relative(i));
}
}
this._pages = pages;
};
/**
* Draws the user interface.
* @todo The option `dotsData` wont work.
*/
NavigationService.prototype.draw = function () {
var _this = this;
var difference;
var settings = this.carouselService.settings, items = this.carouselService.items(), disabled = items.length <= settings.items;
this._navData.disabled = !settings.nav || disabled;
this._dotsData.disabled = !settings.dots || disabled;
if (settings.dots) {
difference = this._pages.length - this._dotsData.dots.length;
if (settings.dotsData && difference !== 0) {
this._dotsData.dots = [];
items.forEach(function (item) {
_this._dotsData.dots.push({
active: false,
id: "dot-" + item.id,
innerContent: item.dotContent,
showInnerContent: true
});
});
}
else if (difference > 0) {
var startI = this._dotsData.dots.length > 0 ? this._dotsData.dots.length : 0;
for (var i = 0; i < difference; i++) {
this._dotsData.dots.push({
active: false,
id: "dot-" + (i + startI),
innerContent: '',
showInnerContent: false
});
}
}
else if (difference < 0) {
this._dotsData.dots.splice(difference, Math.abs(difference));
}
}
this.carouselService.navData = this._navData;
this.carouselService.dotsData = this._dotsData;
};
;
/**
* Updates navigation buttons's and dots's states
*/
NavigationService.prototype.update = function () {
this._updateNavButtons();
this._updateDots();
};
/**
* Changes state of nav buttons (disabled, enabled)
*/
NavigationService.prototype._updateNavButtons = function () {
var settings = this.carouselService.settings, loop = settings.loop || settings.rewind, index = this.carouselService.relative(this.carouselService.current());
if (settings.nav) {
this._navData.prev.disabled = !loop && index <= this.carouselService.minimum(true);
this._navData.next.disabled = !loop && index >= this.carouselService.maximum(true);
}
this.carouselService.navData = this._navData;
};
/**
* Changes active dot if page becomes changed
*/
NavigationService.prototype._updateDots = function () {
var curActiveDotI;
if (!this.carouselService.settings.dots) {
return;
}
this._dotsData.dots.forEach(function (item) {
if (item.active === true) {
item.active = false;
}
});
curActiveDotI = this._current();
if (this._dotsData.dots.length) {
this._dotsData.dots[curActiveDotI].active = true;
}
this.carouselService.dotsData = this._dotsData;
};
/**
* Gets the current page position of the carousel.
* @returns the current page position of the carousel
*/
NavigationService.prototype._current = function () {
var current = this.carouselService.relative(this.carouselService.current());
var finalCurrent;
var pages = this._pages.filter(function (page, index) {
return page.start <= current && page.end >= current;
}).pop();
finalCurrent = this._pages.findIndex(function (page) {
return page.start === pages.start && page.end === pages.end;
});
return finalCurrent;
};
;
/**
* Gets the current succesor/predecessor position.
* @param sussessor position of slide
* @returns the current succesor/predecessor position
*/
NavigationService.prototype._getPosition = function (successor) {
var position, length;
var settings = this.carouselService.settings;
if (settings.slideBy === 'page') {
position = this._current();
length = this._pages.length;
successor ? ++position : --position;
position = this._pages[((position % length) + length) % length].start;
}
else {
position = this.carouselService.relative(this.carouselService.current());
length = this.carouselService.items().length;
successor ? position += +settings.slideBy : position -= +settings.slideBy;
}
return position;
};
;
/**
* Slides to the next item or page.
* @param speed The time in milliseconds for the transition.
*/
NavigationService.prototype.next = function (speed) {
this.carouselService.to(this._getPosition(true), speed);
};
;
/**
* Slides to the previous item or page.
* @param speed The time in milliseconds for the transition.
*/
NavigationService.prototype.prev = function (speed) {
this.carouselService.to(this._getPosition(false), speed);
};
;
/**
* Slides to the specified item or page.
* @param position - The position of the item or page.
* @param speed - The time in milliseconds for the transition.
* @param standard - Whether to use the standard behaviour or not. Default meaning false
*/
NavigationService.prototype.to = function (position, speed, standard) {
var length;
if (!standard && this._pages.length) {
length = this._pages.length;
this.carouselService.to(this._pages[((position % length) + length) % length].start, speed);
}
else {
this.carouselService.to(position, speed);
}
};
;
/**
* Moves carousel after user's clicking on any dots
*/
NavigationService.prototype.moveByDot = function (dotId) {
var index = this._dotsData.dots.findIndex(function (dot) { return dotId === dot.id; });
this.to(index, this.carouselService.settings.dotsSpeed);
};
/**
* rewinds carousel to slide with needed id
* @param id id of slide
*/
NavigationService.prototype.toSlideById = function (id) {
var position = this.carouselService.slidesData.findIndex(function (slide) { return slide.id === id && slide.isCloned === false; });
if (position === -1 || position === this.carouselService.current()) {
return;
}
this.carouselService.to(this.carouselService.relative(position), false);
};
NavigationService = tslib_1.__decorate([
Injectable(),
tslib_1.__metadata("design:paramtypes", [CarouselService])
], NavigationService);
return NavigationService;
}());
export { NavigationService };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.service.js","sourceRoot":"ng://ngx-owl-carousel-o/","sources":["lib/services/navigation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\r\nimport { NavData, DotsData } from '../models/navigation-data.models';\r\nimport { CarouselSlideDirective } from '../carousel/carousel.module';\r\nimport { CarouselService } from './carousel.service';\r\nimport { Subscription, Observable, merge } from 'rxjs';\r\nimport { tap, filter } from 'rxjs/operators';\r\nimport { OwlOptions } from '../models/owl-options.model';\r\n\r\n@Injectable()\r\nexport class NavigationService implements OnDestroy {\r\n  /**\r\n   * Subscrioption to merge Observable  from CarouselService\r\n   */\r\n  navSubscription: Subscription;\r\n\r\n  /**\r\n   * Indicates whether the plugin is initialized or not.\r\n   */\r\n  protected _initialized = false;\r\n\r\n  /**\r\n   * The current paging indexes.\r\n   */\r\n  protected _pages: any[] = [];\r\n\r\n  /**\r\n   * Data for navigation elements of the user interface.\r\n   */\r\n  protected _navData: NavData = {\r\n    disabled: false,\r\n    prev: {\r\n      disabled: false,\r\n      htmlText: ''\r\n    },\r\n    next: {\r\n      disabled: false,\r\n      htmlText: ''\r\n    },\r\n  };\r\n\r\n  /**\r\n   * Data for dot elements of the user interface.\r\n   */\r\n  protected _dotsData: DotsData = {\r\n    disabled: false,\r\n    dots: []\r\n  };\r\n\r\n  constructor(private carouselService: CarouselService) {\r\n    this.spyDataStreams();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.navSubscription.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(state => {\r\n        this.initialize();\r\n        this._updateNavPages();\r\n        this.draw();\r\n        this.update();\r\n        this.carouselService.sendChanges();\r\n      })\r\n    );\r\n\r\n    // mostly changes in carouselService and carousel at all causes carouselService.to(). It moves stage right-left by its code and calling needed functions\r\n    // Thus this method by calling carouselService.current(position) notifies about changes\r\n    const changedSettings$: Observable<any> = this.carouselService.getChangedState().pipe(\r\n      filter(data => data.property.name === 'position'),\r\n      tap(data => {\r\n        this.update();\r\n        // should be the call of the function written at the end of comment\r\n        // but the method carouselServive.to() has setTimeout(f, 0) which contains carouselServive.update() which calls sendChanges() method.\r\n        // carouselService.navData and carouselService.dotsData update earlier than carouselServive.update() gets called\r\n        // updates of carouselService.navData and carouselService.dotsData are being happening withing carouselService.current(position) method which calls next() of _changedSettingsCarousel$\r\n        // carouselService.current(position) is being calling earlier than carouselServive.update();\r\n        // this.carouselService.sendChanges();\r\n      })\r\n    );\r\n\r\n    const refreshedCarousel$: Observable<string> = this.carouselService.getRefreshedState().pipe(\r\n      tap(() => {\r\n        this._updateNavPages();\r\n        this.draw();\r\n        this.update();\r\n        this.carouselService.sendChanges();\r\n      })\r\n    );\r\n\r\n    const navMerge$: Observable<string> = merge(initializedCarousel$, changedSettings$, refreshedCarousel$);\r\n    this.navSubscription = navMerge$.subscribe(\r\n      () => {}\r\n    );\r\n  }\r\n\r\n  /**\r\n\t * Initializes the layout of the plugin and extends the carousel.\r\n\t */\r\n\tinitialize() {\r\n    this._navData.disabled = true;\r\n    this._navData.prev.htmlText = this.carouselService.settings.navText[0];\r\n    this._navData.next.htmlText = this.carouselService.settings.navText[1];\r\n\r\n    this._dotsData.disabled = true;\r\n\r\n    this.carouselService.navData = this._navData;\r\n    this.carouselService.dotsData = this._dotsData;\r\n  }\r\n\r\n  /**\r\n   * Calculates internal states and updates prop _pages\r\n   */\r\n\tprivate _updateNavPages() {\r\n\t\tlet i: number, j: number, k: number;\r\n\t\tconst lower: number = this.carouselService.clones().length / 2,\r\n      upper: number = lower + this.carouselService.items().length,\r\n      maximum: number = this.carouselService.maximum(true),\r\n      pages: any[] = [],\r\n      settings: OwlOptions = this.carouselService.settings;\r\n     let size = settings.center || settings.autoWidth || settings.dotsData\r\n        ? 1 : settings.dotsEach || settings.items;\r\n      size = +size;\r\n\t\tif (settings.slideBy !== 'page') {\r\n\t\t\tsettings.slideBy = Math.min(+settings.slideBy, settings.items);\r\n\t\t}\r\n\r\n\t\tif (settings.dots || settings.slideBy === 'page') {\r\n\r\n\t\t\tfor (i = lower, j = 0, k = 0; i < upper; i++) {\r\n\t\t\t\tif (j >= size || j === 0) {\r\n\t\t\t\t\tpages.push({\r\n\t\t\t\t\t\tstart: Math.min(maximum, i - lower),\r\n\t\t\t\t\t\tend: i - lower + size - 1\r\n\t\t\t\t\t});\r\n\t\t\t\t\tif (Math.min(maximum, i - lower) === maximum) {\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tj = 0, ++k;\r\n\t\t\t\t}\r\n\t\t\t\tj += this.carouselService.mergers(this.carouselService.relative(i)) as number;\r\n\t\t\t}\r\n\t\t}\r\n\t\tthis._pages = pages;\r\n\t}\r\n\r\n  /**\r\n\t * Draws the user interface.\r\n\t * @todo The option `dotsData` wont work.\r\n\t */\r\n  draw() {\r\n\t\tlet difference: number;\r\n    const\tsettings: OwlOptions = this.carouselService.settings,\r\n      items: CarouselSlideDirective[] = this.carouselService.items(),\r\n      disabled = items.length <= settings.items;\r\n\r\n\t\tthis._navData.disabled = !settings.nav || disabled;\r\n\t\tthis._dotsData.disabled = !settings.dots || disabled;\r\n\r\n\t\tif (settings.dots) {\r\n\t\t\tdifference = this._pages.length - this._dotsData.dots.length;\r\n\r\n\t\t\tif (settings.dotsData && difference !== 0) {\r\n        this._dotsData.dots = [];\r\n        items.forEach(item => {\r\n          this._dotsData.dots.push({\r\n            active: false,\r\n            id: `dot-${item.id}`,\r\n            innerContent: item.dotContent,\r\n            showInnerContent: true\r\n          });\r\n        });\r\n\t\t\t} else if (difference > 0) {\r\n        const startI: number = this._dotsData.dots.length > 0 ? this._dotsData.dots.length : 0;\r\n        for (let i = 0; i < difference; i++) {\r\n          this._dotsData.dots.push({\r\n            active: false,\r\n            id: `dot-${i + startI}`,\r\n            innerContent: '',\r\n            showInnerContent: false\r\n          });\r\n        }\r\n\t\t\t} else if (difference < 0) {\r\n        this._dotsData.dots.splice(difference, Math.abs(difference))\r\n\t\t\t}\r\n    }\r\n\r\n    this.carouselService.navData = this._navData;\r\n    this.carouselService.dotsData = this._dotsData;\r\n  };\r\n\r\n  /**\r\n   * Updates navigation buttons's and dots's states\r\n   */\r\n  update() {\r\n    this._updateNavButtons();\r\n    this._updateDots();\r\n  }\r\n\r\n  /**\r\n   * Changes state of nav buttons (disabled, enabled)\r\n   */\r\n  private _updateNavButtons() {\r\n    const\tsettings: OwlOptions = this.carouselService.settings,\r\n      loop: boolean = settings.loop || settings.rewind,\r\n      index: number = this.carouselService.relative(this.carouselService.current());\r\n\r\n    if (settings.nav) {\r\n      this._navData.prev.disabled = !loop && index <= this.carouselService.minimum(true);\r\n\t\t\tthis._navData.next.disabled = !loop && index >= this.carouselService.maximum(true);\r\n    }\r\n\r\n    this.carouselService.navData = this._navData;\r\n  }\r\n\r\n  /**\r\n   * Changes active dot if page becomes changed\r\n   */\r\n  private _updateDots() {\r\n    let curActiveDotI: number;\r\n\r\n    if(!this.carouselService.settings.dots) {\r\n      return;\r\n    }\r\n    this._dotsData.dots.forEach(item => {\r\n      if (item.active === true) {\r\n        item.active = false;\r\n      }\r\n    })\r\n\r\n    curActiveDotI = this._current();\r\n    if (this._dotsData.dots.length) {\r\n      this._dotsData.dots[curActiveDotI].active = true;\r\n    }\r\n    this.carouselService.dotsData = this._dotsData;\r\n  }\r\n\r\n  /**\r\n\t * Gets the current page position of the carousel.\r\n\t * @returns the current page position of the carousel\r\n\t */\r\n\tprivate _current(): any {\r\n    const current: number = this.carouselService.relative(this.carouselService.current());\r\n    let finalCurrent: number;\r\n    const pages: any = this._pages.filter((page, index) => {\r\n      return page.start <= current && page.end >= current;\r\n    }).pop();\r\n\r\n    finalCurrent = this._pages.findIndex(page => {\r\n      return page.start === pages.start && page.end === pages.end;\r\n    });\r\n\r\n    return finalCurrent;\r\n  };\r\n\r\n  /**\r\n\t * Gets the current succesor/predecessor position.\r\n   * @param sussessor position of slide\r\n\t * @returns the current succesor/predecessor position\r\n\t */\r\n\tprivate _getPosition(successor: number | boolean): number {\r\n\t\tlet position: number, length: number;\r\n\t\tconst\tsettings: OwlOptions = this.carouselService.settings;\r\n\r\n\t\tif (settings.slideBy === 'page') {\r\n\t\t\tposition = this._current();\r\n\t\t\tlength = this._pages.length;\r\n\t\t\tsuccessor ? ++position : --position;\r\n\t\t\tposition = this._pages[((position % length) + length) % length].start;\r\n\t\t} else {\r\n\t\t\tposition = this.carouselService.relative(this.carouselService.current());\r\n\t\t\tlength = this.carouselService.items().length;\r\n\t\t\tsuccessor ? position += +settings.slideBy : position -= +settings.slideBy;\r\n\t\t}\r\n\r\n\t\treturn position;\r\n  };\r\n\r\n  /**\r\n\t * Slides to the next item or page.\r\n\t * @param speed The time in milliseconds for the transition.\r\n\t */\r\n\tnext(speed: number | boolean) {\r\n    this.carouselService.to(this._getPosition(true), speed);\r\n\t};\r\n\r\n\t/**\r\n\t * Slides to the previous item or page.\r\n\t * @param speed The time in milliseconds for the transition.\r\n\t */\r\n\tprev(speed: number | boolean) {\r\n    this.carouselService.to(this._getPosition(false), speed);\r\n  };\r\n\r\n \t/**\r\n\t * Slides to the specified item or page.\r\n\t * @param position - The position of the item or page.\r\n\t * @param speed - The time in milliseconds for the transition.\r\n\t * @param standard - Whether to use the standard behaviour or not. Default meaning false\r\n\t */\r\n\tto(position: number, speed: number | boolean, standard?: boolean) {\r\n\t\tlet length: number;\r\n\t\tif (!standard && this._pages.length) {\r\n      length = this._pages.length;\r\n      this.carouselService.to(this._pages[((position % length) + length) % length].start, speed);\r\n\t\t} else {\r\n      this.carouselService.to(position, speed);\r\n\t\t}\r\n  };\r\n\r\n  /**\r\n   * Moves carousel after user's clicking on any dots\r\n   */\r\n  moveByDot(dotId: string) {\r\n    const index: number = this._dotsData.dots.findIndex(dot => dotId === dot.id);\r\n    this.to(index, this.carouselService.settings.dotsSpeed);\r\n  }\r\n\r\n  /**\r\n   * rewinds carousel to slide with needed id\r\n   * @param id id of slide\r\n   */\r\n  toSlideById(id: string) {\r\n    const position = this.carouselService.slidesData.findIndex(slide => slide.id === id && slide.isCloned === false);\r\n\r\n    if (position === -1 || position === this.carouselService.current()) {\r\n      return;\r\n    }\r\n\r\n\t\tthis.carouselService.to(this.carouselService.relative(position), false);\r\n  }\r\n\r\n}\r\n"]}