2019-02-26 18:01:15 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class ActivitiesService
|
2019-03-18 22:38:19 +08:00
|
|
|
def self.load_activities(user, teams, filters = {})
|
|
|
|
# Create condition for view permissions checking first
|
|
|
|
visible_projects = Project.viewable_by_user(user, teams)
|
|
|
|
query = Activity.where('project_id IS NULL AND team_id IN (?)', teams.select(:id))
|
|
|
|
.or(Activity.where(project: visible_projects))
|
|
|
|
|
2019-02-26 18:01:15 +08:00
|
|
|
if filters[:subjects].present?
|
2019-03-18 22:38:19 +08:00
|
|
|
query = query.where(
|
2019-02-27 20:21:05 +08:00
|
|
|
filters[:subjects].map { '(subject_type = ? AND subject_id IN(?))' }
|
|
|
|
.join(' OR '),
|
|
|
|
*filters[:subjects].flatten
|
|
|
|
)
|
2019-02-26 18:01:15 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
query = query.where(owner_id: filters[:users]) if filters[:users]
|
|
|
|
query = query.where(type_of: filters[:types]) if filters[:types]
|
|
|
|
|
|
|
|
if filters[:from_date] && filters[:to_date]
|
|
|
|
activities = query.where(
|
2019-03-15 22:52:30 +08:00
|
|
|
'created_at >= :from AND created_at <= :to',
|
2019-02-26 18:01:15 +08:00
|
|
|
from: Time.zone.parse(filters[:from_date]).beginning_of_day.utc,
|
|
|
|
to: Time.zone.parse(filters[:to_date]).end_of_day.utc
|
|
|
|
)
|
|
|
|
elsif filters[:from_date] && !filters[:to_date]
|
|
|
|
activities = query.where(
|
2019-03-15 22:52:30 +08:00
|
|
|
'created_at >= :from',
|
2019-02-26 18:01:15 +08:00
|
|
|
from: Time.zone.parse(filters[:from_date]).beginning_of_day.utc
|
|
|
|
)
|
|
|
|
else
|
2019-03-15 22:52:30 +08:00
|
|
|
activities = query.where(
|
|
|
|
'created_at >= :from AND created_at <= :to',
|
|
|
|
from: Time.now.beginning_of_day.utc,
|
|
|
|
to: Time.now.end_of_day.utc
|
|
|
|
)
|
2019-02-26 18:01:15 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
activities = activities.order(created_at: :desc)
|
|
|
|
.limit(Constants::ACTIVITY_AND_NOTIF_SEARCH_LIMIT)
|
|
|
|
loaded = activities.length
|
|
|
|
results = activities.group_by do |activity|
|
|
|
|
Time.zone.at(activity.created_at).to_date.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
return results if loaded < Constants::ACTIVITY_AND_NOTIF_SEARCH_LIMIT
|
|
|
|
|
|
|
|
last_date = results.keys.last
|
|
|
|
activities = query.where(
|
2019-03-15 22:52:30 +08:00
|
|
|
'created_at >= :from AND created_at <= :to',
|
2019-02-26 18:01:15 +08:00
|
|
|
from: Time.zone.parse(last_date).beginning_of_day.utc,
|
|
|
|
to: Time.zone.parse(last_date).end_of_day.utc
|
|
|
|
)
|
|
|
|
more_left = query.where(
|
2019-03-15 22:52:30 +08:00
|
|
|
'created_at > :from',
|
2019-02-26 18:01:15 +08:00
|
|
|
from: Time.zone.parse(last_date).end_of_day.utc
|
|
|
|
).exists?
|
|
|
|
results[last_date] = activities.to_a
|
|
|
|
[results, more_left]
|
|
|
|
end
|
|
|
|
end
|