Merge pull request #4881 from h3poteto/feat/maxId

Handle nextId in link header when favourites and bookmarks
This commit is contained in:
AkiraFukushima 2024-03-09 01:08:30 +09:00 committed by GitHub
commit 84be91bf1e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 42 additions and 3 deletions

View File

@ -28,6 +28,7 @@
"electron-store": "^8.1.0", "electron-store": "^8.1.0",
"emoji-mart": "^5.5.2", "emoji-mart": "^5.5.2",
"megalodon": "9.2.2", "megalodon": "9.2.2",
"parse-link-header": "^2.0.0",
"react-blurhash": "^0.3.0", "react-blurhash": "^0.3.0",
"react-hotkeys-hook": "^4.4.1", "react-hotkeys-hook": "^4.4.1",
"react-icons": "^5.0.0", "react-icons": "^5.0.0",

View File

@ -9,6 +9,7 @@ import { useRouter } from 'next/router'
import Compose from '../compose/Compose' import Compose from '../compose/Compose'
import { useHotkeys } from 'react-hotkeys-hook' import { useHotkeys } from 'react-hotkeys-hook'
import { Input, Spinner } from '@material-tailwind/react' import { Input, Spinner } from '@material-tailwind/react'
import parse from 'parse-link-header'
const TIMELINE_STATUSES_COUNT = 30 const TIMELINE_STATUSES_COUNT = 30
const TIMELINE_MAX_STATUSES = 2147483647 const TIMELINE_MAX_STATUSES = 2147483647
@ -27,6 +28,7 @@ export default function Timeline(props: Props) {
const [composeHeight, setComposeHeight] = useState(120) const [composeHeight, setComposeHeight] = useState(120)
const [list, setList] = useState<Entity.List | null>(null) const [list, setList] = useState<Entity.List | null>(null)
const [filters, setFilters] = useState<Array<Entity.Filter>>([]) const [filters, setFilters] = useState<Array<Entity.Filter>>([])
const [nextMaxId, setNextMaxId] = useState<string | null>(null)
const router = useRouter() const router = useRouter()
const { formatMessage } = useIntl() const { formatMessage } = useIntl()
@ -147,11 +149,18 @@ export default function Timeline(props: Props) {
} }
case 'favourites': { case 'favourites': {
const res = await client.getFavourites(options) const res = await client.getFavourites(options)
// TODO: handle next_id in link header to get more posts const link = parse(res.headers.link)
if (link !== null && link.next) {
setNextMaxId(link.next.max_id)
}
return res.data return res.data
} }
case 'bookmarks': { case 'bookmarks': {
const res = await client.getBookmarks(options) const res = await client.getBookmarks(options)
const link = parse(res.headers.link)
if (link !== null && link.next) {
setNextMaxId(link.next.max_id)
}
return res.data return res.data
} }
default: { default: {
@ -190,11 +199,23 @@ export default function Timeline(props: Props) {
const loadMore = useCallback(async () => { const loadMore = useCallback(async () => {
console.debug('appending') console.debug('appending')
const maxId = statuses[statuses.length - 1].id let maxId = null
switch (props.timeline) {
case 'favourites':
case 'bookmarks':
if (!nextMaxId) {
return
}
maxId = nextMaxId
break
default:
maxId = statuses[statuses.length - 1].id
break
}
const append = await loadTimeline(props.timeline, props.client, maxId) const append = await loadTimeline(props.timeline, props.client, maxId)
setStatuses(last => [...last, ...append]) setStatuses(last => [...last, ...append])
}, [props.client, statuses, setStatuses]) }, [props.client, statuses, setStatuses, nextMaxId])
const prependUnreads = useCallback(() => { const prependUnreads = useCallback(() => {
console.debug('prepending') console.debug('prepending')

View File

@ -2706,6 +2706,7 @@ __metadata:
megalodon: 9.2.2 megalodon: 9.2.2
next: ^12.3.4 next: ^12.3.4
nextron: ^8.12.0 nextron: ^8.12.0
parse-link-header: ^2.0.0
postcss: ^8.4.31 postcss: ^8.4.31
react: ^18.2.0 react: ^18.2.0
react-blurhash: ^0.3.0 react-blurhash: ^0.3.0
@ -7156,6 +7157,15 @@ __metadata:
languageName: node languageName: node
linkType: hard linkType: hard
"parse-link-header@npm:^2.0.0":
version: 2.0.0
resolution: "parse-link-header@npm:2.0.0"
dependencies:
xtend: ~4.0.1
checksum: 0e96c6af9910e8f92084b49b8dc6a10dd58db470847d1499f562576180c1ac5e49d18007697f0d538e5f3efdc8ce1d8777641f3ae225302b74af0dd0578b628e
languageName: node
linkType: hard
"parse-srcset@npm:^1.0.2": "parse-srcset@npm:^1.0.2":
version: 1.0.2 version: 1.0.2
resolution: "parse-srcset@npm:1.0.2" resolution: "parse-srcset@npm:1.0.2"
@ -9216,6 +9226,13 @@ __metadata:
languageName: node languageName: node
linkType: hard linkType: hard
"xtend@npm:~4.0.1":
version: 4.0.2
resolution: "xtend@npm:4.0.2"
checksum: ac5dfa738b21f6e7f0dd6e65e1b3155036d68104e67e5d5d1bde74892e327d7e5636a076f625599dc394330a731861e87343ff184b0047fef1360a7ec0a5a36a
languageName: node
linkType: hard
"y18n@npm:^5.0.5": "y18n@npm:^5.0.5":
version: 5.0.8 version: 5.0.8
resolution: "y18n@npm:5.0.8" resolution: "y18n@npm:5.0.8"