summaryrefslogtreecommitdiff
path: root/app/node_modules/oktemplate/index.js
blob: 09a78bff4bbcc87fb706c21c26633875cb6341e8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
var fs = require('fs');
var path = require('path');
var glob = require('glob');
var stringify = require('json-to-html');
var LiquidEngine = require('liquid-node').Engine;
var liquid = new LiquidEngine();

/**
 * Add any custom liquid filters here.
 */
liquid.registerFilters({

  /**
   * Return a string formatted version of a JSON object.
   * Useful for quick debugging of template data.
   */
  stringify: function(obj) {
    return '<pre>' + stringify(obj) + '</pre>';
  }

});

/**
 * Manages templates. Only supports Mustache currently/
 */
function OKTemplateRepo(options) {
  options = options || {};
  this._root = options.root || 'templates';
  this._extPattern = options.ext || '.+(liquid|html)';
  this._cache = {};
  this._populateCache(this._cache);
}

OKTemplateRepo.prototype.getTemplate = function getTemplate(name) {
  return this._cache[name];
}

/**
 * Go through our template dir and read the template files
 * into memory as strings.
 * Assumes all templates fit into memory.
 */
OKTemplateRepo.prototype._populateCache = function _populateCache(cache) {
  var self = this;
  var files = glob.sync(this._root + '/*' + this._extPattern);
  files.forEach(function eachFile(file) {
    var ext = path.extname(file);
    var name = path.basename(file, ext);
    var templateString = fs.readFileSync(file, {encoding: 'UTF8'});
    cache[name] = {
      name: name,
      templateString: templateString,
      render: function(data) {
        // TODO Not sure if this caches parsed templates behind the scenes?
        return liquid.parseAndRender(templateString, data);
      }
    }
  });
}

module.exports = OKTemplateRepo;