@@ -17,15 +17,16 @@ var diveSync = require('diveSync'),
17
17
cleanHtml = require ( 'js-beautify' ) . html ,
18
18
inherits = require ( 'util' ) . inherits ,
19
19
pm = require ( './plugin_manager' ) ,
20
+ fs = require ( 'fs-extra' ) ,
20
21
plutils = require ( './utilities' ) ;
21
22
22
23
var EventEmitter = require ( 'events' ) . EventEmitter ;
23
24
24
- function buildPatternData ( dataFilesPath , fs ) {
25
+ function buildPatternData ( dataFilesPath , fsDep ) {
25
26
var dataFiles = glob . sync ( dataFilesPath + '*.json' , { "ignore" : [ dataFilesPath + 'listitems.json' ] } ) ;
26
27
var mergeObject = { } ;
27
28
dataFiles . forEach ( function ( filePath ) {
28
- var jsonData = fs . readJSONSync ( path . resolve ( filePath ) , 'utf8' ) ;
29
+ var jsonData = fsDep . readJSONSync ( path . resolve ( filePath ) , 'utf8' ) ;
29
30
mergeObject = _ . merge ( mergeObject , jsonData ) ;
30
31
} ) ;
31
32
return mergeObject ;
@@ -83,18 +84,42 @@ function checkConfiguration(patternlab) {
83
84
* @param patternlab - global data store
84
85
*/
85
86
function initializePlugins ( patternlab ) {
87
+
88
+ if ( ! patternlab . config . plugins ) { return ; }
89
+
86
90
var plugin_manager = new pm ( patternlab . config , path . resolve ( __dirname , '../../patternlab-config.json' ) ) ;
87
91
var foundPlugins = plugin_manager . detect_plugins ( ) ;
88
92
89
93
if ( foundPlugins && foundPlugins . length > 0 ) {
90
94
91
95
for ( var i = 0 ; i < foundPlugins . length ; i ++ ) {
92
- var plugin = plugin_manager . load_plugin ( foundPlugins [ i ] ) ;
96
+
97
+ let pluginKey = foundPlugins [ i ] ;
98
+
99
+ if ( patternlab . config . debug ) {
100
+ console . log ( 'Found plugin: ' , pluginKey ) ;
101
+ console . log ( 'Attempting to load and initialize plugin.' ) ;
102
+ }
103
+
104
+ var plugin = plugin_manager . load_plugin ( pluginKey ) ;
93
105
plugin ( patternlab ) ;
94
106
}
95
107
}
96
108
}
97
109
110
+ /**
111
+ * Installs a given plugin. Assumes it has already been pulled down via npm
112
+ * @param pluginName - the name of the plugin
113
+ */
114
+ function installPlugin ( pluginName ) {
115
+ //get the config
116
+ var configPath = path . resolve ( process . cwd ( ) , 'patternlab-config.json' ) ;
117
+ var config = fs . readJSONSync ( path . resolve ( configPath ) , 'utf8' ) ;
118
+ var plugin_manager = new pm ( config , configPath ) ;
119
+
120
+ plugin_manager . install_plugin ( pluginName ) ;
121
+ }
122
+
98
123
function PatternLabEventEmitter ( ) {
99
124
EventEmitter . call ( this ) ;
100
125
}
@@ -104,7 +129,6 @@ var patternlab_engine = function (config) {
104
129
'use strict' ;
105
130
106
131
var JSON5 = require ( 'json5' ) ,
107
- fs = require ( 'fs-extra' ) ,
108
132
pa = require ( './pattern_assembler' ) ,
109
133
pe = require ( './pattern_exporter' ) ,
110
134
lh = require ( './lineage_hunter' ) ,
@@ -123,7 +147,6 @@ var patternlab_engine = function (config) {
123
147
124
148
checkConfiguration ( patternlab ) ;
125
149
126
- //todo: determine if this is the best place to wire up plugins
127
150
initializePlugins ( patternlab ) ;
128
151
129
152
var paths = patternlab . config . paths ;
@@ -504,6 +527,9 @@ var patternlab_engine = function (config) {
504
527
} ,
505
528
loadstarterkit : function ( starterkitName , clean ) {
506
529
loadStarterKit ( starterkitName , clean ) ;
530
+ } ,
531
+ installplugin : function ( pluginName ) {
532
+ installPlugin ( pluginName ) ;
507
533
}
508
534
} ;
509
535
} ;
0 commit comments