mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-15 03:49:24 +08:00
81 lines
2.6 KiB
Ruby
81 lines
2.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class RepositoryNumberValue < ApplicationRecord
|
|
belongs_to :created_by, foreign_key: :created_by_id, class_name: 'User',
|
|
inverse_of: :created_repository_number_values
|
|
belongs_to :last_modified_by, foreign_key: :last_modified_by_id, class_name: 'User',
|
|
inverse_of: :modified_repository_number_values
|
|
has_one :repository_cell, as: :value, dependent: :destroy, inverse_of: :value, touch: true
|
|
accepts_nested_attributes_for :repository_cell
|
|
|
|
validates :repository_cell, :data, presence: true
|
|
|
|
SORTABLE_COLUMN_NAME = 'repository_number_values.data'
|
|
|
|
def formatted
|
|
data.to_s
|
|
end
|
|
|
|
def self.add_filter_condition(repository_rows, join_alias, filter_element)
|
|
parameters = filter_element.parameters
|
|
if filter_element.operator == 'between'
|
|
return repository_rows if parameters['from'].blank? || parameters['to'].blank?
|
|
elsif parameters['number'].blank?
|
|
return repository_rows
|
|
end
|
|
|
|
case filter_element.operator
|
|
when 'equal_to'
|
|
repository_rows.where("#{join_alias}.data = ?", parameters['number'].to_d)
|
|
when 'unequal_to'
|
|
repository_rows.where.not("#{join_alias}.data = ?", parameters['number'].to_d)
|
|
when 'greater_than'
|
|
repository_rows.where("#{join_alias}.data > ?", parameters['number'].to_d)
|
|
when 'greater_than_or_equal_to'
|
|
repository_rows.where("#{join_alias}.data >= ?", parameters['number'].to_d)
|
|
when 'less_than'
|
|
repository_rows.where("#{join_alias}.data < ?", parameters['number'].to_d)
|
|
when 'less_than_or_equal_to'
|
|
repository_rows.where("#{join_alias}.data <= ?", parameters['number'].to_d)
|
|
when 'between'
|
|
repository_rows
|
|
.where("#{join_alias}.data > ? AND #{join_alias}.data < ?", parameters['from'].to_d, parameters['to'].to_d)
|
|
else
|
|
raise ArgumentError, 'Wrong operator for RepositoryNumberValue!'
|
|
end
|
|
end
|
|
|
|
def data_different?(new_data)
|
|
BigDecimal(new_data.to_s) != data
|
|
end
|
|
|
|
def update_data!(new_data, user, preview: false)
|
|
self.data = BigDecimal(new_data.to_s)
|
|
self.last_modified_by = user
|
|
preview ? validate : save!
|
|
end
|
|
|
|
def snapshot!(cell_snapshot)
|
|
value_snapshot = dup
|
|
value_snapshot.assign_attributes(
|
|
repository_cell: cell_snapshot,
|
|
created_at: created_at,
|
|
updated_at: updated_at
|
|
)
|
|
value_snapshot.save!
|
|
end
|
|
|
|
def self.new_with_payload(payload, attributes)
|
|
value = new(attributes)
|
|
value.data = BigDecimal(payload.to_s)
|
|
value
|
|
end
|
|
|
|
def self.import_from_text(text, attributes, _options = {})
|
|
new(attributes.merge(data: BigDecimal(text.to_s)))
|
|
rescue ArgumentError
|
|
nil
|
|
end
|
|
|
|
alias export_formatted formatted
|
|
end
|