/* eslint-disable react/no-array-index-key */ import * as React from 'react'; import dayjs from 'dayjs'; import { FormattedMessage, useIntl } from 'react-intl'; import { Tabs, Skeleton, Avatar, Divider, Empty } from 'antd'; import { useSiteData } from '../../Home/util'; import type { Article, Authors } from '../../Home/util'; import './index.less'; interface ArticleListProps { name: React.ReactNode; data: Article[]; authors: Authors; } const ArticleList: React.FC = ({ name, data = [], authors = [] }) => (

{name}

); export default () => { const { locale } = useIntl(); const isZhCN = locale === 'zh-CN'; const [{ articles = { cn: [], en: [] }, authors = [] }, loading] = useSiteData(); // ========================== Data ========================== const mergedData = React.useMemo(() => { const yearData: Record> = {}; articles[isZhCN ? 'cn' : 'en']?.forEach(article => { const year = dayjs(article.date).year(); yearData[year] = yearData[year] || {}; yearData[year][article.type] = [...(yearData[year][article.type] || []), article]; }); return yearData; }, [articles]); // ========================= Render ========================= let content: React.ReactNode; if (loading) { content = ; } else { const yearList = Object.keys(mergedData).sort((a, b) => Number(b) - Number(a)); content = yearList.length ? ( {yearList.map(year => ( } data={mergedData[year].design} authors={authors} /> } data={mergedData[year].develop} authors={authors} />
))}
) : null; } return (
{content}
); };