Merge pull request #10812 from colinux/date-last-updated-at-tag

ETQ admin, créé les balises "date de mise à jour" du dossier et "date prévisionnelle SVA/SVR"
This commit is contained in:
Colin Darie 2024-09-24 12:21:07 +00:00 committed by GitHub
commit 99534ef834
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
5 changed files with 71 additions and 12 deletions

View file

@ -50,6 +50,6 @@ module MailTemplateConcern
end end
def dossier_tags def dossier_tags
TagsSubstitutionConcern::DOSSIER_TAGS + TagsSubstitutionConcern::DOSSIER_TAGS_FOR_MAIL super + TagsSubstitutionConcern::DOSSIER_TAGS_FOR_MAIL
end end
end end

View file

@ -102,6 +102,13 @@ module TagsSubstitutionConcern
lambda: -> (d) { format_date(d.processed_at) }, lambda: -> (d) { format_date(d.processed_at) },
available_for_states: Dossier::TERMINE available_for_states: Dossier::TERMINE
}, },
{
id: 'dossier_last_champ_updated_at',
libelle: 'date de mise à jour',
description: 'Date de dernière mise à jour dun champ du dossier',
lambda: -> (d) { format_date(d.last_champ_updated_at) },
available_for_states: Dossier::SOUMIS
},
{ {
id: 'dossier_procedure_libelle', id: 'dossier_procedure_libelle',
libelle: 'libellé démarche', libelle: 'libellé démarche',
@ -151,6 +158,14 @@ module TagsSubstitutionConcern
} }
] ]
DOSSIER_SVA_SVR_DECISION_DATE_TAG = {
id: 'dossier_sva_svr_decision_on',
libelle: 'date prévisionnelle SVA/SVR',
description: 'Date prévisionnelle de décision automatique par le SVA/SVR',
lambda: -> (d) { format_date(d.sva_svr_decision_on) },
available_for_states: Dossier.states.fetch(:en_instruction)
}
INDIVIDUAL_TAGS = [ INDIVIDUAL_TAGS = [
{ {
id: 'individual_gender', id: 'individual_gender',
@ -328,7 +343,13 @@ module TagsSubstitutionConcern
def dossier_tags def dossier_tags
# Overridden by MailTemplateConcern # Overridden by MailTemplateConcern
DOSSIER_TAGS DOSSIER_TAGS + contextual_dossier_tags
end
def contextual_dossier_tags
tags = []
tags << DOSSIER_SVA_SVR_DECISION_DATE_TAG if respond_to?(:procedure) && procedure.sva_svr_enabled?
tags
end end
def tags_for_dossier_state(tags) def tags_for_dossier_state(tags)

View file

@ -141,6 +141,14 @@ describe MailTemplateConcern do
let(:mail) { create(:without_continuation_mail, procedure: procedure) } let(:mail) { create(:without_continuation_mail, procedure: procedure) }
it_behaves_like 'inserting the --lien document justificatif-- tag' it_behaves_like 'inserting the --lien document justificatif-- tag'
end end
context 'sva/svr' do
let(:procedure) { create(:procedure, :sva) }
let(:received_mail) { create(:received_mail, procedure:) }
it "treats date de passage en instruction as a tag" do
expect(received_mail.tags).to include(include({ libelle: 'date prévisionnelle SVA/SVR' }))
end
end
end end
describe '#replace_tags' do describe '#replace_tags' do

View file

@ -375,13 +375,17 @@ describe TagsSubstitutionConcern, type: :model do
context "when using a date tag" do context "when using a date tag" do
before do before do
Timecop.freeze(Time.zone.local(2001, 2, 3)) travel_to Time.zone.local(2001, 2, 3)
dossier.passer_en_construction! dossier.passer_en_construction!
Timecop.freeze(Time.zone.local(2004, 5, 6))
travel_to Time.zone.local(2003, 1, 3)
dossier.touch(:last_champ_updated_at)
travel_to Time.zone.local(2004, 5, 6)
dossier.passer_en_instruction!(instructeur: instructeur) dossier.passer_en_instruction!(instructeur: instructeur)
Timecop.freeze(Time.zone.local(2007, 8, 9))
travel_to Time.zone.local(2007, 8, 9)
dossier.accepter!(instructeur: instructeur) dossier.accepter!(instructeur: instructeur)
Timecop.return
end end
context "with date de dépôt" do context "with date de dépôt" do
@ -401,6 +405,26 @@ describe TagsSubstitutionConcern, type: :model do
it { is_expected.to eq('09/08/2007') } it { is_expected.to eq('09/08/2007') }
end end
context "with date last ,champ updated at" do
let(:template) { '--date de mise à jour--' }
it { is_expected.to eq('03/01/2003') }
end
end
context "with date decision sva/svr" do
let(:template) { '--date prévisionnelle SVA/SVR--' }
let(:procedure) { create(:procedure, :published, :sva) }
let(:state) { dossier.state }
before do
dossier.passer_en_construction!
dossier.process_sva_svr!
dossier.update(sva_svr_decision_on: Date.parse("2024-09-20"))
end
it { is_expected.to eq('20/09/2024') }
end end
context "when the template has a libellé démarche tag" do context "when the template has a libellé démarche tag" do

View file

@ -67,24 +67,30 @@ describe ExportTemplate do
context 'for entreprise procedure' do context 'for entreprise procedure' do
let(:for_individual) { false } let(:for_individual) { false }
let(:expected_tags) do let(:expected_tags) do
['entreprise_siren', 'entreprise_numero_tva_intracommunautaire', 'entreprise_siret_siege_social', 'entreprise_raison_sociale', 'entreprise_adresse', 'dossier_depose_at', 'dossier_procedure_libelle', 'dossier_service_name', 'dossier_number', 'dossier_groupe_instructeur'] [
'entreprise_siren', 'entreprise_numero_tva_intracommunautaire', 'entreprise_siret_siege_social', 'entreprise_raison_sociale', 'entreprise_adresse',
'dossier_depose_at', 'dossier_procedure_libelle', 'dossier_service_name', 'dossier_number', 'dossier_groupe_instructeur', 'dossier_last_champ_updated_at'
]
end end
it do it do
expect(export_template.tags.map { _1[:id] }).to eq(expected_tags) expect(export_template.tags.map { _1[:id] }).to match_array(expected_tags)
expect(export_template.pj_tags.map { _1[:id] }).to eq(expected_tags + ['original-filename']) expect(export_template.pj_tags.map { _1[:id] }).to match_array(expected_tags + ['original-filename'])
end end
end end
context 'for individual procedure' do context 'for individual procedure' do
let(:for_individual) { true } let(:for_individual) { true }
let(:expected_tags) do let(:expected_tags) do
['individual_gender', 'individual_last_name', 'individual_first_name', 'dossier_depose_at', 'dossier_procedure_libelle', 'dossier_service_name', 'dossier_number', 'dossier_groupe_instructeur'] [
'individual_gender', 'individual_last_name', 'individual_first_name',
'dossier_depose_at', 'dossier_procedure_libelle', 'dossier_service_name', 'dossier_number', 'dossier_groupe_instructeur', 'dossier_last_champ_updated_at'
]
end end
it do it do
expect(export_template.tags.map { _1[:id] }).to eq(expected_tags) expect(export_template.tags.map { _1[:id] }).to match_array(expected_tags)
expect(export_template.pj_tags.map { _1[:id] }).to eq(expected_tags + ['original-filename']) expect(export_template.pj_tags.map { _1[:id] }).to match_array(expected_tags + ['original-filename'])
end end
end end
end end