ngx-owl-carousel-o
Version:
Angular powered owl-carousel
115 lines • 15.4 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';
var AnimateService = /** @class */ (function () {
function AnimateService(carouselService) {
this.carouselService = carouselService;
/**
* s
*/
this.swapping = true;
/**
* active slide before translating
*/
this.previous = undefined;
/**
* new active slide after translating
*/
this.next = undefined;
this.spyDataStreams();
}
AnimateService.prototype.ngOnDestroy = function () {
this.animateSubscription.unsubscribe();
};
/**
* Defines Observables which service must observe
*/
AnimateService.prototype.spyDataStreams = function () {
var _this = this;
var changeSettings$ = this.carouselService.getChangeState().pipe(tap(function (data) {
if (data.property.name === 'position') {
_this.previous = _this.carouselService.current();
_this.next = data.property.value;
}
}));
var dragCarousel$ = this.carouselService.getDragState();
var draggedCarousel$ = this.carouselService.getDraggedState();
var translatedCarousel$ = this.carouselService.getTranslatedState();
var dragTranslatedMerge$ = merge(dragCarousel$, draggedCarousel$, translatedCarousel$).pipe(tap(function (data) { return _this.swapping = data === 'translated'; }));
var translateCarousel$ = this.carouselService.getTranslateState().pipe(tap(function (data) {
if (_this.swapping && (_this.carouselService._options.animateOut || _this.carouselService._options.animateIn)) {
_this._swap();
}
}));
var animateMerge$ = merge(changeSettings$, translateCarousel$, dragTranslatedMerge$).pipe();
this.animateSubscription = animateMerge$.subscribe(function () { });
};
/**
* Toggles the animation classes whenever an translations starts.
* @returns
*/
AnimateService.prototype._swap = function () {
if (this.carouselService.settings.items !== 1) {
return;
}
// if (!$.support.animation || !$.support.transition) {
// return;
// }
this.carouselService.speed(0);
var left;
var previous = this.carouselService.slidesData[this.previous], next = this.carouselService.slidesData[this.next], incoming = this.carouselService.settings.animateIn, outgoing = this.carouselService.settings.animateOut;
if (this.carouselService.current() === this.previous) {
return;
}
if (outgoing) {
left = +this.carouselService.coordinates(this.previous) - +this.carouselService.coordinates(this.next);
this.carouselService.slidesData.forEach(function (slide) {
if (slide.id === previous.id) {
slide.left = left + "px";
slide.isAnimated = true;
slide.isDefAnimatedOut = true;
slide.isCustomAnimatedOut = true;
}
});
}
if (incoming) {
this.carouselService.slidesData.forEach(function (slide) {
if (slide.id === next.id) {
slide.isAnimated = true;
slide.isDefAnimatedIn = true;
slide.isCustomAnimatedIn = true;
}
});
}
};
;
/**
* Handles the end of 'animationend' event
* @param id Id of slides
*/
AnimateService.prototype.clear = function (id) {
var _this = this;
this.carouselService.slidesData.forEach(function (slide) {
if (slide.id === id) {
slide.left = '';
slide.isAnimated = false;
slide.isDefAnimatedOut = false;
slide.isCustomAnimatedOut = false;
slide.isDefAnimatedIn = false;
slide.isCustomAnimatedIn = false;
slide.classes = _this.carouselService.setCurSlideClasses(slide);
}
});
this.carouselService.onTransitionEnd();
};
;
AnimateService = tslib_1.__decorate([
Injectable(),
tslib_1.__metadata("design:paramtypes", [CarouselService])
], AnimateService);
return AnimateService;
}());
export { AnimateService };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animate.service.js","sourceRoot":"ng://ngx-owl-carousel-o/","sources":["lib/services/animate.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 AnimateService implements OnDestroy{\r\n  /**\r\n   * Subscrioption to merge Observable  from CarouselService\r\n   */\r\n  animateSubscription: Subscription;\r\n\r\n  /**\r\n   * s\r\n   */\r\n  swapping = true;\r\n\r\n  /**\r\n   * active slide before translating\r\n   */\r\n  previous = undefined;\r\n\r\n  /**\r\n   * new active slide after translating\r\n   */\r\n  next = undefined;\r\n\r\n  constructor(private carouselService: CarouselService) {\r\n    this.spyDataStreams();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.animateSubscription.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Defines Observables which service must observe\r\n   */\r\n  spyDataStreams() {\r\n    const changeSettings$: Observable<any> = this.carouselService.getChangeState().pipe(\r\n      tap(data => {\r\n        if (data.property.name === 'position') {\r\n\t\t\t\t\tthis.previous = this.carouselService.current();\r\n\t\t\t\t\tthis.next = data.property.value;\r\n\t\t\t\t}\r\n      })\r\n    );\r\n\r\n    const dragCarousel$: Observable<string> = this.carouselService.getDragState();\r\n    const draggedCarousel$: Observable<string> = this.carouselService.getDraggedState();\r\n    const translatedCarousel$: Observable<string> = this.carouselService.getTranslatedState();\r\n\r\n    const dragTranslatedMerge$: Observable<string> = merge(dragCarousel$, draggedCarousel$, translatedCarousel$).pipe(\r\n      tap(data => this.swapping = data === 'translated')\r\n    );\r\n\r\n    const translateCarousel$: Observable<string> = this.carouselService.getTranslateState().pipe(\r\n      tap(data => {\r\n        if (this.swapping && (this.carouselService._options.animateOut || this.carouselService._options.animateIn)) {\r\n          this._swap();\r\n        }\r\n      })\r\n    );\r\n\r\n    const animateMerge$: Observable<string | any> = merge(changeSettings$, translateCarousel$, dragTranslatedMerge$).pipe();\r\n    this.animateSubscription = animateMerge$.subscribe(\r\n      () => {}\r\n    );\r\n  }\r\n\r\n  /**\r\n\t * Toggles the animation classes whenever an translations starts.\r\n\t * @returns\r\n\t */\r\n\tprivate _swap(): boolean {\r\n\r\n\t\tif (this.carouselService.settings.items !== 1) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\t// if (!$.support.animation || !$.support.transition) {\r\n\t\t// \treturn;\r\n\t\t// }\r\n\r\n\t\tthis.carouselService.speed(0);\r\n\r\n\t\tlet left;\r\n\t\tconst\tprevious = this.carouselService.slidesData[this.previous],\r\n\t\t\tnext = this.carouselService.slidesData[this.next],\r\n\t\t\tincoming = this.carouselService.settings.animateIn,\r\n\t\t\toutgoing = this.carouselService.settings.animateOut;\r\n\r\n\t\tif (this.carouselService.current() === this.previous) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (outgoing) {\r\n\t\t\tleft = +this.carouselService.coordinates(this.previous) - +this.carouselService.coordinates(this.next);\r\n      this.carouselService.slidesData.forEach(slide => {\r\n        if (slide.id === previous.id) {\r\n          slide.left = `${left}px`;\r\n          slide.isAnimated = true;\r\n          slide.isDefAnimatedOut = true;\r\n          slide.isCustomAnimatedOut = true;\r\n        }\r\n      });\r\n\t\t}\r\n\r\n\t\tif (incoming) {\r\n      this.carouselService.slidesData.forEach(slide => {\r\n        if (slide.id === next.id) {\r\n          slide.isAnimated = true;\r\n          slide.isDefAnimatedIn = true;\r\n          slide.isCustomAnimatedIn = true;\r\n        }\r\n      });\r\n\t\t}\r\n\t};\r\n\r\n  /**\r\n   * Handles the end of 'animationend' event\r\n   * @param id Id of slides\r\n   */\r\n  clear(id) {\r\n    this.carouselService.slidesData.forEach(slide => {\r\n      if (slide.id === id) {\r\n        slide.left = '';\r\n        slide.isAnimated = false;\r\n        slide.isDefAnimatedOut = false;\r\n        slide.isCustomAnimatedOut = false;\r\n        slide.isDefAnimatedIn = false;\r\n        slide.isCustomAnimatedIn = false;\r\n        slide.classes = this.carouselService.setCurSlideClasses(slide);\r\n      }\r\n    });\r\n    this.carouselService.onTransitionEnd();\r\n\t};\r\n}\r\n"]}