import React, { Component } from 'react'; import {Link} from 'react-router-dom'; import {Tooltip,Menu} from 'antd'; import Loadable from 'react-loadable'; import Loading from '../../../../Loading'; import {BrowserRouter as Router,Route,Switch} from 'react-router-dom'; import axios from 'axios'; import HomeworkModal from "../../coursesPublic/HomeworkModal"; import AccessoryModal from "../../coursesPublic/AccessoryModal"; import Associationmodel from '../../coursesPublic/Associationmodel'; import CoursesListType from '../../coursesPublic/CoursesListType'; import moment from 'moment'; import "../../css/members.css" import "../../css/Courses.css" import Modals from '../../../modals/Modals'; //毕设描述 const GraduationTasksquestions= Loadable({ loader: () => import('./GraduationTaskssettingquestions'), loading: Loading, }) //毕设任务设置 const GraduationTaskssetting=Loadable({ loader: () => import('./GraduationTaskssetting'), loading: Loading, }) //毕设任务列表 const GraduationTaskslist=Loadable({ loader: () => import('./GraduationTaskssettinglist'), loading: Loading, }) class GraduationTaskDetail extends Component{ constructor(props){ super(props); this.state={ modalname:undefined, visible:false, Topval:undefined, starttime:undefined, starttimes:undefined, typs:undefined, endtime:undefined, Cancelname:undefined, Savesname:undefined, Cancel:undefined, Saves:undefined, Topvalright:undefined, Botvalleft:undefined, course_groupslist:undefined, course_groups:undefined, questionslist:undefined, tab:"list", visibles:undefined, Modalstype:undefined, Modalstopval:undefined, ModalCancel:undefined, ModalSave:undefined } } componentDidMount(){ this.getdatas() } getdatas=()=>{ const task_Id = this.props.match.params.task_Id; let url="/graduation_tasks/"+task_Id+".json"; axios.get(url).then((result)=>{ if(result.status===200){ this.setState({ questionslist:result.data }) } }).catch((error)=>{ console.log(error) }) } //返回 goback=()=>{ // let courseId=this.props.match.params.coursesId; // let category_id=this.props.match.params.category_id; // window.location.href="/courses/"+courseId+"/graduation_tasks/"+category_id; // let courseId = this.props.match.params.coursesId; // if(courseId===undefined){ // this.props.history.push("/courses"); // }else{ // this.props.history.push(this.props.current_user.first_category_url); // } // this.props.history.goBack() this.props.history.replace(`/courses/${this.state.questionslist.course_id}/graduation_tasks/${this.state.questionslist.graduation_id}`); } //立即发布 publish=()=>{ let starttime= this.props.getNowFormatDates(1,1); let endtime=this.props.getNowFormatDates(2,1); // this.homeworkstart() this.setState({ modalname:"立即发布", visible:true, Topval:"学生将立即收到毕设任务", // Botvalleft:"点击修改", // Botval:`本操作只对"未发布"的分班有效`, starttime:moment(moment(new Date())).format("YYYY-MM-DD HH:mm") , starttimes:this.props.getNowFormatDates(1), typs:"start", endtime:endtime, Cancelname:"暂不发布", Savesname:"立即发布", Cancel:this.cancelmodel, Saves:this.homepublish, }) } // 确定立即发布 homepublish=(ids,endtime)=>{ this.cancelmodel(); let task_Id=this.props.match.params.task_Id; const cid = this.props.match.params.coursesId; // let url = `/courses/${cid}/graduation_tasks/publish_task.json`; let url="/courses/"+cid+"/graduation_tasks/publish_task.json" axios.post(url,{ task_ids:[task_Id], group_ids: this.state.course_groupslist, end_time:endtime, }).then((response)=>{ if (response.data.status == 0) { this.getdatas() this.props.showNotification(response.data.message); this.setState({ // Modalstopval:response.data.message, // ModalSave:this.cancelmodel, // Loadtype:true, course_groupslist:[], checkAllValue:false }) } }).catch((error)=>{ }) } // 刷新 resetList=()=>{ this.getdatas(); this.child && this.child.searchValue(); } // 立即截止 end=()=>{ // this.homeworkstart() this.setState({ modalname:"立即截止", visible:true, Topval:"学生将不能再提交作品", // Botvalleft:"暂不截止", // Botval:`本操作只对"提交中"的分班有效`, Cancelname:"暂不截止", Savesname:"立即截止", Cancel:this.cancelmodel, Saves:this.coursetaskend, typs:"end", }) } // 取消 cancelmodel=()=>{ this.setState({ Modalstype:false, Loadtype:false, visible:false, Modulationtype:false, Allocationtype:false, Modalstopval:"", ModalCancel:"", ModalSave:"", }) } getcourse_groupslist=(id)=>{ this.setState({ course_groupslist:id }) } setTab = (tab) =>{ this.setState({ tab }) } // 关联项目 AssociationItems=()=>{ this.setState({ visibles:true }) } Cancel=()=>{ this.setState({ visibles:false }) } // 取消关联 cannelAssociation=()=>{ this.setState({ Modalstype:true, Modalstopval:"确定要取消该项目关联?", ModalCancel:this.cannerassocition, ModalSave:this.savetassociton }) } savetassociton=()=>{ this.cannerassocition(); let {questionslist}=this.state; let url = "/graduation_tasks/"+questionslist.task_id+"/graduation_works/cancel_relate_project.json"; console.log(url) axios.get(url).then((result)=>{ if(result.data.status===0){ this.resetList(); } }).catch((error)=>{ console.log(error) }) } cannerassocition=()=>{ this.setState({ Modalstype:false, Modalstopval:"", ModalCancel:"", ModalSave:"", loadtype:false, visibles:false }) } // 补交附件 handaccessory=()=>{ // let {taskslistdata}=this.state; // let courseId=this.props.match.params.coursesId; // // let url="/courses/"+courseId+"/graduation_tasks/"+taskslistdata.work_id+"/appraise" // // window.location.href=url; this.setState({ avisible:true }) } Cancelvisible=()=>{ this.setState({ avisible:false }) } bindRef = ref => { this.child = ref } ; render(){ let courseId=this.props.match.params.coursesId; let category_id=this.props.match.params.category_id; let task_Id=this.props.match.params.task_Id; let { questionslist , tab , visibles , Modalstype, Modalstopval, ModalCancel, ModalSave } = this.state const commom = { setTab:this.setTab } return(
{ questionslist &&
this.getcourse_groupslist(id)} /> {/*关联项目*/} {visibles===true? this.Cancel()} taskid={ questionslist && questionslist.task_id } funlist={this.resetList} /> :""} {this.state.avisible===true?:""} {/*提示*/}

{questionslist.course_name} > {questionslist.graduation_name} > 任务详情

{questionslist.task_name}

返回
任务列表 毕设描述 设置 {/*导出成绩*/} {/*{this.props.isAdmin()?导出成绩:""}*/} {/*{this.props.isAdmin()?导出作品附件:""}*/} {this.props.isAdmin()?
  • 导出
  • :""} {questionslist.work_status===undefined||questionslist.work_status===null||questionslist.work_status.length===0?"":questionslist.work_status.map((item,key)=>{ return( {item==="提交作品"?提交作品:""} {item==="补交作品"?补交作品:""} {item==="修改作品"?修改作品:""} {item==="查看作品"?查看作品 :""} {item==="创建项目"?创建项目:""} {item==="关联项目"?关联项目:""} {item==="取消关联"?取消关联:""} {item==="补交附件"?补交附件:""} ) })} {/*项目在线质量检测*/} { this.props.isAdmin() ? questionslist.status===1 ? { this.end()} }>立即截止 : "" : "" } { this.props.isAdmin() ? questionslist.status===0 ? { this.publish()} }>立即发布 : "" : "" } { this.props.isAdmin() ? 编辑任务 : "" }
    () } > () } > () }>
    }
    ) } } // CNotificationHOC() ( SnackbarHOC() ( TPMIndexHOC)) export default (GraduationTaskDetail) ;