safety-eval-service-frontend/src/pages/Container/EnterpriseInfo/OrgInfo/index.js

306 lines
8.7 KiB
JavaScript
Raw Normal View History

2026-06-23 18:07:30 +08:00
import { Connect } from "@cqsjjb/jjb-dva-runtime";
import { Button, Form, message, Space } from "antd";
import { useEffect, useState } from "react";
import FormBuilder from "zy-react-library/components/FormBuilder";
import Page from "zy-react-library/components/Page";
import { FORM_ITEM_RENDER_ENUM } from "zy-react-library/enum/formItemRender";
import PageHeader from "../components/PageHeader";
import { NS_ORG_INFO } from "~/enumerate/namespace";
import {
creditCodeRule,
latitudeRule,
longitudeRule,
2026-06-24 11:58:57 +08:00
nonNegativeIntegerRule,
2026-06-23 18:07:30 +08:00
phoneRule,
positiveNumberRule,
urlRule,
} from "~/utils/validators";
2026-06-24 11:58:57 +08:00
const numberFieldProps = { style: { width: "100%" } };
2026-06-23 18:07:30 +08:00
function OrgInfoPage(props) {
const [form] = Form.useForm();
const [editing, setEditing] = useState(true);
const [submitting, setSubmitting] = useState(false);
const [detail, setDetail] = useState({});
2026-06-24 11:58:57 +08:00
/** 是否已存在机构数据(有 id 视为已入库,只能修改) */
const [hasExistingData, setHasExistingData] = useState(false);
2026-06-23 18:07:30 +08:00
const loadDetail = async () => {
try {
const res = await props.orgInfoGet().catch(() => null);
2026-06-24 11:58:57 +08:00
if (res?.data?.id) {
2026-06-23 18:07:30 +08:00
setDetail(res.data);
form.setFieldsValue(res.data);
2026-06-24 11:58:57 +08:00
setHasExistingData(true);
2026-06-23 18:07:30 +08:00
setEditing(false);
}
else {
2026-06-24 11:58:57 +08:00
setDetail({});
setHasExistingData(false);
2026-06-23 18:07:30 +08:00
setEditing(true);
}
}
catch (err) {
console.warn("[OrgInfo] loadDetail failed:", err);
2026-06-24 11:58:57 +08:00
setDetail({});
setHasExistingData(false);
2026-06-23 18:07:30 +08:00
setEditing(true);
}
};
useEffect(() => {
loadDetail();
}, []);
2026-06-24 11:58:57 +08:00
const handleCancelEdit = () => {
if (hasExistingData) {
form.setFieldsValue(detail);
setEditing(false);
}
else {
form.resetFields();
}
};
2026-06-23 18:07:30 +08:00
const handleSave = async (submitType) => {
try {
const values = await form.validateFields();
setSubmitting(true);
2026-06-24 11:58:57 +08:00
let request;
if (hasExistingData) {
// 已有数据:仅走修改接口
request = props.orgInfoSave;
values.id = detail.id;
}
else {
// 无数据:暂存、提交均走保存接口(草稿/已提交由 authStatusCode 区分)
request = submitType === "draft" ? props.orgInfoDraft : props.orgInfoSave;
}
2026-06-23 18:07:30 +08:00
const res = await request(values);
if (res?.success !== false) {
2026-06-24 11:58:57 +08:00
message.success(
hasExistingData
? "修改成功"
: (submitType === "draft" ? "暂存成功" : "提交成功"),
);
2026-06-23 18:07:30 +08:00
setEditing(false);
loadDetail();
}
}
catch (err) {
if (err?.errorFields) {
return;
}
2026-06-24 11:58:57 +08:00
message.error(hasExistingData ? "修改失败,请稍后重试" : "保存失败,请稍后重试");
2026-06-23 18:07:30 +08:00
}
finally {
setSubmitting(false);
}
};
const formOptions = [
{
name: "orgName",
label: "生产经营单位名称",
rules: [{ required: true, message: "请输入生产经营单位名称" }],
},
{
name: "creditCode",
label: "统一社会信用代码",
rules: [creditCodeRule(true)],
},
{
name: "safetyIndustryCategory",
label: "安全生产监管行业类别",
rules: [{ required: true, message: "请输入安全生产监管行业类别" }],
},
{
name: "regionCountyName",
label: "所属(县、区)",
rules: [{ required: true, message: "请输入所属县区" }],
},
{
name: "regionStreetName",
label: "所属镇、街道",
rules: [{ required: true, message: "请输入所属镇街道" }],
},
{
name: "regionCommunityName",
label: "属村(社区)",
2026-06-24 11:58:57 +08:00
required: false,
2026-06-23 18:07:30 +08:00
},
{
name: "longitude",
label: "所在地坐标经度",
2026-06-24 11:58:57 +08:00
render: FORM_ITEM_RENDER_ENUM.INPUT_NUMBER,
useConstraints: false,
componentProps: { ...numberFieldProps, min: -180, max: 180, precision: 6 },
2026-06-23 18:07:30 +08:00
rules: [longitudeRule(false)],
},
{
name: "latitude",
label: "所在地坐标纬度",
2026-06-24 11:58:57 +08:00
render: FORM_ITEM_RENDER_ENUM.INPUT_NUMBER,
useConstraints: false,
componentProps: { ...numberFieldProps, min: -90, max: 90, precision: 6 },
2026-06-23 18:07:30 +08:00
rules: [latitudeRule(false)],
},
{
name: "registerAddress",
label: "注册地址",
rules: [{ required: true, message: "请输入注册地址" }],
render: FORM_ITEM_RENDER_ENUM.TEXTAREA,
},
{
name: "businessAddress",
label: "经营地址",
rules: [{ required: true, message: "请输入经营地址" }],
render: FORM_ITEM_RENDER_ENUM.TEXTAREA,
},
{
name: "ownershipType",
label: "归属类型",
2026-06-24 11:58:57 +08:00
required: false,
2026-06-23 18:07:30 +08:00
},
{
name: "gbIndustryCode",
label: "国民经济行业分类(GB/T4754-2017)",
2026-06-24 11:58:57 +08:00
required: false,
2026-06-23 18:07:30 +08:00
},
{
name: "legalRepresentative",
label: "法定代表人",
rules: [{ required: true, message: "请输入法定代表人" }],
},
{
name: "legalRepPhone",
label: "法定代表人联系电话",
rules: [phoneRule("法定代表人联系电话", false)],
},
{
name: "principal",
label: "主要负责人",
rules: [{ required: true, message: "请输入主要负责人" }],
},
{
name: "principalPhone",
label: "主要负责人联系电话",
rules: [phoneRule("主要负责人联系电话", true)],
},
{
name: "safetyDeptHead",
label: "安全管理部门负责人",
2026-06-24 11:58:57 +08:00
required: false,
2026-06-23 18:07:30 +08:00
},
{
name: "safetyDeptPhone",
label: "安全管理部门负责人联系电话",
rules: [phoneRule("安全管理部门负责人联系电话", false)],
},
{
name: "safetyVp",
label: "主管安全副总",
2026-06-24 11:58:57 +08:00
required: false,
2026-06-23 18:07:30 +08:00
},
{
name: "safetyVpPhone",
label: "主管安全副总联系电话",
rules: [phoneRule("主管安全副总联系电话", false)],
},
{
name: "productionDate",
label: "投产日期",
2026-06-24 11:58:57 +08:00
required: false,
2026-06-23 18:07:30 +08:00
render: FORM_ITEM_RENDER_ENUM.DATE,
},
{
name: "businessStatus",
label: "企业经营状态",
2026-06-24 11:58:57 +08:00
required: false,
2026-06-23 18:07:30 +08:00
},
{
name: "disclosureUrl",
label: "信息公开网址",
2026-06-24 11:58:57 +08:00
useConstraints: false,
2026-06-23 18:07:30 +08:00
rules: [urlRule("信息公开网址", false)],
},
{
name: "workplaceArea",
label: "工作场所建筑面积",
2026-06-24 11:58:57 +08:00
render: FORM_ITEM_RENDER_ENUM.INPUT_NUMBER,
useConstraints: false,
componentProps: { ...numberFieldProps, min: 0, precision: 2 },
2026-06-23 18:07:30 +08:00
rules: [positiveNumberRule("工作场所建筑面积", false)],
},
{
name: "archiveRoomArea",
label: "档案室面积",
2026-06-24 11:58:57 +08:00
render: FORM_ITEM_RENDER_ENUM.INPUT_NUMBER,
useConstraints: false,
componentProps: { ...numberFieldProps, min: 0, precision: 2 },
2026-06-23 18:07:30 +08:00
rules: [positiveNumberRule("档案室面积", false)],
},
{
name: "fullTimeEvaluatorCount",
label: "专职安全评价师数量",
2026-06-24 11:58:57 +08:00
render: FORM_ITEM_RENDER_ENUM.INPUT_NUMBER,
useConstraints: false,
componentProps: { ...numberFieldProps, min: 0, precision: 0 },
rules: [nonNegativeIntegerRule("专职安全评价师数量", false)],
2026-06-23 18:07:30 +08:00
},
{
name: "registeredSafetyEngineerCount",
label: "注册安全工程师数量",
2026-06-24 11:58:57 +08:00
render: FORM_ITEM_RENDER_ENUM.INPUT_NUMBER,
useConstraints: false,
componentProps: { ...numberFieldProps, min: 0, precision: 0 },
rules: [nonNegativeIntegerRule("注册安全工程师数量", false)],
2026-06-23 18:07:30 +08:00
},
];
return (
<Page isShowAllAction={false}>
<PageHeader
title="机构信息管理"
subTitle="新成立或首次使用系统的安全评价机构,可通过系统提供的引导页面,详细填写机构的基本信息。"
2026-06-24 11:58:57 +08:00
extra={hasExistingData && !editing && (
2026-06-23 18:07:30 +08:00
<Button type="primary" onClick={() => setEditing(true)}>
修改
</Button>
)}
/>
<FormBuilder
form={form}
span={12}
disabled={!editing}
2026-06-24 11:58:57 +08:00
useAutoGenerateRequired={false}
2026-06-23 18:07:30 +08:00
options={formOptions}
labelCol={{ span: 10 }}
showActionButtons={false}
/>
{editing && (
<div style={{ marginTop: 24, textAlign: "center" }}>
<Space>
2026-06-24 11:58:57 +08:00
<Button onClick={handleCancelEdit}>
2026-06-23 18:07:30 +08:00
取消
</Button>
2026-06-24 11:58:57 +08:00
{!hasExistingData && (
<Button loading={submitting} onClick={() => handleSave("draft")}>
暂存
</Button>
)}
2026-06-23 18:07:30 +08:00
<Button type="primary" loading={submitting} onClick={() => handleSave("submit")}>
提交
</Button>
</Space>
</div>
)}
</Page>
);
}
export default Connect([NS_ORG_INFO], true)(OrgInfoPage);