summaryrefslogtreecommitdiffstats
path: root/lib/plugins/listAll.js
diff options
context:
space:
mode:
authorSamy Pesse <samypesse@gmail.com>2016-05-02 22:02:45 +0200
committerSamy Pesse <samypesse@gmail.com>2016-05-02 22:02:45 +0200
commit41e687255717c43d1bf2745e7b806057c7de16ae (patch)
tree6be8992936b0c0ec006fc46d5f7577791494aba1 /lib/plugins/listAll.js
parent8de0d6186e8a10cdd5a3efe9a4cf0afcae734223 (diff)
parent30c96c37c2145a28710e2875c677d37156fdaa92 (diff)
downloadgitbook-41e687255717c43d1bf2745e7b806057c7de16ae.zip
gitbook-41e687255717c43d1bf2745e7b806057c7de16ae.tar.gz
gitbook-41e687255717c43d1bf2745e7b806057c7de16ae.tar.bz2
Merge branch 'fix/plugins_deps'
Diffstat (limited to 'lib/plugins/listAll.js')
-rw-r--r--lib/plugins/listAll.js43
1 files changed, 13 insertions, 30 deletions
diff --git a/lib/plugins/listAll.js b/lib/plugins/listAll.js
index d7ce5f3..9b2a96b 100644
--- a/lib/plugins/listAll.js
+++ b/lib/plugins/listAll.js
@@ -1,4 +1,3 @@
-var is = require('is');
var Immutable = require('immutable');
var Plugin = require('../models/plugin');
@@ -8,43 +7,27 @@ var DEFAULT_PLUGINS = require('../constants/defaultPlugins');
/**
List all plugins for a book
- @param {List<Plugin|String>}
+ @param {List<PluginDependency>} deps
@return {OrderedMap<Plugin>}
*/
-function listAll(plugins) {
- if (is.string(plugins)) {
- plugins = Immutable.List(plugins.split(','));
- }
-
- // Convert to an ordered map
- plugins = plugins.map(function(plugin) {
- if (is.string(plugin)) {
- plugin = Plugin.createFromString(plugin);
- } else {
- plugin = new Plugin(plugin);
- }
-
- return [plugin.getName(), plugin];
- });
- plugins = Immutable.OrderedMap(plugins);
-
+function listAll(deps) {
// Extract list of plugins to disable (starting with -)
- var toRemove = plugins.toList()
+ var toRemove = deps
.filter(function(plugin) {
- return plugin.getName()[0] === '-';
+ return !plugin.isEnabled();
})
.map(function(plugin) {
- return plugin.getName().slice(1);
+ return plugin.getName();
});
- // Remove the '-'
- plugins = plugins.mapKeys(function(name) {
- if (name[0] === '-') {
- return name.slice(1);
- } else {
- return name;
- }
- });
+ // Convert to an ordered map of Plugin
+ var plugins = deps
+ .map(function(dep) {
+ var plugin = Plugin.createFromDep(dep);
+
+ return [dep.getName(), plugin];
+ });
+ plugins = Immutable.OrderedMap(plugins);
// Append default plugins
DEFAULT_PLUGINS.forEach(function(pluginName) {