From e585a73f9012fe534c2b84859923c2c5fc5ff589 Mon Sep 17 00:00:00 2001 From: Jason Skomorowski Date: Tue, 10 Jun 2014 20:53:14 -0400 Subject: [PATCH] Template facets --- src/mkws-widget-termlists.js | 58 ++++++++++---------- .../Facet.handlebars | 17 ++++++ .../Termlists.handlebars | 11 ++++ 3 files changed, 57 insertions(+), 29 deletions(-) create mode 100644 src/mkws-widget-termlists.templates/Facet.handlebars create mode 100644 src/mkws-widget-termlists.templates/Termlists.handlebars diff --git a/src/mkws-widget-termlists.js b/src/mkws-widget-termlists.js index 1757b62..54c65c4 100644 --- a/src/mkws-widget-termlists.js +++ b/src/mkws-widget-termlists.js @@ -1,22 +1,19 @@ mkws.registerWidgetType('Termlists', function() { - var that = this; - // Initially hide the termlists; display when we get results + var that = this; + var team = this.team; mkws.$(document).ready(function() { that.node.hide(); }); - this.team.queue("termlists").subscribe(function(data) { + team.queue("termlists").subscribe(function(data) { that.node.show(); }); - var acc = []; - var facets = this.config.facets; - acc.push('
' + mkws.M('Termlists') + '
'); - for (var i = 0; i < facets.length; i++) { - acc.push('
', '
'); - } - this.node.html(acc.join('')); - + var template = team.loadTemplate(this.config.template || "Termlists"); + this.node.html(template({ + team: team, + facets: this.config.facets + })); this.autosearch(); }); @@ -27,8 +24,8 @@ mkws.registerWidgetType('Facet', function() { subject: [ "Subjects", 10, true ], author: [ "Authors", 10, true ] } - var that = this; + var team = this.team; var name = that.config.facet; var ref = facetConfig[name] || [ "Unknown", 10, true ]; var caption = this.config['facet_caption_' + name] || ref[0]; @@ -36,35 +33,38 @@ mkws.registerWidgetType('Facet', function() { var pzIndex = ref[2] ? name : null; that.toString = function() { - return '[Widget ' + that.team.name() + ':' + that.type + '(' + name + ')]'; + return '[Widget ' + team.name() + ':' + that.type + '(' + name + ')]'; }; - that.team.queue("termlists").subscribe(function(data) { + team.queue("termlists").subscribe(function(data) { data = data[name]; - - var teamName = that.team.name(); - var acc = []; - acc.push('
' + mkws.M(caption) + '
'); + var terms = []; + var teamName = team.name(); for (var i = 0; i < data.length && i < max; i++) { - acc.push('
'); - acc.push('' + data[i].name + '' - + ' ' + data[i].freq + ''); - acc.push('
'); + linkdata += 'onclick="' + action + ';return false;"'; + terms.push({ + term: data[i].name, + count: data[i].freq, + linkdata: linkdata + }); } - - that.node.html(acc.join('')); + var template = team.loadTemplate(that.config.template || "Facet"); + that.node.html(template({ + name: name, + caption: caption, + terms: terms + })); }); - this.autosearch(); }); diff --git a/src/mkws-widget-termlists.templates/Facet.handlebars b/src/mkws-widget-termlists.templates/Facet.handlebars new file mode 100644 index 0000000..520ce1d --- /dev/null +++ b/src/mkws-widget-termlists.templates/Facet.handlebars @@ -0,0 +1,17 @@ +{{! +A facet in the search. + +name - facet identifier, typically English and lowercase +caption - caption for this facet +terms: + term - term name + count - count of items matching in the current search for this team + linkdata - attributes to add to the term element including an onclick handler +}} + +
{{caption}}
+{{#each terms}} +
+ {{term}} {{count}} +
+{{/each}} diff --git a/src/mkws-widget-termlists.templates/Termlists.handlebars b/src/mkws-widget-termlists.templates/Termlists.handlebars new file mode 100644 index 0000000..63865dc --- /dev/null +++ b/src/mkws-widget-termlists.templates/Termlists.handlebars @@ -0,0 +1,11 @@ +{{! +Termlists, a container of all configured facets. + +team - the current team +facets - array of facet names +}} + +
Termlists
+{{#each facets}} +
+{{/each}} -- 1.7.10.4