|
|
|
module Validations::PropertyValidations
|
|
|
|
# Validations methods need to be called 'validate_<page_name>' to run on model save
|
|
|
|
# or 'validate_' to run on submit as well
|
|
|
|
include Constants::CaseLog
|
|
|
|
|
|
|
|
POSTCODE_REGEXP = /^(([A-Z]{1,2}[0-9][A-Z0-9]?|ASCN|STHL|TDCU|BBND|[BFS]IQQ|PCRN|TKCA) ?[0-9][A-Z]{2}|BFPO ?[0-9]{1,4}|(KY[0-9]|MSR|VG|AI)[ -]?[0-9]{4}|[A-Z]{2} ?[0-9]{2}|GE ?CX|GIR ?0A{2}|SAN ?TA1)$/i
|
|
|
|
|
|
|
|
def validate_property_number_of_times_relet(record)
|
|
|
|
return unless record.offered
|
|
|
|
|
|
|
|
# Since offered is an integer type ActiveRecord will automatically cast that for us
|
|
|
|
# but it's type casting is a little lax so "random" becomes 0. To make sure that doesn't pass
|
|
|
|
# validation and then get silently dropped we attempt strict type casting on the original value
|
|
|
|
# as part of our validation.
|
|
|
|
begin
|
|
|
|
Integer(record.offered_before_type_cast)
|
|
|
|
rescue ArgumentError
|
|
|
|
record.errors.add :offered, I18n.t("validations.property.offered.relet_number")
|
|
|
|
end
|
|
|
|
|
|
|
|
if record.offered.negative? || record.offered > 20
|
|
|
|
record.errors.add :offered, I18n.t("validations.property.offered.relet_number")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def validate_la(record)
|
|
|
|
if record.la.present? && !LONDON_BOROUGHS.include?(record.la) && (record.rent_type == "London Affordable rent" || record.rent_type == "London living rent")
|
|
|
|
record.errors.add :la, I18n.t("validations.property.la.london_rent")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
FIRST_LET_VACANCY_REASONS = ["First let of new-build property",
|
|
|
|
"First let of conversion, rehabilitation or acquired property",
|
|
|
|
"First let of leased property"].freeze
|
|
|
|
def validate_rsnvac(record)
|
|
|
|
if !record.first_time_property_let_as_social_housing? && FIRST_LET_VACANCY_REASONS.include?(record.rsnvac)
|
|
|
|
record.errors.add :rsnvac, I18n.t("validations.property.rsnvac.first_let_not_social")
|
|
|
|
end
|
|
|
|
|
|
|
|
if record.first_time_property_let_as_social_housing? && record.rsnvac.present? && !FIRST_LET_VACANCY_REASONS.include?(record.rsnvac)
|
|
|
|
record.errors.add :rsnvac, I18n.t("validations.property.rsnvac.first_let_social")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def validate_unitletas(record)
|
|
|
|
if record.first_time_property_let_as_social_housing? && record.unitletas.present?
|
|
|
|
record.errors.add :unitletas, I18n.t("validations.property.rsnvac.previous_let_social")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def validate_property_postcode(record)
|
|
|
|
postcode = record.property_postcode
|
|
|
|
if record.postcode_known == "Yes" && (postcode.blank? || !postcode.match(POSTCODE_REGEXP))
|
|
|
|
error_message = I18n.t("validations.postcode")
|
|
|
|
record.errors.add :property_postcode, error_message
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|