2025-06-27 16:42:11 +08:00
|
|
|
|
import {
|
|
|
|
|
|
MyBetaModalFormProps,
|
|
|
|
|
|
MyButtons,
|
|
|
|
|
|
MyFormItems,
|
|
|
|
|
|
MyModalFormProps,
|
|
|
|
|
|
rulesHelper,
|
|
|
|
|
|
} from '@/common';
|
|
|
|
|
|
import { SysSelects } from '@/components/SysSelects';
|
|
|
|
|
|
import { Apis } from '@/gen/Apis';
|
|
|
|
|
|
import { SysPermissionsTypeEnum } from '@/gen/Enums';
|
|
|
|
|
|
import { BetaSchemaForm } from '@ant-design/pro-components';
|
|
|
|
|
|
import { ButtonProps, Form, message } from 'antd';
|
|
|
|
|
|
|
|
|
|
|
|
export default function Create(
|
|
|
|
|
|
props: {
|
|
|
|
|
|
buttonProps?: ButtonProps;
|
|
|
|
|
|
guardName: string;
|
2025-08-12 18:17:37 +08:00
|
|
|
|
item?: any;
|
2025-06-27 16:42:11 +08:00
|
|
|
|
} & MyBetaModalFormProps,
|
|
|
|
|
|
) {
|
|
|
|
|
|
const [form] = Form.useForm();
|
|
|
|
|
|
return (
|
2025-06-27 17:15:50 +08:00
|
|
|
|
<BetaSchemaForm<ApiTypes.Permission.SysPermissions.Store>
|
2025-06-27 16:42:11 +08:00
|
|
|
|
{...MyModalFormProps.props}
|
|
|
|
|
|
title={`添加${props.title}`}
|
|
|
|
|
|
wrapperCol={{ span: 24 }}
|
|
|
|
|
|
width="600px"
|
|
|
|
|
|
trigger={
|
|
|
|
|
|
<MyButtons.Create title={`添加${props.title}`} {...props.buttonProps} />
|
|
|
|
|
|
}
|
2025-08-08 18:35:02 +08:00
|
|
|
|
// 确保正确弹窗,使用动态的时间参数
|
|
|
|
|
|
key={new Date().getTime()}
|
|
|
|
|
|
form={form}
|
|
|
|
|
|
onOpenChange={(open: any) => {
|
|
|
|
|
|
if (open) {
|
|
|
|
|
|
form.resetFields(); // 清空表单数据
|
2025-08-12 18:17:37 +08:00
|
|
|
|
// 如果有传入的item,设置为上级菜单
|
|
|
|
|
|
if (props.item?.id) {
|
|
|
|
|
|
form.setFieldsValue({
|
|
|
|
|
|
parent_id: props.item.id,
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
2025-08-08 18:35:02 +08:00
|
|
|
|
}
|
|
|
|
|
|
}}
|
2025-06-27 16:42:11 +08:00
|
|
|
|
onFinish={async (values) => {
|
2025-06-27 17:15:50 +08:00
|
|
|
|
return Apis.Permission.SysPermissions.Store({
|
2025-06-27 16:42:11 +08:00
|
|
|
|
...values,
|
|
|
|
|
|
guard_name: props.guardName,
|
|
|
|
|
|
})
|
|
|
|
|
|
.then(() => {
|
|
|
|
|
|
props.reload?.();
|
|
|
|
|
|
message.success(props.title + '成功');
|
|
|
|
|
|
return true;
|
|
|
|
|
|
})
|
|
|
|
|
|
.catch(() => false);
|
|
|
|
|
|
}}
|
|
|
|
|
|
columns={[
|
|
|
|
|
|
SysSelects.SysPermissionsTree({ guard_name: props.guardName }),
|
|
|
|
|
|
{
|
|
|
|
|
|
key: 'name',
|
|
|
|
|
|
title: '标题',
|
|
|
|
|
|
required: true,
|
|
|
|
|
|
formItemProps: { ...rulesHelper.text },
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
key: 'key',
|
|
|
|
|
|
title: '标识(en)',
|
|
|
|
|
|
},
|
|
|
|
|
|
MyFormItems.IconSelect(),
|
|
|
|
|
|
MyFormItems.EnumRadio({
|
|
|
|
|
|
key: 'type',
|
|
|
|
|
|
title: '类型',
|
|
|
|
|
|
valueEnum: SysPermissionsTypeEnum,
|
|
|
|
|
|
required: true,
|
|
|
|
|
|
}),
|
|
|
|
|
|
{ key: 'path', title: '路由' },
|
|
|
|
|
|
SysSelects.Api(),
|
|
|
|
|
|
]}
|
|
|
|
|
|
/>
|
|
|
|
|
|
);
|
|
|
|
|
|
}
|