Merge branch 'dev'

This commit is contained in:
gregoirenovel 2018-10-17 15:46:47 +02:00
commit 4a34b7866e
13 changed files with 77 additions and 30 deletions

View file

@ -16,6 +16,7 @@ class ProcedurePresentation < ApplicationRecord
def fields def fields
fields = [ fields = [
field_hash('Créé le', 'self', 'created_at'), field_hash('Créé le', 'self', 'created_at'),
field_hash('En construction le', 'self', 'en_construction_at'),
field_hash('Mis à jour le', 'self', 'updated_at'), field_hash('Mis à jour le', 'self', 'updated_at'),
field_hash('Demandeur', 'user', 'email') field_hash('Demandeur', 'user', 'email')
] ]

View file

@ -47,11 +47,7 @@
.row .row
.col-xs-4.entreprise-label Exercices : .col-xs-4.entreprise-label Exercices :
.col-xs-8.entreprise-info .col-xs-8.entreprise-info
- @facade.etablissement.exercices.each_with_index do |exercice, index| les exercices comptables des trois dernières années sont joints à votre dossier.
%strong
= "#{exercice.date_fin_exercice.year} : "
= number_to_currency(exercice.ca)
%br
.row.split-row .row.split-row
.col-xs-12.split-hr .col-xs-12.split-hr

View file

@ -2,4 +2,4 @@
= render partial: 'header', locals: { avis: @avis, dossier: @dossier } = render partial: 'header', locals: { avis: @avis, dossier: @dossier }
= render partial: 'shared/dossiers/demande', locals: { dossier: @dossier, demande_seen_at: nil } = render partial: 'shared/dossiers/demande', locals: { dossier: @dossier, demande_seen_at: nil, profile: 'instructeur' }

View file

@ -6,7 +6,7 @@
= render partial: "shared/dossiers/user_infos", locals: { user: @dossier.user } = render partial: "shared/dossiers/user_infos", locals: { user: @dossier.user }
- if @dossier.etablissement.present? - if @dossier.etablissement.present?
= render partial: "shared/dossiers/identite_entreprise", locals: { etablissement: @dossier.etablissement } = render partial: "shared/dossiers/identite_entreprise", locals: { etablissement: @dossier.etablissement, profile: 'instructeur' }
- if @dossier.individual.present? - if @dossier.individual.present?
= render partial: "shared/dossiers/identite_individual", locals: { individual: @dossier.individual } = render partial: "shared/dossiers/identite_individual", locals: { individual: @dossier.individual }
@ -15,7 +15,7 @@
- champs = @dossier.champs.decorate - champs = @dossier.champs.decorate
- if champs.any? - if champs.any?
= render partial: "shared/dossiers/champs", locals: { champs: champs, dossier: @dossier, demande_seen_at: nil } = render partial: "shared/dossiers/champs", locals: { champs: champs, dossier: @dossier, demande_seen_at: nil, profile: 'instructeur' }
- if @dossier.procedure.use_api_carto - if @dossier.procedure.use_api_carto
%h3 Cartographie %h3 Cartographie

View file

@ -2,4 +2,4 @@
= render partial: "header", locals: { dossier: @dossier } = render partial: "header", locals: { dossier: @dossier }
= render partial: "shared/dossiers/demande", locals: { dossier: @dossier, demande_seen_at: @demande_seen_at } = render partial: "shared/dossiers/demande", locals: { dossier: @dossier, demande_seen_at: @demande_seen_at, profile: 'instructeur' }

View file

@ -6,7 +6,7 @@
#dossier-show #dossier-show
= render partial: 'new_user/dossiers/show/header', locals: { dossier: @dossier } = render partial: 'new_user/dossiers/show/header', locals: { dossier: @dossier }
= render partial: 'shared/dossiers/demande', locals: { dossier: @dossier, demande_seen_at: nil } = render partial: 'shared/dossiers/demande', locals: { dossier: @dossier, demande_seen_at: nil, profile: 'usager' }
.container .container
- if !@dossier.read_only? - if !@dossier.read_only?

View file

@ -55,7 +55,7 @@
%td.rich-text %td.rich-text
%span{ class: highlight_if_unseen_class(demande_seen_at, c.updated_at) } %span{ class: highlight_if_unseen_class(demande_seen_at, c.updated_at) }
- if c.etablissement.present? - if c.etablissement.present?
= render partial: "shared/dossiers/identite_entreprise", locals: { etablissement: c.etablissement } = render partial: "shared/dossiers/identite_entreprise", locals: { etablissement: c.etablissement, profile: profile }
- else - else
%th.libelle %th.libelle
= "#{c.libelle} :" = "#{c.libelle} :"

View file

@ -4,7 +4,7 @@
= render partial: "shared/dossiers/user_infos", locals: { user: dossier.user } = render partial: "shared/dossiers/user_infos", locals: { user: dossier.user }
- if dossier.etablissement.present? - if dossier.etablissement.present?
= render partial: "shared/dossiers/identite_entreprise", locals: { etablissement: dossier.etablissement } = render partial: "shared/dossiers/identite_entreprise", locals: { etablissement: dossier.etablissement, profile: profile }
- if dossier.individual.present? - if dossier.individual.present?
= render partial: "shared/dossiers/identite_individual", locals: { individual: dossier.individual } = render partial: "shared/dossiers/identite_individual", locals: { individual: dossier.individual }
@ -13,7 +13,7 @@
- champs = dossier.champs.includes(:type_de_champ).decorate - champs = dossier.champs.includes(:type_de_champ).decorate
- if champs.any? - if champs.any?
.card .card
= render partial: "shared/dossiers/champs", locals: { champs: champs, demande_seen_at: demande_seen_at } = render partial: "shared/dossiers/champs", locals: { champs: champs, demande_seen_at: demande_seen_at, profile: profile }
- if dossier.procedure.use_api_carto - if dossier.procedure.use_api_carto
.tab-title Cartographie .tab-title Cartographie

View file

@ -44,10 +44,14 @@
%tr %tr
%th.libelle Exercices : %th.libelle Exercices :
%td %td
- if profile == 'instructeur'
- etablissement.exercices.each_with_index do |exercice, index| - etablissement.exercices.each_with_index do |exercice, index|
= "#{exercice.date_fin_exercice.year} : " = "#{exercice.date_fin_exercice.year} : "
= pretty_currency(exercice.ca) = pretty_currency(exercice.ca)
%br %br
- elsif etablissement.exercices.present?
= t('activemodel.models.exercices_summary', count: etablissement.exercices.count)
- if etablissement.association? - if etablissement.association?
%tr %tr
%th.libelle Numéro RNA : %th.libelle Numéro RNA :

View file

@ -2,6 +2,9 @@ fr:
activemodel: activemodel:
models: models:
siret: 'SIRET' siret: 'SIRET'
exercices_summary:
one: Lexercice comptable de lannée dernière a été joint à votre dossier.
other: "Les exercices comptables des %{count} dernières années ont été joints à votre dossier."
errors: errors:
models: models:
siret: siret:

View file

@ -58,6 +58,7 @@ describe ProcedurePresentation do
let(:expected) { let(:expected) {
[ [
{ "label" => 'Créé le', "table" => 'self', "column" => 'created_at' }, { "label" => 'Créé le', "table" => 'self', "column" => 'created_at' },
{ "label" => 'En construction le', "table" => 'self', "column" => 'en_construction_at' },
{ "label" => 'Mis à jour le', "table" => 'self', "column" => 'updated_at' }, { "label" => 'Mis à jour le', "table" => 'self', "column" => 'updated_at' },
{ "label" => 'Demandeur', "table" => 'user', "column" => 'email' }, { "label" => 'Demandeur', "table" => 'user', "column" => 'email' },
{ "label" => 'SIREN', "table" => 'etablissement', "column" => 'entreprise_siren' }, { "label" => 'SIREN', "table" => 'etablissement', "column" => 'entreprise_siren' },
@ -129,14 +130,30 @@ describe ProcedurePresentation do
context 'for self table' do context 'for self table' do
let(:table) { 'self' } let(:table) { 'self' }
let(:column) { 'updated_at' } # All other columns work the same, no extra test required
context 'for created_at column' do
let(:column) { 'created_at' }
let(:dossier) { Timecop.freeze(DateTime.new(1992, 3, 22)) { create(:dossier, procedure: procedure) } }
it { is_expected.to eq(DateTime.new(1992, 3, 22)) }
end
context 'for en_construction_at column' do
let(:column) { 'en_construction_at' }
let(:dossier) { create(:dossier, :en_construction, procedure: procedure, en_construction_at: DateTime.new(2018, 10, 17)) }
it { is_expected.to eq(DateTime.new(2018, 10, 17)) }
end
context 'for updated_at column' do
let(:column) { 'updated_at' }
let(:dossier) { create(:dossier, procedure: procedure) } let(:dossier) { create(:dossier, procedure: procedure) }
before { dossier.touch(time: DateTime.new(2018, 9, 25)) } before { dossier.touch(time: DateTime.new(2018, 9, 25)) }
it { is_expected.to eq(DateTime.new(2018, 9, 25)) } it { is_expected.to eq(DateTime.new(2018, 9, 25)) }
end end
end
context 'for user table' do context 'for user table' do
let(:table) { 'user' } let(:table) { 'user' }
@ -240,9 +257,26 @@ describe ProcedurePresentation do
context 'for self table' do context 'for self table' do
let(:table) { 'self' } let(:table) { 'self' }
let(:column) { 'updated_at' } # All other columns work the same, no extra test required
let(:order) { 'asc' } # Desc works the same, no extra test required let(:order) { 'asc' } # Desc works the same, no extra test required
context 'for created_at column' do
let(:column) { 'created_at' }
let!(:recent_dossier) { Timecop.freeze(DateTime.new(2018, 10, 17)) { create(:dossier, procedure: procedure) } }
let!(:older_dossier) { Timecop.freeze(DateTime.new(2003, 11, 11)) { create(:dossier, procedure: procedure) } }
it { is_expected.to eq([older_dossier, recent_dossier].map(&:id)) }
end
context 'for en_construction_at column' do
let(:column) { 'en_construction_at' }
let!(:recent_dossier) { create(:dossier, :en_construction, procedure: procedure, en_construction_at: DateTime.new(2018, 10, 17)) }
let!(:older_dossier) { create(:dossier, :en_construction, procedure: procedure, en_construction_at: DateTime.new(2013, 1, 1)) }
it { is_expected.to eq([older_dossier, recent_dossier].map(&:id)) }
end
context 'for updated_at column' do
let(:column) { 'updated_at' }
let(:recent_dossier) { create(:dossier, procedure: procedure) } let(:recent_dossier) { create(:dossier, procedure: procedure) }
let(:older_dossier) { create(:dossier, procedure: procedure) } let(:older_dossier) { create(:dossier, procedure: procedure) }
@ -253,6 +287,7 @@ describe ProcedurePresentation do
it { is_expected.to eq([older_dossier, recent_dossier].map(&:id)) } it { is_expected.to eq([older_dossier, recent_dossier].map(&:id)) }
end end
end
context 'for type_de_champ table' do context 'for type_de_champ table' do
let(:table) { 'type_de_champ' } let(:table) { 'type_de_champ' }
@ -341,6 +376,14 @@ describe ProcedurePresentation do
it { is_expected.to contain_exactly(kept_dossier.id) } it { is_expected.to contain_exactly(kept_dossier.id) }
end end
context 'for en_construction_at column' do
let!(:kept_dossier) { create(:dossier, :en_construction, procedure: procedure, en_construction_at: DateTime.new(2018, 10, 17)) }
let!(:discarded_dossier) { create(:dossier, :en_construction, procedure: procedure, en_construction_at: DateTime.new(2013, 1, 1)) }
let(:filter) { [{ 'table' => 'self', 'column' => 'en_construction_at', 'value' => '17/10/2018' }] }
it { is_expected.to contain_exactly(kept_dossier.id) }
end
context 'for updated_at column' do context 'for updated_at column' do
let(:kept_dossier) { create(:dossier, procedure: procedure) } let(:kept_dossier) { create(:dossier, procedure: procedure) }
let(:discarded_dossier) { create(:dossier, procedure: procedure) } let(:discarded_dossier) { create(:dossier, procedure: procedure) }

View file

@ -9,7 +9,7 @@ describe 'shared/dossiers/demande.html.haml', type: :view do
sign_in current_gestionnaire sign_in current_gestionnaire
end end
subject! { render 'shared/dossiers/demande.html.haml', dossier: dossier, demande_seen_at: nil } subject! { render 'shared/dossiers/demande.html.haml', dossier: dossier, demande_seen_at: nil, profile: 'usager' }
context 'when dossier was created by an etablissement' do context 'when dossier was created by an etablissement' do
let(:etablissement) { create(:etablissement) } let(:etablissement) { create(:etablissement) }

View file

@ -1,5 +1,5 @@
describe 'shared/dossiers/identite_entreprise.html.haml', type: :view do describe 'shared/dossiers/identite_entreprise.html.haml', type: :view do
before { render 'shared/dossiers/identite_entreprise.html.haml', etablissement: etablissement } before { render 'shared/dossiers/identite_entreprise.html.haml', etablissement: etablissement, profile: 'usager' }
context "there is an association" do context "there is an association" do
let(:etablissement) { create(:etablissement, :is_association) } let(:etablissement) { create(:etablissement, :is_association) }