update conditions_controller

This commit is contained in:
simon lehericey 2022-07-11 21:57:43 +02:00
parent faa2797d80
commit 0179a0a826
8 changed files with 48 additions and 39 deletions

View file

@ -6,54 +6,58 @@ module Administrateurs
def update def update
condition = condition_form.to_condition condition = condition_form.to_condition
tdc.update!(condition: condition) @tdc.update!(condition: condition)
render 'administrateurs/types_de_champ/update.turbo_stream.haml' @condition_component = build_condition_component
end end
def add_row def add_row
condition = Logic.add_empty_condition_to(tdc.condition) condition = Logic.add_empty_condition_to(@tdc.condition)
tdc.update!(condition: condition) @tdc.update!(condition: condition)
render 'administrateurs/types_de_champ/update.turbo_stream.haml' @condition_component = build_condition_component
end end
def delete_row def delete_row
condition = condition_form.delete_row(row_index).to_condition condition = condition_form.delete_row(row_index).to_condition
tdc.update!(condition: condition) @tdc.update!(condition: condition)
render 'administrateurs/types_de_champ/update.turbo_stream.haml' @condition_component = build_condition_component
end end
def destroy def destroy
tdc.update!(condition: nil) @tdc.update!(condition: nil)
render 'administrateurs/types_de_champ/update.turbo_stream.haml' @condition_component = build_condition_component
end end
def change_targeted_champ def change_targeted_champ
condition = condition_form.change_champ(row_index).to_condition condition = condition_form.change_champ(row_index).to_condition
tdc.update!(condition: condition) @tdc.update!(condition: condition)
render 'administrateurs/types_de_champ/update.turbo_stream.haml' @condition_component = build_condition_component
end end
private private
def build_condition_component
TypesDeChampEditor::ConditionsComponent.new(
tdc: @tdc,
upper_tdcs: @upper_tdcs,
procedure_id: @procedure.id
)
end
def condition_form def condition_form
ConditionForm.new(condition_params) ConditionForm.new(condition_params)
end end
def retrieve_coordinate_and_uppers def retrieve_coordinate_and_uppers
@coordinate = draft_revision.coordinate_for(tdc) @tdc = draft_revision.find_and_ensure_exclusive_use(params[:stable_id])
@upper_coordinates = draft_revision @coordinate = draft_revision.coordinate_for(@tdc)
.revision_types_de_champ_public @upper_tdcs = draft_revision
.includes(:type_de_champ) .upper_coordinates(@coordinate.position)
.take_while { |c| c != @coordinate } .map(&:type_de_champ)
end
def tdc
@tdc ||= draft_revision.find_and_ensure_exclusive_use(params[:stable_id])
end end
def draft_revision def draft_revision

View file

@ -0,0 +1,8 @@
- rendered = render @condition_component
- if rendered.present?
= turbo_stream.morph dom_id(@tdc, :conditions) do
- rendered
end
- else
= turbo_stream.remove dom_id(@tdc, :conditions)

View file

@ -0,0 +1 @@
= render partial: 'update'

View file

@ -0,0 +1 @@
= render partial: 'update'

View file

@ -0,0 +1 @@
= render partial: 'update'

View file

@ -0,0 +1 @@
= render partial: 'update'

View file

@ -0,0 +1 @@
= render partial: 'update'

View file

@ -5,9 +5,7 @@ describe Administrateurs::ConditionsController, type: :controller do
let(:first_coordinate) { procedure.draft_revision.revision_types_de_champ.first } let(:first_coordinate) { procedure.draft_revision.revision_types_de_champ.first }
let(:second_tdc) { procedure.draft_revision.types_de_champ.second } let(:second_tdc) { procedure.draft_revision.types_de_champ.second }
before do before { sign_in(procedure.administrateurs.first.user) }
sign_in(procedure.administrateurs.first.user)
end
let(:default_params) do let(:default_params) do
{ {
@ -17,9 +15,7 @@ describe Administrateurs::ConditionsController, type: :controller do
end end
describe '#update' do describe '#update' do
before do before { post :update, params: params, format: :turbo_stream }
post :update, params: params
end
let(:params) { default_params.merge(type_de_champ: { condition_form: condition_form }) } let(:params) { default_params.merge(type_de_champ: { condition_form: condition_form }) }
@ -38,26 +34,22 @@ describe Administrateurs::ConditionsController, type: :controller do
it do it do
expect(second_tdc.reload.condition).to eq(ds_eq(champ_value(1), constant(2))) expect(second_tdc.reload.condition).to eq(ds_eq(champ_value(1), constant(2)))
expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc)) expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc))
expect(assigns(:upper_coordinates)).to eq([first_coordinate]) expect(assigns(:upper_tdcs)).to eq([first_coordinate.type_de_champ])
end end
end end
describe '#add_row' do describe '#add_row' do
before do before { post :add_row, params: default_params, format: :turbo_stream }
post :add_row, params: default_params
end
it do it do
expect(second_tdc.reload.condition).to eq(empty_operator(empty, empty)) expect(second_tdc.reload.condition).to eq(empty_operator(empty, empty))
expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc)) expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc))
expect(assigns(:upper_coordinates)).to eq([first_coordinate]) expect(assigns(:upper_tdcs)).to eq([first_coordinate.type_de_champ])
end end
end end
describe '#delete_row' do describe '#delete_row' do
before do before { delete :delete_row, params: params.merge(row_index: 0), format: :turbo_stream }
delete :delete_row, params: params.merge(row_index: 0)
end
let(:params) { default_params.merge(type_de_champ: { condition_form: condition_form }) } let(:params) { default_params.merge(type_de_champ: { condition_form: condition_form }) }
@ -76,20 +68,20 @@ describe Administrateurs::ConditionsController, type: :controller do
it do it do
expect(second_tdc.reload.condition).to eq(nil) expect(second_tdc.reload.condition).to eq(nil)
expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc)) expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc))
expect(assigns(:upper_coordinates)).to eq([first_coordinate]) expect(assigns(:upper_tdcs)).to eq([first_coordinate.type_de_champ])
end end
end end
describe '#destroy' do describe '#destroy' do
before do before do
second_tdc.update(condition: empty_operator(empty, empty)) second_tdc.update(condition: empty_operator(empty, empty))
delete :destroy, params: default_params delete :destroy, params: default_params, format: :turbo_stream
end end
it do it do
expect(second_tdc.reload.condition).to eq(nil) expect(second_tdc.reload.condition).to eq(nil)
expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc)) expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc))
expect(assigns(:upper_coordinates)).to eq([first_coordinate]) expect(assigns(:upper_tdcs)).to eq([first_coordinate.type_de_champ])
end end
end end
@ -98,7 +90,7 @@ describe Administrateurs::ConditionsController, type: :controller do
before do before do
second_tdc.update(condition: empty_operator(empty, empty)) second_tdc.update(condition: empty_operator(empty, empty))
patch :change_targeted_champ, params: params patch :change_targeted_champ, params: params, format: :turbo_stream
end end
let(:params) { default_params.merge(type_de_champ: { condition_form: condition_form }) } let(:params) { default_params.merge(type_de_champ: { condition_form: condition_form }) }
@ -118,7 +110,7 @@ describe Administrateurs::ConditionsController, type: :controller do
it do it do
expect(second_tdc.reload.condition).to eq(ds_eq(champ_value(number_tdc.stable_id), constant(0))) expect(second_tdc.reload.condition).to eq(ds_eq(champ_value(number_tdc.stable_id), constant(0)))
expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc)) expect(assigns(:coordinate)).to eq(procedure.draft_revision.coordinate_for(second_tdc))
expect(assigns(:upper_coordinates)).to eq([first_coordinate]) expect(assigns(:upper_tdcs)).to eq([first_coordinate.type_de_champ])
end end
end end
end end