mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-11-10 08:21:37 +08:00
Add export of Inventories and their assets
This commit is contained in:
parent
295c6a9432
commit
4b0357b392
1 changed files with 63 additions and 2 deletions
|
|
@ -1,5 +1,6 @@
|
||||||
require 'zip'
|
require 'zip'
|
||||||
require 'fileutils'
|
require 'fileutils'
|
||||||
|
require 'csv'
|
||||||
|
|
||||||
# To use ZipExport you have to define the generate_( type )_zip method!
|
# To use ZipExport you have to define the generate_( type )_zip method!
|
||||||
# Example:
|
# Example:
|
||||||
|
|
@ -203,11 +204,60 @@ class ZipExport < ApplicationRecord
|
||||||
def export_tables(tables, directory)
|
def export_tables(tables, directory)
|
||||||
# Helper method to extract given tables to the directory
|
# Helper method to extract given tables to the directory
|
||||||
tables.each do |table|
|
tables.each do |table|
|
||||||
file = FileUtils.touch("#{directory}/#{table.name}.csv").first
|
file = FileUtils.touch("#{directory}/#{handle_name(table.name)}.csv").first
|
||||||
File.open(file, 'wb') { |f| f.write(table.contents) }
|
File.open(file, 'wb') { |f| f.write(table.contents) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def save_inventories_to_csv(path, repo, repo_rows)
|
||||||
|
# Helper method for saving inventories to CSV
|
||||||
|
repo_name = handle_name(repo.name)
|
||||||
|
file = FileUtils.touch("#{path}/#{repo_name}.csv").first
|
||||||
|
|
||||||
|
# Attachment folder
|
||||||
|
rel_attach_path = "#{repo_name}_ATTACHMENTS"
|
||||||
|
attach_path = "#{path}/#{rel_attach_path}"
|
||||||
|
FileUtils.mkdir_p(attach_path)
|
||||||
|
|
||||||
|
# Define headers and columns IDs
|
||||||
|
headers = ['ID', 'Name', 'Added on', 'Added by'] +
|
||||||
|
repo.repository_columns.map{|x| x.name}
|
||||||
|
col_ids = repo.repository_columns.map{|x| x.id}
|
||||||
|
|
||||||
|
# Generate CSV
|
||||||
|
assets = []
|
||||||
|
csv_data = CSV.generate do |csv|
|
||||||
|
csv << headers
|
||||||
|
|
||||||
|
repo_rows.each do |row|
|
||||||
|
csv_row = [row.id, row.name, row.created_at, row.created_by.name]
|
||||||
|
# TODO: take care of uneven number of columns
|
||||||
|
row.repository_cells.each do |cell|
|
||||||
|
case cell.value_type
|
||||||
|
when 'RepositoryAssetValue'
|
||||||
|
csv_row << "#{rel_attach_path}/#{cell.value.asset.file_file_name}"
|
||||||
|
assets << cell.value.asset
|
||||||
|
when 'RepositoryListValue'
|
||||||
|
csv_row << cell.value.formatted
|
||||||
|
when 'RepositoryDateValue'
|
||||||
|
csv_row << cell.value.formatted
|
||||||
|
when 'RepositoryTextValue'
|
||||||
|
csv_row << cell.value.formatted
|
||||||
|
end
|
||||||
|
end
|
||||||
|
csv << csv_row
|
||||||
|
end
|
||||||
|
end
|
||||||
|
File.open(file, 'wb') { |f| f.write(csv_data) }
|
||||||
|
|
||||||
|
# Save all attachments
|
||||||
|
assets.each do |asset|
|
||||||
|
file = FileUtils.touch("#{attach_path}/#{asset.file_file_name}").first
|
||||||
|
File.open(file, 'wb') { |f| f.write(asset.open.read) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
def generate_teams_zip(tmp_dir, data, _options = {})
|
def generate_teams_zip(tmp_dir, data, _options = {})
|
||||||
# Export all functionality
|
# Export all functionality
|
||||||
# Create team folder
|
# Create team folder
|
||||||
|
|
@ -231,6 +281,18 @@ class ZipExport < ApplicationRecord
|
||||||
inventories = "#{root}/Inventories"
|
inventories = "#{root}/Inventories"
|
||||||
FileUtils.mkdir_p(inventories)
|
FileUtils.mkdir_p(inventories)
|
||||||
|
|
||||||
|
# Find all assigned inventories through all tasks in the project
|
||||||
|
task_ids = p.project_my_modules
|
||||||
|
repo_rows = RepositoryRow.joins(:my_modules).where(my_modules:
|
||||||
|
{ id: task_ids }
|
||||||
|
).distinct
|
||||||
|
|
||||||
|
# Iterate through every inventory repo and save it to CSV
|
||||||
|
repo_rows.map{|x| x.repository}.uniq.each do |repo|
|
||||||
|
curr_repo_rows = repo_rows.select{|x| x.repository_id == repo.id}
|
||||||
|
save_inventories_to_csv(inventories, repo, curr_repo_rows)
|
||||||
|
end
|
||||||
|
|
||||||
# Include all experiments
|
# Include all experiments
|
||||||
p.experiments.each do |ex|
|
p.experiments.each do |ex|
|
||||||
experiment_path = "#{root}/#{handle_name(ex.name)}"
|
experiment_path = "#{root}/#{handle_name(ex.name)}"
|
||||||
|
|
@ -246,7 +308,6 @@ class ZipExport < ApplicationRecord
|
||||||
FileUtils.mkdir_p(protocol_path)
|
FileUtils.mkdir_p(protocol_path)
|
||||||
FileUtils.mkdir_p(result_path)
|
FileUtils.mkdir_p(result_path)
|
||||||
|
|
||||||
|
|
||||||
steps = my_module.protocols.map{ |p| p.steps }.flatten
|
steps = my_module.protocols.map{ |p| p.steps }.flatten
|
||||||
export_assets(StepAsset.where(step: steps).map {|s| s.asset}, protocol_path)
|
export_assets(StepAsset.where(step: steps).map {|s| s.asset}, protocol_path)
|
||||||
export_tables(StepTable.where(step: steps).map {|s| s.table}, protocol_path)
|
export_tables(StepTable.where(step: steps).map {|s| s.table}, protocol_path)
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue