update conditions_controller
This commit is contained in:
parent
faa2797d80
commit
0179a0a826
8 changed files with 48 additions and 39 deletions
|
@ -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
|
||||||
|
|
|
@ -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)
|
|
@ -0,0 +1 @@
|
||||||
|
= render partial: 'update'
|
|
@ -0,0 +1 @@
|
||||||
|
= render partial: 'update'
|
|
@ -0,0 +1 @@
|
||||||
|
= render partial: 'update'
|
|
@ -0,0 +1 @@
|
||||||
|
= render partial: 'update'
|
|
@ -0,0 +1 @@
|
||||||
|
= render partial: 'update'
|
|
@ -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
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue