import React,{ Component } from "react";
import { Modal,Checkbox,Input, Spin, Icon,notification } from "antd";
import axios from 'axios';
import Modals from '../../modals/Modals';
const CheckboxGroup = Checkbox.Group;
class Addcourses extends Component{
constructor(props){
super(props);
this.state={
invite_code:undefined,
Addcoursestype:false,
Checkboxteacherchecked:false,
Checkboxteachingchecked:false,
Checkboxstudentchecked:false,
Checkboxteachertype:false,
Checkboxteachingtype:false,
professor:null,
assistant_professor:null,
student:null,
course_id:undefined,
loadtype:false,
modalsType:false,
modalsTopval:undefined,
modalSave:undefined,
isSpin:false
}
}
componentDidMount() {
axios.interceptors.response.use((response) => {
if (response != undefined)
if (response && response.data.status === 409) {
this.setState({
Addcoursestypes: true
})
}
return response;
}, (error) => {
//TODO 这里如果样式变了会出现css不加载的情况
});
let {Addcoursestype}=this.props;
this.setState({
Addcoursestype:Addcoursestype
})
}
openNotification = (messge) => {
notification.open({
message: "提示",
description:
messge,
onClick: () => {
console.log('Notification Clicked!');
},
});
};
inputjoinclassvalue=(e)=>{
if(e.target.value.length>=7){
this.openNotification("请输入5位课堂邀请码或6位分班邀请码!");
return
}
this.setState({
invite_code:e.target.value
})
}
Checkboxteaching=(e)=>{
if(e.target.checked===true){
this.setState({
assistant_professor:1,
Checkboxteachingchecked:e.target.checked,
Checkboxteachertype:true
})
}else{
this.setState({
professor:null,
Checkboxteachingchecked:e.target.checked,
Checkboxteachertype:false
})
}
}
Checkboxteacher=(e)=>{
if(e.target.checked===true){
this.setState({
professor:1,
Checkboxteacherchecked:e.target.checked,
Checkboxteachingtype:true
})
}else{
this.setState({
professor:null,
assistant_professor:null,
Checkboxteacherchecked:e.target.checked,
Checkboxteachingtype:false
})
}
}
Checkboxstudent=(e)=>{
if(e.target.checked===true){
this.setState({
student:1,
Checkboxstudentchecked:e.target.checked
})
}else{
this.setState({
student:null,
Checkboxstudentchecked:e.target.checked
})
}
}
hidetojoinclass=()=>{
let {Addcoursestype}=this.props;
// console.log(this.props)
this.setState({
invite_code:undefined,
Addcoursestype:false,
Checkboxteacherchecked:false,
Checkboxteachingchecked:false,
Checkboxstudentchecked:false,
Checkboxteachertype:false,
Checkboxteachingtype:false,
professor:null,
assistant_professor:null,
student:null,
Addcoursestypes:false
})
if(Addcoursestype===true){
this.props.hideAddcoursestype();
}else{
window.location.href = "/";
}
}
submitasyn=(course_id)=>{
let{professor,Addcoursestype}=this.state;
if(professor===1){
this.setState({
loadtype:true,
modalsType:true,
modalsTopval:"申请已提交,请等待审核",
modalSave:(course_id)=>this.submitasyns(course_id),
Addcoursestype:false
})
if(Addcoursestype===true){
this.props.hideAddcoursestype();
}
}else{
// let{course_id}=this.state;
this.setState({
Addcoursestype:false
})
if(Addcoursestype===true){
this.props.hideAddcoursestype();
}
window.location.href ="/courses/"+course_id+"/students";
}
}
submitasyns=(course_id)=>{
window.location.href ="/courses/"+course_id+"/students";
}
submittojoinclass=()=>{
let{Addcoursestype}=this.state;
this.setState({
isSpin:true
})
let {invite_code,professor,assistant_professor,student}=this.state;
if(invite_code===undefined||invite_code===""){
this.setState({
invite_codetype:true,
invite_codevalue:"邀请码不能为空",
isSpin:false
})
return
}else{
this.setState({
invite_codetype:false,
invite_codevalue:" ",
isSpin:false
})
}
let url="/courses/apply_to_join_course.json"
axios.post(url, {
invite_code:invite_code,
professor:professor,
assistant_professor:assistant_professor,
student:student
}
).then((response) => {
if(response === undefined){
return
}
if(response.data.status===0){
// course_id: 1545
// message: "成功"
// status: 0
// this.setState({
// // loadtype:true,
// // modalsType:true,
// // modalsTopval:response.data.message,
// // modalSave:this.submitasyn,
// course_id:response.data.course_id
// })
// https://www.trustie.net/issues/22365
if (response.data.course_id == 2704) {
this.props.history.push('/courses/2704/boards/8367/messages/42072')
return;
}
if(response.data.course_id!=undefined){
this.submitasyn(response.data.course_id)
}
notification.open({
message:"提示",
description:response.data.message
});
if(Addcoursestype===true){
this.props.hideAddcoursestype();
}
// this.props.showNotification(response.data.message);
}else{
notification.open({
message:"提示",
description:response.data.message
});
this.setState({
Addcoursestype:false
})
if(Addcoursestype===true){
this.props.hideAddcoursestype();
}
// this.setState({
// loadtype:true,
// modalsType:true,
// modalsTopval:response.data.message,
// modalSave:this.submitasyn,
// course_id:undefined
// })
}
this.setState({
isSpin:false
})
}).catch((error) => {
console.log(error)
this.setState({
isSpin:false
})
})
// if(value===0){
// const form = new FormData();
// form.append('invite_code', tojoinclasstitle);
// form.append('role', pamst);
// form.append('type', 1);
// axios.post(url,form,[true]
// ).then((response) => {
// if( response.data.state===0){
// this.submitstatevalue(0,"加入成功",response.data.course_id)
// }else if( response.data.state===1){
// }else if( response.data.state===2){
// this.submitstatevalue( 0,"课堂已过期! 请联系课堂管理员重启课堂。(在配置课堂处)")
// }else if( response.data.state===3){
// this.submitstatevalue( 0,"您已是课堂成员)",response.data.course_id)
// }else if( response.data.state===4){
// this.submitstatevalue( 0,"您输入的邀请码错误)")
// }else if( response.data.state===5){
// this.submitstatevalue( 0,"您还未登录")
// }else if( response.data.state===6){
// this.submitstatevalue( 0,"申请已提交,请等待审核")
// }else if( response.data.state===7){
// this.submitstatevalue( 0," 您已经发送过申请了,请耐心等待")
// }else if( response.data.state===8){
// this.submitstatevalue( 0,"您已经是该课堂的教师了",response.data.course_id)
// }else if( response.data.state==9){
// this.submitstatevalue( 0,"您已经是该课堂的教辅了",response.data.course_id)
// }else if( response.data.state==10){
// this.submitstatevalue(0,"您已经是该课堂的管理员了",response.data.course_id)
// }else if( response.data.state==11){
// this.submitstatevalue(0," 该课堂已归档,请联系老师")
// }else if( response.data.state==12){
// this.submitstatevalue(0,"您已经发送过申请了,请耐心等待师")
// }else if( response.data.state==13){
// this.submitstatevalue(0,"您申请已提交,请等待审核")
// }else if( response.data.state==14){
// this.submitstatevalue("此邀请码已停用,请与老师联系")
// }else if( response.data.state==15){
// this.submitstatevalue(0,"您已是课堂成员! 加入分班请在课堂具体分班页面进行")
// }else {
// this.submitstatevalue(0," 未知错误,请稍后再试")
// }
// })
//
// }
}
render(){
let {invite_code,
Addcoursestype,
Checkboxteacherchecked,
Checkboxteachertype,
Checkboxteachingchecked,
Checkboxteachingtype,
Checkboxstudentchecked,
loadtype,
modalsType,
modalsTopval,
modalSave,
Addcoursestypes
}=this.state;
const antIcon =
请输入5位课堂邀请码或6位分班邀请码
请至少选择一个身份