2018-09-06 10:07:33 +00:00
|
|
|
# frozen_string_literal: true
|
2012-11-05 18:12:26 +00:00
|
|
|
|
2018-09-06 10:07:33 +00:00
|
|
|
class EventFilter
|
|
|
|
attr_accessor :filter
|
|
|
|
|
|
|
|
ALL = 'all'
|
|
|
|
PUSH = 'push'
|
|
|
|
MERGED = 'merged'
|
|
|
|
ISSUE = 'issue'
|
|
|
|
COMMENTS = 'comments'
|
|
|
|
TEAM = 'team'
|
|
|
|
FILTERS = [ALL, PUSH, MERGED, ISSUE, COMMENTS, TEAM].freeze
|
|
|
|
|
|
|
|
def initialize(filter)
|
|
|
|
# Split using comma to maintain backward compatibility Ex/ "filter1,filter2"
|
|
|
|
filter = filter.to_s.split(',')[0].to_s
|
|
|
|
@filter = FILTERS.include?(filter) ? filter : ALL
|
2012-11-05 18:12:26 +00:00
|
|
|
end
|
|
|
|
|
2018-09-06 10:07:33 +00:00
|
|
|
def active?(key)
|
|
|
|
filter == key.to_s
|
2012-11-05 18:12:26 +00:00
|
|
|
end
|
|
|
|
|
2018-08-27 15:31:01 +00:00
|
|
|
# rubocop: disable CodeReuse/ActiveRecord
|
2014-09-25 22:07:40 +00:00
|
|
|
def apply_filter(events)
|
2018-09-06 10:07:33 +00:00
|
|
|
case filter
|
|
|
|
when PUSH
|
2016-11-22 17:11:34 +00:00
|
|
|
events.where(action: Event::PUSHED)
|
2018-09-06 10:07:33 +00:00
|
|
|
when MERGED
|
2016-11-22 17:11:34 +00:00
|
|
|
events.where(action: Event::MERGED)
|
2018-09-06 10:07:33 +00:00
|
|
|
when COMMENTS
|
2016-11-22 17:11:34 +00:00
|
|
|
events.where(action: Event::COMMENTED)
|
2018-09-06 10:07:33 +00:00
|
|
|
when TEAM
|
2016-11-22 17:11:34 +00:00
|
|
|
events.where(action: [Event::JOINED, Event::LEFT, Event::EXPIRED])
|
2018-09-06 10:07:33 +00:00
|
|
|
when ISSUE
|
2019-03-06 15:22:45 +00:00
|
|
|
events.where(action: [Event::CREATED, Event::UPDATED, Event::CLOSED, Event::REOPENED], target_type: 'Issue')
|
2012-11-05 18:12:26 +00:00
|
|
|
else
|
2018-09-06 10:07:33 +00:00
|
|
|
events
|
2016-11-22 17:11:34 +00:00
|
|
|
end
|
2012-11-05 18:12:26 +00:00
|
|
|
end
|
2018-09-06 10:07:33 +00:00
|
|
|
# rubocop: enable CodeReuse/ActiveRecord
|
2012-11-05 18:12:26 +00:00
|
|
|
end
|