mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-09 21:38:54 +08:00
58 lines
1.2 KiB
TypeScript
58 lines
1.2 KiB
TypeScript
|
import React, { useState } from 'react';
|
|||
|
import { message, Popconfirm, Switch } from 'antd';
|
|||
|
|
|||
|
const App: React.FC = () => {
|
|||
|
const [open, setOpen] = useState(false);
|
|||
|
const [condition, setCondition] = useState(true);
|
|||
|
|
|||
|
const changeCondition = (checked: boolean) => {
|
|||
|
setCondition(checked);
|
|||
|
};
|
|||
|
|
|||
|
const confirm = () => {
|
|||
|
setOpen(false);
|
|||
|
message.success('Next step.');
|
|||
|
};
|
|||
|
|
|||
|
const cancel = () => {
|
|||
|
setOpen(false);
|
|||
|
message.error('Click on cancel.');
|
|||
|
};
|
|||
|
|
|||
|
const handleOpenChange = (newOpen: boolean) => {
|
|||
|
if (!newOpen) {
|
|||
|
setOpen(newOpen);
|
|||
|
return;
|
|||
|
}
|
|||
|
// Determining condition before show the popconfirm.
|
|||
|
console.log(condition);
|
|||
|
if (condition) {
|
|||
|
confirm(); // next step
|
|||
|
} else {
|
|||
|
setOpen(newOpen);
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
return (
|
|||
|
<div>
|
|||
|
<Popconfirm
|
|||
|
title="Are you sure delete this task?"
|
|||
|
open={open}
|
|||
|
onOpenChange={handleOpenChange}
|
|||
|
onConfirm={confirm}
|
|||
|
onCancel={cancel}
|
|||
|
okText="Yes"
|
|||
|
cancelText="No"
|
|||
|
>
|
|||
|
<a href="#">Delete a task</a>
|
|||
|
</Popconfirm>
|
|||
|
<br />
|
|||
|
<br />
|
|||
|
Whether directly execute:
|
|||
|
<Switch defaultChecked onChange={changeCondition} />
|
|||
|
</div>
|
|||
|
);
|
|||
|
};
|
|||
|
|
|||
|
export default App;
|