mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-13 10:59:49 +08:00
114 lines
3 KiB
Ruby
114 lines
3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'csv'
|
|
|
|
module RepositoryStockLedgerZipExport
|
|
COLUMNS = %w(
|
|
consumption_type
|
|
item_name
|
|
item_id
|
|
consumed_amount
|
|
consumed_amount_unit
|
|
added_amount
|
|
added_amount_unit
|
|
consumed_by
|
|
consumed_on
|
|
team
|
|
project
|
|
experiment
|
|
task
|
|
project_id
|
|
experiment_id
|
|
task_id
|
|
stock_amount_balance
|
|
stock_balance_unit
|
|
).freeze
|
|
|
|
def self.to_csv(repository_row_ids)
|
|
csv_header = COLUMNS.map { |col| I18n.t("repository_stock_values.stock_export.headers.#{col}") }
|
|
repository_ledger_records = load_records(repository_row_ids)
|
|
|
|
CSV.generate do |csv|
|
|
csv << csv_header
|
|
repository_ledger_records.each do |record|
|
|
csv << generate_record_data(record)
|
|
end
|
|
end
|
|
end
|
|
|
|
class << self
|
|
private
|
|
|
|
def load_records(repository_row_ids)
|
|
RepositoryLedgerRecord
|
|
.joins(:repository_row)
|
|
.preload(:user, repository_row: { repository: :team })
|
|
.preload(my_module_repository_row: { my_module: { experiment: { project: :team } } })
|
|
.where(repository_row: { id: repository_row_ids })
|
|
.order(:created_at)
|
|
end
|
|
|
|
def generate_record_data(record)
|
|
consumption_type = record.reference_type == 'MyModuleRepositoryRow' ? 'Task' : 'Inventory'
|
|
|
|
if (consumption_type == 'Task' && record.amount.positive?) ||
|
|
(consumption_type == 'Inventory' && record.amount.negative?)
|
|
consumed_amount = record.amount.abs
|
|
consumed_amount_unit = record.unit
|
|
else
|
|
added_amount = record.amount.abs
|
|
added_amount_unit = record.unit
|
|
end
|
|
|
|
row_data = [
|
|
consumption_type,
|
|
record.repository_row.name,
|
|
record.repository_row.code,
|
|
consumed_amount,
|
|
consumed_amount_unit,
|
|
added_amount,
|
|
added_amount_unit,
|
|
record.user.full_name,
|
|
I18n.l(record.created_at, format: :full),
|
|
record.balance,
|
|
record.unit
|
|
]
|
|
breadcrumbs_data =
|
|
if consumption_type == 'Task'
|
|
build_breadcrumbs(record)
|
|
else
|
|
Array.new(7)
|
|
end
|
|
|
|
row_data.insert(9, *breadcrumbs_data)
|
|
row_data
|
|
end
|
|
|
|
def build_breadcrumbs(record)
|
|
if record.my_module_repository_row.present?
|
|
my_module = record.my_module_repository_row.my_module
|
|
[
|
|
my_module.experiment.project.team.name,
|
|
my_module.experiment.project.name,
|
|
my_module.experiment.name,
|
|
my_module.name,
|
|
my_module.experiment.project.code,
|
|
my_module.experiment.code,
|
|
my_module.code
|
|
]
|
|
elsif record.my_module_references.present?
|
|
[
|
|
Team.find_by(id: record.my_module_references['team_id'])&.name,
|
|
nil,
|
|
nil,
|
|
nil,
|
|
Project.code(record.my_module_references['project_id']),
|
|
Experiment.code(record.my_module_references['experiment_id']),
|
|
MyModule.code(record.my_module_references['my_module_id'])
|
|
]
|
|
else
|
|
Array.new(7)
|
|
end
|
|
end
|
|
end
|
|
end
|