86166d2802
This splits the Markdown rendering and reference extraction phases into two distinct code bases. The reference extraction phase no longer relies on the html-pipeline Gem (and any related code) and allows for extracting of references from multiple HTML nodes in a single pass. This means that if you want to extract user references from 200 comments you no longer need to run 200 times N number of queries, instead only a handful of queries may be needed.
25 lines
611 B
Ruby
25 lines
611 B
Ruby
module Banzai
|
|
module ReferenceParser
|
|
class ExternalIssueParser < BaseParser
|
|
self.reference_type = :external_issue
|
|
|
|
def referenced_by(nodes)
|
|
issue_ids = issue_ids_per_project(nodes)
|
|
projects = find_projects_for_hash_keys(issue_ids)
|
|
issues = []
|
|
|
|
projects.each do |project|
|
|
issue_ids[project.id].each do |id|
|
|
issues << ExternalIssue.new(id, project)
|
|
end
|
|
end
|
|
|
|
issues
|
|
end
|
|
|
|
def issue_ids_per_project(nodes)
|
|
gather_attributes_per_project(nodes, self.class.data_attribute)
|
|
end
|
|
end
|
|
end
|
|
end
|