diff --git a/src/app/compiler/compiler-artefacts.js b/src/app/compiler/compiler-artefacts.js index f1ce9fc05d..860954bb2d 100644 --- a/src/app/compiler/compiler-artefacts.js +++ b/src/app/compiler/compiler-artefacts.js @@ -7,8 +7,7 @@ const profile = { name: 'compilerArtefacts', methods: [], events: [], - version: packageJson.version, - required: true + version: packageJson.version } module.exports = class CompilerArtefacts extends Plugin { diff --git a/src/app/components/hidden-panel.js b/src/app/components/hidden-panel.js index 5665c95afe..a76c521f0e 100644 --- a/src/app/components/hidden-panel.js +++ b/src/app/components/hidden-panel.js @@ -13,8 +13,7 @@ const profile = { name: 'hiddenPanel', displayName: 'Hidden Panel', description: '', - version: packageJson.version, - required: true + version: packageJson.version } export class HiddenPanel extends AbstractPanel { diff --git a/src/app/components/main-panel.js b/src/app/components/main-panel.js index d29a51d651..fc63087a76 100644 --- a/src/app/components/main-panel.js +++ b/src/app/components/main-panel.js @@ -16,8 +16,7 @@ const profile = { displayName: 'Main Panel', description: '', version: packageJson.version, - methods: ['addView', 'removeView'], - required: true + methods: ['addView', 'removeView'] } export class MainPanel extends AbstractPanel { diff --git a/src/app/components/plugin-manager-component.js b/src/app/components/plugin-manager-component.js index 8e6c28ba8f..2fc253ad7a 100644 --- a/src/app/components/plugin-manager-component.js +++ b/src/app/components/plugin-manager-component.js @@ -59,8 +59,7 @@ const profile = { kind: 'settings', location: 'sidePanel', documentation: 'https://remix-ide.readthedocs.io/en/latest/plugin_manager.html', - version: packageJson.version, - required: true + version: packageJson.version } class PluginManagerComponent extends ViewPlugin { @@ -146,7 +145,7 @@ class PluginManagerComponent extends ViewPlugin { render () { // Filtering helpers const isFiltered = (api) => api.name.toLowerCase().includes(this.filter) - const isNotRequired = ({profile}) => !profile.required + const isNotRequired = ({profile}) => !this.appManager.isRequired(profile.name) const sortByName = (a, b) => { const nameA = a.name.toUpperCase() const nameB = b.name.toUpperCase() diff --git a/src/app/components/side-panel.js b/src/app/components/side-panel.js index e55e3ba0b7..3bef2eea34 100644 --- a/src/app/components/side-panel.js +++ b/src/app/components/side-panel.js @@ -55,8 +55,7 @@ const sidePanel = { displayName: 'Side Panel', description: '', version: packageJson.version, - methods: ['addView', 'removeView'], - required: true + methods: ['addView', 'removeView'] } // TODO merge with vertical-icons.js diff --git a/src/app/components/vertical-icons.js b/src/app/components/vertical-icons.js index 4d62e5d6d5..7a16ac2c98 100644 --- a/src/app/components/vertical-icons.js +++ b/src/app/components/vertical-icons.js @@ -12,8 +12,7 @@ const profile = { displayName: 'Vertical Icons', description: '', version: packageJson.version, - methods: ['select'], - required: true + methods: ['select'] } // TODO merge with side-panel.js. VerticalIcons should not be a plugin diff --git a/src/app/editor/SourceHighlighters.js b/src/app/editor/SourceHighlighters.js index 70d6533181..2d4b6a9d7c 100644 --- a/src/app/editor/SourceHighlighters.js +++ b/src/app/editor/SourceHighlighters.js @@ -9,8 +9,7 @@ const profile = { name: 'sourceHighlighters', description: 'service - highlight source code', version: packageJson.version, - methods: ['highlight', 'discardHighlight'], - required: true + methods: ['highlight', 'discardHighlight'] } // EditorApi: diff --git a/src/app/editor/contextualListener.js b/src/app/editor/contextualListener.js index 0e8bc6552d..99b492316f 100644 --- a/src/app/editor/contextualListener.js +++ b/src/app/editor/contextualListener.js @@ -12,8 +12,7 @@ const profile = { name: 'contextualListener', methods: [], events: [], - version: packageJson.version, - required: true + version: packageJson.version } /* diff --git a/src/app/files/compiler-metadata.js b/src/app/files/compiler-metadata.js index bfabbe50d8..15aa0360ad 100644 --- a/src/app/files/compiler-metadata.js +++ b/src/app/files/compiler-metadata.js @@ -8,8 +8,7 @@ const profile = { name: 'compilerMetadata', methods: ['deployMetadataOf'], events: [], - version: packageJson.version, - required: true + version: packageJson.version } class CompilerMetadata extends Plugin { diff --git a/src/app/files/fileManager.js b/src/app/files/fileManager.js index 1c99800174..a50cd38dfb 100644 --- a/src/app/files/fileManager.js +++ b/src/app/files/fileManager.js @@ -23,8 +23,7 @@ const profile = { icon: '', permission: true, version: packageJson.version, - methods: ['getFolder', 'getCurrentFile', 'getFile', 'setFile', 'switchFile'], - required: true + methods: ['getFolder', 'getCurrentFile', 'getFile', 'setFile', 'switchFile'] } // File System profile diff --git a/src/app/panels/file-panel.js b/src/app/panels/file-panel.js index a54bbe5cc8..46c12ae681 100644 --- a/src/app/panels/file-panel.js +++ b/src/app/panels/file-panel.js @@ -37,8 +37,7 @@ const profile = { kind: 'fileexplorer', location: 'sidePanel', documentation: 'https://remix-ide.readthedocs.io/en/latest/file_explorer.html', - version: packageJson.version, - required: true + version: packageJson.version } module.exports = class Filepanel extends ViewPlugin { diff --git a/src/app/panels/terminal.js b/src/app/panels/terminal.js index d3dc1374c1..70c965b12c 100644 --- a/src/app/panels/terminal.js +++ b/src/app/panels/terminal.js @@ -34,7 +34,6 @@ const profile = { methods: [], events: [], description: ' - ', - required: true, version: packageJson.version } diff --git a/src/app/tabs/network-module.js b/src/app/tabs/network-module.js index a8835fbff0..93ecdc497f 100644 --- a/src/app/tabs/network-module.js +++ b/src/app/tabs/network-module.js @@ -6,8 +6,7 @@ export const profile = { name: 'network', description: 'Manage the network (mainnet, ropsten, goerli...) and the provider (web3, vm, injected)', methods: [], - version: packageJson.version, - required: true + version: packageJson.version } // Network API has : diff --git a/src/app/tabs/theme-module.js b/src/app/tabs/theme-module.js index 6aa7dd238d..c010c5bf33 100644 --- a/src/app/tabs/theme-module.js +++ b/src/app/tabs/theme-module.js @@ -21,8 +21,7 @@ const profile = { name: 'theme', events: ['themeChanged'], methods: ['switchTheme', 'getThemes', 'currentTheme'], - version: packageJson.version, - required: true + version: packageJson.version } export class ThemeModule extends Plugin { diff --git a/src/app/ui/landing-page/landing-page.js b/src/app/ui/landing-page/landing-page.js index fd5fc25889..6ab3e73b34 100644 --- a/src/app/ui/landing-page/landing-page.js +++ b/src/app/ui/landing-page/landing-page.js @@ -77,8 +77,7 @@ const profile = { description: ' - ', icon: '', location: 'mainPanel', - version: packageJson.version, - required: true + version: packageJson.version } export class LandingPage extends ViewPlugin { diff --git a/src/lib/offsetToLineColumnConverter.js b/src/lib/offsetToLineColumnConverter.js index 495c3e4009..46e192b120 100644 --- a/src/lib/offsetToLineColumnConverter.js +++ b/src/lib/offsetToLineColumnConverter.js @@ -7,8 +7,7 @@ const profile = { name: 'offsetToLineColumnConverter', methods: [], events: [], - version: packageJson.version, - required: true + version: packageJson.version } export class OffsetToLineColumnConverter extends Plugin { diff --git a/src/remixAppManager.js b/src/remixAppManager.js index fc19cca5ca..517cc23a7e 100644 --- a/src/remixAppManager.js +++ b/src/remixAppManager.js @@ -3,6 +3,11 @@ import { PluginEngine, IframePlugin } from '@remixproject/engine' import { EventEmitter } from 'events' import { PermissionHandler } from './app/ui/persmission-handler' +const requiredModules = [ // services + layout views + system views + 'compilerArtefacts', 'compilerMetadata', 'contextualListener', 'sourceHighlighters', 'offsetToLineColumnConverter', 'network', 'theme', 'fileManager', 'contentImport', 'udapp', + 'mainPanel', 'hiddenPanel', 'sidePanel', 'menuicons', 'fileExplorers', + 'terminal', 'home', 'settings', 'pluginManager'] + export class RemixAppManager extends PluginEngine { constructor (plugins) { @@ -54,6 +59,15 @@ export class RemixAppManager extends PluginEngine { this.event.emit('ensureDeactivated', apiName) } + deactivateOne (name) { + if (requiredModules.includes(name)) return + super.deactivateOne(name) + } + + isRequired (name) { + return requiredModules.includes(name) + } + registeredPlugins () { let vyper = { name: 'vyper',