营业执照上传开发
Some checks failed
Node CI / build (14.x, macOS-latest) (push) Has been cancelled
Node CI / build (14.x, ubuntu-latest) (push) Has been cancelled
Node CI / build (14.x, windows-latest) (push) Has been cancelled
Node CI / build (16.x, macOS-latest) (push) Has been cancelled
Node CI / build (16.x, ubuntu-latest) (push) Has been cancelled
Node CI / build (16.x, windows-latest) (push) Has been cancelled
CodeQL / Analyze (javascript) (push) Has been cancelled
coverage CI / build (push) Has been cancelled
Node pnpm CI / build (16.x, macOS-latest) (push) Has been cancelled
Node pnpm CI / build (16.x, ubuntu-latest) (push) Has been cancelled
Node pnpm CI / build (16.x, windows-latest) (push) Has been cancelled

This commit is contained in:
francis-fh
2026-06-03 13:47:25 +08:00
parent 8c0d0b143b
commit 3815dd63da
3 changed files with 147 additions and 63 deletions

View File

@@ -1,9 +1,11 @@
import React, { useEffect, useState } from 'react';
import { Modal, Form, Input, DatePicker, Upload, Button, message } from 'antd';
import { Modal, Form, Input, DatePicker, Upload, Button, message, Row, Col, Select } from 'antd';
import { UploadOutlined, DeleteOutlined } from '@ant-design/icons';
import type { UploadFile } from 'antd/es/upload/interface';
import dayjs from 'dayjs';
import { uploadPolicyFile } from '@/services/cms/policyInfo';
import { getDictValueEnum } from '@/services/system/dict';
import type { DictValueEnumObj } from '@/components/DictTag';
const { TextArea } = Input;
@@ -18,6 +20,13 @@ const EditModal: React.FC<EditModalProps> = ({ open, values, onCancel, onSubmit
const [form] = Form.useForm();
const [fileList, setFileList] = useState<UploadFile[]>([]);
const [uploading, setUploading] = useState(false);
const [userTypeEnum, setUserTypeEnum] = useState<DictValueEnumObj>({});
useEffect(() => {
getDictValueEnum('user_type', false, true).then((data) => {
setUserTypeEnum(data);
});
}, []);
useEffect(() => {
if (open) {
@@ -25,6 +34,9 @@ const EditModal: React.FC<EditModalProps> = ({ open, values, onCancel, onSubmit
form.setFieldsValue({
...values,
publishTime: values.publishTime ? dayjs(values.publishTime) : undefined,
policyTag: values.policyTag
? String(values.policyTag).split(',').filter(Boolean)
: undefined,
});
// 如果有已上传的文件,显示在列表中
if (values.fileUrl && values.fileName) {
@@ -81,88 +93,131 @@ const EditModal: React.FC<EditModalProps> = ({ open, values, onCancel, onSubmit
const handleOk = async () => {
const formValues = await form.validateFields();
const { policyTag, publishTime, ...rest } = formValues;
onSubmit({
...formValues,
...rest,
id: values?.id,
publishTime: formValues.publishTime?.format('YYYY-MM-DD'),
publishTime: publishTime?.format('YYYY-MM-DD'),
policyTag: Array.isArray(policyTag) ? policyTag.join(',') : policyTag,
});
};
const userTypeOptions = Object.values(userTypeEnum).map((item) => ({
label: item.label,
value: item.value,
}));
return (
<Modal
title={values ? '编辑政策' : '新增政策'}
open={open}
onCancel={onCancel}
onOk={handleOk}
width={700}
width={900}
destroyOnClose
>
<Form form={form} layout="vertical">
<Form.Item name="zcmc" label="政策名称" rules={[{ required: true, message: '请输入政策名称' }]}>
<Input placeholder="请输入政策名称" />
</Form.Item>
<Form.Item name="zclx" label="政策类型">
<Input placeholder="请输入政策类型" />
</Form.Item>
<Form.Item name="zcLevel" label="政策级别">
<Input placeholder="请输入政策级别" />
</Form.Item>
<Form.Item name="sourceUnit" label="发文单位">
<Input placeholder="请输入发文单位" />
</Form.Item>
<Form.Item name="acceptUnit" label="受理单位">
<Input placeholder="请输入受理单位" />
</Form.Item>
<Form.Item name="publishTime" label="发文时间">
<DatePicker style={{ width: '100%' }} />
</Form.Item>
<Form.Item name="zcContent" label="政策内容">
<TextArea rows={4} placeholder="请输入政策内容" />
</Form.Item>
<Form.Item name="subsidyStandard" label="补贴标准">
<TextArea rows={2} placeholder="请输入补贴标准" />
</Form.Item>
<Form.Item name="handleChannel" label="经办渠道">
<Input placeholder="请输入经办渠道" />
</Form.Item>
<Form.Item name="applyCondition" label="申报条件">
<TextArea rows={2} placeholder="请输入申报条件" />
</Form.Item>
<Form.Item label="政策文件">
{fileList.length > 0 ? (
<div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>
<a href={fileList[0].url} target="_blank" rel="noopener noreferrer">
{fileList[0].name}
</a>
<Button
type="text"
danger
size="small"
icon={<DeleteOutlined />}
onClick={handleRemoveFile}
<Row gutter={16}>
<Col span={12}>
<Form.Item name="zcmc" label="政策名称" rules={[{ required: true, message: '请输入政策名称' }]}>
<Input placeholder="请输入政策名称" />
</Form.Item>
</Col>
<Col span={12}>
<Form.Item name="zclx" label="政策类型">
<Input placeholder="请输入政策类型" />
</Form.Item>
</Col>
<Col span={12}>
<Form.Item name="zcLevel" label="政策级别">
<Input placeholder="请输入政策级别" />
</Form.Item>
</Col>
<Col span={12}>
<Form.Item name="policyTag" label="人员类型">
<Select
mode="multiple"
allowClear
placeholder="请选择人员类型"
options={userTypeOptions}
/>
</div>
) : (
<Upload
beforeUpload={handleUpload}
showUploadList={false}
maxCount={1}
>
<Button icon={<UploadOutlined />} loading={uploading}>
</Button>
</Upload>
)}
</Form.Item>
</Form.Item>
</Col>
<Col span={12}>
<Form.Item name="sourceUnit" label="发文单位">
<Input placeholder="请输入发文单位" />
</Form.Item>
</Col>
<Col span={12}>
<Form.Item name="acceptUnit" label="受理单位">
<Input placeholder="请输入受理单位" />
</Form.Item>
</Col>
<Col span={12}>
<Form.Item name="publishTime" label="发文时间">
<DatePicker style={{ width: '100%' }} />
</Form.Item>
</Col>
<Col span={12}>
<Form.Item name="handleChannel" label="经办渠道">
<Input placeholder="请输入经办渠道" />
</Form.Item>
</Col>
<Col span={24}>
<Form.Item name="zcContent" label="政策内容">
<TextArea rows={4} placeholder="请输入政策内容" />
</Form.Item>
</Col>
<Col span={24}>
<Form.Item name="subsidyStandard" label="补贴标准">
<TextArea rows={2} placeholder="请输入补贴标准" />
</Form.Item>
</Col>
<Col span={24}>
<Form.Item name="applyCondition" label="申报条件">
<TextArea rows={2} placeholder="请输入申报条件" />
</Form.Item>
</Col>
<Col span={24}>
<Form.Item label="政策文件">
{fileList.length > 0 ? (
<div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>
<a href={fileList[0].url} target="_blank" rel="noopener noreferrer">
{fileList[0].name}
</a>
<Button
type="text"
danger
size="small"
icon={<DeleteOutlined />}
onClick={handleRemoveFile}
/>
</div>
) : (
<Upload
beforeUpload={handleUpload}
showUploadList={false}
maxCount={1}
>
<Button icon={<UploadOutlined />} loading={uploading}>
</Button>
</Upload>
)}
</Form.Item>
</Col>
<Col span={24}>
<Form.Item name="remark" label="备注">
<TextArea rows={2} placeholder="请输入备注" />
</Form.Item>
</Col>
</Row>
<Form.Item name="fileUrl" hidden>
<Input />
</Form.Item>
<Form.Item name="fileName" hidden>
<Input />
</Form.Item>
<Form.Item name="remark" label="备注">
<TextArea rows={2} placeholder="请输入备注" />
</Form.Item>
</Form>
</Modal>
);

View File

@@ -1,4 +1,4 @@
import React, { useRef, useState } from 'react';
import React, { useEffect, useRef, useState } from 'react';
import { useAccess } from '@umijs/max';
import { Button, message, Modal } from 'antd';
import { ActionType, PageContainer, ProColumns, ProTable } from '@ant-design/pro-components';
@@ -10,6 +10,8 @@ import {
updatePolicyInfo,
deletePolicyInfo,
} from '@/services/cms/policyInfo';
import { getDictValueEnum } from '@/services/system/dict';
import DictTag, { DictValueEnumObj } from '@/components/DictTag';
import EditModal from './components/EditModal';
import DetailModal from './components/DetailModal';
@@ -20,6 +22,13 @@ const PolicyMgmt: React.FC = () => {
const [detailModalVisible, setDetailModalVisible] = useState(false);
const [currentRow, setCurrentRow] = useState<API.PolicyInfo.PolicyInfoItem>();
const [selectedRowKeys, setSelectedRowKeys] = useState<React.Key[]>([]);
const [userTypeEnum, setUserTypeEnum] = useState<DictValueEnumObj>({});
useEffect(() => {
getDictValueEnum('user_type', false, true).then((data) => {
setUserTypeEnum(data);
});
}, []);
const handleDelete = async (ids: string) => {
Modal.confirm({
@@ -56,6 +65,25 @@ const PolicyMgmt: React.FC = () => {
hideInSearch: true,
width: 100,
},
{
title: '标签',
dataIndex: 'policyTag',
hideInSearch: true,
width: 160,
render: (_, record) => {
if (!record.policyTag) {
return '-';
}
const tags = String(record.policyTag).split(',').filter(Boolean);
return (
<span style={{ display: 'flex', flexWrap: 'wrap', gap: 4 }}>
{tags.map((tag) => (
<DictTag key={tag} enums={userTypeEnum} value={tag.trim()} />
))}
</span>
);
},
},
{
title: '发文单位',
dataIndex: 'sourceUnit',

View File

@@ -24,6 +24,7 @@ declare namespace API.PolicyInfo {
export interface PolicyInfoItem {
id: number;
policyTag?: string;
zcmc: string;
zclx: string;
zcLevel: string;