76 lines
1.5 KiB
76 lines
1.5 KiB
class BulkUpload < ApplicationRecord |
|
enum log_type: { lettings: "lettings", sales: "sales" } |
|
|
|
belongs_to :user |
|
|
|
has_many :bulk_upload_errors, dependent: :destroy |
|
|
|
has_many :lettings_logs |
|
has_many :sales_logs |
|
|
|
after_initialize :generate_identifier, unless: :identifier |
|
|
|
def year_combo |
|
"#{year}/#{year - 2000 + 1}" |
|
end |
|
|
|
def logs |
|
if lettings? |
|
lettings_logs |
|
else |
|
sales_logs |
|
end |
|
end |
|
|
|
def form |
|
@form ||= if lettings? |
|
FormHandler.instance.lettings_form_for_start_year(year) |
|
else |
|
FormHandler.instance.sales_form_for_start_year(year) |
|
end |
|
end |
|
|
|
def columns_with_errors |
|
bulk_upload_errors |
|
.select(:col) |
|
.distinct(:col) |
|
.pluck(:col) |
|
.sort_by { |col| col.rjust(2, "0") } |
|
end |
|
|
|
def general_needs? |
|
needstype == 1 |
|
end |
|
|
|
def supported_housing? |
|
needstype == 2 |
|
end |
|
|
|
def prefix_namespace |
|
type_class = case log_type |
|
when "lettings" |
|
"Lettings" |
|
when "sales" |
|
"Sales" |
|
else |
|
raise "unknown log type" |
|
end |
|
|
|
year_class = case year |
|
when 2022 |
|
"Year2022" |
|
when 2023 |
|
"Year2023" |
|
else |
|
raise "unknown year" |
|
end |
|
|
|
"BulkUpload::#{type_class}::#{year_class}".constantize |
|
end |
|
|
|
private |
|
|
|
def generate_identifier |
|
self.identifier ||= SecureRandom.uuid |
|
end |
|
end
|
|
|