Merge pull request #1176 from sgmap/fix_1110-port_attestation_tags_to_mail

Fix 1110 4. port attestation tags to mail
This commit is contained in:
gregoirenovel 2018-01-05 18:00:41 +01:00 committed by GitHub
commit 7f44818796
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
15 changed files with 98 additions and 81 deletions

View file

@ -3,28 +3,7 @@ module MailTemplateConcern
include Rails.application.routes.url_helpers include Rails.application.routes.url_helpers
include ActionView::Helpers::UrlHelper include ActionView::Helpers::UrlHelper
include TagsSubstitutionConcern
TAGS = []
TAGS << TAG_NUMERO_DOSSIER = {
libelle: "numero_dossier",
description: "Permet d'afficher le numéro de dossier de l'utilisateur."
}
TAGS << TAG_LIEN_DOSSIER = {
libelle: "lien_dossier",
description: "Permet d'afficher un lien vers le dossier de l'utilisateur."
}
TAGS << TAG_LIBELLE_PROCEDURE = {
libelle: "libelle_procedure",
description: "Permet d'afficher le libellé de la procédure."
}
TAGS << TAG_DATE_DE_DECISION = {
libelle: "date_de_decision",
description: "Permet d'afficher la date à laquelle la décision finale (acceptation, refus, classement sans suite) sur le dossier a été prise."
}
TAGS << TAG_MOTIVATION = {
libelle: "motivation",
description: "Permet d'afficher la motivation associée à la décision finale (acceptation, refus, classement sans suite) sur le dossier. Attention, elle est facultative."
}
def object_for_dossier(dossier) def object_for_dossier(dossier)
replace_tags(object, dossier) replace_tags(object, dossier)
@ -34,14 +13,10 @@ module MailTemplateConcern
replace_tags(body, dossier) replace_tags(body, dossier)
end end
def tags # TODO: remove legacy argument when removing legacy tags
self.class.const_get(:ALLOWED_TAGS) def tags(reject_legacy: true, is_dossier_termine: self.class.const_get(:IS_DOSSIER_TERMINE))
end super(is_dossier_termine: is_dossier_termine)
.reject { |tag| reject_legacy && tag[:is_legacy] }
def replace_tags(string, dossier)
TAGS.inject(string) do |acc, tag|
acc.gsub("--#{tag[:libelle]}--", replace_tag(tag, dossier)) || acc
end
end end
module ClassMethods module ClassMethods
@ -53,20 +28,20 @@ module MailTemplateConcern
private private
def replace_tag(tag, dossier) def dossier_tags
case tag super +
when TAG_NUMERO_DOSSIER [{ libelle: 'lien dossier', description: '', lambda: -> (d) { users_dossier_recapitulatif_link(d) } },
dossier.id.to_s # TODO: remove legacy tags
when TAG_LIEN_DOSSIER { libelle: 'numero_dossier', description: '', target: :id, is_legacy: true },
link_to users_dossier_recapitulatif_url(dossier), users_dossier_recapitulatif_url(dossier), target: '_blank' { libelle: 'lien_dossier', description: '', lambda: -> (d) { users_dossier_recapitulatif_link(d) }, is_legacy: true },
when TAG_LIBELLE_PROCEDURE { libelle: 'libelle_procedure', description: '', lambda: -> (d) { d.procedure.libelle }, is_legacy: true },
dossier.procedure.libelle { libelle: 'date_de_decision', description: '',
when TAG_DATE_DE_DECISION lambda: -> (d) { d.processed_at.present? ? d.processed_at.localtime.strftime('%d/%m/%Y') : '' },
dossier.processed_at.present? ? dossier.processed_at.localtime.strftime("%d/%m/%Y") : "" dossier_termine_only: true, is_legacy: true }]
when TAG_MOTIVATION end
dossier.motivation || ""
else def users_dossier_recapitulatif_link(dossier)
'--BALISE_NON_RECONNUE--' url = users_dossier_recapitulatif_url(dossier)
end link_to(url, url, target: '_blank')
end end
end end

View file

@ -7,7 +7,7 @@ module Mails
SLUG = "closed_mail" SLUG = "closed_mail"
TEMPLATE_NAME = "mails/closed_mail" TEMPLATE_NAME = "mails/closed_mail"
DISPLAYED_NAME = "Accusé d'acceptation" DISPLAYED_NAME = "Accusé d'acceptation"
DEFAULT_OBJECT = 'Votre dossier TPS nº --numero_dossier-- a été accepté' DEFAULT_OBJECT = 'Votre dossier TPS nº --numéro du dossier-- a été accepté'
ALLOWED_TAGS = [TAG_NUMERO_DOSSIER, TAG_LIEN_DOSSIER, TAG_LIBELLE_PROCEDURE, TAG_DATE_DE_DECISION, TAG_MOTIVATION] IS_DOSSIER_TERMINE = true
end end
end end

View file

@ -7,7 +7,7 @@ module Mails
SLUG = "initiated_mail" SLUG = "initiated_mail"
TEMPLATE_NAME = "mails/initiated_mail" TEMPLATE_NAME = "mails/initiated_mail"
DISPLAYED_NAME = 'Accusé de réception' DISPLAYED_NAME = 'Accusé de réception'
DEFAULT_OBJECT = 'Votre dossier TPS nº --numero_dossier-- a bien été reçu' DEFAULT_OBJECT = 'Votre dossier TPS nº --numéro du dossier-- a bien été reçu'
ALLOWED_TAGS = [TAG_NUMERO_DOSSIER, TAG_LIEN_DOSSIER, TAG_LIBELLE_PROCEDURE] IS_DOSSIER_TERMINE = false
end end
end end

View file

@ -7,7 +7,7 @@ module Mails
SLUG = "received_mail" SLUG = "received_mail"
TEMPLATE_NAME = "mails/received_mail" TEMPLATE_NAME = "mails/received_mail"
DISPLAYED_NAME = 'Accusé de passage en instruction' DISPLAYED_NAME = 'Accusé de passage en instruction'
DEFAULT_OBJECT = 'Votre dossier TPS nº --numero_dossier-- va être instruit' DEFAULT_OBJECT = 'Votre dossier TPS nº --numéro du dossier-- va être instruit'
ALLOWED_TAGS = [TAG_NUMERO_DOSSIER, TAG_LIEN_DOSSIER, TAG_LIBELLE_PROCEDURE] IS_DOSSIER_TERMINE = false
end end
end end

View file

@ -7,7 +7,7 @@ module Mails
SLUG = "refused_mail" SLUG = "refused_mail"
TEMPLATE_NAME = "mails/refused_mail" TEMPLATE_NAME = "mails/refused_mail"
DISPLAYED_NAME = 'Accusé de rejet du dossier' DISPLAYED_NAME = 'Accusé de rejet du dossier'
DEFAULT_OBJECT = 'Votre dossier TPS nº --numero_dossier-- a été refusé' DEFAULT_OBJECT = 'Votre dossier TPS nº --numéro du dossier-- a été refusé'
ALLOWED_TAGS = [TAG_NUMERO_DOSSIER, TAG_LIEN_DOSSIER, TAG_LIBELLE_PROCEDURE, TAG_DATE_DE_DECISION, TAG_MOTIVATION] IS_DOSSIER_TERMINE = true
end end
end end

View file

@ -7,7 +7,7 @@ module Mails
SLUG = "without_continuation" SLUG = "without_continuation"
TEMPLATE_NAME = "mails/without_continuation_mail" TEMPLATE_NAME = "mails/without_continuation_mail"
DISPLAYED_NAME = 'Accusé de classement sans suite' DISPLAYED_NAME = 'Accusé de classement sans suite'
DEFAULT_OBJECT = 'Votre dossier TPS nº --numero_dossier-- a été classé sans suite' DEFAULT_OBJECT = 'Votre dossier TPS nº --numéro du dossier-- a été classé sans suite'
ALLOWED_TAGS = [TAG_NUMERO_DOSSIER, TAG_LIEN_DOSSIER, TAG_LIBELLE_PROCEDURE, TAG_DATE_DE_DECISION, TAG_MOTIVATION] IS_DOSSIER_TERMINE = true
end end
end end

View file

@ -1,10 +1,10 @@
Bonjour, Bonjour,
%br %br
%br %br
Votre dossier nº --numero_dossier-- a été accepté le --date_de_decision--. Votre dossier nº --numéro du dossier-- a été accepté le --date de décision--.
%br %br
%br %br
A tout moment, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien_dossier-- A tout moment, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien dossier--
%br %br
%br %br
Bonne journée, Bonne journée,

View file

@ -1,10 +1,10 @@
Bonjour, Bonjour,
%br %br
%br %br
Votre administration vous confirme la bonne réception de votre dossier nº --numero_dossier--. Votre administration vous confirme la bonne réception de votre dossier nº --numéro du dossier--.
%br %br
%br %br
A tout moment, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien_dossier-- A tout moment, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien dossier--
%br %br
%br %br
Bonne journée, Bonne journée,

View file

@ -1,7 +1,7 @@
Bonjour, Bonjour,
%br %br
%br %br
Votre administration vous confirme la bonne réception de votre dossier nº --numero_dossier--. Celui-ci sera instruit dans le délai légal déclaré par votre interlocuteur. Votre administration vous confirme la bonne réception de votre dossier nº --numéro du dossier--. Celui-ci sera instruit dans le délai légal déclaré par votre interlocuteur.
%br %br
%br %br
Bonne journée, Bonne journée,

View file

@ -1,10 +1,10 @@
Bonjour, Bonjour,
%br %br
%br %br
Votre dossier nº --numero_dossier-- a été refusé le --date_de_decision--. Votre dossier nº --numéro du dossier-- a été refusé le --date de décision--.
%br %br
%br %br
Pour en savoir plus sur le motif du refus, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien_dossier-- Pour en savoir plus sur le motif du refus, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien dossier--
%br %br
%br %br
Bonne journée, Bonne journée,

View file

@ -1,10 +1,10 @@
Bonjour, Bonjour,
%br %br
%br %br
Votre dossier nº --numero_dossier-- a été classé sans suite le --date_de_decision--. Votre dossier nº --numéro du dossier-- a été classé sans suite le --date de décision--.
%br %br
%br %br
Pour en savoir plus sur les raisons de ce classement sans suite, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien_dossier-- Pour en savoir plus sur les raisons de ce classement sans suite, vous pouvez consulter le contenu de vos dossiers et les éventuels commentaires de l'administration à cette adresse : --lien dossier--
%br %br
%br %br
Bonne journée, Bonne journée,

View file

@ -0,0 +1,22 @@
namespace :'2017_12_21_replace_deprecated_mail_template_tags' do
task set: :environment do
replace_tag('numero_dossier', 'numéro du dossier')
replace_tag('date_de_decision', 'date de décision')
replace_tag('libelle_procedure', 'libellé procédure')
replace_tag('lien_dossier', 'lien dossier')
end
def replace_tag(old_tag, new_tag)
mails = [ Mails::ClosedMail, Mails::InitiatedMail, Mails::ReceivedMail, Mails::RefusedMail, Mails::WithoutContinuationMail]
mails.each do |mail|
replace_tag_in(mail, 'object', old_tag, new_tag)
replace_tag_in(mail, 'body', old_tag, new_tag)
end
end
def replace_tag_in(mail, field, old_tag, new_tag)
mail
.where("#{field} LIKE ?", "%#{old_tag}%")
.update_all("#{field} = REPLACE(#{field}, '#{old_tag}', '#{new_tag}')")
end
end

View file

@ -1,21 +1,15 @@
FactoryGirl.define do FactoryGirl.define do
factory :mail_template do factory :mail_template, class: Mails::ClosedMail do
object "Object, voila voila" object "Object, voila voila"
body "Blabla ceci est mon body" body "Blabla ceci est mon body"
type 'MailValidated'
trait :dossier_submitted do factory :dossier_submitted_mail_template, class: Mails::ReceivedMail
type 'MailSubmitted'
end
trait :dossier_refused do factory :dossier_refused_mail_template, class: Mails::RefusedMail
type 'MailRefused'
end
trait :dossier_en_instruction do factory :dossier_en_instruction_mail_template, class: Mails::InitiatedMail do
object "[TPS] Accusé de réception pour votre dossier nº --numero_dossier--" object "[TPS] Accusé de réception pour votre dossier nº --numéro du dossier--"
body "Votre administration vous confirme la bonne réception de votre dossier nº --numero_dossier--" body "Votre administration vous confirme la bonne réception de votre dossier nº --numéro du dossier--"
type 'MailReceived'
end end
end end
end end

View file

@ -15,14 +15,14 @@ describe MailTemplateConcern do
end end
describe 'with one token to replace' do describe 'with one token to replace' do
let(:template) { '[TPS] Dossier : --numero_dossier--' } let(:template) { '[TPS] Dossier : --numéro du dossier--' }
it do it do
is_expected.to eq("[TPS] Dossier : #{dossier.id}") is_expected.to eq("[TPS] Dossier : #{dossier.id}")
end end
end end
describe 'with multiples tokens to replace' do describe 'with multiples tokens to replace' do
let(:template) { '[TPS] --numero_dossier-- --libelle_procedure-- --lien_dossier--' } let(:template) { '[TPS] --numéro du dossier-- --libellé procédure-- --lien dossier--' }
it do it do
expected = expected =
"[TPS] #{dossier.id} #{dossier.procedure.libelle} " + "[TPS] #{dossier.id} #{dossier.procedure.libelle} " +
@ -48,10 +48,10 @@ describe MailTemplateConcern do
end end
describe '.replace_tags' do describe '.replace_tags' do
before { initiated_mail.body = "n --numéro du dossier--" }
it "avoids side effects" do it "avoids side effects" do
subject = "n --numero_dossier--" expect(initiated_mail.body_for_dossier(dossier)).to eq("n #{dossier.id}")
expect(initiated_mail.replace_tags(subject, dossier)).to eq("n #{dossier.id}") expect(initiated_mail.body_for_dossier(dossier2)).to eq("n #{dossier2.id}")
expect(initiated_mail.replace_tags(subject, dossier2)).to eq("n #{dossier2.id}")
end end
end end
end end

View file

@ -0,0 +1,26 @@
require 'spec_helper'
describe 'admin/mail_templates/edit.html.haml', type: :view do
let(:procedure) { create(:procedure) }
let(:mail_template) { create(:mail_template, procedure: procedure) }
let(:all_tags) { mail_template.tags(reject_legacy: false) }
before do
allow(view).to receive(:admin_procedure_mail_template_path).and_return("/toto")
allow(view).to receive(:admin_procedure_mail_templates_path).and_return("/toto")
assign(:mail_template, mail_template)
end
subject { render }
context "Legacy champs are not listed in the page" do
it { expect(all_tags).to include(include({ libelle: 'numero_dossier', is_legacy: true })) }
it { is_expected.not_to include("numero_dossier") }
end
context "Non-legacy champs are listed in the page" do
it { expect(all_tags).to include(include({ libelle: 'numéro du dossier' })) }
it { is_expected.to include("numéro du dossier") }
end
end