import { PropType, CSSProperties, HTMLAttributes, ExtractPropTypes } from 'vue';
export interface ScrollTo {
(x: number, y: number): void;
(options: {
left?: number;
top?: number;
behavior?: ScrollBehavior;
debounce?: boolean;
}): void;
(options: {
el: HTMLElement;
behavior?: ScrollBehavior;
debounce?: boolean;
}): void;
(options: {
index: number;
elSize: number;
behavior?: ScrollBehavior;
debounce?: boolean;
}): void;
(options: {
position: 'top' | 'bottom';
behavior?: ScrollBehavior;
debounce?: boolean;
}): void;
}
export interface ScrollBy {
(x: number, y: number): void;
(options: {
left?: number;
top?: number;
behavior?: ScrollBehavior;
}): void;
}
export interface ScrollbarInstMethods {
syncUnifiedContainer: () => void;
scrollTo: ScrollTo;
scrollBy: ScrollBy;
sync: () => void;
handleMouseEnterWrapper: () => void;
handleMouseLeaveWrapper: () => void;
}
export interface ScrollbarInst extends ScrollbarInstMethods {
$el: HTMLElement;
containerRef: HTMLElement | null;
contentRef: HTMLElement | null;
containerScrollTop: number;
}
declare type RemoveReadonly = {
-readonly [key in keyof T]: T[key];
};
export declare type ExtractPublicPropTypes = Omit>>, Extract>;
declare type ExtractInternalPropTypes = Partial>;
declare const scrollbarProps: {
readonly size: {
readonly type: NumberConstructor;
readonly default: 5;
};
readonly duration: {
readonly type: NumberConstructor;
readonly default: 0;
};
readonly scrollable: {
readonly type: BooleanConstructor;
readonly default: true;
};
readonly xScrollable: BooleanConstructor;
readonly trigger: {
readonly type: PropType<"none" | "hover">;
readonly default: "hover";
};
readonly useUnifiedContainer: BooleanConstructor;
readonly triggerDisplayManually: BooleanConstructor;
readonly container: PropType<() => HTMLElement | null | undefined>;
readonly content: PropType<() => HTMLElement | null | undefined>;
readonly containerClass: StringConstructor;
readonly containerStyle: PropType;
readonly contentClass: StringConstructor;
readonly contentStyle: PropType;
readonly horizontalRailStyle: PropType;
readonly verticalRailStyle: PropType;
readonly onScroll: PropType<(e: Event) => void>;
readonly onWheel: PropType<(e: WheelEvent) => void>;
readonly onResize: PropType<(e: ResizeObserverEntry) => void>;
readonly internalOnUpdateScrollLeft: PropType<(scrollLeft: number) => void>;
readonly internalHoistYRail: BooleanConstructor;
};
export declare type ScrollbarProps = ExtractPublicPropTypes;
export declare type ScrollbarInternalProps = ExtractInternalPropTypes;
export declare const Scrollbar: import("vue").DefineComponent<{
readonly size: {
readonly type: NumberConstructor;
readonly default: 5;
};
readonly duration: {
readonly type: NumberConstructor;
readonly default: 0;
};
readonly scrollable: {
readonly type: BooleanConstructor;
readonly default: true;
};
readonly xScrollable: BooleanConstructor;
readonly trigger: {
readonly type: PropType<"none" | "hover">;
readonly default: "hover";
};
readonly useUnifiedContainer: BooleanConstructor;
readonly triggerDisplayManually: BooleanConstructor;
readonly container: PropType<() => HTMLElement | null | undefined>;
readonly content: PropType<() => HTMLElement | null | undefined>;
readonly containerClass: StringConstructor;
readonly containerStyle: PropType;
readonly contentClass: StringConstructor;
readonly contentStyle: PropType;
readonly horizontalRailStyle: PropType;
readonly verticalRailStyle: PropType;
readonly onScroll: PropType<(e: Event) => void>;
readonly onWheel: PropType<(e: WheelEvent) => void>;
readonly onResize: PropType<(e: ResizeObserverEntry) => void>;
readonly internalOnUpdateScrollLeft: PropType<(scrollLeft: number) => void>;
readonly internalHoistYRail: BooleanConstructor;
}, {
mergedClsPrefix: string;
rtlEnabled: boolean;
containerScrollTop: import("vue").Ref;
wrapperRef: import("vue").Ref;
containerRef: import("vue").Ref;
contentRef: import("vue").Ref;
yRailRef: import("vue").Ref;
xRailRef: import("vue").Ref;
needYBar: import("vue").ComputedRef;
needXBar: import("vue").ComputedRef;
yBarSizePx: import("vue").ComputedRef;
xBarSizePx: import("vue").ComputedRef;
yBarTopPx: import("vue").ComputedRef;
xBarLeftPx: import("vue").ComputedRef;
isShowXBar: import("vue").ComputedRef;
isShowYBar: import("vue").ComputedRef;
isIos: boolean;
handleScroll: (e: Event) => void;
handleContentResize: () => void;
handleContainerResize: (e: ResizeObserverEntry) => void;
handleYScrollMouseDown: (e: MouseEvent) => void;
handleXScrollMouseDown: (e: MouseEvent) => void;
syncUnifiedContainer: () => void;
scrollTo: ScrollTo;
scrollBy: ScrollBy;
sync: () => void;
handleMouseEnterWrapper: () => void;
handleMouseLeaveWrapper: () => void;
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly;
readonly default: "hover";
};
readonly useUnifiedContainer: BooleanConstructor;
readonly triggerDisplayManually: BooleanConstructor;
readonly container: PropType<() => HTMLElement | null | undefined>;
readonly content: PropType<() => HTMLElement | null | undefined>;
readonly containerClass: StringConstructor;
readonly containerStyle: PropType;
readonly contentClass: StringConstructor;
readonly contentStyle: PropType;
readonly horizontalRailStyle: PropType;
readonly verticalRailStyle: PropType;
readonly onScroll: PropType<(e: Event) => void>;
readonly onWheel: PropType<(e: WheelEvent) => void>;
readonly onResize: PropType<(e: ResizeObserverEntry) => void>;
readonly internalOnUpdateScrollLeft: PropType<(scrollLeft: number) => void>;
readonly internalHoistYRail: BooleanConstructor;
}>>, {
readonly size: number;
readonly trigger: "none" | "hover";
readonly duration: number;
readonly scrollable: boolean;
readonly xScrollable: boolean;
readonly useUnifiedContainer: boolean;
readonly triggerDisplayManually: boolean;
readonly internalHoistYRail: boolean;
}>;
declare type NativeScrollbarProps = Omit;
declare type MergedProps = Partial;
export default Scrollbar;
export declare const XScrollbar: new () => {
$props: MergedProps;
};