Skip to content

Commit

Permalink
feat: add sort by date for results in sidebar (#444)
Browse files Browse the repository at this point in the history
* feat: add sort by date for results in sidebar

* fix: fix build

---------

Co-authored-by: Расул <[email protected]>
  • Loading branch information
Rassl and Расул authored Sep 27, 2023
1 parent 4f0aad6 commit 469d978
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 14 deletions.
2 changes: 1 addition & 1 deletion src/components/App/SideBar/Latest/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ const _View = ({ isSearchResult }: Props) => (
</span>
</div>
)}
<Relevance />
<Relevance isSearchResult={isSearchResult} />
</Wrapper>
)

Expand Down
21 changes: 9 additions & 12 deletions src/components/App/SideBar/Relevance/index.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { Button } from '@mui/material'
import { ReactNode, useCallback, useMemo, useRef, useState } from 'react'
import { useCallback, useMemo, useRef, useState } from 'react'
import styled from 'styled-components'
import { useGraphData } from '~/components/DataRetriever'
import { ScrollView } from '~/components/ScrollView'
Expand All @@ -10,23 +10,21 @@ import { NodeExtended } from '~/types'
import { formatDescription } from '~/utils/formatDescription'
import { saveConsumedContent } from '~/utils/relayHelper'
import { useIsMatchBreakpoint } from '~/utils/useIsMatchBreakpoint'
import { ErrorSection } from '../Creator/ErrorSection'
import { Episode } from './Episode'

const pageSize = 80

type Props = {
header?: ReactNode
isSearchResult: boolean
}

export const Relevance = ({ header = null }: Props) => {
export const Relevance = ({ isSearchResult }: Props) => {
const data = useGraphData()

const scrollViewRef = useRef<HTMLDivElement | null>(null)

const pageSize = !isSearchResult ? 10 : 80

const setSelectedNode = useDataStore((s) => s.setSelectedNode)
const setSelectedTimestamp = useDataStore((s) => s.setSelectedTimestamp)
const flagErrorIsOpen = useAppStore((s) => s.flagErrorIsOpen)

const [setSidebarOpen] = useAppStore((s) => [s.setSidebarOpen])
const setRelevanceSelected = useAppStore((s) => s.setRelevanceSelected)
Expand All @@ -40,7 +38,10 @@ export const Relevance = ({ header = null }: Props) => {

const isMobile = useIsMatchBreakpoint('sm', 'down')

const currentNodes = useMemo(() => data.nodes.slice(0, endSlice), [data.nodes, endSlice])
const currentNodes = useMemo(
() => [...data.nodes].sort((a, b) => (b.date || 0) - (a.date || 0)).slice(0, endSlice),
[data.nodes, endSlice],
)

const handleNodeClick = useCallback(
(node: NodeExtended) => {
Expand All @@ -55,11 +56,7 @@ export const Relevance = ({ header = null }: Props) => {

return (
<>
{!header && flagErrorIsOpen && <ErrorSection />}

<ScrollView ref={scrollViewRef} id="search-result-list" shrink={1}>
{header}

{currentNodes.map((n, index) => {
const {
image_url: imageUrl,
Expand Down
2 changes: 1 addition & 1 deletion src/components/App/SideBar/View/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ const _View = ({ isSelectedView }: Props) => {
return <Creator />
}
} else {
return <Relevance />
return <Relevance isSearchResult />
}
}

Expand Down

0 comments on commit 469d978

Please sign in to comment.