|
|
|
class BulkUpload::LogToCsv
|
|
|
|
attr_reader :log, :line_ending, :col_offset, :overrides
|
|
|
|
|
|
|
|
def initialize(log:, line_ending: "\n", col_offset: 1, overrides: {})
|
|
|
|
@log = log
|
|
|
|
@line_ending = line_ending
|
|
|
|
@col_offset = col_offset
|
|
|
|
@overrides = overrides
|
|
|
|
end
|
|
|
|
|
|
|
|
def to_csv_row
|
|
|
|
[
|
|
|
|
[nil] * col_offset, # 0
|
|
|
|
log.renttype, # 1
|
|
|
|
nil,
|
|
|
|
nil,
|
|
|
|
log.scheme&.old_visible_id,
|
|
|
|
log.location&.old_visible_id,
|
|
|
|
nil,
|
|
|
|
log.tenancycode,
|
|
|
|
log.startertenancy,
|
|
|
|
log.tenancy,
|
|
|
|
log.tenancyother, # 10
|
|
|
|
log.tenancylength,
|
|
|
|
log.age1 || overrides[:age1],
|
|
|
|
log.age2 || overrides[:age2],
|
|
|
|
log.age3 || overrides[:age3],
|
|
|
|
log.age4 || overrides[:age4],
|
|
|
|
log.age5 || overrides[:age5],
|
|
|
|
log.age6 || overrides[:age6],
|
|
|
|
log.age7 || overrides[:age7],
|
|
|
|
log.age8 || overrides[:age8],
|
|
|
|
|
|
|
|
log.sex1, # 20
|
|
|
|
log.sex2,
|
|
|
|
log.sex3,
|
|
|
|
log.sex4,
|
|
|
|
log.sex5,
|
|
|
|
log.sex6,
|
|
|
|
log.sex7,
|
|
|
|
log.sex8,
|
|
|
|
|
|
|
|
log.relat2,
|
|
|
|
log.relat3,
|
|
|
|
log.relat4, # 30
|
|
|
|
log.relat5,
|
|
|
|
log.relat6,
|
|
|
|
log.relat7,
|
|
|
|
log.relat8,
|
|
|
|
|
|
|
|
log.ecstat1,
|
|
|
|
log.ecstat2,
|
|
|
|
log.ecstat3,
|
|
|
|
log.ecstat4,
|
|
|
|
log.ecstat5,
|
|
|
|
log.ecstat6, # 40
|
|
|
|
log.ecstat7,
|
|
|
|
log.ecstat8,
|
|
|
|
|
|
|
|
log.ethnic,
|
|
|
|
log.national,
|
|
|
|
log.armedforces,
|
|
|
|
log.reservist,
|
|
|
|
log.preg_occ,
|
|
|
|
log.hb,
|
|
|
|
log.benefits,
|
|
|
|
log.earnings, # 50
|
|
|
|
net_income_known,
|
|
|
|
nil,
|
|
|
|
log.reasonother,
|
|
|
|
nil,
|
|
|
|
nil,
|
|
|
|
nil,
|
|
|
|
nil,
|
|
|
|
nil,
|
|
|
|
nil,
|
|
|
|
nil, # 60
|
|
|
|
log.prevten,
|
|
|
|
log.prevloc,
|
|
|
|
((log.ppostcode_full || "").split(" ") || [""]).first,
|
|
|
|
((log.ppostcode_full || "").split(" ") || [""]).last,
|
|
|
|
previous_postcode_known,
|
|
|
|
log.layear,
|
|
|
|
log.waityear,
|
|
|
|
homeless,
|
|
|
|
log.reasonpref,
|
|
|
|
log.rp_homeless, # 70
|
|
|
|
log.rp_insan_unsat,
|
|
|
|
log.rp_medwel,
|
|
|
|
log.rp_hardship,
|
|
|
|
log.rp_dontknow,
|
|
|
|
cbl,
|
|
|
|
chr,
|
|
|
|
cap,
|
|
|
|
log.referral,
|
|
|
|
log.period,
|
|
|
|
|
|
|
|
log.brent, # 80
|
|
|
|
log.scharge,
|
|
|
|
log.pscharge,
|
|
|
|
log.supcharg,
|
|
|
|
log.tcharge,
|
|
|
|
log.chcharge,
|
|
|
|
log.household_charge,
|
|
|
|
log.hbrentshortfall,
|
|
|
|
log.tshortfall,
|
|
|
|
log.voiddate&.day,
|
|
|
|
|
|
|
|
log.voiddate&.month, # 90
|
|
|
|
log.voiddate&.strftime("%y"),
|
|
|
|
log.mrcdate&.day,
|
|
|
|
log.mrcdate&.month,
|
|
|
|
log.mrcdate&.strftime("%y"),
|
|
|
|
nil,
|
|
|
|
log.startdate&.day,
|
|
|
|
log.startdate&.month,
|
|
|
|
log.startdate&.strftime("%y"),
|
|
|
|
log.offered,
|
|
|
|
|
|
|
|
log.propcode, # 100
|
|
|
|
log.beds,
|
|
|
|
log.unittype_gn,
|
|
|
|
log.builtype,
|
|
|
|
log.wchair,
|
|
|
|
log.unitletas,
|
|
|
|
log.rsnvac,
|
|
|
|
log.la,
|
|
|
|
((log.postcode_full || "").split(" ") || [""]).first,
|
|
|
|
((log.postcode_full || "").split(" ") || [""]).last,
|
|
|
|
|
|
|
|
nil, # 110
|
|
|
|
log.owning_organisation&.old_visible_id,
|
|
|
|
nil,
|
|
|
|
log.managing_organisation&.old_visible_id,
|
|
|
|
leftreg,
|
|
|
|
nil,
|
|
|
|
log.incfreq,
|
|
|
|
log.sheltered,
|
|
|
|
overrides[:illness] || log.illness,
|
|
|
|
log.illness_type_1,
|
|
|
|
|
|
|
|
log.illness_type_2, # 120
|
|
|
|
log.illness_type_3,
|
|
|
|
log.illness_type_4,
|
|
|
|
log.illness_type_5,
|
|
|
|
log.illness_type_6,
|
|
|
|
log.illness_type_7,
|
|
|
|
log.illness_type_8,
|
|
|
|
log.illness_type_9,
|
|
|
|
log.illness_type_10,
|
|
|
|
london_affordable_rent,
|
|
|
|
|
|
|
|
intermediate_rent_type, # 130
|
|
|
|
log.irproduct_other,
|
|
|
|
log.declaration,
|
|
|
|
log.joint,
|
|
|
|
renewal,
|
|
|
|
line_ending,
|
|
|
|
].flatten.join(",")
|
|
|
|
end
|
|
|
|
|
|
|
|
def renewal
|
|
|
|
checkbox_value(log.renewal)
|
|
|
|
end
|
|
|
|
|
|
|
|
def london_affordable_rent
|
|
|
|
case log.renttype
|
|
|
|
when Imports::LettingsLogsImportService::RENT_TYPE[:london_affordable_rent]
|
|
|
|
1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def intermediate_rent_type
|
|
|
|
case log.renttype
|
|
|
|
when Imports::LettingsLogsImportService::RENT_TYPE[:rent_to_buy]
|
|
|
|
1
|
|
|
|
when Imports::LettingsLogsImportService::RENT_TYPE[:london_living_rent]
|
|
|
|
2
|
|
|
|
when Imports::LettingsLogsImportService::RENT_TYPE[:other_intermediate_rent_product]
|
|
|
|
3
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def leftreg
|
|
|
|
case log.leftreg
|
|
|
|
when 3
|
|
|
|
3
|
|
|
|
when 1
|
|
|
|
4
|
|
|
|
when 2
|
|
|
|
5
|
|
|
|
when 0
|
|
|
|
6
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def net_income_known
|
|
|
|
case log.net_income_known
|
|
|
|
when 0
|
|
|
|
1
|
|
|
|
when 1
|
|
|
|
2
|
|
|
|
when 2
|
|
|
|
4
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def previous_postcode_known
|
|
|
|
checkbox_value(log.ppcodenk)
|
|
|
|
end
|
|
|
|
|
|
|
|
def homeless
|
|
|
|
case log.homeless
|
|
|
|
when 1
|
|
|
|
1
|
|
|
|
when 11
|
|
|
|
12
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def cbl
|
|
|
|
checkbox_value(log.cbl)
|
|
|
|
end
|
|
|
|
|
|
|
|
def chr
|
|
|
|
checkbox_value(log.chr)
|
|
|
|
end
|
|
|
|
|
|
|
|
def cap
|
|
|
|
checkbox_value(log.cap)
|
|
|
|
end
|
|
|
|
|
|
|
|
def checkbox_value(field)
|
|
|
|
case field
|
|
|
|
when 0
|
|
|
|
2
|
|
|
|
when 1
|
|
|
|
1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|