Commit 6c4618d7 authored by Ujvari Gergely's avatar Ujvari Gergely

Pagesearch does not show separate cards for every matching item in a thread

The SearchController.refresh() function has been enhanced in a way that it keeps track of already chosen top-level annotations that way for every annotation we check if the root is already added or not. If added we don't have to add it again. This on
Fixes #849
parent ccdcc89d
...@@ -804,15 +804,35 @@ class Search ...@@ -804,15 +804,35 @@ class Search
annotator.highlighter = $scope.highlighter annotator.highlighter = $scope.highlighter
threads = [] threads = []
roots = {}
$scope.render_order = {} $scope.render_order = {}
# Choose the root annotations to work with # Choose the root annotations to work with
for id, thread of annotator.threading.idTable when thread.message? for id, thread of annotator.threading.idTable when thread.message?
annotation = thread.message annotation = thread.message
annotation_root = if annotation.references? then annotation.references[0] else annotation.id
# Already handled thread
if roots[annotation_root]? then continue
if annotation.id in $scope.search_filter if annotation.id in $scope.search_filter
# Maybe we have an upper level match too
top_match = null
if annotation.references?
for reference in annotation.references
if reference in $scope.search_filter
top_thread = annotator.threading.getContainer reference
top_match = top_thread.message
break
if top_match
threads.push top_match
$scope.render_order[top_match.id] = []
buildRenderOrder(top_match.id, [top_thread])
else
# We do not have upper match
threads.push thread threads.push thread
$scope.render_order[annotation.id] = [] $scope.render_order[annotation.id] = []
buildRenderOrder(annotation.id, [thread]) buildRenderOrder(annotation.id, [thread])
roots[annotation_root] = true
continue continue
# Maybe it has a child we were looking for # Maybe it has a child we were looking for
...@@ -828,6 +848,7 @@ class Search ...@@ -828,6 +848,7 @@ class Search
threads.push thread threads.push thread
$scope.render_order[annotation.id] = [] $scope.render_order[annotation.id] = []
buildRenderOrder(annotation.id, [thread]) buildRenderOrder(annotation.id, [thread])
roots[annotation_root] = true
# Re-construct exact order the annotation threads will be shown # Re-construct exact order the annotation threads will be shown
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment