|
|
|
@ -12,12 +12,12 @@ const RunTab = require('../tabs/run-tab') |
|
|
|
|
|
|
|
|
|
var registry = require('../../global/registry') |
|
|
|
|
|
|
|
|
|
const styleguide = require('../ui/styles-guide/theme-chooser') |
|
|
|
|
const styles = styleguide.chooser() |
|
|
|
|
// const styleguide = require('../ui/styles-guide/theme-chooser')
|
|
|
|
|
// const styles = styleguide.chooser()
|
|
|
|
|
|
|
|
|
|
const PluginManagerProxy = require('./plugin-manager-proxy') |
|
|
|
|
|
|
|
|
|
const EventEmitter = require ('events') |
|
|
|
|
const EventEmitter = require('events') |
|
|
|
|
|
|
|
|
|
class PluginManagerComponent { |
|
|
|
|
|
|
|
|
@ -44,9 +44,13 @@ class PluginManagerComponent { |
|
|
|
|
'Settings': { name: 'Settings', Type: SettingsTab, icon: '' } |
|
|
|
|
} |
|
|
|
|
this.activated = {} // list all activated modules
|
|
|
|
|
// this.activated = [] // list all activated modules
|
|
|
|
|
this.plugins = [] |
|
|
|
|
this.data = {} |
|
|
|
|
this.data.proxy = new PluginManagerProxy() |
|
|
|
|
|
|
|
|
|
// This load the state from localstorage first then from the second parameter is nothing is found in localstorage
|
|
|
|
|
// this.store = Store.fromLocal('***', {}) // Or EntityStore.fromLocal('***', {}, 'id')
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
proxy () { |
|
|
|
@ -70,21 +74,52 @@ class PluginManagerComponent { |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
render () { |
|
|
|
|
var self = this |
|
|
|
|
// var self = this
|
|
|
|
|
// loop over all this.modules and this.plugins
|
|
|
|
|
return yo` |
|
|
|
|
let pluginManagerDiv = yo` |
|
|
|
|
<div id='pluginManager' class=${css.plugins} > |
|
|
|
|
list all modules / plugins that can be activated |
|
|
|
|
<h2>Plugin Manager</h2> |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
|
for (var mod in this.modulesDefinition) { |
|
|
|
|
if (this.modulesDefinition[mod].icon) pluginManagerDiv.appendChild(this.renderItem(mod)) |
|
|
|
|
} |
|
|
|
|
console.log(this.activated) |
|
|
|
|
return pluginManagerDiv |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
renderItem (item) { |
|
|
|
|
let ctrBtns |
|
|
|
|
if (this.activated.hasOwnProperty(item)) { |
|
|
|
|
ctrBtns = yo` |
|
|
|
|
<button onclick=${() => { this.deactivateInternal(this.modulesDefinition[item].name) }} >deactivate</button> |
|
|
|
|
` |
|
|
|
|
} else { |
|
|
|
|
ctrBtns = yo` |
|
|
|
|
<button onclick=${() => { this.activateInternal() }} >activate</button> |
|
|
|
|
` |
|
|
|
|
} |
|
|
|
|
this.plugins.push(item) |
|
|
|
|
// var self = this
|
|
|
|
|
return yo` |
|
|
|
|
<div id='pluginManager' class=${css.plugin} > |
|
|
|
|
${this.modulesDefinition[item].name} |
|
|
|
|
${ctrBtns} |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
activatePlugin (jsonProfile, api) { |
|
|
|
|
let profile = { json: jsonProfile, api } |
|
|
|
|
let plugin = new Plugin(profile, api) |
|
|
|
|
this.appManager.addPlugin(plugin) |
|
|
|
|
this.event.emit('displayableModuleActivated', jsonProfile, plugin.render()) |
|
|
|
|
this.activated[jsonProfile.name] = plugin |
|
|
|
|
// let profile = { json: jsonProfile, api }
|
|
|
|
|
// let plugin = new Plugin(profile, api)
|
|
|
|
|
// this.appManager.addPlugin(plugin)
|
|
|
|
|
// this.event.emit('displayableModuleActivated', jsonProfile, plugin.render())
|
|
|
|
|
// this.activated[jsonProfile.name] = plugin
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
deactivateInternal (name) { |
|
|
|
|
delete this.activated[name] |
|
|
|
|
this.event.emit('removingItem', name) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
activateInternal (name) { |
|
|
|
@ -116,19 +151,6 @@ class PluginManagerComponent { |
|
|
|
|
_deactivate (item) { |
|
|
|
|
this.event.emit('deactivation', item) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
renderItem (item) { |
|
|
|
|
this.plugins.push(item) |
|
|
|
|
var self = this |
|
|
|
|
var view = yo` |
|
|
|
|
<div id='pluginManager' class=${css.plugin} > |
|
|
|
|
${item.name} |
|
|
|
|
${item.url} |
|
|
|
|
<button onclick=${() => { self._activate(item) }} ></button> |
|
|
|
|
<button onclick=${() => { self._deactivate(item) }} ></button> |
|
|
|
|
</div> |
|
|
|
|
` |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
module.exports = PluginManagerComponent |
|
|
|
@ -137,11 +159,15 @@ const css = csjs` |
|
|
|
|
.plugins { |
|
|
|
|
width : 300px; |
|
|
|
|
} |
|
|
|
|
.plugItIn { |
|
|
|
|
display : none; |
|
|
|
|
.plugin { |
|
|
|
|
border-bottom: 1px black solid; |
|
|
|
|
padding: 10px 20px; |
|
|
|
|
margin-bottom: 20px; |
|
|
|
|
} |
|
|
|
|
.plugItIn.active { |
|
|
|
|
display :block; |
|
|
|
|
display: block; |
|
|
|
|
} |
|
|
|
|
.plugin button { |
|
|
|
|
cursor: pointer; |
|
|
|
|
} |
|
|
|
|
.clearFunds { background-color: lightblue; } |
|
|
|
|
` |
|
|
|
|