scinote-web/app/services/reports/docx/repository_helper.rb

43 lines
1.4 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
module Reports::Docx::RepositoryHelper
include InputSanitizeHelper
def prepare_row_columns(repository_data, my_module, repository)
result = [repository_data[:headers]]
repository_data[:rows].each do |record|
row = []
row.push(record.code)
2020-06-18 14:52:59 +08:00
row.push(escape_input(record.archived ? "#{record.name} [#{I18n.t('general.archived')}]" : record.name))
row.push(I18n.l(record.created_at, format: :full))
row.push(escape_input(record.created_by.full_name))
cell_values = {}
custom_cells = record.repository_cells
custom_cells.each do |cell|
if cell.value.instance_of? RepositoryStockValue
if repository.is_a?(RepositorySnapshot)
consumed_stock = record.repository_stock_consumption_cell&.value&.formatted || 0
cell_values[cell.repository_column_id] = consumed_stock
else
consumption = record.my_module_repository_rows.find_by(my_module: my_module)&.stock_consumption || 0
unit = cell.value.repository_stock_unit_item&.data
cell_values[cell.repository_column_id] = "#{consumption} #{unit}"
end
else
cell_values[cell.repository_column_id] = cell.value.formatted
end
end
repository_data[:custom_columns].each do |column_id|
value = cell_values[column_id]
row.push(value)
end
result.push(row)
end
result
end
end