UNPKG

@testing-library/user-event

Version:
57 lines (55 loc) 2.2 kB
import { dispatchUIEvent } from '../index.js'; import '../../utils/click/isClickableInput.js'; import '../../utils/dataTransfer/Clipboard.js'; import { isContentEditable } from '../../utils/edit/isContentEditable.js'; import { input } from '../../utils/edit/input.js'; import { isEditable } from '../../utils/edit/isEditable.js'; import '@testing-library/dom'; import { isElementType } from '../../utils/misc/isElementType.js'; import '@testing-library/dom/dist/helpers.js'; import '../../utils/keyDef/readNextDescriptor.js'; import '../../utils/misc/level.js'; import '../../options.js'; import { behavior } from './registry.js'; behavior.keypress = (event, target, config)=>{ if (event.key === 'Enter') { if (isElementType(target, 'button') || isElementType(target, 'input') && ClickInputOnEnter.includes(target.type) || isElementType(target, 'a') && Boolean(target.href)) { return ()=>{ dispatchUIEvent(config, target, 'click'); }; } else if (isElementType(target, 'input')) { const form = target.form; const submit = form === null || form === void 0 ? void 0 : form.querySelector('input[type="submit"], button:not([type]), button[type="submit"]'); if (submit) { return ()=>dispatchUIEvent(config, submit, 'click'); } else if (form && SubmitSingleInputOnEnter.includes(target.type) && form.querySelectorAll('input').length === 1) { return ()=>dispatchUIEvent(config, form, 'submit'); } else { return; } } } if (isEditable(target)) { const inputType = event.key === 'Enter' ? isContentEditable(target) && !config.system.keyboard.modifiers.Shift ? 'insertParagraph' : 'insertLineBreak' : 'insertText'; const inputData = event.key === 'Enter' ? '\n' : event.key; return ()=>input(config, target, inputData, inputType); } }; const ClickInputOnEnter = [ 'button', 'color', 'file', 'image', 'reset', 'submit', ]; const SubmitSingleInputOnEnter = [ 'email', 'month', 'password', 'search', 'tel', 'text', 'url', 'week', ];