diff options
Diffstat (limited to 'lib/output')
-rw-r--r-- | lib/output/createTemplateEngine.js | 8 | ||||
-rw-r--r-- | lib/output/json/index.js | 2 | ||||
-rw-r--r-- | lib/output/loaders/conrefs.js | 8 | ||||
-rw-r--r-- | lib/output/website/createTemplateEngine.js | 15 | ||||
-rw-r--r-- | lib/output/website/index.js | 6 | ||||
-rw-r--r-- | lib/output/website/onAsset.js | 23 | ||||
-rw-r--r-- | lib/output/website/onPage.js | 32 | ||||
-rw-r--r-- | lib/output/website/options.js | 8 |
8 files changed, 91 insertions, 11 deletions
diff --git a/lib/output/createTemplateEngine.js b/lib/output/createTemplateEngine.js index fbf39d3..a79f93f 100644 --- a/lib/output/createTemplateEngine.js +++ b/lib/output/createTemplateEngine.js @@ -1,7 +1,7 @@ var Immutable = require('immutable'); +var Templating = require('../templating'); var TemplateEngine = require('../models/templateEngine'); -var ConrefsLoader = require('./loaders/conrefs'); var defaultBlocks = require('../constants/defaultBlocks'); var defaultFilters = require('../constants/defaultFilters'); @@ -15,6 +15,9 @@ var defaultFilters = require('../constants/defaultFilters'); */ function createTemplateEngine(output) { var plugins = output.getPlugins(); + var book = output.getBook(); + var rootFolder = book.getRoot(); + var logger = book.getLogger(); var filters = plugins .reduce(function(result, plugin) { @@ -31,7 +34,8 @@ function createTemplateEngine(output) { blocks = defaultBlocks.concat(blocks); filters = defaultFilters.merge(filters); - var loader = new ConrefsLoader(); + // Create loader + var loader = new Templating.ConrefsLoader(rootFolder, logger); return new TemplateEngine({ filters: filters, diff --git a/lib/output/json/index.js b/lib/output/json/index.js index f721d22..e24c127 100644 --- a/lib/output/json/index.js +++ b/lib/output/json/index.js @@ -1,6 +1,6 @@ - module.exports = { + name: 'json', Options: require('./options'), onPage: require('./onPage') }; diff --git a/lib/output/loaders/conrefs.js b/lib/output/loaders/conrefs.js deleted file mode 100644 index 7580826..0000000 --- a/lib/output/loaders/conrefs.js +++ /dev/null @@ -1,8 +0,0 @@ -var nunjucks = require('nunjucks'); - -var Loader = nunjucks.Loader.extend({ - async: true, - -}); - -module.exports = Loader; diff --git a/lib/output/website/createTemplateEngine.js b/lib/output/website/createTemplateEngine.js new file mode 100644 index 0000000..9aed746 --- /dev/null +++ b/lib/output/website/createTemplateEngine.js @@ -0,0 +1,15 @@ +var TemplateEngine = require('../../models/templateEngine'); + +/** + Create templating engine to render themes + + @param {Output} + @return {TemplateEngine} +*/ +function createTemplateEngine(output) { + return new TemplateEngine({ + + }); +} + +module.exports = createTemplateEngine; diff --git a/lib/output/website/index.js b/lib/output/website/index.js new file mode 100644 index 0000000..e24c127 --- /dev/null +++ b/lib/output/website/index.js @@ -0,0 +1,6 @@ + +module.exports = { + name: 'json', + Options: require('./options'), + onPage: require('./onPage') +}; diff --git a/lib/output/website/onAsset.js b/lib/output/website/onAsset.js new file mode 100644 index 0000000..a2342ae --- /dev/null +++ b/lib/output/website/onAsset.js @@ -0,0 +1,23 @@ +var path = require('path'); +var fs = require('../../utils/fs'); + +/** + Copy an asset to the outptu folder + + @param {Output} output + @param {Page} page +*/ +function onAsset(output, asset) { + var book = output.getBook(); + var options = output.getOptions(); + + var rootFolder = book.getRoot(); + var outputFolder = options.get('root'); + + var filePath = path.resolve(rootFolder, asset); + var outputPath = path.resolve(outputFolder, asset); + + return fs.copy(filePath, outputPath); +} + +module.exports = onAsset; diff --git a/lib/output/website/onPage.js b/lib/output/website/onPage.js new file mode 100644 index 0000000..47274b3 --- /dev/null +++ b/lib/output/website/onPage.js @@ -0,0 +1,32 @@ +var Templating = require('../../templating'); +var JSONUtils = require('../../json'); +var Modifiers = require('../modifiers'); +var Writer = require('../writer'); +var getModifiers = require('../getModifiers'); +var createTemplateEngine = require('./createTemplateEngine'); + +/** + Write a page as a json file + + @param {Output} output + @param {Page} page +*/ +function onPage(output, page) { + var engine = createTemplateEngine(output); + + return Modifiers.modifyHTML(page, getModifiers(output, page)) + .then(function(resultPage) { + // Generate the context + var context = JSONUtils.encodeBookWithPage(output.getBook(), resultPage); + + // Render the theme + return Templating.renderFile(engine, 'website/page.html', context) + + // Write it to the disk + .then(function(html) { + return Writer.writePage(output, resultPage, html); + }); + }); +} + +module.exports = onPage; diff --git a/lib/output/website/options.js b/lib/output/website/options.js new file mode 100644 index 0000000..79167b1 --- /dev/null +++ b/lib/output/website/options.js @@ -0,0 +1,8 @@ +var Immutable = require('immutable'); + +var Options = Immutable.Record({ + // Root folder for the output + root: String() +}); + +module.exports = Options; |