debian-mirror-gitlab/app/views/layouts/header/_default.html.haml

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

175 lines
12 KiB
Text
Raw Normal View History

2019-12-04 20:38:33 +05:30
- has_impersonation_link = header_link?(:admin_impersonation)
2021-01-29 00:20:46 +05:30
- user_status_data = user_status_properties(current_user)
2018-11-20 20:47:30 +05:30
2019-09-30 21:07:59 +05:30
%header.navbar.navbar-gitlab.navbar-expand-sm.js-navbar{ data: { qa_selector: 'navbar' } }
2021-04-29 21:17:54 +05:30
%a.gl-sr-only.gl-accessibility{ href: "#content-body" } Skip to content
2017-08-17 22:00:37 +05:30
.container-fluid
2022-07-16 23:28:13 +05:30
.header-content.js-header-content
2022-10-11 01:57:18 +05:30
.title-container.hide-when-top-nav-responsive-open.gl-transition-medium.gl-display-flex.gl-align-items-stretch.gl-pt-0.gl-mr-3
2022-07-23 23:45:48 +05:30
.title
2020-06-23 00:09:42 +05:30
%span.gl-sr-only GitLab
2022-08-27 11:52:29 +05:30
= link_to root_path, title: _('Dashboard'), id: 'logo', class: 'has-tooltip', **tracking_attrs('main_navigation', 'click_gitlab_logo_link', 'navigation') do
2022-07-23 23:45:48 +05:30
= brand_header_logo
2022-10-11 01:57:18 +05:30
.gl-display-flex.gl-align-items-center
2019-12-26 22:10:19 +05:30
- if Gitlab.com_and_canary?
2022-10-11 01:57:18 +05:30
= gl_badge_tag({ variant: :success, size: :sm }, { href: Gitlab::Saas.canary_toggle_com_url, data: { qa_selector: 'canary_badge_link' }, target: :_blank, rel: 'noopener noreferrer', class: 'canary-badge' }) do
= _('Next')
2017-08-17 22:00:37 +05:30
2022-03-02 08:16:31 +05:30
- if current_user
.gl-display-none.gl-sm-display-block
= render "layouts/nav/top_nav"
- else
- experiment(:logged_out_marketing_header, actor: nil) do |e|
- e.candidate do
= render 'layouts/header/marketing_links'
- e.try(:trial_focused) do
= render 'layouts/header/marketing_links'
- e.control do
.gl-display-none.gl-sm-display-block
= render "layouts/nav/top_nav"
2015-09-11 14:41:01 +05:30
2022-10-11 01:57:18 +05:30
- if top_nav_show_search && Feature.enabled?(:new_navbar_layout)
.navbar-collapse.gl-transition-medium.collapse.gl-mr-auto.global-search-container.hide-when-top-nav-responsive-open
- search_menu_item = top_nav_search_menu_item_attrs
%ul.nav.navbar-nav.gl-w-full.gl-align-items-center
%li.nav-item.header-search-new.gl-display-none.gl-lg-display-block.gl-w-full
- unless current_controller?(:search)
- if Feature.enabled?(:new_header_search)
= render 'layouts/header_search'
- else
= render 'layouts/search'
%li.nav-item{ class: 'd-none d-sm-inline-block d-lg-none' }
= link_to search_menu_item.fetch(:href), title: search_menu_item.fetch(:title), aria: { label: search_menu_item.fetch(:title) }, data: {toggle: 'tooltip', placement: 'bottom', container: 'body'} do
= sprite_icon(search_menu_item.fetch(:icon))
.navbar-collapse.gl-transition-medium.collapse{ class: ('global-search-container' unless Feature.enabled?(:new_navbar_layout)) }
2022-07-23 23:45:48 +05:30
%ul.nav.navbar-nav.gl-w-full.gl-align-items-center.gl-justify-content-end
2018-03-17 18:26:18 +05:30
- if current_user
2022-07-16 23:28:13 +05:30
= render 'layouts/header/new_dropdown', class: 'gl-display-none gl-sm-display-block gl-white-space-nowrap gl-text-right'
2022-10-11 01:57:18 +05:30
- if top_nav_show_search && Feature.disabled?(:new_navbar_layout)
2021-09-04 01:27:46 +05:30
- search_menu_item = top_nav_search_menu_item_attrs
2022-07-23 23:45:48 +05:30
%li.nav-item.header-search-new.gl-display-none.gl-lg-display-block.gl-w-full
2021-11-11 11:23:49 +05:30
- unless current_controller?(:search)
2022-07-16 23:28:13 +05:30
- if Feature.enabled?(:new_header_search)
2022-05-07 20:08:51 +05:30
= render 'layouts/header_search'
2021-11-11 11:23:49 +05:30
- else
= render 'layouts/search'
2021-10-27 15:23:28 +05:30
%li.nav-item{ class: 'd-none d-sm-inline-block d-lg-none' }
2021-09-04 01:27:46 +05:30
= link_to search_menu_item.fetch(:href), title: search_menu_item.fetch(:title), aria: { label: search_menu_item.fetch(:title) }, data: {toggle: 'tooltip', placement: 'bottom', container: 'body'} do
= sprite_icon(search_menu_item.fetch(:icon))
2018-03-27 19:54:05 +05:30
- if header_link?(:issues)
2018-03-17 18:26:18 +05:30
= nav_link(path: 'dashboard#issues', html_options: { class: "user-counter" }) do
2022-01-26 12:08:38 +05:30
= link_to assigned_issues_dashboard_path, title: _('Issues'), class: 'dashboard-shortcuts-issues js-prefetch-document', aria: { label: _('Issues') },
2020-10-24 23:57:45 +05:30
data: { qa_selector: 'issues_shortcut_button', toggle: 'tooltip', placement: 'bottom',
track_label: 'main_navigation',
2021-11-11 11:23:49 +05:30
track_action: 'click_issues_link',
2020-10-24 23:57:45 +05:30
track_property: 'navigation',
container: 'body' } do
= sprite_icon('issues')
2017-08-17 22:00:37 +05:30
- issues_count = assigned_issuables_count(:issues)
2022-04-04 11:22:00 +05:30
= gl_badge_tag({ size: :sm, variant: :success }, { class: "gl-ml-n2 #{(' gl-display-none' if issues_count == 0)}", "aria-label": n_("%d assigned issue", "%d assigned issues", issues_count) % issues_count }) do
2017-08-17 22:00:37 +05:30
= number_with_delimiter(issues_count)
2018-03-27 19:54:05 +05:30
- if header_link?(:merge_requests)
2021-03-11 19:13:27 +05:30
= nav_link(path: 'dashboard#merge_requests', html_options: { class: "user-counter dropdown" }) do
2022-08-27 11:52:29 +05:30
- top_level_link = assigned_mrs_dashboard_path
= link_to top_level_link, class: 'dashboard-shortcuts-merge_requests has-tooltip', title: _('Merge requests'), aria: { label: _('Merge requests') },
2021-03-08 18:12:59 +05:30
data: { qa_selector: 'merge_requests_shortcut_button',
2021-03-11 19:13:27 +05:30
toggle: "dropdown",
2021-03-08 18:12:59 +05:30
placement: 'bottom',
2020-10-24 23:57:45 +05:30
track_label: 'main_navigation',
2021-11-11 11:23:49 +05:30
track_action: 'click_merge_link',
2020-10-24 23:57:45 +05:30
track_property: 'navigation',
container: 'body' } do
= sprite_icon('git-merge')
2022-04-04 11:22:00 +05:30
= gl_badge_tag({ size: :sm, variant: :warning }, { class: "js-merge-requests-count gl-ml-n2#{(' gl-display-none' if user_merge_requests_counts[:total] == 0)}", "aria-label": n_("%d merge request", "%d merge requests", user_merge_requests_counts[:total]) % user_merge_requests_counts[:total] }) do
2021-03-08 18:12:59 +05:30
= number_with_delimiter(user_merge_requests_counts[:total])
2021-03-11 19:13:27 +05:30
= sprite_icon('chevron-down', css_class: 'caret-down gl-mx-0!')
.dropdown-menu.dropdown-menu-right
%ul
%li.dropdown-header
= _('Merge requests')
%li
2022-01-26 12:08:38 +05:30
= link_to assigned_mrs_dashboard_path, class: 'gl-display-flex! gl-align-items-center js-prefetch-document' do
2022-08-27 11:52:29 +05:30
= _('Assigned to you')
2022-04-04 11:22:00 +05:30
= gl_badge_tag({ variant: :neutral, size: :sm }, { class: "js-assigned-mr-count gl-ml-auto" }) do
2021-03-11 19:13:27 +05:30
= user_merge_requests_counts[:assigned]
%li
2022-01-26 12:08:38 +05:30
= link_to reviewer_mrs_dashboard_path, class: 'gl-display-flex! gl-align-items-center js-prefetch-document' do
2022-08-27 11:52:29 +05:30
= _('Review requests for you')
2022-04-04 11:22:00 +05:30
= gl_badge_tag({ variant: :neutral, size: :sm }, { class: "js-reviewer-mr-count gl-ml-auto" }) do
2021-03-11 19:13:27 +05:30
= user_merge_requests_counts[:review_requested]
2018-03-27 19:54:05 +05:30
- if header_link?(:todos)
2018-03-17 18:26:18 +05:30
= nav_link(controller: 'dashboard/todos', html_options: { class: "user-counter" }) do
2022-01-26 12:08:38 +05:30
= link_to dashboard_todos_path, title: _('To-Do List'), aria: { label: _('To-Do List') }, class: 'shortcuts-todos js-prefetch-document',
2020-10-24 23:57:45 +05:30
data: { qa_selector: 'todos_shortcut_button', toggle: 'tooltip', placement: 'bottom',
track_label: 'main_navigation',
2021-11-11 11:23:49 +05:30
track_action: 'click_to_do_link',
2020-10-24 23:57:45 +05:30
track_property: 'navigation',
container: 'body' } do
= sprite_icon('todo-done')
2022-04-04 11:22:00 +05:30
-# The todos' counter badge's visibility is being toggled by adding or removing the .hidden class in Js.
-# We'll eventually migrate to .gl-display-none: https://gitlab.com/gitlab-org/gitlab/-/issues/351792.
= gl_badge_tag({ size: :sm, variant: :info }, { class: "js-todos-count gl-ml-n2#{(' hidden' if todos_pending_count == 0)}", "aria-label": _("Todos count") }) do
2017-08-17 22:00:37 +05:30
= todos_count_format(todos_pending_count)
2022-04-04 11:22:00 +05:30
%li.nav-item.header-help.dropdown.d-none.d-md-block{ data: { track_action: 'click_question_mark_link', track_label: 'main_navigation', track_property: 'navigation', track_experiment: 'cross_stage_fdm' } }
2022-01-26 12:08:38 +05:30
= link_to help_path, class: 'header-help-dropdown-toggle gl-relative', data: { toggle: "dropdown" } do
2020-06-23 00:09:42 +05:30
%span.gl-sr-only
= s_('Nav|Help')
2021-06-08 01:23:25 +05:30
= sprite_icon('question-o')
2021-02-22 17:27:13 +05:30
%span.notification-dot.rounded-circle.gl-absolute
2021-01-03 14:25:43 +05:30
= sprite_icon('chevron-down', css_class: 'caret-down')
2018-12-13 13:39:08 +05:30
.dropdown-menu.dropdown-menu-right
= render 'layouts/header/help_dropdown'
2022-03-02 08:16:31 +05:30
- unless current_user
- experiment(:logged_out_marketing_header, actor: nil) do |e|
- e.candidate do
%li.nav-item.gl-display-none.gl-sm-display-block
= render "layouts/nav/top_nav"
- e.try(:trial_focused) do
%li.nav-item.gl-display-none.gl-sm-display-block
= render "layouts/nav/top_nav"
- e.control {}
2018-03-27 19:54:05 +05:30
- if header_link?(:user_dropdown)
2022-10-11 01:57:18 +05:30
%li.nav-item.header-user.js-nav-user-dropdown.dropdown{ data: { track_label: "profile_dropdown", track_action: "click_dropdown", track_value: "", qa_selector: 'user_menu', testid: 'user-menu' }, class: ('mr-0' if has_impersonation_link) }
2018-03-17 18:26:18 +05:30
= link_to current_user, class: user_dropdown_class, data: { toggle: "dropdown" } do
2020-06-23 00:09:42 +05:30
= image_tag avatar_icon_for_user(current_user, 23), width: 23, height: 23, class: "header-user-avatar qa-user-avatar", alt: current_user.name
2020-04-22 19:07:51 +05:30
= render_if_exists 'layouts/header/user_notification_dot', project: project, namespace: group
2021-01-03 14:25:43 +05:30
= sprite_icon('chevron-down', css_class: 'caret-down')
2018-11-08 19:23:39 +05:30
.dropdown-menu.dropdown-menu-right
2018-10-15 14:42:47 +05:30
= render 'layouts/header/current_user_dropdown'
2019-12-04 20:38:33 +05:30
- if has_impersonation_link
%li.nav-item.impersonation.ml-0
2019-12-21 20:55:43 +05:30
= link_to admin_impersonation_path, class: 'nav-link impersonation-btn', method: :delete, title: _('Stop impersonation'), aria: { label: _('Stop impersonation') }, data: { toggle: 'tooltip', placement: 'bottom', container: 'body', qa_selector: 'stop_impersonation_link' } do
2020-11-24 15:15:51 +05:30
= sprite_icon('incognito', size: 18)
2018-03-27 19:54:05 +05:30
- if header_link?(:sign_in)
2022-03-02 08:16:31 +05:30
- experiment(:logged_out_marketing_header, actor: nil) do |e|
- e.candidate do
%li.nav-item.gl-display-none.gl-sm-display-block
2022-04-04 11:22:00 +05:30
= link_to _('Sign up now'), new_user_registration_path, class: 'gl-button btn btn-default btn-sign-in', data: { track_action: 'click_button', track_experiment: e.name, track_label: 'sign_up_now' }
2022-03-02 08:16:31 +05:30
%li.nav-item.gl-display-none.gl-sm-display-block
= link_to _('Login'), new_session_path(:user, redirect_to_referer: 'yes')
= render 'layouts/header/sign_in_register_button', class: 'gl-sm-display-none'
- e.try(:trial_focused) do
%li.nav-item.gl-display-none.gl-sm-display-block
2022-04-04 11:22:00 +05:30
= link_to _('Get a free trial'), 'https://about.gitlab.com/free-trial/', class: 'gl-button btn btn-default btn-sign-in', data: { track_action: 'click_button', track_experiment: e.name, track_label: 'get_a_free_trial' }
2022-03-02 08:16:31 +05:30
%li.nav-item.gl-display-none.gl-sm-display-block
2022-04-04 11:22:00 +05:30
= link_to _('Sign up'), new_user_registration_path, data: { track_action: 'click_button', track_experiment: e.name, track_label: 'sign_up' }
2022-03-02 08:16:31 +05:30
%li.nav-item.gl-display-none.gl-sm-display-block
= link_to _('Login'), new_session_path(:user, redirect_to_referer: 'yes')
= render 'layouts/header/sign_in_register_button', class: 'gl-sm-display-none'
- e.control do
= render 'layouts/header/sign_in_register_button'
2018-11-18 11:00:15 +05:30
2021-12-11 22:18:48 +05:30
%button.navbar-toggler.d-block.d-sm-none{ type: 'button', class: 'gl-border-none!', data: { testid: 'top-nav-responsive-toggle', qa_selector: 'mobile_navbar_button' } }
2018-11-20 20:47:30 +05:30
%span.sr-only= _('Toggle navigation')
2021-10-27 15:23:28 +05:30
%span.more-icon.gl-px-3.gl-font-sm.gl-font-weight-bold
%span.gl-pr-2= _('Menu')
= sprite_icon('hamburger', size: 16)
2021-09-04 01:27:46 +05:30
= sprite_icon('close', size: 12, css_class: 'close-icon')
2018-12-05 23:21:45 +05:30
2021-04-29 21:17:54 +05:30
- if display_whats_new?
#whats-new-app{ data: { version_digest: whats_new_version_digest } }
2020-10-24 23:57:45 +05:30
2018-12-05 23:21:45 +05:30
- if can?(current_user, :update_user_status, current_user)
2021-01-29 00:20:46 +05:30
.js-set-status-modal-wrapper{ data: user_status_data }