X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-widget-termlists.js;h=33d12b92255e538a33188256a7d8a93ca629ceda;hb=efb2e7adaf2d74aeb9433fedda5b03eaa3fde747;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..33d12b9 100644
--- a/src/mkws-widget-termlists.js
+++ b/src/mkws-widget-termlists.js
@@ -1,64 +1,64 @@
mkws.registerWidgetType('Termlists', function() {
var that = this;
- var M = mkws.M;
+ // Initially hide the termlists; display when we get results
+ $(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(''));
+
+ widget.autosearch(this);
+});
+
+
+mkws.registerWidgetType('Facet', function() {
var facetConfig = {
xtargets: [ "Sources", 16, false ],
subject: [ "Subjects", 10, true ],
- author: [ "Author", 10, true ]
+ author: [ "Authors", 10, true ]
}
- 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;
- }
+ var that = this;
+ var name = that.config.facet;
+ var ref = facetConfig[name] || alert("no facet definition for '" + name + "'");
+ var caption = ref[0];
+ var max = ref[1];
+ var pzIndex = ref[2] ? name : null;
- // display if we first got results
- $(that.node).show();
+ that.team.queue("termlists").subscribe(function(data) {
+ data = data[name];
+ var teamName = that.team.name();
var acc = [];
- acc.push('' + M('Termlists') + '
');
-
- for (var i = 0; i < facets.length; i++) {
- var name = facets[i]
- var ref = facetConfig[name];
- if (!ref) {
- alert("bad facet configuration: '" + name + "'");
+ acc.push('' + mkws.M(caption) + '
');
+ for (var i = 0; i < data.length && i < max; i++) {
+ acc.push('');
}
$(that.node).html(acc.join(''));
-
- 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('
');
- }
});
-
- widget.autosearch(that);
});