Browse Source

refactor: combining duplicated logic

pull/959/head
natdeanlewissoftwire 3 years ago
parent
commit
15b569d3f3
  1. 30
      app/models/lettings_log.rb
  2. 26
      app/models/validations/soft_validations.rb

30
app/models/lettings_log.rb

@ -435,35 +435,29 @@ class LettingsLog < Log
Csv::LettingsLogCsvService.new(user).to_csv Csv::LettingsLogCsvService.new(user).to_csv
end end
def soft_min_for_period def validation_beds
beds = if needstype == 2 if needstype == 2
0 0
else else
self.beds.nil? ? nil : [self.beds, 4].min beds.nil? ? nil : [beds, 4].min
end
end end
la = if needstype == 2
def validation_la
if needstype == 2
defined?(location.location_code) ? location.location_code : nil defined?(location.location_code) ? location.location_code : nil
else else
self.la la
end
end end
soft_min = LaRentRange.find_by(start_year: collection_start_year, la:, beds:, lettype:).soft_min def soft_min_for_period
soft_min = LaRentRange.find_by(start_year: collection_start_year, la: validation_la, beds: validation_beds, lettype:).soft_min
"#{soft_value_for_period(soft_min)} #{SUFFIX_FROM_PERIOD[period].presence || 'every week'}" "#{soft_value_for_period(soft_min)} #{SUFFIX_FROM_PERIOD[period].presence || 'every week'}"
end end
def soft_max_for_period def soft_max_for_period
beds = if needstype == 2 soft_max = LaRentRange.find_by(start_year: collection_start_year, la: validation_la, beds: validation_beds, lettype:).soft_max
0
else
self.beds.nil? ? nil : [self.beds, 4].min
end
la = if needstype == 2
defined?(location.location_code) ? location.location_code : nil
else
self.la
end
soft_max = LaRentRange.find_by(start_year: collection_start_year, la:, beds:, lettype:).soft_max
"#{soft_value_for_period(soft_max)} #{SUFFIX_FROM_PERIOD[period].presence || 'every week'}" "#{soft_value_for_period(soft_max)} #{SUFFIX_FROM_PERIOD[period].presence || 'every week'}"
end end

26
app/models/validations/soft_validations.rb

@ -28,36 +28,14 @@ module Validations::SoftValidations
def rent_in_soft_min_range? def rent_in_soft_min_range?
return unless brent && weekly_value(brent) && startdate return unless brent && weekly_value(brent) && startdate
beds = if needstype == 2 rent_range = LaRentRange.find_by(start_year: collection_start_year, la: validation_la, beds: validation_beds, lettype: get_lettype)
0
else
self.beds.nil? ? nil : [self.beds, 4].min
end
la = if needstype == 2
defined?(location.location_code) ? location.location_code : nil
else
self.la
end
rent_range = LaRentRange.find_by(start_year: collection_start_year, la:, beds:, lettype: get_lettype)
rent_range.present? && weekly_value(brent).between?(rent_range.hard_min, rent_range.soft_min) rent_range.present? && weekly_value(brent).between?(rent_range.hard_min, rent_range.soft_min)
end end
def rent_in_soft_max_range? def rent_in_soft_max_range?
return unless brent && weekly_value(brent) && startdate return unless brent && weekly_value(brent) && startdate
beds = if needstype == 2 rent_range = LaRentRange.find_by(start_year: collection_start_year, la: validation_la, beds: validation_beds, lettype: get_lettype)
0
else
self.beds.nil? ? nil : [self.beds, 4].min
end
la = if needstype == 2
defined?(location.location_code) ? location.location_code : nil
else
self.la
end
rent_range = LaRentRange.find_by(start_year: collection_start_year, la:, beds:, lettype: get_lettype)
rent_range.present? && weekly_value(brent).between?(rent_range.soft_max, rent_range.hard_max) rent_range.present? && weekly_value(brent).between?(rent_range.soft_max, rent_range.hard_max)
end end

Loading…
Cancel
Save