|
|
|
@ -1,16 +1,15 @@
|
|
|
|
|
|
|
|
|
|
import React, { Component } from 'react';
|
|
|
|
|
|
|
|
|
|
import { Route, Link, Switch } from "react-router-dom";
|
|
|
|
|
|
|
|
|
|
import { Row, Col, Menu } from 'antd';
|
|
|
|
|
import { Row, Col, Menu, } from 'antd';
|
|
|
|
|
|
|
|
|
|
import Loading from '../../Loading';
|
|
|
|
|
|
|
|
|
|
import { Loadable } from 'educoder';
|
|
|
|
|
|
|
|
|
|
import TPMIndexHOC from './TPMIndexHOC';
|
|
|
|
|
|
|
|
|
|
import { SnackbarHOC } from 'educoder';
|
|
|
|
|
import { SnackbarHOC, Loadable } from 'educoder';
|
|
|
|
|
|
|
|
|
|
import TPMBanner from './TPMBanner';
|
|
|
|
|
|
|
|
|
@ -33,64 +32,12 @@ import TPMDataset from './TPMDataset';
|
|
|
|
|
|
|
|
|
|
import '../page/tpiPage.css';
|
|
|
|
|
|
|
|
|
|
//任务
|
|
|
|
|
// const TPMChallengeComponent = Loadable({
|
|
|
|
|
// loader: () => import('./TPMChallengeContainer'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
//背景知识
|
|
|
|
|
// const TPMPropaedeuticsComponent = Loadable({
|
|
|
|
|
// loader: () => import('./TPMPropaedeuticsComponent'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
//版本库
|
|
|
|
|
// const TPMRepositoryComponent = Loadable({
|
|
|
|
|
// loader: () => import('./TPMRepositoryComponent'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
// const TPMRepositoryComponent = Loadable({
|
|
|
|
|
// loader: () => import('./TPMRepositoryComponent'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
//合作
|
|
|
|
|
// const TPMCollaboratorsComponent = Loadable({
|
|
|
|
|
// loader: () => import('./TPMCollaboratorsContainer'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//评论
|
|
|
|
|
// const TPMShixunDiscussComponent = Loadable({
|
|
|
|
|
// loader: () => import('./TPMShixunDiscussContainer'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
//排行版
|
|
|
|
|
// const TPMRanking_listComponent = Loadable({
|
|
|
|
|
// loader: () => import('./TPMRanking_listContainer'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
// //编辑实训
|
|
|
|
|
// const TPMModifysettings = Loadable({
|
|
|
|
|
// loader: () =>import('./modules/tpm/TPMsettings/TPMsettings'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
//新建实训
|
|
|
|
|
const TPMchallengesnew = Loadable({
|
|
|
|
|
loader: () => import('./challengesnew/TPMchallengesnew'),
|
|
|
|
|
loading: Loading,
|
|
|
|
|
})
|
|
|
|
|
//新建实训
|
|
|
|
|
// const TPMchallengesnew = Loadable({
|
|
|
|
|
// loader: () => import('./challengesnew/TpmTask/TpmTaskIndex'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
//新建tab2
|
|
|
|
|
const TPMevaluation = Loadable({
|
|
|
|
@ -98,11 +45,6 @@ const TPMevaluation = Loadable({
|
|
|
|
|
loading: Loading,
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
//新建tab3答案
|
|
|
|
|
// const TPManswer = Loadable({
|
|
|
|
|
// loader: () => import('./challengesnew/TPManswer'),
|
|
|
|
|
// loading: Loading,
|
|
|
|
|
// })
|
|
|
|
|
const TPManswer = Loadable({
|
|
|
|
|
loader: () => import('./challengesnew/TPManswer2'),
|
|
|
|
|
loading: Loading,
|
|
|
|
@ -138,8 +80,6 @@ const Uploadfile = Loadable({
|
|
|
|
|
loading: Loading,
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
const interceptorUrlArray = ['repository.json', 'commits.json', 'propaedeutics.json'
|
|
|
|
|
, 'challenges.json', 'discusses.json', 'ranking_list.json', 'collaborators.json']
|
|
|
|
|
const cacheInterceptorUrlMap = {}
|
|
|
|
|
class TPMIndex extends Component {
|
|
|
|
|
constructor(props) {
|
|
|
|
@ -161,7 +101,6 @@ class TPMIndex extends Component {
|
|
|
|
|
newathArray: []
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
openknow = () => {
|
|
|
|
|
let storage = window.localStorage;
|
|
|
|
@ -242,48 +181,39 @@ class TPMIndex extends Component {
|
|
|
|
|
public: response.data.public,
|
|
|
|
|
is_jupyter: response.data.is_jupyter === undefined || response.data.is_jupyter === null ? false : response.data.is_jupyter,
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// this.tpmContentRequestInterceptor = axios.interceptors.request.use((config) => {
|
|
|
|
|
// let url = config.url;
|
|
|
|
|
// // console.log('tpmContentRequestInterceptor:', url)
|
|
|
|
|
// for ( let i = 0; i < interceptorUrlArray.length; i++ ) {
|
|
|
|
|
// if (url.indexOf(interceptorUrlArray[i]) != -1) {
|
|
|
|
|
// url = url.split('?')[0]
|
|
|
|
|
// console.log('loadingContent, url:', url)
|
|
|
|
|
//
|
|
|
|
|
// this.setState({ loadingContent: true })
|
|
|
|
|
//
|
|
|
|
|
// cacheInterceptorUrlMap[url] = true
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// return config;
|
|
|
|
|
// }, function (error) {
|
|
|
|
|
// return Promise.reject(error);
|
|
|
|
|
// });
|
|
|
|
|
|
|
|
|
|
this.tpmContentRequestInterceptor = axios.interceptors.request.use((config) => {
|
|
|
|
|
let url = config.url;
|
|
|
|
|
// console.log('tpmContentRequestInterceptor:', url)
|
|
|
|
|
for (let i = 0; i < interceptorUrlArray.length; i++) {
|
|
|
|
|
if (url.indexOf(interceptorUrlArray[i]) != -1) {
|
|
|
|
|
url = url.split('?')[0]
|
|
|
|
|
console.log('loadingContent, url:', url)
|
|
|
|
|
|
|
|
|
|
this.setState({ loadingContent: false })
|
|
|
|
|
|
|
|
|
|
cacheInterceptorUrlMap[url] = true
|
|
|
|
|
if (userid) {
|
|
|
|
|
if (response.data.identity < 4) {
|
|
|
|
|
if (newTPMsettings === undefined || newTPMsettings === false || newTPMsettings === null) {
|
|
|
|
|
console.log()
|
|
|
|
|
this.setState({
|
|
|
|
|
openknows: true
|
|
|
|
|
})
|
|
|
|
|
} else {
|
|
|
|
|
this.setState({
|
|
|
|
|
openknows: false
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return config;
|
|
|
|
|
}, function (error) {
|
|
|
|
|
return Promise.reject(error);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}).catch((error) => {
|
|
|
|
|
this.setState({
|
|
|
|
|
shixunsDetails: undefined,
|
|
|
|
|
shixunId: undefined,
|
|
|
|
|
star_info: undefined,
|
|
|
|
|
star_infos: undefined,
|
|
|
|
|
power: undefined,
|
|
|
|
|
identity: undefined,
|
|
|
|
|
status: undefined,
|
|
|
|
|
propaedeutics: undefined,
|
|
|
|
|
is_jupyter: false,
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Add a response interceptor
|
|
|
|
|
this.tpmContentResponseInterceptor = axios.interceptors.response.use((response) => {
|
|
|
|
|
// console.log('loadingContent finished, url:', response.config.url)
|
|
|
|
|
// TODO 依赖了api这个前缀
|
|
|
|
|
let url = response.config.url.split('api')[1];
|
|
|
|
|
url = url.split('?')[0]
|
|
|
|
|
if (cacheInterceptorUrlMap[url]) {
|
|
|
|
@ -457,6 +387,20 @@ class TPMIndex extends Component {
|
|
|
|
|
{this.state.is_jupyter === false ? <Menu.Item key="8" className={"competitionmr50"}>
|
|
|
|
|
<span className={"tpmbannernavstyler"}>排行榜</span>
|
|
|
|
|
</Menu.Item> : ""}
|
|
|
|
|
{/*{this.state.identity >4||this.state.identity===undefined ? "":this.state.openknows===true?<span>*/}
|
|
|
|
|
{/* <Popover*/}
|
|
|
|
|
{/* content={*/}
|
|
|
|
|
{/* <pre className={"bannerpd201"}>*/}
|
|
|
|
|
{/* <div>更多设置在这里,点击“配置”看一看~</div>*/}
|
|
|
|
|
{/* <div className={"wechatcenter mt15"}><Button type="primary" onClick={this.openknow} >我知道了</Button></div>*/}
|
|
|
|
|
{/* </pre>*/}
|
|
|
|
|
{/* }*/}
|
|
|
|
|
{/* trigger="click"*/}
|
|
|
|
|
{/* placement="top"*/}
|
|
|
|
|
{/* visible={this.state.openknows}*/}
|
|
|
|
|
{/* >*/}
|
|
|
|
|
{/* </Popover>*/}
|
|
|
|
|
{/*</span>:""}*/}
|
|
|
|
|
|
|
|
|
|
{this.state.identity > 4 || this.state.identity === undefined ? "" :
|
|
|
|
|
<Menu.Item key="9" className={"competitionmr50"}>
|
|
|
|
@ -469,6 +413,10 @@ class TPMIndex extends Component {
|
|
|
|
|
<Link to={`/shixuns/${this.props.match.params.shixunId}/audit_situation`}
|
|
|
|
|
className={`${this.props.match.url.indexOf('audit_situation') != -1 ? 'font-16 audit_situationactive' : 'font-16 audit_situationactive'} fl`}>审核情况</Link>
|
|
|
|
|
</div>
|
|
|
|
|
}
|
|
|
|
|
</Menu>
|
|
|
|
|
</Col>
|
|
|
|
|
</div>
|
|
|
|
|
</Row>
|
|
|
|
|
|
|
|
|
|
{/*筛选*/}
|
|
|
|
@ -517,24 +465,24 @@ class TPMIndex extends Component {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/repository/master/shixun_show/:fileId" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponentdetails {...this.props} {...this.state} {...props} is_jupyter={this.state.is_jupyter}
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} is_jupyter={this.state.is_jupyter} setpathArray={(value) => this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/secret_repository/master/shixun_show/:fileId" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponentdetails {...this.props} {...this.state} {...props} secret_repository_tab={true} is_jupyter={this.state.is_jupyter}
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} secret_repository_tab={true} is_jupyter={this.state.is_jupyter} setpathArray={(value) => this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/repository" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} is_jupyter={this.state.is_jupyter}
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} is_jupyter={this.state.is_jupyter} setpathArray={(value) => this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/secret_repository" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} secret_repository_tab={true} is_jupyter={this.state.is_jupyter}
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} secret_repository_tab={true} is_jupyter={this.state.is_jupyter} setpathArray={(value) => this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
@ -552,32 +500,6 @@ class TPMIndex extends Component {
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/repository/master/shixun_show/:fileId" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} is_jupyter={this.state.is_jupyter} setpathArray={(value)=>this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/secret_repository/master/shixun_show/:fileId" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} secret_repository_tab={true} is_jupyter={this.state.is_jupyter} setpathArray={(value)=>this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/repository" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} is_jupyter={this.state.is_jupyter} setpathArray={(value)=>this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<Route path="/shixuns/:shixunId/secret_repository" render={
|
|
|
|
|
(props) => (<TPMRepositoryComponent {...this.props} {...this.state} {...props} secret_repository_tab={true} is_jupyter={this.state.is_jupyter} setpathArray={(value)=>this.setpathArray(value)}
|
|
|
|
|
/>)
|
|
|
|
|
}></Route>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
{/* <Route exact path="/shixuns/:shixunId/propaedeutics" component={TPMPropaedeuticsComponent}></Route> */}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
{/* <Route exact path="/shixuns/:shixunId/repository/:shixunId/" component={TPMRepositoryComponent}></Route> */}
|
|
|
|
|
|
|
|
|
|