2019-11-18 22:21:57 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-12-06 19:50:19 +08:00
|
|
|
class RepositoryDateTimeValue < RepositoryDateTimeValueBase
|
2019-12-08 23:53:59 +08:00
|
|
|
def data_changed?(new_data)
|
2019-12-10 20:39:08 +08:00
|
|
|
new_time = Time.zone.parse(new_data)
|
|
|
|
new_time.to_i != data.to_i
|
2019-12-08 23:53:59 +08:00
|
|
|
end
|
|
|
|
|
2019-12-10 20:39:08 +08:00
|
|
|
def formatted
|
2020-03-18 16:57:57 +08:00
|
|
|
super(:full_with_comma)
|
|
|
|
end
|
|
|
|
|
2021-12-21 19:38:52 +08:00
|
|
|
def self.add_filter_condition(repository_rows, filter_element)
|
|
|
|
parameters = filter_element.parameters
|
|
|
|
case filter_element.operator
|
|
|
|
when 'today'
|
|
|
|
repository_rows.where('repository_date_time_values.data >= ?', Time.zone.now.beginning_of_day)
|
|
|
|
when 'yesterday'
|
|
|
|
repository_rows.where('repository_date_time_values.data >= ? AND repository_date_time_values.data < ?',
|
|
|
|
Time.zone.now.beginning_of_day - 1.day, Time.zone.now.beginning_of_day)
|
|
|
|
when 'last_week'
|
|
|
|
repository_rows.where('repository_date_time_values.data >= ? AND repository_date_time_values.data < ?',
|
|
|
|
Time.zone.now.beginning_of_week - 1.week, Time.zone.now.beginning_of_week)
|
|
|
|
when 'this_month'
|
|
|
|
repository_rows.where('repository_date_time_values.data >= ?', Time.zone.now.beginning_of_month)
|
|
|
|
when 'last_year'
|
|
|
|
repository_rows.where('repository_date_time_values.data >= ? AND repository_date_time_values.data < ?',
|
|
|
|
Time.zone.now.beginning_of_year - 1.year, Time.zone.now.beginning_of_year)
|
|
|
|
when 'this_year'
|
|
|
|
repository_rows.where('repository_date_time_values.data >= ?', Time.zone.now.beginning_of_year)
|
|
|
|
when 'equal_to'
|
|
|
|
repository_rows.where(repository_date_time_values: { data: parameters['datetime'] })
|
|
|
|
when 'unequal_to'
|
|
|
|
repository_rows.where.not(repository_date_time_values: { data: parameters['datetime'] })
|
|
|
|
when 'greater_than'
|
|
|
|
repository_rows.where('repository_date_time_values.data > ?', parameters['datetime'])
|
|
|
|
when 'greater_than_or_equal_to'
|
|
|
|
repository_rows.where('repository_date_time_values.data >= ?', parameters['datetime'])
|
|
|
|
when 'less_than'
|
|
|
|
repository_rows.where('repository_date_time_values.data < ?', parameters['datetime'])
|
|
|
|
when 'less_than_or_equal_to'
|
|
|
|
repository_rows.where('repository_date_time_values.data <= ?', parameters['datetime'])
|
|
|
|
when 'between'
|
|
|
|
repository_rows.where('repository_date_time_values.data > ? AND repository_date_time_values.data < ?',
|
|
|
|
parameters['start_datetime'], parameters['end_datetime'])
|
|
|
|
else
|
|
|
|
raise ArgumentError, 'Wrong operator for RepositoryDateTimeValue!'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-03-18 16:57:57 +08:00
|
|
|
def export_formatted
|
2020-03-18 17:35:31 +08:00
|
|
|
I18n.l(data, format: :full)
|
2019-12-08 23:53:59 +08:00
|
|
|
end
|
2019-12-09 20:48:24 +08:00
|
|
|
|
|
|
|
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 04:20:50 +08:00
|
|
|
def self.import_from_text(text, attributes, options = {})
|
2020-03-18 16:53:47 +08:00
|
|
|
date_format = (options.dig(:user, :settings, :date_format) || Constants::DEFAULT_DATE_FORMAT).gsub(/%-/, '%') + ' %H:%M'
|
2020-03-25 00:45:09 +08:00
|
|
|
Time.zone = options.dig(:user, :settings, :time_zone) || 'UTC'
|
|
|
|
new(attributes.merge(data: Time.zone.strptime(text, date_format)))
|
2020-03-18 04:20:50 +08:00
|
|
|
rescue ArgumentError
|
|
|
|
nil
|
|
|
|
end
|
2019-11-18 22:21:57 +08:00
|
|
|
end
|