From 80461e6484de47b6c80f347cb7d539f736ff7722 Mon Sep 17 00:00:00 2001 From: Anmol Singh Bhatia <121005188+anmolsinghbhatia@users.noreply.github.com> Date: Fri, 26 Apr 2024 13:21:08 +0530 Subject: [PATCH] chore: filter member option sorting improvement (#4285) --- web/components/modules/dropdowns/filters/lead.tsx | 13 ++++++++----- .../modules/dropdowns/filters/members.tsx | 10 ++++++---- web/components/pages/list/filters/created-by.tsx | 9 ++++++--- web/components/project/dropdowns/filters/lead.tsx | 10 ++++++---- .../project/dropdowns/filters/members.tsx | 10 ++++++---- 5 files changed, 32 insertions(+), 20 deletions(-) diff --git a/web/components/modules/dropdowns/filters/lead.tsx b/web/components/modules/dropdowns/filters/lead.tsx index b8dc8a9d4..9fa1ea5d5 100644 --- a/web/components/modules/dropdowns/filters/lead.tsx +++ b/web/components/modules/dropdowns/filters/lead.tsx @@ -4,7 +4,7 @@ import { observer } from "mobx-react-lite"; // hooks import { Avatar, Loader } from "@plane/ui"; import { FilterHeader, FilterOption } from "@/components/issues"; -import { useMember } from "@/hooks/store"; +import { useMember, useUser } from "@/hooks/store"; // components // ui @@ -22,19 +22,22 @@ export const FilterLead: React.FC = observer((props: Props) => { const [previewEnabled, setPreviewEnabled] = useState(true); // store hooks const { getUserDetails } = useMember(); + const { currentUser } = useUser(); const appliedFiltersCount = appliedFilters?.length ?? 0; const sortedOptions = useMemo(() => { - const filteredOptions = (memberIds || []).filter( - (memberId) => getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) + const filteredOptions = (memberIds || []).filter((memberId) => + getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) ); return sortBy(filteredOptions, [ (memberId) => !(appliedFilters ?? []).includes(memberId), + (memberId) => memberId !== currentUser?.id, (memberId) => getUserDetails(memberId)?.display_name.toLowerCase(), ]); - }, [appliedFilters, getUserDetails, memberIds, , searchQuery]); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [searchQuery]); const handleViewToggle = () => { if (!sortedOptions) return; @@ -65,7 +68,7 @@ export const FilterLead: React.FC = observer((props: Props) => { isChecked={appliedFilters?.includes(member.id) ? true : false} onClick={() => handleUpdate(member.id)} icon={} - title={member.display_name} + title={currentUser?.id === member.id ? "You" : member?.display_name} /> ); })} diff --git a/web/components/modules/dropdowns/filters/members.tsx b/web/components/modules/dropdowns/filters/members.tsx index 3db1f5d04..1a23d0c3e 100644 --- a/web/components/modules/dropdowns/filters/members.tsx +++ b/web/components/modules/dropdowns/filters/members.tsx @@ -4,7 +4,7 @@ import { observer } from "mobx-react-lite"; // hooks import { Avatar, Loader } from "@plane/ui"; import { FilterHeader, FilterOption } from "@/components/issues"; -import { useMember } from "@/hooks/store"; +import { useMember, useUser } from "@/hooks/store"; // components // ui @@ -22,16 +22,18 @@ export const FilterMembers: React.FC = observer((props: Props) => { const [previewEnabled, setPreviewEnabled] = useState(true); // store hooks const { getUserDetails } = useMember(); + const { currentUser } = useUser(); const appliedFiltersCount = appliedFilters?.length ?? 0; const sortedOptions = useMemo(() => { - const filteredOptions = (memberIds || []).filter( - (memberId) => getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) + const filteredOptions = (memberIds || []).filter((memberId) => + getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) ); return sortBy(filteredOptions, [ (memberId) => !(appliedFilters ?? []).includes(memberId), + (memberId) => memberId !== currentUser?.id, (memberId) => getUserDetails(memberId)?.display_name.toLowerCase(), ]); // eslint-disable-next-line react-hooks/exhaustive-deps @@ -66,7 +68,7 @@ export const FilterMembers: React.FC = observer((props: Props) => { isChecked={appliedFilters?.includes(member.id) ? true : false} onClick={() => handleUpdate(member.id)} icon={} - title={member.display_name} + title={currentUser?.id === member.id ? "You" : member?.display_name} /> ); })} diff --git a/web/components/pages/list/filters/created-by.tsx b/web/components/pages/list/filters/created-by.tsx index bddacc550..a90d8bd14 100644 --- a/web/components/pages/list/filters/created-by.tsx +++ b/web/components/pages/list/filters/created-by.tsx @@ -6,7 +6,7 @@ import { Avatar, Loader } from "@plane/ui"; // components import { FilterHeader, FilterOption } from "@/components/issues"; // hooks -import { useMember } from "@/hooks/store"; +import { useMember, useUser } from "@/hooks/store"; type Props = { appliedFilters: string[] | null; @@ -22,6 +22,7 @@ export const FilterCreatedBy: React.FC = observer((props: Props) => { const [previewEnabled, setPreviewEnabled] = useState(true); // store hooks const { getUserDetails } = useMember(); + const { currentUser } = useUser(); const appliedFiltersCount = appliedFilters?.length ?? 0; @@ -32,9 +33,11 @@ export const FilterCreatedBy: React.FC = observer((props: Props) => { return sortBy(filteredOptions, [ (memberId) => !(appliedFilters ?? []).includes(memberId), + (memberId) => memberId !== currentUser?.id, (memberId) => getUserDetails(memberId)?.display_name.toLowerCase(), ]); - }, [appliedFilters, getUserDetails, memberIds, searchQuery]); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [searchQuery]); const handleViewToggle = () => { if (!sortedOptions) return; @@ -65,7 +68,7 @@ export const FilterCreatedBy: React.FC = observer((props: Props) => { isChecked={appliedFilters?.includes(member.id) ? true : false} onClick={() => handleUpdate(member.id)} icon={} - title={member.display_name} + title={currentUser?.id === member.id ? "You" : member?.display_name} /> ); })} diff --git a/web/components/project/dropdowns/filters/lead.tsx b/web/components/project/dropdowns/filters/lead.tsx index 2bfea97df..9fa1ea5d5 100644 --- a/web/components/project/dropdowns/filters/lead.tsx +++ b/web/components/project/dropdowns/filters/lead.tsx @@ -4,7 +4,7 @@ import { observer } from "mobx-react-lite"; // hooks import { Avatar, Loader } from "@plane/ui"; import { FilterHeader, FilterOption } from "@/components/issues"; -import { useMember } from "@/hooks/store"; +import { useMember, useUser } from "@/hooks/store"; // components // ui @@ -22,16 +22,18 @@ export const FilterLead: React.FC = observer((props: Props) => { const [previewEnabled, setPreviewEnabled] = useState(true); // store hooks const { getUserDetails } = useMember(); + const { currentUser } = useUser(); const appliedFiltersCount = appliedFilters?.length ?? 0; const sortedOptions = useMemo(() => { - const filteredOptions = (memberIds || []).filter( - (memberId) => getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) + const filteredOptions = (memberIds || []).filter((memberId) => + getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) ); return sortBy(filteredOptions, [ (memberId) => !(appliedFilters ?? []).includes(memberId), + (memberId) => memberId !== currentUser?.id, (memberId) => getUserDetails(memberId)?.display_name.toLowerCase(), ]); // eslint-disable-next-line react-hooks/exhaustive-deps @@ -66,7 +68,7 @@ export const FilterLead: React.FC = observer((props: Props) => { isChecked={appliedFilters?.includes(member.id) ? true : false} onClick={() => handleUpdate(member.id)} icon={} - title={member.display_name} + title={currentUser?.id === member.id ? "You" : member?.display_name} /> ); })} diff --git a/web/components/project/dropdowns/filters/members.tsx b/web/components/project/dropdowns/filters/members.tsx index 3db1f5d04..1a23d0c3e 100644 --- a/web/components/project/dropdowns/filters/members.tsx +++ b/web/components/project/dropdowns/filters/members.tsx @@ -4,7 +4,7 @@ import { observer } from "mobx-react-lite"; // hooks import { Avatar, Loader } from "@plane/ui"; import { FilterHeader, FilterOption } from "@/components/issues"; -import { useMember } from "@/hooks/store"; +import { useMember, useUser } from "@/hooks/store"; // components // ui @@ -22,16 +22,18 @@ export const FilterMembers: React.FC = observer((props: Props) => { const [previewEnabled, setPreviewEnabled] = useState(true); // store hooks const { getUserDetails } = useMember(); + const { currentUser } = useUser(); const appliedFiltersCount = appliedFilters?.length ?? 0; const sortedOptions = useMemo(() => { - const filteredOptions = (memberIds || []).filter( - (memberId) => getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) + const filteredOptions = (memberIds || []).filter((memberId) => + getUserDetails(memberId)?.display_name.toLowerCase().includes(searchQuery.toLowerCase()) ); return sortBy(filteredOptions, [ (memberId) => !(appliedFilters ?? []).includes(memberId), + (memberId) => memberId !== currentUser?.id, (memberId) => getUserDetails(memberId)?.display_name.toLowerCase(), ]); // eslint-disable-next-line react-hooks/exhaustive-deps @@ -66,7 +68,7 @@ export const FilterMembers: React.FC = observer((props: Props) => { isChecked={appliedFilters?.includes(member.id) ? true : false} onClick={() => handleUpdate(member.id)} icon={} - title={member.display_name} + title={currentUser?.id === member.id ? "You" : member?.display_name} /> ); })}