mirror of
				https://github.com/piskelapp/piskel.git
				synced 2023-08-10 21:12:52 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			98 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| (function () {
 | |
|   var ns = $.namespace('pskl.service.keyboard');
 | |
| 
 | |
|   ns.ShortcutService = function () {
 | |
|     this.shortcuts_ = {};
 | |
|   };
 | |
| 
 | |
|   /**
 | |
|    * @public
 | |
|    */
 | |
|   ns.ShortcutService.prototype.init = function() {
 | |
|     $(document.body).keydown($.proxy(this.onKeyUp_, this));
 | |
|   };
 | |
| 
 | |
|   ns.ShortcutService.prototype.addShortcut = function (rawKey, callback) {
 | |
|     var parsedKey = this.parseKey_(rawKey.toLowerCase());
 | |
| 
 | |
|     var key = parsedKey.key,
 | |
|       meta = parsedKey.meta;
 | |
| 
 | |
|     this.shortcuts_[key] = this.shortcuts_[key] || {};
 | |
| 
 | |
|     if (this.shortcuts_[key][meta]) {
 | |
|       throw 'Shortcut ' + meta + ' + ' + key + ' already registered';
 | |
|     } else {
 | |
|       this.shortcuts_[key][meta] = callback;
 | |
|     }
 | |
|   };
 | |
| 
 | |
|   ns.ShortcutService.prototype.removeShortcut = function (rawKey) {
 | |
|     var parsedKey = this.parseKey_(rawKey.toLowerCase());
 | |
| 
 | |
|     var key = parsedKey.key,
 | |
|       meta = parsedKey.meta;
 | |
| 
 | |
|     this.shortcuts_[key] = this.shortcuts_[key] || {};
 | |
| 
 | |
|     this.shortcuts_[key][meta] = null;
 | |
|   };
 | |
| 
 | |
|   ns.ShortcutService.prototype.parseKey_ = function (key) {
 | |
|     var meta = 'normal';
 | |
|     if (key.indexOf('ctrl+') === 0) {
 | |
|       meta = 'ctrl';
 | |
|       key = key.replace('ctrl+', '');
 | |
|     } else if (key.indexOf('shift+') === 0) {
 | |
|       meta = 'shift';
 | |
|       key = key.replace('shift+', '');
 | |
|     }
 | |
|     return {meta : meta, key : key};
 | |
|   };
 | |
| 
 | |
|   /**
 | |
|    * @private
 | |
|    */
 | |
|   ns.ShortcutService.prototype.onKeyUp_ = function(evt) {
 | |
|     if (!this.isInInput_(evt)) {
 | |
|       // jquery names FTW ...
 | |
|       var keycode = evt.which;
 | |
|       var targetTagName = evt.target.nodeName.toUpperCase();
 | |
|       var charkey = pskl.service.keyboard.KeycodeTranslator.toChar(keycode);
 | |
| 
 | |
|       var keyShortcuts = this.shortcuts_[charkey];
 | |
|       if(keyShortcuts) {
 | |
|         var cb;
 | |
|         if (this.isCtrlKeyPressed_(evt)) {
 | |
|           cb = keyShortcuts.ctrl;
 | |
|         } else if (this.isShiftKeyPressed_(evt)) {
 | |
|           cb = keyShortcuts.shift;
 | |
|         } else {
 | |
|           cb = keyShortcuts.normal;
 | |
|         }
 | |
| 
 | |
|         if(cb) {
 | |
|           cb(charkey);
 | |
|           evt.preventDefault();
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   };
 | |
| 
 | |
|   ns.ShortcutService.prototype.isInInput_ = function (evt) {
 | |
|     var targetTagName = evt.target.nodeName.toUpperCase();
 | |
|     return targetTagName === 'INPUT' || targetTagName === 'TEXTAREA';
 | |
|   };
 | |
| 
 | |
|   ns.ShortcutService.prototype.isCtrlKeyPressed_ = function (evt) {
 | |
|     return this.isMac_() ? evt.metaKey : evt.ctrlKey;
 | |
|   };
 | |
| 
 | |
|   ns.ShortcutService.prototype.isShiftKeyPressed_ = function (evt) {
 | |
|     return evt.shiftKey;
 | |
|   };
 | |
| 
 | |
|   ns.ShortcutService.prototype.isMac_ = function () {
 | |
|     return navigator.appVersion.indexOf("Mac") != -1;
 | |
|   };
 | |
| })(); | 
