Browse Source

Merge remote-tracking branch 'origin/CLDC-1671-deactivate-scheme' into CLDC-1671-deactivate-scheme

# Conflicts:
#	db/schema.rb
pull/980/head
natdeanlewissoftwire 2 years ago
parent
commit
04cf9ec5c7
  1. 26
      app/controllers/locations_controller.rb
  2. 24
      app/controllers/schemes_controller.rb
  3. 2
      app/models/form_handler.rb
  4. 4
      app/models/location.rb
  5. 4
      app/models/scheme.rb
  6. 6
      app/views/locations/deactivate_confirm.html.erb
  7. 2
      app/views/locations/toggle_active.html.erb
  8. 6
      app/views/schemes/deactivate_confirm.html.erb
  9. 9
      db/schema.rb
  10. 2
      spec/models/form_handler_spec.rb

26
app/controllers/locations_controller.rb

@ -24,7 +24,7 @@ class LocationsController < ApplicationController
if params[:location].blank? if params[:location].blank?
render "toggle_active", locals: { action: "deactivate" } render "toggle_active", locals: { action: "deactivate" }
else else
@location.run_deactivation_validations = true @location.run_deactivation_validations!
@location.deactivation_date = deactivation_date @location.deactivation_date = deactivation_date
@location.deactivation_date_type = params[:location][:deactivation_date_type] @location.deactivation_date_type = params[:location][:deactivation_date_type]
if @location.valid? if @location.valid?
@ -36,14 +36,17 @@ class LocationsController < ApplicationController
end end
def deactivate_confirm def deactivate_confirm
render "toggle_active_confirm", locals: { action: "deactivate", deactivation_date: params[:deactivation_date], deactivation_date_type: params[:deactivation_date_type] } @deactivation_date = params[:deactivation_date]
@deactivation_date_type = params[:deactivation_date_type]
end end
def deactivate def deactivate
@location.run_deactivation_validations = true @location.run_deactivation_validations!
@location.deactivation_date = deactivation_date
@location.deactivation_date_type = params[:location][:deactivation_date_type] if @location.update!(deactivation_date:)
confirm_deactivation flash[:notice] = deactivate_success_notice
end
redirect_to scheme_location_path(@scheme, @location)
end end
def reactivate def reactivate
@ -177,14 +180,7 @@ private
location_params["location_admin_district"] != "Select an option" location_params["location_admin_district"] != "Select an option"
end end
def confirm_deactivation def deactivate_success_notice
if @location.update!(deactivation_date: @location.deactivation_date)
flash[:notice] = success_text
end
redirect_to scheme_location_path(@scheme, @location)
end
def success_text
case @location.status case @location.status
when :deactivated when :deactivated
"#{@location.name} has been deactivated" "#{@location.name} has been deactivated"
@ -207,6 +203,6 @@ private
year = params[:location]["deactivation_date(1i)"] year = params[:location]["deactivation_date(1i)"]
return nil if [day, month, year].any?(&:blank?) return nil if [day, month, year].any?(&:blank?)
Time.utc(year.to_i, month.to_i, day.to_i) if Date.valid_date?(year.to_i, month.to_i, day.to_i) Time.zone.local(year.to_i, month.to_i, day.to_i) if Date.valid_date?(year.to_i, month.to_i, day.to_i)
end end
end end

24
app/controllers/schemes_controller.rb

@ -37,14 +37,17 @@ class SchemesController < ApplicationController
end end
def deactivate_confirm def deactivate_confirm
render "toggle_active_confirm", locals: { action: "deactivate", deactivation_date: params[:deactivation_date], deactivation_date_type: params[:deactivation_date_type] } @deactivation_date = params[:deactivation_date]
@deactivation_date_type = params[:deactivation_date_type]
end end
def deactivate def deactivate
@scheme.run_deactivation_validations = true @scheme.run_deactivation_validations!
@scheme.deactivation_date = deactivation_date
@scheme.deactivation_date_type = params[:scheme][:deactivation_date_type] if @scheme.update!(deactivation_date:)
confirm_deactivation flash[:notice] = deactivate_success_notice
end
redirect_to scheme_details_path(@scheme)
end end
def reactivate def reactivate
@ -291,14 +294,7 @@ private
redirect_to @scheme if @scheme.confirmed? redirect_to @scheme if @scheme.confirmed?
end end
def confirm_deactivation def deactivate_success_notice
if @scheme.update!(deactivation_date: @scheme.deactivation_date)
flash[:notice] = success_text
end
redirect_to scheme_details_path(@scheme)
end
def success_text
case @scheme.status case @scheme.status
when :deactivated when :deactivated
"#{@scheme.service_name} has been deactivated" "#{@scheme.service_name} has been deactivated"
@ -321,6 +317,6 @@ private
year = params[:scheme]["deactivation_date(1i)"] year = params[:scheme]["deactivation_date(1i)"]
return nil if [day, month, year].any?(&:blank?) return nil if [day, month, year].any?(&:blank?)
Time.utc(year.to_i, month.to_i, day.to_i) if Date.valid_date?(year.to_i, month.to_i, day.to_i) Time.zone.local(year.to_i, month.to_i, day.to_i) if Date.valid_date?(year.to_i, month.to_i, day.to_i)
end end
end end

2
app/models/form_handler.rb

@ -50,7 +50,7 @@ class FormHandler
end end
def current_collection_start_date def current_collection_start_date
Time.utc(current_collection_start_year, 4, 1) Time.zone.local(current_collection_start_year, 4, 1)
end end
def form_name_from_start_year(year, type) def form_name_from_start_year(year, type)

4
app/models/location.rb

@ -384,6 +384,10 @@ class Location < ApplicationRecord
status == :active status == :active
end end
def run_deactivation_validations!
@run_deactivation_validations = true
end
def implicit_run_deactivation_validations def implicit_run_deactivation_validations
deactivation_date.present? || @run_deactivation_validations deactivation_date.present? || @run_deactivation_validations
end end

4
app/models/scheme.rb

@ -226,6 +226,10 @@ class Scheme < ApplicationRecord
status == :active status == :active
end end
def run_deactivation_validations!
@run_deactivation_validations = true
end
def implicit_run_deactivation_validations def implicit_run_deactivation_validations
deactivation_date.present? || @run_deactivation_validations deactivation_date.present? || @run_deactivation_validations
end end

6
app/views/locations/toggle_active_confirm.html.erb → app/views/locations/deactivate_confirm.html.erb

@ -8,10 +8,10 @@
</h1> </h1>
<%= govuk_warning_text text: I18n.t("warnings.location.deactivation.review_logs") %> <%= govuk_warning_text text: I18n.t("warnings.location.deactivation.review_logs") %>
<%= f.hidden_field :confirm, value: true %> <%= f.hidden_field :confirm, value: true %>
<%= f.hidden_field :deactivation_date, value: deactivation_date %> <%= f.hidden_field :deactivation_date, value: @deactivation_date %>
<%= f.hidden_field :deactivation_date_type, value: deactivation_date_type %> <%= f.hidden_field :deactivation_date_type, value: @deactivation_date_type %>
<div class="govuk-button-group"> <div class="govuk-button-group">
<%= f.govuk_submit "Deactivate this location" %> <%= f.govuk_submit "Deactivate this location" %>
<%= govuk_button_link_to "Cancel", scheme_location_path(scheme_id: @scheme, id: @location.id), html: { method: :get }, secondary: true %> <%= govuk_button_link_to "Cancel", scheme_location_path(@scheme, @location), html: { method: :get }, secondary: true %>
</div> </div>
<% end %> <% end %>

2
app/views/locations/toggle_active.html.erb

@ -4,7 +4,7 @@
<% content_for :before_content do %> <% content_for :before_content do %>
<%= govuk_back_link( <%= govuk_back_link(
text: "Back", text: "Back",
href: scheme_location_path(scheme_id: @location.scheme.id, id: @location.id), href: scheme_location_path(@location.scheme, @location),
) %> ) %>
<% end %> <% end %>

6
app/views/schemes/toggle_active_confirm.html.erb → app/views/schemes/deactivate_confirm.html.erb

@ -1,4 +1,4 @@
<% title = "#{action.humanize} #{@scheme.service_name}" %> <% title = "Deactivate #{@scheme.service_name}" %>
<% content_for :title, title %> <% content_for :title, title %>
<%= form_with model: @scheme, url: scheme_deactivate_path(@scheme), method: "patch", local: true do |f| %> <%= form_with model: @scheme, url: scheme_deactivate_path(@scheme), method: "patch", local: true do |f| %>
<% content_for :before_content do %> <% content_for :before_content do %>
@ -10,8 +10,8 @@
</h1> </h1>
<%= govuk_warning_text text: I18n.t("warnings.scheme.deactivation.review_logs") %> <%= govuk_warning_text text: I18n.t("warnings.scheme.deactivation.review_logs") %>
<%= f.hidden_field :confirm, value: true %> <%= f.hidden_field :confirm, value: true %>
<%= f.hidden_field :deactivation_date, value: deactivation_date %> <%= f.hidden_field :deactivation_date, value: @deactivation_date %>
<%= f.hidden_field :deactivation_date_type, value: deactivation_date_type %> <%= f.hidden_field :deactivation_date_type, value: @deactivation_date_type %>
<div class="govuk-button-group"> <div class="govuk-button-group">
<%= f.govuk_submit "#{action.humanize} this scheme" %> <%= f.govuk_submit "#{action.humanize} this scheme" %>
<%= govuk_button_link_to "Cancel", scheme_details_path(@scheme), html: { method: :get }, secondary: true %> <%= govuk_button_link_to "Cancel", scheme_details_path(@scheme), html: { method: :get }, secondary: true %>

9
db/schema.rb

@ -360,16 +360,16 @@ ActiveRecord::Schema[7.0].define(version: 2022_11_11_102656) do
t.integer "hholdcount" t.integer "hholdcount"
t.integer "age3" t.integer "age3"
t.integer "age3_known" t.integer "age3_known"
t.string "la"
t.integer "la_known"
t.integer "income1"
t.integer "income1nk"
t.integer "age4" t.integer "age4"
t.integer "age4_known" t.integer "age4_known"
t.integer "age5" t.integer "age5"
t.integer "age5_known" t.integer "age5_known"
t.integer "age6" t.integer "age6"
t.integer "age6_known" t.integer "age6_known"
t.string "la"
t.integer "la_known"
t.integer "income1"
t.integer "income1nk"
t.integer "details_known_2" t.integer "details_known_2"
t.integer "details_known_3" t.integer "details_known_3"
t.integer "details_known_4" t.integer "details_known_4"
@ -398,6 +398,7 @@ ActiveRecord::Schema[7.0].define(version: 2022_11_11_102656) do
t.string "old_visible_id" t.string "old_visible_id"
t.integer "total_units" t.integer "total_units"
t.boolean "confirmed" t.boolean "confirmed"
t.datetime "deactivation_date"
t.index ["managing_organisation_id"], name: "index_schemes_on_managing_organisation_id" t.index ["managing_organisation_id"], name: "index_schemes_on_managing_organisation_id"
t.index ["owning_organisation_id"], name: "index_schemes_on_owning_organisation_id" t.index ["owning_organisation_id"], name: "index_schemes_on_owning_organisation_id"
end end

2
spec/models/form_handler_spec.rb

@ -120,7 +120,7 @@ RSpec.describe FormHandler do
end end
it "returns the correct current start date" do it "returns the correct current start date" do
expect(form_handler.current_collection_start_date).to eq(Time.utc(2022, 4, 1)) expect(form_handler.current_collection_start_date).to eq(Time.zone.local(2022, 4, 1))
end end
end end

Loading…
Cancel
Save