Merge branch 'master' into templateallthemarkup
authorJason Skomorowski <jason@indexdata.com>
Mon, 7 Jul 2014 23:30:04 +0000 (19:30 -0400)
committerJason Skomorowski <jason@indexdata.com>
Mon, 7 Jul 2014 23:30:04 +0000 (19:30 -0400)
Conflicts:
src/.gitignore
src/mkws-core.js
src/mkws-team.js
src/mkws-widget-termlists.js
tools/htdocs/Makefile

1  2 
README
src/mkws-core.js
src/mkws-team.js
src/mkws-templates.js
src/mkws-widget-main.js
tools/htdocs/Makefile

diff --cc README
Simple merge
Simple merge
@@@ -386,36 -386,41 +386,36 @@@ function team($, teamName) 
    };
  
  
-   function loadTemplate(name) {
+   function loadTemplate(name, fallbackString) {
      var template = m_template[name];
 -
 -    if (template === undefined) {
 -      // Fall back to generic template if there is no team-specific one
 +    if (template === undefined && Handlebars.compile) {
        var source;
        var node = $(".mkwsTemplate_" + name + " .mkwsTeam_" + that.name());
        if (node && node.length < 1) {
          node = $(".mkwsTemplate_" + name);
        }
 -      if (node) {
 -        source = node.html();
 -      }
 -
 -      // If the template is not defined in HTML, check the following
 -      // in order: template registered in the team by a widget;
 -      // fallback string provided on this invocation; global default.
 -      if (!source) {
 -        source = m_templateText[name];
 -      }
 -      if (!source) {
 -        source = fallbackString;
 -      }
 -      if (!source) {
 -        source = mkws.defaultTemplate(name);
 +      if (node) source = node.html();
 +      if (!source) source = m_templateText[name];
 +      if (source) {
 +        template = Handlebars.compile(source);
 +        log("compiled template '" + name + "'");
        }
 -
 -      if (!source) return null;
 -      template = Handlebars.compile(source);
 -      log("compiled template '" + name + "'");
 +    }
 +    //if (template === undefined) template = mkws_templatesbyteam[m_teamName][name];
 +    if (template === undefined && Handlebars.templates) {
 +      template = Handlebars.templates[name];
 +    }
 +    if (template === undefined && mkws.defaultTemplates) {
 +      template = mkws.defaultTemplates[name];
 +    }
 +    if (template) {
        m_template[name] = template;
 +      return template;
      }
 -
 -    return template;
 +    else {
 +      alert("Missing MKWS template for " + name);
 +    }  
-     }
+   }
    that.loadTemplate = loadTemplate;
  
  
index 0000000,0000000..86150aa
new file mode 100644 (file)
--- /dev/null
--- /dev/null
@@@ -1,0 -1,0 +1,388 @@@
++(function() {
++  var template = Handlebars.template, templates = mkws.defaultTemplates = mkws.defaultTemplates || {};
++templates['Image'] = template(function (Handlebars,depth0,helpers,partials,data) {
++  this.compilerInfo = [4,'>= 1.0.0'];
++helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
++  var buffer = "", stack1, functionType="function", escapeExpression=this.escapeExpression, self=this, helperMissing=helpers.helperMissing;
++
++function program1(depth0,data) {
++  
++  var buffer = "", stack1, helper, options;
++  buffer += "\n  <a href=\"#\" id=\"";
++  if (helper = helpers.detailLinkId) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.detailLinkId); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\" onclick=\"";
++  if (helper = helpers.detailClick) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.detailClick); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\">\n    ";
++  stack1 = (helper = helpers['mkws-first'] || (depth0 && depth0['mkws-first']),options={hash:{},inverse:self.noop,fn:self.programWithDepth(2, program2, data, depth0),data:data},helper ? helper.call(depth0, (depth0 && depth0['md-thumburl']), options) : helperMissing.call(depth0, "mkws-first", (depth0 && depth0['md-thumburl']), options));
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    <br/>\n  </a>\n";
++  return buffer;
++  }
++function program2(depth0,data,depth1) {
++  
++  var buffer = "", stack1;
++  buffer += "\n      <img src=\""
++    + escapeExpression((typeof depth0 === functionType ? depth0.apply(depth0) : depth0))
++    + "\" alt=\""
++    + escapeExpression(((stack1 = (depth1 && depth1['md-title'])),typeof stack1 === functionType ? stack1.apply(depth0) : stack1))
++    + "\"/>\n    ";
++  return buffer;
++  }
++
++  buffer += "\n";
++  stack1 = helpers.each.call(depth0, (depth0 && depth0.hits), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n";
++  return buffer;
++  });
++templates['Record'] = template(function (Handlebars,depth0,helpers,partials,data) {
++  this.compilerInfo = [4,'>= 1.0.0'];
++helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
++  var buffer = "", stack1, helper, options, functionType="function", escapeExpression=this.escapeExpression, helperMissing=helpers.helperMissing, self=this;
++
++function program1(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n        (";
++  if (helper = helpers['md-title-remainder']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title-remainder']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + ")\n      ";
++  return buffer;
++  }
++
++function program3(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n        <i>";
++  if (helper = helpers['md-title-responsibility']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title-responsibility']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</i>\n      ";
++  return buffer;
++  }
++
++function program5(depth0,data) {
++  
++  var buffer = "", stack1, helper, options;
++  buffer += "\n  <tr>\n    <th>"
++    + escapeExpression((helper = helpers['mkws-translate'] || (depth0 && depth0['mkws-translate']),options={hash:{},data:data},helper ? helper.call(depth0, "Date", options) : helperMissing.call(depth0, "mkws-translate", "Date", options)))
++    + "</th>\n    <td>";
++  if (helper = helpers['md-date']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-date']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</td>\n  </tr>\n  ";
++  return buffer;
++  }
++
++function program7(depth0,data) {
++  
++  var buffer = "", stack1, helper, options;
++  buffer += "\n  <tr>\n    <th>"
++    + escapeExpression((helper = helpers['mkws-translate'] || (depth0 && depth0['mkws-translate']),options={hash:{},data:data},helper ? helper.call(depth0, "Author", options) : helperMissing.call(depth0, "mkws-translate", "Author", options)))
++    + "</th>\n    <td>";
++  if (helper = helpers['md-author']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-author']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</td>\n  </tr>\n  ";
++  return buffer;
++  }
++
++function program9(depth0,data) {
++  
++  var buffer = "", stack1, helper, options;
++  buffer += "\n  <tr>\n    <th>"
++    + escapeExpression((helper = helpers['mkws-translate'] || (depth0 && depth0['mkws-translate']),options={hash:{},data:data},helper ? helper.call(depth0, "Links", options) : helperMissing.call(depth0, "mkws-translate", "Links", options)))
++    + "</th>\n    <td>\n      ";
++  stack1 = helpers.each.call(depth0, (depth0 && depth0['md-electronic-url']), {hash:{},inverse:self.noop,fn:self.program(10, program10, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    </td>\n  </tr>\n  ";
++  return buffer;
++  }
++function program10(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n        <a href=\""
++    + escapeExpression((typeof depth0 === functionType ? depth0.apply(depth0) : depth0))
++    + "\">Link";
++  if (helper = helpers['mkws-index1']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['mkws-index1']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</a>\n      ";
++  return buffer;
++  }
++
++function program12(depth0,data) {
++  
++  var buffer = "", stack1, helper, options;
++  buffer += "\n  <tr>\n    <th>"
++    + escapeExpression((helper = helpers['mkws-translate'] || (depth0 && depth0['mkws-translate']),options={hash:{},data:data},helper ? helper.call(depth0, "Subject", options) : helperMissing.call(depth0, "mkws-translate", "Subject", options)))
++    + "</th>\n    <td>\n      ";
++  stack1 = (helper = helpers['mkws-first'] || (depth0 && depth0['mkws-first']),options={hash:{
++    'having': ("md-subject")
++  },inverse:self.noop,fn:self.program(13, program13, data),data:data},helper ? helper.call(depth0, (depth0 && depth0.location), options) : helperMissing.call(depth0, "mkws-first", (depth0 && depth0.location), options));
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    </td>\n  </tr>\n  ";
++  return buffer;
++  }
++function program13(depth0,data) {
++  
++  var buffer = "", stack1;
++  buffer += "\n        ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-subject']), {hash:{},inverse:self.noop,fn:self.program(14, program14, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n      ";
++  return buffer;
++  }
++function program14(depth0,data) {
++  
++  var buffer = "", stack1, helper, options;
++  buffer += "\n          ";
++  stack1 = (helper = helpers['mkws-commaList'] || (depth0 && depth0['mkws-commaList']),options={hash:{},inverse:self.noop,fn:self.program(15, program15, data),data:data},helper ? helper.call(depth0, (depth0 && depth0['md-subject']), options) : helperMissing.call(depth0, "mkws-commaList", (depth0 && depth0['md-subject']), options));
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n        ";
++  return buffer;
++  }
++function program15(depth0,data) {
++  
++  var buffer = "";
++  buffer += "\n            "
++    + escapeExpression((typeof depth0 === functionType ? depth0.apply(depth0) : depth0));
++  return buffer;
++  }
++
++function program17(depth0,data) {
++  
++  var buffer = "", helper, options;
++  buffer += "\n        "
++    + escapeExpression((helper = helpers['mkws-attr'] || (depth0 && depth0['mkws-attr']),options={hash:{},data:data},helper ? helper.call(depth0, "@name", options) : helperMissing.call(depth0, "mkws-attr", "@name", options)));
++  return buffer;
++  }
++
++  buffer += "\n<table>\n  <tr>\n    <th>"
++    + escapeExpression((helper = helpers['mkws-translate'] || (depth0 && depth0['mkws-translate']),options={hash:{},data:data},helper ? helper.call(depth0, "Title", options) : helperMissing.call(depth0, "mkws-translate", "Title", options)))
++    + "</th>\n    <td>\n      ";
++  if (helper = helpers['md-title']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\n      ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-title-remainder']), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n      ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-title-responsibility']), {hash:{},inverse:self.noop,fn:self.program(3, program3, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    </td>\n  </tr>\n  ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-date']), {hash:{},inverse:self.noop,fn:self.program(5, program5, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n  ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-author']), {hash:{},inverse:self.noop,fn:self.program(7, program7, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n  ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-electronic-url']), {hash:{},inverse:self.noop,fn:self.program(9, program9, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n  ";
++  stack1 = (helper = helpers['mkws-if-any'] || (depth0 && depth0['mkws-if-any']),options={hash:{
++    'having': ("md-subject")
++  },inverse:self.noop,fn:self.program(12, program12, data),data:data},helper ? helper.call(depth0, (depth0 && depth0.location), options) : helperMissing.call(depth0, "mkws-if-any", (depth0 && depth0.location), options));
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n  <tr>\n    <th>"
++    + escapeExpression((helper = helpers['mkws-translate'] || (depth0 && depth0['mkws-translate']),options={hash:{},data:data},helper ? helper.call(depth0, "Locations", options) : helperMissing.call(depth0, "mkws-translate", "Locations", options)))
++    + "</th>\n    <td>\n      ";
++  stack1 = (helper = helpers['mkws-commaList'] || (depth0 && depth0['mkws-commaList']),options={hash:{},inverse:self.noop,fn:self.program(17, program17, data),data:data},helper ? helper.call(depth0, (depth0 && depth0.location), options) : helperMissing.call(depth0, "mkws-commaList", (depth0 && depth0.location), options));
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    </td>\n  </tr>\n</table>\n";
++  return buffer;
++  });
++templates['Records'] = template(function (Handlebars,depth0,helpers,partials,data) {
++  this.compilerInfo = [4,'>= 1.0.0'];
++helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
++  var buffer = "", stack1, functionType="function", escapeExpression=this.escapeExpression, self=this;
++
++function program1(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n  <div class=\"";
++  if (helper = helpers.containerClass) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.containerClass); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\">\n    <a href=\"#\" id=\"";
++  if (helper = helpers.detailLinkId) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.detailLinkId); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\" onclick=\"";
++  if (helper = helpers.detailClick) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.detailClick); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\">\n      <b>";
++  if (helper = helpers['md-title']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</b>\n    </a>\n    ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-title-remainder']), {hash:{},inverse:self.noop,fn:self.program(2, program2, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-title-responsibility']), {hash:{},inverse:self.noop,fn:self.program(4, program4, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    ";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0.renderedDetails), {hash:{},inverse:self.noop,fn:self.program(6, program6, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n  </div>\n";
++  return buffer;
++  }
++function program2(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n      <span>";
++  if (helper = helpers['md-title-remainder']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title-remainder']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</span>\n    ";
++  return buffer;
++  }
++
++function program4(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n      <span><i>";
++  if (helper = helpers['md-title-responsibility']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title-responsibility']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</i></span>\n    ";
++  return buffer;
++  }
++
++function program6(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n      ";
++  if (helper = helpers.renderedDetails) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.renderedDetails); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n    ";
++  return buffer;
++  }
++
++  buffer += "\n";
++  stack1 = helpers.each.call(depth0, (depth0 && depth0.hits), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n";
++  return buffer;
++  });
++templates['Reference'] = template(function (Handlebars,depth0,helpers,partials,data) {
++  this.compilerInfo = [4,'>= 1.0.0'];
++helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
++  var buffer = "", stack1, helper, options, functionType="function", escapeExpression=this.escapeExpression, self=this, helperMissing=helpers.helperMissing;
++
++function program1(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n<b>";
++  if (helper = helpers['md-title-remainder']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title-remainder']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</b>\n";
++  return buffer;
++  }
++
++function program3(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n<i>";
++  if (helper = helpers['md-title-responsibility']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title-responsibility']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</i>\n";
++  return buffer;
++  }
++
++  buffer += "\n<img src=\"";
++  if (helper = helpers['md-thumburl']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-thumburl']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\" alt=\"";
++  if (helper = helpers['md-title']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\">\n<h1><a href=\"";
++  if (helper = helpers['md-electronic-url']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-electronic-url']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\">";
++  if (helper = helpers['md-title']) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0['md-title']); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</a></h1>\n";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-title-remainder']), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n";
++  stack1 = helpers['if'].call(depth0, (depth0 && depth0['md-title-responsibility']), {hash:{},inverse:self.noop,fn:self.program(3, program3, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n";
++  stack1 = (helper = helpers['mkws-paragraphs'] || (depth0 && depth0['mkws-paragraphs']),options={hash:{},data:data},helper ? helper.call(depth0, (depth0 && depth0['md-description']), (depth0 && depth0.paragraphs), (depth0 && depth0.sentences), options) : helperMissing.call(depth0, "mkws-paragraphs", (depth0 && depth0['md-description']), (depth0 && depth0.paragraphs), (depth0 && depth0.sentences), options));
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n<p class=\"mkwsCredit\">Wikipedia</p>\n";
++  return buffer;
++  });
++templates['Facet'] = template(function (Handlebars,depth0,helpers,partials,data) {
++  this.compilerInfo = [4,'>= 1.0.0'];
++helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
++  var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression, self=this;
++
++function program1(depth0,data) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n  <div class=\"mkwsTerm\">\n    <a href=\"#\" ";
++  if (helper = helpers.linkdata) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.linkdata); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + ">";
++  if (helper = helpers.term) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.term); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</a> <span>";
++  if (helper = helpers.count) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.count); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</span>\n  </div>\n";
++  return buffer;
++  }
++
++  buffer += "\n\n<div class=\"mkwsFacetTitle\">";
++  if (helper = helpers.caption) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.caption); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "</div>\n";
++  stack1 = helpers.each.call(depth0, (depth0 && depth0.terms), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n";
++  return buffer;
++  });
++templates['Termlists'] = template(function (Handlebars,depth0,helpers,partials,data) {
++  this.compilerInfo = [4,'>= 1.0.0'];
++helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
++  var buffer = "", stack1, functionType="function", escapeExpression=this.escapeExpression, self=this;
++
++function program1(depth0,data,depth1) {
++  
++  var buffer = "", stack1, helper;
++  buffer += "\n  <div class=\"mkwsFacet mkwsTeam_"
++    + escapeExpression(((stack1 = (depth1 && depth1.team)),typeof stack1 === functionType ? stack1.apply(depth0) : stack1))
++    + "\" data-mkws-facet=\"";
++  if (helper = helpers.name) { stack1 = helper.call(depth0, {hash:{},data:data}); }
++  else { helper = (depth0 && depth0.name); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
++  buffer += escapeExpression(stack1)
++    + "\"></div>\n";
++  return buffer;
++  }
++
++  buffer += "\n\n<div class=\"mkwsTermlistsTitle\">Termlists</div>\n";
++  stack1 = helpers.each.call(depth0, (depth0 && depth0.facets), {hash:{},inverse:self.noop,fn:self.programWithDepth(1, program1, data, depth0),data:data});
++  if(stack1 || stack1 === 0) { buffer += stack1; }
++  buffer += "\n";
++  return buffer;
++  });
++})();
Simple merge
index 0000000,388a4b8..02d64f8
mode 000000,100644..100644
--- /dev/null
@@@ -1,0 -1,98 +1,102 @@@
+ # Copyright (c) 2013-2014 IndexData ApS. http://indexdata.com
+ SRC=   ../../src
+ HANDLEBARS_FILE = handlebars-v1.1.2.js
+ JQUERY_FILE = jquery-1.10.0.min.js
+ JQUERY_JSON_FILE = jquery.json-2.4.js
+ PP2_FILE = pz2.js
+ HANDLEBARS_URL = http://builds.handlebarsjs.com.s3.amazonaws.com/${HANDLEBARS_FILE}
+ JQUERY_URL = http://code.jquery.com/${JQUERY_FILE}
+ JQUERY_JSON_URL = https://jquery-json.googlecode.com/files/${JQUERY_JSON_FILE}
+ PP2_URL = http://git.indexdata.com/?p=pazpar2.git;a=blob_plain;f=js/${PP2_FILE};hb=HEAD
+ JQUERY_UI_URL =       http://code.jquery.com/ui/1.10.3/jquery-ui.js
+ VERSION = $(shell tr -d '\012' < ${SRC}/VERSION)
+ COMPONENTS = ${SRC}/mkws-handlebars.js \
+       ${SRC}/mkws-core.js ${SRC}/mkws-team.js ${SRC}/mkws-filter.js \
++      ${SRC}/mkws-templates.js \
+       ${SRC}/mkws-widget.js ${SRC}/mkws-widget-main.js ${SRC}/mkws-widget-termlists.js \
+       ${SRC}/mkws-widget-authname.js ${SRC}/mkws-widget-categories.js ${SRC}/mkws-widget-log.js \
+       ${SRC}/mkws-widget-record.js ${SRC}/mkws-widget-reference.js ${SRC}/mkws-widget-builder.js
+ GENERATED = ${HANDLEBARS_FILE} ${JQUERY_FILE} ${JQUERY_JSON_FILE} ${PP2_FILE} \
 -      mkws.js mkws.min.js mkws-complete.js mkws-complete.min.js
++      mkws.js mkws.min.js mkws-complete.js mkws-complete.min.js mkws-templates.js
+ **make-default**: all
+ all: mkws.min.js mkws-complete.min.js
+ mkws-js mkws-complete.js: Makefile mkws.js ${SRC}/mkws-jquery.js ${HANDLEBARS_FILE} ${JQUERY_FILE} ${JQUERY_JSON_FILE} ${PP2_FILE}
+       ( set -e; \
+         echo "/*! Copyright (c) 2013-2014 IndexData ApS. http://indexdata.com"; \
+         echo "   Licence: GPL, http://www.indexdata.com/licences/gpl"; \
+         echo "   created at: $$(date)"; \
+         echo "   MKWS GIT id: $$(git show | head -n 1 | perl -npe 's,\S+\s+,,')"; \
+         echo "   pz2.js GIT id: $$(curl -sSf 'http://git.indexdata.com/?p=pazpar2.git;a=rss' | egrep '<guid' | head -1 | perl -ne 'print "$$1\n" if m,.*=([0-9a-f]+)</guid>,')"; \
+         echo "*/"; \
+         cat ${JQUERY_FILE}; \
+         cat ${JQUERY_JSON_FILE}; \
+         echo 'mkws_jQuery = jQuery.noConflict(true);'; \
+         cat ${HANDLEBARS_FILE}; \
+         cat ${PP2_FILE}; \
+         cat  mkws.js; \
+         cat  ${SRC}/mkws-jquery.js; \
+       ) > mkws-complete.js.tmp
+       mv -f mkws-complete.js.tmp mkws-complete.js
+ %.min.js: %.js
+       yui-compressor $? > $@.tmp
+       mv -f $@.tmp $@
+ mkws-syntax-check:
+       yui-compressor mkws.js >/dev/null
+ ${HANDLEBARS_FILE}:
+       curl -sSf ${HANDLEBARS_URL} -o $@.tmp
+       mv -f $@.tmp $@
+ ${JQUERY_FILE}:
+       curl -sSf ${JQUERY_URL} -o $@.tmp
+       perl -npe 's,sourceMappingURL=jquery.*map,,' $@.tmp > $@
+       rm -f $@.tmp
+ ${JQUERY_JSON_FILE}:
+       curl -sSf ${JQUERY_JSON_URL} -o $@.tmp
+       mv -f $@.tmp $@
+ ${PP2_FILE}:
+       curl -sSf "${PP2_URL}" -o $@.tmp
+       mv -f $@.tmp $@
+ release: mkws.js mkws-complete.js mkws.min.js mkws-complete.min.js
+       @if [ -f ${SRC}/releases/mkws-$(VERSION).js ]; then \
+               echo "*** There is already a release $(VERSION)"; \
+       else \
+               cp -p mkws.js ${SRC}/releases/mkws-$(VERSION).js; \
+               cp -p mkws.min.js ${SRC}/releases/mkws-$(VERSION).min.js; \
+               cp -p mkws-complete.js ${SRC}/releases/mkws-complete-$(VERSION).js; \
+               cp -p mkws-complete.min.js ${SRC}/releases/mkws-complete-$(VERSION).min.js; \
+               echo "Made release $(VERSION)"; \
+       fi
 -mkws.js: $(COMPONENTS) Makefile
++mkws.js: mkws-templates.js $(COMPONENTS) Makefile
+       rm -f $@
+       cat ${COMPONENTS} > $@.tmp
+       mv -f $@.tmp $@
+       chmod 444 $@
++mkws-templates.js:
++      handlebars -n mkws.defaultTemplates ${SRC}/*.templates/*.handlebars -f ${SRC}/mkws-templates.js
++
+ distclean: clean
+       @echo "(No need for distclean, 'make clean' is fine)"
+ clean:
+       rm -f ${GENERATED}
+ help:
+       @echo "make [ all | release | clean | distclean ]"
+       @echo "     [ mkws-syntax-check ]"