ant-design-vue/components/_util/antInputDirective.ts

43 lines
1.2 KiB
TypeScript
Raw Normal View History

2023-08-30 13:44:03 +00:00
import type { Directive } from 'vue';
function onCompositionStart(e: any) {
2020-10-02 07:44:10 +00:00
e.target.composing = true;
}
2023-08-30 13:44:03 +00:00
function onCompositionEnd(e: any) {
2020-10-02 07:44:10 +00:00
// prevent triggering an input event for no reason
if (!e.target.composing) return;
e.target.composing = false;
trigger(e.target, 'input');
}
2020-10-02 07:44:10 +00:00
function trigger(el, type) {
2019-01-12 03:33:27 +00:00
const e = document.createEvent('HTMLEvents');
e.initEvent(type, true, true);
el.dispatchEvent(e);
}
2023-08-30 13:44:03 +00:00
export function addEventListener(
el: HTMLElement,
event: string,
handler: EventListenerOrEventListenerObject,
options?: boolean | AddEventListenerOptions,
) {
el.addEventListener(event, handler, options);
}
2023-08-30 13:44:03 +00:00
const antInput: Directive = {
2020-10-02 07:44:10 +00:00
created(el, binding) {
if (!binding.modifiers || !binding.modifiers.lazy) {
addEventListener(el, 'compositionstart', onCompositionStart);
addEventListener(el, 'compositionend', onCompositionEnd);
// Safari < 10.2 & UIWebView doesn't fire compositionend when
// switching focus before confirming composition choice
// this also fixes the issue where some browsers e.g. iOS Chrome
// fires "change" instead of "input" on autocomplete.
addEventListener(el, 'change', onCompositionEnd);
2020-07-03 14:53:50 +00:00
}
},
};
2018-12-13 14:47:23 +00:00
export default antInput;