diff --git a/app/controllers/homework_attach_controller.rb b/app/controllers/homework_attach_controller.rb
index cd7c0b81c..a3a484079 100644
--- a/app/controllers/homework_attach_controller.rb
+++ b/app/controllers/homework_attach_controller.rb
@@ -26,13 +26,39 @@ class HomeworkAttachController < ApplicationController
end
end
- def add_users users
- if users != nil && users.count > 0
- users.each do |user|
- @homework.homework_users.build(:user_id => user.id)
- @homework.save
+ #作业添加成员(参与人员)
+ def add_homework_users
+ @homework = HomeworkAttach.find(params[:id])
+
+ if params[:membership]
+ if params[:membership][:user_ids]
+ attrs = params[:membership].dup
+ user_ids = attrs.delete(:user_ids)
+ user_ids.each do |user_id|
+ @homework.homework_users.build(:user_id => user_id)
+ end
end
end
+ @homework.save
+ @hoemwork_users = users_for_homework(@homework)
+ @members = members_for_homework(@homework,@hoemwork_users)
+ @members = paginateHelper @members,10
+ respond_to do |format|
+ format.js
+ end
+ end
+
+ #作业删除成员(参与人员)
+ def destory_homework_users
+ @homework = HomeworkAttach.find(params[:id])
+ homework_user = @homework.homework_users.where("user_id = #{params[:user_id]}").first
+ homework_user.destroy
+ @hoemwork_users = users_for_homework(@homework)
+ @members = members_for_homework(@homework,@hoemwork_users)
+ @members = paginateHelper @members,10
+ respond_to do |format|
+ format.js
+ end
end
def create
@@ -78,10 +104,10 @@ class HomeworkAttachController < ApplicationController
def new
@bid = Bid.find(params[:id])
if User.current.admin? || User.current.member_of?(@bid.courses.first)
- #该课程的学生的集合
- @members = @bid.courses.first.members.joins(:member_roles).where("member_roles.role_id IN (:role_id) and user_id <> #{User.current.id}", {:role_id => [5, 10]})
+ #该课程的学生的集合(新建不实现功能:添加成员)
+ #@members = @bid.courses.first.members.joins(:member_roles).where("member_roles.role_id IN (:role_id) and user_id <> #{User.current.id}", {:role_id => [5, 10]})
- @members = paginateHelper @members,10
+ #@members = paginateHelper @members,10
#@all_user = []
#@bid.courses.first.members.each do |member|
# @all_user << member.user
@@ -98,38 +124,43 @@ class HomeworkAttachController < ApplicationController
end
end
+ #获取作业成员的集合
def get_homework_member_list
- @bid = Bid.find(params[:bid_id])
- if User.current.admin? || User.current.member_of?(@bid.courses.first)
+ @homework = HomeworkAttach.includes(:homework_users).includes(:user).find(params[:bid_id])
+ course = @homework.bid.courses.first
+ if User.current.admin? || User.current.member_of?(course)
+ @hoemwork_users = users_for_homework(@homework)
+ @members = members_for_homework(@homework,@hoemwork_users)
#该课程的学生的集合
- @members = @bid.courses.first.members.joins(:member_roles).where("member_roles.role_id IN (:role_id) and user_id <> #{User.current.id}", {:role_id => [5, 10]})
-
+ #@members = course.members.joins(:member_roles).where("member_roles.role_id IN (:role_id)", {:role_id => [5, 10]})
@members = paginateHelper @members,10
else
raise "error"
end
-
respond_to do |format|
format.js
end
end
#获取指定作业的所有成员
- def members_for_homework homework
- people = []
- if homework != nil
- people << homework.user
- homework.homework_users do |homework_user|
- people << homework_user.user
- end
- else
- end
- people
+ def users_for_homework homework
+ homework.nil? ? [] : (homework.users + [homework.user])
+ end
+
+ #获取可选成员列表
+ #homework:作业
+ #users:该作业所有成员
+ def members_for_homework homework,users
+ homework.bid.courses.first.members.joins(:member_roles).where("member_roles.role_id IN (:role_id) and user_id not in (:users)", {:role_id => [5, 10],:users => users})
end
def edit
- @homework = HomeworkAttach.find(params[:id])
+ @homework = HomeworkAttach.includes(:homework_users).includes(:user).find(params[:id])
if User.current.admin? || User.current.member_of?(@homework.bid.courses.first)
+ #@members = @homework.bid.courses.first.members.joins(:member_roles).where("member_roles.role_id IN (:role_id)", {:role_id => [5, 10]})
+ @hoemwork_users = users_for_homework(@homework)
+ @members = members_for_homework(@homework,@hoemwork_users)
+ @members = paginateHelper @members,10
else
render_403 :message => :notice_not_authorized
end
@@ -137,7 +168,8 @@ class HomeworkAttachController < ApplicationController
def update
@homework = HomeworkAttach.find(params[:id])
- if User.current.admin? || User.current.member_of?(@homework.bid.courses.first)
+ course = @homework.bid.courses.first
+ if User.current.admin? || User.current.member_of?(course)
name = params[:homework_name]
description = params[:homework_description]
@homework.name = name
diff --git a/app/helpers/homework_attach_helper.rb b/app/helpers/homework_attach_helper.rb
index 0e34573e4..28bb48d3c 100644
--- a/app/helpers/homework_attach_helper.rb
+++ b/app/helpers/homework_attach_helper.rb
@@ -20,15 +20,16 @@ module HomeworkAttachHelper
#scope = Principal.active.sorted.not_member_of(project).like(params[:q])
#scope = project.members
#principals = paginateHelper members,10
- principals = members
+ #principals = members
#principal_count = members.count
#limit = 10
#principal_pages = Redmine::Pagination::Paginator.new principal_count, limit, params['page'] #by young
#offset ||= principal_pages.offset
#principals = members[offset, limit]
- s = content_tag('div', member_check_box_tags_ex('membership[user_ids][]', principals), :id => 'principals')
+ users = members.map(&:user)
+ s = content_tag('div', member_check_box_tags_ex('membership[user_ids][]', users), :id => 'principals')
links = pagination_links_full(@obj_pages, @obj_count, :per_page_links => false) {|text, parameters, options|
- link_to text, get_homework_member_list_homework_attach_index_path( parameters.merge(:q => params[:q], bid_id: params[:id]||@bid)), :remote => true }
+ link_to text, get_homework_member_list_homework_attach_index_path( parameters.merge(:q => params[:q], bid_id: params[:id]||@homework)), :remote => true }
return s + content_tag('div', content_tag('ul', links), :class => 'pagination_new')
end
@@ -36,7 +37,7 @@ module HomeworkAttachHelper
def member_check_box_tags_ex(name, principals)
s = ''
principals.each do |member|
- s << "
"
+ s << "
"
end
s.html_safe
end
diff --git a/app/models/homework_attach.rb b/app/models/homework_attach.rb
index ad59d107d..c801885b1 100644
--- a/app/models/homework_attach.rb
+++ b/app/models/homework_attach.rb
@@ -7,6 +7,7 @@ class HomeworkAttach < ActiveRecord::Base
belongs_to :bid
has_many :journals_for_messages, :as => :jour, :dependent => :destroy
has_many :homework_users, :dependent => :destroy
+ has_many :users, :through => :homework_users
seems_rateable :allow_update => true, :dimensions => :quality
safe_attributes "bid_id",
diff --git a/app/models/homework_user.rb b/app/models/homework_user.rb
index 0adef62c4..df75ef821 100644
--- a/app/models/homework_user.rb
+++ b/app/models/homework_user.rb
@@ -1,6 +1,6 @@
class HomeworkUser < ActiveRecord::Base
attr_accessible :homework_attach_id, :user_id
- belongs_to :homework_attach
+ belongs_to :homework_attach, :foreign_key => :homework_attach_id
belongs_to :user
end
diff --git a/app/models/user.rb b/app/models/user.rb
index 331ff6993..c0b1ba24e 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -73,7 +73,8 @@ class User < Principal
['none', :label_user_mail_option_none]
]
- belongs_to :homework_user
+ has_many :homework_users
+ has_many :homework_attaches, :through => :homework_users
has_and_belongs_to_many :groups, :after_add => Proc.new {|user, group| group.user_added(user)},
:after_remove => Proc.new {|user, group| group.user_removed(user)}
diff --git a/app/views/homework_attach/_homework_member.html.erb b/app/views/homework_attach/_homework_member.html.erb
index ff25064a0..a372f105f 100644
--- a/app/views/homework_attach/_homework_member.html.erb
+++ b/app/views/homework_attach/_homework_member.html.erb
@@ -1,5 +1,6 @@
<%= error_messages_for 'member' %>
-
<%= link_to_user User.current %> | + +|||
<%= link_to_user homework.user %> | 发布人员 | -删除 | +|
<%= link_to_user user %> | +开发人员 | +<%= link_to l(:button_delete),destory_homework_users_homework_attach_path(:user_id=>user),:remote => true, :method => :post %> | + <% end %> +
<%=raw l(:label_new_homework)%>
-<%=raw l(:label_edit_homework)%>
+- 标 题: - <%= f.text_field :name, :required => true, :name => "homework_name", :size => 60, :style => "width:490px;"%> -
-- 描 述: - - <%= f.text_area :description, :rows => 8, :name => "homework_description", :class => 'wiki-edit', :style => "font-size:small;width:490px;margin-left:10px;" %> - -
--
- -- - <%= submit_tag t(:label_button_ok), :sta => 0, :class => "enterprise"%> - -
++ 标 题: + <%= f.text_field :name, :required => true, :name => "homework_name", :size => 60, :style => "width:490px;"%> +
++ 描 述: + + <%= f.text_area :description, :rows => 8, :name => "homework_description", :class => 'wiki-edit', :style => "font-size:small;width:490px;margin-left:10px;" %> + +
++
+ ++ + <%= submit_tag t(:label_button_ok), :sta => 0, :class => "enterprise"%> + +
<% end %> -<%=h l(:label_new_homework)%>
+ 标 题: + <%= f.text_field "name", :required => true, :size => 60, :style => "width:490px;" %> +
++ 描 述: + + <%= f.text_area "description", :rows => 8, :class => 'wiki-edit', :style => "font-size:small;width:490px;margin-left:10px;" %> + +
++
+ -+
<%= submit_tag t(:label_button_ok), :sta => 0, :class => "enterprise"%>
<% end %> -