ZeusWPI/FK-enrolment

View on GitHub
app/exports/excel_export.rb

Summary

Maintainability
A
55 mins
Test Coverage
require 'tempfile'

# Generate excel-export
class ExcelExport
  def self.create(members, academic_year)
    export = ExcelExport.new
    export.add_members(members, academic_year)
    data = export.save
    yield data
    data.close
  end

  def initialize
    @export = Spreadsheet::Workbook.new
    @sheet = @export.create_worksheet :name => 'Leden'
    @sheet.row(0).concat ['Kring', 'Voornaam', 'Familienaam', 'Geslacht',
      'UGent-nummer', 'E-mailadres', 'Geboortedatum', 'Thuisadres', 'Kotadres',
      'Foto', 'Geregistreerd', 'Kaartnummer', 'Status', 'ISIC status']
  end

  def add_members(members, academic_year)
    return if members.length == 0

    club = members.first.club
    members.each_with_index do |member, i|
      card = member.current_card || Card.build_for(member)
      @sheet.row(i+1).concat [club.name, member.first_name, member.last_name,
        member.sex, member.ugent_nr, member.email, member.date_of_birth,
        member.home_street.to_s + "\n" + member.home_postal_code.to_s + ' ' + member.home_city.to_s,
        member.studenthome_street.to_s + "\n" + member.studenthome_postal_code.to_s + ' ' + member.studenthome_city.to_s,
        member.photo.url(:cropped, use_timestamp = false), member.created_at,
        card.number, card.status, card.isic_status]
    end

    # Extra attributes
    club.extra_attributes.each do |spec|
      next if spec.field_type.blank?
      @sheet.row(0).concat [spec.name]
    end
    members.each_with_index do |member, i|
      attributes = []
      club.extra_attributes.each do |spec|
        next if spec.field_type.blank?
        attributes << encode_attribute(spec, member.extra_attributes)
      end
      @sheet.row(i+1).concat attributes
    end
  end

  def save
    data = Tempfile.new(["export", ".xls"])
    @export.write(data)
    data
  end

  private

  def encode_attribute(spec, attributes)
    attribute = attributes.find {|attr| attr.spec_id == spec.id }
    if attribute
      if attribute.value.class.include?(Enumerable)
        return attribute.value.delete_if { |v| v.blank? }.join(', ')
      else
        return attribute.value.sub("\r\n", "\n") if attribute.value
      end
    end
    ''
  end
end