X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-widget-termlists.js;h=33d12b92255e538a33188256a7d8a93ca629ceda;hb=efb2e7adaf2d74aeb9433fedda5b03eaa3fde747;hp=5986a57e4ce17ab0f5bdeb73eb358a4acf504811;hpb=ad1b08617688bdbd9de3f92f85b91f8c27d99734;p=mkws-moved-to-github.git
diff --git a/src/mkws-widget-termlists.js b/src/mkws-widget-termlists.js
index 5986a57..33d12b9 100644
--- a/src/mkws-widget-termlists.js
+++ b/src/mkws-widget-termlists.js
@@ -1,86 +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;
- }
+ 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 + "'");
- } else {
- acc.push('');
- acc.push('
');
- }
- }
- $(that.node).html(acc.join(''));
-
-
- var output = {};
- 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('');
}
- for (var i = 0; i < facets.length; i++) {
- var name = facets[i]
- var ref = facetConfig[name];
- var caption = ref[0];
-
- that.log("setting HTML for facet '" + name + "'");
- that.team.findnode('.mkwsFacet' + caption).html(output[name]);
- }
-
-
- 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);
});