module Validations::Sales::FinancialValidations # Validations methods need to be called 'validate_' to run on model save # or 'validate_' to run on submit as well def validate_income1(record) return unless record.ecstat1 && record.income1 && record.la && record.ownershipsch == 1 relevant_fields = %i[income1 ecstat1 ownershipsch la postcode_full] if record.london_property? && record.income1 > 90_000 relevant_fields.each { |field| record.errors.add field, I18n.t("validations.financial.income.over_hard_max", hard_max: 90_000) } elsif record.property_not_in_london? && record.income1 > 80_000 relevant_fields.each { |field| record.errors.add field, I18n.t("validations.financial.income.over_hard_max", hard_max: 80_000) } end end def validate_income2(record) return unless record.ecstat2 && record.income2 && record.la && record.ownershipsch == 1 relevant_fields = %i[income2 ecstat2 ownershipsch la postcode_full] if record.london_property? && record.income2 > 90_000 relevant_fields.each { |field| record.errors.add field, I18n.t("validations.financial.income.over_hard_max", hard_max: 90_000) } elsif record.property_not_in_london? && record.income2 > 80_000 relevant_fields.each { |field| record.errors.add field, I18n.t("validations.financial.income.over_hard_max", hard_max: 80_000) } end end def validate_combined_income(record) return unless record.ecstat1 && record.income1 && record.ecstat2 && record.income2 && record.la && record.ownershipsch == 1 combined_income = record.income1 + record.income2 relevant_fields = %i[income1 ecstat1 income2 ecstat2 ownershipsch la postcode_full] if record.london_property? && combined_income > 90_000 relevant_fields.each { |field| record.errors.add field, I18n.t("validations.financial.income.combined_over_hard_max", hard_max: 90_000) } elsif record.property_not_in_london? && combined_income > 80_000 relevant_fields.each { |field| record.errors.add field, I18n.t("validations.financial.income.combined_over_hard_max", hard_max: 80_000) } end end def validate_cash_discount(record) return unless record.cashdis unless record.cashdis.between?(0, 999_999) record.errors.add :cashdis, I18n.t("validations.financial.cash_discount_invalid") end end def validate_percentage_bought_not_greater_than_percentage_owned(record) return unless record.stairbought && record.stairowned if record.stairbought > record.stairowned record.errors.add :stairowned, I18n.t("validations.financial.staircasing.percentage_bought_must_be_greater_than_percentage_owned") end end def validate_percentage_owned_not_too_much_if_older_person(record) return unless record.old_persons_shared_ownership? && record.stairowned if record.stairowned > 75 record.errors.add :stairowned, I18n.t("validations.financial.staircasing.older_person_percentage_owned_maximum_75") record.errors.add :type, I18n.t("validations.financial.staircasing.older_person_percentage_owned_maximum_75") end end end