vexip-ui
Version:
A Vue 3 UI library, Highly customizability, full TypeScript, performance pretty good
408 lines (407 loc) • 24.6 kB
TypeScript
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;
};
};