Commit acb402a1c1cfb23613be0f988b60884c352de37c
1 parent
7a42dece
Exists in
master
and in
4 other branches
Ability to leave group from profile area
Showing
7 changed files
with
56 additions
and
2 deletions
Show diff stats
app/assets/stylesheets/common.scss
| ... | ... | @@ -0,0 +1,24 @@ |
| 1 | +class Profiles::GroupsController < ApplicationController | |
| 2 | + layout "profile" | |
| 3 | + | |
| 4 | + def index | |
| 5 | + @groups = current_user.authorized_groups.all | |
| 6 | + end | |
| 7 | + | |
| 8 | + def leave | |
| 9 | + @users_group = group.users_groups.where(user_id: current_user.id).first | |
| 10 | + | |
| 11 | + if group.owner == current_user | |
| 12 | + redirect_to(profile_groups_path, alert: "You can't leave group. You must transfer it to another owner before leaving.") | |
| 13 | + else | |
| 14 | + @users_group.destroy | |
| 15 | + redirect_to(profile_groups_path, info: "You left #{group.name} group.") | |
| 16 | + end | |
| 17 | + end | |
| 18 | + | |
| 19 | + private | |
| 20 | + | |
| 21 | + def group | |
| 22 | + @group ||= Group.find_by_path(params[:id]) | |
| 23 | + end | |
| 24 | +end | ... | ... |
app/views/layouts/_flash.html.haml
app/views/layouts/nav/_profile.html.haml
| ... | ... | @@ -12,6 +12,8 @@ |
| 12 | 12 | %span.count= current_user.keys.count |
| 13 | 13 | = nav_link(path: 'profiles#design') do |
| 14 | 14 | = link_to "Design", design_profile_path |
| 15 | + = nav_link(controller: :groups) do | |
| 16 | + = link_to "Groups", profile_groups_path | |
| 15 | 17 | = nav_link(path: 'profiles#history') do |
| 16 | 18 | = link_to "History", history_profile_path |
| 17 | 19 | ... | ... |
| ... | ... | @@ -0,0 +1,17 @@ |
| 1 | +.ui-box | |
| 2 | + %h5.title Groups | |
| 3 | + %ul.well-list | |
| 4 | + - @groups.each do |group| | |
| 5 | + %li | |
| 6 | + .pull-right | |
| 7 | + - if can?(current_user, :manage_group, group) | |
| 8 | + = link_to edit_group_path(group), class: "btn-small btn grouped" do | |
| 9 | + %i.icon-cogs | |
| 10 | + Settings | |
| 11 | + | |
| 12 | + = link_to leave_profile_group_path(group), confirm: "Are you sure you want to leave #{group.name} group?", method: :delete, class: "btn-small btn grouped", title: 'Remove user from group' do | |
| 13 | + %i.icon-signout | |
| 14 | + Leave | |
| 15 | + | |
| 16 | + = link_to group, class: 'group-name' do | |
| 17 | + = group.name | ... | ... |
app/views/users_groups/_users_group.html.haml
| ... | ... | @@ -13,6 +13,7 @@ |
| 13 | 13 | - else |
| 14 | 14 | = member.human_access |
| 15 | 15 | |
| 16 | - - if show_controls && user != current_user && user != @group.owner | |
| 16 | + - if show_controls && user != @group.owner && user != current_user | |
| 17 | 17 | = link_to group_users_group_path(@group, member), confirm: remove_user_from_group_message(@group, user), method: :delete, remote: true, class: "btn-tiny btn btn-remove", title: 'Remove user from group' do |
| 18 | 18 | %i.icon-minus.icon-white |
| 19 | + | ... | ... |
config/routes.rb
| ... | ... | @@ -116,6 +116,11 @@ Gitlab::Application.routes.draw do |
| 116 | 116 | resource :notifications, only: [:show, :update] |
| 117 | 117 | resource :password, only: [:new, :create] |
| 118 | 118 | resources :keys |
| 119 | + resources :groups, only: [:index] do | |
| 120 | + member do | |
| 121 | + delete :leave | |
| 122 | + end | |
| 123 | + end | |
| 119 | 124 | end |
| 120 | 125 | end |
| 121 | 126 | ... | ... |