diff --git a/app/models/form/sales/pages/mortgage_value_check.rb b/app/models/form/sales/pages/mortgage_value_check.rb new file mode 100644 index 000000000..0495f4f4f --- /dev/null +++ b/app/models/form/sales/pages/mortgage_value_check.rb @@ -0,0 +1,21 @@ +class Form::Sales::Pages::MortgageValueCheck < ::Form::Page + def initialize(id, hsh, subsection) + super + @id = "mortgage_value_check" + @header = "" + @description = "" + @subsection = subsection + @depends_on = [ + { + "mortgage_over_soft_max?" => true, + }, + ] + @informative_text = {} + end + + def questions + @questions ||= [ + Form::Sales::Questions::MortgageValueCheck.new(nil, nil, self), + ] + end +end diff --git a/app/models/form/sales/questions/mortgage_value_check.rb b/app/models/form/sales/questions/mortgage_value_check.rb new file mode 100644 index 000000000..9d063f428 --- /dev/null +++ b/app/models/form/sales/questions/mortgage_value_check.rb @@ -0,0 +1,25 @@ +class Form::Sales::Questions::MortgageValueCheck < ::Form::Question + def initialize(id, hsh, page) + super + @id = "mortgage_value_check" + @check_answer_label = "Mortgage confirmation" + @header = "Are you sure that the mortgage is more than 5 times the income used for the mortgage application?" + @type = "interruption_screen" + @answer_options = { + "0" => { "value" => "Yes" }, + "1" => { "value" => "No" }, + } + @hidden_in_check_answers = { + "depends_on" => [ + { + "mortgage_value_check" => 0, + }, + { + "mortgage_value_check" => 1, + }, + ], + } + @check_answers_card_number = 1 + @page = page + end +end diff --git a/app/models/form/sales/subsections/income_benefits_and_savings.rb b/app/models/form/sales/subsections/income_benefits_and_savings.rb index ca76bb588..447aba589 100644 --- a/app/models/form/sales/subsections/income_benefits_and_savings.rb +++ b/app/models/form/sales/subsections/income_benefits_and_savings.rb @@ -13,6 +13,7 @@ class Form::Sales::Subsections::IncomeBenefitsAndSavings < ::Form::Subsection Form::Sales::Pages::Buyer1IncomeValueCheck.new(nil, nil, self), Form::Sales::Pages::Buyer1Mortgage.new(nil, nil, self), Form::Sales::Pages::Buyer2Income.new(nil, nil, self), + Form::Sales::Pages::MortgageValueCheck.new(nil, nil, self), Form::Sales::Pages::Savings.new(nil, nil, self), Form::Sales::Pages::PreviousOwnership.new(nil, nil, self), ] diff --git a/app/models/validations/sales/soft_validations.rb b/app/models/validations/sales/soft_validations.rb index 5d3dce615..478ce6647 100644 --- a/app/models/validations/sales/soft_validations.rb +++ b/app/models/validations/sales/soft_validations.rb @@ -12,4 +12,8 @@ module Validations::Sales::SoftValidations income1 < ALLOWED_INCOME_RANGES[ecstat1][:soft_min] end + + def mortgage_over_soft_max? + true + end end diff --git a/spec/factories/sales_log.rb b/spec/factories/sales_log.rb index 945b58201..6186d1af9 100644 --- a/spec/factories/sales_log.rb +++ b/spec/factories/sales_log.rb @@ -56,11 +56,13 @@ FactoryBot.define do inc1mort { 1 } income2nk { 0 } income2 { 10_000 } + inc2mort { 1 } la_known { "1" } la { "E09000003" } savingsnk { 1 } prevown { 1 } sex3 { "X" } + mortgage { 20_000 } end end end diff --git a/spec/models/form/sales/pages/mortgage_value_check_spec.rb b/spec/models/form/sales/pages/mortgage_value_check_spec.rb new file mode 100644 index 000000000..4083df07b --- /dev/null +++ b/spec/models/form/sales/pages/mortgage_value_check_spec.rb @@ -0,0 +1,33 @@ +require "rails_helper" + +RSpec.describe Form::Sales::Pages::MortgageValueCheck, type: :model do + subject(:page) { described_class.new(page_id, page_definition, subsection) } + + let(:page_id) { nil } + let(:page_definition) { nil } + let(:subsection) { instance_double(Form::Subsection) } + + it "has correct subsection" do + expect(page.subsection).to eq(subsection) + end + + it "has correct questions" do + expect(page.questions.map(&:id)).to eq(%w[mortgage_value_check]) + end + + it "has the correct id" do + expect(page.id).to eq("mortgage_value_check") + end + + it "has the correct header" do + expect(page.header).to eq("") + end + + it "has correct depends_on" do + expect(page.depends_on).to eq([ + { + "mortgage_over_soft_max?" => true, + }, + ]) + end +end diff --git a/spec/models/form/sales/questions/mortgage_value_check_spec.rb b/spec/models/form/sales/questions/mortgage_value_check_spec.rb new file mode 100644 index 000000000..7abc07e1f --- /dev/null +++ b/spec/models/form/sales/questions/mortgage_value_check_spec.rb @@ -0,0 +1,61 @@ +require "rails_helper" + +RSpec.describe Form::Sales::Questions::MortgageValueCheck, type: :model do + subject(:question) { described_class.new(question_id, question_definition, page) } + + let(:question_id) { nil } + let(:question_definition) { nil } + let(:page) { instance_double(Form::Page) } + + it "has correct page" do + expect(question.page).to eq(page) + end + + it "has the correct id" do + expect(question.id).to eq("mortgage_value_check") + end + + it "has the correct header" do + expect(question.header).to eq("Are you sure that the mortgage is more than 5 times the income used for the mortgage application?") + end + + it "has the correct check_answer_label" do + expect(question.check_answer_label).to eq("Mortgage confirmation") + end + + it "has the correct type" do + expect(question.type).to eq("interruption_screen") + end + + it "is not marked as derived" do + expect(question.derived?).to be false + end + + it "has the correct hint" do + expect(question.hint_text).to be_nil + end + + it "has a correct check_answers_card_number" do + expect(question.check_answers_card_number).to eq(1) + end + + it "has the correct answer_options" do + expect(question.answer_options).to eq({ + "0" => { "value" => "Yes" }, + "1" => { "value" => "No" }, + }) + end + + it "has the correct hidden_in_check_answers" do + expect(question.hidden_in_check_answers).to eq({ + "depends_on" => [ + { + "mortgage_value_check" => 0, + }, + { + "mortgage_value_check" => 1, + }, + ], + }) + end +end diff --git a/spec/models/form/sales/subsections/income_benefits_and_savings_spec.rb b/spec/models/form/sales/subsections/income_benefits_and_savings_spec.rb index 0000f108f..86af4c67a 100644 --- a/spec/models/form/sales/subsections/income_benefits_and_savings_spec.rb +++ b/spec/models/form/sales/subsections/income_benefits_and_savings_spec.rb @@ -18,6 +18,7 @@ RSpec.describe Form::Sales::Subsections::IncomeBenefitsAndSavings, type: :model buyer_1_income_value_check buyer_1_mortgage buyer_2_income + mortgage_value_check savings previous_ownership ], diff --git a/spec/models/form_handler_spec.rb b/spec/models/form_handler_spec.rb index 692b9d2f5..0f1cdc5da 100644 --- a/spec/models/form_handler_spec.rb +++ b/spec/models/form_handler_spec.rb @@ -52,14 +52,14 @@ RSpec.describe FormHandler do it "is able to load a current sales form" do form = form_handler.get_form("current_sales") expect(form).to be_a(Form) - expect(form.pages.count).to eq(52) + expect(form.pages.count).to eq(53) expect(form.name).to eq("2022_2023_sales") end it "is able to load a previous sales form" do form = form_handler.get_form("previous_sales") expect(form).to be_a(Form) - expect(form.pages.count).to eq(52) + expect(form.pages.count).to eq(53) expect(form.name).to eq("2021_2022_sales") end end