2022-11-09 12:28:04 +08:00
|
|
|
import * as React from 'react';
|
2022-11-30 11:05:41 +08:00
|
|
|
import { Skeleton, Typography } from 'antd';
|
|
|
|
import { css } from '@emotion/react';
|
2022-11-09 12:28:04 +08:00
|
|
|
import type { Extra, Icon } from './util';
|
|
|
|
import useSiteToken from '../../../hooks/useSiteToken';
|
|
|
|
|
|
|
|
const useStyle = () => {
|
|
|
|
const { token } = useSiteToken();
|
|
|
|
|
|
|
|
return {
|
|
|
|
card: css`
|
|
|
|
border: ${token.lineWidth}px solid ${token.colorBorderSecondary};
|
|
|
|
border-radius: ${token.borderRadiusLG}px;
|
|
|
|
padding-block: ${token.paddingMD}px;
|
|
|
|
padding-inline: ${token.paddingLG}px;
|
|
|
|
flex: 1 1 0;
|
|
|
|
width: 33%;
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
align-items: stretch;
|
|
|
|
text-decoration: none;
|
|
|
|
transition: all ${token.motionDurationSlow};
|
|
|
|
background: ${token.colorBgContainer};
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
box-shadow: ${token.boxShadowCard};
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export interface BannerRecommendsProps {
|
|
|
|
extras?: Extra[];
|
|
|
|
icons?: Icon[];
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function BannerRecommends({ extras = [], icons = [] }: BannerRecommendsProps) {
|
|
|
|
const style = useStyle();
|
2022-11-17 20:56:35 +08:00
|
|
|
const first3 = extras.length === 0 ? Array(3).fill(null) : extras.slice(0, 3);
|
2022-11-09 12:28:04 +08:00
|
|
|
const { token } = useSiteToken();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
maxWidth: 1208,
|
|
|
|
marginInline: 'auto',
|
|
|
|
boxSizing: 'border-box',
|
|
|
|
paddingInline: token.marginXXL,
|
|
|
|
display: 'flex',
|
|
|
|
columnGap: token.paddingMD * 2,
|
|
|
|
alignItems: 'stretch',
|
|
|
|
textAlign: 'start',
|
|
|
|
}}
|
|
|
|
>
|
2022-11-30 11:05:41 +08:00
|
|
|
{first3.map((extra) => {
|
2022-11-17 20:56:35 +08:00
|
|
|
if (!extra) {
|
2022-11-30 11:05:41 +08:00
|
|
|
return <Skeleton key={extra.title} />;
|
2022-11-17 20:56:35 +08:00
|
|
|
}
|
2022-11-30 11:05:41 +08:00
|
|
|
const icon = icons.find((i) => i.name === extra.source);
|
2022-11-09 12:28:04 +08:00
|
|
|
return (
|
2022-11-30 11:05:41 +08:00
|
|
|
<a key={extra.title} href={extra.href} target="_blank" css={style.card} rel="noreferrer">
|
2022-11-09 12:28:04 +08:00
|
|
|
<Typography.Title level={5}>{extra.title}</Typography.Title>
|
|
|
|
<Typography.Paragraph type="secondary" style={{ flex: 'auto' }}>
|
|
|
|
{extra.description}
|
|
|
|
</Typography.Paragraph>
|
|
|
|
<div style={{ display: 'flex', justifyContent: 'space-between' }}>
|
|
|
|
<Typography.Text>{extra.date}</Typography.Text>
|
2022-11-30 11:05:41 +08:00
|
|
|
{icon && <img src={icon.href} style={{ height: token.fontSize }} alt="banner" />}
|
2022-11-09 12:28:04 +08:00
|
|
|
</div>
|
|
|
|
</a>
|
|
|
|
);
|
|
|
|
})}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|