# 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 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