pay-admin/src/pages/asset/list/modals/AssetUpdate.tsx

185 lines
5.1 KiB
TypeScript
Raw Normal View History

2025-06-29 18:42:50 +08:00
import {
MyBetaModalFormProps,
MyButtons,
MyFormItems,
MyModalFormProps,
rulesHelper,
} from '@/common';
import { Address } from '@/components/Address';
2025-09-08 17:22:58 +08:00
import { Selects } from '@/components/Select';
2025-06-29 18:42:50 +08:00
import { Apis } from '@/gen/Apis';
import {
AssetProjectsChargeEnum,
AssetProjectsEntrustTypeEnum,
AssetProjectsPropertyTypeEnum,
AssetProjectsStatusEnum,
} from '@/gen/Enums';
import { BetaSchemaForm } from '@ant-design/pro-components';
import { Form, message } from 'antd';
2025-06-29 18:42:50 +08:00
export default function Update(props: MyBetaModalFormProps) {
const [form] = Form.useForm();
2025-06-29 18:42:50 +08:00
return (
<BetaSchemaForm<ApiTypes.Asset.AssetProjects.Update>
{...MyModalFormProps.props}
title={`编辑${props.title}`}
2025-07-10 18:01:45 +08:00
trigger={<MyButtons.Default title="编辑" type="primary" size="small" />}
2025-06-29 18:42:50 +08:00
wrapperCol={{ span: 24 }}
width="600px"
key={new Date().getTime()}
form={form}
2025-09-02 16:22:57 +08:00
onOpenChange={(open: any, props: any) => {
if (open && props.item) {
2025-09-08 17:22:58 +08:00
form.setFieldsValue({
companies_id: props.item?.companies_id,
location: `${props.item?.longitude || ''},${
props.item?.latitude || ''
}`,
});
}
}}
2025-06-29 18:42:50 +08:00
request={() =>
Promise.resolve({
...props.item,
2025-09-08 17:22:58 +08:00
location: `${props.item?.longitude || ''},${
props.item?.latitude || ''
}`,
2025-06-29 18:42:50 +08:00
casacader: [
props.item?.province_id || '',
props.item?.city_id || '',
props.item?.area_id || '',
props.item?.street_id || '',
],
})
}
2025-09-08 17:22:58 +08:00
onFinish={async (values: any) =>
2025-09-02 16:22:57 +08:00
Apis.Asset.AssetProjects.Update({
...values,
id: props.item?.id ?? 0,
longitude: values?.location ? values.location.split(',')[0] : '',
latitude: values?.location ? values.location.split(',')[1] : '',
})
2025-06-29 18:42:50 +08:00
.then(() => {
props.reload?.();
message.success(props.title + '成功');
return true;
})
.catch(() => false)
}
columns={[
{
key: 'name',
title: '项目名称',
2025-06-30 14:20:46 +08:00
colProps: { span: 12 },
2025-06-29 18:42:50 +08:00
formItemProps: { ...rulesHelper.text },
},
{
key: 'alias_name',
title: '项目别名',
colProps: { span: 12 },
2025-06-29 18:42:50 +08:00
},
2025-08-27 11:24:29 +08:00
// Selects?.Companies({
// key: 'companies_id',
// title: '所属机构',
// colProps: { span: 24 },
// formItemProps: { ...rulesHelper.number },
// }),
2025-09-08 17:22:58 +08:00
Selects?.PropertyBrands({
title: '选择物业品牌',
key: 'company_property_brands_id',
params: {
companies_id: props.item?.companies_id,
},
colProps: { span: 24 },
formItemProps: { ...rulesHelper.text },
fieldProps: {
showSearch: true,
},
}),
2025-06-29 18:42:50 +08:00
Address.Cascader({
key: 'casacader',
title: '选择地址',
colProps: { span: 16 },
2025-06-29 18:42:50 +08:00
keys: ['province', 'city', 'area', 'street'],
required: true,
}),
{
key: 'address',
title: '详细地址',
colProps: { span: 8 },
2025-06-30 14:20:46 +08:00
formItemProps: { ...rulesHelper.text },
2025-06-29 18:42:50 +08:00
},
2025-06-30 14:20:46 +08:00
MyFormItems.EnumSelect({
key: 'property_type',
title: '项目类型',
colProps: { span: 8 },
2025-06-30 14:20:46 +08:00
valueEnum: AssetProjectsPropertyTypeEnum,
// required: true,
}),
MyFormItems.EnumSelect({
key: 'status',
title: '项目状态',
colProps: { span: 8 },
2025-06-30 14:20:46 +08:00
valueEnum: AssetProjectsStatusEnum,
// required: true,
}),
MyFormItems.EnumSelect({
key: 'entrust_type',
title: '委托类型',
colProps: { span: 8 },
2025-06-30 14:20:46 +08:00
valueEnum: AssetProjectsEntrustTypeEnum,
// required: true,
}),
MyFormItems.EnumRadio({
key: 'charge',
title: '收费方式',
colProps: { span: 8 },
2025-06-30 14:20:46 +08:00
valueEnum: AssetProjectsChargeEnum,
// required: true,
}),
2025-06-29 18:42:50 +08:00
{
key: 'takeover_date',
title: '接管日期',
valueType: 'date',
2025-06-30 14:20:46 +08:00
fieldProps: {
style: {
width: '100%',
},
},
colProps: { span: 8 },
2025-06-29 18:42:50 +08:00
},
{
key: 'closure_date',
title: '封园日期',
valueType: 'date',
2025-06-30 14:20:46 +08:00
fieldProps: {
style: {
width: '100%',
},
},
colProps: { span: 8 },
2025-06-29 18:42:50 +08:00
},
2025-09-02 16:22:57 +08:00
{
title: '项目经纬度',
dataIndex: 'location',
colProps: { span: 24 },
fieldProps: {
addonAfter: (
<MyButtons.View
title="获取经纬度"
onClick={() => {
window.open(
'https://api.map.baidu.com/lbsapi/getpoint/index.html',
);
}}
/>
),
},
},
2025-06-29 18:42:50 +08:00
]}
/>
);
}