X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-widget-termlists.js;h=fef616f71ae8e6991ce7416ffcbcdfdd0a60267a;hb=18e6ebfc3219c0991124d9a3f9968640fb7d95b4;hp=61751002c1bcb6535122f42d1d2b415e0bdec840;hpb=011aa84e21fa9f9ff46ad16fe8d7afd28d9b7372;p=mkws-moved-to-github.git
diff --git a/src/mkws-widget-termlists.js b/src/mkws-widget-termlists.js
index 6175100..fef616f 100644
--- a/src/mkws-widget-termlists.js
+++ b/src/mkws-widget-termlists.js
@@ -1,64 +1,82 @@
mkws.registerWidgetType('Termlists', function() {
- var that = this;
- var M = mkws.M;
+ var that = this;
- var facetConfig = {
- xtargets: [ "Sources", 16, false ],
- subject: [ "Subjects", 10, true ],
- author: [ "Author", 10, true ]
- }
+ // 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();
+});
- this.team.queue("termlists").subscribe(function(data) {
- // no facets: this should never happen
- var facets = that.config.facets;
- if (!facets || facets.length == 0) {
- alert("onTerm called even though we have no facets: " + $.toJSON(data));
- $(that.node).hide();
- return;
- }
- // display if we first got results
- $(that.node).show();
+mkws.registerWidgetType('Facet', function() {
+ var facetConfig = {
+ xtargets: [ "Sources", 16, false ],
+ subject: [ "Subjects", 10, true ],
+ author: [ "Authors", 10, true ]
+ }
- var acc = [];
- acc.push('' + M('Termlists') + '
');
+ 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;
- for (var i = 0; i < facets.length; i++) {
- var name = facets[i]
- var ref = facetConfig[name];
- if (!ref) {
- alert("bad facet configuration: '" + name + "'");
- } else {
- addSingleFacet(acc, ref[0], data[name], ref[1], ref[2] ? name : null);
- }
- }
+ that.toString = function() {
+ return '[Widget ' + that.team.name() + ':' + that.type + '(' + name + ')]';
+ };
- $(that.node).html(acc.join(''));
+ 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, '
');
+ }
- function addSingleFacet(acc, caption, data, max, pzIndex) {
- var teamName = that.team.name();
- acc.push('');
- acc.push('
' + M(caption) + '
');
- for (var i = 0; i < data.length && i < max; i++) {
- acc.push('
');
- }
- acc.push('
');
- }
- });
+ that.node.html(acc.join(''));
+ });
- widget.autosearch(that);
+ this.autosearch();
});