import { AppManagerApi, Plugin } from 'remix-plugin' import { EventEmitter } from 'events' import PluginManagerProxy from './app/components/plugin-manager-proxy' export class RemixAppManager extends AppManagerApi { constructor (store) { super(null) this.store = store this.hiddenServices = {} this.event = new EventEmitter() this.data = { proxy: new PluginManagerProxy() } } proxy () { // that's temporary. should be removed when we can have proper notification registration return this.data.proxy } setActive (name, isActive) { const entity = this.getEntity(name) // temp if (entity && name === 'solidity') { isActive ? this.data.proxy.register(entity.api) : this.data.proxy.unregister(entity.api) } isActive ? this.store.activate(name) : this.store.deactivate(name) if (!isActive) { this.removeHiddenServices(entity) } } getEntity (entityName) { return this.store.get(entityName) } addEntity (entity) { this.store.add(entity.profile.name, entity) } // this function is only used for iframe plugins resolveLocation (profile, domEl) { if (profile.icon) { this.event.emit('pluginNeedsLocation', profile, domEl) } else { this.hiddenServices[profile.name] = domEl document.body.appendChild(domEl) } } removeHiddenServices (profile) { let hiddenServices = this.hiddenServices[profile.name] if (hiddenServices) document.body.removeChild(hiddenServices) } plugins () { let vyper = { name: 'vyper', events: [], methods: [], notifications: {}, url: 'https://plugin.vyper.live', description: 'compile vyper contracts', icon: '' } let ethDoc = { name: 'eth doc', events: ['newDoc'], methods: ['getdoc'], notifications: { 'solCompiler': ['getCompilationFinished'] }, url: 'https://ipfs.io/ipfs/QmbxaFhAzSYbQ4TNQhCQqBgW3dFMt7Zj1D2achHHYvJhkz/', description: 'generate solidity documentation' } var pipeline = { name: 'pipeline', events: [], methods: [], notifications: {}, url: 'https://pipeline.pipeos.one', description: ' - ', icon: '', prefferedLocation: 'mainPanel' } return [{ profile: ethDoc, api: new Plugin(ethDoc, { resolveLocaton: (iframe) => { return this.resolveLocation(ethDoc, iframe) } }) }, { profile: pipeline, api: new Plugin(pipeline, { resolveLocaton: (iframe) => { return this.resolveLocation(pipeline, iframe) } }) }, { profile: vyper, api: new Plugin(vyper, { resolveLocaton: (iframe) => { return this.resolveLocation(vyper, iframe) } }) }] } }