1 mkws.registerWidgetType('facets', function() {
2 // Initially hide the facets; display when we get results
6 this.team.queue("searchtriggered").subscribe(function() {
7 var op = that.config.newsearch_opacity;
8 if (op !== undefined) { that.node.fadeTo(500, op); }
11 team.queue("facets").subscribe(function(data) {
13 that.node.css('opacity', 1);
14 that.node.addClass("active");
17 var template = team.loadTemplate(this.config.template || "facets");
18 this.node.html(template({
20 facets: this.config.facets
26 mkws.registerWidgetType('facet', function() {
28 xtargets: [ "Sources", 16, false ],
29 subject: [ "Subjects", 10, true ],
30 author: [ "Authors", 10, true ]
34 var name = that.config.facet;
35 var ref = facetConfig[name] || [ "Unknown", 10, true ];
36 var caption = this.config['facet_caption_' + name] || ref[0];
37 var max = parseInt(this.config['facet_max_' + name] || ref[1]);
38 var pzIndex = ref[2] ? name : null;
40 that.toString = function() {
41 return '[Widget ' + team.name() + ':' + that.type + '(' + name + ')]';
44 team.queue("facets").subscribe(function(data) {
47 for (var i = 0; i < data.length && i < max; i++) {
48 var fs = team.filters().deepCopy();
50 // Special case: target selection
51 fs.add(targetFilter(data[i].id, data[i].name));
53 fs.add(fieldFilter(pzIndex, data[i].name));
58 href: '#' + team.urlFragment({ filters: fs })
61 // configured template > facet specific template > default facet template
63 if (that.config.template) {
64 template = team.loadTemplate(that.config.template);
66 template = team.loadTemplate("facet-" + name);
68 that.info("Using facet-" + name + " template.")
70 that.info("No " + name + " specific template, using default.")
71 template = team.loadTemplate("facet");
74 that.node.html(template({