|
|
|
module LocationsHelper
|
|
|
|
def mobility_type_selection
|
|
|
|
mobility_types_to_display = Location.mobility_types.excluding("Property designed to accessible general standard", "Missing")
|
|
|
|
mobility_types_to_display.map { |key, value| OpenStruct.new(id: key, name: key.to_s.humanize, description: I18n.t("questions.descriptions.location.mobility_type.#{value}")) }
|
|
|
|
end
|
|
|
|
|
|
|
|
def another_location_selection
|
|
|
|
selection_options(%w[Yes No])
|
|
|
|
end
|
|
|
|
|
|
|
|
def type_of_units_selection
|
|
|
|
selection_options(Location.type_of_units)
|
|
|
|
end
|
|
|
|
|
|
|
|
def local_authorities_selection
|
|
|
|
null_option = [OpenStruct.new(id: "", name: "Select an option")]
|
|
|
|
null_option + Location.local_authorities_for_current_year.map { |code, name| OpenStruct.new(code:, name:) }
|
|
|
|
end
|
|
|
|
|
|
|
|
def selection_options(resource)
|
|
|
|
return [] if resource.blank?
|
|
|
|
|
|
|
|
resource.map { |key, _| OpenStruct.new(id: key, name: key.to_s.humanize) }
|
|
|
|
end
|
|
|
|
|
|
|
|
def display_location_attributes(location)
|
|
|
|
[
|
|
|
|
{ name: "Postcode", value: location.postcode, attribute: "postcode" },
|
|
|
|
{ name: "Location name", value: location.name, attribute: "name" },
|
|
|
|
{ name: "Local authority", value: formatted_local_authority_timeline(location, "name"), attribute: "local_authority" },
|
|
|
|
{ name: "Number of units", value: location.units, attribute: "units" },
|
|
|
|
{ name: "Most common unit", value: location.type_of_unit, attribute: "type_of_unit" },
|
|
|
|
{ name: "Mobility standards", value: location.mobility_type, attribute: "mobility_standards" },
|
|
|
|
{ name: "Location code", value: formatted_local_authority_timeline(location, "code"), attribute: "location_code" },
|
|
|
|
{ name: "Availability", value: location_availability(location), attribute: "availability" },
|
|
|
|
{ name: "Status", value: location.status, attribute: "status" },
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
def display_location_attributes_for_check_answers(location)
|
|
|
|
[
|
|
|
|
{ name: "Postcode", value: location.postcode, attribute: "postcode" },
|
|
|
|
{ name: "Location name", value: location.name, attribute: "name" },
|
|
|
|
{ name: "Local authority", value: formatted_local_authority_timeline(location, "name"), attribute: "local_authority" },
|
|
|
|
{ name: "Number of units", value: location.units, attribute: "units" },
|
|
|
|
{ name: "Most common unit", value: location.type_of_unit, attribute: "type_of_unit" },
|
|
|
|
{ name: "Mobility standards", value: location.mobility_type, attribute: "mobility_standards" },
|
|
|
|
{ name: "Availability", value: location&.startdate&.to_formatted_s(:govuk_date), attribute: "availability" },
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
def location_availability(location)
|
|
|
|
availability = ""
|
|
|
|
location_active_periods(location).each do |period|
|
|
|
|
if period.from.present?
|
|
|
|
availability << "\nActive from #{period.from.to_formatted_s(:govuk_date)}"
|
|
|
|
availability << " to #{(period.to - 1.day).to_formatted_s(:govuk_date)}\nDeactivated on #{period.to.to_formatted_s(:govuk_date)}" if period.to.present?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
availability.strip
|
|
|
|
end
|
|
|
|
|
|
|
|
def location_edit_path(location, attribute)
|
|
|
|
send("scheme_location_#{attribute}_path", location.scheme, location, referrer: "check_answers", route: params[:route])
|
|
|
|
end
|
|
|
|
|
|
|
|
def action_text_helper(attr, location)
|
|
|
|
attr[:value].blank? || (attr[:attribute] == "availability" && location.startdate.blank?) ? "Answer" : "Change"
|
|
|
|
end
|
|
|
|
|
|
|
|
def toggle_location_link(location)
|
|
|
|
return govuk_button_link_to "Deactivate this location", scheme_location_new_deactivation_path(location.scheme, location), warning: true if location.active?
|
|
|
|
return govuk_button_link_to "Reactivate this location", scheme_location_new_reactivation_path(location.scheme, location) if location.deactivated?
|
|
|
|
end
|
|
|
|
|
|
|
|
def location_creation_success_notice(location)
|
|
|
|
if location.confirmed
|
|
|
|
"#{location.postcode} #{location.startdate.blank? || location.startdate.before?(Time.zone.now) ? 'has been' : 'will be'} added to this scheme"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def user_can_edit_scheme?(user, scheme)
|
|
|
|
user.support? || user.organisation == scheme.owning_organisation
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
ActivePeriod = Struct.new(:from, :to)
|
|
|
|
def location_active_periods(location)
|
|
|
|
periods = [ActivePeriod.new(location.available_from, nil)]
|
|
|
|
|
|
|
|
sorted_deactivation_periods = remove_nested_periods(location.location_deactivation_periods.sort_by(&:deactivation_date))
|
|
|
|
sorted_deactivation_periods.each do |deactivation|
|
|
|
|
periods.last.to = deactivation.deactivation_date
|
|
|
|
periods << ActivePeriod.new(deactivation.reactivation_date, nil)
|
|
|
|
end
|
|
|
|
|
|
|
|
remove_overlapping_and_empty_periods(periods)
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_overlapping_and_empty_periods(periods)
|
|
|
|
periods.select { |period| period.from.present? && (period.to.nil? || period.from < period.to) }
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_nested_periods(periods)
|
|
|
|
periods.select { |inner_period| periods.none? { |outer_period| is_nested?(inner_period, outer_period) } }
|
|
|
|
end
|
|
|
|
|
|
|
|
def is_nested?(inner, outer)
|
|
|
|
return false if inner == outer
|
|
|
|
return false if [inner.deactivation_date, inner.reactivation_date, outer.deactivation_date, outer.reactivation_date].any?(&:blank?)
|
|
|
|
|
|
|
|
[inner.deactivation_date, inner.reactivation_date].all? { |date| date.between?(outer.deactivation_date, outer.reactivation_date) }
|
|
|
|
end
|
|
|
|
|
|
|
|
def formatted_local_authority_timeline(location, field)
|
|
|
|
sorted_linked_authorities = location.linked_local_authorities.sort_by(&:start_date)
|
|
|
|
return sorted_linked_authorities.first[field] if sorted_linked_authorities.count == 1
|
|
|
|
|
|
|
|
sorted_linked_authorities.map { |linked_local_authority|
|
|
|
|
formatted_start_date = linked_local_authority.start_date.year == 2021 ? "until" : "#{linked_local_authority.start_date&.to_formatted_s(:govuk_date)} -"
|
|
|
|
formatted_end_date = linked_local_authority.end_date&.to_formatted_s(:govuk_date) || "present"
|
|
|
|
"#{linked_local_authority[field]} (#{formatted_start_date} #{formatted_end_date})"
|
|
|
|
}.join("\n")
|
|
|
|
end
|
|
|
|
end
|