legalgo-FE-reactrouter/app/routes/_news.detail.$slug.tsx

45 lines
1.1 KiB
TypeScript
Raw Normal View History

import { getNewsBySlug } from '~/apis/common/get-news-by-slug'
import { getUser } from '~/apis/news/get-user'
import { APP } from '~/configs/meta'
import { handleCookie } from '~/libs/cookies'
import { NewsDetailPage } from '~/pages/news-detail'
import type { Route } from './+types/_news.detail.$slug'
export const loader = async ({ request, params }: Route.LoaderArgs) => {
const { userToken } = await handleCookie(request)
let userData
if (userToken) {
const { data } = await getUser({
accessToken: userToken,
})
userData = data
}
// TODO: need handle if user not access non premium data
const { data: newsDetailData } = await getNewsBySlug({
slug: params.slug,
accessToken: userToken,
})
return {
newsDetailData,
userData,
}
}
export const meta = ({ data }: Route.MetaArgs) => {
const { newsDetailData } = data
const metaTitle = APP.title
const title = `${newsDetailData.title} - ${metaTitle}`
return [
{
title,
},
]
}
const NewsDetailLayout = () => <NewsDetailPage />
export default NewsDetailLayout