198 lines
5.2 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 {
AssetHousesOrientationEnum,
AssetHousesOwnershipTypeEnum,
AssetHousesStatusEnum,
AssetHousesUsageEnum,
} 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
console.log(props?.item, 'item');
return (
<BetaSchemaForm<ApiTypes.Asset.AssetHouses.Store>
{...MyModalFormProps.props}
title={`添加${props.title}`}
wrapperCol={{ span: 24 }}
width="800px"
2025-06-30 14:20:46 +08:00
trigger={<MyButtons.Create title={`添加${props.title}`} />}
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.AssetHouses.Store({
...values,
asset_projects_id: props?.item?.id,
asset_buildings_id: props?.item?.asset_buildings_id,
asset_units_id: props?.item?.asset_units_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: 6 },
formItemProps: { ...rulesHelper.text },
2025-06-29 18:42:50 +08:00
},
MyFormItems.EnumRadio({
key: 'usage',
title: '用途',
2025-06-30 14:20:46 +08:00
colProps: { span: 18 },
2025-06-29 18:42:50 +08:00
valueEnum: AssetHousesUsageEnum,
required: true,
}),
{
key: 'floor',
title: '楼层',
valueType: 'digit',
fieldProps: {
addonAfter: '楼',
max: 99,
},
colProps: { span: 6 },
formItemProps: { ...rulesHelper.number },
},
2025-06-29 18:42:50 +08:00
{
key: 'built_area',
title: '建筑面积',
valueType: 'digit',
fieldProps: {
addonAfter: '㎡',
2025-06-30 14:20:46 +08:00
max: 99999,
2025-06-29 18:42:50 +08:00
},
2025-06-30 14:20:46 +08:00
colProps: { span: 6 },
formItemProps: { ...rulesHelper.number },
2025-06-29 18:42:50 +08:00
},
{
key: 'inside_area',
title: '套内面积',
valueType: 'digit',
fieldProps: {
addonAfter: '㎡',
2025-06-30 14:20:46 +08:00
max: 99999,
2025-06-29 18:42:50 +08:00
},
2025-06-30 14:20:46 +08:00
colProps: { span: 6 },
formItemProps: { ...rulesHelper.number },
2025-06-29 18:42:50 +08:00
},
{
key: 'chargeable_area',
title: '计费面积',
valueType: 'digit',
fieldProps: {
addonAfter: '㎡',
2025-06-30 14:20:46 +08:00
max: 99999,
2025-06-29 18:42:50 +08:00
},
2025-06-30 14:20:46 +08:00
colProps: { span: 6 },
formItemProps: { ...rulesHelper.number },
2025-06-29 18:42:50 +08:00
},
{
valueType: 'group',
columns: [
{
key: 'room',
title: '房',
valueType: 'digit',
fieldProps: {
addonAfter: '房',
},
colProps: { span: 5 },
2025-06-29 18:42:50 +08:00
},
{
key: 'hall',
title: '厅',
valueType: 'digit',
fieldProps: {
addonAfter: '厅',
},
colProps: { span: 5 },
2025-06-29 18:42:50 +08:00
},
{
2025-06-30 14:20:46 +08:00
key: 'bathroom',
title: '卫',
2025-06-29 18:42:50 +08:00
valueType: 'digit',
fieldProps: {
2025-06-30 14:20:46 +08:00
addonAfter: '卫',
2025-06-29 18:42:50 +08:00
},
colProps: { span: 5 },
2025-06-29 18:42:50 +08:00
},
{
2025-06-30 14:20:46 +08:00
key: 'kitchen',
title: '厨',
2025-06-29 18:42:50 +08:00
valueType: 'digit',
fieldProps: {
2025-06-30 14:20:46 +08:00
addonAfter: '厨',
2025-06-29 18:42:50 +08:00
},
colProps: { span: 4 },
},
{
key: 'balcony',
title: '阳台',
valueType: 'digit',
fieldProps: {
addonAfter: '阳台',
},
colProps: { span: 5 },
2025-06-29 18:42:50 +08:00
},
],
},
MyFormItems.EnumRadio({
key: 'orientation',
title: '房屋朝向',
colProps: { span: 24 },
valueEnum: AssetHousesOrientationEnum,
// required: true,
}),
MyFormItems.EnumRadio({
key: 'status',
title: '房屋状态',
colProps: { span: 6 },
// valueEnum: AssetHousesStatusEnum,
// required: true,
valueEnum: () => {
let obj: any = JSON.parse(JSON.stringify(AssetHousesStatusEnum));
delete obj.SelfOccupied;
delete obj.Rented;
delete obj.Vacant;
return obj;
},
}),
MyFormItems.EnumSelect({
key: 'ownership_type',
title: '产权性质',
colProps: { span: 6 },
valueEnum: AssetHousesOwnershipTypeEnum,
// required: true,
}),
{
key: 'ownership_term',
title: '产权年限',
fieldProps: {
addonAfter: '年',
},
colProps: { span: 6 },
},
2025-06-29 18:42:50 +08:00
]}
/>
);
}