Merge branch 'guange_homework' into szzh

tmp
sw 10 years ago
commit 4405a31c9c

@ -154,7 +154,21 @@ class HomeworkCommonController < ApplicationController
#编程作业相关属性 #编程作业相关属性
if @homework.homework_type == 2 if @homework.homework_type == 2
@homework.homework_detail_programing ||= HomeworkDetailPrograming.new
@homework_detail_programing = @homework.homework_detail_programing
@homework_detail_programing.ta_proportion = params[:ta_proportion] || 0.6
@homework_detail_programing.language = params[:language_type].to_i
@homework.homework_tests.delete_all
inputs = params[:program][:input]
if Array === inputs
inputs.each_with_index do |val, i|
@homework.homework_tests << HomeworkTest.new(
input: val,
output: params[:program][:output][i]
)
end
end
end end
if @homework.save if @homework.save

@ -631,7 +631,7 @@ class StudentWorkController < ApplicationController
unless @homework.save unless @homework.save
logger.debug @homework.errors.full_messages logger.debug @homework.errors.full_messages
else else
student_work = @homework.student_works.where(user_id: User.current.id).first student_work = StudentWork.where(homework_common_id: @homework.id, user_id: User.current.id).first
end end
end end
student_work student_work

@ -354,7 +354,7 @@ class UsersController < ApplicationController
@user = User.current @user = User.current
@homework = HomeworkCommon.find(params[:homework_id]) @homework = HomeworkCommon.find(params[:homework_id])
@is_test = params[:is_test] == 'true' @is_test = params[:is_test] == 'true'
@student_work = @homework.student_works.where(user_id: User.current.id).first @student_work = StudentWork.where(homework_common_id: @homework.id, user_id: User.current.id).first
if @student_work.nil? if @student_work.nil?
@student_work = StudentWork.new @student_work = StudentWork.new
end end
@ -382,7 +382,7 @@ class UsersController < ApplicationController
def user_commit_homework def user_commit_homework
homework = HomeworkCommon.find(params[:homework]) homework = HomeworkCommon.find(params[:homework])
student_work = homework.student_works.where(user_id: User.current.id).first student_work = StudentWork.where(homework_common_id: homework.id, user_id: User.current.id).first
if student_work if student_work
student_work.save student_work.save
flash[:notice] = l(:notice_successful_create) flash[:notice] = l(:notice_successful_create)

@ -60,6 +60,6 @@ class HomeworkCommon < ActiveRecord::Base
self.homework_type == 2 && self.homework_detail_programing self.homework_type == 2 && self.homework_detail_programing
end end
delegate :language_name, :to => :homework_detail_programing delegate :language_name, :language, :to => :homework_detail_programing
end end

@ -1,6 +1,11 @@
<% content_for :header_tags do %> <% content_for :header_tags do %>
<%= javascript_include_tag "/assets/kindeditor/kindeditor",'/assets/kindeditor/pasteimg'%> <%= javascript_include_tag "/assets/kindeditor/kindeditor",'/assets/kindeditor/pasteimg'%>
<%= javascript_include_tag 'homework','baiduTemplate' %> <%= javascript_include_tag 'homework','baiduTemplate' %>
<script type="text/javascript">
$(function(){
$("#BluePopupBox a.BlueCirBtn").click();
});
</script>
<% end %> <% end %>
<div class="HomeWorkCon"> <div class="HomeWorkCon">
@ -57,7 +62,7 @@
<div class="cl"></div> <div class="cl"></div>
</div> </div>
<input type="hidden" name="homework_type" value="1"> <input type="hidden" name="homework_type" value="<%= edit_mode ? homework.homework_type : 1 %>">
</div> </div>
</div> </div>
@ -90,15 +95,29 @@
<div class="HomeWorkCon"> <div class="HomeWorkCon">
<div class="mt15"> <div class="mt15">
<select class="InputBox W120 language_type" > <select class="InputBox W120 language_type" >
<option value="1" selected>C语言</option> <%= options_for_select({"C语言"=>1, "C++"=>2}, (edit_mode && homework.is_program_homework?) ? homework.language : 1) %>
<option value="2">C++</option>
</select> </select>
</div> </div>
<% if edit_mode && homework.is_program_homework? %>
<% homework.homework_tests.each_with_index do |test, index| %>
<div class="mt10">
<textarea class="InputBox W320 fl mr10" placeholder="测试输入" id="textarea_input_test"><%= test.input %></textarea><textarea class="InputBox W320 fl mr5" placeholder="测试输出"><%= test.output %></textarea>
<a href="javascript:void(0);" class=" fl icon_add" title="增加测试组"></a>
<% if index != 0 %>
<a href="javascript:void(0);" class=" fl icon_remove" title="删除测试组"></a>
<% end %>
<div class="cl"></div>
</div>
<% end %>
<% else %>
<div class="mt10"> <div class="mt10">
<textarea class="InputBox W320 fl mr10" placeholder="测试输入" id="textarea_input_test"></textarea><textarea class="InputBox W320 fl mr5" placeholder="测试输出"></textarea> <textarea class="InputBox W320 fl mr10" placeholder="测试输入" id="textarea_input_test"></textarea><textarea class="InputBox W320 fl mr5" placeholder="测试输出"></textarea>
<a href="javascript:void(0);" class=" fl icon_add" title="增加测试组"></a> <a href="javascript:void(0);" class=" fl icon_add" title="增加测试组"></a>
<div class="cl"></div> <div class="cl"></div>
</div> </div>
<% end %>
<div class="mt10"> <div class="mt10">
<a href="javascript:void(0);" class="BlueCirBtn fr">确&nbsp;&nbsp;定</a> <a href="javascript:void(0);" class="BlueCirBtn fr">确&nbsp;&nbsp;定</a>

@ -58,10 +58,10 @@ $(function(){
); );
}; };
$('#test-program-btn').live('click', test_program); $('#test-program-btn').on('click', test_program);
$('#commit-program-work-btn').live('click', function(){ $('#commit-program-work-btn').on('click', function(){
if(!valid_form()){ if(!valid_form()){
return; return;
} }
@ -89,11 +89,10 @@ $(function(){
$(".HomeWorkCon form").submit(); $(".HomeWorkCon form").submit();
}); });
$('form.edit_student_work').live('keydown', '#program-src', function(){ $('form.edit_student_work').on('keydown', '#program-src', function(){
tested = false; tested = false;
}); });
//发布作业 //发布作业
$('#program-src').focus(function(){ $('#program-src').focus(function(){
@ -104,25 +103,28 @@ $(function(){
$('input.date-input').datepicker(datepickerOptions); $('input.date-input').datepicker(datepickerOptions);
$('a.pic_date').live('click', function(){ $('a.pic_date').on('click', function(){
$(this).parent().prev().first().focus(); $(this).parent().prev().first().focus();
}) })
$('a.ProBtn').live('click', function(){
$("#BluePopupBox").dialog({ $("#BluePopupBox").dialog({
modal: true, modal: true,
autoOpen: false,
dialogClass: 'BluePopupBox', dialogClass: 'BluePopupBox',
minWidth: 753 minWidth: 753
}); });
$(".ui-dialog-titlebar").hide();
$("a.CloseBtn").live('click', function(){ $('a.ProBtn').on('click', function(){
$("#BluePopupBox").dialog("open");
$(".ui-dialog-titlebar").hide();
$("a.CloseBtn").on('click', function(){
$("#BluePopupBox" ).dialog("close"); $("#BluePopupBox" ).dialog("close");
}); });
$('#textarea_input_test').focus(); $('#textarea_input_test').focus();
});
$("#BluePopupBox a.BlueCirBtn").live('click', function(){ $("#BluePopupBox a.BlueCirBtn").on('click', function(){
var test_numbers = 0; var test_numbers = 0;
var valid = true; var valid = true;
var input = null; var input = null;
@ -157,17 +159,18 @@ $(function(){
$('.program-input').remove(); $('.program-input').remove();
var html=bt('t:program-input-list',data); var html=bt('t:program-input-list',data);
$("input[name=homework_type]").after(html); $("input[name=homework_type]").after(html);
if($( "#BluePopupBox" ).dialog( "isOpen" )){
$("#BluePopupBox").dialog( "close" ); $("#BluePopupBox").dialog( "close" );
} }
}); }
}); });
$("#BluePopupBox").live('click', 'a.icon_add', function(){ $("#BluePopupBox").on('click', 'a.icon_add', function(){
var html = bt('t:test-answer-list', null); var html = bt('t:test-answer-list', null);
$(this).parent('.mt10').after(html); $(this).parent('.mt10').after(html);
}); });
$("#BluePopupBox").live('click', 'a.icon_remove', function(){ $("#BluePopupBox").on('click', 'a.icon_remove', function(){
$(this).parent('.mt10').remove(); $(this).parent('.mt10').remove();
}); });
}); });
Loading…
Cancel
Save