UNPKG

@varlet/ui

Version:

A Vue3 component library based on Material Design 2 and 3, supporting mobile and desktop.

65 lines (48 loc) 1.83 kB
import { TeleportProps, VNode } from 'vue' import { PositioningStrategy } from '@popperjs/core' import { Placement as PopperPlacement } from '@popperjs/core/lib/enums' import { BasicAttributes, ListenerProp, SetPropsDefaults, VarComponent } from './varComponent' export declare const tooltipProps: Record<keyof TooltipProps, any> type TooltipNeededPopperPlacement = Exclude<PopperPlacement, 'auto' | 'auto-start' | 'auto-end'> export type TooltipPlacement = TooltipNeededPopperPlacement export type TooltipTrigger = 'click' | 'hover' | 'manual' export type TooltipReference = string | HTMLElement export type TooltipType = 'default' | 'primary' | 'info' | 'success' | 'warning' | 'danger' export type TooltipStrategy = PositioningStrategy export interface TooltipProps extends BasicAttributes { show?: boolean disabled?: boolean content?: string color?: string textColor?: string type?: TooltipType trigger?: TooltipTrigger reference?: TooltipReference placement?: TooltipPlacement strategy?: TooltipStrategy offsetX?: string | number offsetY?: string | number teleport?: TeleportProps['to'] | false sameWidth?: boolean closeOnClickReference?: boolean closeOnKeyEscape?: boolean onOpen?: ListenerProp<() => void> onOpened?: ListenerProp<() => void> onClose?: ListenerProp<() => void> onClosed?: ListenerProp<() => void> onClickOutside?: ListenerProp<(event: Event) => void> 'onUpdate:show'?: ListenerProp<(show: boolean) => void> } export class Tooltip extends VarComponent { static setPropsDefaults: SetPropsDefaults<TooltipProps> $props: TooltipProps $slots: { default(): VNode[] content(): VNode[] } open(): void close(): void resize(): void setReference(reference: TooltipReference): void } export class _TooltipComponent extends Tooltip {}