Merge pull request #9936 from colinux/badge-corrige

ETQ instructeur, je vois un badge Corrigé lorsque le dossier a été corrigé
This commit is contained in:
Colin Darie 2024-01-29 08:57:54 +00:00 committed by GitHub
commit c02171ede7
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
7 changed files with 35 additions and 4 deletions

View file

@ -103,8 +103,8 @@ module DossierHelper
tag.span(Dossier.human_attribute_name("pending_correction.#{for_profile}"), class: ['fr-badge fr-badge--sm fr-badge--warning super', html_class], role: 'status') tag.span(Dossier.human_attribute_name("pending_correction.#{for_profile}"), class: ['fr-badge fr-badge--sm fr-badge--warning super', html_class], role: 'status')
end end
def correction_resolved_badge def correction_resolved_badge(html_class: nil)
tag.span(Dossier.human_attribute_name("pending_correction.resolved"), class: ['fr-badge fr-badge--sm fr-badge--success super'], role: 'status') tag.span(Dossier.human_attribute_name("pending_correction.resolved"), class: ['fr-badge fr-badge--sm fr-badge--success super', html_class], role: 'status')
end end
def demandeur_dossier(dossier) def demandeur_dossier(dossier)

View file

@ -40,6 +40,10 @@ module DossierCorrectableConcern
pending_corrections.exists? pending_corrections.exists?
end end
def last_correction_resolved?
corrections.last&.resolved?
end
def resolve_pending_correction def resolve_pending_correction
pending_correction&.resolve pending_correction&.resolve
end end

View file

@ -5,6 +5,12 @@ class DossierProjectionService
corrections.any? { _1[:resolved_at].nil? } corrections.any? { _1[:resolved_at].nil? }
end end
def resolved_corrections?
return false if corrections.blank?
corrections.all? { _1[:resolved_at].present? }
end
end end
end end

View file

@ -9,7 +9,10 @@
= procedure_badge(dossier.procedure) = procedure_badge(dossier.procedure)
= status_badge(dossier.state) = status_badge(dossier.state)
= pending_correction_badge(:for_instructeur) if dossier.pending_correction? - if dossier.pending_correction?
= pending_correction_badge(:for_instructeur)
- elsif dossier.en_construction? && dossier.last_correction_resolved?
= correction_resolved_badge
= render Instructeurs::SVASVRDecisionBadgeComponent.new(projection_or_dossier: dossier, procedure: dossier.procedure, with_label: true) = render Instructeurs::SVASVRDecisionBadgeComponent.new(projection_or_dossier: dossier, procedure: dossier.procedure, with_label: true)

View file

@ -175,7 +175,10 @@
%td.status-col %td.status-col
- status = [status_badge(p.state)] - status = [status_badge(p.state)]
- status << pending_correction_badge(:for_instructeur, html_class: "fr-mt-1v") if p.pending_correction? - if p.pending_correction?
- status << pending_correction_badge(:for_instructeur, html_class: "fr-mt-1v")
- elsif p.state.to_sym == :en_construction && p.resolved_corrections?
- status << correction_resolved_badge(html_class: "fr-mt-1v")
= link_to_if(p.hidden_by_administration_at.blank?, safe_join(status), path, class: class_names("cell-link": true, "fr-py-0": status.many?)) = link_to_if(p.hidden_by_administration_at.blank?, safe_join(status), path, class: class_names("cell-link": true, "fr-py-0": status.many?))
- if @procedure.sva_svr_enabled? - if @procedure.sva_svr_enabled?

View file

@ -258,16 +258,19 @@ describe DossierProjectionService do
before { create(:dossier_correction, dossier:) } before { create(:dossier_correction, dossier:) }
it { expect(subject.pending_correction?).to be(true) } it { expect(subject.pending_correction?).to be(true) }
it { expect(subject.resolved_corrections?).to eq(false) }
end end
context "when dossier has a resolved correction" do context "when dossier has a resolved correction" do
before { create(:dossier_correction, :resolved, dossier:) } before { create(:dossier_correction, :resolved, dossier:) }
it { expect(subject.pending_correction?).to eq(false) } it { expect(subject.pending_correction?).to eq(false) }
it { expect(subject.resolved_corrections?).to eq(true) }
end end
context "when dossier has no correction at all" do context "when dossier has no correction at all" do
it { expect(subject.pending_correction?).to eq(false) } it { expect(subject.pending_correction?).to eq(false) }
it { expect(subject.resolved_corrections?).to eq(false) }
end end
end end
end end

View file

@ -70,6 +70,10 @@ describe 'instructeurs/dossiers/show', type: :view do
it { expect(subject).to have_button('Passer en instruction', disabled: false) } it { expect(subject).to have_button('Passer en instruction', disabled: false) }
it 'shows the correction badge' do
expect(subject).to have_selector('.fr-badge--warning', text: "en attente")
end
context 'with procedure blocking pending correction' do context 'with procedure blocking pending correction' do
before { Flipper.enable(:blocking_pending_correction, dossier.procedure) } before { Flipper.enable(:blocking_pending_correction, dossier.procedure) }
@ -79,6 +83,14 @@ describe 'instructeurs/dossiers/show', type: :view do
end end
end end
end end
context 'with resolved correction' do
before { create(:dossier_correction, dossier:, resolved_at: 1.minute.ago) }
it 'shows the resolved badge' do
expect(subject).to have_selector('.fr-badge--success', text: "corrigé")
end
end
end end
context 'en_instruction' do context 'en_instruction' do