mirror of
https://github.com/ant-design/ant-design.git
synced 2026-02-09 02:49:18 +08:00
* feat[Button]: "iconPosition" instead "iconPlacement" * test: add test to iconPlacement * docs: Modify the 'iconPosition' of other demo * Update components/button/button.tsx Co-authored-by: thinkasany <480968828@qq.com> Signed-off-by: EmilyyyLiu <100924403+EmilyyyLiu@users.noreply.github.com> * docs: change docs (iconPosition) * docs: change fileName (icon-position -> icon-placement) * Update components/button/index.en-US.md Co-authored-by: thinkasany <480968828@qq.com> Signed-off-by: EmilyyyLiu <100924403+EmilyyyLiu@users.noreply.github.com> * test: update snapshots --------- Signed-off-by: EmilyyyLiu <100924403+EmilyyyLiu@users.noreply.github.com> Co-authored-by: 刘欢 <lh01217311@antgroup.com> Co-authored-by: thinkasany <480968828@qq.com>
80 lines
2.1 KiB
TypeScript
80 lines
2.1 KiB
TypeScript
import React, { useState } from 'react';
|
|
import { PoweroffOutlined, SyncOutlined } from '@ant-design/icons';
|
|
import { Button, Flex } from 'antd';
|
|
|
|
const App: React.FC = () => {
|
|
const [loadings, setLoadings] = useState<boolean[]>([]);
|
|
|
|
const enterLoading = (index: number) => {
|
|
console.log('Start loading:', index);
|
|
|
|
setLoadings((prevLoadings) => {
|
|
const newLoadings = [...prevLoadings];
|
|
newLoadings[index] = true;
|
|
return newLoadings;
|
|
});
|
|
|
|
setTimeout(() => {
|
|
setLoadings((prevLoadings) => {
|
|
const newLoadings = [...prevLoadings];
|
|
newLoadings[index] = false;
|
|
return newLoadings;
|
|
});
|
|
}, 3000);
|
|
};
|
|
|
|
return (
|
|
<Flex gap="small" vertical>
|
|
<Flex gap="small" align="center" wrap>
|
|
<Button type="primary" loading>
|
|
Loading
|
|
</Button>
|
|
<Button type="primary" size="small" loading>
|
|
Loading
|
|
</Button>
|
|
<Button type="primary" icon={<PoweroffOutlined />} loading />
|
|
<Button type="primary" loading={{ icon: <SyncOutlined spin /> }}>
|
|
Loading Icon
|
|
</Button>
|
|
</Flex>
|
|
<Flex gap="small" wrap>
|
|
<Button type="primary" loading={loadings[0]} onClick={() => enterLoading(0)}>
|
|
Icon Start
|
|
</Button>
|
|
<Button
|
|
type="primary"
|
|
loading={loadings[2]}
|
|
onClick={() => enterLoading(2)}
|
|
iconPlacement="end"
|
|
>
|
|
Icon End
|
|
</Button>
|
|
<Button
|
|
type="primary"
|
|
icon={<PoweroffOutlined />}
|
|
loading={loadings[1]}
|
|
onClick={() => enterLoading(1)}
|
|
>
|
|
Icon Replace
|
|
</Button>
|
|
<Button
|
|
type="primary"
|
|
icon={<PoweroffOutlined />}
|
|
loading={loadings[3]}
|
|
onClick={() => enterLoading(3)}
|
|
/>
|
|
<Button
|
|
type="primary"
|
|
icon={<PoweroffOutlined />}
|
|
loading={loadings[3] && { icon: <SyncOutlined spin /> }}
|
|
onClick={() => enterLoading(3)}
|
|
>
|
|
Loading Icon
|
|
</Button>
|
|
</Flex>
|
|
</Flex>
|
|
);
|
|
};
|
|
|
|
export default App;
|