import React, {Component} from "react"; import {WordsBtn} from 'educoder'; import {Tooltip, message} from 'antd'; import {Link} from 'react-router-dom'; import {getImageUrl} from 'educoder'; import axios from 'axios' import {getUrl} from 'educoder'; import moment from 'moment' import CoursesListType from '../coursesPublic/CoursesListType'; import Showoldfiles from "../coursesPublic/Showoldfiles"; import Modals from '../../modals/Modals'; class Fileslistitem extends Component { constructor(props) { super(props); this.state = {} } settingList = (bools) => { let {discussMessage} = this.props this.setState({ discussMessageid: discussMessage.id }) if (bools === true) { this.props.Settingtypes(discussMessage.id) } else { this.props.Settingtypess(discussMessage.id,discussMessage.title,discussMessage.link) } } //外链 showfiless = (url,id) => { window.open(url) let urls=`/files/${id}/update_visits.json`; axios.post(urls,{ }).then((result)=>{ if(result.data.status===0){ this.props.Updateresourcepage() }else{ this.props.showNotification(result.data.message); } }) } showfiles = (list) => { if (this.props.checkIfLogin() === false) { this.props.showLoginDialog() return } // if(this.props.checkIfProfileCompleted()===false){ // this.setState({ // AccountProfiletype:true // }) // return // } // if(this.props.checkIfProfessionalCertification()===false){ // this.props.showProfileCompleteDialog() // return // } if (list.is_history_file === false) { // this.props.DownloadFileA(list.title,list.url) //window.location.href=list.url; window.open(list.url, '_blank'); } else { let {discussMessage, coursesId} = this.props let file_id = discussMessage.id let url = "/files/" + file_id + "/histories.json" axios.get(url, { params: { course_id: coursesId }, }).then((result) => { if (result.data.attachment_histories.length === 0) { // if(result.data.is_pdf===true){ // this.props.ShowOnlinePdf(result.data.url) // //预览pdf // }else{ // // } // this.props.DownloadFileA(result.data.title,result.data.url) window.open(list.url, '_blank'); } else { this.setState({ Showoldfiles: true, allfiles: result.data }) } }).catch((error) => { console.log(error) }) } } closaoldfilesprops = () => { this.setState({ Showoldfiles: false, }) } onDelete = (id) => { this.setState({ Modalstype: true, Modalstopval: "是否确认删除?", ModalCancel: this.cancelmodel, ModalSave: () => this.savedelete(id), }) } cancelmodel = () => { this.setState({ Modalstype: false, Loadtype: false, Modalstopval: "", ModalCancel: "", ModalSave: "", checkBoxValues: [], }) } savedelete = (id) => { this.setState({ Modalstype: false, }) const cid = this.props.match.params.coursesId const url = `/files/bulk_delete.json`; axios.delete(url, { data: { course_id: cid, ids: [id], } }) .then((response) => { if (response.data.status == 0) { //Modalstopval:response.data.message, this.props.updatafiledfun() this.setState({ // Modalstype:true, // Modalstopval:"删除成功", ModalsBottomval: "", // ModalSave:this.cancelmodel, // Loadtype:true, checkBoxValues: [], checkAllValue: false }) this.props.showNotification("删除成功"); } }) .catch(function (error) { console.log(error); }); } eventStop = (event) => { event.stopPropagation() } render() { const { checkBox, discussMessage, index } = this.props; let bools = discussMessage.link && discussMessage.link ? false : true; return (
{/*提示*/} {this.state.Modalstype && this.state.Modalstype === true ? : ""} {/**/} {/**/} {/**/}
window.$(`.sourceitem${index} input`).click()}>
this.eventStop(event)}> {checkBox} { this.props.isAdmin ? (bools === true ? this.showfiles(discussMessage)} title={discussMessage.title} className="fl mt3 font-16 font-bd color-dark maxwidth580">{discussMessage.title} : this.showfiless(discussMessage.link,discussMessage.id)} title={discussMessage.title} className="fl mt3 font-16 font-bd color-dark maxwidth580">{discussMessage.title} ) : "" } { this.props.isStudent ? (bools === true ? this.showfiles(discussMessage)} title={discussMessage.title} className="fl mt3 font-16 font-bd color-dark maxwidth580">{discussMessage.title} : this.showfiless(discussMessage.link,discussMessage.id)} title={discussMessage.title} className="fl mt3 font-16 font-bd color-dark maxwidth580">{discussMessage.title} ) : "" } { this.props.isNotMember === true ? discussMessage.is_lock === true ? {discussMessage.title} : (bools === true ? this.showfiles(discussMessage)} title={discussMessage.title} className="fl mt3 font-16 font-bd color-dark maxwidth580">{discussMessage.title} : this.showfiless(discussMessage.link,discussMessage.id)} title={discussMessage.title} className="fl mt3 font-16 font-bd color-dark maxwidth580">{discussMessage.title} ) : "" } { discussMessage.is_lock === true ? : "" } { discussMessage.link && discussMessage.link ?

外链

: "" } {discussMessage.is_publish === false ? : ""} {this.props.isAdmin ? this.eventStop(event)}> this.settingList(bools)}>设置 : ""} {this.props.isStudent === true && this.props.current_user.login === discussMessage.author.login ? this.eventStop(event)}> this.settingList(bools)}>设置 this.onDelete(discussMessage.id)}>删除 : ""}
{/*资源分班*/} {/*{discussMessage.course_groups.length===0?"":*/} {/*

*/} {/*{discussMessage.course_groups.map((item,key)=>{*/} {/*return(*/} {/*

*/} {/*{item.course_group_name}*/} {/*将发布于 { moment(item.course_group_publish_time).format('YYYY-MM-DD HH:mm')}*/} {/*
*/} {/*)*/} {/*})}*/} {/*

}*/}

{discussMessage.author.name} { bools ? 大小 {discussMessage.filesize} : "" } { bools ? 下载 {discussMessage.downloads_count} : 点击次数:{discussMessage.downloads_count} } {/*引用 {discussMessage.quotes}*/} {/*{moment(discussMessage.publish_time).format('YYYY-MM-DD HH:mm:ss')}*/} {/*{moment(discussMessage.publish_time).fromNow()}*/} {discussMessage.publish_time === null ? "" : discussMessage.is_publish === true ? "" : "发布于"} {discussMessage.publish_time === null ? "" : discussMessage.is_publish === true ? moment(discussMessage.publish_time).fromNow() : moment(discussMessage.publish_time).format('YYYY-MM-DD HH:mm')} {discussMessage && discussMessage.category_name === null ? "" : this.props.child === false ?

所属目录:{discussMessage && discussMessage.category_name}
: ""}

资源描述 :{discussMessage.description === null ? "暂无描述" : discussMessage.description} {/**/} {/*/!**!/*/} {/**/} {/**/} {/*/!*{this.props.isAdmin ?this.settingList()}>:""}*!/*/} {/**/}

) } } export default Fileslistitem;