import './proj-config-list-mod.css'; import { Alert, Breadcrumb, Button, Col, Flex, Form, Input, message, Modal, Row, Spin, } from "antd"; import {Link, useNavigate, useParams} from "react-router-dom"; import {useEffect, useState} from "react"; import FaiconSelect from "../../../components/faicon/FaIconSelect.tsx"; import ModField, {IModField} from "../../../components/modfield/ModField.tsx"; import {post} from "../../../util/AjaxUtils.ts"; type FormFieldType = { modName: string; modDesc: string; modIcon: string; fields: IModField[]; } export default function ProjConfigModSave() { const nav = useNavigate(); const pathParams = useParams(); const [messageApi, contextHolder] = message.useMessage(); const [form] = Form.useForm(); const [loading, setLoading] = useState(false); const [isModIconModalOpen, setIsModIconModalOpen] = useState(false); const [isEditModalOpen, setIsEditModalOpen] = useState(false); const [selectedModIcon, setSelectedModIcon] = useState('fa fa-list'); const height = window.innerHeight - 180; useEffect(() => { form.setFieldsValue({ modIcon: 'fa fa-list' }) }, []) return ( <> {contextHolder} 首页}, {title: 创建项目}, {title: 编辑项目}, {title: 系统菜单管理}, {title: '添加菜单'}, ]} />
{ setIsEditModalOpen(true); }} autoComplete="off" > label="菜单名称" name="modName" extra="此内容会作为菜单名生成菜单,最多8个字" rules={[{required: true, message: '请输入菜单名称'}]} > label="菜单说明" name="modDesc" extra="此内容会作为功能描述生成到操作手册中,请详细描述,最多600字" rules={[{required: true, message: '请输入菜单说明'}]} > label="菜单图标" name="modIcon" extra="菜单图标会显示在菜单栏中" rules={[{required: true, message: '请输入菜单图标'}]} > name="fields" rules={[{required: true, message: '请添加菜单属性'}]} > { if (!dataArray) { return; } form.setFieldValue('fields', dataArray); }}/>
{ setIsEditModalOpen(false); post({ messageApi, url: `/api/proj-mod/save`, body: { projId: pathParams.projId, modName: form.getFieldValue('modName'), modDesc: form.getFieldValue('modDesc'), modIcon: form.getFieldValue('modIcon'), fields: form.getFieldValue('fields'), }, onBefore() { setLoading(true); }, onSuccess() { messageApi.success('添加成功'); nav(0); }, onFinally() { setLoading(false); } }) }} onCancel={() => { setIsEditModalOpen(false); }}>
确定提交吗?
{ setIsModIconModalOpen(false); }}>
{ form.setFieldValue('modIcon', icon); setSelectedModIcon(icon); }} />
) }