Fix added on this month filter [SCI-6584] (#3904)

Co-authored-by: Anton <anton@scinote.net>
This commit is contained in:
aignatov-bio 2022-02-28 11:16:29 +01:00 committed by GitHub
parent 155b437d6a
commit 99e8f7e3cb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -202,7 +202,7 @@ class RepositoryDatatableService
) )
when 'this_month' when 'this_month'
repository_rows.where( repository_rows.where(
"date_trunc('minute', \"created_at\") >= ? AND date_trunc('minute', \"created_at\") <= ?", "date_trunc('minute', \"repository_rows\".\"created_at\") >= ? AND date_trunc('minute', \"repository_rows\".\"created_at\") <= ?",
Time.zone.now.beginning_of_month, Time.zone.now.beginning_of_month,
Time.zone.now.end_of_month Time.zone.now.end_of_month
) )
@ -254,22 +254,22 @@ class RepositoryDatatableService
case filter_element_params[:operator] case filter_element_params[:operator]
when 'today' when 'today'
repository_rows.where("date_trunc('minute', \"archived_on\") >= ? AND date_trunc('minute', \"archived_on\") <= ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") >= ? AND date_trunc('minute', \"repository_rows\".\"archived_on\") <= ?",
Time.zone.now.beginning_of_day, Time.zone.now.end_of_day) Time.zone.now.beginning_of_day, Time.zone.now.end_of_day)
when 'yesterday' when 'yesterday'
repository_rows.where("date_trunc('minute', \"archived_on\") >= ? AND date_trunc('minute', \"archived_on\") < ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") >= ? AND date_trunc('minute', \"repository_rows\".\"archived_on\") < ?",
Time.zone.now.beginning_of_day - 1.day, Time.zone.now.beginning_of_day) Time.zone.now.beginning_of_day - 1.day, Time.zone.now.beginning_of_day)
when 'last_week' when 'last_week'
repository_rows.where("date_trunc('minute', \"archived_on\") >= ? AND date_trunc('minute', \"archived_on\") < ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") >= ? AND date_trunc('minute', \"repository_rows\".\"archived_on\") < ?",
Time.zone.now.beginning_of_week - 1.week, Time.zone.now.beginning_of_week) Time.zone.now.beginning_of_week - 1.week, Time.zone.now.beginning_of_week)
when 'this_month' when 'this_month'
repository_rows.where( repository_rows.where(
"date_trunc('minute', \"archived_on\") >= ? AND date_trunc('minute', \"archived_on\") <= ?", "date_trunc('minute', \"repository_rows\".\"archived_on\") >= ? AND date_trunc('minute', \"repository_rows\".\"archived_on\") <= ?",
Time.zone.now.beginning_of_month, Time.zone.now.beginning_of_month,
Time.zone.now.end_of_month Time.zone.now.end_of_month
) )
when 'last_year' when 'last_year'
repository_rows.where("date_trunc('minute', \"archived_on\") >= ? AND date_trunc('minute', \"archived_on\") < ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") >= ? AND date_trunc('minute', \"repository_rows\".\"archived_on\") < ?",
Time.zone.now.beginning_of_year - 1.year, Time.zone.now.beginning_of_year) Time.zone.now.beginning_of_year - 1.year, Time.zone.now.beginning_of_year)
when 'this_year' when 'this_year'
repository_rows.where( repository_rows.where(
@ -279,25 +279,25 @@ class RepositoryDatatableService
Time.zone.now.end_of_year Time.zone.now.end_of_year
) )
when 'equal_to' when 'equal_to'
repository_rows.where("date_trunc('minute', \"archived_on\") = ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") = ?",
Time.zone.parse(filter_element_params.dig(:parameters, :datetime))) Time.zone.parse(filter_element_params.dig(:parameters, :datetime)))
when 'unequal_to' when 'unequal_to'
repository_rows.where.not("date_trunc('minute', \"archived_on\") = ?", repository_rows.where.not("date_trunc('minute', \"repository_rows\".\"archived_on\") = ?",
Time.zone.parse(filter_element_params.dig(:parameters, :datetime))) Time.zone.parse(filter_element_params.dig(:parameters, :datetime)))
when 'greater_than' when 'greater_than'
repository_rows.where("date_trunc('minute', \"archived_on\") > ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") > ?",
Time.zone.parse(filter_element_params.dig(:parameters, :datetime))) Time.zone.parse(filter_element_params.dig(:parameters, :datetime)))
when 'greater_than_or_equal_to' when 'greater_than_or_equal_to'
repository_rows.where("date_trunc('minute', \"archived_on\") >= ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") >= ?",
Time.zone.parse(filter_element_params.dig(:parameters, :datetime))) Time.zone.parse(filter_element_params.dig(:parameters, :datetime)))
when 'less_than' when 'less_than'
repository_rows.where("date_trunc('minute', \"archived_on\") < ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") < ?",
Time.zone.parse(filter_element_params.dig(:parameters, :datetime))) Time.zone.parse(filter_element_params.dig(:parameters, :datetime)))
when 'less_than_or_equal_to' when 'less_than_or_equal_to'
repository_rows.where("date_trunc('minute', \"archived_on\") <= ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") <= ?",
Time.zone.parse(filter_element_params.dig(:parameters, :datetime))) Time.zone.parse(filter_element_params.dig(:parameters, :datetime)))
when 'between' when 'between'
repository_rows.where("date_trunc('minute', \"archived_on\") > ? AND date_trunc('minute', \"archived_on\") < ?", repository_rows.where("date_trunc('minute', \"repository_rows\".\"archived_on\") > ? AND date_trunc('minute', \"repository_rows\".\"archived_on\") < ?",
Time.zone.parse(filter_element_params.dig(:parameters, :start_datetime)), Time.zone.parse(filter_element_params.dig(:parameters, :start_datetime)),
Time.zone.parse(filter_element_params.dig(:parameters, :end_datetime))) Time.zone.parse(filter_element_params.dig(:parameters, :end_datetime)))
else else