rfx-scroll-animation
Advanced tools
Comparing version 3.4.0 to 3.5.0
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/platform-browser'), require('@angular/platform-browser/animations'), require('rxjs'), require('@angular/animations')) : | ||
typeof define === 'function' && define.amd ? define('rfx-scroll-animation', ['exports', '@angular/core', '@angular/platform-browser', '@angular/platform-browser/animations', 'rxjs', '@angular/animations'], factory) : | ||
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global['rfx-scroll-animation'] = {}, global.ng.core, global.ng.platformBrowser, global.ng.platformBrowser.animations, global.rxjs, global.ng.animations)); | ||
}(this, (function (exports, i0, platformBrowser, animations$1, rxjs, animations) { 'use strict'; | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/platform-browser'), require('@angular/platform-browser/animations'), require('rxjs'), require('@angular/common'), require('@angular/animations')) : | ||
typeof define === 'function' && define.amd ? define('rfx-scroll-animation', ['exports', '@angular/core', '@angular/platform-browser', '@angular/platform-browser/animations', 'rxjs', '@angular/common', '@angular/animations'], factory) : | ||
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global['rfx-scroll-animation'] = {}, global.ng.core, global.ng.platformBrowser, global.ng.platformBrowser.animations, global.rxjs, global.ng.common, global.ng.animations)); | ||
}(this, (function (exports, i0, platformBrowser, animations$1, rxjs, common, animations) { 'use strict'; | ||
@@ -581,3 +581,3 @@ function _interopNamespace(e) { | ||
var RfxScrollAnimationService = /** @class */ (function () { | ||
function RfxScrollAnimationService(scrollEventService, resizeEventService, heightEventService, elementsManagementService) { | ||
function RfxScrollAnimationService(scrollEventService, resizeEventService, heightEventService, elementsManagementService, platformId) { | ||
this.scrollEventService = scrollEventService; | ||
@@ -587,2 +587,4 @@ this.resizeEventService = resizeEventService; | ||
this.elementsManagementService = elementsManagementService; | ||
this.platformId = platformId; | ||
this.isBrowser = common.isPlatformBrowser(this.platformId); | ||
} | ||
@@ -604,10 +606,11 @@ RfxScrollAnimationService.prototype.ngOnDestroy = function () { | ||
* Default body element is the document element. | ||
* @param {HTMLElement} element - Scroll element to use. | ||
* @param {HTMLElement | Document | undefined} element - Scroll element to use. | ||
*/ | ||
RfxScrollAnimationService.prototype.initListeners = function (element) { | ||
if (element === void 0) { element = document; } | ||
this.destroyListeners(); | ||
this.scrollEventService.createListener(element); | ||
this.resizeEventService.createListener(); | ||
this.heightEventService.createListener(element); | ||
if (this.isBrowser) { | ||
this.scrollEventService.createListener(element !== null && element !== void 0 ? element : document); | ||
this.resizeEventService.createListener(); | ||
this.heightEventService.createListener(element !== null && element !== void 0 ? element : document); | ||
} | ||
}; | ||
@@ -637,3 +640,3 @@ /** | ||
}()); | ||
RfxScrollAnimationService.ɵprov = i0__namespace.ɵɵdefineInjectable({ factory: function RfxScrollAnimationService_Factory() { return new RfxScrollAnimationService(i0__namespace.ɵɵinject(ScrollEventService), i0__namespace.ɵɵinject(ResizeEventService), i0__namespace.ɵɵinject(HeightEventService), i0__namespace.ɵɵinject(ElementsManagementService)); }, token: RfxScrollAnimationService, providedIn: "root" }); | ||
RfxScrollAnimationService.ɵprov = i0__namespace.ɵɵdefineInjectable({ factory: function RfxScrollAnimationService_Factory() { return new RfxScrollAnimationService(i0__namespace.ɵɵinject(ScrollEventService), i0__namespace.ɵɵinject(ResizeEventService), i0__namespace.ɵɵinject(HeightEventService), i0__namespace.ɵɵinject(ElementsManagementService), i0__namespace.ɵɵinject(i0__namespace.PLATFORM_ID)); }, token: RfxScrollAnimationService, providedIn: "root" }); | ||
RfxScrollAnimationService.decorators = [ | ||
@@ -648,3 +651,4 @@ { type: i0.Injectable, args: [{ | ||
{ type: HeightEventService }, | ||
{ type: ElementsManagementService } | ||
{ type: ElementsManagementService }, | ||
{ type: Object, decorators: [{ type: i0.Inject, args: [i0.PLATFORM_ID,] }] } | ||
]; }; | ||
@@ -685,3 +689,3 @@ | ||
var RfxScrollAnimationComponent = /** @class */ (function () { | ||
function RfxScrollAnimationComponent(htmlElement, renderer, scrollEventService, heightEventService, resizeEventService, elementsManagementService) { | ||
function RfxScrollAnimationComponent(htmlElement, renderer, scrollEventService, heightEventService, resizeEventService, elementsManagementService, platformId) { | ||
this.htmlElement = htmlElement; | ||
@@ -693,2 +697,3 @@ this.renderer = renderer; | ||
this.elementsManagementService = elementsManagementService; | ||
this.platformId = platformId; | ||
this.animationType = exports.AnimationTypeEnum.NONE; | ||
@@ -709,2 +714,3 @@ this.animationDistancePx = 25; | ||
this.elementIndex = this.elementsManagementService.registerElement(this); | ||
this.isBrowser = common.isPlatformBrowser(platformId); | ||
} | ||
@@ -731,3 +737,5 @@ Object.defineProperty(RfxScrollAnimationComponent.prototype, "visibility", { | ||
RfxScrollAnimationComponent.prototype.ngAfterViewInit = function () { | ||
this.createListeners(); | ||
if (this.isBrowser) { | ||
this.createListeners(); | ||
} | ||
this.subscribeToElementsReadyEvent(); | ||
@@ -805,3 +813,8 @@ this.elementsManagementService.setElementReady(this.elementIndex); | ||
_this.isPageReady = true; | ||
_this.calculateElementProperties(); | ||
if (_this.isBrowser) { | ||
_this.calculateElementProperties(); | ||
} | ||
else { | ||
_this.setVisibility(exports.AnimationVisibilityEnum.VISIBLE); | ||
} | ||
} | ||
@@ -971,3 +984,4 @@ }); | ||
{ type: ResizeEventService }, | ||
{ type: ElementsManagementService } | ||
{ type: ElementsManagementService }, | ||
{ type: Object, decorators: [{ type: i0.Inject, args: [i0.PLATFORM_ID,] }] } | ||
]; }; | ||
@@ -974,0 +988,0 @@ RfxScrollAnimationComponent.propDecorators = { |
@@ -1,7 +0,8 @@ | ||
import { Component, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2 } from '@angular/core'; | ||
import { Component, ElementRef, EventEmitter, HostBinding, Inject, Input, Output, PLATFORM_ID, Renderer2 } from '@angular/core'; | ||
import { ElementsManagementService, ScrollEventService, ResizeEventService, HeightEventService } from '../../services'; | ||
import { visibilityAnimation } from '../../animations'; | ||
import { AnimationTypeEnum, AnimationVisibilityEnum } from '../../models'; | ||
import { isPlatformBrowser } from '@angular/common'; | ||
export class RfxScrollAnimationComponent { | ||
constructor(htmlElement, renderer, scrollEventService, heightEventService, resizeEventService, elementsManagementService) { | ||
constructor(htmlElement, renderer, scrollEventService, heightEventService, resizeEventService, elementsManagementService, platformId) { | ||
this.htmlElement = htmlElement; | ||
@@ -13,2 +14,3 @@ this.renderer = renderer; | ||
this.elementsManagementService = elementsManagementService; | ||
this.platformId = platformId; | ||
this.animationType = AnimationTypeEnum.NONE; | ||
@@ -29,2 +31,3 @@ this.animationDistancePx = 25; | ||
this.elementIndex = this.elementsManagementService.registerElement(this); | ||
this.isBrowser = isPlatformBrowser(platformId); | ||
} | ||
@@ -47,3 +50,5 @@ /** | ||
ngAfterViewInit() { | ||
this.createListeners(); | ||
if (this.isBrowser) { | ||
this.createListeners(); | ||
} | ||
this.subscribeToElementsReadyEvent(); | ||
@@ -117,3 +122,8 @@ this.elementsManagementService.setElementReady(this.elementIndex); | ||
this.isPageReady = true; | ||
this.calculateElementProperties(); | ||
if (this.isBrowser) { | ||
this.calculateElementProperties(); | ||
} | ||
else { | ||
this.setVisibility(AnimationVisibilityEnum.VISIBLE); | ||
} | ||
} | ||
@@ -280,3 +290,4 @@ }); | ||
{ type: ResizeEventService }, | ||
{ type: ElementsManagementService } | ||
{ type: ElementsManagementService }, | ||
{ type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] } | ||
]; | ||
@@ -295,2 +306,2 @@ RfxScrollAnimationComponent.propDecorators = { | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-scroll-animation.component.js","sourceRoot":"","sources":["../../../../../../projects/rfx-scroll-animation/src/lib/components/rfx-scroll-animation/rfx-scroll-animation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostBinding, Input, OnChanges, OnDestroy, Output, Renderer2, SimpleChanges } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ElementsManagementService, ScrollEventService, ResizeEventService, HeightEventService } from '../../services';\r\nimport { visibilityAnimation } from '../../animations';\r\nimport { AnimationExpInterface, AnimationTypeEnum, AnimationVisibilityEnum, SectionAreaModel } from '../../models';\r\n\r\n\r\n@Component({\r\n  selector: '[libRfxScrollAnimation]',\r\n  templateUrl: './rfx-scroll-animation.component.html',\r\n  styleUrls: ['./rfx-scroll-animation.component.less'],\r\n  animations: [\r\n    visibilityAnimation\r\n  ]\r\n})\r\nexport class RfxScrollAnimationComponent implements AfterViewInit, OnChanges, OnDestroy {\r\n  /**\r\n   * Element animation type.\r\n   * Default is NONE.\r\n   * Must be 'NONE' if you want to implement custom animation.\r\n   * @type {AnimationTypeEnum}\r\n   */\r\n  @Input()\r\n  public animationType: AnimationTypeEnum | string;\r\n\r\n  /**\r\n   * Element animation shift from correct position.\r\n   * If zero, there is no animation.\r\n   * Default is 25px.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public animationDistancePx: number;\r\n\r\n  /**\r\n   * Zoom animation ratio.\r\n   * Can be positive or negative.\r\n   * Default is 1.5.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public scaleRatio: number;\r\n\r\n  /**\r\n   * Animation transition duration in milliseconds.\r\n   * Must be more or equal to zero.\r\n   * If zero, there is no animation.\r\n   * Default is 500.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public transitionDurationMs: number;\r\n\r\n  /**\r\n   * Animation transition delay in milliseconds.\r\n   * Must be more or equal to zero.\r\n   * If zero, there is no delay.\r\n   * Default is 0.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public transitionDelayMs: number;\r\n\r\n  /**\r\n   * Animation timing function\r\n   * Default is 'cubic-bezier(0.4, 0.0, 0.2, 1)'.\r\n   * @type {string}\r\n   */\r\n  @Input()\r\n  public transitionTimingFunction: string;\r\n\r\n  /**\r\n   * How much space (in percentage) from the bottom of the page\r\n   * before the element is considered to be visible.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public distanceFromPageBottomPercentage: number;\r\n\r\n  /**\r\n   * If true, element appears only once and never hides.\r\n   * Default is true.\r\n   * @type {boolean}\r\n   */\r\n  @Input()\r\n  public isOnlyFirstTime: boolean;\r\n\r\n  /**\r\n   * Emit element visibility change event.\r\n   * @param {boolean} isVisible\r\n   */\r\n  @Output()\r\n  public elementVisibleChange: EventEmitter<boolean>;\r\n\r\n  /**\r\n   * Subscription to body height changes.\r\n   * @type {Subscription}\r\n   */\r\n  private heightListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Subscription to scroll value changes.\r\n   * @type {Subscription}\r\n   */\r\n  private scrollListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Subscription to window resize changes.\r\n   * @type {Subscription}\r\n   */\r\n  private resizeListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Subscription to elements ready value changes.\r\n   * @type {Subscription}\r\n   */\r\n  private elementsReadyListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Animation visibility status.\r\n   * Can be 'HIDDEN' or 'VISIBLE'.\r\n   * @type {AnimationVisibilityEnum}\r\n   */\r\n  private animationVisibility: AnimationVisibilityEnum;\r\n\r\n  /**\r\n   * Animation will change value.\r\n   */\r\n  private animationWillChange: boolean;\r\n\r\n  /**\r\n   * Current transform value.\r\n   * Default is 'translate(0, 0) scale(1)'.\r\n   * @type {string}\r\n   */\r\n  private currentTransform: string;\r\n\r\n  /**\r\n   * Current page height in pixels.\r\n   * @type {number}\r\n   */\r\n  private currentPageHeight: number;\r\n\r\n  /**\r\n   * Is page ready to animate elements.\r\n   * Default is false.\r\n   */\r\n  private isPageReady: boolean;\r\n\r\n  /**\r\n   * Registered element index inside service.\r\n   * @type {number}\r\n   */\r\n  public elementIndex: number;\r\n\r\n  /**\r\n   * Value where the element is considered to be visible.\r\n   * @type {number | undefined}\r\n   */\r\n  private visibilityBarrier: number | undefined;\r\n\r\n  /**\r\n   * Values where the element have will-change property.\r\n   * @type {SectionAreaModel | undefined}\r\n   */\r\n  private willChangeArea: SectionAreaModel | undefined;\r\n\r\n  /**\r\n   * Bind visibility animation to host element.\r\n   */\r\n  @HostBinding('@visibility')\r\n  get visibility(): AnimationExpInterface | null {\r\n    return this.animationType === AnimationTypeEnum.NONE ? null : {\r\n      value: this.animationVisibility,\r\n      params: {\r\n        currentTransform: this.currentTransform,\r\n        transitionTimingFunction: this.transitionTimingFunction,\r\n        transitionDurationMs: this.transitionDurationMs,\r\n        transitionDelayMs: this.transitionDelayMs,\r\n        scaleRatio: this.scaleRatio\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private renderer: Renderer2,\r\n    private scrollEventService: ScrollEventService,\r\n    private heightEventService: HeightEventService,\r\n    private resizeEventService: ResizeEventService,\r\n    private elementsManagementService: ElementsManagementService\r\n  ) {\r\n    this.animationType = AnimationTypeEnum.NONE;\r\n    this.animationDistancePx = 25;\r\n    this.scaleRatio = 1.5;\r\n    this.transitionDurationMs = 500;\r\n    this.transitionDelayMs = 0;\r\n    this.transitionTimingFunction = 'cubic-bezier(0.4, 0.0, 0.2, 1)';\r\n    this.distanceFromPageBottomPercentage = 20;\r\n    this.isOnlyFirstTime = true;\r\n    this.elementVisibleChange = new EventEmitter<boolean>();\r\n    this.currentTransform = 'translate(0, 0) scale(1)';\r\n    this.animationVisibility = AnimationVisibilityEnum.HIDDEN;\r\n    this.animationWillChange = true;\r\n    this.currentPageHeight = 0;\r\n    this.isPageReady = false;\r\n    this.elementIndex = this.elementsManagementService.registerElement(this);\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    this.createListeners();\r\n    this.subscribeToElementsReadyEvent();\r\n    this.elementsManagementService.setElementReady(this.elementIndex);\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    if (\r\n      changes?.animationType?.currentValue !== undefined ||\r\n      changes?.animationDistancePx?.currentValue !== undefined ||\r\n      changes?.scaleRatio?.currentValue !== undefined\r\n    ) {\r\n      this.currentTransform = this.getCurrentTransform(\r\n        this.animationType,\r\n        this.animationDistancePx,\r\n        this.scaleRatio\r\n      );\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.destroyListeners();\r\n  }\r\n\r\n  /**\r\n   * Create listeners.\r\n   * Destroy all existing listeners before creating new ones.\r\n   */\r\n  private createListeners(): void {\r\n    this.destroyListeners();\r\n    this.subscribeToResizeEvent();\r\n    this.subscribeToHeightEvent();\r\n    this.subscribeToScrollEvent();\r\n  }\r\n\r\n  /**\r\n   * Destroy all listeners.\r\n   */\r\n  private destroyListeners(): void {\r\n    this.heightListenerSubscription?.unsubscribe();\r\n    this.scrollListenerSubscription?.unsubscribe();\r\n    this.resizeListenerSubscription?.unsubscribe();\r\n    this.elementsReadyListenerSubscription?.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Subscribe to window resize event.\r\n   * When window is resized, update element properties.\r\n   */\r\n  private subscribeToResizeEvent(): void {\r\n    this.resizeListenerSubscription = this.resizeEventService.getResize().subscribe(\r\n      () => this.calculateElementProperties()\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Subscribe to height change event.\r\n   * When height change, update element properties.\r\n   */\r\n  private subscribeToHeightEvent(): void {\r\n    this.heightListenerSubscription = this.heightEventService.getHeight().subscribe(\r\n      (height) => {\r\n        if (this.currentPageHeight !== height) {\r\n          this.calculateElementProperties();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Subscribe to scroll change event.\r\n   */\r\n  private subscribeToScrollEvent(): void {\r\n    this.scrollListenerSubscription = this.scrollEventService.getMouseScroll().subscribe(\r\n      (scroll: number) => this.onScrollEvent(scroll)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Subscribe to elements ready flag event.\r\n   * If elements are ready, calculate element properties and destroy this listener.\r\n   */\r\n  private subscribeToElementsReadyEvent(): void {\r\n    this.elementsReadyListenerSubscription = this.elementsManagementService.getElementsReady().subscribe(\r\n      (isReady: boolean) => {\r\n        if (isReady) {\r\n          this.elementsReadyListenerSubscription?.unsubscribe();\r\n          this.isPageReady = true;\r\n          this.calculateElementProperties();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Calculate and set will-change area.\r\n   * Calculate and set visibility barrier.\r\n   * Trigger page scroll event so that element can be updated.\r\n   */\r\n  public calculateElementProperties(): void {\r\n    this.visibilityBarrier = undefined;\r\n    const windowHeightPx: number = window.innerHeight;\r\n    const scroll: number = this.scrollEventService.getMouseScrollValue();\r\n    this.currentPageHeight = this.heightEventService.getHeightValue();\r\n\r\n    this.willChangeArea = this.getWillChangeArea(\r\n      this.htmlElement.nativeElement, scroll, windowHeightPx\r\n    );\r\n\r\n    this.visibilityBarrier = this.getVisibilityBarrier(\r\n      this.htmlElement.nativeElement, scroll, windowHeightPx, this.currentPageHeight, this.distanceFromPageBottomPercentage\r\n    );\r\n\r\n    this.onScrollEvent(scroll);\r\n  }\r\n\r\n  /**\r\n   * Calculate area where element is probably going to be animated soon.\r\n   * @param {HTMLElement} element - Element to calculate will-change area for.\r\n   * @param {number} scroll - Current scroll value.\r\n   * @param {number} windowHeightPx - Current window height.\r\n   * @returns {number} - Will-change area.\r\n   */\r\n  private getWillChangeArea(element: HTMLElement, scroll: number, windowHeightPx: number): SectionAreaModel {\r\n    const elementRect: DOMRect = element.getBoundingClientRect();\r\n    const elementTop: number = elementRect.top + scroll;\r\n    const triggerArea: number = windowHeightPx * 2;\r\n    const areaTop: number = elementTop - triggerArea;\r\n    const areaBottom: number = elementTop + triggerArea;\r\n    return { top: areaTop, bottom: areaBottom };\r\n  }\r\n\r\n  /**\r\n   * Get value which indicates where element is visible.\r\n   * If bottom limit cannot be reached, force it at the very bottom of the page\r\n   * so we can see the element.\r\n   * @param {HTMLElement} element - Element to check.\r\n   * @param {number} scroll - Current scroll value.\r\n   * @param {number} windowHeightPx - Window height in pixels.\r\n   * @param {number} pageHeightPx - Page height in pixels.\r\n   * @param {number} distanceFromPageBottomPercentage - Distance from page bottom in percentage.\r\n   * @returns {number} - Visibility barrier.\r\n   */\r\n  private getVisibilityBarrier(\r\n    element: HTMLElement,\r\n    scroll: number,\r\n    windowHeightPx: number,\r\n    pageHeightPx: number,\r\n    distanceFromPageBottomPercentage: number\r\n  ): number {\r\n    const elementRect: DOMRect = element.getBoundingClientRect();\r\n    const bottomDistancePx: number = windowHeightPx * distanceFromPageBottomPercentage / 100;\r\n    const bottomLimitPx: number = elementRect.top + scroll - windowHeightPx + bottomDistancePx;\r\n    const bottomPageLimitPx: number = pageHeightPx - windowHeightPx;\r\n    return bottomLimitPx > bottomPageLimitPx ? bottomPageLimitPx : bottomLimitPx;\r\n  }\r\n\r\n  /**\r\n   * Retuns current transform value based on animation type, distance and scale ratio.\r\n   * @param {AnimationTypeEnum} animationType - Animation type.\r\n   * @param {number} animationDistancePx - Animation distance in pixels.\r\n   * @param {number} scaleRatio - Scale ratio.\r\n   * @returns {string} - Current transform value.\r\n   */\r\n  private getCurrentTransform(animationType: AnimationTypeEnum | string, animationDistancePx: number = 0, scaleRatio: number = 1): string {\r\n    switch (animationType) {\r\n      case AnimationTypeEnum.TOP:\r\n        return `translate(0, -${animationDistancePx}px) scale(1)`;\r\n      case AnimationTypeEnum.BOTTOM:\r\n        return `translate(0, ${animationDistancePx}px) scale(1)`;\r\n      case AnimationTypeEnum.LEFT:\r\n        return `translate(-${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.RIGHT:\r\n        return `translate(${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.ZOOM:\r\n        return `translate(0, 0) scale(${scaleRatio})`;\r\n      default:\r\n        return 'translate(0, 0) scale(1)';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Scroll event handler:\r\n   * - calculate visibility\r\n   * - destroy listeners if element is visible and is a one-shot element\r\n   * - set element visibility if changed\r\n   * - set will-change property if element is near the barrier value\r\n   * @param {number} scroll - Current scroll value.\r\n   */\r\n  private onScrollEvent(scroll: number): void {\r\n    if (this.isPageReady && this.visibilityBarrier !== undefined && this.willChangeArea !== undefined) {\r\n      const visibility: AnimationVisibilityEnum = this.getVisibility(scroll, this.visibilityBarrier);\r\n\r\n      if (this.isOnlyFirstTime && visibility === AnimationVisibilityEnum.VISIBLE) {\r\n        this.destroyListeners();\r\n      }\r\n\r\n      if (visibility !== this.animationVisibility) {\r\n        this.setVisibility(visibility);\r\n      }\r\n\r\n      const isElementInArea: boolean = this.isElementInArea(scroll, this.willChangeArea);\r\n\r\n      if (!this.isOnlyFirstTime && (isElementInArea !== this.animationWillChange)) {\r\n        this.setWillChange(isElementInArea);\r\n      }\r\n\r\n      if (this.isOnlyFirstTime && visibility === AnimationVisibilityEnum.VISIBLE) {\r\n        this.setWillChange(false);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get visibility state.\r\n   * Element is visible when scroll position crosses visibility barrier.\r\n   * @param {number} scroll - Scroll position.\r\n   * @param {number} visibilityBarrier - the limit where the element becomes visible.\r\n   * @returns {AnimationVisibilityEnum}\r\n   */\r\n  private getVisibility(scroll: number, visibilityBarrier: number): AnimationVisibilityEnum {\r\n    const isVisible: boolean = scroll >= visibilityBarrier;\r\n    return isVisible ? AnimationVisibilityEnum.VISIBLE : AnimationVisibilityEnum.HIDDEN;\r\n  }\r\n\r\n  /**\r\n   * Set element visiblity and emit visibility change event.\r\n   * If animation is only first time, wait for animation to finish and remove will-change.\r\n   * @param {AnimationVisibilityEnum} visibility - Visibility value.\r\n   */\r\n  public setVisibility(visible: AnimationVisibilityEnum): void {\r\n    this.animationVisibility = visible;\r\n    this.elementVisibleChange.emit(visible === AnimationVisibilityEnum.VISIBLE);\r\n  }\r\n\r\n  /**\r\n   * Reset element visibility state.\r\n   * Usefull when element is a one-shot element and\r\n   * we want to hide it after it has been visible.\r\n   */\r\n  public reset(): void {\r\n    this.createListeners();\r\n  }\r\n\r\n  /**\r\n   * Set element will-change property.\r\n   * @param {boolean} willChange - will-change enabled or disabled.\r\n   */\r\n  private setWillChange(willChange: boolean): void {\r\n    this.animationWillChange = willChange;\r\n    this.renderer.setStyle(\r\n      this.htmlElement.nativeElement,\r\n      'will-change',\r\n      willChange ? 'opacity, transform' : 'auto'\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Check if element is in will-change area.\r\n   * @param {number} scroll - Scroll position.\r\n   * @param {SectionAreaModel} willChangeArea - Will-change area.\r\n   * @returns {boolean} - Is element in will-change area.\r\n   */\r\n  private isElementInArea(scroll: number, willChangeArea: SectionAreaModel): boolean {\r\n    return scroll >= willChangeArea.top && scroll <= willChangeArea.bottom;\r\n  }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-scroll-animation.component.js","sourceRoot":"","sources":["../../../../../../projects/rfx-scroll-animation/src/lib/components/rfx-scroll-animation/rfx-scroll-animation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostBinding, Inject, Input, OnChanges, OnDestroy, Output, PLATFORM_ID, Renderer2, SimpleChanges } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ElementsManagementService, ScrollEventService, ResizeEventService, HeightEventService } from '../../services';\r\nimport { visibilityAnimation } from '../../animations';\r\nimport { AnimationExpInterface, AnimationTypeEnum, AnimationVisibilityEnum, SectionAreaModel } from '../../models';\r\nimport { isPlatformBrowser } from '@angular/common';\r\n\r\n\r\n@Component({\r\n  selector: '[libRfxScrollAnimation]',\r\n  templateUrl: './rfx-scroll-animation.component.html',\r\n  styleUrls: ['./rfx-scroll-animation.component.less'],\r\n  animations: [\r\n    visibilityAnimation\r\n  ]\r\n})\r\nexport class RfxScrollAnimationComponent implements AfterViewInit, OnChanges, OnDestroy {\r\n  /**\r\n   * Element animation type.\r\n   * Default is NONE.\r\n   * Must be 'NONE' if you want to implement custom animation.\r\n   * @type {AnimationTypeEnum}\r\n   */\r\n  @Input()\r\n  public animationType: AnimationTypeEnum | string;\r\n\r\n  /**\r\n   * Element animation shift from correct position.\r\n   * If zero, there is no animation.\r\n   * Default is 25px.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public animationDistancePx: number;\r\n\r\n  /**\r\n   * Zoom animation ratio.\r\n   * Can be positive or negative.\r\n   * Default is 1.5.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public scaleRatio: number;\r\n\r\n  /**\r\n   * Animation transition duration in milliseconds.\r\n   * Must be more or equal to zero.\r\n   * If zero, there is no animation.\r\n   * Default is 500.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public transitionDurationMs: number;\r\n\r\n  /**\r\n   * Animation transition delay in milliseconds.\r\n   * Must be more or equal to zero.\r\n   * If zero, there is no delay.\r\n   * Default is 0.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public transitionDelayMs: number;\r\n\r\n  /**\r\n   * Animation timing function\r\n   * Default is 'cubic-bezier(0.4, 0.0, 0.2, 1)'.\r\n   * @type {string}\r\n   */\r\n  @Input()\r\n  public transitionTimingFunction: string;\r\n\r\n  /**\r\n   * How much space (in percentage) from the bottom of the page\r\n   * before the element is considered to be visible.\r\n   * @type {number}\r\n   */\r\n  @Input()\r\n  public distanceFromPageBottomPercentage: number;\r\n\r\n  /**\r\n   * If true, element appears only once and never hides.\r\n   * Default is true.\r\n   * @type {boolean}\r\n   */\r\n  @Input()\r\n  public isOnlyFirstTime: boolean;\r\n\r\n  /**\r\n   * Emit element visibility change event.\r\n   * @param {boolean} isVisible\r\n   */\r\n  @Output()\r\n  public elementVisibleChange: EventEmitter<boolean>;\r\n\r\n  /**\r\n   * Subscription to body height changes.\r\n   * @type {Subscription}\r\n   */\r\n  private heightListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Subscription to scroll value changes.\r\n   * @type {Subscription}\r\n   */\r\n  private scrollListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Subscription to window resize changes.\r\n   * @type {Subscription}\r\n   */\r\n  private resizeListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Subscription to elements ready value changes.\r\n   * @type {Subscription}\r\n   */\r\n  private elementsReadyListenerSubscription: Subscription | undefined;\r\n\r\n  /**\r\n   * Animation visibility status.\r\n   * Can be 'HIDDEN' or 'VISIBLE'.\r\n   * @type {AnimationVisibilityEnum}\r\n   */\r\n  private animationVisibility: AnimationVisibilityEnum;\r\n\r\n  /**\r\n   * Animation will change value.\r\n   */\r\n  private animationWillChange: boolean;\r\n\r\n  /**\r\n   * Current transform value.\r\n   * Default is 'translate(0, 0) scale(1)'.\r\n   * @type {string}\r\n   */\r\n  private currentTransform: string;\r\n\r\n  /**\r\n   * Current page height in pixels.\r\n   * @type {number}\r\n   */\r\n  private currentPageHeight: number;\r\n\r\n  /**\r\n   * Is page ready to animate elements.\r\n   * Default is false.\r\n   */\r\n  private isPageReady: boolean;\r\n\r\n  /**\r\n   * Registered element index inside service.\r\n   * @type {number}\r\n   */\r\n  public elementIndex: number;\r\n\r\n  /**\r\n   * Value where the element is considered to be visible.\r\n   * @type {number | undefined}\r\n   */\r\n  private visibilityBarrier: number | undefined;\r\n\r\n  /**\r\n   * Values where the element have will-change property.\r\n   * @type {SectionAreaModel | undefined}\r\n   */\r\n  private willChangeArea: SectionAreaModel | undefined;\r\n\r\n  /**\r\n   * Is platform browser.\r\n   * False for example when using SSR.\r\n   * @type {boolean}\r\n   */\r\n  private isBrowser: boolean;\r\n\r\n  /**\r\n   * Bind visibility animation to host element.\r\n   */\r\n  @HostBinding('@visibility')\r\n  get visibility(): AnimationExpInterface | null {\r\n    return this.animationType === AnimationTypeEnum.NONE ? null : {\r\n      value: this.animationVisibility,\r\n      params: {\r\n        currentTransform: this.currentTransform,\r\n        transitionTimingFunction: this.transitionTimingFunction,\r\n        transitionDurationMs: this.transitionDurationMs,\r\n        transitionDelayMs: this.transitionDelayMs,\r\n        scaleRatio: this.scaleRatio\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private renderer: Renderer2,\r\n    private scrollEventService: ScrollEventService,\r\n    private heightEventService: HeightEventService,\r\n    private resizeEventService: ResizeEventService,\r\n    private elementsManagementService: ElementsManagementService,\r\n    @Inject(PLATFORM_ID) private platformId: Object\r\n  ) {\r\n    this.animationType = AnimationTypeEnum.NONE;\r\n    this.animationDistancePx = 25;\r\n    this.scaleRatio = 1.5;\r\n    this.transitionDurationMs = 500;\r\n    this.transitionDelayMs = 0;\r\n    this.transitionTimingFunction = 'cubic-bezier(0.4, 0.0, 0.2, 1)';\r\n    this.distanceFromPageBottomPercentage = 20;\r\n    this.isOnlyFirstTime = true;\r\n    this.elementVisibleChange = new EventEmitter<boolean>();\r\n    this.currentTransform = 'translate(0, 0) scale(1)';\r\n    this.animationVisibility = AnimationVisibilityEnum.HIDDEN;\r\n    this.animationWillChange = true;\r\n    this.currentPageHeight = 0;\r\n    this.isPageReady = false;\r\n    this.elementIndex = this.elementsManagementService.registerElement(this);\r\n    this.isBrowser = isPlatformBrowser(platformId);\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    if (this.isBrowser) {\r\n      this.createListeners();\r\n    }\r\n\r\n    this.subscribeToElementsReadyEvent();\r\n    this.elementsManagementService.setElementReady(this.elementIndex);\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    if (\r\n      changes?.animationType?.currentValue !== undefined ||\r\n      changes?.animationDistancePx?.currentValue !== undefined ||\r\n      changes?.scaleRatio?.currentValue !== undefined\r\n    ) {\r\n      this.currentTransform = this.getCurrentTransform(\r\n        this.animationType,\r\n        this.animationDistancePx,\r\n        this.scaleRatio\r\n      );\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.destroyListeners();\r\n  }\r\n\r\n  /**\r\n   * Create listeners.\r\n   * Destroy all existing listeners before creating new ones.\r\n   */\r\n  private createListeners(): void {\r\n    this.destroyListeners();\r\n    this.subscribeToResizeEvent();\r\n    this.subscribeToHeightEvent();\r\n    this.subscribeToScrollEvent();\r\n  }\r\n\r\n  /**\r\n   * Destroy all listeners.\r\n   */\r\n  private destroyListeners(): void {\r\n    this.heightListenerSubscription?.unsubscribe();\r\n    this.scrollListenerSubscription?.unsubscribe();\r\n    this.resizeListenerSubscription?.unsubscribe();\r\n    this.elementsReadyListenerSubscription?.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Subscribe to window resize event.\r\n   * When window is resized, update element properties.\r\n   */\r\n  private subscribeToResizeEvent(): void {\r\n    this.resizeListenerSubscription = this.resizeEventService.getResize().subscribe(\r\n      () => this.calculateElementProperties()\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Subscribe to height change event.\r\n   * When height change, update element properties.\r\n   */\r\n  private subscribeToHeightEvent(): void {\r\n    this.heightListenerSubscription = this.heightEventService.getHeight().subscribe(\r\n      (height) => {\r\n        if (this.currentPageHeight !== height) {\r\n          this.calculateElementProperties();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Subscribe to scroll change event.\r\n   */\r\n  private subscribeToScrollEvent(): void {\r\n    this.scrollListenerSubscription = this.scrollEventService.getMouseScroll().subscribe(\r\n      (scroll: number) => this.onScrollEvent(scroll)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Subscribe to elements ready flag event.\r\n   * If elements are ready, calculate element properties and destroy this listener.\r\n   */\r\n  private subscribeToElementsReadyEvent(): void {\r\n    this.elementsReadyListenerSubscription = this.elementsManagementService.getElementsReady().subscribe(\r\n      (isReady: boolean) => {\r\n        if (isReady) {\r\n          this.elementsReadyListenerSubscription?.unsubscribe();\r\n          this.isPageReady = true;\r\n\r\n          if (this.isBrowser) {\r\n            this.calculateElementProperties();\r\n          } else {\r\n            this.setVisibility(AnimationVisibilityEnum.VISIBLE);\r\n          }\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Calculate and set will-change area.\r\n   * Calculate and set visibility barrier.\r\n   * Trigger page scroll event so that element can be updated.\r\n   */\r\n  public calculateElementProperties(): void {\r\n    this.visibilityBarrier = undefined;\r\n    const windowHeightPx: number = window.innerHeight;\r\n    const scroll: number = this.scrollEventService.getMouseScrollValue();\r\n    this.currentPageHeight = this.heightEventService.getHeightValue();\r\n\r\n    this.willChangeArea = this.getWillChangeArea(\r\n      this.htmlElement.nativeElement, scroll, windowHeightPx\r\n    );\r\n\r\n    this.visibilityBarrier = this.getVisibilityBarrier(\r\n      this.htmlElement.nativeElement, scroll, windowHeightPx, this.currentPageHeight, this.distanceFromPageBottomPercentage\r\n    );\r\n\r\n    this.onScrollEvent(scroll);\r\n  }\r\n\r\n  /**\r\n   * Calculate area where element is probably going to be animated soon.\r\n   * @param {HTMLElement} element - Element to calculate will-change area for.\r\n   * @param {number} scroll - Current scroll value.\r\n   * @param {number} windowHeightPx - Current window height.\r\n   * @returns {number} - Will-change area.\r\n   */\r\n  private getWillChangeArea(element: HTMLElement, scroll: number, windowHeightPx: number): SectionAreaModel {\r\n    const elementRect: DOMRect = element.getBoundingClientRect();\r\n    const elementTop: number = elementRect.top + scroll;\r\n    const triggerArea: number = windowHeightPx * 2;\r\n    const areaTop: number = elementTop - triggerArea;\r\n    const areaBottom: number = elementTop + triggerArea;\r\n    return { top: areaTop, bottom: areaBottom };\r\n  }\r\n\r\n  /**\r\n   * Get value which indicates where element is visible.\r\n   * If bottom limit cannot be reached, force it at the very bottom of the page\r\n   * so we can see the element.\r\n   * @param {HTMLElement} element - Element to check.\r\n   * @param {number} scroll - Current scroll value.\r\n   * @param {number} windowHeightPx - Window height in pixels.\r\n   * @param {number} pageHeightPx - Page height in pixels.\r\n   * @param {number} distanceFromPageBottomPercentage - Distance from page bottom in percentage.\r\n   * @returns {number} - Visibility barrier.\r\n   */\r\n  private getVisibilityBarrier(\r\n    element: HTMLElement,\r\n    scroll: number,\r\n    windowHeightPx: number,\r\n    pageHeightPx: number,\r\n    distanceFromPageBottomPercentage: number\r\n  ): number {\r\n    const elementRect: DOMRect = element.getBoundingClientRect();\r\n    const bottomDistancePx: number = windowHeightPx * distanceFromPageBottomPercentage / 100;\r\n    const bottomLimitPx: number = elementRect.top + scroll - windowHeightPx + bottomDistancePx;\r\n    const bottomPageLimitPx: number = pageHeightPx - windowHeightPx;\r\n    return bottomLimitPx > bottomPageLimitPx ? bottomPageLimitPx : bottomLimitPx;\r\n  }\r\n\r\n  /**\r\n   * Retuns current transform value based on animation type, distance and scale ratio.\r\n   * @param {AnimationTypeEnum} animationType - Animation type.\r\n   * @param {number} animationDistancePx - Animation distance in pixels.\r\n   * @param {number} scaleRatio - Scale ratio.\r\n   * @returns {string} - Current transform value.\r\n   */\r\n  private getCurrentTransform(animationType: AnimationTypeEnum | string, animationDistancePx: number = 0, scaleRatio: number = 1): string {\r\n    switch (animationType) {\r\n      case AnimationTypeEnum.TOP:\r\n        return `translate(0, -${animationDistancePx}px) scale(1)`;\r\n      case AnimationTypeEnum.BOTTOM:\r\n        return `translate(0, ${animationDistancePx}px) scale(1)`;\r\n      case AnimationTypeEnum.LEFT:\r\n        return `translate(-${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.RIGHT:\r\n        return `translate(${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.ZOOM:\r\n        return `translate(0, 0) scale(${scaleRatio})`;\r\n      default:\r\n        return 'translate(0, 0) scale(1)';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Scroll event handler:\r\n   * - calculate visibility\r\n   * - destroy listeners if element is visible and is a one-shot element\r\n   * - set element visibility if changed\r\n   * - set will-change property if element is near the barrier value\r\n   * @param {number} scroll - Current scroll value.\r\n   */\r\n  private onScrollEvent(scroll: number): void {\r\n    if (this.isPageReady && this.visibilityBarrier !== undefined && this.willChangeArea !== undefined) {\r\n      const visibility: AnimationVisibilityEnum = this.getVisibility(scroll, this.visibilityBarrier);\r\n\r\n      if (this.isOnlyFirstTime && visibility === AnimationVisibilityEnum.VISIBLE) {\r\n        this.destroyListeners();\r\n      }\r\n\r\n      if (visibility !== this.animationVisibility) {\r\n        this.setVisibility(visibility);\r\n      }\r\n\r\n      const isElementInArea: boolean = this.isElementInArea(scroll, this.willChangeArea);\r\n\r\n      if (!this.isOnlyFirstTime && (isElementInArea !== this.animationWillChange)) {\r\n        this.setWillChange(isElementInArea);\r\n      }\r\n\r\n      if (this.isOnlyFirstTime && visibility === AnimationVisibilityEnum.VISIBLE) {\r\n        this.setWillChange(false);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get visibility state.\r\n   * Element is visible when scroll position crosses visibility barrier.\r\n   * @param {number} scroll - Scroll position.\r\n   * @param {number} visibilityBarrier - the limit where the element becomes visible.\r\n   * @returns {AnimationVisibilityEnum}\r\n   */\r\n  private getVisibility(scroll: number, visibilityBarrier: number): AnimationVisibilityEnum {\r\n    const isVisible: boolean = scroll >= visibilityBarrier;\r\n    return isVisible ? AnimationVisibilityEnum.VISIBLE : AnimationVisibilityEnum.HIDDEN;\r\n  }\r\n\r\n  /**\r\n   * Set element visiblity and emit visibility change event.\r\n   * If animation is only first time, wait for animation to finish and remove will-change.\r\n   * @param {AnimationVisibilityEnum} visibility - Visibility value.\r\n   */\r\n  public setVisibility(visible: AnimationVisibilityEnum): void {\r\n    this.animationVisibility = visible;\r\n    this.elementVisibleChange.emit(visible === AnimationVisibilityEnum.VISIBLE);\r\n  }\r\n\r\n  /**\r\n   * Reset element visibility state.\r\n   * Usefull when element is a one-shot element and\r\n   * we want to hide it after it has been visible.\r\n   */\r\n  public reset(): void {\r\n    this.createListeners();\r\n  }\r\n\r\n  /**\r\n   * Set element will-change property.\r\n   * @param {boolean} willChange - will-change enabled or disabled.\r\n   */\r\n  private setWillChange(willChange: boolean): void {\r\n    this.animationWillChange = willChange;\r\n    this.renderer.setStyle(\r\n      this.htmlElement.nativeElement,\r\n      'will-change',\r\n      willChange ? 'opacity, transform' : 'auto'\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Check if element is in will-change area.\r\n   * @param {number} scroll - Scroll position.\r\n   * @param {SectionAreaModel} willChangeArea - Will-change area.\r\n   * @returns {boolean} - Is element in will-change area.\r\n   */\r\n  private isElementInArea(scroll: number, willChangeArea: SectionAreaModel): boolean {\r\n    return scroll >= willChangeArea.top && scroll <= willChangeArea.bottom;\r\n  }\r\n}\r\n"]} |
@@ -1,2 +0,2 @@ | ||
import { Injectable } from '@angular/core'; | ||
import { Inject, Injectable, PLATFORM_ID } from '@angular/core'; | ||
import { ScrollEventService } from './scroll-event.service'; | ||
@@ -6,2 +6,3 @@ import { ResizeEventService } from './resize-event.service'; | ||
import { ElementsManagementService } from './elements-management.service'; | ||
import { isPlatformBrowser } from '@angular/common'; | ||
import * as i0 from "@angular/core"; | ||
@@ -13,3 +14,3 @@ import * as i1 from "./scroll-event.service"; | ||
export class RfxScrollAnimationService { | ||
constructor(scrollEventService, resizeEventService, heightEventService, elementsManagementService) { | ||
constructor(scrollEventService, resizeEventService, heightEventService, elementsManagementService, platformId) { | ||
this.scrollEventService = scrollEventService; | ||
@@ -19,2 +20,4 @@ this.resizeEventService = resizeEventService; | ||
this.elementsManagementService = elementsManagementService; | ||
this.platformId = platformId; | ||
this.isBrowser = isPlatformBrowser(this.platformId); | ||
} | ||
@@ -36,9 +39,11 @@ ngOnDestroy() { | ||
* Default body element is the document element. | ||
* @param {HTMLElement} element - Scroll element to use. | ||
* @param {HTMLElement | Document | undefined} element - Scroll element to use. | ||
*/ | ||
initListeners(element = document) { | ||
initListeners(element) { | ||
this.destroyListeners(); | ||
this.scrollEventService.createListener(element); | ||
this.resizeEventService.createListener(); | ||
this.heightEventService.createListener(element); | ||
if (this.isBrowser) { | ||
this.scrollEventService.createListener(element !== null && element !== void 0 ? element : document); | ||
this.resizeEventService.createListener(); | ||
this.heightEventService.createListener(element !== null && element !== void 0 ? element : document); | ||
} | ||
} | ||
@@ -56,3 +61,3 @@ /** | ||
} | ||
RfxScrollAnimationService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RfxScrollAnimationService_Factory() { return new RfxScrollAnimationService(i0.ɵɵinject(i1.ScrollEventService), i0.ɵɵinject(i2.ResizeEventService), i0.ɵɵinject(i3.HeightEventService), i0.ɵɵinject(i4.ElementsManagementService)); }, token: RfxScrollAnimationService, providedIn: "root" }); | ||
RfxScrollAnimationService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RfxScrollAnimationService_Factory() { return new RfxScrollAnimationService(i0.ɵɵinject(i1.ScrollEventService), i0.ɵɵinject(i2.ResizeEventService), i0.ɵɵinject(i3.HeightEventService), i0.ɵɵinject(i4.ElementsManagementService), i0.ɵɵinject(i0.PLATFORM_ID)); }, token: RfxScrollAnimationService, providedIn: "root" }); | ||
RfxScrollAnimationService.decorators = [ | ||
@@ -67,4 +72,5 @@ { type: Injectable, args: [{ | ||
{ type: HeightEventService }, | ||
{ type: ElementsManagementService } | ||
{ type: ElementsManagementService }, | ||
{ type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3JmeC1zY3JvbGwtYW5pbWF0aW9uL3NyYy9saWIvc2VydmljZXMvcmZ4LXNjcm9sbC1hbmltYXRpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLCtCQUErQixDQUFDOzs7Ozs7QUFNMUUsTUFBTSxPQUFPLHlCQUF5QjtJQUNwQyxZQUNVLGtCQUFzQyxFQUN0QyxrQkFBc0MsRUFDdEMsa0JBQXNDLEVBQ3RDLHlCQUFvRDtRQUhwRCx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQW9CO1FBQ3RDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFDdEMsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFvQjtRQUN0Qyw4QkFBeUIsR0FBekIseUJBQXlCLENBQTJCO0lBQzFELENBQUM7SUFFRSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRDs7T0FFRztJQUNLLGdCQUFnQjtRQUN0QixJQUFJLENBQUMsa0JBQWtCLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDMUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQzFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxhQUFhLENBQUMsVUFBa0MsUUFBUTtRQUM3RCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUN4QixJQUFJLENBQUMsa0JBQWtCLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2hELElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN6QyxJQUFJLENBQUMsa0JBQWtCLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFFRDs7O09BR0c7SUFDSSxLQUFLO1FBQ1YsTUFBTSxrQkFBa0IsR0FBMkIsSUFBSSxDQUFDLHlCQUF5QixDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRWhHLEtBQUssTUFBTSxpQkFBaUIsSUFBSSxrQkFBa0IsRUFBRTtZQUNsRCxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDbkM7SUFDSCxDQUFDOzs7O1lBL0NGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBUlEsa0JBQWtCO1lBQ2xCLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIseUJBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNjcm9sbEV2ZW50U2VydmljZSB9IGZyb20gJy4vc2Nyb2xsLWV2ZW50LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBSZXNpemVFdmVudFNlcnZpY2UgfSBmcm9tICcuL3Jlc2l6ZS1ldmVudC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgSGVpZ2h0RXZlbnRTZXJ2aWNlIH0gZnJvbSAnLi9oZWlnaHQtZXZlbnQuc2VydmljZSc7XHJcbmltcG9ydCB7IEVsZW1lbnRzTWFuYWdlbWVudFNlcnZpY2UgfSBmcm9tICcuL2VsZW1lbnRzLW1hbmFnZW1lbnQuc2VydmljZSc7XHJcbmltcG9ydCB7IEFuaW1hdGVkRWxlbWVudE1vZGVsIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFJmeFNjcm9sbEFuaW1hdGlvblNlcnZpY2UgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBzY3JvbGxFdmVudFNlcnZpY2U6IFNjcm9sbEV2ZW50U2VydmljZSxcclxuICAgIHByaXZhdGUgcmVzaXplRXZlbnRTZXJ2aWNlOiBSZXNpemVFdmVudFNlcnZpY2UsXHJcbiAgICBwcml2YXRlIGhlaWdodEV2ZW50U2VydmljZTogSGVpZ2h0RXZlbnRTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBlbGVtZW50c01hbmFnZW1lbnRTZXJ2aWNlOiBFbGVtZW50c01hbmFnZW1lbnRTZXJ2aWNlXHJcbiAgKSB7IH1cclxuXHJcbiAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy5kZXN0cm95TGlzdGVuZXJzKCk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBEZXN0cm95IGFsbCBsaXN0ZW5lcnMuXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBkZXN0cm95TGlzdGVuZXJzKCk6IHZvaWQge1xyXG4gICAgdGhpcy5yZXNpemVFdmVudFNlcnZpY2UuZGVzdHJveUxpc3RlbmVyKCk7XHJcbiAgICB0aGlzLnNjcm9sbEV2ZW50U2VydmljZS5kZXN0cm95TGlzdGVuZXIoKTtcclxuICAgIHRoaXMuaGVpZ2h0RXZlbnRTZXJ2aWNlLmRlc3Ryb3lMaXN0ZW5lcigpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogRGVzdHJveSBhbGwgZXh0aXN0aW5nIGxpc3RlbmVycyBhbmQgdGhlbiBjcmVhdGUgbmV3IGxpc3RlbmVycy5cclxuICAgKiBJbml0aWFsaXplIG1vdXNlIHNjcm9sbCwgYm9keSBoZWlnaHQgYW5kIGhlaWdodCBjaGFuZ2UgbGlzdGVuZXJzLlxyXG4gICAqIERlZmF1bHQgYm9keSBlbGVtZW50IGlzIHRoZSBkb2N1bWVudCBlbGVtZW50LlxyXG4gICAqIEBwYXJhbSB7SFRNTEVsZW1lbnR9IGVsZW1lbnQgLSBTY3JvbGwgZWxlbWVudCB0byB1c2UuXHJcbiAgICovXHJcbiAgcHVibGljIGluaXRMaXN0ZW5lcnMoZWxlbWVudDogSFRNTEVsZW1lbnQgfCBEb2N1bWVudCA9IGRvY3VtZW50KTogdm9pZCB7XHJcbiAgICB0aGlzLmRlc3Ryb3lMaXN0ZW5lcnMoKTtcclxuICAgIHRoaXMuc2Nyb2xsRXZlbnRTZXJ2aWNlLmNyZWF0ZUxpc3RlbmVyKGVsZW1lbnQpO1xyXG4gICAgdGhpcy5yZXNpemVFdmVudFNlcnZpY2UuY3JlYXRlTGlzdGVuZXIoKTtcclxuICAgIHRoaXMuaGVpZ2h0RXZlbnRTZXJ2aWNlLmNyZWF0ZUxpc3RlbmVyKGVsZW1lbnQpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmVzZXQgYWxsIGVsZW1lbnRzIHBvc2l0aW9ucy5cclxuICAgKiBVc2VmdWwgd2hlbiB5b3Ugd2FudCB0byByZXNldCBhbGwgZWxlbWVudHMgdG8gdGhlaXIgb3JpZ2luYWwgcG9zaXRpb24uXHJcbiAgICovXHJcbiAgcHVibGljIHJlc2V0KCk6IHZvaWQge1xyXG4gICAgY29uc3QgcmVnaXN0ZXJlZEVsZW1lbnRzOiBBbmltYXRlZEVsZW1lbnRNb2RlbFtdID0gdGhpcy5lbGVtZW50c01hbmFnZW1lbnRTZXJ2aWNlLmdldEVsZW1lbnRzKCk7XHJcblxyXG4gICAgZm9yIChjb25zdCByZWdpc3RlcmVkRWxlbWVudCBvZiByZWdpc3RlcmVkRWxlbWVudHMpIHtcclxuICAgICAgcmVnaXN0ZXJlZEVsZW1lbnQuZWxlbWVudC5yZXNldCgpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3JmeC1zY3JvbGwtYW5pbWF0aW9uL3NyYy9saWIvc2VydmljZXMvcmZ4LXNjcm9sbC1hbmltYXRpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBYSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFMUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7Ozs7OztBQUtwRCxNQUFNLE9BQU8seUJBQXlCO0lBR3BDLFlBQ1Usa0JBQXNDLEVBQ3RDLGtCQUFzQyxFQUN0QyxrQkFBc0MsRUFDdEMseUJBQW9ELEVBQy9CLFVBQWtCO1FBSnZDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFDdEMsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFvQjtRQUN0Qyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQW9CO1FBQ3RDLDhCQUF5QixHQUF6Qix5QkFBeUIsQ0FBMkI7UUFDL0IsZUFBVSxHQUFWLFVBQVUsQ0FBUTtRQUUvQyxJQUFJLENBQUMsU0FBUyxHQUFHLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQ7O09BRUc7SUFDSyxnQkFBZ0I7UUFDdEIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQzFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUMxQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDNUMsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0ksYUFBYSxDQUFDLE9BQTJDO1FBQzlELElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBRXhCLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNsQixJQUFJLENBQUMsa0JBQWtCLENBQUMsY0FBYyxDQUFDLE9BQU8sYUFBUCxPQUFPLGNBQVAsT0FBTyxHQUFJLFFBQVEsQ0FBQyxDQUFDO1lBQzVELElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN6QyxJQUFJLENBQUMsa0JBQWtCLENBQUMsY0FBYyxDQUFDLE9BQU8sYUFBUCxPQUFPLGNBQVAsT0FBTyxHQUFJLFFBQVEsQ0FBQyxDQUFDO1NBQzdEO0lBQ0gsQ0FBQztJQUVEOzs7T0FHRztJQUNJLEtBQUs7UUFDVixNQUFNLGtCQUFrQixHQUEyQixJQUFJLENBQUMseUJBQXlCLENBQUMsV0FBVyxFQUFFLENBQUM7UUFFaEcsS0FBSyxNQUFNLGlCQUFpQixJQUFJLGtCQUFrQixFQUFFO1lBQ2xELGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNuQztJQUNILENBQUM7Ozs7WUF2REYsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7WUFUUSxrQkFBa0I7WUFDbEIsa0JBQWtCO1lBQ2xCLGtCQUFrQjtZQUNsQix5QkFBeUI7WUFlVyxNQUFNLHVCQUE5QyxNQUFNLFNBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgT25EZXN0cm95LCBQTEFURk9STV9JRCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTY3JvbGxFdmVudFNlcnZpY2UgfSBmcm9tICcuL3Njcm9sbC1ldmVudC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgUmVzaXplRXZlbnRTZXJ2aWNlIH0gZnJvbSAnLi9yZXNpemUtZXZlbnQuc2VydmljZSc7XHJcbmltcG9ydCB7IEhlaWdodEV2ZW50U2VydmljZSB9IGZyb20gJy4vaGVpZ2h0LWV2ZW50LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBFbGVtZW50c01hbmFnZW1lbnRTZXJ2aWNlIH0gZnJvbSAnLi9lbGVtZW50cy1tYW5hZ2VtZW50LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBBbmltYXRlZEVsZW1lbnRNb2RlbCB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFJmeFNjcm9sbEFuaW1hdGlvblNlcnZpY2UgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xyXG4gIHByaXZhdGUgaXNCcm93c2VyOiBib29sZWFuO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgc2Nyb2xsRXZlbnRTZXJ2aWNlOiBTY3JvbGxFdmVudFNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJlc2l6ZUV2ZW50U2VydmljZTogUmVzaXplRXZlbnRTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBoZWlnaHRFdmVudFNlcnZpY2U6IEhlaWdodEV2ZW50U2VydmljZSxcclxuICAgIHByaXZhdGUgZWxlbWVudHNNYW5hZ2VtZW50U2VydmljZTogRWxlbWVudHNNYW5hZ2VtZW50U2VydmljZSxcclxuICAgIEBJbmplY3QoUExBVEZPUk1fSUQpIHByaXZhdGUgcGxhdGZvcm1JZDogT2JqZWN0XHJcbiAgKSB7XHJcbiAgICB0aGlzLmlzQnJvd3NlciA9IGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLmRlc3Ryb3lMaXN0ZW5lcnMoKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIERlc3Ryb3kgYWxsIGxpc3RlbmVycy5cclxuICAgKi9cclxuICBwcml2YXRlIGRlc3Ryb3lMaXN0ZW5lcnMoKTogdm9pZCB7XHJcbiAgICB0aGlzLnJlc2l6ZUV2ZW50U2VydmljZS5kZXN0cm95TGlzdGVuZXIoKTtcclxuICAgIHRoaXMuc2Nyb2xsRXZlbnRTZXJ2aWNlLmRlc3Ryb3lMaXN0ZW5lcigpO1xyXG4gICAgdGhpcy5oZWlnaHRFdmVudFNlcnZpY2UuZGVzdHJveUxpc3RlbmVyKCk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBEZXN0cm95IGFsbCBleHRpc3RpbmcgbGlzdGVuZXJzIGFuZCB0aGVuIGNyZWF0ZSBuZXcgbGlzdGVuZXJzLlxyXG4gICAqIEluaXRpYWxpemUgbW91c2Ugc2Nyb2xsLCBib2R5IGhlaWdodCBhbmQgaGVpZ2h0IGNoYW5nZSBsaXN0ZW5lcnMuXHJcbiAgICogRGVmYXVsdCBib2R5IGVsZW1lbnQgaXMgdGhlIGRvY3VtZW50IGVsZW1lbnQuXHJcbiAgICogQHBhcmFtIHtIVE1MRWxlbWVudCB8IERvY3VtZW50IHwgdW5kZWZpbmVkfSBlbGVtZW50IC0gU2Nyb2xsIGVsZW1lbnQgdG8gdXNlLlxyXG4gICAqL1xyXG4gIHB1YmxpYyBpbml0TGlzdGVuZXJzKGVsZW1lbnQ6IEhUTUxFbGVtZW50IHwgRG9jdW1lbnQgfCB1bmRlZmluZWQpOiB2b2lkIHtcclxuICAgIHRoaXMuZGVzdHJveUxpc3RlbmVycygpO1xyXG5cclxuICAgIGlmICh0aGlzLmlzQnJvd3Nlcikge1xyXG4gICAgICB0aGlzLnNjcm9sbEV2ZW50U2VydmljZS5jcmVhdGVMaXN0ZW5lcihlbGVtZW50ID8/IGRvY3VtZW50KTtcclxuICAgICAgdGhpcy5yZXNpemVFdmVudFNlcnZpY2UuY3JlYXRlTGlzdGVuZXIoKTtcclxuICAgICAgdGhpcy5oZWlnaHRFdmVudFNlcnZpY2UuY3JlYXRlTGlzdGVuZXIoZWxlbWVudCA/PyBkb2N1bWVudCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXNldCBhbGwgZWxlbWVudHMgcG9zaXRpb25zLlxyXG4gICAqIFVzZWZ1bCB3aGVuIHlvdSB3YW50IHRvIHJlc2V0IGFsbCBlbGVtZW50cyB0byB0aGVpciBvcmlnaW5hbCBwb3NpdGlvbi5cclxuICAgKi9cclxuICBwdWJsaWMgcmVzZXQoKTogdm9pZCB7XHJcbiAgICBjb25zdCByZWdpc3RlcmVkRWxlbWVudHM6IEFuaW1hdGVkRWxlbWVudE1vZGVsW10gPSB0aGlzLmVsZW1lbnRzTWFuYWdlbWVudFNlcnZpY2UuZ2V0RWxlbWVudHMoKTtcclxuXHJcbiAgICBmb3IgKGNvbnN0IHJlZ2lzdGVyZWRFbGVtZW50IG9mIHJlZ2lzdGVyZWRFbGVtZW50cykge1xyXG4gICAgICByZWdpc3RlcmVkRWxlbWVudC5lbGVtZW50LnJlc2V0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ== |
import * as i0 from '@angular/core'; | ||
import { Injectable, EventEmitter, Component, ElementRef, Renderer2, Input, Output, HostBinding, NgModule } from '@angular/core'; | ||
import { Injectable, Inject, PLATFORM_ID, EventEmitter, Component, ElementRef, Renderer2, Input, Output, HostBinding, NgModule } from '@angular/core'; | ||
import { BrowserModule } from '@angular/platform-browser'; | ||
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; | ||
import { BehaviorSubject, Subject } from 'rxjs'; | ||
import { isPlatformBrowser } from '@angular/common'; | ||
import { trigger, state, style, transition, animate } from '@angular/animations'; | ||
@@ -237,3 +238,3 @@ | ||
class RfxScrollAnimationService { | ||
constructor(scrollEventService, resizeEventService, heightEventService, elementsManagementService) { | ||
constructor(scrollEventService, resizeEventService, heightEventService, elementsManagementService, platformId) { | ||
this.scrollEventService = scrollEventService; | ||
@@ -243,2 +244,4 @@ this.resizeEventService = resizeEventService; | ||
this.elementsManagementService = elementsManagementService; | ||
this.platformId = platformId; | ||
this.isBrowser = isPlatformBrowser(this.platformId); | ||
} | ||
@@ -260,9 +263,11 @@ ngOnDestroy() { | ||
* Default body element is the document element. | ||
* @param {HTMLElement} element - Scroll element to use. | ||
* @param {HTMLElement | Document | undefined} element - Scroll element to use. | ||
*/ | ||
initListeners(element = document) { | ||
initListeners(element) { | ||
this.destroyListeners(); | ||
this.scrollEventService.createListener(element); | ||
this.resizeEventService.createListener(); | ||
this.heightEventService.createListener(element); | ||
if (this.isBrowser) { | ||
this.scrollEventService.createListener(element !== null && element !== void 0 ? element : document); | ||
this.resizeEventService.createListener(); | ||
this.heightEventService.createListener(element !== null && element !== void 0 ? element : document); | ||
} | ||
} | ||
@@ -280,3 +285,3 @@ /** | ||
} | ||
RfxScrollAnimationService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RfxScrollAnimationService_Factory() { return new RfxScrollAnimationService(i0.ɵɵinject(ScrollEventService), i0.ɵɵinject(ResizeEventService), i0.ɵɵinject(HeightEventService), i0.ɵɵinject(ElementsManagementService)); }, token: RfxScrollAnimationService, providedIn: "root" }); | ||
RfxScrollAnimationService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RfxScrollAnimationService_Factory() { return new RfxScrollAnimationService(i0.ɵɵinject(ScrollEventService), i0.ɵɵinject(ResizeEventService), i0.ɵɵinject(HeightEventService), i0.ɵɵinject(ElementsManagementService), i0.ɵɵinject(i0.PLATFORM_ID)); }, token: RfxScrollAnimationService, providedIn: "root" }); | ||
RfxScrollAnimationService.decorators = [ | ||
@@ -291,3 +296,4 @@ { type: Injectable, args: [{ | ||
{ type: HeightEventService }, | ||
{ type: ElementsManagementService } | ||
{ type: ElementsManagementService }, | ||
{ type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] } | ||
]; | ||
@@ -328,3 +334,3 @@ | ||
class RfxScrollAnimationComponent { | ||
constructor(htmlElement, renderer, scrollEventService, heightEventService, resizeEventService, elementsManagementService) { | ||
constructor(htmlElement, renderer, scrollEventService, heightEventService, resizeEventService, elementsManagementService, platformId) { | ||
this.htmlElement = htmlElement; | ||
@@ -336,2 +342,3 @@ this.renderer = renderer; | ||
this.elementsManagementService = elementsManagementService; | ||
this.platformId = platformId; | ||
this.animationType = AnimationTypeEnum.NONE; | ||
@@ -352,2 +359,3 @@ this.animationDistancePx = 25; | ||
this.elementIndex = this.elementsManagementService.registerElement(this); | ||
this.isBrowser = isPlatformBrowser(platformId); | ||
} | ||
@@ -370,3 +378,5 @@ /** | ||
ngAfterViewInit() { | ||
this.createListeners(); | ||
if (this.isBrowser) { | ||
this.createListeners(); | ||
} | ||
this.subscribeToElementsReadyEvent(); | ||
@@ -440,3 +450,8 @@ this.elementsManagementService.setElementReady(this.elementIndex); | ||
this.isPageReady = true; | ||
this.calculateElementProperties(); | ||
if (this.isBrowser) { | ||
this.calculateElementProperties(); | ||
} | ||
else { | ||
this.setVisibility(AnimationVisibilityEnum.VISIBLE); | ||
} | ||
} | ||
@@ -603,3 +618,4 @@ }); | ||
{ type: ResizeEventService }, | ||
{ type: ElementsManagementService } | ||
{ type: ElementsManagementService }, | ||
{ type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] } | ||
]; | ||
@@ -606,0 +622,0 @@ RfxScrollAnimationComponent.propDecorators = { |
@@ -11,2 +11,3 @@ import { AfterViewInit, ElementRef, EventEmitter, OnChanges, OnDestroy, Renderer2, SimpleChanges } from '@angular/core'; | ||
private elementsManagementService; | ||
private platformId; | ||
/** | ||
@@ -134,6 +135,12 @@ * Element animation type. | ||
/** | ||
* Is platform browser. | ||
* False for example when using SSR. | ||
* @type {boolean} | ||
*/ | ||
private isBrowser; | ||
/** | ||
* Bind visibility animation to host element. | ||
*/ | ||
get visibility(): AnimationExpInterface | null; | ||
constructor(htmlElement: ElementRef, renderer: Renderer2, scrollEventService: ScrollEventService, heightEventService: HeightEventService, resizeEventService: ResizeEventService, elementsManagementService: ElementsManagementService); | ||
constructor(htmlElement: ElementRef, renderer: Renderer2, scrollEventService: ScrollEventService, heightEventService: HeightEventService, resizeEventService: ResizeEventService, elementsManagementService: ElementsManagementService, platformId: Object); | ||
ngAfterViewInit(): void; | ||
@@ -140,0 +147,0 @@ ngOnChanges(changes: SimpleChanges): void; |
@@ -11,3 +11,5 @@ import { OnDestroy } from '@angular/core'; | ||
private elementsManagementService; | ||
constructor(scrollEventService: ScrollEventService, resizeEventService: ResizeEventService, heightEventService: HeightEventService, elementsManagementService: ElementsManagementService); | ||
private platformId; | ||
private isBrowser; | ||
constructor(scrollEventService: ScrollEventService, resizeEventService: ResizeEventService, heightEventService: HeightEventService, elementsManagementService: ElementsManagementService, platformId: Object); | ||
ngOnDestroy(): void; | ||
@@ -22,5 +24,5 @@ /** | ||
* Default body element is the document element. | ||
* @param {HTMLElement} element - Scroll element to use. | ||
* @param {HTMLElement | Document | undefined} element - Scroll element to use. | ||
*/ | ||
initListeners(element?: HTMLElement | Document): void; | ||
initListeners(element: HTMLElement | Document | undefined): void; | ||
/** | ||
@@ -27,0 +29,0 @@ * Reset all elements positions. |
{ | ||
"name": "rfx-scroll-animation", | ||
"version": "3.4.0", | ||
"version": "3.5.0", | ||
"description": "RfxScrollAnimation - animate your page elements on scroll", | ||
@@ -5,0 +5,0 @@ "author": { |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"RfxScrollAnimationModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"BrowserModule","line":10,"character":4},{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":11,"character":4}],"exports":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}]}]}],"members":{}},"RfxScrollAnimationService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":7,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"},{"__symbolic":"reference","name":"ɵh"},{"__symbolic":"reference","name":"ɵi"}]}],"ngOnDestroy":[{"__symbolic":"method"}],"destroyListeners":[{"__symbolic":"method"}],"initListeners":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"RfxScrollAnimationComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":7,"character":1},"arguments":[{"selector":"[libRfxScrollAnimation]","animations":[{"__symbolic":"reference","name":"ɵa"}],"template":"<ng-content></ng-content>\r\n","styles":[":host{will-change:transform,opacity}\n"]}]}],"members":{"animationType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":22,"character":3}}]}],"animationDistancePx":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":3}}]}],"scaleRatio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"transitionDurationMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":50,"character":3}}]}],"transitionDelayMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":3}}]}],"transitionTimingFunction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"distanceFromPageBottomPercentage":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":3}}]}],"isOnlyFirstTime":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":84,"character":3}}]}],"elementVisibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":91,"character":3}}]}],"visibility":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":170,"character":3},"arguments":["@visibility"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":185,"character":25},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":186,"character":22},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListeners":[{"__symbolic":"method"}],"destroyListeners":[{"__symbolic":"method"}],"subscribeToResizeEvent":[{"__symbolic":"method"}],"subscribeToHeightEvent":[{"__symbolic":"method"}],"subscribeToScrollEvent":[{"__symbolic":"method"}],"subscribeToElementsReadyEvent":[{"__symbolic":"method"}],"calculateElementProperties":[{"__symbolic":"method"}],"getWillChangeArea":[{"__symbolic":"method"}],"getVisibilityBarrier":[{"__symbolic":"method"}],"getCurrentTransform":[{"__symbolic":"method"}],"onScrollEvent":[{"__symbolic":"method"}],"getVisibility":[{"__symbolic":"method"}],"setVisibility":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"setWillChange":[{"__symbolic":"method"}],"isElementInArea":[{"__symbolic":"method"}]}},"AnimationTypeEnum":{"NONE":"none","TOP":"top","BOTTOM":"bottom","RIGHT":"right","LEFT":"left","ZOOM":"zoom"},"AnimationVisibilityEnum":{"VISIBLE":"visible","HIDDEN":"hidden"},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListener":[{"__symbolic":"method"}],"destroyListener":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}],"getMouseScroll":[{"__symbolic":"method"}],"getMouseScrollValue":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListener":[{"__symbolic":"method"}],"destroyListener":[{"__symbolic":"method"}],"onResizeEvent":[{"__symbolic":"method"}],"getResize":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"ɵh":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListener":[{"__symbolic":"method"}],"destroyListener":[{"__symbolic":"method"}],"onHeightEvent":[{"__symbolic":"method"}],"getHeight":[{"__symbolic":"method"}],"getHeightValue":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"ɵi":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":5,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"onElementsReady":[{"__symbolic":"method"}],"getElementsReady":[{"__symbolic":"method"}],"registerElement":[{"__symbolic":"method"}],"setElementReady":[{"__symbolic":"method"}],"getElements":[{"__symbolic":"method"}],"checkElementsReady":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}}},"origins":{"RfxScrollAnimationModule":"./lib/rfx-scroll-animation.module","RfxScrollAnimationService":"./lib/services/rfx-scroll-animation.service","RfxScrollAnimationComponent":"./lib/components/rfx-scroll-animation/rfx-scroll-animation.component","AnimationTypeEnum":"./lib/models/animation-type.enum","AnimationVisibilityEnum":"./lib/models/animation-visiblity.enum","ɵa":"./lib/animations","ɵb":"./lib/services","ɵc":"./lib/services","ɵd":"./lib/services","ɵe":"./lib/services","ɵf":"./lib/services/scroll-event.service","ɵg":"./lib/services/resize-event.service","ɵh":"./lib/services/height-event.service","ɵi":"./lib/services/elements-management.service"},"importAs":"rfx-scroll-animation"} | ||
{"__symbolic":"module","version":4,"metadata":{"RfxScrollAnimationModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"BrowserModule","line":10,"character":4},{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":11,"character":4}],"exports":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}]}]}],"members":{}},"RfxScrollAnimationService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":8,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":19,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":19,"character":12}]}]],"parameters":[{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"},{"__symbolic":"reference","name":"ɵh"},{"__symbolic":"reference","name":"ɵi"},{"__symbolic":"reference","name":"Object"}]}],"ngOnDestroy":[{"__symbolic":"method"}],"destroyListeners":[{"__symbolic":"method"}],"initListeners":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"RfxScrollAnimationComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":8,"character":1},"arguments":[{"selector":"[libRfxScrollAnimation]","animations":[{"__symbolic":"reference","name":"ɵa"}],"template":"<ng-content></ng-content>\r\n","styles":[":host{will-change:transform,opacity}\n"]}]}],"members":{"animationType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3}}]}],"animationDistancePx":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"scaleRatio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":41,"character":3}}]}],"transitionDurationMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":3}}]}],"transitionDelayMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":61,"character":3}}]}],"transitionTimingFunction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":69,"character":3}}]}],"distanceFromPageBottomPercentage":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":77,"character":3}}]}],"isOnlyFirstTime":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":85,"character":3}}]}],"elementVisibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":92,"character":3}}]}],"visibility":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":178,"character":3},"arguments":["@visibility"]}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":199,"character":5},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":199,"character":12}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":193,"character":25},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":194,"character":22},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"Object"}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListeners":[{"__symbolic":"method"}],"destroyListeners":[{"__symbolic":"method"}],"subscribeToResizeEvent":[{"__symbolic":"method"}],"subscribeToHeightEvent":[{"__symbolic":"method"}],"subscribeToScrollEvent":[{"__symbolic":"method"}],"subscribeToElementsReadyEvent":[{"__symbolic":"method"}],"calculateElementProperties":[{"__symbolic":"method"}],"getWillChangeArea":[{"__symbolic":"method"}],"getVisibilityBarrier":[{"__symbolic":"method"}],"getCurrentTransform":[{"__symbolic":"method"}],"onScrollEvent":[{"__symbolic":"method"}],"getVisibility":[{"__symbolic":"method"}],"setVisibility":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"setWillChange":[{"__symbolic":"method"}],"isElementInArea":[{"__symbolic":"method"}]}},"AnimationTypeEnum":{"NONE":"none","TOP":"top","BOTTOM":"bottom","RIGHT":"right","LEFT":"left","ZOOM":"zoom"},"AnimationVisibilityEnum":{"VISIBLE":"visible","HIDDEN":"hidden"},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListener":[{"__symbolic":"method"}],"destroyListener":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}],"getMouseScroll":[{"__symbolic":"method"}],"getMouseScrollValue":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListener":[{"__symbolic":"method"}],"destroyListener":[{"__symbolic":"method"}],"onResizeEvent":[{"__symbolic":"method"}],"getResize":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"ɵh":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":3,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnDestroy":[{"__symbolic":"method"}],"createListener":[{"__symbolic":"method"}],"destroyListener":[{"__symbolic":"method"}],"onHeightEvent":[{"__symbolic":"method"}],"getHeight":[{"__symbolic":"method"}],"getHeightValue":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"ɵi":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":5,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"onElementsReady":[{"__symbolic":"method"}],"getElementsReady":[{"__symbolic":"method"}],"registerElement":[{"__symbolic":"method"}],"setElementReady":[{"__symbolic":"method"}],"getElements":[{"__symbolic":"method"}],"checkElementsReady":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}}},"origins":{"RfxScrollAnimationModule":"./lib/rfx-scroll-animation.module","RfxScrollAnimationService":"./lib/services/rfx-scroll-animation.service","RfxScrollAnimationComponent":"./lib/components/rfx-scroll-animation/rfx-scroll-animation.component","AnimationTypeEnum":"./lib/models/animation-type.enum","AnimationVisibilityEnum":"./lib/models/animation-visiblity.enum","ɵa":"./lib/animations","ɵb":"./lib/services","ɵc":"./lib/services","ɵd":"./lib/services","ɵe":"./lib/services","ɵf":"./lib/services/scroll-event.service","ɵg":"./lib/services/resize-event.service","ɵh":"./lib/services/height-event.service","ɵi":"./lib/services/elements-management.service"},"importAs":"rfx-scroll-animation"} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
322657
2866