Commit 167af35e authored by Nicolò Maria Mezzopera's avatar Nicolò Maria Mezzopera

Merge branch '230757-tabs-haml-migrate-milestones_filter-html-haml' into 'master'

Migrate milestone filter Bootstrap tabs to GlTabs

See merge request gitlab-org/gitlab!71710
parents 11b002b9 b04efb9b
...@@ -78,19 +78,6 @@ module TimeboxesHelper ...@@ -78,19 +78,6 @@ module TimeboxesHelper
end end
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
# Show 'active' class if provided GET param matches check
# `or_blank` allows the function to return 'active' when given an empty param
# Could be refactored to be simpler but that may make it harder to read
def milestone_class_for_state(param, check, match_blank_param = false)
if match_blank_param
'active' if param.blank? || param == check
elsif param == check
'active'
else
check
end
end
def milestone_progress_tooltip_text(milestone) def milestone_progress_tooltip_text(milestone)
has_issues = milestone.total_issues_count > 0 has_issues = milestone.total_issues_count > 0
......
%ul.nav-links.mobile-separator.nav.nav-tabs - count_badge_classes = 'badge badge-muted badge-pill gl-badge gl-tab-counter-badge sm gl-display-none gl-sm-display-inline-flex'
%li{ class: milestone_class_for_state(params[:state], 'opened', true) }>
= link_to milestones_filter_path(state: 'opened') do = gl_tabs_nav( {class: 'gl-border-b-0 gl-flex-grow-1', data: { testid: 'milestones-filter' } } ) do
= gl_tab_link_to milestones_filter_path(state: 'opened'), { item_active: params[:state].blank? || params[:state] == 'opened' } do
= _('Open') = _('Open')
%span.badge.badge-pill= counts[:opened] %span{ class: count_badge_classes }
%li{ class: milestone_class_for_state(params[:state], 'closed') }> = counts[:opened]
= link_to milestones_filter_path(state: 'closed', sort: 'due_date_desc') do = gl_tab_link_to milestones_filter_path(state: 'closed', sort: 'due_date_desc'), { item_active: params[:state] == 'closed' } do
= _('Closed') = _('Closed')
%span.badge.badge-pill= counts[:closed] %span{ class: count_badge_classes }
%li{ class: milestone_class_for_state(params[:state], 'all') }> = counts[:closed]
= link_to milestones_filter_path(state: 'all', sort: 'due_date_desc') do = gl_tab_link_to milestones_filter_path(state: 'all', sort: 'due_date_desc'), { item_active: params[:state] == 'all' } do
= _('All') = _('All')
%span.badge.badge-pill= counts[:all] %span{ class: count_badge_classes }
= counts[:all]
...@@ -65,11 +65,12 @@ RSpec.describe Dashboard::MilestonesController do ...@@ -65,11 +65,12 @@ RSpec.describe Dashboard::MilestonesController do
expect(response.body).not_to include(project_milestone.title) expect(response.body).not_to include(project_milestone.title)
end end
it 'shows counts of open and closed group and project milestones to which the user belongs to' do it 'shows counts of open/closed/all group and project milestones to which the user belongs to' do
get :index get :index
expect(response.body).to include("Open\n<span class=\"badge badge-pill\">2</span>") expect(response.body).to have_content('Open 2')
expect(response.body).to include("Closed\n<span class=\"badge badge-pill\">2</span>") expect(response.body).to have_content('Closed 2')
expect(response.body).to have_content('All 4')
end end
context 'external authorization' do context 'external authorization' do
......
...@@ -98,9 +98,11 @@ RSpec.describe 'Group milestones' do ...@@ -98,9 +98,11 @@ RSpec.describe 'Group milestones' do
end end
it 'counts milestones correctly' do it 'counts milestones correctly' do
expect(find('.top-area .active .badge').text).to eq("3") page.within '[data-testid="milestones-filter"]' do
expect(find('.top-area .closed .badge').text).to eq("3") expect(page).to have_content('Open 3')
expect(find('.top-area .all .badge').text).to eq("6") expect(page).to have_content('Closed 3')
expect(page).to have_content('All 6')
end
end end
it 'lists group and project milestones' do it 'lists group and project milestones' do
......
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