36 lines
1.5 KiB
TypeScript
Raw Normal View History

2025-02-28 19:43:11 +08:00
import { type Ref, type CSSProperties } from 'vue';
export type TabsType = 'line' | 'card' | 'bar' | 'segment';
export type OnUpdateValue = (value: string & number) => void;
export type OnUpdateValueImpl = (value: string | number) => void;
export type OnClose = (name: string & number) => void;
export type OnCloseImpl = (name: string | number) => void;
export type OnBeforeLeave = (name: string & number, oldName: string & number & null) => boolean | Promise<boolean>;
export type OnBeforeLeaveImpl = (name: string | number, oldName: string | number | null) => boolean | Promise<boolean>;
export interface TabsInjection {
mergedClsPrefixRef: Ref<string>;
valueRef: Ref<string | number | null>;
typeRef: Ref<TabsType>;
closableRef: Ref<boolean>;
tabStyleRef: Ref<string | CSSProperties | undefined>;
tabClassRef: Ref<string | undefined>;
addTabClassRef: Ref<string | undefined>;
addTabStyleRef: Ref<string | CSSProperties | undefined>;
paneClassRef: Ref<string | undefined>;
paneStyleRef: Ref<string | CSSProperties | undefined>;
tabChangeIdRef: {
id: number;
};
onBeforeLeaveRef: Ref<OnBeforeLeave | undefined>;
triggerRef: Ref<'click' | 'hover'>;
activateTab: (panelName: string | number) => void;
handleClose: (panelName: string | number) => void;
handleAdd: () => void;
}
export type Addable = boolean | {
disabled?: boolean;
};
export declare const tabsInjectionKey: import("vue").InjectionKey<TabsInjection>;
export interface TabsInst {
syncBarPosition: () => void;
}