summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
Diffstat (limited to 'app')
-rw-r--r--app/controllers/projects/settings/repository_controller.rb23
-rw-r--r--app/helpers/repository_helper.rb5
-rw-r--r--app/presenters/projects/settings/deploy_keys_presenter.rb15
-rw-r--r--app/views/projects/deploy_keys/_index.html.haml9
4 files changed, 29 insertions, 23 deletions
diff --git a/app/controllers/projects/settings/repository_controller.rb b/app/controllers/projects/settings/repository_controller.rb
index 3c9417b9270..7a1edee0822 100644
--- a/app/controllers/projects/settings/repository_controller.rb
+++ b/app/controllers/projects/settings/repository_controller.rb
@@ -1,8 +1,6 @@
module Projects
module Settings
class RepositoryController < Projects::ApplicationController
- include RepositoryHelper
-
before_action :authorize_admin_project!
def show
@@ -23,6 +21,27 @@ module Projects
def load_protected_branches
@protected_branches = @project.protected_branches.order(:name).page(params[:page])
end
+
+ def access_levels_options
+ {
+ push_access_levels: {
+ "Roles" => ProtectedBranch::PushAccessLevel.human_access_levels.map do |id, text|
+ { id: id, text: text, before_divider: true }
+ end
+ },
+ merge_access_levels: {
+ "Roles" => ProtectedBranch::MergeAccessLevel.human_access_levels.map do |id, text|
+ { id: id, text: text, before_divider: true }
+ end
+ }
+ }
+ end
+
+ def load_gon_index
+ open_branches = @project.open_branches.map { |br| { text: br.name, id: br.name, title: br.name } }
+ params = { open_branches: open_branches }
+ gon.push(params.merge(access_levels_options))
+ end
end
end
end
diff --git a/app/helpers/repository_helper.rb b/app/helpers/repository_helper.rb
index e34f9338b54..cd0ca3f9450 100644
--- a/app/helpers/repository_helper.rb
+++ b/app/helpers/repository_helper.rb
@@ -15,9 +15,8 @@ module RepositoryHelper
end
def load_gon_index
- params = { open_branches: @project.open_branches.map do |br|
- { text: br.name, id: br.name, title: br.name }
- end }
+ open_branches = @project.open_branches.map { |br| { text: br.name, id: br.name, title: br.name } }
+ params = { open_branches: open_branches }
gon.push(params.merge(access_levels_options))
end
end
diff --git a/app/presenters/projects/settings/deploy_keys_presenter.rb b/app/presenters/projects/settings/deploy_keys_presenter.rb
index 25be14bd28b..86ac513b3c0 100644
--- a/app/presenters/projects/settings/deploy_keys_presenter.rb
+++ b/app/presenters/projects/settings/deploy_keys_presenter.rb
@@ -2,6 +2,9 @@ module Projects
module Settings
class DeployKeysPresenter < Gitlab::View::Presenter::Simple
presents :project
+ delegate :size, to: :enabled_keys, prefix: true
+ delegate :size, to: :available_project_keys, prefix: true
+ delegate :size, to: :available_public_keys, prefix: true
def new_key
@key ||= DeployKey.new
@@ -15,10 +18,6 @@ module Projects
enabled_keys.any?
end
- def enabled_keys_size
- enabled_keys.size
- end
-
def available_keys
@available_keys ||= current_user.accessible_deploy_keys - enabled_keys
end
@@ -31,10 +30,6 @@ module Projects
available_project_keys.any?
end
- def available_project_keys_size
- available_project_keys.size
- end
-
def key_available?(deploy_key)
available_keys.include?(deploy_key)
end
@@ -53,10 +48,6 @@ module Projects
available_public_keys.any?
end
- def available_public_keys_size
- available_public_keys.size
- end
-
def to_partial_path
'projects/deploy_keys/index'
end
diff --git a/app/views/projects/deploy_keys/_index.html.haml b/app/views/projects/deploy_keys/_index.html.haml
index 9f351d3b90e..0cbe9b3275a 100644
--- a/app/views/projects/deploy_keys/_index.html.haml
+++ b/app/views/projects/deploy_keys/_index.html.haml
@@ -15,8 +15,7 @@
Enabled deploy keys for this project (#{@deploy_keys.enabled_keys_size})
- if @deploy_keys.any_keys_enabled?
%ul.well-list
- - @deploy_keys.enabled_keys.each do |enabled_key|
- = render partial: 'projects/deploy_keys/deploy_key', locals: {deploy_key: enabled_key}
+ = render partial: 'projects/deploy_keys/deploy_key', collection: @deploy_keys.enabled_keys, as: :deploy_key
- else
.settings-message.text-center
No deploy keys found. Create one with the form above.
@@ -24,8 +23,7 @@
Deploy keys from projects you have access to (#{@deploy_keys.available_project_keys_size})
- if @deploy_keys.any_available_project_keys_enabled?
%ul.well-list
- - @deploy_keys.available_project_keys.each do |available_key|
- = render partial: 'projects/deploy_keys/deploy_key', locals: {deploy_key: available_key}
+ = render partial: 'projects/deploy_keys/deploy_key', collection: @deploy_keys.available_project_keys, as: :deploy_key
- else
.settings-message.text-center
No deploy keys from your projects could be found. Create one with the form above or add existing one below.
@@ -33,5 +31,4 @@
%h5.prepend-top-default
Public deploy keys available to any project (#{@deploy_keys.available_public_keys_size})
%ul.well-list
- - @deploy_keys.available_public_keys.each do |available_key|
- = render partial: 'projects/deploy_keys/deploy_key', locals: {deploy_key: available_key}
+ = render partial: 'projects/deploy_keys/deploy_key', collection: @deploy_keys.available_public_keys, as: :deploy_key