aboutsummaryrefslogtreecommitdiff
path: root/src/console/index.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/console/index.tsx')
-rw-r--r--src/console/index.tsx42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/console/index.tsx b/src/console/index.tsx
new file mode 100644
index 0000000..3190a9a
--- /dev/null
+++ b/src/console/index.tsx
@@ -0,0 +1,42 @@
+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(
+ <Provider store={store} >
+ <Console></Console>
+ </Provider>,
+ 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);