import React,{ Component } from "react"; import { Modal,Checkbox,Upload,Button,Icon,message,DatePicker,Select,Tooltip} from "antd"; import axios from 'axios'; import Modals from '../../modals/Modals'; import {getUrl,handleDateString,bytesToSize,appendFileSizeToUploadFileAll} from 'educoder'; import locale from 'antd/lib/date-picker/locale/zh_CN'; import moment from 'moment'; const CheckboxGroup = Checkbox.Group; const Option = Select.Option; function range(start, end) { const result = []; for (let i = start; i < end; i++) { result.push(i); } return result; } function disabledDateTime() { return { // disabledHours: () => range(0, 24).splice(4, 20), disabledMinutes: () => range(1, 30).concat(range(31, 60)), // disabledSeconds: () => [0, 60], }; } function disabledDate(current) { return current && current < moment().endOf('day').subtract(1, 'days'); } const dateFormat="YYYY-MM-DD HH:mm"; class Sendresource extends Component{ constructor(props){ super(props); this.state={ group_ids:[], fileList:[], Modalstype:false, Modalstopval:"", ModalCancel:"", ModalSave:"", fileListtype:false, loadtype:false, is_unified_setting:true, is_public:false, datatime:undefined, // moment(new Date()).format('YYYY-MM-DD HH:mm:ss'), course_group_publish_times:[ { course_group_id : undefined, publish_time :"" }], course_groups:undefined, course_groups_count:undefined } } componentDidMount() { let coursesId=this.props.match.params.coursesId; if(this.props.isAdmin()){ let url = `/courses/${coursesId}/all_course_groups.json` axios.get(url, { }) .then((response) => { this.setState({ course_groups: response.data.course_groups, course_groups_count:response.data.course_groups_count }) }) .catch(function (error) { console.log(error); }); } } //勾选实训 shixunhomeworkedit=(list)=>{ this.setState({ group_ids:list }) } // 附件相关 START handleChange = (info) => { let fileList = info.fileList; if(info.file.status!="removed"){ this.setState({ fileList: appendFileSizeToUploadFileAll(fileList), fileListtype:true }); }else{ this.setState({ fileList: appendFileSizeToUploadFileAll(fileList), }); } } // onAttachmentRemove = (file) => { // // this.setState({ // fileListtype:false, // }) // // confirm({ // // title: '确定要删除这个附件吗?', // // okText: '确定', // // cancelText: '取消', // // // content: 'Some descriptions', // // onOk: () => { // // this.deleteAttachment(file) // // }, // // onCancel() { // // console.log('Cancel'); // // }, // // }); // // return false; // // // this.setState({ // // Modalstype:true, // // Modalstopval:'确定要删除这个附件吗?', // // ModalSave: ()=>this.deleteAttachment(file), // // ModalCancel:this.cancelAttachment // // }) // // return false; // // this.deleteAttachment(file); // } onAttachmentRemove = (file) => { if(!file.percent || file.percent == 100){ const url = `/attachments/${file.response ? file.response.id : file.uid}.json` axios.delete(url, { }) .then((response) => { if (response.data) { const { status } = response.data; if (status == 0) { this.setState({ fileListtype:false, fileList:[] }) } } }) .catch(function (error) { console.log(error); }); this.setState({ fileListtype:false, }) }else{ this.setState({ fileListtype:false, fileList:[] }) } } ModalCancelModalCancel=()=>{ this.setState({ Modalstype:false, Modalstopval:"", ModalSave:this.ModalCancelModalCancel, loadtype:false }) this.props.Cancel() } Saves=()=>{ let id=this.props.categoryid; let {fileList,description,is_public,is_unified_setting,datatime,course_group_publish_times} =this.state; let newfileList=[]; for(var list of fileList){ newfileList.push(list.response.id) } if(newfileList.length===0){ this.setState({ newfileListtype:true }) return } // if(is_unified_setting===false){ // course_group_publish_times.forEach((item,key)=>{ // if(item.course_group_id===undefined||item.publish_time===undefined){ // this.setState({ // course_group_publish_timestype:true // }) // return // } // }) // // } if(description===undefined){ }else if(description.length>100){ this.setState({ descriptiontype:true }) return } let coursesId=this.props.match.params.coursesId; let attachmentId=this.props.attachmentId; let url="/files/upload.json"; axios.post(url,{ course_id:coursesId, course_second_category_id:this.props.coursesidtype===undefined||this.props.coursesidtype==="node"?0:attachmentId, attachment_ids:newfileList, is_public:is_public, is_unified_setting:is_unified_setting, publish_time:is_unified_setting===true?datatime===undefined? moment(new Date()).format('YYYY-MM-DD HH:mm'):datatime:undefined, description:description, course_group_publish_times:is_unified_setting===false?course_group_publish_times:undefined }).then((result)=>{ if(result.data.status===0){ // this.setState({ // Modalstype:true, // Modalstopval:result.data.message, // ModalSave:this.ModalCancelModalCancel, // loadtype:true // }) this.ModalCancelModalCancel(); this.props.updataleftNavfun(); // this.props.showNotification(result.data.message); this.props.showNotification("上传资源成功"); this.props.setupdate(this.props.attachmentId) } }) } settextarea=(e)=>{ this.setState({ description:e.target.value }) } onChangesetting=(e)=>{ this.setState({ is_unified_setting:e.target.checked }) } onChangepublic=(e)=>{ this.setState({ is_public:e.target.checked }) } onChangeTimepublish= (date, dateString,key,type) => { if(type===1){ this.setState({ datatime:handleDateString(dateString), }) }else if(type===2){ let {course_group_publish_times}=this.state; let newgroup_publish=course_group_publish_times; for(var i=0; i{ let {course_group_publish_times}=this.state; let newgroup_publish=course_group_publish_times; for(var i=0; i{ let newlist=this.state.course_group_publish_times; newlist.splice(key,1); this.setState({ course_group_publish_times:newlist }) } addgrouppublish=()=>{ let newlist=this.state.course_group_publish_times; newlist.push( { course_group_id : undefined, publish_time :undefined }) this.setState({ course_group_publish_times:newlist }) } render(){ let {settextarea,newfileListtype,descriptiontype, course_group_publish_timestype, Modalstopval, ModalCancel, ModalSave, loadtype, is_unified_setting, is_public, datatime, course_group_publish_times, course_groups }=this.state; const uploadProps = { width: 600, // showUploadList:false, action: `${getUrl()}/api/attachments.json`, onChange: this.handleChange, onRemove: this.onAttachmentRemove, beforeUpload: (file) => { // console.log('beforeUpload', file.name); const isLt150M = file.size / 1024 / 1024 < 150; if (!isLt150M) { this.props.showNotification('文件大小必须小于150MB!'); } return isLt150M; }, }; return(
{/*提示*/}

{ this.state.fileListtype===true?"":}

{ this.state.fileListtype===true?

每次只能上传一个资源,
删除下面资源可重新上传 }>
(单个文件最大150M)
:"" } {this.state.fileListtype===false? (单个文件最大150M) :""}

{/**/} {/*{this.state.fileList.length===0?"":this.state.fileList.map((item,key)=>{*/} {/*debugger*/} {/*return(*/} {/*

*/} {/**/} {/**/} {/**/} {/**/} {/*{item.name}*/} {/**/} {/**/} {/*{item.response===undefined?"":isNaN(bytesToSize(item.filesize))?"":bytesToSize(item.filesize)}*/} {/**/} {/*this.onAttachmentRemove(item.response===undefined?"":item.response.id&&item.response.id)}>*/} {/*

*/} {/*)*/} {/*})}*/} {newfileListtype===true&&this.state.fileListtype===false?

请先上传资源

:""}

{/*

*/} {/*勾选后所有用户可见,否则仅课堂成员可见*/} {/**/} {this.state.course_groups_count&&this.state.course_groups_count>0? 统一设置(选中则所有分班使用相同的发布设置,否则各个单独设置) :""}
{is_unified_setting===false? course_group_publish_times.map((item,key)=>{ return(
this.onChangeTimepublish(e,index,key,2)} // onChange={ this.onChangeTimepublish } disabledTime={disabledDateTime} disabledDate={disabledDate} /> {key!=0?this.deletegrouppublish(key)}>:""} {key===course_group_publish_times.length-1&&key:""}
) }) :""}

{is_unified_setting===true?

this.onChangeTimepublish(e,index,undefined,1)} disabledTime={disabledDateTime} disabledDate={disabledDate} />

:""} {/*{course_group_publish_timestype===true?

请填写完整

:""}*/} {descriptiontype===true?

请输入资源描述,最大限制100个字符

:""}
) } } export default Sendresource;