From e545c652d98b06254295fbaf02e902505bbe3a3e Mon Sep 17 00:00:00 2001 From: yann300 Date: Wed, 18 Sep 2019 11:33:08 +0200 Subject: [PATCH 1/3] add plugin directory --- src/app.js | 9 +++++++-- src/remixAppManager.js | 9 ++++++--- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/src/app.js b/src/app.js index 54c9b0e9f5..fca6a249cd 100644 --- a/src/app.js +++ b/src/app.js @@ -328,10 +328,15 @@ Please make a backup of your contracts and start using http://remix.ethereum.org debug, analysis, test, - filePanel.remixdHandle, - ...appManager.registeredPlugins() + filePanel.remixdHandle ]) + try { + appManager.register(await appManager.registeredPlugins()) + } catch (e) { + console.log('couldn\'t register iframe plugins', e.message) + } + await appManager.activate(['contentImport', 'theme', 'editor', 'fileManager', 'compilerMetadata', 'compilerArtefacts', 'network', 'offsetToLineColumnConverter']) await appManager.activate(['mainPanel']) await appManager.activate(['menuicons', 'home', 'sidePanel', 'pluginManager', 'fileExplorers', 'settings']) diff --git a/src/remixAppManager.js b/src/remixAppManager.js index 272eacdac4..9a87fd973b 100644 --- a/src/remixAppManager.js +++ b/src/remixAppManager.js @@ -1,4 +1,4 @@ -/* global localStorage */ +/* global localStorage, fetch */ import { PluginEngine, IframePlugin } from '@remixproject/engine' import { EventEmitter } from 'events' import { PermissionHandler } from './app/ui/persmission-handler' @@ -20,6 +20,7 @@ export class RemixAppManager extends PluginEngine { super(plugins, settings) this.event = new EventEmitter() this.registered = {} + this.pluginsDirectory = 'https://github.com/ethereum/remix-plugins-directory' } onActivated (plugin) { @@ -73,7 +74,7 @@ export class RemixAppManager extends PluginEngine { return requiredModules.includes(name) } - registeredPlugins () { + async registeredPlugins () { const vyper = { name: 'vyper', displayName: 'Vyper', @@ -262,6 +263,7 @@ export class RemixAppManager extends PluginEngine { icon: 'https://zokrates.blockchain-it.hr/zokrates.svg', location: 'sidePanel' } + const plugins = JSON.parse(await fetch(this.pluginsDirectory)) return [ new IframePlugin(pipeline), new IframePlugin(vyper), @@ -277,7 +279,8 @@ export class RemixAppManager extends PluginEngine { new IframePlugin(gasProfiler), new IframePlugin(flattener), new IframePlugin(ethpm), - new IframePlugin(zokrates) + new IframePlugin(zokrates), + ...plugins ] } } From bfdafca2e990723e69df486806c7ad01ea8975d8 Mon Sep 17 00:00:00 2001 From: yann300 Date: Mon, 30 Sep 2019 13:43:46 +0200 Subject: [PATCH 2/3] use "none" for plugin that does not have kind --- src/app/components/vertical-icons.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/app/components/vertical-icons.js b/src/app/components/vertical-icons.js index b95f879836..e863828cb2 100644 --- a/src/app/components/vertical-icons.js +++ b/src/app/components/vertical-icons.js @@ -73,7 +73,7 @@ export class VerticalIcons extends Plugin { title="${title}"> ${name} ` - this.iconKind[kind || 'other'].appendChild(this.icons[name]) + this.iconKind[kind || 'none'].appendChild(this.icons[name]) } /** @@ -146,7 +146,7 @@ export class VerticalIcons extends Plugin { * @param {ModuleProfile} profile The profile of the module */ removeIcon ({kind, name}) { - if (this.icons[name]) this.iconKind[kind || 'other'].removeChild(this.icons[name]) + if (this.icons[name]) this.iconKind[kind || 'none'].removeChild(this.icons[name]) } /** @@ -335,7 +335,7 @@ export class VerticalIcons extends Plugin { ` - this.iconKind['other'] = yo` + this.iconKind['none'] = yo`
` @@ -354,7 +354,7 @@ export class VerticalIcons extends Plugin { ${this.iconKind['testing']} ${this.iconKind['analysis']} ${this.iconKind['debugging']} - ${this.iconKind['other']} + ${this.iconKind['none']} ${this.iconKind['settings']} ` From 7e2345ff3e8721a440d26427af3ba0e912acae63 Mon Sep 17 00:00:00 2001 From: yann300 Date: Mon, 30 Sep 2019 13:44:03 +0200 Subject: [PATCH 3/3] uses profile.json --- src/remixAppManager.js | 78 +++--------------------------------------- 1 file changed, 4 insertions(+), 74 deletions(-) diff --git a/src/remixAppManager.js b/src/remixAppManager.js index 9a87fd973b..432a261683 100644 --- a/src/remixAppManager.js +++ b/src/remixAppManager.js @@ -20,7 +20,7 @@ export class RemixAppManager extends PluginEngine { super(plugins, settings) this.event = new EventEmitter() this.registered = {} - this.pluginsDirectory = 'https://github.com/ethereum/remix-plugins-directory' + this.pluginsDirectory = 'https://raw.githubusercontent.com/ethereum/remix-plugins-directory/master/build/profile.json' } onActivated (plugin) { @@ -75,20 +75,6 @@ export class RemixAppManager extends PluginEngine { } async registeredPlugins () { - const vyper = { - name: 'vyper', - displayName: 'Vyper', - events: ['compilationFinished'], - methods: [], - notifications: { - 'fileManager': ['currentFileChanged'] - }, - url: 'https://remix-vyper-plugin.surge.sh', - description: 'Compile vyper contracts', - kind: 'compiler', - icon: '', - location: 'sidePanel' - } const pipeline = { name: 'pipeline', displayName: 'Pipeline', @@ -102,47 +88,6 @@ export class RemixAppManager extends PluginEngine { icon: '', location: 'mainPanel' } - const etherscan = { - name: 'etherscan', - displayName: 'Etherscan - Contract verification', - events: [], - methods: [], - notifications: { - 'solidity': ['compilationFinished'] - }, - url: 'https://remix-etherscan-plugin.surge.sh', - description: 'Verify Solidity contract code using Etherscan API', - icon: '', - location: 'sidePanel' - } - const ethdoc = { - name: 'solidityDocMd', - displayName: 'Solidity documentation generator', - events: [], - methods: [], - notifications: { - 'solidity': ['compilationFinished'] - }, - url: 'https://remix-ethdoc-plugin.surge.sh', - description: 'Generate Solidity documentation (as md) using Natspec', - icon: '', - location: 'sidePanel' - } - const mythx = { - name: 'remythx', - displayName: 'MythX Security Verification', - events: [], - methods: [], - notifications: { - 'solidity': ['compilationFinished'] - }, - version: '0.1.0', - url: 'https://remix-mythx-plugin.surge.sh', - description: 'Perform Static and Dynamic Security Analysis using the MythX Cloud Service', - icon: 'https://remix-mythx-plugin.surge.sh/logo.png', - location: 'sidePanel', - documentation: 'https://github.com/aquiladev/remix-mythx-plugin/blob/master/README.md' - } const provable = { name: 'provable', displayName: 'Provable - oracle service', @@ -169,17 +114,6 @@ export class RemixAppManager extends PluginEngine { icon: 'https://raw.githubusercontent.com/3box/3box-dapp/master/public/3Box3.png', location: 'sidePanel' } - const remixWorkshop = { - name: 'workshops', - displayName: 'Remix Workshops', - description: 'Learn Ethereum with Remix !', - methods: [], - events: [], - version: '0.1.0-alpha', - url: 'https://remix-plugin-workshops.surge.sh', - icon: 'https://image.flaticon.com/icons/svg/1570/1570493.svg', - location: 'sidePanel' - } const debugPlugin = { name: 'debugPlugin', displayName: 'Debug Tools for Remix plugins', @@ -263,16 +197,12 @@ export class RemixAppManager extends PluginEngine { icon: 'https://zokrates.blockchain-it.hr/zokrates.svg', location: 'sidePanel' } - const plugins = JSON.parse(await fetch(this.pluginsDirectory)) + const res = await fetch(this.pluginsDirectory) + const plugins = await res.json() return [ new IframePlugin(pipeline), - new IframePlugin(vyper), - new IframePlugin(etherscan), - new IframePlugin(ethdoc), - new IframePlugin(mythx), new IframePlugin(provable), new IframePlugin(threeBox), - new IframePlugin(remixWorkshop), new IframePlugin(debugPlugin), new IframePlugin(libraTools), new IframePlugin(oneClickDapp), @@ -280,7 +210,7 @@ export class RemixAppManager extends PluginEngine { new IframePlugin(flattener), new IframePlugin(ethpm), new IframePlugin(zokrates), - ...plugins + ...plugins.map(plugin => new IframePlugin(plugin)) ] } }