Commit 76e7496b authored by csillag's avatar csillag

Implement multiple selection of annotations

Pressing Ctrl (or Compose), and clicking on a highlight,
or a tab on the heatmap now adds annotations to the current selection.
A second such clicks removes them agian.

k
parent 4353ade3
...@@ -198,6 +198,11 @@ class Annotator.Guest extends Annotator ...@@ -198,6 +198,11 @@ class Annotator.Guest extends Annotator
(a.id for a in annotations) (a.id for a in annotations)
] ]
xorToViewer: (annotations) =>
@panel?.notify
method: "xorToViewer"
params: (a.id for a in annotations)
updateViewer: (viewName, annotations) => updateViewer: (viewName, annotations) =>
@panel?.notify @panel?.notify
method: "updateViewer" method: "updateViewer"
...@@ -270,28 +275,32 @@ class Annotator.Guest extends Annotator ...@@ -270,28 +275,32 @@ class Annotator.Guest extends Annotator
else else
super super
onAnchorMouseover: (annotations) -> onAnchorMouseover: (event, annotations) ->
if (@tool is 'highlight') or @visibleHighlights if (@tool is 'highlight') or @visibleHighlights
this.addEmphasis annotations this.addEmphasis annotations
onAnchorMouseout: (annotations) -> onAnchorMouseout: (event, annotations) ->
if (@tool is 'highlight') or @visibleHighlights if (@tool is 'highlight') or @visibleHighlights
this.removeEmphasis annotations this.removeEmphasis annotations
# When clicking on a highlight in highlighting mode, # When clicking on a highlight in highlighting mode,
# set @noBack to true to prevent the sidebar from closing # set @noBack to true to prevent the sidebar from closing
onAnchorMousedown: (annotations) => onAnchorMousedown: (event, annotations) =>
if (@tool is 'highlight') or @visibleHighlights if (@tool is 'highlight') or @visibleHighlights
@noBack = true @noBack = true
# When clicking on a highlight in highlighting mode, # When clicking on a highlight in highlighting mode,
# tell the sidebar to bring up the viewer for the relevant annotations # tell the sidebar to bring up the viewer for the relevant annotations
onAnchorClick: (annotations) => onAnchorClick: (event, annotations) =>
return unless (@tool is 'highlight') or @visibleHighlights and @noBack return unless (@tool is 'highlight') or @visibleHighlights and @noBack
# Switch off dynamic mode; we are going to "Selection" scope # Switch off dynamic mode; we are going to "Selection" scope
@plugins.Heatmap.dynamicBucket = false @plugins.Heatmap.dynamicBucket = false
if event.metaKey or event.ctrlKey
# Tell sidebar to add these annotations to the sidebar
this.xorToViewer annotations
else
# Tell sidebar to show the viewer for these annotations # Tell sidebar to show the viewer for these annotations
this.showViewer "Selection", annotations this.showViewer "Selection", annotations
......
...@@ -468,6 +468,9 @@ class Annotator.Plugin.Heatmap extends Annotator.Plugin ...@@ -468,6 +468,9 @@ class Annotator.Plugin.Heatmap extends Annotator.Plugin
else else
d3.event.stopPropagation() d3.event.stopPropagation()
@dynamicBucket = false @dynamicBucket = false
if d3.event.ctrlKey or d3.event.metaKey
annotator.xorToViewer @buckets[bucket]
else
annotator.showViewer "Selection", @buckets[bucket] annotator.showViewer "Selection", @buckets[bucket]
tabs.exit().remove() tabs.exit().remove()
......
...@@ -227,6 +227,10 @@ class Hypothesis extends Annotator ...@@ -227,6 +227,10 @@ class Hypothesis extends Annotator
$rootScope.$apply => this.updateViewer viewName, this._getAnnotationsFromIDs ids $rootScope.$apply => this.updateViewer viewName, this._getAnnotationsFromIDs ids
) )
.bind('xorToViewer', (ctx, ids = []) =>
$rootScope.$apply => this.xorToViewer this._getAnnotationsFromIDs ids
)
.bind('setTool', (ctx, name) => .bind('setTool', (ctx, name) =>
$rootScope.$apply => this.setTool name $rootScope.$apply => this.setTool name
) )
...@@ -315,6 +319,30 @@ class Hypothesis extends Annotator ...@@ -315,6 +319,30 @@ class Hypothesis extends Annotator
annotation.reply_list = children.sort(@sortAnnotations).reverse() annotation.reply_list = children.sort(@sortAnnotations).reverse()
@buildReplyList children @buildReplyList children
xorToViewer: (annotations=[]) =>
annotations = annotations.filter (a) -> a?
@element.injector().invoke [
'$rootScope',
($rootScope) =>
if $rootScope.view is "Selection"
# We are already in selection mode; just XOR this list
# to the current selection
@buildReplyList annotations
list = $rootScope.annotations
for a in annotations
if a in list
list.splice list.indexOf(a), 1
else
list.push a
else
# We are not in selection mode,
# so we switch to it, and make this list
# the new selection
$rootScope.view = "Selection"
$rootScope.annotations = annotations
]
this
updateViewer: (viewName, annotations=[]) => updateViewer: (viewName, annotations=[]) =>
annotations = annotations.filter (a) -> a? annotations = annotations.filter (a) -> a?
@element.injector().invoke [ @element.injector().invoke [
......
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