scinote-web/app/models/repository_number_value.rb

76 lines
2.4 KiB
Ruby
Raw Normal View History

2019-12-09 23:38:21 +08:00
# frozen_string_literal: true
class RepositoryNumberValue < ApplicationRecord
belongs_to :created_by, foreign_key: :created_by_id, class_name: 'User',
2019-12-10 19:02:08 +08:00
inverse_of: :created_repository_number_values
2019-12-09 23:38:21 +08:00
belongs_to :last_modified_by, foreign_key: :last_modified_by_id, class_name: 'User',
2019-12-10 19:02:08 +08:00
inverse_of: :modified_repository_number_values
2019-12-09 23:38:21 +08:00
has_one :repository_cell, as: :value, dependent: :destroy, inverse_of: :value
accepts_nested_attributes_for :repository_cell
validates :repository_cell, :data, presence: true
SORTABLE_COLUMN_NAME = 'repository_number_values.data'
def formatted
2020-01-06 16:39:38 +08:00
data.to_s
2019-12-09 23:38:21 +08:00
end
def self.add_filter_condition(repository_rows, filter_element)
parameters = filter_element.parameters
case filter_element.operator
when 'equal_to'
repository_rows.where(repository_number_values: { data: parameters['number'] })
when 'unequal_to'
repository_rows.where.not(repository_number_values: { data: parameters['number'] })
when 'greater_than'
repository_rows.where('repository_number_values.data > ?', parameters['number'])
when 'greater_than_or_equal_to'
repository_rows.where('repository_number_values.data >= ?', parameters['number'])
when 'less_than'
repository_rows.where('repository_number_values.data < ?', parameters['number'])
when 'less_than_or_equal_to'
repository_rows.where('repository_number_values.data <= ?', parameters['number'])
when 'between'
repository_rows.where('repository_number_values.data > ? AND repository_number_values.data < ?',
parameters['from'], parameters['to'])
else
raise ArgumentError, 'Wrong operator for RepositoryNumberValue!'
end
end
def data_changed?(new_data)
BigDecimal(new_data.to_s) != data
end
def update_data!(new_data, user)
self.data = BigDecimal(new_data.to_s)
self.last_modified_by = user
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
2020-01-10 16:29:20 +08:00
2020-03-05 21:34:31 +08:00
def self.import_from_text(text, attributes, _options = {})
new(attributes.merge(data: BigDecimal(text.to_s)))
rescue ArgumentError
nil
end
2020-01-10 16:29:20 +08:00
alias export_formatted formatted
2019-12-09 23:38:21 +08:00
end