UNPKG

@testing-library/user-event

Version:
89 lines (86 loc) 4.14 kB
import '../setup/index.js'; import '../utils/click/isClickableInput.js'; import '../utils/dataTransfer/Clipboard.js'; import '../event/eventMap.js'; import '../event/behavior/click.js'; import '../event/behavior/cut.js'; import '../event/behavior/keydown.js'; import '../event/behavior/keypress.js'; import '../event/behavior/keyup.js'; import '../event/behavior/paste.js'; import '@testing-library/dom'; import '../utils/edit/maxLength.js'; import '../utils/edit/isEditable.js'; import '@testing-library/dom/dist/helpers.js'; import '../utils/keyDef/readNextDescriptor.js'; import { setLevelRef, ApiLevel } from '../utils/misc/level.js'; import { wait } from '../utils/misc/wait.js'; import '../options.js'; import { parseKeyDef } from './parseKeyDef.js'; import { Config } from '../setup/config.js'; async function pointer(input) { const { pointerMap } = this[Config]; const actions = []; (Array.isArray(input) ? input : [ input ]).forEach((actionInput)=>{ if (typeof actionInput === 'string') { actions.push(...parseKeyDef(pointerMap, actionInput)); } else if ('keys' in actionInput) { actions.push(...parseKeyDef(pointerMap, actionInput.keys).map((i)=>({ ...actionInput, ...i }))); } else { actions.push(actionInput); } }); for(let i = 0; i < actions.length; i++){ await wait(this[Config]); await pointerAction(this[Config], actions[i]); } this[Config].system.pointer.resetClickCount(); } async function pointerAction(config, action) { var ref, ref1; const pointerName = 'pointerName' in action && action.pointerName ? action.pointerName : 'keyDef' in action ? config.system.pointer.getPointerName(action.keyDef) : 'mouse'; const previousPosition = config.system.pointer.getPreviousPosition(pointerName); var _target, _coords, _node, _offset; const position = { target: (_target = action.target) !== null && _target !== void 0 ? _target : getPrevTarget(config, previousPosition), coords: (_coords = action.coords) !== null && _coords !== void 0 ? _coords : previousPosition === null || previousPosition === void 0 ? void 0 : previousPosition.coords, caret: { node: (_node = action.node) !== null && _node !== void 0 ? _node : hasCaretPosition(action) ? undefined : previousPosition === null || previousPosition === void 0 ? void 0 : (ref = previousPosition.caret) === null || ref === void 0 ? void 0 : ref.node, offset: (_offset = action.offset) !== null && _offset !== void 0 ? _offset : hasCaretPosition(action) ? undefined : previousPosition === null || previousPosition === void 0 ? void 0 : (ref1 = previousPosition.caret) === null || ref1 === void 0 ? void 0 : ref1.offset } }; if ('keyDef' in action) { if (config.system.pointer.isKeyPressed(action.keyDef)) { setLevelRef(config, ApiLevel.Trigger); await config.system.pointer.release(config, action.keyDef, position); } if (!action.releasePrevious) { setLevelRef(config, ApiLevel.Trigger); await config.system.pointer.press(config, action.keyDef, position); if (action.releaseSelf) { setLevelRef(config, ApiLevel.Trigger); await config.system.pointer.release(config, action.keyDef, position); } } } else { setLevelRef(config, ApiLevel.Trigger); await config.system.pointer.move(config, pointerName, position); } } function hasCaretPosition(action) { var _target, ref; return !!((ref = (_target = action.target) !== null && _target !== void 0 ? _target : action.node) !== null && ref !== void 0 ? ref : action.offset !== undefined); } function getPrevTarget(config, position) { if (!position) { throw new Error('This pointer has no previous position. Provide a target property!'); } var _target; return (_target = position.target) !== null && _target !== void 0 ? _target : config.document.body; } export { pointer };