Browse Source

WIP

CLDC-1730-stock-owning-validation2
James Rose 2 years ago
parent
commit
7e0aa0ceb7
  1. 96
      app/controllers/organisation_relationships_controller.rb
  2. 14
      app/models/organisation_relationship.rb
  3. 2
      app/views/organisation_relationships/_related_organisation_select_question.html.erb
  4. 1
      app/views/organisation_relationships/add_housing_provider.html.erb
  5. 1
      app/views/organisation_relationships/add_managing_agent.html.erb
  6. 4
      app/views/organisation_relationships/remove_managing_agent.html.erb

96
app/controllers/organisation_relationships_controller.rb

@ -5,13 +5,19 @@ class OrganisationRelationshipsController < ApplicationController
before_action :authenticate_user! before_action :authenticate_user!
before_action :authenticate_scope! before_action :authenticate_scope!
before_action :organisations
before_action :target_organisation, only: %i[
remove_housing_provider
remove_managing_agent
delete_housing_provider
delete_managing_agent
]
def housing_providers def housing_providers
housing_providers = organisation.housing_providers housing_providers = organisation.housing_providers
unpaginated_filtered_housing_providers = filtered_collection(housing_providers, search_term) unpaginated_filtered_housing_providers = filtered_collection(housing_providers, search_term)
organisations = Organisation.where.not(id: @organisation.id).pluck(:id, :name)
respond_to :html
@pagy, @housing_providers = pagy(unpaginated_filtered_housing_providers) @pagy, @housing_providers = pagy(unpaginated_filtered_housing_providers)
@organisations = organisations
@searched = search_term.presence @searched = search_term.presence
@total_count = housing_providers.size @total_count = housing_providers.size
end end
@ -19,95 +25,85 @@ class OrganisationRelationshipsController < ApplicationController
def managing_agents def managing_agents
managing_agents = organisation.managing_agents managing_agents = organisation.managing_agents
unpaginated_filtered_managing_agents = filtered_collection(managing_agents, search_term) unpaginated_filtered_managing_agents = filtered_collection(managing_agents, search_term)
organisations = Organisation.where.not(id: @organisation.id).pluck(:id, :name)
respond_to :html
@pagy, @managing_agents = pagy(unpaginated_filtered_managing_agents) @pagy, @managing_agents = pagy(unpaginated_filtered_managing_agents)
@organisations = organisations
@searched = search_term.presence @searched = search_term.presence
@total_count = managing_agents.size @total_count = managing_agents.size
end end
def add_housing_provider def add_housing_provider
@organisations = Organisation.where.not(id: @organisation.id).pluck(:id, :name) @organisation_relationship = organisation.parent_organisation_relationships.new
respond_to :html
end end
def add_managing_agent def add_managing_agent
@organisations = Organisation.where.not(id: @organisation.id).pluck(:id, :name) @organisation_relationship = organisation.child_organisation_relationships.new
respond_to :html
end end
def create_housing_provider def create_housing_provider
child_organisation = @organisation @organisation_relationship = organisation.parent_organisation_relationships.new(organisation_relationship_params)
if params[:organisation_relationship].present? && params[:organisation_relationship][:related_organisation_id].present? if @organisation_relationship.save
parent_organisation = related_organisation flash[:notice] = "#{@organisation_relationship.parent_organisation.name} is now one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} housing providers"
end
@organisation_relationship = OrganisationRelationship.new(child_organisation:, parent_organisation:)
if @organisation_relationship.save(context: :housing_provider)
flash[:notice] = "#{related_organisation.name} is now one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} housing providers"
redirect_to housing_providers_organisation_path redirect_to housing_providers_organisation_path
else else
@organisations = Organisation.where.not(id: child_organisation.id).pluck(:id, :name) @organisations = Organisation.where.not(id: organisation.id).pluck(:id, :name)
render "organisation_relationships/add_housing_provider", status: :unprocessable_entity render "organisation_relationships/add_housing_provider", status: :unprocessable_entity
end end
end end
def create_managing_agent def create_managing_agent
parent_organisation = @organisation @organisation_relationship = organisation.child_organisation_relationships.new(organisation_relationship_params)
if params[:organisation_relationship].present? && params[:organisation_relationship][:related_organisation_id].present? if @organisation_relationship.save
child_organisation = related_organisation flash[:notice] = "#{@organisation_relationship.child_organisation.name} is now one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} managing agents"
end
@organisation_relationship = OrganisationRelationship.new(child_organisation:, parent_organisation:)
if @organisation_relationship.save(context: :managing_agent)
flash[:notice] = "#{related_organisation.name} is now one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} managing agents"
redirect_to managing_agents_organisation_path redirect_to managing_agents_organisation_path
else else
@organisations = Organisation.where.not(id: parent_organisation.id).pluck(:id, :name) @organisations = Organisation.where.not(id: organisation.id).pluck(:id, :name)
render "organisation_relationships/add_managing_agent", status: :unprocessable_entity render "organisation_relationships/add_managing_agent", status: :unprocessable_entity
end end
end end
def remove_housing_provider def remove_housing_provider; end
@target_organisation_id = target_organisation.id def remove_managing_agent; end
end
def delete_housing_provider def delete_housing_provider
relationship = OrganisationRelationship.find_by!( OrganisationRelationship.find_by!(
child_organisation: @organisation, child_organisation: organisation,
parent_organisation: target_organisation, parent_organisation: target_organisation,
) ).destroy!
relationship.destroy!
flash[:notice] = "#{target_organisation.name} is no longer one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} housing providers" flash[:notice] = "#{target_organisation.name} is no longer one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} housing providers"
redirect_to housing_providers_organisation_path redirect_to housing_providers_organisation_path
end end
def remove_managing_agent
@target_organisation_id = target_organisation.id
end
def delete_managing_agent def delete_managing_agent
relationship = OrganisationRelationship.find_by!( OrganisationRelationship.find_by!(
parent_organisation: @organisation, parent_organisation: organisation,
child_organisation: target_organisation, child_organisation: target_organisation,
) ).destroy!
relationship.destroy!
flash[:notice] = "#{target_organisation.name} is no longer one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} managing agents" flash[:notice] = "#{target_organisation.name} is no longer one of #{current_user.data_coordinator? ? 'your' : "this organisation's"} managing agents"
redirect_to managing_agents_organisation_path redirect_to managing_agents_organisation_path
end end
private private
def create!(child_organisation:, parent_organisation:) def organisation
@resource = OrganisationRelationship.new(child_organisation:, parent_organisation:) @organisation ||= if current_user.support?
@resource.save! Organisation.find(params[:id])
else
current_user.organisation
end
end end
def organisation def organisations
@organisation ||= Organisation.find(params[:id]) @organisations ||= Organisation.where.not(id: organisation.id).pluck(:id, :name)
end end
def related_organisation def parent_organisation
@related_organisation ||= Organisation.find(params[:organisation_relationship][:related_organisation_id]) @parent_organisation ||= Organisation.find(params[:organisation_relationship][:parent_organisation_id])
end
def child_organisation
@child_organisation ||= Organisation.find(params[:organisation_relationship][:child_organisation_id])
end end
def target_organisation def target_organisation
@ -118,6 +114,10 @@ private
params["search"] params["search"]
end end
def organisation_relationship_params
params.require(:organisation_relationship).permit(:parent_organisation_id, :child_organisation_id)
end
def authenticate_scope! def authenticate_scope!
if current_user.organisation != organisation && !current_user.support? if current_user.organisation != organisation && !current_user.support?
render_not_found render_not_found

14
app/models/organisation_relationship.rb

@ -1,26 +1,26 @@
class OrganisationRelationship < ApplicationRecord class OrganisationRelationship < ApplicationRecord
belongs_to :child_organisation, class_name: "Organisation" belongs_to :child_organisation, class_name: "Organisation"
belongs_to :parent_organisation, class_name: "Organisation" belongs_to :parent_organisation, class_name: "Organisation"
validate :validate_housing_provider_relationship, on: :housing_provider validate :validate_housing_provider_relationship
validate :validate_managing_agent_relationship, on: :managing_agent validate :validate_managing_agent_relationship
private private
def validate_housing_provider_relationship def validate_housing_provider_relationship
if parent_organisation_id.blank? if parent_organisation_id.blank?
errors.add :related_organisation_id, "You must choose a housing provider" errors.add :parent_organisation_id, "You must choose a housing provider"
elsif OrganisationRelationship.exists?(child_organisation:, parent_organisation:) elsif OrganisationRelationship.exists?(child_organisation:, parent_organisation:)
errors.add :related_organisation_id, "You have already added this housing provider" errors.add :parent_organisation_id, "You have already added this housing provider"
elsif parent_organisation_id.present? && !parent_organisation.holds_own_stock elsif parent_organisation_id.present? && !parent_organisation.holds_own_stock
errors.add :related_organisation_id, I18n.t("validations.scheme.owning_organisation.does_not_own_stock") errors.add :parent_organisation_id, I18n.t("validations.scheme.owning_organisation.does_not_own_stock")
end end
end end
def validate_managing_agent_relationship def validate_managing_agent_relationship
if child_organisation_id.blank? if child_organisation_id.blank?
errors.add :related_organisation_id, "You must choose a managing agent" errors.add :child_organisation_id, "You must choose a managing agent"
elsif OrganisationRelationship.exists?(child_organisation:, parent_organisation:) elsif OrganisationRelationship.exists?(child_organisation:, parent_organisation:)
errors.add :related_organisation_id, "You have already added this managing agent" errors.add :child_organisation_id, "You have already added this managing agent"
end end
end end
end end

2
app/views/organisation_relationships/_related_organisation_select_question.html.erb

@ -1,3 +1,3 @@
<% answers = question.answer_options.map { |key, value| OpenStruct.new(id: key, name: value) } %> <% answers = question.answer_options.map { |key, value| OpenStruct.new(id: key, name: value) } %>
<%= f.govuk_collection_select :related_organisation_id, answers, :id, :name, label: { hidden: true }, "data-controller": "accessible-autocomplete" do %> <%= f.govuk_collection_select field, answers, :id, :name, label: { hidden: true }, "data-controller": "accessible-autocomplete" do %>
<% end %> <% end %>

1
app/views/organisation_relationships/add_housing_provider.html.erb

@ -18,6 +18,7 @@
<% answer_options[organisation[0]] = organisation[1] %> <% answer_options[organisation[0]] = organisation[1] %>
<% end %> <% end %>
<%= render partial: "organisation_relationships/related_organisation_select_question", locals: { <%= render partial: "organisation_relationships/related_organisation_select_question", locals: {
field: :parent_organisation_id,
question: Form::Question.new("", { "answer_options" => answer_options }, nil), question: Form::Question.new("", { "answer_options" => answer_options }, nil),
f:, f:,
} %> } %>

1
app/views/organisation_relationships/add_managing_agent.html.erb

@ -18,6 +18,7 @@
<% answer_options[organisation[0]] = organisation[1] %> <% answer_options[organisation[0]] = organisation[1] %>
<% end %> <% end %>
<%= render partial: "organisation_relationships/related_organisation_select_question", locals: { <%= render partial: "organisation_relationships/related_organisation_select_question", locals: {
field: :child_organisation_id,
question: Form::Question.new("", { "answer_options" => answer_options }, nil), question: Form::Question.new("", { "answer_options" => answer_options }, nil),
f:, f:,
} %> } %>

4
app/views/organisation_relationships/remove_managing_agent.html.erb

@ -1,7 +1,7 @@
<%= form_with url: managing_agents_organisation_path(target_organisation_id: @target_organisation.id), method: "delete", local: true do |f| %> <%= form_with url: managing_agents_organisation_path(target_organisation_id: @target_organisation.id), method: "delete", local: true do |f| %>
<% if current_user.support? %> <% if current_user.support? %>
<%= render partial: "organisations/headings", locals: { main: @organisation.name, sub: nil } %> <%= render partial: "organisations/headings", locals: { main: organisation.name, sub: nil } %>
<%= render SubNavigationComponent.new(items: secondary_items(request.path, @organisation.id)) %> <%= render SubNavigationComponent.new(items: secondary_items(request.path, organisation.id)) %>
<h2 class="govuk-visually-hidden">Remove Managing Agent</h2> <h2 class="govuk-visually-hidden">Remove Managing Agent</h2>
<% end %> <% end %>
<% if current_user.support? %> <% if current_user.support? %>

Loading…
Cancel
Save