primevue-mirror/components/lib/animateonscroll/AnimateOnScroll.d.ts

107 lines
3.2 KiB
TypeScript

/**
*
* AnimateOnScroll manages PrimeFlex CSS classes declaratively to during enter/leave animations on scroll or on page load.
*
* [Live Demo](https://primevue.org/animateonscroll)
*
* @module animateonscroll
*/
import { DirectiveBinding, ObjectDirective } from 'vue';
import { DirectiveHooks } from '../basedirective/BaseDirective';
import { PassThroughOptions } from '../passthrough';
import { PassThrough } from '../ts-helpers';
/**
* Defines options of AnimateOnScroll.
*/
export interface AnimateOnScrollOptions {
/**
* AnimateOnScroll scroll to add when item begins to get displayed.
*/
enterClass?: string | undefined;
/**
* AnimateOnScroll scroll to add when item begins to get hidden.
*/
leaveClass?: string | undefined;
/**
* Specifies the `root` option of the IntersectionObserver API
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/IntersectionObserver/root)
*/
root?: Element | Document | null;
/**
* Specifies the `rootMargin` option of the IntersectionObserver API
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/IntersectionObserver/rootMargin)
*/
rootMargin?: string;
/**
* Specifies the `threshold` option of the IntersectionObserver API
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/IntersectionObserver/thresholds)
*/
threshold?: ReadonlyArray<number>;
/**
* Whether the `enterClass` animation will run if the target is in the viewport when the page is loaded.
*/
animateOnLoad?: boolean;
/**
* Used to pass attributes to DOM elements inside the component.
* @type {AnimateOnScrollDirectivePassThroughOptions}
*/
pt?: PassThrough<AnimateOnScrollDirectivePassThroughOptions>;
/**
* Used to configure passthrough(pt) options of the component.
* @type {PassThroughOptions}
*/
ptOptions?: PassThroughOptions;
}
/**
* Custom passthrough(pt) directive options.
*/
export interface AnimateOnScrollDirectivePassThroughOptions {
/**
* Used to manage all lifecycle hooks
* @see {@link BaseDirective.DirectiveHooks}
*/
hooks?: DirectiveHooks;
}
/**
* Defines modifiers of AnimateOnScroll.
*/
export interface AnimateOnScrollDirectiveModifiers {
/**
* Whether the scroll event listener should be removed after initial run.
* @defaultValue true
*/
once?: boolean | undefined;
}
/**
* Binding of AnimateOnScroll directive.
*/
export interface AnimateOnScrollDirectiveBinding extends Omit<DirectiveBinding, 'modifiers' | 'value'> {
/**
* Value of the AnimateOnScroll.
*/
value?: AnimateOnScrollOptions | undefined;
/**
* Modifiers of the tooltip.
* @type {AnimateOnScrollDirectiveModifiers}
*/
modifiers?: AnimateOnScrollDirectiveModifiers | undefined;
}
/**
* **PrimeVue - AnimateOnScroll**
*
* _AnimateOnScroll manages PrimeFlex CSS classes declaratively to during enter/leave animations on scroll or on page load._
*
* [Live Demo](https://www.primevue.org/animateonscroll/)
* --- ---
* ![PrimeVue](https://primefaces.org/cdn/primevue/images/logo-100.png)
*
*/
declare const AnimateOnScroll: ObjectDirective;
export default AnimateOnScroll;