95 lines
2.4 KiB
TypeScript
Raw Normal View History

2025-06-29 18:42:50 +08:00
import {
MyBetaModalFormProps,
MyButtons,
MyFormItems,
MyModalFormProps,
rulesHelper,
} from '@/common';
import { Apis } from '@/gen/Apis';
import {
AssetUnitsBuildingStructureEnum,
AssetUnitsBuildingTypeEnum,
} from '@/gen/Enums';
import { BetaSchemaForm } from '@ant-design/pro-components';
2025-06-30 14:20:46 +08:00
import { Form, message } from 'antd';
2025-06-29 18:42:50 +08:00
export default function Create(props: MyBetaModalFormProps) {
2025-06-30 14:20:46 +08:00
const [form] = Form.useForm();
2025-06-29 18:42:50 +08:00
return (
<BetaSchemaForm<ApiTypes.Asset.AssetUnits.Store>
{...MyModalFormProps.props}
title={`添加${props.title}`}
wrapperCol={{ span: 24 }}
width="700px"
2025-09-18 19:40:30 +08:00
trigger={
<MyButtons.Create
title={`${props.title}`}
size={props?.item?.size || 'middle'}
/>
}
2025-06-30 14:20:46 +08:00
form={form}
key={new Date().getTime()}
2025-06-30 14:20:46 +08:00
onOpenChange={(open: any) => {
if (open) {
form.resetFields(); // 清空表单数据
}
}}
2025-06-29 18:42:50 +08:00
onFinish={async (values) =>
Apis.Asset.AssetUnits.Store({
...values,
asset_projects_id: props?.item?.id,
asset_buildings_id: props?.item?.asset_buildings_id,
2025-06-29 18:42:50 +08:00
})
.then(() => {
props.reload?.();
message.success(props.title + '成功');
return true;
})
.catch(() => false)
}
columns={[
{
key: 'name',
title: '单元名称',
colProps: { span: 12 },
formItemProps: { ...rulesHelper.text },
},
{
key: 'alias_name',
title: '单元别名',
colProps: { span: 12 },
},
MyFormItems.EnumRadio({
key: 'building_structure',
title: '建筑结构',
colProps: { span: 12 },
valueEnum: AssetUnitsBuildingStructureEnum,
// required: true,
2025-06-29 18:42:50 +08:00
}),
MyFormItems.EnumRadio({
key: 'building_type',
title: '建筑类型',
colProps: { span: 12 },
valueEnum: AssetUnitsBuildingTypeEnum,
// required: true,
2025-06-29 18:42:50 +08:00
}),
{
key: 'elevator_count',
title: '电梯数量',
2025-06-30 14:20:46 +08:00
colProps: { span: 6 },
2025-06-29 18:42:50 +08:00
},
{
key: 'units_per_building',
title: '单元户数',
2025-06-30 14:20:46 +08:00
colProps: { span: 6 },
2025-06-29 18:42:50 +08:00
},
{
key: 'highest_floor',
title: '最高楼层',
2025-06-30 14:20:46 +08:00
colProps: { span: 6 },
2025-06-29 18:42:50 +08:00
},
]}
/>
);
}