Sha256: b1cc91a53434b69bba331fa733c53d6d28c24b5797adf353bf9f4b7c41e5c555
Contents?: true
Size: 1.41 KB
Versions: 26
Compression:
Stored size: 1.41 KB
Contents
import '../../utils/click/isClickableInput.js'; import '../../utils/dataTransfer/Clipboard.js'; import '../../utils/edit/isEditable.js'; import '../../utils/edit/maxLength.js'; import { isElementType } from '../../utils/misc/isElementType.js'; import { getWindow } from '../../utils/misc/getWindow.js'; import { isFocusable } from '../../utils/focus/isFocusable.js'; import '../../utils/keyDef/readNextDescriptor.js'; import { cloneEvent } from '../../utils/misc/cloneEvent.js'; import '../../utils/misc/level.js'; import '../../options.js'; import { focusElement, blurElement } from '../focus.js'; import { behavior } from './registry.js'; behavior.click = (event, target, instance)=>{ const context = target.closest('button,input,label,select,textarea'); const control = context && isElementType(context, 'label') && context.control; if (control) { return ()=>{ if (isFocusable(control)) { focusElement(control); } instance.dispatchEvent(control, cloneEvent(event)); }; } else if (isElementType(target, 'input', { type: 'file' })) { return ()=>{ // blur fires when the file selector pops up blurElement(target); target.dispatchEvent(new (getWindow(target)).Event('fileDialog')); // focus fires after the file selector has been closed focusElement(target); }; } };
Version data entries
26 entries across 26 versions & 1 rubygems