# 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