|
|
|
@ -1,95 +1,97 @@
|
|
|
|
|
import React, {Component} from "react";
|
|
|
|
|
import {WordsBtn} from 'educoder';
|
|
|
|
|
import {Table,InputNumber,Tooltip} from "antd";
|
|
|
|
|
import {Link,Switch,Route,Redirect} from 'react-router-dom';
|
|
|
|
|
import {Table, InputNumber, Tooltip} from "antd";
|
|
|
|
|
import {Link, Switch, Route, Redirect} from 'react-router-dom';
|
|
|
|
|
import axios from 'axios';
|
|
|
|
|
|
|
|
|
|
class OfficialAcademicTranscript extends Component {
|
|
|
|
|
|
|
|
|
|
constructor(props) {
|
|
|
|
|
super(props);
|
|
|
|
|
this.state = {
|
|
|
|
|
loadingstate:true,
|
|
|
|
|
datas:undefined,
|
|
|
|
|
customsids:undefined
|
|
|
|
|
loadingstate: true,
|
|
|
|
|
datas: undefined,
|
|
|
|
|
customsids: undefined
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
myjumptopic=(e)=>{
|
|
|
|
|
|
|
|
|
|
myjumptopic = (e) => {
|
|
|
|
|
console.log("获取到值");
|
|
|
|
|
console.log(e);
|
|
|
|
|
this.props.jumptopic(e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
editgame_scores=(e,id,maxsum)=>{
|
|
|
|
|
let{datas}=this.state;
|
|
|
|
|
let newdatas=datas;
|
|
|
|
|
let score=e.target.value;
|
|
|
|
|
editgame_scores = (e, id, maxsum) => {
|
|
|
|
|
let {datas} = this.state;
|
|
|
|
|
let newdatas = datas;
|
|
|
|
|
let score = e.target.value;
|
|
|
|
|
|
|
|
|
|
if(score!=null&&score!=undefined&&score!=""){
|
|
|
|
|
if(score<0){
|
|
|
|
|
if (score != null && score != undefined && score != "") {
|
|
|
|
|
if (score < 0) {
|
|
|
|
|
this.props.showNotification("不能小于0");
|
|
|
|
|
this.setState({
|
|
|
|
|
customsids:id
|
|
|
|
|
customsids: id
|
|
|
|
|
})
|
|
|
|
|
}else if(score>maxsum){
|
|
|
|
|
} else if (score > maxsum) {
|
|
|
|
|
this.props.showNotification(`不能大于关卡分值${maxsum}`);
|
|
|
|
|
this.setState({
|
|
|
|
|
customsids:id
|
|
|
|
|
customsids: id
|
|
|
|
|
})
|
|
|
|
|
}else{
|
|
|
|
|
let work_id=this.props.data.work_id;
|
|
|
|
|
let url=`/student_works/${work_id}/adjust_review_score.json`
|
|
|
|
|
axios.post(url,{
|
|
|
|
|
type:"report",
|
|
|
|
|
score:score,
|
|
|
|
|
challenge_id:id
|
|
|
|
|
}).then((result)=>{
|
|
|
|
|
if(result.data.status===0){
|
|
|
|
|
} else {
|
|
|
|
|
let work_id = this.props.data.work_id;
|
|
|
|
|
let url = `/student_works/${work_id}/adjust_review_score.json`
|
|
|
|
|
axios.post(url, {
|
|
|
|
|
type: "report",
|
|
|
|
|
score: score,
|
|
|
|
|
challenge_id: id
|
|
|
|
|
}).then((result) => {
|
|
|
|
|
if (result.data.status === 0) {
|
|
|
|
|
// this.props.getdatalist()
|
|
|
|
|
this.props.showNotification(result.data.message);
|
|
|
|
|
this.props.setupdalist(result.data.challenge_score,result.data.overall_appraisal,result.data.work_score)
|
|
|
|
|
newdatas.map((item,key)=>{
|
|
|
|
|
if(item.challenge_id.id===id){
|
|
|
|
|
item.game_scores.game_score=score
|
|
|
|
|
this.props.setupdalist(result.data.challenge_score, result.data.overall_appraisal, result.data.work_score)
|
|
|
|
|
newdatas.map((item, key) => {
|
|
|
|
|
if (item.challenge_id.id === id) {
|
|
|
|
|
item.game_scores.game_score = score
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
this.setState({
|
|
|
|
|
datas:newdatas,
|
|
|
|
|
customsids:undefined
|
|
|
|
|
datas: newdatas,
|
|
|
|
|
customsids: undefined
|
|
|
|
|
})
|
|
|
|
|
}else{
|
|
|
|
|
} else {
|
|
|
|
|
this.props.showNotification(result.data.message);
|
|
|
|
|
}
|
|
|
|
|
}).catch((error)=>{
|
|
|
|
|
}).catch((error) => {
|
|
|
|
|
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}else{
|
|
|
|
|
} else {
|
|
|
|
|
this.props.showNotification("调分为空将不会修改之前的分数");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
render() {
|
|
|
|
|
let {customsids}=this.state;
|
|
|
|
|
let {data}=this.props;
|
|
|
|
|
let {customsids} = this.state;
|
|
|
|
|
let {data} = this.props;
|
|
|
|
|
|
|
|
|
|
let datas=[];
|
|
|
|
|
if(data!=undefined){
|
|
|
|
|
data.stage_list===undefined?"":data.stage_list.forEach((item,key)=>{
|
|
|
|
|
let datas = [];
|
|
|
|
|
if (data != undefined) {
|
|
|
|
|
data.stage_list === undefined ? "" : data.stage_list.forEach((item, key) => {
|
|
|
|
|
datas.push({
|
|
|
|
|
customs: key+1,
|
|
|
|
|
taskname:{name:item.name,complete_status:item.complete_status},
|
|
|
|
|
openingtime:item.open_time,
|
|
|
|
|
customs: key + 1,
|
|
|
|
|
taskname: {name: item.name, complete_status: item.complete_status},
|
|
|
|
|
openingtime: item.open_time,
|
|
|
|
|
evaluating: item.evaluate_count,
|
|
|
|
|
finishtime:item.finished_time,
|
|
|
|
|
elapsedtime:item.time_consuming,
|
|
|
|
|
empvalue:{myself:item.myself_experience,experience:item.experience},
|
|
|
|
|
game_scores:{game_score:item.game_score,game_score_full:item.game_score_full},
|
|
|
|
|
challenge_id:{id:item.challenge_id},
|
|
|
|
|
finishtime: item.finished_time,
|
|
|
|
|
elapsedtime: item.time_consuming,
|
|
|
|
|
empvalue: {myself: item.myself_experience, experience: item.experience},
|
|
|
|
|
game_scores: {game_score: item.game_score, game_score_full: item.game_score_full},
|
|
|
|
|
challenge_id: {id: item.challenge_id},
|
|
|
|
|
challenge_comment: item.challenge_comment,
|
|
|
|
|
challenge_comment_hidden: item.challenge_comment_hidden,
|
|
|
|
|
// adjustmentminute:asdasd
|
|
|
|
@ -97,7 +99,7 @@ class OfficialAcademicTranscript extends Component {
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let columns=[{
|
|
|
|
|
let columns = [{
|
|
|
|
|
title: '关卡',
|
|
|
|
|
dataIndex: 'customs',
|
|
|
|
|
key: 'customs',
|
|
|
|
@ -110,13 +112,17 @@ class OfficialAcademicTranscript extends Component {
|
|
|
|
|
title: '任务名称',
|
|
|
|
|
dataIndex: 'taskname',
|
|
|
|
|
key: 'taskname',
|
|
|
|
|
className:"TaskForms",
|
|
|
|
|
className: "TaskForms",
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
<span className={"task-hide linhe15"} style={{color:"#676767"}}><a className="tasknameName font-14" onClick={()=>this.myjumptopic("id"+record.customs)} title={record.taskname.name.length>15?record.taskname.name:""} >
|
|
|
|
|
<span className={"task-hide linhe15"} style={{color: "#676767"}}><a className="tasknameName font-14"
|
|
|
|
|
onClick={() => this.myjumptopic("id" + record.customs)}
|
|
|
|
|
title={record.taskname.name.length > 15 ? record.taskname.name : ""}>
|
|
|
|
|
{record.taskname.name}
|
|
|
|
|
</a>
|
|
|
|
|
{record.taskname.complete_status===2?<span className={"tasknamebox ml10"}>延时</span>:record.taskname.complete_status===3?<span className={"tasknameboxs ml10"}>延时</span>:""}
|
|
|
|
|
{record.taskname.complete_status === 2 ?
|
|
|
|
|
<span className={"tasknamebox ml10"}>延时</span> : record.taskname.complete_status === 3 ?
|
|
|
|
|
<span className={"tasknameboxs ml10"}>延时</span> : ""}
|
|
|
|
|
</span>
|
|
|
|
|
</span>
|
|
|
|
|
),
|
|
|
|
@ -158,79 +164,101 @@ class OfficialAcademicTranscript extends Component {
|
|
|
|
|
{record.elapsedtime}
|
|
|
|
|
</span>
|
|
|
|
|
),
|
|
|
|
|
}, {
|
|
|
|
|
title: '经验值',
|
|
|
|
|
key: 'empvalue',
|
|
|
|
|
dataIndex: 'empvalue',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '查看答案',
|
|
|
|
|
dataIndex: 'view_answer',
|
|
|
|
|
key: 'view_answer',
|
|
|
|
|
className: "edu-txt-center",
|
|
|
|
|
render: (text, record) => {
|
|
|
|
|
return (
|
|
|
|
|
<span style={{cursor: "default"}}>{record.view_answer === true ? <Tooltip placement="bottom" title={
|
|
|
|
|
<pre>
|
|
|
|
|
学生在完成任务评测之前查是否看了参考答案
|
|
|
|
|
</pre>
|
|
|
|
|
}><span style={{cursor: "default"}}>已查看</span> </Tooltip> : <Tooltip placement="bottom" title={
|
|
|
|
|
<pre>
|
|
|
|
|
学生在完成任务评测之前查是否看了参考答案
|
|
|
|
|
</pre>
|
|
|
|
|
}><span style={{cursor: "default"}}>未查看</span> </Tooltip>}</span>
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '经验值',
|
|
|
|
|
key: 'empvalue',
|
|
|
|
|
dataIndex: 'empvalue',
|
|
|
|
|
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
<span style={{color:'#29BD8B'}}>{record.empvalue.myself}</span><span className={"color-grey-9"}>/{record.empvalue.experience}</span>
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
<span style={{color: '#29BD8B'}}>{record.empvalue.myself}</span><span
|
|
|
|
|
className={"color-grey-9"}>/{record.empvalue.experience}</span>
|
|
|
|
|
</span>
|
|
|
|
|
),
|
|
|
|
|
},{
|
|
|
|
|
title: '关卡得分',
|
|
|
|
|
key: 'game_scores',
|
|
|
|
|
dataIndex: 'game_scores',
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
),
|
|
|
|
|
}, {
|
|
|
|
|
title: '关卡得分',
|
|
|
|
|
key: 'game_scores',
|
|
|
|
|
dataIndex: 'game_scores',
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
<Tooltip placement="bottom" title={
|
|
|
|
|
<pre>
|
|
|
|
|
关卡得分:{record.game_scores.game_score}/关卡满分:{record.game_scores.game_score_full}
|
|
|
|
|
</pre>
|
|
|
|
|
}>
|
|
|
|
|
<span style={{color:'#29BD8B'}}>{record.game_scores.game_score}</span><span className={"color-grey-9"}>/{record.game_scores.game_score_full}</span>
|
|
|
|
|
<span style={{color: '#29BD8B'}}>{record.game_scores.game_score}</span><span
|
|
|
|
|
className={"color-grey-9"}>/{record.game_scores.game_score_full}</span>
|
|
|
|
|
</Tooltip>
|
|
|
|
|
</span>
|
|
|
|
|
),
|
|
|
|
|
},{
|
|
|
|
|
title: '调分',
|
|
|
|
|
key: 'adjustmentminute',
|
|
|
|
|
dataIndex: 'adjustmentminute',
|
|
|
|
|
),
|
|
|
|
|
}, {
|
|
|
|
|
title: '调分',
|
|
|
|
|
key: 'adjustmentminute',
|
|
|
|
|
dataIndex: 'adjustmentminute',
|
|
|
|
|
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
<a><InputNumber size="small" className={customsids===record.challenge_id.id?"bor-red":""} defaultValue={record.game_scores.game_score}
|
|
|
|
|
onBlur={(e) => this.editgame_scores(e,record.challenge_id.id,record.game_scores.game_score_full)}
|
|
|
|
|
// min={0} max={record.game_scores.game_score_full}
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
<a><InputNumber size="small" className={customsids === record.challenge_id.id ? "bor-red" : ""}
|
|
|
|
|
defaultValue={record.game_scores.game_score}
|
|
|
|
|
onBlur={(e) => this.editgame_scores(e, record.challenge_id.id, record.game_scores.game_score_full)}
|
|
|
|
|
// min={0} max={record.game_scores.game_score_full}
|
|
|
|
|
/></a>
|
|
|
|
|
{/*<a style={{textAlign: "center"}} className="color-blue font-14 mr20">查看</a>*/}
|
|
|
|
|
{/*<a style={{textAlign: "center"}} className="color-blue font-14 mr20">查看</a>*/}
|
|
|
|
|
</span>
|
|
|
|
|
),
|
|
|
|
|
},{
|
|
|
|
|
title: '操作',
|
|
|
|
|
key: 'operation',
|
|
|
|
|
dataIndex: 'operation',
|
|
|
|
|
),
|
|
|
|
|
}, {
|
|
|
|
|
title: '操作',
|
|
|
|
|
key: 'operation',
|
|
|
|
|
dataIndex: 'operation',
|
|
|
|
|
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
render: (text, record) => (
|
|
|
|
|
<span>
|
|
|
|
|
|
|
|
|
|
<a
|
|
|
|
|
className=" color-blue font-14 fr mr22"
|
|
|
|
|
onClick={()=>this.props.showAppraiseModal("child",record.challenge_id.id,record.challenge_comment,record.challenge_comment_hidden)}
|
|
|
|
|
onClick={() => this.props.showAppraiseModal("child", record.challenge_id.id, record.challenge_comment, record.challenge_comment_hidden)}
|
|
|
|
|
>评阅</a>
|
|
|
|
|
</span>
|
|
|
|
|
),
|
|
|
|
|
}];
|
|
|
|
|
|
|
|
|
|
),
|
|
|
|
|
}];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(this.props.isAdmin()===false){
|
|
|
|
|
columns.some((item,key)=> {
|
|
|
|
|
if (item.title === "调分") {
|
|
|
|
|
columns.splice(key, 1)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
columns.some((item,key)=> {
|
|
|
|
|
if (item.title === "操作") {
|
|
|
|
|
columns.splice(key, 1)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
if (this.props.isAdmin() === false) {
|
|
|
|
|
columns.some((item, key) => {
|
|
|
|
|
if (item.title === "调分") {
|
|
|
|
|
columns.splice(key, 1)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
columns.some((item, key) => {
|
|
|
|
|
if (item.title === "操作") {
|
|
|
|
|
columns.splice(key, 1)
|
|
|
|
|
return true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
return (
|
|
|
|
|
<div>
|
|
|
|
|
{/*{data===undefined?"":""}*/}
|
|
|
|
@ -301,10 +329,10 @@ class OfficialAcademicTranscript extends Component {
|
|
|
|
|
}
|
|
|
|
|
`}
|
|
|
|
|
</style>
|
|
|
|
|
{datas===undefined?"":<Table
|
|
|
|
|
dataSource={datas}
|
|
|
|
|
{datas === undefined ? "" : <Table
|
|
|
|
|
dataSource={datas}
|
|
|
|
|
columns={columns}
|
|
|
|
|
pagination={false}
|
|
|
|
|
pagination={false}
|
|
|
|
|
// loading={loadingstate}
|
|
|
|
|
// onChange={this.TablePagination}
|
|
|
|
|
/>}
|
|
|
|
|