Record details generated by a Handlebars template now correctly appear
[mkws-moved-to-github.git] / tools / htdocs / mkws.js
index e560ad1..60464d7 100644 (file)
@@ -640,7 +640,26 @@ function replaceHtml(el, html) {
 
 function renderDetails(data, marker)
 {
-    var details = '<div class="details" id="mkwsDet_'+data.recid+'"><table>';
+    var details = '<div class="details" id="mkwsDet_'+data.recid+'">';
+
+    if (mkws.templateRecord === undefined) {
+       maybeLoadTemplate("Record");
+    }
+
+    if (mkws.templateRecord) {
+       var template = mkws.templateRecord;
+       details += template(data);
+    } else {
+       details += defaultRenderRecord(data, marker);
+    }
+
+    details += '</div>';
+    return details;
+}
+
+function defaultRenderRecord(data, marker)
+{
+    var details = '<table>';
     if (marker) details += '<tr><td colspan="2">'+ marker + '</td></tr>';
 
     var locations = [];
@@ -658,11 +677,27 @@ function renderDetails(data, marker)
     } else {
        details += renderField("Location" + (locations.length == 1 ? "" : "s"), locations);
     }
-    details += '</table></div>';
-
+    details += '</table>';
     return details;
 }
 
+
+function maybeLoadTemplate(name)
+{
+    var source = $("#mkwsTemplate" + name).html();
+    if (!source) {
+       debug("no template '" + name + "': falling back to default behaviour");
+       // Mark template as not provided
+       mkws['template' + name] = 0;
+       return;
+    }
+
+    var template = Handlebars.compile(source);
+    debug("compiled template '" + name + "'");
+    mkws['template' + name] = template;
+}
+
+
 function renderField(caption, data, data2, data3) {
     if (data === undefined) {
        return "";