scinote-web/app/models/samples_table.rb

57 lines
2.1 KiB
Ruby

class SamplesTable < ApplicationRecord
belongs_to :user, inverse_of: :samples_tables, optional: true
belongs_to :team, inverse_of: :samples_tables, optional: true
validates :user, :team, presence: true
validates :user, uniqueness: { scope: :team }
scope :find_status,
->(user, team) { where(user: user, team: team).pluck(:status) }
def self.update_samples_table_state(custom_field, column_index)
samples_table = SamplesTable.where(user: custom_field.user,
team: custom_field.team)
team_status = samples_table.first['status']
if column_index
# delete column
team_status['columns'].delete(column_index)
team_status['columns'].keys.each do |index|
if index.to_i > column_index.to_i
team_status['columns'][(index.to_i - 1).to_s] =
team_status['columns'].delete(index)
else
index
end
end
team_status['ColReorder'].delete(column_index)
team_status['ColReorder'].map! do |index|
if index.to_i > column_index.to_i
(index.to_i - 1).to_s
else
index
end
end
else
# add column
index = team_status['columns'].count
team_status['columns'][index] = SampleDatatable::
SAMPLES_TABLE_DEFAULT_STATE['columns'].first
team_status['ColReorder'].insert(2, index)
end
samples_table.first.update(status: team_status)
end
def self.create_samples_table_state(user_team)
default_columns_num = SampleDatatable::
SAMPLES_TABLE_DEFAULT_STATE['columns'].count
team_status = SampleDatatable::SAMPLES_TABLE_DEFAULT_STATE.deep_dup
user_team.team.custom_fields.each_with_index do |_, index|
team_status['columns'] << SampleDatatable::
SAMPLES_TABLE_DEFAULT_STATE['columns'].first
team_status['ColReorder'] << (default_columns_num + index)
end
SamplesTable.create(user: user_team.user,
team: user_team.team,
status: team_status)
end
end