summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSamy Pessé <samypesse@gmail.com>2016-04-27 13:47:12 +0200
committerSamy Pessé <samypesse@gmail.com>2016-04-27 13:47:12 +0200
commit7298dec35314065e965b5738e751ad25e4ff2a94 (patch)
tree31c2b36c398771356de4891e163831a1d413a5ac
parent7574b01863e7c8a55bacc07f38dd4180baa41d62 (diff)
downloadgitbook-7298dec35314065e965b5738e751ad25e4ff2a94.zip
gitbook-7298dec35314065e965b5738e751ad25e4ff2a94.tar.gz
gitbook-7298dec35314065e965b5738e751ad25e4ff2a94.tar.bz2
Add plugins.resources for template context
-rw-r--r--lib/constants/pluginResources.js6
-rw-r--r--lib/output/generateBook.js3
-rw-r--r--lib/output/website/onPage.js8
-rw-r--r--lib/plugins/index.js3
-rw-r--r--lib/plugins/listResources.js45
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;