provide notes filter
This commit is contained in:
parent
b1218577f3
commit
aeba93eb14
@ -43,19 +43,19 @@ class AdditionalsJournal
|
|||||||
# Preloads visible last notes for a collection of entity
|
# Preloads visible last notes for a collection of entity
|
||||||
# this is a copy of Issue.load_visible_last_notes, but usable for all entities
|
# this is a copy of Issue.load_visible_last_notes, but usable for all entities
|
||||||
# @see https://www.redmine.org/projects/redmine/repository/entry/trunk/app/models/issue.rb#L1214
|
# @see https://www.redmine.org/projects/redmine/repository/entry/trunk/app/models/issue.rb#L1214
|
||||||
def load_visible_last_notes(entries, entity, user = User.current)
|
def load_visible_last_notes(entries, entity, user = User.current, scope = nil)
|
||||||
return unless entries.any?
|
return if entries.none?
|
||||||
|
|
||||||
ids = entries.map(&:id)
|
ids = entries.map(&:id)
|
||||||
|
|
||||||
journal_class = (entity == Issue ? Journal : "#{entity}Journal").constantize
|
journal_class = (entity == Issue ? Journal : "#{entity}Journal").constantize
|
||||||
journal_ids = journal_class.joins(entity.name.underscore.to_sym => :project)
|
scope ||= journal_class.joins entity.name.underscore.to_sym => :project
|
||||||
.where(journalized_type: entity.to_s, journalized_id: ids)
|
journal_ids = scope.where(journalized_type: entity.to_s, journalized_id: ids)
|
||||||
.where(journal_class.visible_notes_condition(user, skip_pre_condition: true))
|
.where(journal_class.visible_notes_condition(user, skip_pre_condition: true))
|
||||||
.where.not(notes: '')
|
.where.not(notes: '')
|
||||||
.group(:journalized_id)
|
.group(:journalized_id)
|
||||||
.maximum(:id)
|
.maximum(:id)
|
||||||
.values
|
.values
|
||||||
|
|
||||||
journals = Journal.where(id: journal_ids).to_a
|
journals = Journal.where(id: journal_ids).to_a
|
||||||
|
|
||||||
|
@ -163,6 +163,20 @@ module AdditionalsQuery
|
|||||||
values
|
values
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def initialize_notes_filter(position: nil)
|
||||||
|
add_available_filter 'notes', type: :text, order: position
|
||||||
|
end
|
||||||
|
|
||||||
|
def sql_for_notes_field(field, operator, value)
|
||||||
|
subquery = "SELECT 1 FROM #{Journal.table_name}" \
|
||||||
|
" WHERE #{Journal.table_name}.journalized_type='#{queried_class}'" \
|
||||||
|
" AND #{Journal.table_name}.journalized_id=#{queried_table_name}.id" \
|
||||||
|
" AND (#{sql_for_field field, operator.sub(/^!/, ''), value, Journal.table_name, 'notes'})" \
|
||||||
|
" AND (#{Journal.visible_notes_condition User.current, skip_pre_condition: true})"
|
||||||
|
|
||||||
|
"#{/^!/.match?(operator) ? 'NOT EXISTS' : 'EXISTS'} (#{subquery})"
|
||||||
|
end
|
||||||
|
|
||||||
def sql_for_watcher_id_field(field, operator, value)
|
def sql_for_watcher_id_field(field, operator, value)
|
||||||
watchable_type = queried_class == User ? 'Principal' : queried_class.to_s
|
watchable_type = queried_class == User ? 'Principal' : queried_class.to_s
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user