2012-05-02 10:18:07 +01:00
|
|
|
class Groups::MembersController < Groups::BaseController
|
2014-03-11 07:39:25 +00:00
|
|
|
before_filter -> { authorize! :manage_members, @group }
|
2011-12-05 12:32:18 +00:00
|
|
|
|
|
|
|
def index
|
2014-03-24 18:28:03 +00:00
|
|
|
@members = @group.members.order(:uname) - [@group.owner]
|
2011-12-05 12:32:18 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
2014-11-11 23:50:15 +00:00
|
|
|
raise CanCan::AccessDenied if @group.owner_id.to_s == params[:member_id]
|
|
|
|
|
|
|
|
relation = @group.actors.where(actor_id: params[:member_id], actor_type: 'User').first
|
|
|
|
relation ||= @group.actors.build(actor_id: params[:member_id], actor_type: 'User')
|
|
|
|
relation.role = params[:role]
|
|
|
|
relation.save!
|
|
|
|
|
|
|
|
flash[:notice] = t("flash.members.successfully_changed")
|
2014-03-04 10:46:10 +00:00
|
|
|
redirect_to group_members_path(@group)
|
2011-12-05 12:32:18 +00:00
|
|
|
end
|
|
|
|
|
2012-03-01 14:23:26 +00:00
|
|
|
def remove
|
2014-11-11 23:50:15 +00:00
|
|
|
User.where(id: params[:members]).each do |user|
|
2014-03-04 10:46:10 +00:00
|
|
|
@group.remove_member(user)
|
2012-03-01 15:41:40 +00:00
|
|
|
end
|
2014-03-04 10:46:10 +00:00
|
|
|
redirect_to group_members_path(@group)
|
2011-12-05 12:32:18 +00:00
|
|
|
end
|
|
|
|
|
2011-12-09 23:40:13 +00:00
|
|
|
def add
|
2014-11-11 23:50:15 +00:00
|
|
|
@user = User.where(id: params[:member_id]).first
|
2012-11-13 14:29:45 +00:00
|
|
|
if !@user
|
2014-01-21 04:51:49 +00:00
|
|
|
flash[:error] = t("flash.collaborators.wrong_user", uname: params[:user_uname])
|
2014-03-04 10:46:10 +00:00
|
|
|
elsif @group.add_member(@user, params[:role])
|
2012-11-13 14:29:45 +00:00
|
|
|
flash[:notice] = t("flash.members.successfully_added")
|
|
|
|
else
|
|
|
|
flash[:error] = t("flash.members.error_in_adding")
|
2011-12-09 23:40:13 +00:00
|
|
|
end
|
2014-03-04 10:46:10 +00:00
|
|
|
redirect_to group_members_path(@group)
|
2011-12-09 23:40:13 +00:00
|
|
|
end
|
2011-12-05 12:32:18 +00:00
|
|
|
end
|