12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- 'use strict';
- Object.defineProperty(exports, '__esModule', { value: true });
- var vue = require('vue');
- var core = require('@vueuse/core');
- require('../../utils/index.js');
- var shared = require('@vue/shared');
- var types = require('../../utils/types.js');
- function useFocusController(target, {
- beforeFocus,
- afterFocus,
- beforeBlur,
- afterBlur
- } = {}) {
- const instance = vue.getCurrentInstance();
- const { emit } = instance;
- const wrapperRef = vue.shallowRef();
- const isFocused = vue.ref(false);
- const handleFocus = (event) => {
- const cancelFocus = shared.isFunction(beforeFocus) ? beforeFocus(event) : false;
- if (cancelFocus || isFocused.value)
- return;
- isFocused.value = true;
- emit("focus", event);
- afterFocus == null ? void 0 : afterFocus();
- };
- const handleBlur = (event) => {
- var _a;
- const cancelBlur = shared.isFunction(beforeBlur) ? beforeBlur(event) : false;
- if (cancelBlur || event.relatedTarget && ((_a = wrapperRef.value) == null ? void 0 : _a.contains(event.relatedTarget)))
- return;
- isFocused.value = false;
- emit("blur", event);
- afterBlur == null ? void 0 : afterBlur();
- };
- const handleClick = () => {
- var _a, _b;
- if (((_a = wrapperRef.value) == null ? void 0 : _a.contains(document.activeElement)) && wrapperRef.value !== document.activeElement)
- return;
- (_b = target.value) == null ? void 0 : _b.focus();
- };
- vue.watch(wrapperRef, (el) => {
- if (el) {
- el.setAttribute("tabindex", "-1");
- }
- });
- core.useEventListener(wrapperRef, "focus", handleFocus, true);
- core.useEventListener(wrapperRef, "blur", handleBlur, true);
- core.useEventListener(wrapperRef, "click", handleClick, true);
- if (process.env.NODE_ENV === "test") {
- vue.onMounted(() => {
- const targetEl = types.isElement(target.value) ? target.value : document.querySelector("input,textarea");
- if (targetEl) {
- core.useEventListener(targetEl, "focus", handleFocus, true);
- core.useEventListener(targetEl, "blur", handleBlur, true);
- }
- });
- }
- return {
- isFocused,
- wrapperRef,
- handleFocus,
- handleBlur
- };
- }
- exports.useFocusController = useFocusController;
- //# sourceMappingURL=index.js.map
|