diff --git a/app/controllers/challenges_controller.rb b/app/controllers/challenges_controller.rb
index 74352724c..ebce98b62 100644
--- a/app/controllers/challenges_controller.rb
+++ b/app/controllers/challenges_controller.rb
@@ -1,5 +1,5 @@
class ChallengesController < ApplicationController
- before_action :require_login, :check_auth
+ before_action :require_login, :check_auth, except: [:index]
before_action :find_shixun, only: [:new, :create, :index]
skip_before_action :verify_authenticity_token, only: [:create, :update, :create_choose_question, :crud_answer]
before_action :find_challenge, only: [:edit, :show, :update, :create_choose_question, :index_down, :index_up,
diff --git a/app/controllers/courses_controller.rb b/app/controllers/courses_controller.rb
index 8ea6df506..6aaa04f12 100644
--- a/app/controllers/courses_controller.rb
+++ b/app/controllers/courses_controller.rb
@@ -49,30 +49,12 @@ class CoursesController < ApplicationController
@user = current_user
# 根据分类查询课堂(全部,我的,最新,最热)
@order = params[:order].present? ? params[:order] : "all"
- order_str = @order != "course_members_count" && @order != "created_at" ? "updated_at" : @order
-
- # if @order == "all"
- # @course = Course.where(is_delete: 0, is_hidden: 0).select("select c.name, c.id, s.name, u.login, ifnull(concat(u.lastname,u.firstname),
- # u.login), s.name from courses c, users u, user_extensions ue, schools s where c.is_delete=0 and
- # c.tea_id=u.id and u.id=ue.user_id and ue.school_id=s.id")
-
- # @courses = Course.where(is_delete: 0, is_hidden: 0)
- # .order("courses.id = 1309 desc, courses.created_at desc")
-
- # @courses = Course.where(is_delete: 0, is_hidden: 0).select("courses.id, courses.tea_id, courses.name, courses.exercises_count, courses.polls_count,
- # courses.is_public, courses.is_end, courses.visits, courses.course_members_count,courses.homework_commons_count,(SELECT MAX(created_at)
- # FROM `course_activities` WHERE course_activities.course_id = courses.id) AS a")
- # .order("courses.id = 1309 desc, a desc")
- if @order == "mine"
- tip_exception(401, "..") unless current_user.logged?
- @courses = Course.joins(:course_members)
- .where("is_delete = 0 AND is_hidden = 0 AND course_members.user_id = ?", @user.id).distinct
- elsif @order == "created_at"
- # REDO:Extension
- @courses = Course.where(is_delete: 0, is_hidden: 0, is_end: 0).distinct
+ if @order == "visits"
+ order_str = "courses.id = 1309 DESC, courses.visits DESC"
+ @courses = Course.where(is_delete: 0, is_hidden: 0)
else
- # REDO:Extension
- @courses = Course.where(is_delete: 0, is_hidden: 0).distinct
+ order_str = "courses.id = 1309 DESC, courses.homepage_show DESC, courses.created_at desc"
+ @courses = Course.where(is_delete: 0, is_hidden: 0, is_end: 0)
end
# 根据搜索关键字进一步筛选
@@ -92,7 +74,7 @@ class CoursesController < ApplicationController
.where("#{sql}", keyword: "%#{params[:search]}%").distinct
end
@courses_count = @courses.count("courses.id")
- @courses = @courses.order("courses.id = 1309 DESC, courses.#{order_str} DESC")
+ @courses = @courses.order(order_str)
# 分页
page = params[:page] || 1
diff --git a/app/controllers/discusses_controller.rb b/app/controllers/discusses_controller.rb
index 4af27b919..6ddf71ba4 100644
--- a/app/controllers/discusses_controller.rb
+++ b/app/controllers/discusses_controller.rb
@@ -1,5 +1,6 @@
class DiscussesController < ApplicationController
LIMIT = 10
+ before_action :require_login, only: [:create, :reply, :hidden, :reward_code, :plus, :destroy]
before_action :find_container, only: [:index, :hidden]
before_action :find_discuss, except: [:create, :index, :new_message, :reward_code, :forum_discusses, :plus]
diff --git a/app/controllers/shixuns_controller.rb b/app/controllers/shixuns_controller.rb
index 3145636df..fb999b879 100644
--- a/app/controllers/shixuns_controller.rb
+++ b/app/controllers/shixuns_controller.rb
@@ -2,7 +2,8 @@ class ShixunsController < ApplicationController
include ShixunsHelper
include ApplicationHelper
- before_action :require_login, :check_auth, except: [:download_file, :index, :menus]
+ before_action :require_login, :check_auth, except: [:download_file, :index, :menus, :show, :show_right, :ranking_list,
+ :discusses, :collaborators, :fork_list, :propaedeutics]
before_action :check_account, only: [:new, :create, :shixun_exec]
diff --git a/app/controllers/stages_controller.rb b/app/controllers/stages_controller.rb
index 3967554aa..acf0e4829 100644
--- a/app/controllers/stages_controller.rb
+++ b/app/controllers/stages_controller.rb
@@ -1,5 +1,5 @@
class StagesController < ApplicationController
- before_action :require_login, :check_auth
+ before_action :require_login, :check_auth, except: [:index]
before_action :find_subject, only: [:create, :index]
before_action :find_stage, only: [:update, :destroy, :edit, :up_position, :down_position]
before_action :allowed, except: [:index]
diff --git a/app/controllers/subjects_controller.rb b/app/controllers/subjects_controller.rb
index 396c0900e..825040528 100644
--- a/app/controllers/subjects_controller.rb
+++ b/app/controllers/subjects_controller.rb
@@ -1,7 +1,7 @@
class SubjectsController < ApplicationController
- before_action :require_login, :check_auth, except: [:index]
+ before_action :require_login, :check_auth, except: [:index, :show]
# before_action :check_auth, except: [:index]
- before_action :check_account, only: [:new, :create]
+ before_action :check_account, except: [:index, :show]
before_action :find_subject, except: [:index, :create, :new, :append_to_stage]
before_action :allowed, only: [:update, :edit, :destroy, :publish, :cancel_publish, :cancel_has_publish,
:search_members, :add_subject_members, :statistics, :shixun_report, :school_report,
diff --git a/public/react/src/modules/courses/coursesHome/CoursesHome.js b/public/react/src/modules/courses/coursesHome/CoursesHome.js
index 962413e54..2cf7aca90 100644
--- a/public/react/src/modules/courses/coursesHome/CoursesHome.js
+++ b/public/react/src/modules/courses/coursesHome/CoursesHome.js
@@ -16,7 +16,7 @@ class CoursesHome extends Component{
this.state = {
limit:16,
page:1,
- order:"all",
+ order:"created_at",
coursesHomelist:undefined,
search:"",
}
@@ -118,25 +118,25 @@ class CoursesHome extends Component{
diff --git a/public/react/src/modules/courses/coursesPublic/PathModal.js b/public/react/src/modules/courses/coursesPublic/PathModal.js
index 3fbbd4af4..07ce55024 100644
--- a/public/react/src/modules/courses/coursesPublic/PathModal.js
+++ b/public/react/src/modules/courses/coursesPublic/PathModal.js
@@ -122,16 +122,20 @@ class PathModal extends Component{
contentViewScrolledit=(e)=>{
//滑动到底判断
+ const {shixunmodallist} = this.state;
if(e.currentTarget.scrollHeight-e.currentTarget.scrollTop===e.currentTarget.clientHeight){
- let {Searchvalue,type,page,shixunpathlist}=this.state;
- let newpage=page+1
- this.funshixunpathlist(Searchvalue,type,true,newpage)
- this.setState({
- page:newpage
- })
-
+ if(shixunmodallist.subject_list.length===0){
+ return;
+ }else{
+ let {Searchvalue,type,page,shixunpathlist}=this.state;
+ let newpage=page+1
+ this.funshixunpathlist(Searchvalue,type,true,newpage)
+ this.setState({
+ page:newpage
+ })
+ }
}
}
diff --git a/public/react/src/modules/courses/coursesPublic/ShixunModal.js b/public/react/src/modules/courses/coursesPublic/ShixunModal.js
index 1ae63da90..2a53cf104 100644
--- a/public/react/src/modules/courses/coursesPublic/ShixunModal.js
+++ b/public/react/src/modules/courses/coursesPublic/ShixunModal.js
@@ -100,17 +100,21 @@ class ShixunModal extends Component{
}
contentViewScrolledit=(e)=>{
-
+ const {shixunmodallist}=this.state;
//滑动到底判断
- if(e.currentTarget.scrollHeight-e.currentTarget.scrollTop===e.currentTarget.clientHeight){
- let {Searchvalue,type,page}=this.state;
- let newpage=page+1
- this.setupdatalist(Searchvalue,type,true,newpage)
- this.setState({
- page:newpage
- })
- }
-
+ if(e.currentTarget.scrollHeight-e.currentTarget.scrollTop===e.currentTarget.clientHeight) {
+
+ if (shixunmodallist.shixun_list.length === 0) {
+ return;
+ } else {
+ let {Searchvalue, type, page} = this.state;
+ let newpage = page + 1
+ this.setupdatalist(Searchvalue, type, true, newpage)
+ this.setState({
+ page: newpage
+ })
+ }
+ }
}
//搜索
diff --git a/public/react/src/modules/courses/css/Courses.css b/public/react/src/modules/courses/css/Courses.css
index 47db2f595..b6388b1e7 100644
--- a/public/react/src/modules/courses/css/Courses.css
+++ b/public/react/src/modules/courses/css/Courses.css
@@ -477,9 +477,9 @@ a.white-btn.use_scope-btn:hover{
}
.pathInfobox li{
margin-right: 20px;
- height: 15px;
+ height: 20px;
/*overflow: hidden;*/
- line-height: 15px;
+ line-height: 20px;
}
.width70f{
width: 70px;
diff --git a/public/react/src/modules/courses/exercise/ExerciseReviewAndAnswer.js b/public/react/src/modules/courses/exercise/ExerciseReviewAndAnswer.js
index 778829d72..c2c9b7bcf 100644
--- a/public/react/src/modules/courses/exercise/ExerciseReviewAndAnswer.js
+++ b/public/react/src/modules/courses/exercise/ExerciseReviewAndAnswer.js
@@ -526,7 +526,7 @@ class ExerciseReviewAndAnswer extends Component{
height: 28px;
}
`}
-
+ {/**/}
-
+ {/**/}
{
+ paginationonChangestwo = (pageNumber) => {
this.setState({
page: pageNumber,
loadingstate: true,
@@ -2495,7 +2495,10 @@ class Listofworksstudentone extends Component {
// console.log(datajs);
// console.log("2202");
// console.log(this.props.isAdmin());
-
+ // console.log("2498");
+ // console.log(data);
+ // console.log(datas);
+ // console.log(this.props.isAdmin());
return (
this.props.isAdmin() === true ?
(
@@ -2776,13 +2779,13 @@ class Listofworksstudentone extends Component {
}
.edu-table thead th,.edu-table tbody tr:last-child td{
border-bottom: none!important;
- height: 85px;
+ height: 58px;
}
.ant-tables .ant-table-tbody > tr > td {
- height: 85px;
+ height: 58px;
}
.ysltableo .ant-table-thead > tr > th{
- height: 85px;
+ height: 58px;
}
.ysltableo .ant-table-thead > tr > th, .ant-table-tbody > tr > td {
padding: 9px;
@@ -2927,8 +2930,8 @@ class Listofworksstudentone extends Component {
{teacherdata === undefined ? "" : teacherdata.commit_count === undefined ? "" : teacherdata.commit_count}已交{teacherdata === undefined ? "" : teacherdata.uncommit_count}未交
+ className="color-orange-tip">{teacherdata === undefined ? "0" : teacherdata.commit_count === undefined ? "0" : teacherdata.commit_count}已交{teacherdata === undefined ? "0" : teacherdata.uncommit_count}未交
{teacherdata === undefined ? "" : teacherdata.left_time === undefined ? "" : teacherdata.left_time === null ? "" :
{teacherdata.left_time.status}
}
@@ -2969,11 +2972,17 @@ class Listofworksstudentone extends Component {
.ant-spin-nested-loading > div > .ant-spin .ant-spin-dot {
top: 72%;}
}
+ .edu-table .ant-table-tbody > tr > td {
+ height: 58px;
+ }
+ .edu-table .ant-table-thead > tr > th{
+ height: 58px;
+ }
.ysltableow .ant-table-thead > tr > th{
- height: 85px;
+ height: 58px;
}
.ysltableow .ant-table-tbody > tr > td{
- height: 85px;
+ height: 58px;
}
.ysltableow .ant-table-thead > tr > th, .ant-table-tbody > tr > td {
padding: 9px;
@@ -3033,7 +3042,7 @@ class Listofworksstudentone extends Component {
}
-
+
@@ -263,24 +276,33 @@ class TraineetraininginformationModal extends Component {
columns={columns}
loading={false}
pagination={false}
- onChange={this.TablePagination}
/>}
:
+
{this.props.game_list === undefined ? "" :
}
@@ -302,7 +324,15 @@ class TraineetraininginformationModal extends Component {
{
` .ant-table-body{
overflow: hidden !important;
- }`
+ }
+ .edu-table .ant-table-tbody > tr > td {
+ height: 58px;
+ }
+ .edu-table .ant-table-thead > tr > th{
+ height: 58px;
+ }
+
+ `
}
@@ -313,24 +343,32 @@ class TraineetraininginformationModal extends Component {
columns={columnss}
loading={false}
pagination={false}
- onChange={this.TablePagination}
/>}
:
+
{this.props.game_list === undefined ? "" :
}
diff --git a/public/react/src/modules/courses/shixunHomework/shixunreport/Coursesshixundetails.js b/public/react/src/modules/courses/shixunHomework/shixunreport/Coursesshixundetails.js
index 529a4646b..23f6d1e48 100644
--- a/public/react/src/modules/courses/shixunHomework/shixunreport/Coursesshixundetails.js
+++ b/public/react/src/modules/courses/shixunHomework/shixunreport/Coursesshixundetails.js
@@ -44,7 +44,7 @@ class Coursesshixundetails extends Component {
data&&data.forEach((item,key)=>{
datas.push({
number: item.position,
- name: item.output_detail
+ name: item.output_detail=== ""||item.output_detail===null?"暂无数据":item.output_detail
})
})
diff --git a/public/react/src/modules/courses/shixunHomework/shixunreport/OfficialAcademicTranscript.js b/public/react/src/modules/courses/shixunHomework/shixunreport/OfficialAcademicTranscript.js
index c7c3b67e4..e2cefe247 100644
--- a/public/react/src/modules/courses/shixunHomework/shixunreport/OfficialAcademicTranscript.js
+++ b/public/react/src/modules/courses/shixunHomework/shixunreport/OfficialAcademicTranscript.js
@@ -177,6 +177,8 @@ class OfficialAcademicTranscript extends Component {
}
.TaskForms{
width: 500px;
+ text-align: left !important;
+ padding: 16px !important;
}
.TaskForms.ant-table-header-column{
width: 100%;
diff --git a/public/react/src/modules/courses/shixunHomework/shixunreport/Shixunechart.js b/public/react/src/modules/courses/shixunHomework/shixunreport/Shixunechart.js
index dff7c6859..c12ec13d5 100644
--- a/public/react/src/modules/courses/shixunHomework/shixunreport/Shixunechart.js
+++ b/public/react/src/modules/courses/shixunHomework/shixunreport/Shixunechart.js
@@ -12,6 +12,7 @@ function startechart(data){
var option = {
title: {
text: '工作效率',
+ subtext: '工作效率=log(实训总得分/实训总耗时)'
},
grid:{
left: '3%',
@@ -61,7 +62,7 @@ function startechart(data){
yAxis: [
{
type : "value",
- name : " 实训总得分/实训总耗时",
+ name : " ",
nameGap: 20,
nameTextStyle: {
color: '#000',
@@ -169,6 +170,7 @@ function startechart(data){
var option1 = {
title: {
text: '能力值',
+ subtext: '能力值(实训获得经验值/实训评测次数)'
},
backgroundColor: '#fff',
color: [
@@ -212,7 +214,7 @@ function startechart(data){
},
yAxis: {
type: 'value',
- name: " 实训获得经验值/实训评测次数",
+ name: " ",
nameLocation: 'end',
nameGap: 20,
nameTextStyle: {
@@ -356,7 +358,7 @@ class Shixunechart extends Component {
`}
-
+
姓名
diff --git a/public/react/src/modules/message/js/MessagSub.js b/public/react/src/modules/message/js/MessagSub.js
index ef0d35dd1..ab814aab8 100644
--- a/public/react/src/modules/message/js/MessagSub.js
+++ b/public/react/src/modules/message/js/MessagSub.js
@@ -308,7 +308,7 @@ class MessagSub extends Component{
//记得跳评阅页面
default :
// 课堂-试卷列表详情 :id = container_id
- return window.open(`/courses/${item.belong_container_id}/exercises/${item.container_id}`)
+ return window.open(`/courses/${item.belong_container_id}/exercises/${item.container_id}/student_exercise_list?tab=0`);
}
case 'StudentGraduationTopic' :
//课堂-毕业选题详情 :id = parent_container_id
diff --git a/public/react/src/modules/paths/PathDetail/DetailCards.js b/public/react/src/modules/paths/PathDetail/DetailCards.js
index 21165ff57..1dd93daa8 100644
--- a/public/react/src/modules/paths/PathDetail/DetailCards.js
+++ b/public/react/src/modules/paths/PathDetail/DetailCards.js
@@ -193,12 +193,20 @@ class DetailCards extends Component{
}
startgameid=(id)=>{
+
+ if(this.props.checkIfLogin()===false){
+ this.props.showLoginDialog()
+ return
+ }
+
if(this.props.current_user&&this.props.current_user.profile_completed===false){
this.setState({
AccountProfiletype:true
})
return
}
+
+
let url = "/shixuns/" + id + "/shixun_exec.json";
axios.get(url).then((response) => {
diff --git a/public/react/src/modules/paths/PathDetail/PathDetailIndex.js b/public/react/src/modules/paths/PathDetail/PathDetailIndex.js
index 36537e7d0..302af3d52 100644
--- a/public/react/src/modules/paths/PathDetail/PathDetailIndex.js
+++ b/public/react/src/modules/paths/PathDetail/PathDetailIndex.js
@@ -326,6 +326,15 @@ class PathDetailIndex extends Component{
return(
+
}
{
- detailInfoList === undefined ? "" : detailInfoList.progress === null ? "" :
+ this.props.checkIfLogin()===false?"":detailInfoList === undefined ? "" : detailInfoList.progress === null ? "" :
我的进展
diff --git a/public/react/src/modules/paths/PathDetail/addCollaborators.js b/public/react/src/modules/paths/PathDetail/addCollaborators.js
index c828f1589..6100ab2f6 100644
--- a/public/react/src/modules/paths/PathDetail/addCollaborators.js
+++ b/public/react/src/modules/paths/PathDetail/addCollaborators.js
@@ -1,216 +1,213 @@
-import React, { Component } from 'react';
-import { Modal,Checkbox,Input } from "antd";
-import axios from 'axios';
-
-const Search = Input.Search;
-const CheckboxGroup = Checkbox.Group;
-class addCollaborators extends Component{
- constructor(props){
- super(props);
- this.state = {
- addPartner:false,
- page:1,
- partnerList:undefined,
- search:'',
- partnerListid:[],
- checkAll: false,
- optionss:[]
- }
- }
- addBox=()=>{
-
- this.setState({
- addPartner:true,
- search:"",
- page:1,
- partnerList:undefined,
- optionss:[]
- })
- this.searchList("")
-
- }
- hideAddBox=()=>{
- this.setState({
- addPartner:false,
- optionss:[],
- partnerListid:[]
- })
- }
- // 搜索框输入
- changeSearchValue=(e)=>{
- this.setState({
- search: e.target.value
- })
- }
- // 回车搜索--搜索成功后page为1
- searchList=()=>{
- let id=this.props.match.params.pathId;
- let {search,page}=this.state;
- let url='/paths/'+id+'/search_members.json?search='+search+"&page="+page;
- axios.post(url).then((result)=>{
- if(result.status==200){
- let list=result.data.users;
- let optionss=[]
- for(var i=0; i{
- console.log(error);
- })
- }
-
-
- SaveAddBox=()=>{
- let {partnerListid} =this.state;
- let id=this.props.match.params.pathId;
- let url="/paths/"+id+"/add_subject_members.json"
- axios.post(url,{
- user_ids:partnerListid
- }).then((response) => {
- if(response.status==200){
- this.setState({
- addPartner:false,
- optionss:[],
- partnerListid:[]
- })
- this.props.updatadetailInfoLists();
- }
- }).catch((error) => {
- console.log(error)
- });
- }
-
- addCollaboratorsid=(id)=>{
- this.setState({
- partnerListid:id
- })
- }
-
- onCheckAllChange = (e) => {
- let {optionss} =this.state;
-
- if(e.target.checked===true){
- this.setState({
- checkAll: e.target.checked,
- partnerListid:optionss
- });
- }else{
- this.setState({
- checkAll: e.target.checked,
- partnerListid:[]
- });
- }
-
- }
-
- contentViewScroll=(e)=>{
- //滑动到底判断
- if(e.currentTarget.scrollHeight-e.currentTarget.scrollTop===e.currentTarget.clientHeight){
- // console.log("到达底部");
-
- let id=this.props.match.params.pathId;
- let {search,page,partnerList,optionss}=this.state;
- let newpage=page+1;
- let url='/paths/'+id+'/search_members.json?search='+search+"&page="+newpage;
-
- axios.post(url).then((result)=>{
- if(result.status==200){
- let list=result.data.users;
- let newlist=partnerList;
- for(var j=0; j{
- console.log(error);
- })
-
- }
-
- }
-
- render(){
- let {addPartner,search,partnerList,optionss,checkAll,partnerListid} = this.state;
-
- return(
-
- {
- this.props.detailInfoList===undefined?"":this.props.detailInfoList.allow_add_member===true?
-
+ 添加合作者
- :""
- }
-
-
-
-
- this.searchList(search)} />
-
-
-
- 姓名
- 昵称
- 职位
- 单位
-
-
-
- {
- partnerList && partnerList.map((item,key)=>{
- return(
- -
-
- {item.user_name}
- {item.nickname}
- {item.identity}
- {item.school_name}
-
- )
- })
- }
-
-
-
-
-
-
- )
- }
-}
+import React, { Component } from 'react';
+import { Modal,Checkbox,Input } from "antd";
+import axios from 'axios';
+
+const Search = Input.Search;
+const CheckboxGroup = Checkbox.Group;
+class addCollaborators extends Component{
+ constructor(props){
+ super(props);
+ this.state = {
+ addPartner:false,
+ page:1,
+ partnerList:undefined,
+ search:'',
+ partnerListid:[],
+ checkAll: false,
+ optionss:[]
+ }
+ }
+ addBox=()=>{
+
+ this.setState({
+ addPartner:true,
+ search:"",
+ page:1,
+ partnerList:undefined,
+ optionss:[]
+ })
+ this.searchList("")
+
+ }
+ hideAddBox=()=>{
+ this.setState({
+ addPartner:false,
+ optionss:[],
+ partnerListid:[]
+ })
+ }
+ // 搜索框输入
+ changeSearchValue=(e)=>{
+ this.setState({
+ search: e.target.value
+ })
+ }
+ // 回车搜索--搜索成功后page为1
+ searchList=()=>{
+ let id=this.props.match.params.pathId;
+ let {search,page}=this.state;
+ let url='/paths/'+id+'/search_members.json?search='+search+"&page="+page;
+ axios.post(url).then((result)=>{
+ if(result.status==200){
+ let list=result.data.users;
+ let optionss=[]
+ for(var i=0; i{
+ console.log(error);
+ })
+ }
+
+
+ SaveAddBox=()=>{
+ let {partnerListid} =this.state;
+ let id=this.props.match.params.pathId;
+ let url="/paths/"+id+"/add_subject_members.json"
+ axios.post(url,{
+ user_ids:partnerListid
+ }).then((response) => {
+ if(response.status==200){
+ this.setState({
+ addPartner:false,
+ optionss:[],
+ partnerListid:[]
+ })
+ this.props.updatadetailInfoLists();
+ }
+ }).catch((error) => {
+ console.log(error)
+ });
+ }
+
+ addCollaboratorsid=(id)=>{
+ this.setState({
+ partnerListid:id
+ })
+ }
+
+ onCheckAllChange = (e) => {
+ let {optionss} =this.state;
+
+ if(e.target.checked===true){
+ this.setState({
+ checkAll: e.target.checked,
+ partnerListid:optionss
+ });
+ }else{
+ this.setState({
+ checkAll: e.target.checked,
+ partnerListid:[]
+ });
+ }
+
+ }
+
+ contentViewScroll=(e)=>{
+ //滑动到底判断
+ if(e.currentTarget.scrollHeight-e.currentTarget.scrollTop===e.currentTarget.clientHeight){
+ // console.log("到达底部");
+
+ let id=this.props.match.params.pathId;
+ let {search,page,partnerList,optionss}=this.state;
+ let newpage=page+1;
+ let url='/paths/'+id+'/search_members.json?search='+search+"&page="+newpage;
+
+ axios.post(url).then((result)=>{
+ if(result.status==200){
+ let list=result.data.users;
+ let newlist=partnerList;
+ for(var j=0; j{
+ console.log(error);
+ })
+
+ }
+
+ }
+
+ render(){
+ let {addPartner,search,partnerList,optionss,checkAll,partnerListid} = this.state;
+
+ return(
+ this.props.detailInfoList===undefined?"":this.props.detailInfoList.allow_add_member===true?
+
+
+ 添加合作者
+
+
+
+ this.searchList(search)} />
+
+
+
+ 姓名
+ 昵称
+ 职位
+ 单位
+
+
+
+ {
+ partnerList && partnerList.map((item,key)=>{
+ return(
+ -
+
+ {item.user_name}
+ {item.nickname}
+ {item.identity}
+ {item.school_name}
+
+ )
+ })
+ }
+
+
+
+
+
+
:""
+
+ )
+ }
+}
export default addCollaborators;
\ No newline at end of file
diff --git a/public/react/src/modules/paths/PathDetail/sendPanel.js b/public/react/src/modules/paths/PathDetail/sendPanel.js
index 2f9059a18..ae7dd5b00 100644
--- a/public/react/src/modules/paths/PathDetail/sendPanel.js
+++ b/public/react/src/modules/paths/PathDetail/sendPanel.js
@@ -27,9 +27,27 @@ class sendPanel extends Component{
//发送至
SentToLesson =() =>{
- this.setState({
- sentShixunPath:true
- })
+ let id=this.props.detailInfoList.id;
+ let url="/paths/"+id+"/choose_course.json";
+ axios.get(url).then((result)=>{
+ if(result.status==200){
+
+ if (result.data.status === 403||result.data.status === 402||result.data.status === 407||result.data.status === 408) {
+
+ }else{
+ this.setState({
+ sendToCourseList:result.data,
+ sentShixunPath:true
+ })
+ }
+
+ }
+ }).catch((error)=>{
+ console.log(error);
+ })
+ // this.setState({
+ // sentShixunPath:true
+ // })
}
//隐藏发送至弹框
hideSenttothevalue =()=>{
@@ -99,17 +117,17 @@ class sendPanel extends Component{
}
componentDidMount(){
- let id=this.props.detailInfoList.id;
- let url="/paths/"+id+"/choose_course.json";
- axios.get(url).then((result)=>{
- if(result.status==200){
- this.setState({
- sendToCourseList:result.data
- })
- }
- }).catch((error)=>{
- console.log(error);
- })
+ // let id=this.props.detailInfoList.id;
+ // let url="/paths/"+id+"/choose_course.json";
+ // axios.get(url).then((result)=>{
+ // if(result.status==200){
+ // this.setState({
+ // sendToCourseList:result.data
+ // })
+ // }
+ // }).catch((error)=>{
+ // console.log(error);
+ // })
}
cardsModalcancel=()=>{
diff --git a/public/react/src/modules/paths/ShixunPathSearch.js b/public/react/src/modules/paths/ShixunPathSearch.js
index da19e0521..3cba8e33f 100644
--- a/public/react/src/modules/paths/ShixunPathSearch.js
+++ b/public/react/src/modules/paths/ShixunPathSearch.js
@@ -14,7 +14,7 @@ class ShixunPathSearch extends Component{
constructor(props) {
super(props)
this.state = {
- order:"publish_time",
+ order:"updated_at",
select:0,
search:"",
page:1,
@@ -126,20 +126,20 @@ class ShixunPathSearch extends Component{
{
diff --git a/public/react/src/modules/tpm/NewHeader.js b/public/react/src/modules/tpm/NewHeader.js
index 7e40b9edd..b816448e0 100644
--- a/public/react/src/modules/tpm/NewHeader.js
+++ b/public/react/src/modules/tpm/NewHeader.js
@@ -8,7 +8,7 @@ import PropTypes from 'prop-types';
// /images/educoder/icon/search.svg
-import { getImageUrl, toPath } from 'educoder'
+import { getImageUrl, toPath ,trigger,broadcastChannelPostMessage} from 'educoder'
import axios from 'axios';
@@ -30,8 +30,6 @@ import 'antd/lib/input/style/index.css';
import './TPMIndex.css';
-import { trigger, broadcastChannelPostMessage } from 'educoder';
-
const $ = window.$
// TODO 这部分脚本从公共脚本中直接调用
@@ -316,6 +314,7 @@ class NewHeader extends Component {
// this.setState({
// isRender:true
// })
+ broadcastChannelPostMessage('refreshPage')
window.location.href = "/";
}
}).catch((error) => {
@@ -881,9 +880,9 @@ submittojoinclass=(value)=>{
/>:""}
{/* /courses/join_course_multi_role */}
- {/*
*/}
+
加入项目
- {/**/}
+
{tojoinitemtype===true?
{
- let id = this.props.match.params.shixunId;
+ if(this.props.checkIfLogin()===false){
+ this.props.showLoginDialog()
+ return
+ }
+ if(this.props.current_user&&this.props.current_user.profile_completed===false){
+ this.setState({
+ AccountProfiletype:true
+ })
+ return
+ }
+ let id = this.props.match.params.shixunId;
let url="/shixuns/" + id +"/search_user_courses.json";
this.setState({
Senttothetype:true
@@ -384,6 +394,11 @@ class TPMBanner extends Component {
//开始实战按钮
startshixunCombat=(id, reset)=>{
+ if(this.props.checkIfLogin()===false){
+ this.props.showLoginDialog()
+ return
+ }
+
if(this.props.current_user&&this.props.current_user.profile_completed===false){
this.setState({
AccountProfiletype:true
diff --git a/public/react/src/modules/tpm/shixunchild/Challenges/Challenges.js b/public/react/src/modules/tpm/shixunchild/Challenges/Challenges.js
index 980e1d5b2..66054142a 100644
--- a/public/react/src/modules/tpm/shixunchild/Challenges/Challenges.js
+++ b/public/react/src/modules/tpm/shixunchild/Challenges/Challenges.js
@@ -220,6 +220,13 @@ class Challenges extends Component {
//开始实战按钮
startshixunCombat = (type, ids, id) => {
+
+ if(this.props.checkIfLogin()===false){
+ this.props.showLoginDialog()
+ return
+ }
+
+
if(this.props.current_user&&this.props.current_user.profile_completed===false){
this.setState({
AccountProfiletype:true
@@ -227,7 +234,7 @@ class Challenges extends Component {
return
}
- debugger
+
let { ChallengesDataList } = this.state;
// let id = this.props.match.params.shixunId;
this.setState({
diff --git a/public/react/src/modules/tpm/shixuns/ShixunCardList.js b/public/react/src/modules/tpm/shixuns/ShixunCardList.js
index 078016057..d95ef75fe 100644
--- a/public/react/src/modules/tpm/shixuns/ShixunCardList.js
+++ b/public/react/src/modules/tpm/shixuns/ShixunCardList.js
@@ -64,9 +64,9 @@ class ShixunCardList extends Component {
let type;
- if(id==="all"){
- type="publish_time";
- }
+ // if(id==="all"){
+ // type="publish_time";
+ // }
if(id==="hot"){
type="hot";
}else if(id==="new"){
@@ -166,16 +166,16 @@ class ShixunCardList extends Component {
-
this.latestHot(e,1)}>全部
-
-
this.onSwitchChange(e,2)}>我的
-
+ {/*
this.latestHot(e,1)}>全部*/}
+ {/*
*/}
+ {/*
this.onSwitchChange(e,2)}>我的*/}
+ {/*
*/}
-
this.latestHot(e,4)}>最新
@@ -186,26 +186,26 @@ class ShixunCardList extends Component {
-
this.upcircles("asc")}
- >
-
-
- {/**/}
-
-
-
this.upcircles("desc")}
- style={{display:upcircle===true?"none":"block"}}
- >
-
-
- {/**/}
-
-
-
-
+ {/*
this.upcircles("asc")}*/}
+ {/*>*/}
+ {/**/}
+ {/**/}
+ {/*/!**!/*/}
+ {/**/}
+ {/*
*/}
+ {/*
this.upcircles("desc")}*/}
+ {/*style={{display:upcircle===true?"none":"block"}}*/}
+ {/*>*/}
+ {/**/}
+ {/**/}
+ {/*/!**!/*/}
+ {/**/}
+ {/*
*/}
+
+ {/*
*/}
{/* this.Input_search(value)}
autoComplete="off"
> */}
-
-
- {
- this.props.search_tags === null ? "" : this.props.search_tags
- }
+ {/*
*/}
+ {/*
*/}
+ {/*
{*/}
+ {/*this.props.search_tags === null ? "" : this.props.search_tags*/}
+ {/*}*/}
{/*
*/}
{/*/!*
*/}
{/*
*!/*/}
@@ -242,8 +242,8 @@ class ShixunCardList extends Component {
{/*
*/}
{/*
隐藏我的*/}
-
-
+ {/*
*/}
+ {/*
*/}
);
diff --git a/public/react/src/modules/tpm/shixuns/ShixunsIndex.js b/public/react/src/modules/tpm/shixuns/ShixunsIndex.js
index 9a73a2f6d..15579610d 100644
--- a/public/react/src/modules/tpm/shixuns/ShixunsIndex.js
+++ b/public/react/src/modules/tpm/shixuns/ShixunsIndex.js
@@ -28,7 +28,7 @@ class ShixunsIndex extends Component {
constructor(props) {
super(props)
this.state={
- order_by: "publish_time",
+ order_by: "new",
page:1,
limit:16,
keyword:"",
@@ -115,10 +115,9 @@ class ShixunsIndex extends Component {
}
allUpdatashixunlist=()=>{
- let{sort}=this.state;
+ let{sort,order_by}=this.state;
this.setState({
- order_by: 'publish_time',
tag_level: 1,
tag_id:'',
page: 1,
@@ -129,7 +128,7 @@ class ShixunsIndex extends Component {
})
let params={
- order_by: 'publish_time',
+ order_by:order_by,
tag_level: 1,
tag_id:'',
page: 1,