UNPKG

vexip-ui

Version:

A Vue 3 UI library, Highly customizability, full TypeScript, performance pretty good

408 lines (407 loc) 24.6 kB
import { ScrollbarExposed } from '../scrollbar'; import { EventHandler } from '@vexip-ui/utils'; declare function getState(): { scrollX: number; scrollY: number; percentX: number; percentY: number; enableXScroll: boolean; enableYScroll: boolean; }; declare function scrollTo(clientX: number, clientY: number, duration?: number): Promise<void>; declare function scrollBy(deltaX: number, deltaY: number, duration?: number): Promise<void>; declare function scrollToElement(el: string | Element, duration?: number, offset?: number): Promise<void>; declare function ensureInView(el: string | Element, duration?: number, offset?: number): Promise<void>; declare function getXScrollLimit(): number[]; declare function getYScrollLimit(): number[]; declare function addScrollListener(listener: EventHandler): void; declare function removeScrollListener(listener: EventHandler): void; declare function __VLS_template(): { attrs: Partial<{}>; slots: { extra?(_: { getState: typeof getState; refresh: () => Promise<void>; scrollTo: typeof scrollTo; scrollBy: typeof scrollBy; scrollToElement: typeof scrollToElement; ensureInView: typeof ensureInView; }): any; default?(_: { getState: typeof getState; refresh: () => Promise<void>; scrollTo: typeof scrollTo; scrollBy: typeof scrollBy; scrollToElement: typeof scrollToElement; ensureInView: typeof ensureInView; }): any; }; refs: { wrapperEl: HTMLDivElement; contentEl: unknown; xBar: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, { container: HTMLDivElement; track: HTMLDivElement; bar: HTMLDivElement; }, HTMLDivElement, import('vue').ComponentProvideOptions, { P: {}; B: {}; D: {}; C: {}; M: {}; Defaults: {}; }, Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, {}> | null; yBar: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, { container: HTMLDivElement; track: HTMLDivElement; bar: HTMLDivElement; }, HTMLDivElement, import('vue').ComponentProvideOptions, { P: {}; B: {}; D: {}; C: {}; M: {}; Defaults: {}; }, Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, {}> | null; }; rootEl: HTMLDivElement; }; type __VLS_TemplateResult = ReturnType<typeof __VLS_template>; declare const __VLS_component: import('vue').DefineComponent<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; scrollClass: import('vue').PropType<string | Record<string, any> | (string | Record<string, any>)[]>; scrollStyle: import('vue').PropType<string | import('vue').CSSProperties | (string | import('vue').CSSProperties)[]>; scrollAttrs: import('vue').PropType<Record<string, any>>; mode: import('vue').PropType<"horizontal" | "vertical" | "both" | "horizontal-exact">; width: import('vue').PropType<string | number>; height: import('vue').PropType<string | number>; deltaX: import('vue').PropType<number>; deltaY: import('vue').PropType<number>; disabled: import('vue').PropType<boolean>; pointer: import('vue').PropType<boolean>; wheel: import('vue').PropType<boolean>; scrollX: import('vue').PropType<number>; scrollY: import('vue').PropType<number>; useXBar: import('vue').PropType<boolean>; useYBar: import('vue').PropType<boolean>; barFade: import('vue').PropType<number>; barClass: import('vue').PropType<string | Record<string, any> | (string | Record<string, any>)[]>; autoplay: import('vue').PropType<number | boolean>; playWaiting: import('vue').PropType<number>; noBuffer: import('vue').PropType<boolean>; noTransition: import('vue').PropType<boolean>; onBeforeScroll: import('vue').PropType<(payload: { signX: number; signY: number; }) => boolean>; useBarTrack: import('vue').PropType<boolean>; scrollTag: import('vue').PropType<string>; onResize: import('vue').PropType<((entry: ResizeObserverEntry) => void) | ((entry: ResizeObserverEntry) => void)[]>; onXEnabledChange: import('vue').PropType<((enabled: boolean) => void) | ((enabled: boolean) => void)[]>; onYEnabledChange: import('vue').PropType<((enabled: boolean) => void) | ((enabled: boolean) => void)[]>; onWheel: import('vue').PropType<((payload: import('./symbol').BarScrollPayload & { sign: 1 | -1; }) => void) | ((payload: import('./symbol').BarScrollPayload & { sign: 1 | -1; }) => void)[]>; onScrollStart: import('vue').PropType<((payload: Omit<import('./symbol').ScrollPayload, "type">) => void) | ((payload: Omit<import('./symbol').ScrollPayload, "type">) => void)[]>; onScroll: import('vue').PropType<((payload: import('./symbol').ScrollPayload) => void) | ((payload: import('./symbol').ScrollPayload) => void)[]>; onScrollEnd: import('vue').PropType<((payload: Omit<import('./symbol').ScrollPayload, "type">) => void) | ((payload: Omit<import('./symbol').ScrollPayload, "type">) => void)[]>; onBarScrollStart: import('vue').PropType<((payload: import('./symbol').BarScrollPayload) => void) | ((payload: import('./symbol').BarScrollPayload) => void)[]>; onBarScroll: import('vue').PropType<((payload: import('./symbol').BarScrollPayload) => void) | ((payload: import('./symbol').BarScrollPayload) => void)[]>; onBarScrollEnd: import('vue').PropType<((payload: import('./symbol').BarScrollPayload) => void) | ((payload: import('./symbol').BarScrollPayload) => void)[]>; onReady: import('vue').PropType<import('@vexip-ui/config').AnyFunction | import('@vexip-ui/config').AnyFunction[]>; }>, { percentX: import('vue').Ref<number, number>; percentY: import('vue').Ref<number, number>; x: import('vue').Ref<number, number>; y: import('vue').Ref<number, number>; isReady: import('vue').Ref<boolean, boolean>; xBarLength: import('vue').ComputedRef<number>; yBarLength: import('vue').ComputedRef<number>; enableXScroll: import('vue').ComputedRef<boolean>; enableYScroll: import('vue').ComputedRef<boolean>; wrapper: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; content: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; xBar: import('vue').Ref<ScrollbarExposed | undefined, ScrollbarExposed | undefined>; yBar: import('vue').Ref<ScrollbarExposed | undefined, ScrollbarExposed | undefined>; refresh: () => Promise<void>; scrollTo: typeof scrollTo; scrollBy: typeof scrollBy; scrollToElement: typeof scrollToElement; ensureInView: typeof ensureInView; getXScrollLimit: typeof getXScrollLimit; getYScrollLimit: typeof getYScrollLimit; addScrollListener: typeof addScrollListener; removeScrollListener: typeof removeScrollListener; }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; scrollClass: import('vue').PropType<string | Record<string, any> | (string | Record<string, any>)[]>; scrollStyle: import('vue').PropType<string | import('vue').CSSProperties | (string | import('vue').CSSProperties)[]>; scrollAttrs: import('vue').PropType<Record<string, any>>; mode: import('vue').PropType<"horizontal" | "vertical" | "both" | "horizontal-exact">; width: import('vue').PropType<string | number>; height: import('vue').PropType<string | number>; deltaX: import('vue').PropType<number>; deltaY: import('vue').PropType<number>; disabled: import('vue').PropType<boolean>; pointer: import('vue').PropType<boolean>; wheel: import('vue').PropType<boolean>; scrollX: import('vue').PropType<number>; scrollY: import('vue').PropType<number>; useXBar: import('vue').PropType<boolean>; useYBar: import('vue').PropType<boolean>; barFade: import('vue').PropType<number>; barClass: import('vue').PropType<string | Record<string, any> | (string | Record<string, any>)[]>; autoplay: import('vue').PropType<number | boolean>; playWaiting: import('vue').PropType<number>; noBuffer: import('vue').PropType<boolean>; noTransition: import('vue').PropType<boolean>; onBeforeScroll: import('vue').PropType<(payload: { signX: number; signY: number; }) => boolean>; useBarTrack: import('vue').PropType<boolean>; scrollTag: import('vue').PropType<string>; onResize: import('vue').PropType<((entry: ResizeObserverEntry) => void) | ((entry: ResizeObserverEntry) => void)[]>; onXEnabledChange: import('vue').PropType<((enabled: boolean) => void) | ((enabled: boolean) => void)[]>; onYEnabledChange: import('vue').PropType<((enabled: boolean) => void) | ((enabled: boolean) => void)[]>; onWheel: import('vue').PropType<((payload: import('./symbol').BarScrollPayload & { sign: 1 | -1; }) => void) | ((payload: import('./symbol').BarScrollPayload & { sign: 1 | -1; }) => void)[]>; onScrollStart: import('vue').PropType<((payload: Omit<import('./symbol').ScrollPayload, "type">) => void) | ((payload: Omit<import('./symbol').ScrollPayload, "type">) => void)[]>; onScroll: import('vue').PropType<((payload: import('./symbol').ScrollPayload) => void) | ((payload: import('./symbol').ScrollPayload) => void)[]>; onScrollEnd: import('vue').PropType<((payload: Omit<import('./symbol').ScrollPayload, "type">) => void) | ((payload: Omit<import('./symbol').ScrollPayload, "type">) => void)[]>; onBarScrollStart: import('vue').PropType<((payload: import('./symbol').BarScrollPayload) => void) | ((payload: import('./symbol').BarScrollPayload) => void)[]>; onBarScroll: import('vue').PropType<((payload: import('./symbol').BarScrollPayload) => void) | ((payload: import('./symbol').BarScrollPayload) => void)[]>; onBarScrollEnd: import('vue').PropType<((payload: import('./symbol').BarScrollPayload) => void) | ((payload: import('./symbol').BarScrollPayload) => void)[]>; onReady: import('vue').PropType<import('@vexip-ui/config').AnyFunction | import('@vexip-ui/config').AnyFunction[]>; }>> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, { wrapperEl: HTMLDivElement; contentEl: unknown; xBar: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, { container: HTMLDivElement; track: HTMLDivElement; bar: HTMLDivElement; }, HTMLDivElement, import('vue').ComponentProvideOptions, { P: {}; B: {}; D: {}; C: {}; M: {}; Defaults: {}; }, Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, {}> | null; yBar: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, { container: HTMLDivElement; track: HTMLDivElement; bar: HTMLDivElement; }, HTMLDivElement, import('vue').ComponentProvideOptions, { P: {}; B: {}; D: {}; C: {}; M: {}; Defaults: {}; }, Readonly<import('vue').ExtractPropTypes<{ inherit: import('vue').PropType<boolean>; placement: import('vue').PropType<"bottom" | "top" | "right" | "left">; scroll: import('vue').PropType<number>; barLength: import('vue').PropType<number>; width: import('vue').PropType<number>; appear: import('vue').PropType<boolean>; fade: import('vue').PropType<number>; barColor: import('vue').PropType<string>; trackColor: import('vue').PropType<string>; disabled: import('vue').PropType<boolean>; wrapper: import('vue').PropType<string | HTMLElement>; duration: import('vue').PropType<number>; useTrack: import('vue').PropType<boolean>; trackSpeed: import('vue').PropType<number>; onScrollStart: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScroll: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; onScrollEnd: import('vue').PropType<((percent: number) => void) | ((percent: number) => void)[]>; }>> & Readonly<{}>, { currentScroll: import('vue').Ref<number, number>; container: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; bar: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; track: import('vue').Ref<HTMLElement | undefined, HTMLElement | undefined>; handleScroll: (scroll: number) => void; }, {}, {}, {}, {}> | null; }, HTMLDivElement>; declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>; export default _default; type __VLS_WithTemplateSlots<T, S> = T & { new (): { $slots: S; }; };