diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2017-09-03 17:48:46 +0900 |
---|---|---|
committer | Shin'ya Ueoka <ueokande@i-beam.org> | 2017-09-03 17:48:46 +0900 |
commit | 8cabd68b927fe7022efa11dee082aafe8c2d4f30 (patch) | |
tree | 3cdcc1f557d148cd70a16b767e88b19220761e51 /src/content | |
parent | 044f24efb64ec52dfdb02e0e0807bc4545c4a21c (diff) | |
parent | 29f82d3a7f339fa99759b589923f0d8657da28f5 (diff) |
Merge branch 'buffer'
Diffstat (limited to 'src/content')
-rw-r--r-- | src/content/index.js | 40 |
1 files changed, 31 insertions, 9 deletions
diff --git a/src/content/index.js b/src/content/index.js index 66b1121..8b3eb58 100644 --- a/src/content/index.js +++ b/src/content/index.js @@ -7,7 +7,7 @@ import Follow from './follow'; let vvConsole = new ConsoleFrame(window); -const invokeEvent = (action) => { +const doAction = (action) => { if (typeof action === 'undefined' || action === null) { return; } @@ -24,6 +24,9 @@ const invokeEvent = (action) => { vvConsole.showCommand('open '); } break; + case actions.CMD_BUFFER: + vvConsole.showCommand('buffer '); + break; case actions.SCROLL_LINES: scrolls.scrollLines(window, action[1]); break; @@ -54,6 +57,18 @@ const invokeEvent = (action) => { } } +const handleResponse = (response) => { + if (!response) { + return; + } + + switch(response.type) { + case 'response.action': + doAction(response.action); + break; + } +}; + window.addEventListener("keypress", (e) => { if (e.target instanceof HTMLInputElement) { return; @@ -66,27 +81,34 @@ window.addEventListener("keypress", (e) => { } browser.runtime.sendMessage(request) - .then(invokeEvent, - (err) => { - console.log(`Vim Vixen: ${err}`); - }); + .then(handleResponse) + .catch((err) => { + vvConsole.showError(err.message); + console.log(`Vim Vixen: ${err}`); + }); }); messages.receive(window, (message) => { switch (message.type) { - case 'vimvixen.commandline.blur': - vvConsole.hide(); + case 'vimvixen.command.blur': + if (!vvConsole.isErrorShown()) { + vvConsole.hide(); + } break; - case 'vimvixen.commandline.enter': + case 'vimvixen.command.enter': browser.runtime.sendMessage({ type: 'event.cmd.enter', text: message.value + }).catch((e) => { + vvConsole.showError(e.message); }); break; - case 'vimvixen.commandline.change': + case 'vimvixen.command.change': browser.runtime.sendMessage({ type: 'event.cmd.suggest', text: message.value + }).catch((e) => { + vvConsole.showError(e.message); }); break; default: |