X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-widget-termlists.js;h=2e684f660564b32002c86b07ca7d8bd4983cfa02;hb=9760c20d77e528ca91397ac4754db7e4f3be7443;hp=3df2f60bb45c4f869435525c03e93d4601248541;hpb=6f59bb0256441ab1d48816a5524b8666dc799ff7;p=mkws-moved-to-github.git
diff --git a/src/mkws-widget-termlists.js b/src/mkws-widget-termlists.js
index 3df2f60..2e684f6 100644
--- a/src/mkws-widget-termlists.js
+++ b/src/mkws-widget-termlists.js
@@ -1,34 +1,28 @@
-mkws.registerWidgetType('Termlists', function() {
- var that = this;
-
+mkws.registerWidgetType('termlists', function() {
// Initially hide the termlists; display when we get results
- mkws.$(document).ready(function() {
- that.node.hide();
- });
- this.team.queue("termlists").subscribe(function(data) {
- that.node.show();
+ var that = this;
+ var team = this.team;
+ team.queue("termlists").subscribe(function(data) {
+ that.node.addClass("active");
});
- 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.name(),
+ facets: this.config.facets
+ }));
this.autosearch();
});
-mkws.registerWidgetType('Facet', function() {
+mkws.registerWidgetType('facet', function() {
var facetConfig = {
xtargets: [ "Sources", 16, false ],
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,40 +30,52 @@ 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 template = that.team.loadTemplate('facetTitle-' + caption, mkws.M(caption))
- var title = template({ query: that.config.query });
- var acc = [];
- acc.push('', title, '
');
-
- var teamName = that.team.name();
+ var terms = [];
+ var teamName = team.name();
for (var i = 0; i < data.length && i < max; i++) {
- var fn, field;
- // General case modifies the query; special case selects a target
- if (pzIndex) {
- fn = 'limitQuery'; field = pzIndex;
- } else if (!that.team.targetFiltered(data[i].id)) {
- fn = 'limitTarget'; field = data[i].id;
+ var linkdata = "";
+ var action = "";
+ if (!pzIndex) {
+ // Special case: target selection
+ linkdata += ('target_id='+data[i].id+' ');
+ if (!team.targetFiltered(data[i].id)) {
+ action = 'mkws.limitTarget(\'' + teamName + '\', this.getAttribute(\'target_id\'),this.firstChild.nodeValue)';
+ }
+ } else {
+ action = 'mkws.limitQuery(\'' + teamName + '\', \'' + pzIndex + '\', this.firstChild.nodeValue)';
}
-
- var template = that.team.loadTemplate('Facet');
- var s = template({
- team: teamName,
- fn: fn,
- field: field,
+ linkdata += 'onclick="' + action + ';return false;"';
+ terms.push({
term: data[i].name,
+ field: data[i].id,
count: data[i].freq,
- query: that.config.query
- });
- acc.push('', s, '
');
+ linkdata: linkdata
+ });
}
-
- that.node.html(acc.join(''));
+ // configured template > facet specific template > default facet template
+ var template;
+ if (that.config.template) {
+ template = team.loadTemplate(that.config.template);
+ } else {
+ template = team.loadTemplate("Facet-" + caption);
+ if (template) {
+ that.log("Using Facet-" + caption + " template.")
+ } else {
+ that.log("No " + caption + " specific template, using default.")
+ template = team.loadTemplate("Facet");
+ }
+ }
+ that.node.html(template({
+ name: name,
+ caption: caption,
+ query: that.config.query,
+ terms: terms
+ }));
});
-
this.autosearch();
});