scinote-web/app/models/repository_date_range_value.rb

49 lines
2 KiB
Ruby
Raw Normal View History

2019-12-06 19:50:19 +08:00
# frozen_string_literal: true
class RepositoryDateRangeValue < RepositoryDateTimeRangeValueBase
def data_changed?(new_data)
data = new_data.is_a?(String) ? JSON.parse(new_data).symbolize_keys : new_data
2019-12-17 20:42:25 +08:00
st = Time.zone.parse(data[:start_time])
et = Time.zone.parse(data[:end_time])
2019-12-10 20:39:08 +08:00
st.to_date != start_time.to_date || et.to_date != end_time.to_date
end
2019-12-10 20:39:08 +08:00
def formatted
super(:full_date)
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_date_time_range_values: { start_time: parameters['start_date'], end_time: parameters['end_date'] })
when 'unequal_to'
repository_rows.where.not(repository_date_time_range_values: { start_time: parameters['start_date'], end_time: parameters['end_date'] })
when 'greater_than'
repository_rows.where('repository_date_time_range_values.start_time > ?', parameters['end_date'])
when 'greater_than_or_equal_to'
repository_rows.where('repository_date_time_range_values.start_time >= ?', parameters['end_date'])
when 'less_than'
repository_rows.where('repository_date_time_range_values.end_time < ?', parameters['start_date'])
when 'less_than_or_equal_to'
repository_rows.where('repository_date_time_range_values.end_time <= ?', parameters['start_date'])
when 'between'
repository_rows.where('repository_date_time_range_values.start_time > ? AND repository_date_time_range_values.end_time < ?',
parameters['start_date'], parameters['end_date'])
else
raise ArgumentError, 'Wrong operator for RepositoryDateRangeValue!'
end
end
def self.new_with_payload(payload, attributes)
data = payload.is_a?(String) ? JSON.parse(payload).symbolize_keys : payload
2019-12-17 20:42:25 +08:00
value = new(attributes)
2019-12-17 20:42:25 +08:00
value.start_time = Time.zone.parse(data[:start_time])
value.end_time = Time.zone.parse(data[:end_time])
value
end
2020-01-10 16:29:20 +08:00
alias export_formatted formatted
2019-12-06 19:50:19 +08:00
end