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:
commit
c02171ede7
7 changed files with 35 additions and 4 deletions
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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?
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue