summaryrefslogtreecommitdiff
path: root/web-ui/app/js/tags/ui
diff options
context:
space:
mode:
Diffstat (limited to 'web-ui/app/js/tags/ui')
-rw-r--r--web-ui/app/js/tags/ui/tag_list.js7
-rw-r--r--web-ui/app/js/tags/ui/tag_shortcut.js13
2 files changed, 17 insertions, 3 deletions
diff --git a/web-ui/app/js/tags/ui/tag_list.js b/web-ui/app/js/tags/ui/tag_list.js
index 02eee7f8..22b1e77b 100644
--- a/web-ui/app/js/tags/ui/tag_list.js
+++ b/web-ui/app/js/tags/ui/tag_list.js
@@ -56,13 +56,20 @@ define(
this.trigger(list, events.tags.teardown);
list.empty();
}.bind(this));
+
}
+ this.resetShortcuts = function () {
+ $('#tags-shortcuts').empty();
+ this.trigger(document, events.tags.shortcuts.teardown);
+ };
+
this.renderTagList = function(tags) {
var defaultList = this.select('defaultTagList');
var customList = this.select('customTagList');
resetTagList.bind(this, [defaultList, customList]).call();
+ this.resetShortcuts();
tags.forEach(function (tag) {
renderTag.bind(this, tag, defaultList, customList).call();
diff --git a/web-ui/app/js/tags/ui/tag_shortcut.js b/web-ui/app/js/tags/ui/tag_shortcut.js
index 6e5c6960..59556794 100644
--- a/web-ui/app/js/tags/ui/tag_shortcut.js
+++ b/web-ui/app/js/tags/ui/tag_shortcut.js
@@ -3,10 +3,11 @@ define(
'flight/lib/component',
'views/templates',
'page/events',
- 'tags/ui/tag_base'
+ 'tags/ui/tag_base',
+ 'flight/lib/utils'
],
- function (describeComponent, templates, events, tagBase) {
+ function (describeComponent, templates, events, tagBase, utils) {
var TagShortcut = describeComponent(tagShortcut, tagBase);
@@ -20,7 +21,6 @@ define(
function tagShortcut() {
-
this.renderAndAttach = function (parent, options) {
var linkTo = options.linkTo;
@@ -58,9 +58,16 @@ define(
this.$node.addClass('selected');
};
+ this.doTeardown = function () {
+ if (!jQuery.contains(document, this.$node[0])) {
+ this.teardown();
+ }
+ };
+
this.after('initialize', function () {
this.on('click', function () { this.attr.trigger.triggerSelect(); });
this.on(document, events.ui.tag.select, this.selectTag);
+ this.on(document, events.tags.shortcuts.teardown, this.doTeardown);
});
}