2018-03-17 18:26:18 +05:30
|
|
|
- breadcrumb_title "General Settings"
|
2017-09-10 17:25:29 +05:30
|
|
|
- page_title "General"
|
|
|
|
- @content_class = "limit-container-width" unless fluid_layout
|
|
|
|
- expanded = Rails.env.test?
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
.project-edit-container
|
2018-11-08 19:23:39 +05:30
|
|
|
%section.settings.general-settings.no-animate#js-general-project-settings{ class: ('expanded' if expanded) }
|
2017-09-10 17:25:29 +05:30
|
|
|
.settings-header
|
|
|
|
%h4
|
2018-11-08 19:23:39 +05:30
|
|
|
General project
|
2018-05-09 12:01:36 +05:30
|
|
|
%button.btn.js-settings-toggle{ type: 'button' }
|
2017-09-10 17:25:29 +05:30
|
|
|
= expanded ? 'Collapse' : 'Expand'
|
|
|
|
%p
|
|
|
|
Update your project name, description, avatar, and other general settings.
|
2018-03-17 18:26:18 +05:30
|
|
|
.settings-content
|
2016-09-13 17:45:13 +05:30
|
|
|
.project-edit-errors
|
2016-06-16 23:09:34 +05:30
|
|
|
= form_for [@project.namespace.becomes(Namespace), @project], remote: true, html: { multipart: true, class: "edit-project" }, authenticity_token: true do |f|
|
2017-08-17 22:00:37 +05:30
|
|
|
%fieldset
|
|
|
|
.row
|
|
|
|
.form-group.col-md-9
|
2018-11-18 11:00:15 +05:30
|
|
|
= f.label :name, class: 'label-bold', for: 'project_name_edit' do
|
2017-08-17 22:00:37 +05:30
|
|
|
Project name
|
|
|
|
= f.text_field :name, class: "form-control", id: "project_name_edit"
|
|
|
|
|
|
|
|
.form-group.col-md-3
|
2018-11-18 11:00:15 +05:30
|
|
|
= f.label :id, class: 'label-bold' do
|
2017-08-17 22:00:37 +05:30
|
|
|
Project ID
|
|
|
|
= f.text_field :id, class: 'form-control', readonly: true
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
.form-group
|
2018-11-18 11:00:15 +05:30
|
|
|
= f.label :description, class: 'label-bold' do
|
2016-06-16 23:09:34 +05:30
|
|
|
Project description
|
|
|
|
%span.light (optional)
|
|
|
|
= f.text_area :description, class: "form-control", rows: 3, maxlength: 250
|
2016-06-02 11:05:42 +05:30
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
= render_if_exists 'projects/classification_policy_settings', f: f
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
- unless @project.empty_repo?
|
2015-04-26 12:48:37 +05:30
|
|
|
.form-group
|
2018-11-18 11:00:15 +05:30
|
|
|
= f.label :default_branch, "Default Branch", class: 'label-bold'
|
2016-06-16 23:09:34 +05:30
|
|
|
= f.select(:default_branch, @project.repository.branch_names, {}, {class: 'select2 select-wide'})
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
= render_if_exists 'shared/repository_size_limit_setting', form: f, type: :project
|
|
|
|
|
2016-06-16 23:09:34 +05:30
|
|
|
.form-group
|
2018-11-18 11:00:15 +05:30
|
|
|
= f.label :tag_list, "Tags", class: 'label-bold'
|
2017-08-17 22:00:37 +05:30
|
|
|
= f.text_field :tag_list, value: @project.tag_list.sort.join(', '), maxlength: 2000, class: "form-control"
|
2018-11-08 19:23:39 +05:30
|
|
|
%p.form-text.text-muted Separate tags with commas.
|
2017-09-10 17:25:29 +05:30
|
|
|
%fieldset.features
|
2018-03-17 18:26:18 +05:30
|
|
|
%h5.prepend-top-0= _("Project avatar")
|
2016-06-16 23:09:34 +05:30
|
|
|
.form-group
|
|
|
|
- if @project.avatar?
|
2018-03-17 18:26:18 +05:30
|
|
|
.avatar-container.s160.append-bottom-15
|
2018-11-18 11:00:15 +05:30
|
|
|
= project_icon(@project.full_path, alt: '', class: 'avatar project-avatar s160', width: 160, height: 160)
|
2018-03-17 18:26:18 +05:30
|
|
|
- if @project.avatar_in_git
|
|
|
|
%p.light
|
|
|
|
= _("Project avatar in repository: %{link}").html_safe % { link: @project.avatar_in_git }
|
|
|
|
.prepend-top-5.append-bottom-10
|
|
|
|
%button.btn.js-choose-project-avatar-button{ type: 'button' }= _("Choose file...")
|
|
|
|
%span.file_name.prepend-left-default.js-avatar-filename= _("No file chosen")
|
|
|
|
= f.file_field :avatar, class: "js-project-avatar-input hidden"
|
2018-11-08 19:23:39 +05:30
|
|
|
.form-text.text-muted= _("The maximum file size allowed is 200KB.")
|
2016-06-16 23:09:34 +05:30
|
|
|
- if @project.avatar?
|
|
|
|
%hr
|
2018-03-17 18:26:18 +05:30
|
|
|
= link_to _('Remove avatar'), project_avatar_path(@project), data: { confirm: _("Avatar will be removed. Are you sure?") }, method: :delete, class: "btn btn-danger btn-inverted"
|
2018-03-27 19:54:05 +05:30
|
|
|
= f.submit 'Save changes', class: "btn btn-success js-btn-save-general-project-settings"
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
%section.settings.sharing-permissions.no-animate#js-shared-permissions{ class: ('expanded' if expanded) }
|
2017-09-10 17:25:29 +05:30
|
|
|
.settings-header
|
|
|
|
%h4
|
2018-03-17 18:26:18 +05:30
|
|
|
Permissions
|
2018-05-09 12:01:36 +05:30
|
|
|
%button.btn.js-settings-toggle{ type: 'button' }
|
2017-09-10 17:25:29 +05:30
|
|
|
= expanded ? 'Collapse' : 'Expand'
|
|
|
|
%p
|
|
|
|
Enable or disable certain project features and choose access levels.
|
2018-03-17 18:26:18 +05:30
|
|
|
.settings-content
|
2017-09-10 17:25:29 +05:30
|
|
|
= form_for [@project.namespace.becomes(Namespace), @project], remote: true, html: { multipart: true, class: "sharing-permissions-form" }, authenticity_token: true do |f|
|
2018-03-27 19:54:05 +05:30
|
|
|
-# haml-lint:disable InlineJavaScript
|
2018-03-17 18:26:18 +05:30
|
|
|
%script.js-project-permissions-form-data{ type: "application/json" }= project_permissions_panel_data(@project)
|
|
|
|
.js-project-permissions-form
|
2017-09-10 17:25:29 +05:30
|
|
|
= f.submit 'Save changes', class: "btn btn-save"
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
= render_if_exists 'projects/issues_settings'
|
|
|
|
|
|
|
|
%section.qa-merge-request-settings.settings.merge-requests-feature.no-animate#js-merge-request-settings{ class: [('expanded' if expanded), ('hidden' if @project.project_feature.send(:merge_requests_access_level) == 0)] }
|
2017-09-10 17:25:29 +05:30
|
|
|
.settings-header
|
|
|
|
%h4
|
2018-11-08 19:23:39 +05:30
|
|
|
Merge request
|
2018-05-09 12:01:36 +05:30
|
|
|
%button.btn.js-settings-toggle{ type: 'button' }
|
2017-09-10 17:25:29 +05:30
|
|
|
= expanded ? 'Collapse' : 'Expand'
|
|
|
|
%p
|
|
|
|
Customize your merge request restrictions.
|
2018-03-17 18:26:18 +05:30
|
|
|
.settings-content
|
2018-11-08 19:23:39 +05:30
|
|
|
= render_if_exists 'shared/promotions/promote_mr_features'
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
= form_for [@project.namespace.becomes(Namespace), @project], remote: true, html: { multipart: true, class: "merge-request-settings-form" }, authenticity_token: true do |f|
|
2018-11-08 19:23:39 +05:30
|
|
|
= render 'projects/merge_request_settings', form: f
|
2018-03-27 19:54:05 +05:30
|
|
|
= f.submit 'Save changes', class: "btn btn-save qa-save-merge-request-changes"
|
2017-09-10 17:25:29 +05:30
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
= render_if_exists 'projects/service_desk_settings'
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
= render 'export', project: @project
|
2017-09-10 17:25:29 +05:30
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
%section.qa-advanced-settings.settings.advanced-settings.no-animate#js-project-advanced-settings{ class: ('expanded' if expanded) }
|
2017-09-10 17:25:29 +05:30
|
|
|
.settings-header
|
|
|
|
%h4
|
2018-11-08 19:23:39 +05:30
|
|
|
Advanced
|
2018-05-09 12:01:36 +05:30
|
|
|
%button.btn.js-settings-toggle{ type: 'button' }
|
2017-09-10 17:25:29 +05:30
|
|
|
= expanded ? 'Collapse' : 'Expand'
|
|
|
|
%p
|
2018-03-17 18:26:18 +05:30
|
|
|
Perform advanced options such as housekeeping, archiving, renaming, transferring, or removing your project.
|
|
|
|
.settings-content
|
2017-09-10 17:25:29 +05:30
|
|
|
.sub-section
|
|
|
|
%h4 Housekeeping
|
|
|
|
%p
|
|
|
|
Runs a number of housekeeping tasks within the current repository, such as compressing file revisions and removing unreachable objects.
|
|
|
|
= link_to 'Run housekeeping', housekeeping_project_path(@project),
|
|
|
|
method: :post, class: "btn btn-default"
|
|
|
|
- if can? current_user, :archive_project, @project
|
|
|
|
.sub-section
|
|
|
|
%h4.warning-title
|
|
|
|
- if @project.archived?
|
|
|
|
Unarchive project
|
|
|
|
- else
|
|
|
|
Archive project
|
2016-06-16 23:09:34 +05:30
|
|
|
- if @project.archived?
|
2017-09-10 17:25:29 +05:30
|
|
|
%p
|
2018-05-09 12:01:36 +05:30
|
|
|
Unarchiving the project will restore people's ability to make changes to it.
|
|
|
|
The repository can be committed to, and issues, comments and other entities can be created.
|
2017-09-10 17:25:29 +05:30
|
|
|
%strong Once active this project shows up in the search and on the dashboard.
|
|
|
|
= link_to 'Unarchive project', unarchive_project_path(@project),
|
2018-05-09 12:01:36 +05:30
|
|
|
data: { confirm: "Are you sure that you want to unarchive this project?" },
|
2017-09-10 17:25:29 +05:30
|
|
|
method: :post, class: "btn btn-success"
|
2016-06-16 23:09:34 +05:30
|
|
|
- else
|
2017-09-10 17:25:29 +05:30
|
|
|
%p
|
2018-05-09 12:01:36 +05:30
|
|
|
Archiving the project will make it entirely read-only. It is hidden from the dashboard and doesn't show up in searches.
|
|
|
|
%strong The repository cannot be committed to, and no issues, comments or other entities can be created.
|
2017-09-10 17:25:29 +05:30
|
|
|
= link_to 'Archive project', archive_project_path(@project),
|
2018-05-09 12:01:36 +05:30
|
|
|
data: { confirm: "Are you sure that you want to archive this project?" },
|
2017-09-10 17:25:29 +05:30
|
|
|
method: :post, class: "btn btn-warning"
|
|
|
|
.sub-section.rename-respository
|
|
|
|
%h4.warning-title
|
|
|
|
Rename repository
|
|
|
|
= render 'projects/errors'
|
|
|
|
= form_for([@project.namespace.becomes(Namespace), @project]) do |f|
|
|
|
|
.form-group.project_name_holder
|
2018-11-18 11:00:15 +05:30
|
|
|
= f.label :name, class: 'label-bold' do
|
2017-09-10 17:25:29 +05:30
|
|
|
Project name
|
|
|
|
.form-group
|
|
|
|
= f.text_field :name, class: "form-control"
|
2016-06-16 23:09:34 +05:30
|
|
|
.form-group
|
2018-11-18 11:00:15 +05:30
|
|
|
= f.label :path, class: 'label-bold' do
|
2017-09-10 17:25:29 +05:30
|
|
|
%span Path
|
2016-06-16 23:09:34 +05:30
|
|
|
.form-group
|
2017-09-10 17:25:29 +05:30
|
|
|
.input-group
|
2018-11-08 19:23:39 +05:30
|
|
|
.input-group-prepend
|
|
|
|
.input-group-text
|
|
|
|
#{URI.join(root_url, @project.namespace.full_path)}/
|
2017-09-10 17:25:29 +05:30
|
|
|
= f.text_field :path, class: 'form-control'
|
2016-06-16 23:09:34 +05:30
|
|
|
%ul
|
2017-09-10 17:25:29 +05:30
|
|
|
%li Be careful. Renaming a project's repository can have unintended side effects.
|
2016-06-16 23:09:34 +05:30
|
|
|
%li You will need to update your local repositories to point to the new location.
|
2018-03-17 18:26:18 +05:30
|
|
|
- if @project.deployment_platform.present?
|
2017-09-10 17:25:29 +05:30
|
|
|
%li Your deployment services will be broken, you will need to manually fix the services after renaming.
|
|
|
|
= f.submit 'Rename project', class: "btn btn-warning"
|
|
|
|
- if can?(current_user, :change_namespace, @project)
|
|
|
|
.sub-section
|
|
|
|
%h4.danger-title
|
|
|
|
Transfer project
|
|
|
|
= form_for([@project.namespace.becomes(Namespace), @project], url: transfer_project_path(@project), method: :put, remote: true, html: { class: 'js-project-transfer-form' } ) do |f|
|
|
|
|
.form-group
|
2018-11-18 11:00:15 +05:30
|
|
|
= label_tag :new_namespace_id, nil, class: 'label-bold' do
|
2017-09-10 17:25:29 +05:30
|
|
|
%span Select a new namespace
|
|
|
|
.form-group
|
|
|
|
= select_tag :new_namespace_id, namespaces_options(nil), include_blank: true, class: 'select2'
|
|
|
|
%ul
|
|
|
|
%li Be careful. Changing the project's namespace can have unintended side effects.
|
|
|
|
%li You can only transfer the project to namespaces you manage.
|
|
|
|
%li You will need to update your local repositories to point to the new location.
|
|
|
|
%li Project visibility level will be changed to match namespace rules when transferring to a group.
|
|
|
|
= f.submit 'Transfer project', class: "btn btn-remove js-confirm-danger", data: { "confirm-danger-message" => transfer_project_message(@project) }
|
|
|
|
- if @project.forked? && can?(current_user, :remove_fork_project, @project)
|
|
|
|
.sub-section
|
|
|
|
%h4.danger-title
|
|
|
|
Remove fork relationship
|
2016-06-16 23:09:34 +05:30
|
|
|
%p
|
|
|
|
This will remove the fork relationship to source project
|
|
|
|
= succeed "." do
|
2018-03-17 18:26:18 +05:30
|
|
|
- if @project.fork_source
|
|
|
|
= link_to(fork_source_name(@project), project_path(@project.fork_source))
|
|
|
|
- else
|
|
|
|
= fork_source_name(@project)
|
2017-09-10 17:25:29 +05:30
|
|
|
= form_for([@project.namespace.becomes(Namespace), @project], url: remove_fork_project_path(@project), method: :delete, remote: true, html: { class: 'transfer-project' }) do |f|
|
|
|
|
%p
|
|
|
|
%strong Once removed, the fork relationship cannot be restored and you will no longer be able to send merge requests to the source.
|
|
|
|
= button_to 'Remove fork relationship', '#', class: "btn btn-remove js-confirm-danger", data: { "confirm-danger-message" => remove_fork_project_message(@project) }
|
|
|
|
- if can?(current_user, :remove_project, @project)
|
|
|
|
.sub-section
|
|
|
|
%h4.danger-title
|
|
|
|
Remove project
|
2016-06-16 23:09:34 +05:30
|
|
|
%p
|
2017-09-10 17:25:29 +05:30
|
|
|
Removing the project will delete its repository and all related resources including issues, merge requests etc.
|
|
|
|
= form_tag(project_path(@project), method: :delete) do
|
|
|
|
%p
|
|
|
|
%strong Removed projects cannot be restored!
|
|
|
|
= button_to 'Remove project', '#', class: "btn btn-remove js-confirm-danger", data: { "confirm-danger-message" => remove_project_message(@project) }
|
2014-09-02 18:07:02 +05:30
|
|
|
|
|
|
|
.save-project-loader.hide
|
|
|
|
.center
|
|
|
|
%h2
|
2015-04-26 12:48:37 +05:30
|
|
|
%i.fa.fa-spinner.fa-spin
|
2014-09-02 18:07:02 +05:30
|
|
|
Saving project.
|
|
|
|
%p Please wait a moment, this page will automatically refresh when ready.
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
= render 'shared/confirm_modal', phrase: @project.path
|