scinote-web/app/models/repository_time_value.rb

51 lines
1.8 KiB
Ruby
Raw Normal View History

2019-12-06 19:50:19 +08:00
# frozen_string_literal: true
class RepositoryTimeValue < RepositoryDateTimeValueBase
def data_different?(new_data)
2019-12-10 20:39:08 +08:00
new_time = Time.zone.parse(new_data)
new_time.min != data.min || new_time.hour != data.hour
end
2019-12-10 20:39:08 +08:00
def formatted
super(:time)
end
def self.add_filter_condition(repository_rows, join_alias, filter_element)
parameters = filter_element.parameters
case filter_element.operator
when 'equal_to'
repository_rows.where("#{join_alias}.data::time = ?", Time.zone.parse(parameters['time']))
when 'unequal_to'
repository_rows.where.not("#{join_alias}.data::time = ?", Time.zone.parse(parameters['time']))
when 'greater_than'
repository_rows.where("#{join_alias}.data::time > ?", Time.zone.parse(parameters['time']))
when 'greater_than_or_equal_to'
repository_rows.where("#{join_alias}.data::time >= ?", Time.zone.parse(parameters['time']))
when 'less_than'
repository_rows.where("#{join_alias}.data::time < ?", Time.zone.parse(parameters['time']))
when 'less_than_or_equal_to'
repository_rows.where("#{join_alias}.data::time <= ?", Time.zone.parse(parameters['time']))
when 'between'
repository_rows.where("#{join_alias}.data::time > ? AND #{join_alias}.data::time < ?",
Time.zone.parse(parameters['start_time']), Time.zone.parse(parameters['end_time']))
else
raise ArgumentError, 'Wrong operator for RepositoryTimeValue!'
end
end
def self.new_with_payload(payload, attributes)
value = new(attributes)
value.data = Time.zone.parse(payload)
value
end
2020-01-10 16:29:20 +08:00
2020-03-18 17:35:31 +08:00
def self.import_from_text(text, attributes, _options = {})
2020-03-18 16:53:47 +08:00
time_format = '%H:%M'
new(attributes.merge(data: DateTime.strptime(text, time_format).strftime(time_format)))
rescue ArgumentError
nil
end
2020-01-10 16:29:20 +08:00
alias export_formatted formatted
2019-12-06 19:50:19 +08:00
end