Commit c9e0dae2 authored by Jacob Schatz's avatar Jacob Schatz

Merge branch 'protected-branches-dropdown-headers' into 'master'

Protected branches dropdown headers

Closes #1294

See merge request !1114
parents c93b73c1 7fd235da
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
this.isAllowedToPushDropdown = false; this.isAllowedToPushDropdown = false;
this.groups = []; this.groups = [];
this.accessLevel = accessLevel; this.accessLevel = accessLevel;
this.accessLevelsData = accessLevelsData; this.accessLevelsData = accessLevelsData.roles;
this.$dropdown = $dropdown; this.$dropdown = $dropdown;
this.$wrap = this.$dropdown.closest(`.${this.accessLevel}-container`); this.$wrap = this.$dropdown.closest(`.${this.accessLevel}-container`);
this.usersPath = '/autocomplete/users.json'; this.usersPath = '/autocomplete/users.json';
...@@ -275,8 +275,7 @@ ...@@ -275,8 +275,7 @@
let consolidatedData = []; let consolidatedData = [];
const map = []; const map = [];
let roles = []; let roles = [];
const selectedUsers = []; const users = [];
const unselectedUsers = [];
let groups = []; let groups = [];
const selectedItems = this.getSelectedItems(); const selectedItems = this.getSelectedItems();
...@@ -319,12 +318,12 @@ ...@@ -319,12 +318,12 @@
if (current.type !== LEVEL_TYPES.USER) { continue; } if (current.type !== LEVEL_TYPES.USER) { continue; }
// Collect selected users // Collect selected users
selectedUsers.push({ users.push({
id: current.user_id, id: current.user_id,
name: current.name, name: current.name,
username: current.username, username: current.username,
avatar_url: current.avatar_url, avatar_url: current.avatar_url,
type: LEVEL_TYPES.USER type: LEVEL_TYPES.USER,
}); });
// Save identifiers for easy-checking more later // Save identifiers for easy-checking more later
...@@ -339,32 +338,24 @@ ...@@ -339,32 +338,24 @@
// Add is it has not been added // Add is it has not been added
if (map.indexOf(LEVEL_TYPES.USER + u.id) === -1) { if (map.indexOf(LEVEL_TYPES.USER + u.id) === -1) {
u.type = LEVEL_TYPES.USER; u.type = LEVEL_TYPES.USER;
unselectedUsers.push(u); users.push(u);
} }
} }
if (groups.length) { if (roles.length) {
consolidatedData = consolidatedData.concat(groups); consolidatedData = consolidatedData.concat([{ header: 'Roles', }], roles);
} }
if (roles.length) { if (groups.length) {
if (groups.length) { if (roles.length) {
consolidatedData = consolidatedData.concat(['divider']); consolidatedData = consolidatedData.concat(['divider']);
} }
consolidatedData = consolidatedData.concat(roles); consolidatedData = consolidatedData.concat([{ header: 'Groups', }], groups);
} }
if (selectedUsers.length) { if (users.length) {
consolidatedData = consolidatedData.concat(['divider'], selectedUsers); consolidatedData = consolidatedData.concat(['divider'], [{ header: 'Users', }], users);
}
if (unselectedUsers.length) {
if (!selectedUsers.length) {
consolidatedData = consolidatedData.concat(['divider']);
}
consolidatedData = consolidatedData.concat(unselectedUsers);
} }
return consolidatedData; return consolidatedData;
...@@ -434,9 +425,8 @@ ...@@ -434,9 +425,8 @@
groupRowHtml(group, isActive) { groupRowHtml(group, isActive) {
const avatarHtml = group.avatar_url ? `<img src='${group.avatar_url}' class='avatar avatar-inline' width='30'>` : ''; const avatarHtml = group.avatar_url ? `<img src='${group.avatar_url}' class='avatar avatar-inline' width='30'>` : '';
const nameHtml = `<strong class='dropdown-menu-group-full-name'>${group.name}</strong>`;
const groupnameHtml = `<span class='dropdown-menu-group-groupname'>${group.name}</span>`; const groupnameHtml = `<span class='dropdown-menu-group-groupname'>${group.name}</span>`;
return `<li><a href='#' class='${isActive ? 'is-active' : ''}'>${avatarHtml} ${nameHtml} ${groupnameHtml}</a></li>`; return `<li><a href='#' class='${isActive ? 'is-active' : ''}'>${avatarHtml} ${groupnameHtml}</a></li>`;
} }
roleRowHtml(role, isActive) { roleRowHtml(role, isActive) {
......
...@@ -69,8 +69,14 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController ...@@ -69,8 +69,14 @@ class Projects::ProtectedBranchesController < Projects::ApplicationController
def access_levels_options def access_levels_options
{ {
push_access_levels: ProtectedBranch::PushAccessLevel.human_access_levels.map { |id, text| { id: id, text: text, before_divider: true } }, push_access_levels: {
merge_access_levels: ProtectedBranch::MergeAccessLevel.human_access_levels.map { |id, text| { id: id, text: text, before_divider: true } } roles: ProtectedBranch::PushAccessLevel.human_access_levels.map { |id, text| { id: id, text: text, before_divider: true } },
},
merge_access_levels: {
roles: ProtectedBranch::MergeAccessLevel.human_access_levels.map { |id, text| { id: id, text: text, before_divider: true } },
},
selected_merge_access_levels: @protected_branch.merge_access_levels.map { |access_level| access_level.user_id || access_level.access_level },
selected_push_access_levels: @protected_branch.push_access_levels.map { |access_level| access_level.user_id || access_level.access_level }
} }
end end
......
---
title: Added headers to protected branches access dropdowns
merge_request:
author:
...@@ -92,6 +92,13 @@ RSpec.shared_examples "protected branches > access control > EE" do ...@@ -92,6 +92,13 @@ RSpec.shared_examples "protected branches > access control > EE" do
within(".protected-branches-list") do within(".protected-branches-list") do
find(".js-allowed-to-#{git_operation}").click find(".js-allowed-to-#{git_operation}").click
find(".dropdown-input-field").set(users.last.name) # Find a user that is not loaded find(".dropdown-input-field").set(users.last.name) # Find a user that is not loaded
expect(page).to have_selector('.dropdown-header', count: 3)
%w{Roles Groups Users}.each_with_index do |header, index|
expect(all('.dropdown-header')[index]).to have_content(header)
end
wait_for_ajax wait_for_ajax
click_on users.last.name click_on users.last.name
find(".js-allowed-to-#{git_operation}").click # close find(".js-allowed-to-#{git_operation}").click # close
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment