mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2024-11-12 12:16:06 +08:00
50 lines
1.8 KiB
Ruby
50 lines
1.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Reports::Docx::RepositoryHelper
|
|
include InputSanitizeHelper
|
|
include ActionView::Helpers::NumberHelper
|
|
|
|
def prepare_row_columns(repository_data, my_module, repository)
|
|
result = [repository_data[:headers]]
|
|
repository_data[:rows].each do |record|
|
|
row = []
|
|
row.push(record.code)
|
|
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 = number_with_precision(
|
|
record.my_module_repository_rows.find_by(my_module: my_module)&.stock_consumption || 0,
|
|
precision: (record.repository.repository_stock_column.metadata['decimals'].to_i || 0),
|
|
strip_insignificant_zeros: true
|
|
)
|
|
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
|
|
if repository.repository_stock_column.present? && record.repository_stock_cell.blank?
|
|
cell_values[repository.repository_stock_column.id] = '-'
|
|
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
|