mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-12 10:45:10 +08:00
bbd16a08e9
* refactor(hooks): remove use-css-var * refactor(hooks): remove use-events * refactor(hooks): remove use-migrating * refactor(hooks): remove use-transition * refactor(hooks): named export useAttrs * refactor(hooks): named export useFocus * refactor(hooks): refactor useFormItem * refactor(hooks): refactor useGlobalConfig * refactor(hooks): refactor useLocale * refactor(hooks): refactor useLockscreen * refactor(hooks): refactor useModal * refactor(hooks): refactor useModelToggle * refactor(hooks): refactor usePreventGlobal * refactor(hooks): refactor useRestoreActive * refactor(hooks): refactor useTeleport * refactor(hooks): refactor useThrottleRender * refactor(hooks): refactor useTimeout * refactor(hooks): refactor useTransitionFallthrogh
34 lines
759 B
TypeScript
34 lines
759 B
TypeScript
import { ref, nextTick } from 'vue'
|
|
import { EVENT_CODE } from '@element-plus/utils/aria'
|
|
|
|
import { useModal } from '../use-modal'
|
|
|
|
describe('useModal', () => {
|
|
test('should work when ref value changed', async () => {
|
|
const visible = ref(false)
|
|
const handleClose = jest.fn()
|
|
|
|
useModal(
|
|
{
|
|
handleClose,
|
|
},
|
|
visible
|
|
)
|
|
|
|
expect(handleClose).not.toHaveBeenCalled()
|
|
|
|
visible.value = true
|
|
await nextTick()
|
|
const event = new KeyboardEvent('keydown', {
|
|
code: EVENT_CODE.esc,
|
|
})
|
|
document.dispatchEvent(event)
|
|
expect(handleClose).toHaveBeenCalledTimes(1)
|
|
|
|
visible.value = false
|
|
await nextTick()
|
|
document.dispatchEvent(event)
|
|
expect(handleClose).toHaveBeenCalledTimes(1)
|
|
})
|
|
})
|