Browse Source

#140

feature/140
みてるぞ 1 week ago
parent
commit
5cbe21b5d7
3 changed files with 17 additions and 16 deletions
  1. +5
    -4
      frontend/src/components/PostList.tsx
  2. +7
    -7
      frontend/src/components/PrefetchLink.tsx
  3. +5
    -5
      frontend/src/pages/posts/PostDetailPage.tsx

+ 5
- 4
frontend/src/components/PostList.tsx View File

@@ -11,10 +11,11 @@ type Props = { posts: Post[]
export default (({ posts, onClick }: Props) => (
<div className="flex flex-wrap gap-6 p-4">
{posts.map ((post, i) => (
<PrefetchLink to={`/posts/${ post.id }`}
key={post.id}
className="w-40 h-40 overflow-hidden rounded-lg shadow-md hover:shadow-lg"
onClick={onClick}>
<PrefetchLink
to={`/posts/${ post.id }`}
key={post.id}
className="w-40 h-40 overflow-hidden rounded-lg shadow-md hover:shadow-lg"
onClick={onClick}>
<img src={post.thumbnail || post.thumbnailBase || undefined}
alt={post.title || post.url}
title={post.title || post.url || undefined}


+ 7
- 7
frontend/src/components/PrefetchLink.tsx View File

@@ -16,13 +16,13 @@ type Props = AnchorHTMLAttributes<HTMLAnchorElement> & {


export default (({ to,
replace,
className,
onMouseEnter,
onTouchStart,
onClick,
cancelOnError = false,
...rest }: Props) => {
replace,
className,
onMouseEnter,
onTouchStart,
onClick,
cancelOnError = false,
...rest }: Props) => {
const navigate = useNavigate ()
const qc = useQueryClient ()
const url = useMemo (() => (new URL (to, location.origin)).toString (), [to])


+ 5
- 5
frontend/src/pages/posts/PostDetailPage.tsx View File

@@ -43,19 +43,19 @@ export default (({ user }: Props) => {
return next
},
onMutate: async () => {
await qc.cancelQueries ({ queryKey: ['post', String (id)] })
const prev = qc.getQueryData<any> (['post', String (id)])
qc.setQueryData (['post', String (id)],
await qc.cancelQueries ({ queryKey: ['posts', String (id)] })
const prev = qc.getQueryData<any> (['posts', String (id)])
qc.setQueryData (['posts', String (id)],
(cur: any) => cur ? { ...cur, viewed: !(cur.viewed) } : cur)
return { prev }
},
onError: (...[, , ctx]) => {
if (ctx?.prev)
qc.setQueryData (['post', String (id)], ctx.prev)
qc.setQueryData (['posts', String (id)], ctx.prev)
toast ({ title: '失敗……', description: '通信に失敗しました……' })
},
onSuccess: () => {
qc.invalidateQueries ({ queryKey: ['posts'] })
qc.invalidateQueries ({ queryKey: ['posts', 'index'] })
qc.invalidateQueries ({ queryKey: ['related', String (id)] })
} })



Loading…
Cancel
Save