import { unref } from 'vue' import { buildProps } from '@element-plus/utils' import { useTimeout } from '../use-timeout' import type { ExtractPropTypes, ToRefs } from 'vue' export const useDelayedToggleProps = buildProps({ showAfter: { type: Number, default: 0, }, hideAfter: { type: Number, default: 200, }, } as const) export type UseDelayedToggleProps = { open: () => void close: () => void } & ToRefs> export const useDelayedToggle = ({ showAfter, hideAfter, open, close, }: UseDelayedToggleProps) => { const { registerTimeout } = useTimeout() const onOpen = () => { registerTimeout(() => { open() }, unref(showAfter)) } const onClose = () => { registerTimeout(() => { close() }, unref(hideAfter)) } return { onOpen, onClose, } }