summaryrefslogtreecommitdiffstats
path: root/lib/templating
diff options
context:
space:
mode:
authorSamy Pessé <samypesse@gmail.com>2016-04-25 13:52:56 +0200
committerSamy Pessé <samypesse@gmail.com>2016-04-25 13:52:56 +0200
commit4aed2cf65240abb26384d7d86ccb27b171e6bb9a (patch)
tree949ede45c93c37215c44bd1b190248d7669501b0 /lib/templating
parent244fb0ca28f29ac429f58e0e885d21cc6c40beba (diff)
downloadgitbook-4aed2cf65240abb26384d7d86ccb27b171e6bb9a.zip
gitbook-4aed2cf65240abb26384d7d86ccb27b171e6bb9a.tar.gz
gitbook-4aed2cf65240abb26384d7d86ccb27b171e6bb9a.tar.bz2
Add post processing for templates
Diffstat (limited to 'lib/templating')
-rw-r--r--lib/templating/index.js3
-rw-r--r--lib/templating/postRender.js28
-rw-r--r--lib/templating/replaceBlocks.js34
3 files changed, 64 insertions, 1 deletions
diff --git a/lib/templating/index.js b/lib/templating/index.js
index 312146a..3a8f989 100644
--- a/lib/templating/index.js
+++ b/lib/templating/index.js
@@ -1,4 +1,5 @@
module.exports = {
- render: require('./render')
+ render: require('./render'),
+ postRender: require('./postRender')
};
diff --git a/lib/templating/postRender.js b/lib/templating/postRender.js
new file mode 100644
index 0000000..6928e82
--- /dev/null
+++ b/lib/templating/postRender.js
@@ -0,0 +1,28 @@
+var Promise = require('../utils/promise');
+var replaceBlocks = require('./replaceBlocks');
+
+/**
+ Post render a template:
+ - Execute "post" for blocks
+ - Replace block content
+
+ @param {TemplateEngine} engine
+ @param {String} content
+ @return {Promise<String>}
+*/
+function postRender(engine, content) {
+ var result = replaceBlocks(content);
+
+ return Promise.forEach(result.blocks, function(blockType) {
+ var block = engine.getBlock();
+ var post = block.getPost();
+ if (!post) {
+ return;
+ }
+
+ return post();
+ })
+ .thenResolve(result.content);
+}
+
+module.exports = postRender;
diff --git a/lib/templating/replaceBlocks.js b/lib/templating/replaceBlocks.js
new file mode 100644
index 0000000..4b1c37f
--- /dev/null
+++ b/lib/templating/replaceBlocks.js
@@ -0,0 +1,34 @@
+var Immutable = require('immutable');
+var TemplateBlock = require('../models/templateBlock');
+
+/**
+ Replace position markers of blocks by body after processing
+ This is done to avoid that markdown/asciidoc processer parse the block content
+
+ @param {String} content
+ @return {Object} {blocks: Set, content: String}
+*/
+function replaceBlocks(content) {
+ var blockTypes = new Immutable.Set();
+ var newContent = content.replace(/\{\{\-\%([\s\S]+?)\%\-\}\}/g, function(match, key) {
+ var replacedWith = match;
+
+ var block = TemplateBlock.getBlockResultByKey(key);
+ if (block) {
+ var result = replaceBlocks(block.body);
+
+ blockTypes = blockTypes.add(block.name);
+ blockTypes = blockTypes.concat(result.blocks);
+ replacedWith = result.content;
+ }
+
+ return replacedWith;
+ });
+
+ return {
+ content: newContent,
+ blocks: blockTypes
+ };
+}
+
+module.exports = replaceBlocks;