Browse Source

review comments update

pull/39/head
Matthew Phelan 3 years ago
parent
commit
301ae82a59
  1. 2
      app/controllers/case_logs_controller.rb
  2. 35
      app/models/case_log.rb
  3. 3
      config/forms/2021_2022.json
  4. 1
      db/schema.rb

2
app/controllers/case_logs_controller.rb

@ -26,7 +26,7 @@ class CaseLogsController < ApplicationController
previous_page = params[:case_log][:previous_page] previous_page = params[:case_log][:previous_page]
questions_for_page = form.questions_for_page(previous_page).keys questions_for_page = form.questions_for_page(previous_page).keys
answers_for_page = page_params(questions_for_page).select { |k, _v| questions_for_page.include?(k) } answers_for_page = page_params(questions_for_page).select { |k, _v| questions_for_page.include?(k) }
@case_log.custom_validator_options = { previous_page: previous_page, validation: form.questions_for_page(previous_page)[previous_page]["regex_validation"] } @case_log.previous_page(previous_page)
if @case_log.update(answers_for_page) if @case_log.update(answers_for_page)
redirect_path = form.next_page_redirect_path(previous_page) redirect_path = form.next_page_redirect_path(previous_page)
redirect_to(send(redirect_path, @case_log)) redirect_to(send(redirect_path, @case_log))

35
app/models/case_log.rb

@ -1,32 +1,39 @@
class CaseLogValidator < ActiveModel::Validator class CaseLogValidator < ActiveModel::Validator
def validate_tenant_age(record, validation_regex) # Methods need to be named 'validate_' followed by field name
regexp = Regexp.new validation_regex # this is how the metaprogramming of the method name being
if !record.tenant_age? # call in the validate method works.
def validate_tenant_code(record)
if record.tenant_code.blank?
record.errors.add :tenant_code, "Tenant code can't be blank"
end
end
def validate_tenant_age(record)
if record.tenant_age.blank?
record.errors.add :tenant_age, "Tenant age can't be blank" record.errors.add :tenant_age, "Tenant age can't be blank"
elsif !(record.tenant_age.to_s =~ regexp) elsif !(record.tenant_age.to_s =~ /^[1-9][0-9]?$|^100$/)
record.errors.add :tenant_age, "Tenant age must be between 0 and 100" record.errors.add :tenant_age, "Tenant age must be between 0 and 100"
end end
end end
def validate(record) def validate(record)
question_to_validate = options[:previous_page] question_to_validate = options[:previous_page]
validation_regex = options[:validation] public_send("validate_#{question_to_validate}", record)
if question_to_validate == "tenant_code"
if !record.tenant_code?
record.errors.add :tenant_code, "Tenant code can't be blank"
end
elsif question_to_validate == "tenant_age"
validate_tenant_age(record, validation_regex)
end
end end
end end
class CaseLog < ApplicationRecord class CaseLog < ApplicationRecord
validate :instance_validations validate :instance_validations
attr_accessor :custom_validator_options @previous_page
enum status: { "in progress" => 0, "submitted" => 1 } enum status: { "in progress" => 0, "submitted" => 1 }
def previous_page(value)
@previous_page = value
end
def instance_validations def instance_validations
validates_with CaseLogValidator, (custom_validator_options || {}) validates_with CaseLogValidator, ({ previous_page: @previous_page } || {})
end end
end end

3
config/forms/2021_2022.json

@ -32,8 +32,7 @@
"type": "numeric", "type": "numeric",
"min": 0, "min": 0,
"max": 150, "max": 150,
"step": 1, "step": 1
"regex_validation" : "^[1-9][0-9]?$|^100$"
} }
} }
}, },

1
db/schema.rb

@ -109,6 +109,7 @@ ActiveRecord::Schema.define(version: 2021_10_05_115813) do
t.string "chr_letting" t.string "chr_letting"
t.string "cap_letting" t.string "cap_letting"
t.string "outstanding_rent_or_charges" t.string "outstanding_rent_or_charges"
t.string "other_reason_for_leaving_last_settled_home"
end end
end end

Loading…
Cancel
Save