Skip to content

Commit

Permalink
Filter and sort dropdowns fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
JanJaroszczak committed Mar 25, 2024
1 parent 37b0c5f commit a23e9ab
Show file tree
Hide file tree
Showing 8 changed files with 72 additions and 63 deletions.
30 changes: 0 additions & 30 deletions govtool/frontend/src/components/atoms/ClickOutside.tsx

This file was deleted.

1 change: 0 additions & 1 deletion govtool/frontend/src/components/atoms/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ export * from "./ActionRadio";
export * from "./Background";
export * from "./Button";
export * from "./Checkbox";
export * from "./ClickOutside";
export * from "./CopyButton";
export * from "./DrawerLink";
export * from "./ExternalModalButton";
Expand Down
34 changes: 16 additions & 18 deletions govtool/frontend/src/components/molecules/DataActionsBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ import Search from "@mui/icons-material/Search";

import { GovernanceActionsFilters, GovernanceActionsSorting } from "@molecules";
import { OrderActionsChip } from "./OrderActionsChip";
import { ClickOutside } from "../atoms";
import { theme } from "@/theme";

type DataActionsBarProps = {
Expand Down Expand Up @@ -86,24 +85,23 @@ export const DataActionsBar: FC<DataActionsBarProps> = ({ ...props }) => {
setSortOpen={setSortOpen}
sortingActive={sortingActive}
sortOpen={sortOpen}
/>
>
{filtersOpen && (
<GovernanceActionsFilters
chosenFilters={chosenFilters}
setChosenFilters={setChosenFilters}
closeFilters={closeFilters}
/>
)}
{sortOpen && (
<GovernanceActionsSorting
chosenSorting={chosenSorting}
setChosenSorting={setChosenSorting}
closeSorts={closeSorts}
/>
)}
</OrderActionsChip>
</Box>
{filtersOpen && (
<ClickOutside onClick={closeFilters}>
<GovernanceActionsFilters
chosenFilters={chosenFilters}
setChosenFilters={setChosenFilters}
/>
</ClickOutside>
)}
{sortOpen && (
<ClickOutside onClick={closeSorts}>
<GovernanceActionsSorting
chosenSorting={chosenSorting}
setChosenSorting={setChosenSorting}
/>
</ClickOutside>
)}
</>
);
};
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Dispatch, SetStateAction, useCallback } from "react";
import { Dispatch, SetStateAction, useCallback, useRef } from "react";
import {
Box,
Checkbox,
Expand All @@ -8,16 +8,18 @@ import {
} from "@mui/material";

import { GOVERNANCE_ACTIONS_FILTERS } from "@consts";
import { useScreenDimension, useTranslation } from "@hooks";
import { useOnClickOutside, useScreenDimension, useTranslation } from "@hooks";

interface Props {
chosenFilters: string[];
setChosenFilters: Dispatch<SetStateAction<string[]>>;
closeFilters: () => void;
}

export const GovernanceActionsFilters = ({
chosenFilters,
setChosenFilters,
closeFilters,
}: Props) => {
const handleFilterChange = useCallback(
(e: React.ChangeEvent<HTMLInputElement>) => {
Expand All @@ -36,7 +38,10 @@ export const GovernanceActionsFilters = ({
);

const { t } = useTranslation();
const { isMobile } = useScreenDimension();
const { isMobile, screenWidth } = useScreenDimension();

const wrapperRef = useRef<HTMLDivElement>(null);
useOnClickOutside(wrapperRef, closeFilters);

return (
<Box
Expand All @@ -48,11 +53,12 @@ export const GovernanceActionsFilters = ({
boxShadow: "1px 2px 11px 0px #00123D5E",
borderRadius: "10px",
padding: "12px 0px",
width: "auto",
width: screenWidth < 850 ? "315px" : "415px",
zIndex: "1",
right: isMobile ? "73px" : "141px",
top: isMobile ? "274px" : "200px",
right: isMobile ? "59px" : "115px",
top: "53px",
}}
ref={wrapperRef}
>
<FormLabel
sx={{
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Dispatch, SetStateAction } from "react";
import { Dispatch, SetStateAction, useRef } from "react";
import {
Box,
FormControl,
Expand All @@ -9,19 +9,23 @@ import {
} from "@mui/material";

import { GOVERNANCE_ACTIONS_SORTING } from "@consts";
import { useScreenDimension, useTranslation } from "@hooks";
import { useTranslation, useOnClickOutside } from "@hooks";

interface Props {
chosenSorting: string;
setChosenSorting: Dispatch<SetStateAction<string>>;
closeSorts: () => void;
}

export const GovernanceActionsSorting = ({
chosenSorting,
setChosenSorting,
closeSorts,
}: Props) => {
const { t } = useTranslation();
const { isMobile } = useScreenDimension();

const wrapperRef = useRef<HTMLDivElement>(null);
useOnClickOutside(wrapperRef, closeSorts);

return (
<Box
Expand All @@ -33,11 +37,12 @@ export const GovernanceActionsSorting = ({
boxShadow: "1px 2px 11px 0px #00123D5E",
borderRadius: "10px",
padding: "12px 0px",
width: "auto",
width: "315px",
zIndex: "1",
right: isMobile ? "17px" : "29px",
top: isMobile ? "274px" : "200px",
right: "3px",
top: "53px",
}}
ref={wrapperRef}
>
<FormControl>
<Box display="flex" justifyContent="space-between" px="20px">
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ type Props = {
sortOpen: boolean;
setSortOpen: Dispatch<SetStateAction<boolean>>;
sortingActive: boolean;
children?: React.ReactNode;
isFiltering?: boolean;
};

Expand All @@ -32,6 +33,7 @@ export const OrderActionsChip = (props: Props) => {
setSortOpen,
sortingActive,
isFiltering = true,
children,
} = props;

return (
Expand All @@ -41,6 +43,8 @@ export const OrderActionsChip = (props: Props) => {
alignItems="center"
ml="8px"
gap={isMobile ? "8px" : "24px"}
position="relative"
sx={{ alignSelf: "end" }}
>
{isFiltering && (
<Box
Expand Down Expand Up @@ -185,6 +189,7 @@ export const OrderActionsChip = (props: Props) => {
</Box>
)}
</Box>
{children}
</Box>
);
};
5 changes: 3 additions & 2 deletions govtool/frontend/src/hooks/index.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
export { useTranslation } from "react-i18next";
export * from "./useFetchNextPageDetector";
export * from "./useOutsideClick";
export * from "./useSaveScrollPosition";
export * from "./useScreenDimension";
export * from "./useSlider";
export * from "./useSaveScrollPosition";
export * from "./useFetchNextPageDetector";
export * from "./useWalletConnectionListener";

export * from "./forms";
Expand Down
25 changes: 25 additions & 0 deletions govtool/frontend/src/hooks/useOutsideClick.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import { MutableRefObject, useEffect } from "react";

export function useOnClickOutside(
ref: MutableRefObject<HTMLDivElement | HTMLLIElement | null>,
handler: (event: MouseEvent | TouchEvent) => void,
) {
useEffect(() => {
const listener = (event: MouseEvent | TouchEvent) => {
const target = event.target as Node;

if (!ref.current || ref.current.contains(target)) {
return;
}
handler(event);
};

document.addEventListener("mousedown", listener as EventListener);
document.addEventListener("touchstart", listener as EventListener);

return () => {
document.removeEventListener("mousedown", listener as EventListener);
document.removeEventListener("touchstart", listener as EventListener);
};
}, [ref, handler]);
}

0 comments on commit a23e9ab

Please sign in to comment.