X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-widget-termlists.js;h=33d12b92255e538a33188256a7d8a93ca629ceda;hb=5f3657b4c2aa6adb492be5addee94a3486dd839a;hp=d3dc14998559b3d9fcf7638361c393fa45e2cde1;hpb=438d9003c3d82eb7695d5adf12c6b3f380f1e46a;p=mkws-moved-to-github.git
diff --git a/src/mkws-widget-termlists.js b/src/mkws-widget-termlists.js
index d3dc149..33d12b9 100644
--- a/src/mkws-widget-termlists.js
+++ b/src/mkws-widget-termlists.js
@@ -1,80 +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: [ "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;
- }
-
- // display if we first got results
- $(that.node).show();
+ 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;
+ 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 + "'");
- } else {
- acc.push('');
- acc.push('
');
- }
- }
- $(that.node).html(acc.join(''));
-
-
- for (var i = 0; i < facets.length; i++) {
- var name = facets[i]
- var ref = facetConfig[name];
- var caption = ref[0];
- if (!ref) {
- alert("bad facet configuration: '" + name + "'");
+ acc.push('' + mkws.M(caption) + '
');
+ for (var i = 0; i < data.length && i < max; i++) {
+ acc.push('');
}
-
- function makeSingleFacet(caption, data, max, pzIndex) {
- var teamName = that.team.name();
-
- var a2 = [];
- a2.push('' + M(caption) + '
');
- for (var i = 0; i < data.length && i < max; i++) {
- a2.push('');
- }
- return a2.join('');
- }
+ $(that.node).html(acc.join(''));
});
-
- widget.autosearch(that);
});