import React,{ Component } from "react"; import { getImageUrl, markdownToHTML, WordsBtn, getUrl } from 'educoder'; import { Tooltip } from 'antd' import TPMMDEditor from '../../../tpm/challengesnew/TPMMDEditor' import axios from 'axios' import moment from 'moment' const _origin = '' /** https://www.showdoc.cc/127895880302646?page_id=1962215317836957 comment_scores[:appeal_status] int 0:正常;1:申诉中,2:撤销申诉;3:申诉成功;4:申诉被拒绝;5:申诉失效 */ const ACCEPT = 3 const REFUSE = 4 class CCommentItem extends Component{ constructor(props){ super(props); this.state = { show_reply: false, show_appeal: false, } } cancelReply = () => { this.setState({ show_reply: false }) } showReply = () => { this.setState({ show_reply: true, show_appeal: false }) } showAppeal = () => { this.setState({ show_appeal: true, show_reply: false }) } cancelAppeal = () => { this.setState({ show_appeal: false }) } onCancel = () => { this.state.show_reply ? this.cancelReply() : this.cancelAppeal() } cancelMyAppeal = () => { this.props.confirm({ content:
撤销申诉后,无法再对本评阅记录进行申诉
是否确认撤销申诉
, onOk: () => { let studentWorkId =this.props.match.params.studentWorkId; let { item, commentIndex }=this.props; const url = `/student_works/${studentWorkId}/cancel_appeal.json` axios.post(url, { score_id: item.id }) .then((response) => { if (response.data.status == 0) { this.props.showNotification('撤销成功') this.props.replySuccess() } }) .catch(function (error) { console.log(error); }); } }) } onSubmit = () => { let workId=this.props.match.params.workId; let studentWorkId =this.props.match.params.studentWorkId; let { item, commentIndex }=this.props; if (!this.state.secondReplyContent || !this.state.secondReplyContent.trim()) { this.props.showNotification('内容不能为空') return; } if (this.state.show_reply) { const url = `/student_works/${studentWorkId}/add_score_reply.json` axios.post(url, { score_id: item.id, comment: this.state.secondReplyContent }).then((result)=>{ if(result.data.status == 0){ this.props.replySuccess() this.cancelReply() } }).catch((error)=>{ console.log(error) }) } else { const appealUrl = `/student_works/${studentWorkId}/appeal_anonymous_score.json` axios.post(appealUrl, { score_id: item.id, comment: this.state.secondReplyContent }).then((result)=>{ if(result.data.status == 0){ this.props.replySuccess() this.cancelAppeal() } }).catch((error)=>{ console.log(error) }) } } onDeleteSecondReply = (item) => { this.props.confirm({ // content: `确认要删除所选的${len}个帖子吗?`, content: `是否确认删除?`, onOk: () => { const url = `/commons/delete.json` axios.delete(url, { data: { object_id: item.id, object_type: 'journals_for_message' }}) .then((response) => { if (response.data.status == 0) { this.props.replySuccess() this.cancelAppeal() } }) .catch(function (error) { console.log(error); }); } }) } on_deal_appeal_score = (mode, item) => { this.props.confirm({ // content: `确认要删除所选的${len}个帖子吗?`, content:
{mode == ACCEPT ? '此匿评成绩将被废弃,评阅人的作品将被违规扣分' : '此匿评成绩将被认为合理'}
是否确认{mode == ACCEPT ? '接受申诉' : '拒绝申诉'}
, onOk: () => { let studentWorkId =this.props.match.params.studentWorkId; const url = `/student_works/${studentWorkId}/deal_appeal_score.json` axios.post(url, { score_id: item.score_id, status: mode }) .then((response) => { if (response.data.status == 0) { this.props.showNotification(`${mode == ACCEPT ? '接受申诉' : '拒绝申诉'}成功`) this.props.replySuccess() } }) .catch(function (error) { console.log(error); }); } }) } parseCommentContent = (oldContent) => { return markdownToHTML(oldContent); } renderChildenComments = (parent) => { if (parent.journals.length == 0) { return ''; } const isAdmin = this.props.isAdmin() /** can_delete: true content: "qwe" id: 81136 time: "2019-06-04T11:00:21.000+08:00" user_image_url: "avatars/User/1" user_login: "innov" user_name: "社区导师" */ // is_appeal_info true 是匿评人匿评信息,需要统一使用头像去掉链接 return parent.journals.map(item => { //
{item.content} {item.user_info.user_name}
// src={getImageUrl(`images/${item.image_url}`)} return (
{item.is_appeal_info == true ? 用户头像 : 用户头像 }
{item.user_info.user_login==="--"? {item.user_info.user_name} : {item.user_info.user_name} } {moment(item.time).format('YYYY-MM-DD HH:mm')} {item.is_appeal_info && (item.appeal_status == 1 ? 申诉中 : item.appeal_status == 2 ? 申诉已撤销 : item.appeal_status == 3 ? 申诉成功 : item.appeal_status == 4 ? 申诉被拒绝 : item.appeal_status == 5 ? 申诉失败 : '') } {/* fr */} {/* { item.is_invalid ? 失效 : */} {!item.is_appeal_info && item.can_delete == true && this.onDeleteSecondReply(item)} style={{ cursor: 'pointer' }} > } {/* } */} {item.is_appeal_info && isAdmin && item.appeal_status == 1 && this.on_deal_appeal_score(REFUSE, item)} className="fr ml6">拒绝申诉 this.on_deal_appeal_score(ACCEPT, item)} className="fr">接受申诉 } {item.appeal_status == 1 && this.props.is_author == true && this.cancelMyAppeal()}>撤销申诉}
) }) } render(){ let { item, commentIndex, homework_status, is_author }=this.props; let { show_reply, show_appeal }=this.state; const _content = item.content ? this.parseCommentContent(item.content) : '' const isAnonymous = homework_status && homework_status.indexOf('匿评中') != -1 const isAppealing = homework_status && homework_status.indexOf('申诉中') != -1 const attachments = item.attachments; return(
{item.image_url == '--' ? 用户头像 : 用户头像 } {/* 用户头像 */}
{ item.user_login==="--"? {item.username}({item.comment_role}) : {item.username}({item.comment_role}) } {item.time} {/* 分数 */} {item.score !== null && {item.score}分} {/* !item.is_invalid && */} {/* { item.delete && this.props.onDelete(item)}> } */} {/* fr */} {/* 回复 */} { item.is_invalid ? 失效 : 回复 {(isAppealing || isAnonymous) && item.can_appeal && item.appeal_status == 0 && 申诉} }
{!!_content && _content !== 'null' &&
} {!_content && {"暂未写评语"}}
{attachments && attachments.map((attaItem, key)=>{ return(
{attaItem.title} {attaItem.filesize} {/*{item.delete===true?:""}*/}
) })}
{/* {(item && item.journals && item.journals.length) ?
: ''} */} {this.renderChildenComments(item)} {/* { item.isAllChildrenLoaded != true && item.journals && this.props.isChildCommentPagination == true && item.journals.length >= 5?
{this.props.loadMoreChildComments && this.props.loadMoreChildComments(item)}}>
: ''} */}
{/* style={{ height: '130px'}} */}

{/* 第二排右侧按钮区域 */} {/* ${this.state.show_reply ? '回复' : '申诉'} */} {(show_reply || show_appeal) && this.setState({ secondReplyContent: val})} placeholder={`请输入内容`} noStorage={true} >

{this.state.show_reply ? '回复' : '申诉'} 取消
}

) } } export default CCommentItem;