From 1c447731aa91d89bcde812d957c7ba91887beb93 Mon Sep 17 00:00:00 2001 From: Ben Furber Date: Wed, 18 Dec 2024 14:41:19 +0000 Subject: [PATCH] feat: add vertical category view to research --- src/pages/Research/Content/ResearchList.tsx | 81 ++--------- ...ilterHeader.tsx => ResearchListHeader.tsx} | 132 ++++++++++++------ 2 files changed, 102 insertions(+), 111 deletions(-) rename src/pages/Research/Content/{ResearchFilterHeader.tsx => ResearchListHeader.tsx} (54%) diff --git a/src/pages/Research/Content/ResearchList.tsx b/src/pages/Research/Content/ResearchList.tsx index 303317e5c1..a27474995d 100644 --- a/src/pages/Research/Content/ResearchList.tsx +++ b/src/pages/Research/Content/ResearchList.tsx @@ -1,31 +1,23 @@ import { useEffect, useState } from 'react' -import { Link, useSearchParams } from '@remix-run/react' +import { useSearchParams } from '@remix-run/react' import { observer } from 'mobx-react' import { Button, Loader } from 'oa-components' -import { AuthWrapper } from 'src/common/AuthWrapper' -import { useCommonStores } from 'src/common/hooks/useCommonStores' -import { isPreciousPlastic } from 'src/config/config' import { logger } from 'src/logger' -import DraftButton from 'src/pages/common/Drafts/DraftButton' import useDrafts from 'src/pages/common/Drafts/useDrafts' -import { Box, Flex, Heading, useThemeUI } from 'theme-ui' +import { Box, Flex } from 'theme-ui' -import { ITEMS_PER_PAGE, RESEARCH_EDITOR_ROLES } from '../constants' +import { ITEMS_PER_PAGE } from '../constants' import { listing } from '../labels' import { researchService } from '../research.service' -import { ResearchFilterHeader } from './ResearchFilterHeader' +import { ResearchFilterHeader } from './ResearchListHeader' import ResearchListItem from './ResearchListItem' import { ResearchSearchParams } from './ResearchSearchParams' import type { DocumentData, QueryDocumentSnapshot } from 'firebase/firestore' import type { IResearch, ResearchStatus } from 'oa-shared' -import type { ThemeWithName } from 'oa-themes' import type { ResearchSortOption } from '../ResearchSortOptions' const ResearchList = observer(() => { - const themeUi = useThemeUI() - const theme = themeUi.theme as ThemeWithName - const { userStore } = useCommonStores().stores const [isFetching, setIsFetching] = useState(true) const [researchItems, setResearchItems] = useState([]) const { draftCount, isFetchingDrafts, drafts, showDrafts, handleShowDrafts } = @@ -98,63 +90,12 @@ const ResearchList = observer(() => { } return ( - <> - - - {listing.heading} - - - - - {!showDrafts ? :
} - - - {isPreciousPlastic() ? ( - <> - {userStore.activeUser && ( - - )} - - - - - ) : ( - - - - - - - )} - -
+ + {showDrafts ? (
    @@ -197,7 +138,7 @@ const ResearchList = observer(() => { )} {(isFetching || isFetchingDrafts) && } - + ) }) export default ResearchList diff --git a/src/pages/Research/Content/ResearchFilterHeader.tsx b/src/pages/Research/Content/ResearchListHeader.tsx similarity index 54% rename from src/pages/Research/Content/ResearchFilterHeader.tsx rename to src/pages/Research/Content/ResearchListHeader.tsx index c1d4ac54e8..eedcad450c 100644 --- a/src/pages/Research/Content/ResearchFilterHeader.tsx +++ b/src/pages/Research/Content/ResearchListHeader.tsx @@ -1,20 +1,31 @@ import { useCallback, useEffect, useState } from 'react' -import { useSearchParams } from '@remix-run/react' +import { Link, useSearchParams } from '@remix-run/react' import debounce from 'debounce' -import { SearchField, Select } from 'oa-components' +import { CategoryVerticalList, SearchField, Select } from 'oa-components' import { ResearchStatus } from 'oa-shared' +import { AuthWrapper } from 'src/common/AuthWrapper' import { FieldContainer } from 'src/common/Form/FieldContainer' -import { Flex } from 'theme-ui' +import { useCommonStores } from 'src/common/hooks/useCommonStores' +import { isPreciousPlastic } from 'src/config/config' +import DraftButton from 'src/pages/common/Drafts/DraftButton' +import { ListHeader } from 'src/pages/common/Layout/ListHeader' +import { Button, Flex } from 'theme-ui' -import { CategoriesSelectV2 } from '../../common/Category/CategoriesSelectV2' +import { RESEARCH_EDITOR_ROLES } from '../constants' import { listing } from '../labels' import { researchService } from '../research.service' import { ResearchSortOptions } from '../ResearchSortOptions' import { ResearchSearchParams } from './ResearchSearchParams' -import type { SelectValue } from '../../common/Category/CategoriesSelectV2' +import type { ICategory } from 'oa-shared' import type { ResearchSortOption } from '../ResearchSortOptions' +interface IProps { + draftCount: number + handleShowDrafts: () => void + showDrafts: boolean +} + const researchStatusOptions = [ { label: 'All', value: '' }, ...Object.values(ResearchStatus).map((x) => ({ @@ -23,33 +34,29 @@ const researchStatusOptions = [ })), ] -export const ResearchFilterHeader = () => { - const [categories, setCategories] = useState([]) +export const ResearchFilterHeader = (props: IProps) => { + const { draftCount, handleShowDrafts, showDrafts } = props + + const [categories, setCategories] = useState([]) const [searchString, setSearchString] = useState('') const [searchParams, setSearchParams] = useSearchParams() const categoryParam = searchParams.get(ResearchSearchParams.category) - const category = categories?.find((x) => x.value === categoryParam) ?? null + const category = categories?.find((x) => x._id === categoryParam) ?? null const q = searchParams.get(ResearchSearchParams.q) const sort = searchParams.get(ResearchSearchParams.sort) as ResearchSortOption const status = (searchParams.get(ResearchSearchParams.status) as ResearchStatus) || '' - // TODO: create a library component for this - const _inputStyle = { - width: ['100%', '100%', '230px'], - mr: [0, 0, 2], - mb: [3, 3, 0], - } + const isUserLoggedIn = useCommonStores().stores.userStore?.user useEffect(() => { const initCategories = async () => { const categories = (await researchService.getResearchCategories()) || [] - setCategories( - categories.map((x) => { - return { value: x._id, label: x.label } - }), + const notDeletedCategories = categories.filter( + ({ _deleted }) => _deleted === false, ) + setCategories(notDeletedCategories) } initCategories() @@ -71,7 +78,7 @@ export const ResearchFilterHeader = () => { const onSearchInputChange = useCallback( debounce((value: string) => { searchValue(value) - }, 1000), + }, 500), [searchParams], ) @@ -90,29 +97,62 @@ export const ResearchFilterHeader = () => { setSearchParams(params) } - return ( + const actionComponents = ( + <> + {isPreciousPlastic() ? ( + <> + {isUserLoggedIn && ( + + )} + + + + + ) : ( + + + + + + + )} + + ) + + const categoryComponent = ( + + updateFilter( + ResearchSearchParams.category, + updatedCategory ? updatedCategory._id : '', + ) + } + /> + ) + + const filteringComponents = ( - {/* Categories */} - - - updateFilter(ResearchSearchParams.category, updatedCategory) - } - placeholder={listing.filterCategory} - isForm={false} - categories={categories} - /> - - {/* Sort */} - + { /> - {/* Text search */} - + + { ) + + return ( + + ) }