diff --git a/src/views/ArticleDetail/AuthorSidebar/Tabs/index.tsx b/src/views/ArticleDetail/AuthorSidebar/Tabs/index.tsx index 71cd569cd1..3315608294 100644 --- a/src/views/ArticleDetail/AuthorSidebar/Tabs/index.tsx +++ b/src/views/ArticleDetail/AuthorSidebar/Tabs/index.tsx @@ -6,7 +6,7 @@ import { ArticleDetailPublicQuery } from '~/gql/graphql' import styles from './styles.module.css' -export type TABS = 'Collection' | 'Author' | 'Recommendation' +export type TABS = 'Collection' | 'Author' | 'Recommendation' | undefined type TabsProps = { article: NonNullable diff --git a/src/views/ArticleDetail/AuthorSidebar/index.tsx b/src/views/ArticleDetail/AuthorSidebar/index.tsx index a9e0588cf3..34986e0c69 100644 --- a/src/views/ArticleDetail/AuthorSidebar/index.tsx +++ b/src/views/ArticleDetail/AuthorSidebar/index.tsx @@ -19,19 +19,36 @@ type AuthorSidebarProps = { export const AuthorSidebar = ({ article }: AuthorSidebarProps) => { const { getQuery } = useRoute() const cid = getQuery('collection') - const [tab, setTab] = useState(!!cid ? 'Collection' : 'Author') + const latestWorks = article.author?.latestWorks.filter((work) => { + return work.id !== article.id + }) + const hasFromAuthor = latestWorks && latestWorks.length > 0 + const hasRecommendation = article.relatedArticles?.totalCount > 0 + const [tab, setTab] = useState( + !!cid + ? 'Collection' + : hasFromAuthor + ? 'Author' + : hasRecommendation + ? 'Recommendation' + : undefined + ) return ( <> - -
- {!!cid && tab === 'Collection' && ( - - )} - {tab === 'Author' && } - {tab === 'Recommendation' && } -
+ {!!tab && ( + <> + +
+ {!!cid && tab === 'Collection' && ( + + )} + {tab === 'Author' && } + {tab === 'Recommendation' && } +
+ + )} ) }