docs(list): add semantic dom (#50413)
parent
3b9a1b1123
commit
7005212e15
@ -0,0 +1,91 @@
|
||||
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;
|
Loading…
Reference in New Issue