gitcoinco/code_fund_ads

View on GitHub
app/mailers/campaign_reports_mailer.rb

Summary

Maintainability
A
0 mins
Test Coverage
class CampaignReportsMailer < ApplicationMailer
  def organization_report_email
    @organization_report = OrganizationReport.find(params[:organization_report_id])
    recipients = params[:recipients]

    @organization_report.pdf.attachment.open do |pdf|
      attachments[@organization_report.pdf.filename.to_s] = pdf.read
    end

    mail to: recipients, subject: "CodeFund Campaign Report"
  end

  def campaign_report_email
    @campaign = params[:campaign]
    @start_date = Date.coerce(params[:start_date])
    @end_date = Date.coerce(params[:end_date])
    @summary = @campaign.summary(@start_date, @end_date)

    workbook = create_report_workbook(@campaign, @start_date, @end_date)
    filename = "campaign-report-#{@campaign.id}-#{@start_date.to_s("yyyymmdd")}-#{@end_date.to_s("yyyymmdd")}.xls"

    Tempfile.open(filename, Rails.root.join("tmp")) do |file|
      workbook.write file
      file.rewind
      attachments[filename] = file.read
    end

    mail to: params[:to], subject: "CodeFund Campaign Report: #{@campaign.analytics_key}"
  end

  private

  def create_report_workbook(campaign, start_date, end_date)
    Spreadsheet::Workbook.new.tap do |workbook|
      campaign.daily_worksheet workbook, start_date, end_date
      campaign.creative_worksheet workbook, start_date, end_date
      campaign.property_worksheet workbook, start_date, end_date
      campaign.country_code_worksheet workbook, start_date, end_date
    end
  end
end