From 13babf022d9eec4eb591d0648880a3c2f999db0b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=87etin?= <69278826+cetincakiroglu@users.noreply.github.com> Date: Tue, 3 Sep 2024 13:10:20 +0300 Subject: [PATCH] Remove pAnimate directive, fixes #16334 --- src/app/components/animate/animate.ts | 95 ---------------------- src/app/components/animate/ng-package.json | 6 -- src/app/components/animate/public_api.ts | 1 - 3 files changed, 102 deletions(-) delete mode 100644 src/app/components/animate/animate.ts delete mode 100644 src/app/components/animate/ng-package.json delete mode 100644 src/app/components/animate/public_api.ts diff --git a/src/app/components/animate/animate.ts b/src/app/components/animate/animate.ts deleted file mode 100644 index 40569336691..00000000000 --- a/src/app/components/animate/animate.ts +++ /dev/null @@ -1,95 +0,0 @@ -import { CommonModule } from '@angular/common'; -import { AfterViewInit, Directive, ElementRef, Input, NgModule, OnInit, Renderer2 } from '@angular/core'; -import { DomHandler } from 'primeng/dom'; -/** - * Animate manages PrimeFlex CSS classes declaratively to during enter/leave animations on scroll or on page load. - * @group Components - */ -@Directive({ - selector: '[pAnimate]', - host: { - '[class.p-animate]': 'true' - } -}) -export class Animate implements OnInit, AfterViewInit { - /** - * Selector to define the CSS class for enter animation. - * @group Props - */ - @Input() enterClass: string | undefined; - /** - * Selector to define the CSS class for leave animation. - * @group Props - */ - @Input() leaveClass: string | undefined; - - observer: IntersectionObserver | undefined; - - timeout: any; - - constructor( - private host: ElementRef, - public el: ElementRef, - public renderer: Renderer2 - ) {} - - ngOnInit() { - console.log('pAnimate directive is deprecated in 16.7.0 and will be removed in the future. Use pAnimateOnScroll directive instead'); - } - - ngAfterViewInit() { - this.bindIntersectionObserver(); - } - - bindIntersectionObserver() { - const options = { - root: null, - rootMargin: '0px', - threshold: 1.0 - }; - - this.observer = new IntersectionObserver((el) => this.isVisible(el), options); - this.observer.observe(this.host.nativeElement); - } - - isVisible(element: IntersectionObserverEntry[]) { - const [intersectionObserverEntry] = element; - intersectionObserverEntry.isIntersecting ? this.enter() : this.leave(); - } - - enter() { - this.host.nativeElement.style.visibility = 'visible'; - DomHandler.addClass(this.host.nativeElement, this.enterClass as string); - } - - leave() { - DomHandler.removeClass(this.host.nativeElement, this.enterClass as string); - if (this.leaveClass) { - DomHandler.addClass(this.host.nativeElement, this.leaveClass); - } - - const animationDuration = this.host.nativeElement.style.animationDuration || 500; - - this.timeout = setTimeout(() => { - this.host.nativeElement.style.visibility = 'hidden'; - }, animationDuration); - } - - unbindIntersectionObserver() { - if (this.observer) { - this.observer.unobserve(this.host.nativeElement); - } - } - - ngOnDestroy() { - this.unbindIntersectionObserver(); - clearTimeout(this.timeout); - } -} - -@NgModule({ - imports: [CommonModule], - exports: [Animate], - declarations: [Animate] -}) -export class AnimateModule {} diff --git a/src/app/components/animate/ng-package.json b/src/app/components/animate/ng-package.json deleted file mode 100644 index 0e529e387d7..00000000000 --- a/src/app/components/animate/ng-package.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "$schema": "ng-packagr/ng-package.schema.json", - "lib": { - "entryFile": "public_api.ts" - } -} \ No newline at end of file diff --git a/src/app/components/animate/public_api.ts b/src/app/components/animate/public_api.ts deleted file mode 100644 index 39b624b55c5..00000000000 --- a/src/app/components/animate/public_api.ts +++ /dev/null @@ -1 +0,0 @@ -export * from './animate';