Merge branch 'develop' of https://git.trustie.net/jacknudt/trustieforge into dev_raining

This commit is contained in:
daiao 2017-02-24 20:15:03 +08:00
commit a50ddd201c
3 changed files with 24 additions and 14 deletions

View File

@ -870,7 +870,7 @@ class ProjectsController < ApplicationController
end
end
# TrainintTask.status 0评测中 1评测成功 2评测惊醒
# TrainintTask.status 0评测中 1评测成功 2评测进行
# 非项目成员、非实训子项目不允许执行该方法
def task_execute
if !@project.is_child_training_project? || !User.current.member_of?(@project)
@ -943,22 +943,25 @@ class ProjectsController < ApplicationController
return
end
original_tasks_count = original_project.training_tasks.count
position = @training_task.try(:position) + 1
position = @training_task.try(:position)
# 测试,默认成功
if status == 0
ActiveRecord::Base.transaction do
if position <= original_tasks_count
if position < original_tasks_count
# 继续发布下一个任务
position = position + 1
publish_training_tasks original_project_id, @training_task.project_id, position
@training_task.update_attribute(:status, 1)
end
@training_task.update_attribute(:status, 1)
# 创建一条回复提醒
content = position == original_tasks_count ? "恭喜您,您已经完成了实训项目的所有任务" : "恭喜您,您已经完成了本任务"
content = (position == original_tasks_count) ? "恭喜您,您已经完成了实训项目的所有任务" : "恭喜您,您已经完成了本任务"
add_training_task_journal(content, original_project.user_id)
end
else
content = "很抱歉,您的任务未通过,请继续加油,错误信息如下:#{message}"
add_training_task_journal(content, original_project.user_id)
# 失败的时候可以继续提交
@training_task.update_attribute(:status, 0)
end
end

View File

@ -11,7 +11,7 @@
TO
<%= link_to activity.project.name.to_s+" | 实训任务", project_training_tasks_path(activity.project), :class => "newsBlue ml15"%>
</div>
<% if User.current.logged? && is_project_manager?(User.current.id, project_id) || activity.author_id == User.current.id %>
<% if !@project.is_child_training_project? && User.current.logged? && (is_project_manager?(User.current.id, project_id) || activity.author_id == User.current.id) %>
<div class="homepagePostSetting">
<ul>
<li class="homepagePostSettingIcon">

View File

@ -17,21 +17,28 @@
该项目还没有创建版本库,暂时不支持实训
</li>
<% else %>
<% if has_forked_cur_project(@project) %>
<li class="center mb5" style="line-height:20px">
<% if has_forked_cur_project(@project) %>
您已经实训过该项目,点击“确定”将会跳转到您的实训项目主页,请问您是否继续?
<% elsif @project.training_tasks.count == 0 %>
该项目还没有创建实训任务,暂时不支持开启实训
<% else %>
实训将在后台为您创建一个新的同名项目,并为您推送第一个任务,请问您是否继续?
<% end %>
您已经实训过该项目,点击“确定”将会跳转到您的实训项目主页,请问您是否继续?
</li>
<li class="mt10">
<label class="mr27">&nbsp;</label>
<a href="javascript:void(0);" class="sy_btn_grey fl " onclick="hideModal()">取&nbsp;&nbsp;消</a>
<%= link_to "确 定", {:controller => 'projects', :action => 'training_project_extend'}, :class => "sy_btn_blue fl ml20", :onclick => "hideModal();", :target => "_blank" %>
<% project = Project.where(:forked_from_project_id => @project.id, :user_id => User.current.id).first %>
<%= link_to "确 定", project_path(project), :class => "sy_btn_blue fl ml20", :onclick => "hideModal();", :target => "_blank" %>
<div class="cl"></div>
</li>
<% else %>
<li class="center mb5" style="line-height:20px">
实训将在后台为您创建一个新的同名项目,并为您推送第一个任务,请问您是否继续?
</li>
<li class="mt10">
<label class="mr27">&nbsp;</label>
<a href="javascript:void(0);" class="sy_btn_grey fl " onclick="hideModal()">取&nbsp;&nbsp;消</a>
<%= link_to "确 定", {:controller => 'projects', :action => 'training_project_extend'}, :class => "sy_btn_blue fl ml20", :onclick => "hideModal();", :target => "_blank" %>
<div class="cl"></div>
</li>
<% end %>
<% end %>
<% end %>
</ul>