aboutsummaryrefslogtreecommitdiffstats
path: root/main.js
diff options
context:
space:
mode:
authorTeddy Wing2021-03-21 15:36:48 +0100
committerTeddy Wing2021-03-21 17:45:12 +0100
commitdb45d89fc0acf1999c2b996397d2872159c0b74c (patch)
tree54d838270905976e93ca2100a661b7160b95fd78 /main.js
parentd938c8053540d34a00925e0960ac80dbddfc7a26 (diff)
downloadPeniquitous-db45d89fc0acf1999c2b996397d2872159c0b74c.tar.bz2
Work out the proper way to import scripts
In order to import our script dependencies and inject them correctly into the page, we need to remove the existing IIFEs, append them to the page in `<script>` tags, and wrap them in custom IIFEs. If I leave the original IIFEs, they get executed too early, and I can't insert the scripts into the page correctly. Got the custom IIFE idea from Max Shawabkeh (https://stackoverflow.com/users/181765/max-shawabkeh) on Stack Overflow: https://stackoverflow.com/questions/2303147/injecting-js-functions-into-the-page-from-a-greasemonkey-script-on-chrome/2303228#2303228 This is working now, but I want a way to build the final user script without copy-pasting the imports in the main file. Going to work out the build rules next.
Diffstat (limited to 'main.js')
-rw-r--r--main.js179
1 files changed, 177 insertions, 2 deletions
diff --git a/main.js b/main.js
index 16fd714..927dea6 100644
--- a/main.js
+++ b/main.js
@@ -14,5 +14,180 @@
// along with this program. If not, see <https://www.gnu.org/licenses/>.
-require('./lib/mousetrap/tests/libs/key-event.js');
-require('./peniquitous');
+// var key_event = require('./lib/mousetrap/tests/libs/key-event.js');
+// var peniquitous = require('./peniquitous');
+
+function key_event () {
+ var KeyEvent = function(data, type) {
+ this.keyCode = 'keyCode' in data ? data.keyCode : 0;
+ this.charCode = 'charCode' in data ? data.charCode : 0;
+
+ var modifiers = 'modifiers' in data ? data.modifiers : [];
+
+ this.ctrlKey = false;
+ this.metaKey = false;
+ this.altKey = false;
+ this.shiftKey = false;
+
+ for (var i = 0; i < modifiers.length; i++) {
+ this[modifiers[i] + 'Key'] = true;
+ }
+
+ this.type = type || 'keypress';
+ };
+
+ KeyEvent.prototype.toNative = function() {
+ var event = document.createEventObject ? document.createEventObject() : document.createEvent('Events');
+
+ if (event.initEvent) {
+ event.initEvent(this.type, true, true);
+ }
+
+ event.keyCode = this.keyCode;
+ event.which = this.charCode || this.keyCode;
+ event.shiftKey = this.shiftKey;
+ event.metaKey = this.metaKey;
+ event.altKey = this.altKey;
+ event.ctrlKey = this.ctrlKey;
+
+ return event;
+ };
+
+ KeyEvent.prototype.fire = function(element) {
+ var event = this.toNative();
+ if (element.dispatchEvent) {
+ element.dispatchEvent(event);
+ return;
+ }
+
+ element.fireEvent('on' + this.type, event);
+ };
+
+ // simulates complete key event as if the user pressed the key in the browser
+ // triggers a keydown, then a keypress, then a keyup
+ KeyEvent.simulate = function(charCode, keyCode, modifiers, element, repeat) {
+ if (modifiers === undefined) {
+ modifiers = [];
+ }
+
+ if (element === undefined) {
+ element = document;
+ }
+
+ if (repeat === undefined) {
+ repeat = 1;
+ }
+
+ var modifierToKeyCode = {
+ 'shift': 16,
+ 'ctrl': 17,
+ 'alt': 18,
+ 'meta': 91
+ };
+
+ // if the key is a modifier then take it out of the regular
+ // keypress/keydown
+ if (keyCode == 16 || keyCode == 17 || keyCode == 18 || keyCode == 91) {
+ repeat = 0;
+ }
+
+ var modifiersToInclude = [];
+ var keyEvents = [];
+
+ // modifiers would go down first
+ for (var i = 0; i < modifiers.length; i++) {
+ modifiersToInclude.push(modifiers[i]);
+ keyEvents.push(new KeyEvent({
+ charCode: 0,
+ keyCode: modifierToKeyCode[modifiers[i]],
+ modifiers: modifiersToInclude
+ }, 'keydown'));
+ }
+
+ // @todo factor in duration for these
+ while (repeat > 0) {
+ keyEvents.push(new KeyEvent({
+ charCode: 0,
+ keyCode: keyCode,
+ modifiers: modifiersToInclude
+ }, 'keydown'));
+
+ keyEvents.push(new KeyEvent({
+ charCode: charCode,
+ keyCode: charCode,
+ modifiers: modifiersToInclude
+ }, 'keypress'));
+
+ repeat--;
+ }
+
+ keyEvents.push(new KeyEvent({
+ charCode: 0,
+ keyCode: keyCode,
+ modifiers: modifiersToInclude
+ }, 'keyup'));
+
+ // now lift up the modifier keys
+ for (i = 0; i < modifiersToInclude.length; i++) {
+ var modifierKeyCode = modifierToKeyCode[modifiersToInclude[i]];
+ modifiersToInclude.splice(i, 1);
+ keyEvents.push(new KeyEvent({
+ charCode: 0,
+ keyCode: modifierKeyCode,
+ modifiers: modifiersToInclude
+ }, 'keyup'));
+ }
+
+ for (i = 0; i < keyEvents.length; i++) {
+ // console.log('firing', keyEvents[i].type, keyEvents[i].keyCode, keyEvents[i].charCode);
+ keyEvents[i].fire(element);
+ }
+ };
+
+ window.KeyEvent = KeyEvent;
+}
+
+function peniquitous () {
+ key_codes = {
+ p: 80,
+ n: 78,
+ UP_ARROW: 38,
+ DOWN_ARROW: 40
+ };
+
+ // Additional types:
+ // * email
+ // * number
+ // * tel
+ // * url
+ var all_inputs = document.querySelectorAll('input[type="text"], input[type="search"]');
+
+ for (var i = 0; i < all_inputs.length; i++) {
+ all_inputs[i].addEventListener('keyup', function(e) {
+ if (e.ctrlKey && e.keyCode === key_codes.p) {
+ KeyEvent.simulate(0, key_codes.UP_ARROW, [], e.target);
+ }
+ else if (e.ctrlKey && e.keyCode === key_codes.n) {
+ KeyEvent.simulate(0, key_codes.DOWN_ARROW, [], e.target);
+ }
+ });
+ }
+}
+
+(function() {
+ [
+ key_event,
+ peniquitous
+ ].forEach(function(script) {
+ console.log('peniquitous', script);
+ var s = document.createElement('script');
+ s.appendChild(
+ document.createTextNode('(' + script + ')();')
+ );
+ // s.src = chrome.extension.getURL(file);
+ // s.onload = function() {
+ // this.parentNode.removeChild(this);
+ // };
+ document.documentElement.appendChild(s);
+ });
+})();