pay-admin/src/pages/company/list/modals/CompanyUpdate.tsx

123 lines
3.4 KiB
TypeScript
Raw Normal View History

2025-06-29 18:42:50 +08:00
import {
MyBetaModalFormProps,
MyButtons,
MyFormItems,
2025-06-29 18:42:50 +08:00
MyModalFormProps,
rulesHelper,
} from '@/common';
import { Address } from '@/components/Address';
import { Apis } from '@/gen/Apis';
import { BetaSchemaForm } from '@ant-design/pro-components';
2025-06-30 13:41:38 +08:00
import { Form, message } from 'antd';
2025-06-29 18:42:50 +08:00
export default function Update(props: MyBetaModalFormProps) {
2025-06-30 13:41:38 +08:00
const [form] = Form.useForm();
2025-06-29 18:42:50 +08:00
return (
<BetaSchemaForm<ApiTypes.Company.Companies.Update>
{...MyModalFormProps.props}
title={`编辑${props.title}`}
2025-07-17 13:58:54 +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-06-30 13:41:38 +08:00
onOpenChange={(open: any) => {
if (open && props.item) {
form.setFieldsValue({
...props.item,
casacader: [
props.item?.province_id || '',
props.item?.city_id || '',
props.item?.area_id || '',
props.item?.street_id || '',
],
});
}
}}
2025-06-29 18:42:50 +08:00
onFinish={async (values) =>
Apis.Company.Companies.Update({ ...values, id: props.item?.id ?? 0 })
.then(() => {
props.reload?.();
message.success(props.title + '成功');
return true;
})
.catch(() => false)
}
columns={[
{
2025-09-19 00:16:07 +08:00
key: 'name',
title: '机构名称',
colProps: { span: 14 },
2025-06-29 18:42:50 +08:00
formItemProps: { ...rulesHelper.text },
},
{
2025-09-19 00:16:07 +08:00
key: 'short_name',
title: '机构简称',
colProps: { span: 10 },
formItemProps: { ...rulesHelper.text },
2025-06-29 18:42:50 +08:00
},
{
key: 'business_license_number',
title: '营业执照号',
colProps: { span: 24 },
2025-06-29 18:42:50 +08:00
formItemProps: { ...rulesHelper.text },
fieldProps: {
maxLength: 18,
},
2025-06-29 18:42:50 +08:00
},
{
key: 'contact_name',
title: '联系人姓名',
colProps: { span: 6 },
formItemProps: { ...rulesHelper.text },
2025-06-29 18:42:50 +08:00
},
{
key: 'contact_phone',
title: '联系人手机',
colProps: { span: 8 },
valueType: 'number',
fieldProps: {
maxLength: 11,
},
formItemProps: { ...rulesHelper.phone },
2025-06-29 18:42:50 +08:00
},
{
key: 'contact_email',
title: '联系人邮箱',
valueType: 'text',
colProps: { span: 10 },
fieldProps: {
placeholder: '139@mail.com',
type: 'email',
},
formItemProps: {
rules: [
{
pattern: /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/,
message: '请输入正确的邮箱,如 139@email.com 格式输入',
},
],
},
2025-06-29 18:42:50 +08:00
},
Address.Cascader({
key: 'casacader',
title: '联系地址',
colProps: { span: 14 },
2025-06-29 18:42:50 +08:00
keys: ['province', 'city', 'area', 'street'],
required: true,
}),
{
key: 'address',
2025-06-30 13:41:38 +08:00
title: '详细地址',
colProps: { span: 10 },
2025-06-29 18:42:50 +08:00
},
MyFormItems.UploadImages({
key: 'business_license_image',
title: '营业执照',
max: 1,
}),
2025-06-29 18:42:50 +08:00
]}
/>
);
}