import { nextTick, ref } from 'vue'
import { shallowMount } from '@vue/test-utils'
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest'
import { POPPER_INJECTION_KEY } from '@element-plus/tokens'
import ElContent from '../src/content.vue'
const AXIOM = 'rem is the best girl'
const popperInjection = {
triggerRef: ref(),
popperInstanceRef: ref(),
contentRef: ref(),
}
const mountContent = (props = {}) =>
shallowMount(ElContent, {
props,
slots: {
default: () => AXIOM,
},
global: {
provide: {
[POPPER_INJECTION_KEY as symbol]: popperInjection,
},
},
})
describe('', () => {
describe('with triggerRef provided', () => {
const triggerKls = 'el-popper__trigger'
let wrapper: ReturnType
beforeEach(() => {
const trigger = document.createElement('div')
trigger.className = triggerKls
popperInjection.triggerRef.value = trigger
})
afterEach(() => {
popperInjection.triggerRef.value = null
wrapper?.unmount()
})
it('should mount the component correctly and set popperInstance correctly', async () => {
wrapper = mountContent()
await nextTick()
expect(popperInjection.triggerRef).toBeDefined()
expect(wrapper.html()).toContain(AXIOM)
expect(popperInjection.popperInstanceRef.value).toBeDefined()
expect(wrapper.classes()).toEqual(['el-popper', 'is-dark'])
expect(wrapper.vm.contentStyle[0]).toHaveProperty('zIndex')
expect(wrapper.vm.contentStyle[1]).toBeUndefined()
})
it('should be able to be pure and themed', async () => {
wrapper = mountContent()
await nextTick()
await wrapper.setProps({
pure: true,
effect: 'custom',
})
expect(wrapper.classes()).toEqual(['el-popper', 'is-pure', 'is-custom'])
})
it('should be able to set customized styles', async () => {
wrapper = mountContent()
await nextTick()
const style = {
position: 'absolute',
}
await wrapper.setProps({
popperStyle: style,
})
expect(wrapper.vm.contentStyle[1]).toEqual(style)
})
it('should be able to emit events', async () => {
wrapper = mountContent()
await nextTick()
expect(wrapper.emitted()).not.toHaveProperty('mouseenter')
expect(wrapper.emitted()).not.toHaveProperty('mouseleave')
await wrapper.trigger('mouseenter')
expect(wrapper.emitted()).toHaveProperty('mouseenter')
await wrapper.trigger('mouseleave')
expect(wrapper.emitted()).toHaveProperty('mouseleave')
})
describe('instantiate popper instance', () => {
it('should be able to update the current instance', async () => {
wrapper = mountContent()
await nextTick()
vi.spyOn(
popperInjection.triggerRef.value,
'getBoundingClientRect'
).mockImplementation(() => ({
bottom: 1,
height: 0,
left: 0,
right: 0,
top: 0,
width: 0,
}))
wrapper.vm.$forceUpdate()
})
it('should be able to update the reference node', async () => {
wrapper = mountContent()
await nextTick()
const oldInstance = wrapper.vm.popperInstanceRef
const newRef = document.createElement('div')
newRef.classList.add('new-ref')
popperInjection.triggerRef.value = newRef
await nextTick()
expect(wrapper.vm.popperInstanceRef).not.toStrictEqual(oldInstance)
popperInjection.triggerRef.value = undefined
await nextTick()
expect(wrapper.vm.popperInstanceRef).toBeUndefined()
})
})
})
})