diff options
author | Teddy Wing | 2015-05-23 16:21:38 -0400 |
---|---|---|
committer | Teddy Wing | 2015-05-23 16:21:38 -0400 |
commit | 3a09e4dd09a6af3b228fcda68aa0709626b5ee51 (patch) | |
tree | a434d76ccae2a55cfe4f4c0215a99017de4bba33 /lib/mousetrap/plugins/global-bind/mousetrap-global-bind.js | |
parent | 6183a0bb3caf4805ed4242a4ac104b9890db3601 (diff) | |
download | Peniquitous-3a09e4dd09a6af3b228fcda68aa0709626b5ee51.tar.bz2 |
Set up Bower. Install Mousetrap.
* Create limited bower.json file
* Create .bowerrc that tells Bower to use the `lib` directory
* Install Mousetrap for key events
Diffstat (limited to 'lib/mousetrap/plugins/global-bind/mousetrap-global-bind.js')
-rw-r--r-- | lib/mousetrap/plugins/global-bind/mousetrap-global-bind.js | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/lib/mousetrap/plugins/global-bind/mousetrap-global-bind.js b/lib/mousetrap/plugins/global-bind/mousetrap-global-bind.js new file mode 100644 index 0000000..1c4ac14 --- /dev/null +++ b/lib/mousetrap/plugins/global-bind/mousetrap-global-bind.js @@ -0,0 +1,43 @@ +/** + * adds a bindGlobal method to Mousetrap that allows you to + * bind specific keyboard shortcuts that will still work + * inside a text input field + * + * usage: + * Mousetrap.bindGlobal('ctrl+s', _saveChanges); + */ +/* global Mousetrap:true */ +(function(Mousetrap) { + var _globalCallbacks = {}; + var _originalStopCallback = Mousetrap.prototype.stopCallback; + + Mousetrap.prototype.stopCallback = function(e, element, combo, sequence) { + var self = this; + + if (self.paused) { + return true; + } + + if (_globalCallbacks[combo] || _globalCallbacks[sequence]) { + return false; + } + + return _originalStopCallback.call(self, e, element, combo); + }; + + Mousetrap.prototype.bindGlobal = function(keys, callback, action) { + var self = this; + self.bind(keys, callback, action); + + if (keys instanceof Array) { + for (var i = 0; i < keys.length; i++) { + _globalCallbacks[keys[i]] = true; + } + return; + } + + _globalCallbacks[keys] = true; + }; + + Mousetrap.init(); +}) (Mousetrap); |