mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-24 11:05:17 +08:00
55348b30b6
* style: use prettier * style: just prettier format, no code changes * style: eslint fix object-shorthand, prefer-const * style: fix no-void * style: no-console
374 lines
12 KiB
TypeScript
374 lines
12 KiB
TypeScript
import { mount } from '@vue/test-utils'
|
|
import { sleep } from '@element-plus/test-utils'
|
|
import { EVENT_CODE } from '@element-plus/utils/aria'
|
|
import Dropdown from '../src/dropdown.vue'
|
|
import DropdownItem from '../src/dropdown-item.vue'
|
|
import DropdownMenu from '../src/dropdown-menu.vue'
|
|
|
|
const TIMEOUT = 250
|
|
const MOUSE_ENTER_EVENT = 'mouseenter'
|
|
const MOUSE_LEAVE_EVENT = 'mouseleave'
|
|
const CLICK = 'click'
|
|
const CONTEXTMENU = 'contextmenu'
|
|
|
|
const _mount = (template: string, data, otherObj?) =>
|
|
mount({
|
|
components: {
|
|
[Dropdown.name]: Dropdown,
|
|
[DropdownItem.name]: DropdownItem,
|
|
[DropdownMenu.name]: DropdownMenu,
|
|
},
|
|
template,
|
|
data,
|
|
...otherObj,
|
|
})
|
|
|
|
describe('Dropdown', () => {
|
|
test('create', async () => {
|
|
const wrapper = mount({
|
|
setup() {
|
|
return () => (
|
|
<Dropdown
|
|
ref="b"
|
|
placement="right"
|
|
v-slots={{
|
|
dropdown: () => (
|
|
<DropdownMenu>
|
|
<DropdownItem>Apple</DropdownItem>
|
|
<DropdownItem>Orange</DropdownItem>
|
|
<DropdownItem>Cherry</DropdownItem>
|
|
<DropdownItem disabled>Peach</DropdownItem>
|
|
<DropdownItem divided>Pear</DropdownItem>
|
|
</DropdownMenu>
|
|
),
|
|
}}
|
|
>
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
</Dropdown>
|
|
)
|
|
},
|
|
})
|
|
const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
expect(content.visible).toBe(false)
|
|
await triggerElm.trigger('keydown')
|
|
await triggerElm.trigger('focus')
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(true)
|
|
await triggerElm.trigger(MOUSE_LEAVE_EVENT)
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(false)
|
|
})
|
|
|
|
test('menu click', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown ref="b" @command="commandHandler" placement="right">
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item command="a">Apple</el-dropdown-item>
|
|
<el-dropdown-item command="b">Orange</el-dropdown-item>
|
|
<el-dropdown-item ref="c" :command="myCommandObject">Cherry</el-dropdown-item>
|
|
<el-dropdown-item command="d">Peach</el-dropdown-item>
|
|
<el-dropdown-item command="e">Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({
|
|
myCommandObject: { name: 'CommandC' },
|
|
name: '',
|
|
}),
|
|
{
|
|
methods: {
|
|
commandHandler(command) {
|
|
this.name = command.name
|
|
},
|
|
},
|
|
}
|
|
)
|
|
// const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
await wrapper.findComponent({ ref: 'c' }).trigger('click')
|
|
await sleep(TIMEOUT)
|
|
expect((wrapper.vm as any).name).toBe('CommandC')
|
|
})
|
|
|
|
test('trigger', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown trigger="click" ref="b" placement="right">
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item command="a">Apple</el-dropdown-item>
|
|
<el-dropdown-item command="b">Orange</el-dropdown-item>
|
|
<el-dropdown-item ref="c" :command="myCommandObject">Cherry</el-dropdown-item>
|
|
<el-dropdown-item command="d">Peach</el-dropdown-item>
|
|
<el-dropdown-item command="e">Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({
|
|
myCommandObject: { name: 'CommandC' },
|
|
name: '',
|
|
})
|
|
)
|
|
const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
expect(content.visible).toBe(false)
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(false)
|
|
await triggerElm.trigger(CLICK)
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(true)
|
|
})
|
|
|
|
test('trigger contextmenu', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown trigger="contextmenu" ref="b" placement="right">
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item command="a">Apple</el-dropdown-item>
|
|
<el-dropdown-item command="b">Orange</el-dropdown-item>
|
|
<el-dropdown-item ref="c" :command="myCommandObject">Cherry</el-dropdown-item>
|
|
<el-dropdown-item command="d">Peach</el-dropdown-item>
|
|
<el-dropdown-item command="e">Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({
|
|
myCommandObject: { name: 'CommandC' },
|
|
name: '',
|
|
})
|
|
)
|
|
const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
expect(content.visible).toBe(false)
|
|
await triggerElm.trigger(CONTEXTMENU)
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(true)
|
|
})
|
|
|
|
test('split button', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown @click="handleClick" split-button type="primary" ref="b" placement="right">
|
|
dropdown
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item command="a">Apple</el-dropdown-item>
|
|
<el-dropdown-item command="b">Orange</el-dropdown-item>
|
|
<el-dropdown-item ref="c" :command="myCommandObject">Cherry</el-dropdown-item>
|
|
<el-dropdown-item command="d">Peach</el-dropdown-item>
|
|
<el-dropdown-item command="e">Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({
|
|
myCommandObject: { name: 'CommandC' },
|
|
name: '',
|
|
}),
|
|
{
|
|
methods: {
|
|
handleClick() {
|
|
this.name = 'click'
|
|
},
|
|
},
|
|
}
|
|
)
|
|
const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown__caret-button')
|
|
const button = wrapper.find('.el-button')
|
|
expect(content.visible).toBe(false)
|
|
await button.trigger('click')
|
|
expect((wrapper.vm as any).name).toBe('click')
|
|
await triggerElm.trigger('keydown')
|
|
await triggerElm.trigger('focus')
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(true)
|
|
})
|
|
|
|
test('hide on click', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown ref="b" placement="right" :hide-on-click="false">
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Apple</el-dropdown-item>
|
|
<el-dropdown-item>Orange</el-dropdown-item>
|
|
<el-dropdown-item ref="c">Cherry</el-dropdown-item>
|
|
<el-dropdown-item disabled>Peach</el-dropdown-item>
|
|
<el-dropdown-item divided>Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({})
|
|
)
|
|
|
|
const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
await triggerElm.trigger('keydown')
|
|
await triggerElm.trigger('focus')
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
await wrapper.findComponent({ ref: 'c' }).trigger('click')
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(true)
|
|
})
|
|
|
|
test('triggerElm keydown', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown ref="b" placement="right" :hide-on-click="false">
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Apple</el-dropdown-item>
|
|
<el-dropdown-item>Orange</el-dropdown-item>
|
|
<el-dropdown-item ref="c">Cherry</el-dropdown-item>
|
|
<el-dropdown-item disabled>Peach</el-dropdown-item>
|
|
<el-dropdown-item divided>Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({})
|
|
)
|
|
|
|
const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
await triggerElm.trigger('keydown')
|
|
await triggerElm.trigger('focus')
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
await triggerElm.trigger('keydown', {
|
|
code: EVENT_CODE.enter,
|
|
})
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(false)
|
|
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
await triggerElm.trigger('keydown', {
|
|
code: EVENT_CODE.tab,
|
|
})
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(false)
|
|
})
|
|
|
|
test('dropdown menu keydown', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown ref="b" placement="right" :hide-on-click="false">
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu ref="a">
|
|
<el-dropdown-item ref="d">Apple</el-dropdown-item>
|
|
<el-dropdown-item>Orange</el-dropdown-item>
|
|
<el-dropdown-item ref="c">Cherry</el-dropdown-item>
|
|
<el-dropdown-item disabled>Peach</el-dropdown-item>
|
|
<el-dropdown-item divided>Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({})
|
|
)
|
|
|
|
const content = wrapper.findComponent({ ref: 'a' })
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
await content.trigger('keydown', {
|
|
code: EVENT_CODE.down,
|
|
})
|
|
await sleep(TIMEOUT)
|
|
expect(wrapper.findComponent({ ref: 'd' }).attributes('tabindex')).toBe('0')
|
|
})
|
|
|
|
test('max height', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown ref="b" max-height="60px">
|
|
<span class="el-dropdown-link" ref="a">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Apple</el-dropdown-item>
|
|
<el-dropdown-item>Orange</el-dropdown-item>
|
|
<el-dropdown-item>Cherry</el-dropdown-item>
|
|
<el-dropdown-item disabled>Peach</el-dropdown-item>
|
|
<el-dropdown-item divided>Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({})
|
|
)
|
|
const content = wrapper.findComponent({ ref: 'b' })
|
|
const scrollbar = content.findComponent({ ref: 'scrollbar' })
|
|
expect(scrollbar.find('.el-scrollbar__wrap').attributes('style')).toContain(
|
|
'max-height: 60px;'
|
|
)
|
|
})
|
|
|
|
test('tooltip debounce', async () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<el-dropdown ref="b">
|
|
<span class="el-dropdown-link">
|
|
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Apple</el-dropdown-item>
|
|
<el-dropdown-item>Orange</el-dropdown-item>
|
|
<el-dropdown-item>Cherry</el-dropdown-item>
|
|
<el-dropdown-item>Peach</el-dropdown-item>
|
|
<el-dropdown-item>Pear</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
`,
|
|
() => ({})
|
|
)
|
|
const content = wrapper.findComponent({ ref: 'b' }).vm as any
|
|
const triggerElm = wrapper.find('.el-dropdown-link')
|
|
expect(content.visible).toBe(false)
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await triggerElm.trigger(MOUSE_LEAVE_EVENT)
|
|
await triggerElm.trigger(MOUSE_ENTER_EVENT)
|
|
await sleep(TIMEOUT)
|
|
expect(content.visible).toBe(true)
|
|
})
|
|
})
|