index.js 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var core = require('@vueuse/core');
  5. var index = require('../use-prop/index.js');
  6. var types = require('../../utils/types.js');
  7. var shared = require('@vue/shared');
  8. function useFocusController(target, {
  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 disabled = index.useProp("disabled");
  18. const isFocused = vue.ref(false);
  19. const handleFocus = (event) => {
  20. const cancelFocus = shared.isFunction(beforeFocus) ? beforeFocus(event) : false;
  21. if (cancelFocus || isFocused.value)
  22. return;
  23. isFocused.value = true;
  24. emit("focus", event);
  25. afterFocus == null ? void 0 : afterFocus();
  26. };
  27. const handleBlur = (event) => {
  28. var _a;
  29. const cancelBlur = shared.isFunction(beforeBlur) ? beforeBlur(event) : false;
  30. if (cancelBlur || event.relatedTarget && ((_a = wrapperRef.value) == null ? void 0 : _a.contains(event.relatedTarget)))
  31. return;
  32. isFocused.value = false;
  33. emit("blur", event);
  34. afterBlur == null ? void 0 : afterBlur();
  35. };
  36. const handleClick = () => {
  37. var _a, _b;
  38. if (((_a = wrapperRef.value) == null ? void 0 : _a.contains(document.activeElement)) && wrapperRef.value !== document.activeElement || disabled.value)
  39. return;
  40. (_b = target.value) == null ? void 0 : _b.focus();
  41. };
  42. vue.watch([wrapperRef, disabled], ([el, disabled2]) => {
  43. if (!el)
  44. return;
  45. if (disabled2) {
  46. el.removeAttribute("tabindex");
  47. } else {
  48. el.setAttribute("tabindex", "-1");
  49. }
  50. });
  51. core.useEventListener(wrapperRef, "focus", handleFocus, true);
  52. core.useEventListener(wrapperRef, "blur", handleBlur, true);
  53. core.useEventListener(wrapperRef, "click", handleClick, true);
  54. if (process.env.NODE_ENV === "test") {
  55. vue.onMounted(() => {
  56. const targetEl = types.isElement(target.value) ? target.value : document.querySelector("input,textarea");
  57. if (targetEl) {
  58. core.useEventListener(targetEl, "focus", handleFocus, true);
  59. core.useEventListener(targetEl, "blur", handleBlur, true);
  60. }
  61. });
  62. }
  63. return {
  64. isFocused,
  65. wrapperRef,
  66. handleFocus,
  67. handleBlur
  68. };
  69. }
  70. exports.useFocusController = useFocusController;
  71. //# sourceMappingURL=index.js.map