fix: auto close dropdowns in the create issue modal when we navigate through keyboard

This commit is contained in:
gurusainath 2024-03-20 16:43:03 +05:30
parent 2f883e4939
commit 1d93719d44
9 changed files with 37 additions and 2 deletions

View File

@ -8,6 +8,7 @@ import { cn } from "@/helpers/common.helper";
import { useCycle } from "@/hooks/store"; import { useCycle } from "@/hooks/store";
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
// components // components
import { DropdownButton } from "../buttons"; import { DropdownButton } from "../buttons";
// icons // icons
@ -84,6 +85,7 @@ export const CycleDropdown: React.FC<Props> = observer((props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
return ( return (
<Combobox <Combobox

View File

@ -9,6 +9,7 @@ import { renderFormattedDate, getDate } from "@/helpers/date-time.helper";
// hooks // hooks
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
// components // components
import { DropdownButton } from "./buttons"; import { DropdownButton } from "./buttons";
// types // types
@ -103,6 +104,7 @@ export const DateDropdown: React.FC<Props> = (props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
const disabledDays: Matcher[] = []; const disabledDays: Matcher[] = [];
if (minDate) disabledDays.push({ before: minDate }); if (minDate) disabledDays.push({ before: minDate });

View File

@ -9,6 +9,7 @@ import { cn } from "@/helpers/common.helper";
import { useApplication, useEstimate } from "@/hooks/store"; import { useApplication, useEstimate } from "@/hooks/store";
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
// components // components
import { DropdownButton } from "./buttons"; import { DropdownButton } from "./buttons";
// helpers // helpers
@ -146,6 +147,7 @@ export const EstimateDropdown: React.FC<Props> = observer((props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
useEffect(() => { useEffect(() => {
if (isOpen && inputRef.current) { if (isOpen && inputRef.current) {

View File

@ -7,6 +7,7 @@ import { cn } from "@/helpers/common.helper";
import { useMember } from "@/hooks/store"; import { useMember } from "@/hooks/store";
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
// components // components
import { DropdownButton } from "../buttons"; import { DropdownButton } from "../buttons";
import { BUTTON_VARIANTS_WITH_TEXT } from "../constants"; import { BUTTON_VARIANTS_WITH_TEXT } from "../constants";
@ -84,6 +85,7 @@ export const MemberDropdown: React.FC<Props> = observer((props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
return ( return (
<Combobox <Combobox

View File

@ -8,6 +8,7 @@ import { cn } from "@/helpers/common.helper";
import { useModule } from "@/hooks/store"; import { useModule } from "@/hooks/store";
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
import { usePlatformOS } from "@/hooks/use-platform-os"; import { usePlatformOS } from "@/hooks/use-platform-os";
// components // components
import { DropdownButton } from "../buttons"; import { DropdownButton } from "../buttons";
@ -201,6 +202,7 @@ export const ModuleDropdown: React.FC<Props> = observer((props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
const comboboxProps: any = { const comboboxProps: any = {
value, value,

View File

@ -10,6 +10,7 @@ import { ISSUE_PRIORITIES } from "@/constants/issue";
import { cn } from "@/helpers/common.helper"; import { cn } from "@/helpers/common.helper";
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
import { usePlatformOS } from "@/hooks/use-platform-os"; import { usePlatformOS } from "@/hooks/use-platform-os";
// icons // icons
// helpers // helpers
@ -360,6 +361,7 @@ export const PriorityDropdown: React.FC<Props> = (props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
const ButtonToRender = BORDER_BUTTON_VARIANTS.includes(buttonVariant) const ButtonToRender = BORDER_BUTTON_VARIANTS.includes(buttonVariant)
? BorderButton ? BorderButton

View File

@ -9,6 +9,7 @@ import { cn } from "@/helpers/common.helper";
import { useApplication, useProjectState } from "@/hooks/store"; import { useApplication, useProjectState } from "@/hooks/store";
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
// components // components
import { DropdownButton } from "./buttons"; import { DropdownButton } from "./buttons";
// icons // icons
@ -128,6 +129,7 @@ export const StateDropdown: React.FC<Props> = observer((props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
useEffect(() => { useEffect(() => {
if (isOpen && inputRef.current) { if (isOpen && inputRef.current) {

View File

@ -9,6 +9,7 @@ import { IssueLabelsList } from "@/components/ui";
import { useLabel } from "@/hooks/store"; import { useLabel } from "@/hooks/store";
import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down"; import { useDropdownKeyDown } from "@/hooks/use-dropdown-key-down";
import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector";
import useOutsideKeydownDetector from "@/hooks/use-outside-keydown-detector";
// ui // ui
// icons // icons
@ -76,6 +77,7 @@ export const IssueLabelSelect: React.FC<Props> = observer((props) => {
}; };
useOutsideClickDetector(dropdownRef, handleClose); useOutsideClickDetector(dropdownRef, handleClose);
useOutsideKeydownDetector(dropdownRef, handleClose);
useEffect(() => { useEffect(() => {
if (isDropdownOpen && inputRef.current) { if (isDropdownOpen && inputRef.current) {

View File

@ -0,0 +1,19 @@
import React, { useEffect } from "react";
const useOutsideKeydownDetector = (ref: React.RefObject<HTMLElement>, callback: () => void) => {
const handleKeyDown = (event: KeyboardEvent) => {
if (ref.current && !ref.current.contains(event.target as Node)) {
callback();
}
};
useEffect(() => {
document.addEventListener("keydown", handleKeyDown);
return () => {
document.removeEventListener("keydown", handleKeyDown);
};
});
};
export default useOutsideKeydownDetector;