aboutsummaryrefslogtreecommitdiff
path: root/src/content/index.js
blob: 78389fdaff58c0ac5603f9cd4b0d419496c780ae (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import * as scrolls from './scrolls';
import FooterLine from './footer-line';
import Follow from './follow';
import * as actions from '../shared/actions';

var footer = null;

const createFooterLine = (initial = '') => {
  footer = new FooterLine(document, initial);
  footer.onPromptChange((e) => {
    let request = {
      type: 'event.cmd.suggest',
      text: e.target.value
    };
    browser.runtime.sendMessage(request);
  });
  footer.onEntered((e) => {
    let request = {
      type: 'event.cmd.enter',
      text: e.target.value
    };
    browser.runtime.sendMessage(request);
  });
  footer.focus();
}

const invokeEvent = (action) => {
  if (typeof action === 'undefined' || action === null) {
    return;
  }

  switch (action[0]) {
  case actions.CMD_OPEN:
    createFooterLine();
    break;
  case actions.CMD_TABS_OPEN:
    if (action[1] || false) {
      // alter url
      createFooterLine('open ' + window.location.href);
    } else {
      createFooterLine('open ');
    }
    break;
  case actions.SCROLL_UP:
    scrolls.scrollUp(window, action[1] || 1);
    break;
  case actions.SCROLL_DOWN:
    scrolls.scrollDown(window, action[1] || 1);
    break;
  case actions.SCROLL_TOP:
    scrolls.scrollTop(window, action[1]);
    break;
  case actions.SCROLL_BOTTOM:
    scrolls.scrollBottom(window, action[1]);
    break;
  case actions.FOLLOW_START:
    new Follow(window.document, action[1] || false);
    break;
  }
}

const isModifier = (code) => {
  return code === KeyboardEvent.DOM_VK_SHIFT ||
    code === KeyboardEvent.DOM_VK_ALT ||
    code === KeyboardEvent.DOM_VK_CONTROL ||
    code === KeyboardEvent.DOM_VK_META;
}

window.addEventListener("keydown", (e) => {
  if (e.target instanceof HTMLInputElement) {
    return;
  }
  if (isModifier(e.keyCode)) {
    return;
  }

  let request = {
    type: 'event.keydown',
    code: e.keyCode,
    shift: e.shiftKey,
    alt: e.altKey,
    meta: e.metaKey,
    ctrl: e.ctrlKey,
  }

  browser.runtime.sendMessage(request)
    .then(invokeEvent,
      (err) => {
        console.log(`Vim Vixen: ${err}`);
      });
});