From 67c9fefba6f97a9c73bbda9a7768f119c6fe62ce Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Tue, 10 Jun 2014 14:27:55 +0800
Subject: [PATCH 01/10] =?UTF-8?q?=E5=A2=9E=E5=8A=A0tab=E9=A1=B5=E5=88=87?=
=?UTF-8?q?=E6=8D=A2=E7=9A=84js?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/helpers/homework_attach_helper.rb | 6 +--
...mework.html.erb => _new_homework.html.erb} | 4 +-
app/views/homework_attach/new.html.erb | 54 ++++++++++++-------
3 files changed, 38 insertions(+), 26 deletions(-)
rename app/views/homework_attach/{_edit_homework.html.erb => _new_homework.html.erb} (75%)
diff --git a/app/helpers/homework_attach_helper.rb b/app/helpers/homework_attach_helper.rb
index ed8d0949b..85f9a64ad 100644
--- a/app/helpers/homework_attach_helper.rb
+++ b/app/helpers/homework_attach_helper.rb
@@ -9,12 +9,10 @@ module HomeworkAttachHelper
end
#作业添加、编辑界面的tab页
def homework_settings_tabs f
- @project = Project.find 76
@f = f
- tabs = [{:name => 'info', :action => :edit_homework, :partial => 'homework_attach/edit_homework', :label => :label_information_plural},
- {:name => 'members', :action => :homework_member, :partial => 'homework_attach/homework_member', :label => :label_member_plural}
+ tabs = [{:name => 'info', :partial => 'homework_attach/edit_homework', :label => :label_information_plural},
+ {:name => 'members', :partial => 'homework_attach/homework_member', :label => :label_member_plural}
]
- #tabs.select {|tab| User.current.allowed_to?(tab[:action], @homework)}
end
#作业可选成员列表分页
diff --git a/app/views/homework_attach/_edit_homework.html.erb b/app/views/homework_attach/_new_homework.html.erb
similarity index 75%
rename from app/views/homework_attach/_edit_homework.html.erb
rename to app/views/homework_attach/_new_homework.html.erb
index 25f90f186..9ff3e2ffe 100644
--- a/app/views/homework_attach/_edit_homework.html.erb
+++ b/app/views/homework_attach/_new_homework.html.erb
@@ -2,12 +2,12 @@
diff --git a/app/views/homework_attach/new.html.erb b/app/views/homework_attach/new.html.erb
index 966176a1d..0ead4babd 100644
--- a/app/views/homework_attach/new.html.erb
+++ b/app/views/homework_attach/new.html.erb
@@ -1,3 +1,13 @@
+
+
<%= form_for('new_form', :method => :post,
@@ -6,26 +16,30 @@
:user_id => User.current.id,
:bid_id => @bid
}) do |f|%>
-
- 标 题:
- <%= 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;" %>
-
-
-
-
-
+
+
+
+
+ <%= render :partial => "new_homework",:locals => {:f => f} %>
+
+
+
+ <%= render :partial => "homework_member" %>
+
+
<%= submit_tag t(:label_button_ok), :sta => 0, :class => "enterprise"%>
From cbb348dc0ebbd1cdf0ab22768455a7261cb7896a Mon Sep 17 00:00:00 2001
From: sw <939547590@qq.com>
Date: Tue, 10 Jun 2014 15:44:10 +0800
Subject: [PATCH 02/10] =?UTF-8?q?=E5=AE=9E=E7=8E=B0=E7=BB=99=E4=BD=9C?=
=?UTF-8?q?=E4=B8=9A=E5=A2=9E=E5=8A=A0=E7=94=A8=E6=88=B7=E9=A1=B5=E9=9D=A2?=
=?UTF-8?q?=E7=9B=B8=E5=85=B3js=E4=BB=A3=E7=A0=81=E5=8F=8Acss=E4=BB=A3?=
=?UTF-8?q?=E7=A0=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/controllers/homework_attach_controller.rb | 2 +-
app/helpers/homework_attach_helper.rb | 32 ++--
.../homework_attach/_homework_member.html.erb | 149 +++---------------
.../homework_attach/_new_homework.html.erb | 1 -
app/views/homework_attach/new.html.erb | 4 +-
5 files changed, 50 insertions(+), 138 deletions(-)
diff --git a/app/controllers/homework_attach_controller.rb b/app/controllers/homework_attach_controller.rb
index c4c1f8922..e20a5a868 100644
--- a/app/controllers/homework_attach_controller.rb
+++ b/app/controllers/homework_attach_controller.rb
@@ -78,8 +78,8 @@ 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]})
-
#@all_user = []
#@bid.courses.first.members.each do |member|
# @all_user << member.user
diff --git a/app/helpers/homework_attach_helper.rb b/app/helpers/homework_attach_helper.rb
index 85f9a64ad..95327edd1 100644
--- a/app/helpers/homework_attach_helper.rb
+++ b/app/helpers/homework_attach_helper.rb
@@ -19,23 +19,37 @@ module HomeworkAttachHelper
def render_new_members_for_homework members
#scope = Principal.active.sorted.not_member_of(project).like(params[:q])
#scope = project.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]
+ principals = paginateHelper members,10
+ #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')
- links = pagination_links_full(principal_pages, principal_count, :per_page_links => false,:remote => true)
-
- s + content_tag('div', content_tag('ul', links), :class => 'pagination_new')
+ links = pagination_links_full(@obj_pages, @obj_count, :per_page_links => false) {|text, parameters, options|
+ link_to text, new_homework_attach_path( parameters.merge(:q => params[:q], :format => 'js')), :remote => true }
+ return s + content_tag('div', content_tag('ul', links), :class => 'pagination_new')
end
#扩展的checkbox生成
def member_check_box_tags_ex(name, principals)
s = ''
principals.each do |member|
- s << "\n"
+ s << "
"
end
s.html_safe
end
+
+ def paginateHelper obj, pre_size=20
+ @obj_count = obj.count
+ @obj_pages = Redmine::Pagination::Paginator.new @obj_count, pre_size, params['page']
+ if obj.kind_of? ActiveRecord::Base or obj.kind_of? ActiveRecord::Relation
+ obj.limit(@obj_pages.per_page).offset(@obj_pages.offset)
+ elsif obj.kind_of? Array
+ obj[@obj_pages.offset, @obj_pages.per_page]
+ else
+ logger.error "[ApplicationController] Error : application_controller#paginateHelper ===> unknow category: #{obj.class}"
+ raise RuntimeError, 'unknow type, Please input you type into this helper.'
+ end
+ end
end
\ No newline at end of file
diff --git a/app/views/homework_attach/_homework_member.html.erb b/app/views/homework_attach/_homework_member.html.erb
index f69f9edff..ed268f652 100644
--- a/app/views/homework_attach/_homework_member.html.erb
+++ b/app/views/homework_attach/_homework_member.html.erb
@@ -1,131 +1,30 @@
<%= error_messages_for 'member' %>
-<%
- roles = Role.givable.all
- if @project.project_type == Project::ProjectType_course
- roles = roles[3..5]
- else
- roles = roles[0..2]
- end
- members = @project.member_principals.includes(:roles, :principal).all.sort
-%>
-
-
- <% if members.any? %>
-
-
-
- <%= l(:label_user) %> |
- <%= l(:label_role_plural) %> |
- |
- <%= call_hook(:view_projects_settings_members_table_header, :project => @project) %>
+
+
+
+
+ <%= l(:label_user) %> |
+ <%= l(:label_role_plural) %> |
+ |
+
+
+
+
+ <%= link_to_user User.current %> |
+ 发布人员 |
-
-
- <% members.each do |member| %>
- <% next if member.new_record? %>
-
- <%= link_to_user member.principal %> |
-
-
- <%= h member.roles.sort.collect(&:to_s).join(', ') %>
-
- <%= form_for(member, {:as => :membership, :remote => true, :url => membership_path(member),
- :method => :put,
- :html => {:id => "member-#{member.id}-roles-form", :class => 'hol'}}
- ) do |f| %>
-
-
- <% roles.each do |role| %>
-
- <% end %>
- <%= hidden_field_tag 'membership[role_ids][]', '' %>
- <%= submit_tag l(:button_change), :class => "small" %>
- <%= link_to_function l(:button_cancel),
- "$('#member-#{member.id}-roles').show(); $('#member-#{member.id}-roles-form').hide(); return false;"
- %>
- <% end %>
- |
-
- <% if @project.project_type == 1 %>
- <% if member.roles.first.to_s == "Manager" %>
- |
- <% else %>
-
- <%= link_to_function l(:button_edit),
- "$('#member-#{member.id}-roles').hide(); $('#member-#{member.id}-roles-form').show(); return false;",
- :class => 'icon icon-edit' %>
- <%= delete_link membership_path(member),
- :remote => true,
- :data => (!User.current.admin? && member.include?(User.current) ? {:confirm => l(:text_own_membership_delete_confirmation)} : {}) if member.deletable? %>
- |
- <% end %>
- <% else %>
-
- <%= link_to_function l(:button_edit),
- "$('#member-#{member.id}-roles').hide(); $('#member-#{member.id}-roles-form').show(); return false;",
- :class => 'icon icon-edit' %>
- <%= delete_link membership_path(member),
- :remote => true,
- :data => (!User.current.admin? && member.include?(User.current) ? {:confirm => l(:text_own_membership_delete_confirmation)} : {}) if member.deletable? %>
- |
- <% end %>
-
- <%= call_hook(:view_projects_settings_members_table_row, {:project => @project, :member => member}) %>
-
- <% end; reset_cycle %>
-
-
- <% else %>
-
<%= l(:label_no_data) %>
- <% end %>
+
+
-
- <% if roles.any? %>
- <% if @project.applied_projects.any? %>
-
- <%= form_for(@applied_members, {:as => :membership, :url => project_memberships_path(@project), :remote => true, :method => :post}) do |f| %>
-
- <% end %>
-
- <% end %>
-
- <%= form_for(@member, {:as => :membership, :url => project_memberships_path(@project), :remote => true, :method => :post}) do |f| %>
-