Merge pull request #2342 from ethereum/add_plugins_directory

Add plugins from the plugin directory
pull/1/head
yann300 5 years ago committed by GitHub
commit 39b877010c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 9
      src/app.js
  2. 8
      src/app/components/vertical-icons.js
  3. 81
      src/remixAppManager.js

@ -317,10 +317,15 @@ Please make a backup of your contracts and start using http://remix.ethereum.org
debug, debug,
analysis, analysis,
test, test,
filePanel.remixdHandle, filePanel.remixdHandle
...appManager.registeredPlugins()
]) ])
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(['contentImport', 'theme', 'editor', 'fileManager', 'compilerMetadata', 'compilerArtefacts', 'network', 'offsetToLineColumnConverter'])
await appManager.activate(['mainPanel']) await appManager.activate(['mainPanel'])
await appManager.activate(['menuicons', 'home', 'sidePanel', 'pluginManager', 'fileExplorers', 'settings']) await appManager.activate(['menuicons', 'home', 'sidePanel', 'pluginManager', 'fileExplorers', 'settings'])

@ -73,7 +73,7 @@ export class VerticalIcons extends Plugin {
title="${title}"> title="${title}">
<img class="image" src="${icon}" alt="${name}" /> <img class="image" src="${icon}" alt="${name}" />
</div>` </div>`
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 * @param {ModuleProfile} profile The profile of the module
*/ */
removeIcon ({kind, name}) { 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])
} }
/** /**
@ -266,7 +266,7 @@ export class VerticalIcons extends Plugin {
</div> </div>
` `
this.iconKind['other'] = yo` this.iconKind['none'] = yo`
<div id='otherIcons'> <div id='otherIcons'>
</div> </div>
` `
@ -285,7 +285,7 @@ export class VerticalIcons extends Plugin {
${this.iconKind['testing']} ${this.iconKind['testing']}
${this.iconKind['analysis']} ${this.iconKind['analysis']}
${this.iconKind['debugging']} ${this.iconKind['debugging']}
${this.iconKind['other']} ${this.iconKind['none']}
${this.iconKind['settings']} ${this.iconKind['settings']}
</div> </div>
` `

@ -1,4 +1,4 @@
/* global localStorage */ /* global localStorage, fetch */
import { PluginEngine, IframePlugin } from '@remixproject/engine' import { PluginEngine, IframePlugin } from '@remixproject/engine'
import { EventEmitter } from 'events' import { EventEmitter } from 'events'
import { PermissionHandler } from './app/ui/persmission-handler' import { PermissionHandler } from './app/ui/persmission-handler'
@ -21,6 +21,7 @@ export class RemixAppManager extends PluginEngine {
this.event = new EventEmitter() this.event = new EventEmitter()
this.donotAutoReload = ['remixd'] // that would be a bad practice to force loading some plugins at page load. this.donotAutoReload = ['remixd'] // that would be a bad practice to force loading some plugins at page load.
this.registered = {} this.registered = {}
this.pluginsDirectory = 'https://raw.githubusercontent.com/ethereum/remix-plugins-directory/master/build/profile.json'
} }
onActivated (plugin) { onActivated (plugin) {
@ -76,21 +77,7 @@ export class RemixAppManager extends PluginEngine {
return requiredModules.includes(name) return requiredModules.includes(name)
} }
registeredPlugins () { 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 = { const pipeline = {
name: 'pipeline', name: 'pipeline',
displayName: 'Pipeline', displayName: 'Pipeline',
@ -104,47 +91,6 @@ export class RemixAppManager extends PluginEngine {
icon: '', icon: '',
location: 'mainPanel' 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 = { const provable = {
name: 'provable', name: 'provable',
displayName: 'Provable - oracle service', displayName: 'Provable - oracle service',
@ -171,17 +117,6 @@ export class RemixAppManager extends PluginEngine {
icon: 'https://raw.githubusercontent.com/3box/3box-dapp/master/public/3Box3.png', icon: 'https://raw.githubusercontent.com/3box/3box-dapp/master/public/3Box3.png',
location: 'sidePanel' 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 = { const debugPlugin = {
name: 'debugPlugin', name: 'debugPlugin',
displayName: 'Debug Tools for Remix plugins', displayName: 'Debug Tools for Remix plugins',
@ -267,22 +202,20 @@ export class RemixAppManager extends PluginEngine {
icon: 'https://zokrates.blockchain-it.hr/zokrates.svg', icon: 'https://zokrates.blockchain-it.hr/zokrates.svg',
location: 'sidePanel' location: 'sidePanel'
} }
const res = await fetch(this.pluginsDirectory)
const plugins = await res.json()
return [ return [
new IframePlugin(pipeline), new IframePlugin(pipeline),
new IframePlugin(vyper),
new IframePlugin(etherscan),
new IframePlugin(ethdoc),
new IframePlugin(mythx),
new IframePlugin(provable), new IframePlugin(provable),
new IframePlugin(threeBox), new IframePlugin(threeBox),
new IframePlugin(remixWorkshop),
new IframePlugin(debugPlugin), new IframePlugin(debugPlugin),
new IframePlugin(libraTools), new IframePlugin(libraTools),
new IframePlugin(oneClickDapp), new IframePlugin(oneClickDapp),
new IframePlugin(gasProfiler), new IframePlugin(gasProfiler),
new IframePlugin(flattener), new IframePlugin(flattener),
new IframePlugin(ethpm), new IframePlugin(ethpm),
new IframePlugin(zokrates) new IframePlugin(zokrates),
...plugins.map(plugin => new IframePlugin(plugin))
] ]
} }
} }

Loading…
Cancel
Save