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.course_name} > {questionslist.graduation_name} > 任务详情