mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-30 04:18:28 +08:00
92 lines
2.6 KiB
TypeScript
92 lines
2.6 KiB
TypeScript
|
import React from 'react';
|
||
|
|
||
|
import SemanticPreview from '../../../.dumi/components/SemanticPreview';
|
||
|
import useLocale from '../../../.dumi/hooks/useLocale';
|
||
|
|
||
|
import { Avatar, List, Space } from 'antd';
|
||
|
import { LikeOutlined, MessageOutlined, StarOutlined } from '@ant-design/icons';
|
||
|
|
||
|
const locales = {
|
||
|
cn: {
|
||
|
extra: '设置额外内容',
|
||
|
actions: '设置列表操作组',
|
||
|
},
|
||
|
en: {
|
||
|
extra: 'set `extra` of List.Item',
|
||
|
actions: 'set `actions` of List.Item',
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const IconText = ({ icon, text }: { icon: React.FC; text: string }) => (
|
||
|
<Space>
|
||
|
{React.createElement(icon)}
|
||
|
{text}
|
||
|
</Space>
|
||
|
);
|
||
|
|
||
|
const data = Array.from({ length: 1 }).map((_, i) => ({
|
||
|
href: 'https://ant.design',
|
||
|
title: `ant design part ${i}`,
|
||
|
avatar: `https://api.dicebear.com/7.x/miniavs/svg?seed=${i}`,
|
||
|
description:
|
||
|
'Ant Design, a design language for background applications, is refined by Ant UED Team.',
|
||
|
content:
|
||
|
'We supply a series of design principles, practical patterns and high quality design resources (Sketch and Axure), to help people create their product prototypes beautifully and efficiently.',
|
||
|
}));
|
||
|
|
||
|
const BlockList: React.FC<React.PropsWithChildren> = (props) => {
|
||
|
const divRef = React.useRef<HTMLDivElement>(null);
|
||
|
|
||
|
return (
|
||
|
<div ref={divRef} style={{ position: 'absolute', inset: 0, height: 300 }}>
|
||
|
<List
|
||
|
itemLayout="vertical"
|
||
|
size="large"
|
||
|
dataSource={data}
|
||
|
renderItem={(item) => (
|
||
|
<List.Item
|
||
|
{...props}
|
||
|
key={item.title}
|
||
|
actions={[
|
||
|
<IconText icon={StarOutlined} text="156" key="list-vertical-star-o" />,
|
||
|
<IconText icon={LikeOutlined} text="156" key="list-vertical-like-o" />,
|
||
|
<IconText icon={MessageOutlined} text="2" key="list-vertical-message" />,
|
||
|
]}
|
||
|
extra={
|
||
|
<img
|
||
|
width={272}
|
||
|
alt="logo"
|
||
|
src="https://gw.alipayobjects.com/zos/rmsportal/mqaQswcyDLcXyDKnZfES.png"
|
||
|
/>
|
||
|
}
|
||
|
>
|
||
|
<List.Item.Meta
|
||
|
avatar={<Avatar src={item.avatar} />}
|
||
|
title={<a href={item.href}>{item.title}</a>}
|
||
|
description={item.description}
|
||
|
/>
|
||
|
{item.content}
|
||
|
</List.Item>
|
||
|
)}
|
||
|
/>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
const App: React.FC = () => {
|
||
|
const [locale] = useLocale(locales);
|
||
|
return (
|
||
|
<SemanticPreview
|
||
|
height={300}
|
||
|
semantics={[
|
||
|
{ name: 'extra', desc: locale.extra, version: '5.18.0' },
|
||
|
{ name: 'actions', desc: locale.actions, version: '5.18.0' },
|
||
|
]}
|
||
|
>
|
||
|
<BlockList />
|
||
|
</SemanticPreview>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default App;
|