1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2024-12-12 23:09:03 +01:00
fab-manager/app/services/accounting/vat_export_service.rb

105 lines
3.0 KiB
Ruby
Raw Normal View History

2021-12-29 17:00:49 +01:00
# frozen_string_literal: false
# module definition
module Accounting; end
2021-12-29 17:00:49 +01:00
# Provides the routine to export the collected VAT data to a CSV file.
class Accounting::VatExportService
2021-12-29 17:00:49 +01:00
include ActionView::Helpers::NumberHelper
attr_reader :encoding, :format, :separator, :date_format, :columns, :decimal_separator
def initialize(columns, encoding: 'UTF-8', format: 'CSV', separator: ';')
@encoding = encoding
@format = format
@separator = separator
@decimal_separator = '.'
@date_format = '%Y-%m-%d'
@columns = columns
2022-12-23 15:52:10 +01:00
@vat_name = Setting.get('invoice_VAT-name')
2021-12-29 17:00:49 +01:00
end
2022-12-05 11:29:53 +01:00
def set_options(decimal_separator: ',', date_format: '%d/%m/%Y', label_max_length: nil, export_zeros: nil)
2021-12-29 17:00:49 +01:00
@decimal_separator = decimal_separator
@date_format = date_format
2022-12-05 11:29:53 +01:00
# these unused parameters are required for compatibility with AccountingExportService
@label_max_length = label_max_length
@export_zeros = export_zeros
2021-12-29 17:00:49 +01:00
end
def export(start_date, end_date, file)
# build CSV content
content = header_row
invoices = Invoice.where('created_at >= ? AND created_at <= ?', start_date, end_date).order('created_at ASC')
vat_totals = compute_vat_totals(invoices)
content << generate_rows(vat_totals, start_date, end_date)
# write content to file
File.open(file, "w:#{encoding}") { |f| f.puts content.encode(encoding, invalid: :replace, undef: :replace) }
end
private
def header_row
row = ''
columns.each do |column|
2023-02-24 17:26:55 +01:00
row << I18n.t("vat_export.#{column}", **{ NAME: @vat_name }) << separator
2021-12-29 17:00:49 +01:00
end
"#{row}\n"
end
def generate_rows(vat_totals, start_date, end_date)
rows = ''
vat_totals.each do |rate, total|
next if rate.zero?
rows += "#{row(
start_date,
end_date,
rate,
total
)}\n"
end
rows
end
def compute_vat_totals(invoices)
vat_total = []
service = VatHistoryService.new
invoices.each do |i|
Rails.logger.info "processing invoice #{i.id}..." unless Rails.env.test?
2021-12-29 17:00:49 +01:00
vat_total.push service.invoice_vat(i)
end
vat_total.map(&:values).flatten.group_by { |tot| tot[:vat_rate] }.transform_values { |v| v.pluck(:total_vat).reduce(:+) }
2021-12-29 17:00:49 +01:00
end
# Generate a row of the export, filling the configured columns with the provided values
def row(start_date, end_date, vat_rate, amount)
row = ''
columns.each do |column|
case column
when 'start_date'
2023-02-17 11:44:04 +01:00
row << Time.zone.parse(start_date).strftime(date_format)
2021-12-29 17:00:49 +01:00
when 'end_date'
2023-02-17 11:44:04 +01:00
row << Time.zone.parse(end_date).strftime(date_format)
2021-12-29 17:00:49 +01:00
when 'vat_rate'
row << vat_rate.to_s
when 'amount'
row << format_number(amount / 100.0)
else
Rails.logger.warn "Unsupported column: #{column}"
2021-12-29 17:00:49 +01:00
end
row << separator
end
row
end
# Format the given number as a string, using the configured separator
def format_number(num)
number_to_currency(num, unit: '', separator: decimal_separator, delimiter: '', precision: 2)
end
end