aboutsummaryrefslogtreecommitdiff
path: root/src/console/index.jsx
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2018-11-17 12:29:32 +0900
committerShin'ya Ueoka <ueokande@i-beam.org>2018-11-17 12:29:32 +0900
commit1fb5f433056e54aecc542fe1f4f684ada047032e (patch)
treeb867c8cab1f56477ae0dfefa5b5c86f5b181b9a5 /src/console/index.jsx
parent97787c773f0d1b5e80beb438246b5a693dbd08aa (diff)
Use preact in console
Diffstat (limited to 'src/console/index.jsx')
-rw-r--r--src/console/index.jsx43
1 files changed, 43 insertions, 0 deletions
diff --git a/src/console/index.jsx b/src/console/index.jsx
new file mode 100644
index 0000000..c0d1807
--- /dev/null
+++ b/src/console/index.jsx
@@ -0,0 +1,43 @@
+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 'preact-redux';
+import Console from './components/console';
+
+import { render, h } from 'preact';
+
+const store = createStore(
+ reducers,
+ applyMiddleware(promise),
+);
+
+window.addEventListener('load', () => {
+ render(
+ <Provider store={store} >
+ <Console></Console>
+ </Provider>,
+ document.body);
+});
+
+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);
+window.addEventListener('message', (event) => {
+ onMessage(JSON.parse(event.data));
+}, false);