aboutsummaryrefslogtreecommitdiff
path: root/src/components
diff options
context:
space:
mode:
authorShin'ya UEOKA <ueokande@i-beam.org>2017-10-03 02:54:38 +0000
committerShin'ya Ueoka <ueokande@i-beam.org>2017-10-03 20:20:24 +0900
commiteff8d9a83edf63bab09df4bd7f6e20e85fba3899 (patch)
treefb1caae5abf8c4c01a8e537b173ce45806c3592e /src/components
parentb5e52a75d760c23d2ac7257056f9ba592ad17b34 (diff)
comtent input as compoents
Diffstat (limited to 'src/components')
-rw-r--r--src/components/content-input.js31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/components/content-input.js b/src/components/content-input.js
new file mode 100644
index 0000000..81f2e6b
--- /dev/null
+++ b/src/components/content-input.js
@@ -0,0 +1,31 @@
+import messages from '../content/messages';
+
+export default class ContentInputComponent {
+ constructor(target) {
+ target.addEventListener('keypress', this.onKeyPress.bind(this));
+ target.addEventListener('keydown', this.onKeyDown.bind(this));
+ target.addEventListener('keyup', this.onKeyUp.bind(this));
+ }
+
+ onKeyPress(e) {
+ if (e.target instanceof HTMLInputElement ||
+ e.target instanceof HTMLTextAreaElement ||
+ e.target instanceof HTMLSelectElement) {
+ if (e.key === 'Escape' && e.target.blur) {
+ e.target.blur();
+ }
+ return;
+ }
+ browser.runtime.sendMessage({
+ type: messages.KEYDOWN,
+ code: e.which,
+ ctrl: e.ctrlKey
+ });
+ }
+
+ onKeyDown() {
+ }
+
+ onKeyUp() {
+ }
+}