Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

rfx-scroll-animation

Package Overview
Dependencies
Maintainers
1
Versions
30
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

rfx-scroll-animation - npm Package Compare versions

Comparing version 3.4.0 to 3.5.0

46

bundles/rfx-scroll-animation.umd.js
(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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc