diff --git a/src/app.js b/src/app.js index a0e6475f79..d6428fda3a 100644 --- a/src/app.js +++ b/src/app.js @@ -54,7 +54,7 @@ import { EntityStore } from './lib/store' import { RemixAppManager } from './remixAppManager' import { LandingPage } from './app/ui/landing-page/landing-page' import framingService from './framingService' -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' import { TxListenerModule } from './app/tabs/txlistener-module' import { ThemeModule } from './app/tabs/theme-module' @@ -116,9 +116,15 @@ var css = csjs` } ` -class App extends ApiFactory { +const profile = { + name: 'app', + description: 'service - provides information about current context (network).', + methods: ['getExecutionContextProvider', 'getProviderEndpoint', 'detectNetWork', 'addProvider', 'removeProvider'] +} + +class App extends BaseApi { constructor (api = {}, events = {}, opts = {}) { - super() + super(profile) var self = this this.event = new EventManager() self._components = {} @@ -171,14 +177,6 @@ class App extends ApiFactory { run.apply(self) } - get profile () { - return { - name: 'app', - description: 'service - provides information about current context (network).', - methods: ['getExecutionContextProvider', 'getProviderEndpoint', 'detectNetWork', 'addProvider', 'removeProvider'] - } - } - render () { var self = this if (self._view.el) return self._view.el diff --git a/src/app/components/plugin-manager-component.js b/src/app/components/plugin-manager-component.js index 5be1d9a220..df31814660 100644 --- a/src/app/components/plugin-manager-component.js +++ b/src/app/components/plugin-manager-component.js @@ -2,7 +2,7 @@ const yo = require('yo-yo') const csjs = require('csjs-inject') const EventEmitter = require('events') const LocalPlugin = require('./local-plugin') -import { Plugin, ApiFactory } from 'remix-plugin' +import { Plugin, BaseApi } from 'remix-plugin' const css = csjs` .pluginSearch { @@ -34,10 +34,20 @@ const css = csjs` } ` -class PluginManagerComponent extends ApiFactory { +const profile = { + displayName: 'plugin manager', + name: 'pluginManager', + methods: [], + events: [], + icon: '', + description: 'start/stop services, modules and plugins', + kind: 'settings' +} + +class PluginManagerComponent extends BaseApi { constructor () { - super() + super(profile) this.event = new EventEmitter() this.views = { root: null, @@ -47,19 +57,6 @@ class PluginManagerComponent extends ApiFactory { this.filter = '' } - get profile () { - return { - displayName: 'plugin manager', - name: 'pluginManager', - methods: [], - events: [], - icon: '', - description: 'start/stop services, modules and plugins', - kind: 'settings', - location: 'swapPanel' - } - } - setApp (appManager) { this.appManager = appManager } diff --git a/src/app/editor/SourceHighlighters.js b/src/app/editor/SourceHighlighters.js index 85c69e2537..fc8e119839 100644 --- a/src/app/editor/SourceHighlighters.js +++ b/src/app/editor/SourceHighlighters.js @@ -1,24 +1,22 @@ 'use strict' const SourceHighlighter = require('./sourceHighlighter') -import { ApiFactory } from 'remix-plugin' +import { EditorApi } from 'remix-plugin' -class SourceHighlighters extends ApiFactory { +const profile = { + displayName: 'source highlighters', + name: 'sourceHighlighters', + methods: ['highlight', 'discardHighlight'], + description: 'service - highlight source code' +} + +class SourceHighlighters extends EditorApi { constructor () { - super() + super(profile) this.highlighters = {} } - get profile () { - return { - displayName: 'source highlighters', - name: 'sourceHighlighters', - methods: ['highlight', 'discardHighlight'], - description: 'service - highlight source code' - } - } - highlight (lineColumnPos, filePath, hexColor) { const { from } = this.currentRequest try { diff --git a/src/app/files/browser-files-tree.js b/src/app/files/browser-files-tree.js index 3c8eecf991..12e7f1cbc3 100644 --- a/src/app/files/browser-files-tree.js +++ b/src/app/files/browser-files-tree.js @@ -2,12 +2,16 @@ var EventManager = require('../../lib/events') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' -class FilesTree extends ApiFactory { + class FilesTree extends BaseApi { constructor (name, storage) { - super() + super({ + name: name, + methods: ['get', 'set', 'remove'], + description: 'service - read/write file to the `config` explorer without need of additionnal permission.' + }) this.event = new EventManager() this.storage = storage this.type = name @@ -15,15 +19,6 @@ class FilesTree extends ApiFactory { this.tree = {} } - get profile () { - // TODO should make them promisable - return { - name: this.type, - methods: ['get', 'set', 'remove'], - description: 'service - read/write file to the `config` explorer without need of additionnal permission.' - } - } - exists (path, cb) { cb(null, this._exists(path)) } diff --git a/src/app/files/fileManager.js b/src/app/files/fileManager.js index 0ed8a3395d..627c0c062b 100644 --- a/src/app/files/fileManager.js +++ b/src/app/files/fileManager.js @@ -6,15 +6,25 @@ const EventEmitter = require('events') var globalRegistry = require('../../global/registry') var CompilerImport = require('../compiler/compiler-imports') var toaster = require('../ui/tooltip') +import { FileSystemApi } from 'remix-plugin' /* attach to files event (removed renamed) trigger: currentFileChanged */ -class FileManager extends ApiFactory { +const profile = { + displayName: 'file manager', + name: 'fileManager', + methods: ['getFilesFromPath', 'getCurrentFile', 'getFile', 'setFile'], + events: ['currentFileChanged'], + description: 'service - read/write to any files or folders, require giving permissions', + permission: true +} + +class FileManager extends FileSystemApi { constructor (localRegistry) { - super() + super(profile) this.openedFiles = {} // list all opened files this.events = new EventEmitter() this._components = {} @@ -42,18 +52,6 @@ class FileManager extends ApiFactory { this._deps.localhostExplorer.event.register('closed', (event) => { this.removeTabsOf(this._deps.localhostExplorer) }) } - get profile () { - return { - displayName: 'file manager', - name: 'fileManager', - methods: ['getFilesFromPath', 'getCurrentFile', 'getFile', 'setFile'], - events: ['currentFileChanged'], - description: 'service - read/write to any files or folders, require giving permissions', - permission: true, - icon: '' - } - } - fileRenamedEvent (oldName, newName, isFolder) { if (!isFolder) { this._deps.config.set('currentFile', '') diff --git a/src/app/files/remixd-handle.js b/src/app/files/remixd-handle.js index f0cf7b8162..6787e2104d 100644 --- a/src/app/files/remixd-handle.js +++ b/src/app/files/remixd-handle.js @@ -1,5 +1,5 @@ -import { ApiFactory } from 'remix-plugin' let globalRegistry = require('../../global/registry') +import { BaseApi } from 'remix-plugin' var yo = require('yo-yo') var modalDialog = require('../ui/modaldialog') @@ -18,23 +18,21 @@ var css = csjs` } ` -export class RemixdHandle extends ApiFactory { +const profile = { + name: 'remixd', + methods: [], + events: [], + description: 'using Remixd daemon, allow to access file system', + kind: 'other' +} + +export class RemixdHandle extends BaseApi { constructor (fileSystemExplorer, locahostProvider) { - super() + super(profile) this.fileSystemExplorer = fileSystemExplorer this.locahostProvider = locahostProvider } - get profile () { - return { - name: 'remixd', - methods: [], - events: [], - description: 'using Remixd daemon, allow to access file system', - kind: 'other' - } - } - deactivate () { this.locahostProvider.close((error) => { if (error) console.log(error) diff --git a/src/app/panels/file-panel.js b/src/app/panels/file-panel.js index 5a42d28a2f..4388de2d69 100644 --- a/src/app/panels/file-panel.js +++ b/src/app/panels/file-panel.js @@ -6,7 +6,7 @@ var { RemixdHandle } = require('../files/remixd-handle.js') var globalRegistry = require('../../global/registry') var css = require('./styles/file-panel-styles') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' var canUpload = window.File || window.FileReader || window.FileList || window.Blob @@ -27,10 +27,20 @@ var canUpload = window.File || window.FileReader || window.FileList || window.Bl - call fileProvider API */ -module.exports = class Filepanel extends ApiFactory { +const profile = { + name: 'fileExplorers', + displayName: 'file explorers', + methods: [], + events: [], + icon: '', + description: ' - ', + kind: 'fileexplorer' +} + +module.exports = class Filepanel extends BaseApi { constructor (localRegistry) { - super() + super(profile) var self = this self._components = {} self._components.registry = localRegistry || globalRegistry @@ -132,18 +142,5 @@ module.exports = class Filepanel extends ApiFactory { self.render = function render () { return element } } - - get profile () { - return { - name: 'fileExplorers', - displayName: 'file explorers', - methods: [], - events: [], - icon: '', - description: ' - ', - kind: 'fileexplorer', - location: 'swapPanel' - } - } } diff --git a/src/app/tabs/analysis-tab.js b/src/app/tabs/analysis-tab.js index 321189e0ea..54760b43e7 100644 --- a/src/app/tabs/analysis-tab.js +++ b/src/app/tabs/analysis-tab.js @@ -3,31 +3,28 @@ var StaticAnalysis = require('../staticanalysis/staticAnalysisView') var EventManager = require('../../lib/events') var css = require('./styles/analysis-tab-styles') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' import { EventEmitter } from 'events' -class AnalysisTab extends ApiFactory { +const profile = { + name: 'solidityStaticAnalysis', + displayName: 'solidity static analysis', + methods: [], + events: [], + icon: '', + description: ' - ', + kind: 'analysis' +} + +class AnalysisTab extends BaseApi { constructor (registry) { - super() + super(profile) this.event = new EventManager() this.events = new EventEmitter() this.registry = registry } - get profile () { - return { - name: 'solidityStaticAnalysis', - displayName: 'solidity static analysis', - methods: [], - events: [], - icon: '', - description: ' - ', - kind: 'analysis', - location: 'swapPanel' - } - } - render () { var staticanalysis = new StaticAnalysis() staticanalysis.event.register('staticAnaysisWarning', (count) => { diff --git a/src/app/tabs/compile-tab.js b/src/app/tabs/compile-tab.js index 4e5680b838..fdd53f82da 100644 --- a/src/app/tabs/compile-tab.js +++ b/src/app/tabs/compile-tab.js @@ -17,12 +17,23 @@ var css = require('./styles/compile-tab-styles') const CompileTabLogic = require('./compileTab/compileTab.js') const CompilerContainer = require('./compileTab/compilerContainer.js') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' + +const profile = { + displayName: 'solidity compiler', + name: 'solidity', + methods: ['getCompilationResult'], + events: ['compilationFinished'], + icon: '', + description: 'compile solidity contracts', + kind: 'compile', + permission: true +} -class CompileTab extends ApiFactory { +class CompileTab extends BaseApi { constructor (editor, config, renderer, swarmfileProvider, fileManager, fileProviders, pluginManager) { - super() + super(profile) this.events = new EventEmitter() this._view = { el: null, @@ -57,20 +68,6 @@ class CompileTab extends ApiFactory { ) } - get profile () { - return { - displayName: 'solidity compiler', - name: 'solidity', - methods: ['getCompilationResult'], - events: ['compilationFinished'], - icon: '', - description: 'compile solidity contracts', - kind: 'compile', - permission: true, - location: 'swapPanel' - } - } - /************ * EVENTS */ diff --git a/src/app/tabs/debugger-tab.js b/src/app/tabs/debugger-tab.js index 5e1c3cb4ac..3486f7fc42 100644 --- a/src/app/tabs/debugger-tab.js +++ b/src/app/tabs/debugger-tab.js @@ -3,28 +3,25 @@ var css = require('./styles/debugger-tab-styles') var DebuggerUI = require('../debugger/debuggerUI') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' + +const profile = { + displayName: 'debugger', + name: 'debugger', + methods: [], + events: [], + icon: '', + description: 'debug transactions', + kind: 'debugging' +} -class DebuggerTab extends ApiFactory { +class DebuggerTab extends BaseApi { constructor () { - super() + super(profile) this.el = null } - get profile () { - return { - displayName: 'debugger', - name: 'debugger', - methods: [], - events: [], - icon: '', - description: 'debug transactions', - kind: 'debugging', - location: 'swapPanel' - } - } - render () { if (this.el) return this.el diff --git a/src/app/tabs/run-tab.js b/src/app/tabs/run-tab.js index ca6ebc8765..e2fe378bd8 100644 --- a/src/app/tabs/run-tab.js +++ b/src/app/tabs/run-tab.js @@ -12,12 +12,22 @@ var ContractDropdownUI = require('./runTab/contractDropdown.js') var Recorder = require('./runTab/model/recorder.js') var RecorderUI = require('./runTab/recorder.js') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' + +const profile = { + name: 'run', + displayName: 'run transactions', + methods: [], + events: [], + icon: '', + description: 'execute and save transactions', + kind: 'run' +} -class RunTab extends ApiFactory { +class RunTab extends BaseApi { constructor (udapp, udappUI, config, fileManager, editor, logCallback, filePanel, pluginManager, compilersArtefacts) { - super() + super(profile) this.event = new EventManager() this.renderInstanceContainer() @@ -28,19 +38,6 @@ class RunTab extends ApiFactory { this.renderContainer() } - get profile () { - return { - name: 'run', - displayName: 'run transactions', - methods: [], - events: [], - icon: '', - description: 'execute and save transactions', - kind: 'run', - location: 'swapPanel' - } - } - renderContainer () { this.container = yo`
` diff --git a/src/app/tabs/settings-tab.js b/src/app/tabs/settings-tab.js index a3a7c31fea..f013829dba 100644 --- a/src/app/tabs/settings-tab.js +++ b/src/app/tabs/settings-tab.js @@ -4,11 +4,22 @@ var tooltip = require('../ui/tooltip') var copyToClipboard = require('../ui/copy-to-clipboard') var EventManager = require('../../lib/events') var css = require('./styles/settings-tab-styles') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' -module.exports = class SettingsTab extends ApiFactory { +const profile = { + displayName: 'settings', + name: 'settings', + methods: [], + events: [], + icon: '', + description: ' - ', + kind: 'settings', + location: 'swapPanel' +} + +module.exports = class SettingsTab extends BaseApi { constructor (config, editor, appManager) { - super() + super(profile) this.config = config this.editor = editor this.appManager = appManager @@ -30,18 +41,7 @@ module.exports = class SettingsTab extends ApiFactory { initTheme () { this.currentTheme = this._deps.themeModule.currentTheme() } - get profile () { - return { - displayName: 'settings', - name: 'settings', - methods: [], - events: [], - icon: '', - description: ' - ', - kind: 'settings', - location: 'swapPanel' - } - } + createThemeCheckies () { let themes = this._deps.themeModule.getThemes() const onswitchTheme = (event, name) => { diff --git a/src/app/tabs/test-tab.js b/src/app/tabs/test-tab.js index 97efc68c93..15a05750ba 100644 --- a/src/app/tabs/test-tab.js +++ b/src/app/tabs/test-tab.js @@ -3,13 +3,22 @@ var async = require('async') var tooltip = require('../ui/tooltip') var css = require('./styles/test-tab-styles') var remixTests = require('remix-tests') -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' const TestTabLogic = require('./testTab/testTab') -module.exports = class TestTab extends ApiFactory { +const profile = { + name: 'solidityUnitTesting', + displayName: 'solidity unit testing', + methods: [], + events: [], + icon: '', + description: ' - ' +} + +module.exports = class TestTab extends BaseApi { constructor (fileManager, filePanel, compileTab) { - super() + super(profile) this.compileTab = compileTab this._view = { el: null } this.compileTab = compileTab @@ -20,18 +29,6 @@ module.exports = class TestTab extends ApiFactory { this.testList = yo`` } - get profile () { - return { - name: 'solidityUnitTesting', - displayName: 'solidity unit testing', - methods: [], - events: [], - icon: '', - description: ' - ', - location: 'swapPanel' - } - } - activate () { this.listenToEvents() } diff --git a/src/app/tabs/theme-module.js b/src/app/tabs/theme-module.js index a334a35d95..406c36ddee 100644 --- a/src/app/tabs/theme-module.js +++ b/src/app/tabs/theme-module.js @@ -1,4 +1,4 @@ -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' import { EventEmitter } from 'events' const Storage = require('remix-lib').Storage @@ -17,24 +17,22 @@ const themes = [ {name: 'Superhero', quality: 'dark', url: 'https://stackpath.bootstrapcdn.com/bootswatch/4.3.1/superhero/bootstrap.min.css'} ] -export class ThemeModule extends ApiFactory { +const profile = { + name: 'theme', + events: ['themeChanged'], + methods: ['switchTheme', 'getThemes', 'currentTheme'] +} + +export class ThemeModule extends BaseApi { constructor () { - super() + super(profile) this.events = new EventEmitter() this.storage = new Storage('style:') this.themes = themes.reduce((acc, theme) => ({ ...acc, [theme.name]: theme }), {}) this.active = this.storage.exists('theme') ? this.storage.get('theme') : 'Cerulean' } - get profile () { - return { - name: 'theme', - events: ['themeChanged'], - methods: ['switchTheme', 'getThemes', 'currentTheme'] - } - } - /** Return the active theme */ currentTheme () { return this.themes[this.active] diff --git a/src/app/tabs/txlistener-module.js b/src/app/tabs/txlistener-module.js index fb872dd5da..a6a17f6289 100644 --- a/src/app/tabs/txlistener-module.js +++ b/src/app/tabs/txlistener-module.js @@ -1,23 +1,21 @@ -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' import { EventEmitter } from 'events' -export class TxListenerModule extends ApiFactory { +const profile = { + name: 'txListener', + displayName: 'transaction listener', + events: ['newTransaction'], + description: 'service - notify new transactions', + permission: true +} + +export class TxListenerModule extends BaseApi { constructor (txlistener) { - super() + super(profile) this.events = new EventEmitter() txlistener.event.register('newTransaction', (tx) => { this.events.emit('newTransaction', tx) }) } - - get profile () { - return { - name: 'txListener', - displayName: 'transaction listener', - events: ['newTransaction'], - description: 'service - notify new transactions', - permission: true - } - } } diff --git a/src/app/ui/landing-page/landing-page.js b/src/app/ui/landing-page/landing-page.js index 6569a7bcee..9c918d9099 100644 --- a/src/app/ui/landing-page/landing-page.js +++ b/src/app/ui/landing-page/landing-page.js @@ -56,13 +56,23 @@ let css = csjs` ` import { defaultWorkspaces } from './workspace' -import { ApiFactory } from 'remix-plugin' +import { BaseApi } from 'remix-plugin' import Section from './section' -export class LandingPage extends ApiFactory { +const profile = { + displayName: 'Home', + name: 'home', + methods: [], + events: [], + description: ' - ', + icon: '', + location: 'mainPanel' +} + +export class LandingPage extends BaseApi { constructor (appManager, appStore) { - super() + super(profile) this.appStore = appStore this.sections = [] let load = function (item) { @@ -178,18 +188,6 @@ export class LandingPage extends ApiFactory { this.sections.push(sectionResources) } - get profile () { - return { - displayName: 'Home', - name: 'home', - methods: [], - events: [], - description: ' - ', - icon: '', - location: 'mainPanel' - } - } - render () { let logo = '' let totalLook = yo` diff --git a/src/universal-dapp.js b/src/universal-dapp.js index a36e1f87ff..b57489d9c9 100644 --- a/src/universal-dapp.js +++ b/src/universal-dapp.js @@ -7,12 +7,19 @@ var TxRunner = remixLib.execution.txRunner var txHelper = remixLib.execution.txHelper var EventManager = remixLib.EventManager var executionContext = remixLib.execution.executionContext -import { ApiFactory } from 'remix-plugin' +import { UdappApi } from 'remix-plugin' -module.exports = class UniversalDApp extends ApiFactory { +const profile = { + name: 'udapp', + displayName: 'universal dapp', + methods: ['runTestTx', 'getAccounts', 'createVMAccount'], + description: 'service - run transaction and access account' +} + +module.exports = class UniversalDApp extends UdappApi { constructor (registry) { - super() + super(profile) this.event = new EventManager() this._deps = { config: registry.get('config').api @@ -32,15 +39,6 @@ module.exports = class UniversalDApp extends ApiFactory { executionContext.event.register('contextChanged', this.resetEnvironment.bind(this)) } - get profile () { - return { - name: 'udapp', - displayName: 'universal dapp', - methods: ['runTestTx', 'getAccounts', 'createVMAccount'], - description: 'service - run transaction and access account' - } - } - resetEnvironment () { this.accounts = {} if (executionContext.isVM()) {