|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(function (jQuery){ |
|
this.version = '(beta)(0.0.3)'; |
|
this.all = {}; |
|
this.special_keys = { |
|
27: 'esc', 9: 'tab', 32:'space', 13: 'return', 8:'backspace', 145: 'scroll', 20: 'capslock', |
|
144: 'numlock', 19:'pause', 45:'insert', 36:'home', 46:'del',35:'end', 33: 'pageup', |
|
34:'pagedown', 37:'left', 38:'up', 39:'right',40:'down', 112:'f1',113:'f2', 114:'f3', |
|
115:'f4', 116:'f5', 117:'f6', 118:'f7', 119:'f8', 120:'f9', 121:'f10', 122:'f11', 123:'f12'}; |
|
|
|
this.shift_nums = { "`":"~", "1":"!", "2":"@", "3":"#", "4":"$", "5":"%", "6":"^", "7":"&", |
|
"8":"*", "9":"(", "0":")", "-":"_", "=":"+", ";":":", "'":"\"", ",":"<", |
|
".":">", "/":"?", "\\":"|" }; |
|
|
|
this.add = function(combi, options, callback) { |
|
if ( typeof options === 'function' ){ |
|
callback = options; |
|
options = {}; |
|
} |
|
var opt = {}, |
|
defaults = {type: 'keydown', propagate: false, disableInInput: false, target: jQuery('html')[0]}, |
|
that = this; |
|
opt = jQuery.extend( opt , defaults, options || {} ); |
|
combi = combi.toLowerCase(); |
|
|
|
|
|
var inspector = function(event) { |
|
|
|
|
|
var element = event.target; |
|
|
|
|
|
|
|
|
|
if ( opt['disableInInput'] ) { |
|
var target = jQuery(element); |
|
|
|
if ( ( target.is('input') || target.is('textarea') ) && |
|
( ! opt.noDisable || ! target.is( opt.noDisable ) ) ) { |
|
|
|
return; |
|
} |
|
} |
|
var code = event.which, |
|
type = event.type, |
|
character = String.fromCharCode(code).toLowerCase(), |
|
special = that.special_keys[code], |
|
shift = event.shiftKey, |
|
ctrl = event.ctrlKey, |
|
alt= event.altKey, |
|
meta = event.metaKey, |
|
propagate = true, |
|
mapPoint = null; |
|
|
|
|
|
|
|
|
|
|
|
|
|
while (!that.all[element] && element.parentNode){ |
|
element = element.parentNode; |
|
} |
|
|
|
var cbMap = that.all[element].events[type].callbackMap; |
|
if(!shift && !ctrl && !alt && !meta) { |
|
mapPoint = cbMap[special] || cbMap[character] |
|
} |
|
|
|
else{ |
|
var modif = ''; |
|
if(alt) modif +='alt+'; |
|
if(ctrl) modif+= 'ctrl+'; |
|
if(shift) modif += 'shift+'; |
|
if(meta) modif += 'meta+'; |
|
|
|
mapPoint = cbMap[modif+special] || cbMap[modif+character] || cbMap[modif+that.shift_nums[character]] |
|
} |
|
if (mapPoint){ |
|
mapPoint.cb(event); |
|
if(!mapPoint.propagate) { |
|
event.stopPropagation(); |
|
event.preventDefault(); |
|
return false; |
|
} |
|
} |
|
}; |
|
|
|
if (!this.all[opt.target]){ |
|
this.all[opt.target] = {events:{}}; |
|
} |
|
if (!this.all[opt.target].events[opt.type]){ |
|
this.all[opt.target].events[opt.type] = {callbackMap: {}} |
|
jQuery.event.add(opt.target, opt.type, inspector); |
|
} |
|
this.all[opt.target].events[opt.type].callbackMap[combi] = {cb: callback, propagate:opt.propagate}; |
|
return jQuery; |
|
}; |
|
this.remove = function(exp, opt) { |
|
opt = opt || {}; |
|
target = opt.target || jQuery('html')[0]; |
|
type = opt.type || 'keydown'; |
|
exp = exp.toLowerCase(); |
|
delete this.all[target].events[type].callbackMap[exp] |
|
return jQuery; |
|
}; |
|
jQuery.hotkeys = this; |
|
return jQuery; |
|
})(jQuery); |
|
|