index.js 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var core = require('@vueuse/core');
  5. var aria = require('../../utils/dom/aria.js');
  6. var shared = require('@vue/shared');
  7. function useFocusController(target, {
  8. disabled,
  9. beforeFocus,
  10. afterFocus,
  11. beforeBlur,
  12. afterBlur
  13. } = {}) {
  14. const instance = vue.getCurrentInstance();
  15. const { emit } = instance;
  16. const wrapperRef = vue.shallowRef();
  17. const isFocused = vue.ref(false);
  18. const handleFocus = (event) => {
  19. const cancelFocus = shared.isFunction(beforeFocus) ? beforeFocus(event) : false;
  20. if (vue.unref(disabled) || isFocused.value || cancelFocus)
  21. return;
  22. isFocused.value = true;
  23. emit("focus", event);
  24. afterFocus == null ? void 0 : afterFocus();
  25. };
  26. const handleBlur = (event) => {
  27. var _a;
  28. const cancelBlur = shared.isFunction(beforeBlur) ? beforeBlur(event) : false;
  29. if (vue.unref(disabled) || event.relatedTarget && ((_a = wrapperRef.value) == null ? void 0 : _a.contains(event.relatedTarget)) || cancelBlur)
  30. return;
  31. isFocused.value = false;
  32. emit("blur", event);
  33. afterBlur == null ? void 0 : afterBlur();
  34. };
  35. const handleClick = (event) => {
  36. var _a, _b;
  37. if (vue.unref(disabled) || aria.isFocusable(event.target) || ((_a = wrapperRef.value) == null ? void 0 : _a.contains(document.activeElement)) && wrapperRef.value !== document.activeElement)
  38. return;
  39. (_b = target.value) == null ? void 0 : _b.focus();
  40. };
  41. vue.watch([wrapperRef, () => vue.unref(disabled)], ([el, disabled2]) => {
  42. if (!el)
  43. return;
  44. if (disabled2) {
  45. el.removeAttribute("tabindex");
  46. } else {
  47. el.setAttribute("tabindex", "-1");
  48. }
  49. });
  50. core.useEventListener(wrapperRef, "focus", handleFocus, true);
  51. core.useEventListener(wrapperRef, "blur", handleBlur, true);
  52. core.useEventListener(wrapperRef, "click", handleClick, true);
  53. return {
  54. isFocused,
  55. wrapperRef,
  56. handleFocus,
  57. handleBlur
  58. };
  59. }
  60. exports.useFocusController = useFocusController;
  61. //# sourceMappingURL=index.js.map