import { nextTick, ref } from 'vue'
import { mount } from '@vue/test-utils'
import { afterEach, describe, expect, it, vi } from 'vitest'
import { POPPER_INJECTION_KEY } from '@element-plus/components/popper'
import ElTrigger from '../src/trigger.vue'
import type { VueWrapper } from '@vue/test-utils'
import type { PopperTriggerInstance } from '../src/trigger'
const AXIOM = 'rem is the best girl'
const popperInjection = {
triggerRef: ref(null),
popperInstanceRef: ref(null),
contentRef: ref(null),
}
const mountTrigger = (props = {}) =>
mount({AXIOM}, {
global: {
provide: {
[POPPER_INJECTION_KEY as symbol]: popperInjection,
},
},
})
describe('', () => {
let wrapper: VueWrapper
afterEach(() => {
popperInjection.triggerRef.value = null
})
describe('rendering', () => {
it('should be able to render with children', async () => {
wrapper = mountTrigger()
await nextTick()
expect(popperInjection.triggerRef.value).not.toBeNull()
expect(wrapper.text()).toEqual(AXIOM)
})
it('should be able to render for virtual ref', async () => {
wrapper = mountTrigger({
virtualTriggering: true,
})
await nextTick()
expect(wrapper.text()).not.toEqual(AXIOM)
const virtualRef = document.createElement('div')
await wrapper.setProps({
virtualRef,
})
expect(popperInjection.triggerRef.value).toStrictEqual
})
})
describe('can attach handlers', () => {
it('should be able to attach handlers to the trigger', async () => {
const onClick = vi.fn()
const virtualRef = document.createElement('div')
wrapper = mountTrigger({
onClick,
virtualTriggering: true,
virtualRef,
})
await nextTick()
expect(onClick).not.toHaveBeenCalled()
const evt = new MouseEvent('click')
virtualRef.dispatchEvent(evt)
await nextTick()
expect(onClick).toHaveBeenCalled()
})
})
})