import { nextTick } from 'vue' import { mount } from '@vue/test-utils' import { afterEach, describe, expect, it } from 'vitest' import { EVENT_CODE } from '@element-plus/constants' import { TOOLTIP_INJECTION_KEY } from '@element-plus/components/tooltip' import ElTooltipTrigger from '../src/trigger.vue' import { genTooltipProvides } from '../test-helper/provides' import type { VueWrapper } from '@vue/test-utils' const AXIOM = 'rem is the best girl' describe('', () => { const { controlled, id, open, onOpen, onClose, onToggle, onShow, onHide, onBeforeShow, onBeforeHide, } = genTooltipProvides() const defaultProvide = { [TOOLTIP_INJECTION_KEY as symbol]: { controlled, id, open, onOpen, onClose, onToggle, onShow, onHide, onBeforeShow, onBeforeHide, }, } const createComponent = (props = {}) => mount( { setup() { return () => {AXIOM} }, }, { global: { provide: defaultProvide, stubs: ['ElPopperTrigger'], }, attachTo: document.body, } ) let wrapper: VueWrapper afterEach(() => { open.value = false controlled.value = false wrapper?.unmount() document.body.innerHTML = '' }) describe('rendering', () => { it('should render correctly', async () => { wrapper = createComponent() }) }) describe('trigger event', () => { describe('controlled', () => { it('should not trigger anything when tooltip is controlled', async () => { wrapper = createComponent() controlled.value = true await nextTick() const { vm } = wrapper.findComponent( ElTooltipTrigger ) as VueWrapper const blurEvt = new FocusEvent('blur') vm.onBlur(blurEvt) await nextTick() expect(onClose).not.toHaveBeenCalled() const focusEvt = new FocusEvent('focus') vm.onFocus(focusEvt) await nextTick() expect(onOpen).not.toHaveBeenCalled() const mousedownEvt = new MouseEvent('mousedown') vm.onClick(mousedownEvt) await nextTick() expect(onToggle).not.toHaveBeenCalled() const mouseenterEvt = new MouseEvent('mouseenter') vm.onMouseenter(mouseenterEvt) await nextTick() expect(onOpen).not.toHaveBeenCalled() const mouseleaveEvt = new MouseEvent('mouseleave') vm.onMouseleave(mouseleaveEvt) await nextTick() expect(onClose).not.toHaveBeenCalled() const contextmenuEvt = new MouseEvent('contextmenu') vm.onContextMenu(contextmenuEvt) await nextTick() expect(onToggle).not.toHaveBeenCalled() // keyboard evt const keyboardEvt = new KeyboardEvent('keydown') vm.onKeydown(keyboardEvt) await nextTick() expect(onToggle).not.toHaveBeenCalled() }) }) describe('uncontrolled', () => { it('should be able to dispatch event when uncontrolled', async () => { wrapper = createComponent() await nextTick() const { vm } = wrapper.findComponent( ElTooltipTrigger ) as VueWrapper await wrapper.setProps({ trigger: 'focus', }) const blurEvt = new FocusEvent('blur') vm.onBlur(blurEvt) await nextTick() expect(onClose).toHaveBeenCalledTimes(1) const focusEvt = new FocusEvent('focus') vm.onFocus(focusEvt) await nextTick() expect(onOpen).toHaveBeenCalledTimes(1) await wrapper.setProps({ trigger: 'click', }) const mousedownEvt = new MouseEvent('mousedown') vm.onClick(mousedownEvt) await nextTick() await wrapper.setProps({ trigger: 'hover', }) expect(onToggle).toHaveBeenCalledTimes(1) const mouseenterEvt = new MouseEvent('mouseenter') vm.onMouseenter(mouseenterEvt) await nextTick() expect(onOpen).toHaveBeenCalledTimes(2) const mouseleaveEvt = new MouseEvent('mouseleave') vm.onMouseleave(mouseleaveEvt) await nextTick() expect(onClose).toHaveBeenCalledTimes(2) await wrapper.setProps({ trigger: 'contextmenu', }) const contextmenuEvt = new MouseEvent('contextmenu') vm.onContextMenu(contextmenuEvt) await nextTick() expect(onToggle).toHaveBeenCalledTimes(2) // keyboard evt let keyboardEvt = new KeyboardEvent('keydown', { code: EVENT_CODE.esc, }) vm.onKeydown(keyboardEvt) await nextTick() expect(onToggle).toHaveBeenCalledTimes(2) keyboardEvt = new KeyboardEvent('keydown', { code: EVENT_CODE.enter, }) vm.onKeydown(keyboardEvt) await nextTick() expect(onToggle).toHaveBeenCalledTimes(3) keyboardEvt = new KeyboardEvent('keydown', { code: EVENT_CODE.space, }) vm.onKeydown(keyboardEvt) await nextTick() expect(onToggle).toHaveBeenCalledTimes(4) }) }) }) })