Browse Source
			
			
			
			
				
		* feat: core functionality * feat: update schema.rb * feat: add link for privacy notice, refactor to separate tenant/buyer * feat: make privacy notices open in new tab * test: make previous tests pass * test: add new testspull/932/head v0.2.12
				 13 changed files with 133 additions and 10 deletions
			
			
		| @ -0,0 +1,18 @@ | ||||
| class Form::Sales::Pages::PrivacyNotice < ::Form::Page | ||||
|   def initialize(id, hsh, subsection) | ||||
|     super | ||||
|     @id = "privacy_notice" | ||||
|     @header = "Department for Levelling Up, Housing and Communities privacy notice" | ||||
|     @description = "" | ||||
|     @subsection = subsection | ||||
|     @depends_on = [{ | ||||
|       "noint" => 1, | ||||
|     }] | ||||
|   end | ||||
| 
 | ||||
|   def questions | ||||
|     @questions ||= [ | ||||
|       Form::Sales::Questions::PrivacyNotice.new(nil, nil, self), | ||||
|     ] | ||||
|   end | ||||
| end | ||||
| @ -0,0 +1,18 @@ | ||||
| class Form::Sales::Questions::PrivacyNotice < ::Form::Question | ||||
|   def initialize(id, hsh, page) | ||||
|     super | ||||
|     @id = "privacynotice" | ||||
|     @check_answer_label = "Buyer has seen the privacy notice?" | ||||
|     @header = "Declaration" | ||||
|     @type = "checkbox" | ||||
|     @hint_text = "" | ||||
|     @page = page | ||||
|     @answer_options = ANSWER_OPTIONS | ||||
|     @guidance_position = GuidancePosition::TOP | ||||
|     @guidance_partial = "privacy_notice_buyer" | ||||
|   end | ||||
| 
 | ||||
|   ANSWER_OPTIONS = { | ||||
|     "privacynotice" => { "value" => "The buyer has seen the DLUHC privacy notice" }, | ||||
|   }.freeze | ||||
| end | ||||
| @ -0,0 +1 @@ | ||||
| <p class="govuk-body">Make sure the buyer has seen <%= govuk_link_to "the Department for Levelling Up, Housing & Communities (DLUHC) privacy notice", privacy_notice_path, target: :_blank %> before completing this log.</p> | ||||
| @ -1 +1 @@ | ||||
| <p class="govuk-body">Make sure the tenant has seen <%= govuk_link_to "the Department for Levelling Up, Housing & Communities (DLUHC) privacy notice", privacy_notice_path %> before completing this log.</p> | ||||
| <p class="govuk-body">Make sure the tenant has seen <%= govuk_link_to "the Department for Levelling Up, Housing & Communities (DLUHC) privacy notice", privacy_notice_path, target: :_blank %> before completing this log.</p> | ||||
| @ -0,0 +1,7 @@ | ||||
| class AddPrivacyNoticeToSalesLog < ActiveRecord::Migration[7.0] | ||||
|   def change | ||||
|     change_table :sales_logs, bulk: true do |t| | ||||
|       t.column :privacynotice, :int | ||||
|     end | ||||
|   end | ||||
| end | ||||
| @ -0,0 +1,33 @@ | ||||
| require "rails_helper" | ||||
| 
 | ||||
| RSpec.describe Form::Sales::Pages::PrivacyNotice, 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[privacynotice]) | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct id" do | ||||
|     expect(page.id).to eq("privacy_notice") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct header" do | ||||
|     expect(page.header).to eq("Department for Levelling Up, Housing and Communities privacy notice") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct description" do | ||||
|     expect(page.description).to eq("") | ||||
|   end | ||||
| 
 | ||||
|   it "has correct depends_on" do | ||||
|     expect(page.depends_on).to eq([{ "noint" => 1 }]) | ||||
|   end | ||||
| end | ||||
| @ -0,0 +1,43 @@ | ||||
| require "rails_helper" | ||||
| 
 | ||||
| RSpec.describe Form::Sales::Questions::PrivacyNotice, 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("privacynotice") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct header" do | ||||
|     expect(question.header).to eq("Declaration") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct check_answer_label" do | ||||
|     expect(question.check_answer_label).to eq("Buyer has seen the privacy notice?") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct type" do | ||||
|     expect(question.type).to eq("checkbox") | ||||
|   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 eq("") | ||||
|   end | ||||
| 
 | ||||
|   it "has the correct answer_options" do | ||||
|     expect(question.answer_options).to eq({ | ||||
|       "privacynotice" => { "value" => "The buyer has seen the DLUHC privacy notice" }, | ||||
|     }) | ||||
|   end | ||||
| end | ||||
					Loading…
					
					
				
		Reference in new issue