import './proj-edit.css'; import { useNavigate, useParams} from "react-router-dom"; import { Button, message} from "antd"; import StepProjEdit from "../../components/step/StepProjEdit.tsx"; import CardProjEdit from "../../components/card/CardProjEdit.tsx"; import {Process} from "../../interfaces/step/IStepProj.ts"; import CardProjDownload from "../../components/card/CardProjDownload.tsx"; import CardProjJump from "../../components/card/CardProjJump.tsx"; import {useEffect, useState} from "react"; import {Axios, get} from "../../util/AjaxUtils.ts"; import {EditStepEnum, IProjEdit} from "../../interfaces/card/ICardProj.ts"; import {MAX_MOD_SIZE} from "./edit/ProjConfigModList.tsx"; import {GenerateStatus} from "../../interfaces/proj/IProj.ts"; export default function ProjEditAll() { const nav = useNavigate(); const pathParams = useParams(); const [messageApi, contextHolder] = message.useMessage(); const [editStepArray, setEditStepArray] = useState([]); const [isEditStepEdited, setIsEditStepEdited] = useState(false); const [isConfigEdited, setIsConfigEdited] = useState(false); const [generateStatus, setGenerateStatus] = useState(GenerateStatus.NONE); const [previewUrl, setPreviewUrl] = useState(''); // const height = window.innerHeight - 240; const renderEditStep = (editSteps: any[], isEdited: boolean, isGenerateSuccess: boolean) => { const editStepArray: IProjEdit[] = []; editStepArray.push( { title: '标题简介', desc: '完善代码、样式类型和详细介绍等内容', step: 1, btnName: !isGenerateSuccess ? '设置' : '查看', status: editSteps[0].editStatus, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/step1/${pathParams.projId}`) } else { nav(`/proj-edit/step1-show/${pathParams.projId}`) } } }, { title: '著作人信息', desc: '请完善著作人相关信息', step: 4, btnName: !isGenerateSuccess ? '设置' : '查看', status: editSteps[3].editStatus, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/step4/${pathParams.projId}`) } else { nav(`/proj-edit/step4-show/${pathParams.projId}`) } } }, { title: '申请人信息', desc: '请完善申请人信息', step: 5, btnName: !isGenerateSuccess ? '设置' : '查看', status: editSteps[4].editStatus, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/step5/${pathParams.projId}`) } else { nav(`/proj-edit/step5-show/${pathParams.projId}`) } } }, ) setEditStepArray(editStepArray); setIsEditStepEdited(isEdited); } const renderData = () => { get({ messageApi: messageApi, url: `/api/proj/get/${pathParams.projId}`, onSuccess({data}) { const isEdited = data.editSteps[0].editStatus == EditStepEnum.EDITED && data.editSteps[1].editStatus == EditStepEnum.EDITED && data.editSteps[2].editStatus == EditStepEnum.EDITED && data.editSteps[3].editStatus == EditStepEnum.EDITED && data.editSteps[4].editStatus == EditStepEnum.EDITED && data.editSteps[5].editStatus == EditStepEnum.EDITED; const isConfig = data.loginpage.loginpageId && MAX_MOD_SIZE > 0; const isGenerateSuccess: boolean = data.generate.generateStatus == GenerateStatus.SUCCESS; renderEditStep(data.editSteps, isEdited, isGenerateSuccess); setIsConfigEdited(isConfig); setGenerateStatus(data.generate.generateStatus); setPreviewUrl(data.previewUrl); } }) } useEffect(() => { renderData(); }, []) return ( <> {contextHolder} {/* 首页}, {title: 创建项目}, {title: '编辑项目'}, ]} /> */}
{ editStepArray.map((item, index) => { return }) } { { window.open(`${Axios.defaults?.baseURL}/${previewUrl}`, '_blank') }} /> } { window.open(`${Axios.defaults?.baseURL}/route/proj/download/apply/${pathParams.projId}`) }} /> { window.open(`${Axios.defaults?.baseURL}/route/proj/download/manual/${pathParams.projId}`) }} /> { window.open(`${Axios.defaults?.baseURL}/route/proj/download/code-zip/${pathParams.projId}`) }} /> { window.open(`${Axios.defaults?.baseURL}/route/proj/download/code/${pathParams.projId}`) }} />
) }