summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--app/assets/javascripts/users_select.js.coffee2
-rw-r--r--app/controllers/teams/members_controller.rb2
-rw-r--r--app/helpers/application_helper.rb6
-rw-r--r--app/models/user_team.rb3
-rw-r--r--app/views/team_members/_form.html.haml3
-rw-r--r--app/views/teams/members/new.html.haml3
6 files changed, 12 insertions, 7 deletions
diff --git a/app/assets/javascripts/users_select.js.coffee b/app/assets/javascripts/users_select.js.coffee
index 8dad599a6d8..45e4a17d676 100644
--- a/app/assets/javascripts/users_select.js.coffee
+++ b/app/assets/javascripts/users_select.js.coffee
@@ -16,7 +16,7 @@ $ ->
$('.ajax-users-select').select2
placeholder: "Search for a user"
- multiple: true
+ multiple: $('.ajax-users-select').hasClass('multiselect')
minimumInputLength: 0
ajax: # instead of writing the function to execute the request we use Select2's convenient helper
url: "/api/v3/users.json"
diff --git a/app/controllers/teams/members_controller.rb b/app/controllers/teams/members_controller.rb
index 4bd70fd7247..f87d422f84e 100644
--- a/app/controllers/teams/members_controller.rb
+++ b/app/controllers/teams/members_controller.rb
@@ -13,7 +13,7 @@ class Teams::MembersController < Teams::ApplicationController
def create
unless params[:user_ids].blank?
- user_ids = params[:user_ids]
+ user_ids = params[:user_ids].split(',')
access = params[:default_project_access]
is_admin = params[:group_admin]
user_team.add_members(user_ids, access, is_admin)
diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
index 45972612baf..7567da15f9e 100644
--- a/app/helpers/application_helper.rb
+++ b/app/helpers/application_helper.rb
@@ -170,7 +170,9 @@ module ApplicationHelper
alias_method :url_to_image, :image_url
- def users_select_tag(id)
- hidden_field_tag(id, '', class: "ajax-users-select")
+ def users_select_tag(id, opts = {})
+ css_class = "ajax-users-select"
+ css_class << " multiselect" if opts[:multiple]
+ hidden_field_tag(id, '', class: css_class)
end
end
diff --git a/app/models/user_team.rb b/app/models/user_team.rb
index 0cb84edd66d..d5b75851279 100644
--- a/app/models/user_team.rb
+++ b/app/models/user_team.rb
@@ -69,6 +69,9 @@ class UserTeam < ActiveRecord::Base
end
def add_members(users, access, group_admin)
+ # reject existing users
+ users.reject! { |id| member_ids.include?(id.to_i) }
+
users.each do |user|
add_member(user, access, group_admin)
end
diff --git a/app/views/team_members/_form.html.haml b/app/views/team_members/_form.html.haml
index e45c6f6fca9..4e8f67702cf 100644
--- a/app/views/team_members/_form.html.haml
+++ b/app/views/team_members/_form.html.haml
@@ -12,8 +12,7 @@
.clearfix
= f.label :user_ids, "People"
.input
- = users_select_tag(:user_ids)
- -#= select_tag(:user_ids, options_from_collection_for_select(User.active.not_in_project(@project).alphabetically, :id, :name_with_username), {data: {placeholder: "Select users"}, class: "chosen xxlarge", multiple: true})
+ = users_select_tag(:user_ids, multiple: true)
%h6 2. Set access level for them
.clearfix
diff --git a/app/views/teams/members/new.html.haml b/app/views/teams/members/new.html.haml
index 1a03cea05cc..9b9b3cef59b 100644
--- a/app/views/teams/members/new.html.haml
+++ b/app/views/teams/members/new.html.haml
@@ -20,7 +20,8 @@
%td= @team.admin?(member) ? "Admin" : "Member"
%td
%tr
- %td= select_tag :user_ids, options_from_collection_for_select(@users , :id, :name_with_username), multiple: true, data: {placeholder: 'Select users'}, class: 'chosen span5'
+ %td
+ = users_select_tag(:user_ids, multiple: true)
%td= select_tag :default_project_access, options_for_select(Project.access_options), {class: "project-access-select chosen span3" }
%td
%span= check_box_tag :group_admin