diff options
author | Samy Pessé <samypesse@gmail.com> | 2016-04-27 13:47:12 +0200 |
---|---|---|
committer | Samy Pessé <samypesse@gmail.com> | 2016-04-27 13:47:12 +0200 |
commit | 7298dec35314065e965b5738e751ad25e4ff2a94 (patch) | |
tree | 31c2b36c398771356de4891e163831a1d413a5ac | |
parent | 7574b01863e7c8a55bacc07f38dd4180baa41d62 (diff) | |
download | gitbook-7298dec35314065e965b5738e751ad25e4ff2a94.zip gitbook-7298dec35314065e965b5738e751ad25e4ff2a94.tar.gz gitbook-7298dec35314065e965b5738e751ad25e4ff2a94.tar.bz2 |
Add plugins.resources for template context
-rw-r--r-- | lib/constants/pluginResources.js | 6 | ||||
-rw-r--r-- | lib/output/generateBook.js | 3 | ||||
-rw-r--r-- | lib/output/website/onPage.js | 8 | ||||
-rw-r--r-- | lib/plugins/index.js | 3 | ||||
-rw-r--r-- | lib/plugins/listResources.js | 45 |
5 files changed, 60 insertions, 5 deletions
diff --git a/lib/constants/pluginResources.js b/lib/constants/pluginResources.js index de5eb18..ae283bf 100644 --- a/lib/constants/pluginResources.js +++ b/lib/constants/pluginResources.js @@ -1,4 +1,6 @@ -module.exports = [ +var Immutable = require('immutable'); + +module.exports = Immutable.List([ 'js', 'css' -]; +]); diff --git a/lib/output/generateBook.js b/lib/output/generateBook.js index ef7d5f1..5138f88 100644 --- a/lib/output/generateBook.js +++ b/lib/output/generateBook.js @@ -42,7 +42,8 @@ function generateBook(generator, book, options) { new Output({ book: book, options: options, - state: state + state: state, + generator: generator.name }) ) .then(preparePlugins) diff --git a/lib/output/website/onPage.js b/lib/output/website/onPage.js index 8af3622..ddae986 100644 --- a/lib/output/website/onPage.js +++ b/lib/output/website/onPage.js @@ -2,6 +2,7 @@ var path = require('path'); var omit = require('omit-keys'); var Templating = require('../../templating'); +var Plugins = require('../../plugins'); var JSONUtils = require('../../json'); var LocationUtils = require('../../utils/location'); var Modifiers = require('../modifiers'); @@ -22,6 +23,7 @@ function onPage(output, page) { var prefix = options.get('prefix'); var book = output.getBook(); var config = book.getConfig(); + var plugins = output.getPlugins(); var engine = createTemplateEngine(output, page.getPath()); @@ -36,7 +38,11 @@ function onPage(output, page) { .then(function(resultPage) { // Generate the context var context = JSONUtils.encodeBookWithPage(output.getBook(), resultPage); + context.config = config.getValues().toJS(); + context.plugins = { + resources: Plugins.listResources(plugins, prefix).toJS() + }; context.template = { getJSContext: function() { @@ -47,7 +53,7 @@ function onPage(output, page) { gitbook: context.gitbook, basePath: basePath, book: { - language: null //context.book.language + language: null // context.book.language } }; } diff --git a/lib/plugins/index.js b/lib/plugins/index.js index 622f00c..8842342 100644 --- a/lib/plugins/index.js +++ b/lib/plugins/index.js @@ -2,6 +2,7 @@ module.exports = { loadForBook: require('./loadForBook'), validateConfig: require('./validateConfig'), - installPlugins: require('./installPlugins') + installPlugins: require('./installPlugins'), + listResources: require('./listResources') }; diff --git a/lib/plugins/listResources.js b/lib/plugins/listResources.js new file mode 100644 index 0000000..b4a16cb --- /dev/null +++ b/lib/plugins/listResources.js @@ -0,0 +1,45 @@ +var Immutable = require('immutable'); +var path = require('path'); + +var LocationUtils = require('../utils/location'); +var PLUGIN_RESOURCES = require('../constants/pluginResources'); + +/** + Encode plugins as JSON + + @param {OrderedMap<String:Plugin>} + @param {String} type + @return {Map<String:List<{url, path}>} +*/ +function listResources(plugins, type) { + return plugins.reduce(function(result, plugin) { + var npmId = plugin.getNpmID(); + var resources = plugin.getResources(type); + + PLUGIN_RESOURCES.forEach(function(resourceType) { + var assets = resources.get(resourceType); + if (!assets) return; + + var list = result.get(resourceType) || Immutable.List(); + + assets = assets.map(function(assetFile) { + if (LocationUtils.isExternal(assetFile)) { + return { + url: assetFile + }; + } else { + return { + path: LocationUtils.normalize(path.join(npmId, assetFile)) + }; + } + }); + + list = list.concat(assets); + result = result.set(resourceType, list); + }); + + return result; + }, Immutable.Map()); +} + +module.exports = listResources; |