X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-widget-termlists.js;h=fef616f71ae8e6991ce7416ffcbcdfdd0a60267a;hb=dbec0f36afacc8faa86b1a15497300a6a295c3ed;hp=ce801ec20dd5ab143a68ee7d11a585f2e1293153;hpb=ee3953c2d2dcdec10648134bc75ae6fcf257e9b0;p=mkws-moved-to-github.git diff --git a/src/mkws-widget-termlists.js b/src/mkws-widget-termlists.js index ce801ec..fef616f 100644 --- a/src/mkws-widget-termlists.js +++ b/src/mkws-widget-termlists.js @@ -1,50 +1,82 @@ mkws.registerWidgetType('Termlists', function() { - var that = this; - var facets = that.config.facets; - var M = mkws.M; - - this.team.queue("termlists").subscribe(function(data) { - // display if we first got results - $(that.node).show(); - - for (var i = 0; i < facets.length; i++) { - var name = facets[i] - var ref = mkws.facetConfig[name]; - var caption = ref[0]; - if (!ref) { - alert("bad facet configuration: '" + name + "'"); - } else { - var output = makeSingleFacet(ref[0], data[name], ref[1], ref[2] ? name : null); - that.team.findnode('.mkwsFacet' + caption).html(output); - } - } - - - function makeSingleFacet(caption, data, max, pzIndex) { - var teamName = that.team.name(); - - var acc = []; - acc.push('
' + M(caption) + '
'); - for (var i = 0; i < data.length && i < max; i++) { - acc.push('
'); - acc.push('' + data[i].name + '' - + ' ' + data[i].freq + ''); - acc.push('
'); - } - return acc.join(''); - } - }); - - widget.autosearch(that); + var that = this; + + // 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 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('')); + + this.autosearch(); +}); + + +mkws.registerWidgetType('Facet', function() { + var facetConfig = { + xtargets: [ "Sources", 16, false ], + subject: [ "Subjects", 10, true ], + author: [ "Authors", 10, true ] + } + + var that = this; + var name = that.config.facet; + var ref = facetConfig[name] || [ "Unknown", 10, true ]; + var caption = this.config['facet_caption_' + name] || ref[0]; + var max = parseInt(this.config['facet_max_' + name] || ref[1]); + var pzIndex = ref[2] ? name : null; + + that.toString = function() { + return '[Widget ' + that.team.name() + ':' + that.type + '(' + name + ')]'; + }; + + var t2 = that.team.loadTemplate('Facet-' + caption); + that.log("template for Facet-" + caption + " is " + !!t2); + if (!t2) { + that.log("no " + caption + "-specific template, falling back"); + t2 = that.team.loadTemplate('Facet'); + } + that.log("template for Facet is " + !!t2); + + that.team.queue("termlists").subscribe(function(data) { + data = data[name]; + var t1 = that.team.loadTemplate('facetTitle-' + caption, mkws.M(caption)) + var title = t1({ query: that.config.query }); + var acc = []; + acc.push('
', title, '
'); + + var teamName = that.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 s = t2({ + team: teamName, + fn: fn, + field: field, + term: data[i].name, + count: data[i].freq, + query: that.config.query + }); + acc.push('
', s, '
'); + } + + that.node.html(acc.join('')); + }); + + this.autosearch(); });