import messages from 'shared/messages'; import reducers from 'console/reducers'; import { createStore, applyMiddleware } from 'redux'; import promise from 'redux-promise'; import * as consoleActions from 'console/actions/console'; import { Provider } from 'react-redux'; import Console from './components/Console'; import React from 'react'; import ReactDOM from 'react-dom'; const store = createStore( reducers, applyMiddleware(promise), ); window.addEventListener('load', () => { let wrapper = document.getElementById('vimvixen-console'); ReactDOM.render( , wrapper); }); const onMessage = (message) => { switch (message.type) { case messages.CONSOLE_SHOW_COMMAND: return store.dispatch(consoleActions.showCommand(message.command)); case messages.CONSOLE_SHOW_FIND: return store.dispatch(consoleActions.showFind()); case messages.CONSOLE_SHOW_ERROR: return store.dispatch(consoleActions.showError(message.text)); case messages.CONSOLE_SHOW_INFO: return store.dispatch(consoleActions.showInfo(message.text)); case messages.CONSOLE_HIDE: return store.dispatch(consoleActions.hide()); } }; browser.runtime.onMessage.addListener(onMessage); let port = browser.runtime.connect({ name: 'vimvixen-console' }); port.onMessage.addListener(onMessage);