2019-12-06 12:50:19 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class RepositoryTimeRangeValue < RepositoryDateTimeRangeValueBase
|
2022-04-12 15:56:20 +02:00
|
|
|
SORTABLE_COLUMN_NAME = 'repository_date_time_range_values.start_time::time'
|
|
|
|
|
2022-02-21 12:08:35 +01:00
|
|
|
def data_different?(new_data)
|
2020-02-17 00:26:20 +01:00
|
|
|
data = new_data.is_a?(String) ? JSON.parse(new_data).symbolize_keys : new_data
|
2019-12-17 13:42:25 +01:00
|
|
|
|
|
|
|
st = Time.zone.parse(data[:start_time])
|
|
|
|
et = Time.zone.parse(data[:end_time])
|
2019-12-10 13:39:08 +01:00
|
|
|
st.hour != start_time.hour || et.hour != end_time.hour || st.min != start_time.min || et.min != end_time.min
|
2019-12-08 16:53:59 +01:00
|
|
|
end
|
|
|
|
|
2019-12-10 13:39:08 +01:00
|
|
|
def formatted
|
|
|
|
super(:time)
|
2019-12-08 16:53:59 +01:00
|
|
|
end
|
2019-12-09 13:48:24 +01:00
|
|
|
|
2022-02-22 13:29:50 +01:00
|
|
|
def self.add_filter_condition(repository_rows, join_alias, filter_element)
|
2022-01-31 09:21:08 +01:00
|
|
|
parameters = filter_element.parameters
|
|
|
|
case filter_element.operator
|
|
|
|
when 'equal_to'
|
2022-03-08 10:20:53 +01:00
|
|
|
repository_rows.where("#{join_alias}.start_time::time = (?)::time AND #{join_alias}.end_time::time = (?)::time",
|
2022-03-10 13:49:09 +01:00
|
|
|
Time.zone.parse(parameters['start_time']), Time.zone.parse(parameters['end_time']))
|
2022-01-31 09:21:08 +01:00
|
|
|
when 'unequal_to'
|
2022-03-08 10:20:53 +01:00
|
|
|
repository_rows
|
|
|
|
.where.not("#{join_alias}.start_time::time = (?)::time AND #{join_alias}.end_time::time = (?)::time",
|
2022-03-10 13:49:09 +01:00
|
|
|
Time.zone.parse(parameters['start_time']), Time.zone.parse(parameters['end_time']))
|
2022-01-31 09:21:08 +01:00
|
|
|
when 'greater_than'
|
2022-03-10 13:49:09 +01:00
|
|
|
repository_rows.where("#{join_alias}.start_time::time > (?)::time", Time.zone.parse(parameters['end_time']))
|
2022-01-31 09:21:08 +01:00
|
|
|
when 'greater_than_or_equal_to'
|
2022-03-10 13:49:09 +01:00
|
|
|
repository_rows.where("#{join_alias}.start_time::time >= (?)::time", Time.zone.parse(parameters['end_time']))
|
2022-01-31 09:21:08 +01:00
|
|
|
when 'less_than'
|
2022-03-10 13:49:09 +01:00
|
|
|
repository_rows.where("#{join_alias}.end_time::time < (?)::time", Time.zone.parse(parameters['start_time']))
|
2022-01-31 09:21:08 +01:00
|
|
|
when 'less_than_or_equal_to'
|
2022-03-10 13:49:09 +01:00
|
|
|
repository_rows.where("#{join_alias}.end_time::time <= (?)::time", Time.zone.parse(parameters['start_time']))
|
2022-01-31 09:21:08 +01:00
|
|
|
when 'between'
|
2022-03-08 10:20:53 +01:00
|
|
|
repository_rows.where("#{join_alias}.start_time::time > (?)::time AND #{join_alias}.end_time::time < (?)::time",
|
2022-03-10 13:49:09 +01:00
|
|
|
Time.zone.parse(parameters['start_time']), Time.zone.parse(parameters['end_time']))
|
2022-01-31 09:21:08 +01:00
|
|
|
else
|
|
|
|
raise ArgumentError, 'Wrong operator for RepositoryTimeRangeValue!'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-12-09 13:48:24 +01:00
|
|
|
def self.new_with_payload(payload, attributes)
|
2020-02-17 00:26:20 +01:00
|
|
|
data = payload.is_a?(String) ? JSON.parse(payload).symbolize_keys : payload
|
2019-12-17 13:42:25 +01:00
|
|
|
|
2019-12-09 13:48:24 +01:00
|
|
|
value = new(attributes)
|
2019-12-17 13:42:25 +01:00
|
|
|
value.start_time = Time.zone.parse(data[:start_time])
|
|
|
|
value.end_time = Time.zone.parse(data[:end_time])
|
2019-12-09 13:48:24 +01:00
|
|
|
value
|
|
|
|
end
|
2020-01-10 09:29:20 +01:00
|
|
|
|
|
|
|
alias export_formatted formatted
|
2019-12-06 12:50:19 +01:00
|
|
|
end
|