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_FREE } from "./edit/ProjConfigModList.tsx"; import { GenerateStatus } from "../../interfaces/proj/IProj.ts"; export default function ProjEdit() { const nav = useNavigate(); const pathParams = useParams(); const [messageApi, contextHolder] = message.useMessage(); const [editStepArray, setEditStepArray] = useState([]); const [configArray, setConfigArray] = useState([]); const [isEditStepEdited, setIsEditStepEdited] = useState(false); const [isConfigEdited, setIsConfigEdited] = useState(false); const [canGenerate, setCanGenerate] = useState(false); const [generateStatus, setGenerateStatus] = useState(GenerateStatus.NONE); const [previewUrl, setPreviewUrl] = useState(''); // const height = window.innerHeight - 240; const renderEditStep = (data: any, isEdited: boolean, isGenerateSuccess: boolean) => { const editStepArray: IProjEdit[] = []; editStepArray.push( { title: '标题简介', desc: '完善代码、样式类型和详细介绍等内容', step: 1, btnName: !isGenerateSuccess ? '设置' : '查看', status: data.projIntroduction?EditStepEnum.EDITED:EditStepEnum.UN_EDIT, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/step1/${pathParams.projId}`) } else { nav(`/proj-edit/step1-show/${pathParams.projId}`) } } }, { title: '基本信息', desc: '完善项目简介、编程语言、版本、公司等内容', step: 2, btnName: !isGenerateSuccess ? '设置' : '查看', status: data.apply.projDevCompleteDate?EditStepEnum.EDITED:EditStepEnum.UN_EDIT, canBtnClick: false, handleEdit() { if (generateStatus != GenerateStatus.SUCCESS) { nav(`/proj-edit/step2/${pathParams.projId}`) } else { nav(`/proj-edit/step2-show/${pathParams.projId}`) } } }, { title: '软件功能特点', desc: '请完善软件功能特点', step: 3, btnName: !isGenerateSuccess ? '设置' : '查看', status: data.apply.envHardDev?EditStepEnum.EDITED:EditStepEnum.UN_EDIT, canBtnClick: false, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/step3/${pathParams.projId}`) } else { nav(`/proj-edit/step3-show/${pathParams.projId}`) } } }, { title: '登录界面设置', desc: '请对登录界面完成个性化设置', step: 1, btnName: !isGenerateSuccess ? '设置' : '查看', canBtnClick: false, // 状态判断lyp status:data.loginpage.loginpageId?EditStepEnum.EDITED:EditStepEnum.UN_EDIT, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/config-loginpage/${pathParams.projId}`) } else { nav(`/proj-edit/config-loginpage-show/${pathParams.projId}`) } } }, // { // title: '著作人信息', // desc: '请完善著作人相关信息', // step: 4, // btnName: !isGenerateSuccess ? '设置' : '查看', // status: editSteps[3].editStatus, // canBtnClick: false, // 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, // canBtnClick: false, // handleEdit() { // if (!isGenerateSuccess) { // nav(`/proj-edit/step5/${pathParams.projId}`) // } else { // nav(`/proj-edit/step5-show/${pathParams.projId}`) // } // } // }, // { // title: '选择登录页面', // desc: '选择软件的登录页面模板', // step: 6, // btnName: !isGenerateSuccess ? '设置' : '查看', // status: editSteps[5].editStatus, // handleEdit() { // if (!isGenerateSuccess) { // nav(`/proj-edit/step6/${pathParams.projId}`) // } else { // nav(`/proj-edit/step6-show/${pathParams.projId}`) // } // } // } ) setEditStepArray(editStepArray); setIsEditStepEdited(isEdited); } const renderSetting = (data: any, isConfig: boolean, isGenerateSuccess: boolean) => { const configArray: IProjEdit[] = []; configArray.push( // { // title: '登录界面设置', // desc: '请对登录界面完成个性化设置', // step: 1, // btnName: !isGenerateSuccess ? '设置' : '查看', // status: data.loginpage.loginpageId ? EditStepEnum.EDITED : EditStepEnum.UN_EDIT, // handleEdit() { // if (!isGenerateSuccess) { // nav(`/proj-edit/config-loginpage/${pathParams.projId}`) // } else { // nav(`/proj-edit/config-loginpage-show/${pathParams.projId}`) // } // } // }, { title: '系统菜单管理', desc: '请对系统菜单进行设置', step: 2, btnName: !isGenerateSuccess ? '设置' : '查看', status: data.projModCount > MAX_MOD_SIZE_FREE ? EditStepEnum.EDITED : EditStepEnum.UN_EDIT, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/config-mod-flist/${pathParams.projId}`) } else { nav(`/proj-edit/config-mod-flist-show/${pathParams.projId}`) } } }, { title: '菜单顺序', desc: '调整菜单顺序', step: 3, btnName: !isGenerateSuccess ? '设置' : '查看', status: data.projModCount > MAX_MOD_SIZE_FREE ? EditStepEnum.EDITED : EditStepEnum.UN_EDIT, handleEdit() { if (!isGenerateSuccess) { nav(`/proj-edit/config-menu-list/${pathParams.projId}`) } else { nav(`/proj-edit/config-menu-list-show/${pathParams.projId}`) } } } ) setConfigArray(configArray); setIsConfigEdited(isConfig); } const renderData = () => { get({ messageApi: messageApi, url: `/api/proj/get/${pathParams.projId}`, onSuccess({ data }) { // const isEdited = data.editSteps[0].editStatus == EditStepEnum.EDITED // && data.editSteps[5].editStatus == EditStepEnum.EDITED; // console.log(data); const isEdited = Boolean(data.projIntroduction) && Boolean(data.loginpage.loginpageId) == true // console.log('isEdited',isEdited); const isConfig = data.loginpage.loginpageId && data.projModCount > MAX_MOD_SIZE_FREE; const isGenerate = isEdited && isConfig; const isGenerateSuccess: boolean = data.generate.generateStatus == GenerateStatus.SUCCESS; renderEditStep(data, isEdited, isGenerateSuccess); renderSetting(data, isConfig, isGenerateSuccess); setCanGenerate(isGenerate); setGenerateStatus(data.generate.generateStatus); setPreviewUrl(data.previewUrl); } }) } useEffect(() => { renderData(); }, []) return ( <> {contextHolder} {/* 首页 }, { title: 创建项目 }, { title: '编辑项目' }, ]} /> */}
{ editStepArray.map((item, index) => { return }) } { configArray.map((item, index) => { return }) } { isEditStepEdited && isConfigEdited ? ( { window.open(`${Axios.defaults?.baseURL}/${previewUrl}`, '_blank') }} /> ) : <> } { generateStatus == GenerateStatus.NONE || generateStatus == GenerateStatus.FAILED ? ( { }} background='#f3f3f3' /> ) : <> } { }} /> { }} /> { }} /> { }} /> { }} />
) }