diff --git a/src/app.js b/src/app.js index e63d02b2d7..9751b7f9e5 100644 --- a/src/app.js +++ b/src/app.js @@ -356,7 +356,7 @@ Please make a backup of your contracts and start using http://remix.ethereum.org resolveReceipt: function (tx, cb) { transactionReceiptResolver.resolve(tx, cb) } - }, + } event: { udapp: udapp.event }}) @@ -420,11 +420,6 @@ Please make a backup of your contracts and start using http://remix.ethereum.org const verticalIconApi = new VerticalsIconApi(verticalIconComponent) const pluginManagerAPI = new pluginManagerAPI(pluginManagerComponent) - self._components.filePanel = new FilePanel() - registry.put({api: self._components.filePanel, name: 'filepanel'}) - - var settings = new SettingsTab() - // All Plugins and Modules are registered in the contructor // You cannot add module after appManager.init({ @@ -434,7 +429,6 @@ Please make a backup of your contracts and start using http://remix.ethereum.org { json: SwapPanelProfile, api: swapPanelApi }, { json: PluginManagerProfile, api: pluginManagerApi }, { json: FileManagerProfile, api: self._components.filePanel }, - { json: SettingsProfile, api: settings } ], // Plugins need to be activated plugins: [], @@ -443,47 +437,38 @@ Please make a backup of your contracts and start using http://remix.ethereum.org } }) + self._components.filePanel = new FilePanel() + registry.put({api: self._components.filePanel, name: 'filepanel'}) + swapPanelApi.addView('File', self._components.filePanel.render()) + verticalIconApi.addIcon('') + const compileTab = new CompileTab(self._components.registry) - const compileTabProfile = { - type: 'solidityCompile', - methods: [], - } - appManager.addPlugin({json: compileTabProfile, api: new InternalModule(compileTab) }) + swapPanelApi.addView('Compile', compileTab.render()) + verticalIconApi.addIcon('') const testTab = new TestTab(self._components.registry, compileTab) - const testTabProfile = { - type: 'solidityUnitTesting', - methods: [], - } - appManager.addPlugin({json: testTabProfile, api: testTab}) + swapPanelApi.addView('Test', testTab.render()) + verticalIconApi.addIcon('') const runTab = new RunTab(self._components.registry) - const runTabProfile = { - type: 'runTransaction', - methods: [], - } - appManager.addPlugin({json: runTabProfile, api: runTab}) + swapPanelApi.addView('Run', runTab.render()) + verticalIconApi.addIcon('') const analysisTab = new AnalysisTab(self._components.registry) - const analysisTabProfile = { - type: 'solidityStaticAnalisys', - methods: [], - } - appManager.addPlugin({json: analysisTabProfile, api: analysisTab}) + swapPanelApi.addView('Analysis', analysisTab.render()) + verticalIconApi.addIcon('') const debuggerTab = new DebuggerTab(self._components.registry) - const debuggerTabProfile = { - type: 'debugger', - methods: [], - } - appManager.addPlugin({json: debuggerTabProfile, api: debuggerTab}) + swapPanelApi.addView('Debugger', debuggerTab.render()) + verticalIconApi.addIcon('') const supportTab = new SupportTab(self._components.registry) - const supportTabProfile = { - type: 'support', - methods: [], - } - appManager.addPlugin({json: supportTabProfile, api: supportTab}) + swapPanelApi.addView('Support', supportTab.render()) + verticalIconApi.addIcon('') + + const settings = new SettingsTab()(self._components.registry) + swapPanelApi.addView('Settings', settingsTab.render()) + verticalIconApi.addIcon('') self._components.iconpanel.appendChild(verticalIconComponent.render()) self._components.iconpanel.event.register('resize', delta => self._adjustLayout('left', delta)) diff --git a/src/app/components/plugin-manager-api.js b/src/app/components/plugin-manager-api.js index 55691b4583..2007ade32a 100644 --- a/src/app/components/plugin-manager-api.js +++ b/src/app/components/plugin-manager-api.js @@ -8,19 +8,15 @@ const styles = styleguide.chooser() const EventManager = remixLib.EventManager class PluginManagerApi { - constructor (swapPanelComponent) { + constructor (swapPanelComponent, pluginManagerComponent, appManager) { this.component = swapPanelComponent - } - - /* - viewTitle: string - content: DOM element - */ - addView(viewTitle, content) { - // add the DOM to the swappanel - this.component.addView(viewTitle, contents) + this.appManager = appManager + appManager.event.register('pluginLoaded', (item) => { + pluginManagerComponent.addItem(item) + }) + pluginManagerComponent.event.on('activation', (item) => this.event.emit('activation', item)) + pluginManagerComponent.event.on('deactivation', (item) => this.event.emit('deactivation', item)) } } - module.exports = SwapPanelApi diff --git a/src/app/components/plugin-manager-component.js b/src/app/components/plugin-manager-component.js index 85d62a46c1..37af829745 100644 --- a/src/app/components/plugin-manager-component.js +++ b/src/app/components/plugin-manager-component.js @@ -8,11 +8,7 @@ const styles = styleguide.chooser() const EventManager = remixLib.EventManager class PluginManagerComponent { - constructor (appManager) { - this.appManager = appManager - appManager.event.register('pluginLoaded', () => { - // call this.renderItem - }) + constructor () { } render () { @@ -24,6 +20,11 @@ class PluginManagerComponent { ` } + addItem (item) { + // add to appManager and then render + renderItem(item) + } + _activate(item) { this.event.emit('activation', item) } @@ -32,10 +33,6 @@ class PluginManagerComponent { this.event.emit('deactivation', item) } - _addPlugin(url){ - this.event.emit('plugin loading', url) - } - renderItem (item) { var self = this @@ -46,7 +43,6 @@ class PluginManagerComponent {