X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fmkws-widget-termlists.js;h=e8cab105c6a4f9c6aa2e5cf54c49f4ef2565fde3;hb=e57e1a47bd7f90509d61d65fbe2f6d2092478770;hp=166c853d37cb64f90b3d3eb43afdbdc8a20b3957;hpb=a8222fe3f79e3d9ab3974326254596261cb2a460;p=mkws-moved-to-github.git
diff --git a/src/mkws-widget-termlists.js b/src/mkws-widget-termlists.js
index 166c853..e8cab10 100644
--- a/src/mkws-widget-termlists.js
+++ b/src/mkws-widget-termlists.js
@@ -1,91 +1,81 @@
-mkws.registerWidgetType('Termlists', function() {
- var that = this;
- var M = mkws.M;
+mkws.registerWidgetType('termlists', function() {
+ // Initially hide the termlists; display when we get results
+ var that = this;
+ var team = this.team;
+ team.queue("termlists").subscribe(function(data) {
+ that.node.addClass("active");
+ });
- 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 output = {};
- 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 {
- addSingleScaffold(acc, ref[0]);
- function addSingleScaffold(acc, caption) {
- var teamName = that.team.name();
- acc.push('');
- acc.push('
');
- }
- }
- }
-
- for (var i = 0; i < facets.length; i++) {
- var name = facets[i]
- var ref = facetConfig[name];
- if (!ref) {
- alert("bad facet configuration: '" + name + "'");
- } else {
- output[name] = makeSingleFacet(ref[0], data[name], ref[1], ref[2] ? name : null);
- }
- }
-
- $(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];
-
- that.log("setting HTML for facet '" + name + "'");
- that.team.findnode('.mkwsFacet' + caption).html(output[name]);
- }
+ var template = team.loadTemplate(this.config.template || "Termlists");
+ this.node.html(template({
+ team: team.name(),
+ facets: this.config.facets
+ }));
+ this.autosearch();
+});
- function makeSingleFacet(caption, data, max, pzIndex) {
- var teamName = that.team.name();
+mkws.registerWidgetType('facet', function() {
+ var facetConfig = {
+ xtargets: [ "Sources", 16, false ],
+ subject: [ "Subjects", 10, true ],
+ author: [ "Authors", 10, true ]
+ }
+ var that = this;
+ var team = this.team;
+ 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;
- var a2 = [];
- a2.push('' + M(caption) + '
');
- for (var i = 0; i < data.length && i < max; i++) {
- a2.push('');
- }
- return a2.join('');
- }
- });
+ that.toString = function() {
+ return '[Widget ' + team.name() + ':' + that.type + '(' + name + ')]';
+ };
- widget.autosearch(that);
+ team.queue("termlists").subscribe(function(data) {
+ data = data[name];
+ var terms = [];
+ var teamName = team.name();
+ for (var i = 0; i < data.length && i < max; i++) {
+ var linkdata = "";
+ var action = "";
+ if (!pzIndex) {
+ // Special case: target selection
+ linkdata += ('target_id='+data[i].id+' ');
+ if (!team.targetFiltered(data[i].id)) {
+ action = 'mkws.limitTarget(\'' + teamName + '\', this.getAttribute(\'target_id\'),this.firstChild.nodeValue)';
+ }
+ } else {
+ action = 'mkws.limitQuery(\'' + teamName + '\', \'' + pzIndex + '\', this.firstChild.nodeValue)';
+ }
+ linkdata += 'onclick="' + action + ';return false;"';
+ terms.push({
+ term: data[i].name,
+ field: data[i].id,
+ count: data[i].freq,
+ linkdata: linkdata
+ });
+ }
+ // configured template > facet specific template > default facet template
+ var template;
+ if (that.config.template) {
+ template = team.loadTemplate(that.config.template);
+ } else {
+ template = team.loadTemplate("facet-" + name);
+ if (template) {
+ that.log("Using facet-" + name + " template.")
+ } else {
+ that.log("No " + name + " specific template, using default.")
+ template = team.loadTemplate("Facet");
+ }
+ }
+ that.node.html(template({
+ name: name,
+ caption: caption,
+ query: that.config.query,
+ terms: terms
+ }));
+ });
+ this.autosearch();
});