Remove nav when empty

This commit is contained in:
Corinne Durrmeyer 2024-08-12 15:12:05 +02:00
parent 5c6eb69c43
commit 480c8f493e
No known key found for this signature in database
GPG key ID: DDC049DDA35585B6
2 changed files with 41 additions and 39 deletions

View file

@ -24,6 +24,7 @@
= render Dossiers::UserProcedureFilterComponent.new(procedures_for_select: @procedures_for_select)
- if @search_terms.blank?
- if [@user_dossiers, @dossiers_traites, @dossiers_invites, @dossiers_close_to_expiration, @dossiers_supprimes, @dossier_transferes].any?(&:present?)
- cache([I18n.locale, current_user.id, @statut, current_user.dossiers, current_user.dossiers_invites], expires_in: 1.hour) do
%nav.fr-tabs{ role: 'navigation', 'aria-label': t('views.users.dossiers.secondary_menu') }
%ul.fr-tabs__list{ role: 'tablist' }
@ -32,6 +33,7 @@
dossiers_path(statut: 'en-cours', procedure_id: params[:procedure_id]),
active: @statut == 'en-cours',
badge: number_with_html_delimiter(@user_dossiers.count))
- if @dossiers_traites.present?
// TODO: when renaming this tab in "Terminé", update notify_near_deletion_to_user email wording accordingly.
= tab_item(t('pluralize.traites', count: @dossiers_traites.count),

View file

@ -113,12 +113,12 @@ describe 'users/dossiers/index', type: :view do
context 'caching', caching: true do
it "works" do
expect(user_dossiers).to receive(:present?).once
expect(user_dossiers).to receive(:present?).thrice
2.times { render; user.reload }
end
it "cache key depends on statut" do
expect(user_dossiers).to receive(:present?).twice
expect(user_dossiers).to receive(:present?).exactly(4).times
render
assign(:statut, "termines")
@ -128,7 +128,7 @@ describe 'users/dossiers/index', type: :view do
end
it "cache key depends on dossier updated_at" do
expect(user_dossiers).to receive(:present?).twice
expect(user_dossiers).to receive(:present?).exactly(4).times
render
dossier_termine.touch
@ -149,7 +149,7 @@ describe 'users/dossiers/index', type: :view do
end
it "cache key depends on dossier invites" do
expect(user_dossiers).to receive(:present?).twice
expect(user_dossiers).to receive(:present?).exactly(4).times
render
create(:invite, user:)
@ -159,7 +159,7 @@ describe 'users/dossiers/index', type: :view do
end
it "cache key depends on dossier deletion" do
expect(user_dossiers).to receive(:present?).twice
expect(user_dossiers).to receive(:present?).exactly(4).times
render
dossier_termine.hide_and_keep_track!(:automatic, :expired)