diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/key_codes.ts | 4 | ||||
| -rw-r--r-- | src/multi_key_command.ts | 29 | ||||
| -rw-r--r-- | src/sidebar.ts | 32 | 
3 files changed, 43 insertions, 22 deletions
| diff --git a/src/key_codes.ts b/src/key_codes.ts index 301b44a..2442f3c 100644 --- a/src/key_codes.ts +++ b/src/key_codes.ts @@ -1,4 +1,6 @@ -var key_codes: { [index: string]: number } = { +export type KeyCode = number; + +var key_codes: { [index: string]: KeyCode } = {  	SLASH: 220,  	M: 77  }; diff --git a/src/multi_key_command.ts b/src/multi_key_command.ts new file mode 100644 index 0000000..7e303fe --- /dev/null +++ b/src/multi_key_command.ts @@ -0,0 +1,29 @@ +import key_codes, { KeyCode } from './key_codes'; + +export default function( +	el: HTMLDocument | HTMLElement, +	command: KeyCode[], +	action: () => void +): void { +	var key_buffer: number[] = []; + +	el.addEventListener('keydown', function(e: KeyboardEvent) { +		command.forEach((key_code) => { +			if (e.keyCode === key_code) { +				key_buffer.push(key_code); +			} +		}); +	}); + +	el.addEventListener('keyup', function(e: KeyboardEvent) { +		if (key_buffer.length >= 2) { +			var command_executed = key_buffer.length === command.length +				&& key_buffer.every((value, index) => value === command[index]); + +			if (command_executed) { +				action(); +				key_buffer = []; +			} +		} +	}); +}; diff --git a/src/sidebar.ts b/src/sidebar.ts index dbf9cbe..1af0cf5 100644 --- a/src/sidebar.ts +++ b/src/sidebar.ts @@ -1,32 +1,22 @@  import { SIDEBAR } from './gmail_css_class';  import key_codes from './key_codes'; +import multi_key_command from './multi_key_command';  export default function() {  	var key_buffer: number[] = [];  	var sidebar: HTMLElement = document.getElementsByClassName(SIDEBAR)[0] as HTMLElement; -	document.addEventListener('keydown', function(e) { -		if (e.keyCode === key_codes.SLASH) { -			key_buffer.push(e.keyCode); -		} -		if (e.keyCode === key_codes.M) { -			key_buffer.push(e.keyCode); -		} -	}); - -	document.addEventListener('keyup', function(e) { -		if (key_buffer.length >= 2) { -			if (key_buffer[0] === key_codes.SLASH -				&& key_buffer[1] === key_codes.M) { -				if (sidebar.offsetParent === null) { -					sidebar.style.display = 'block'; -				} -				else { -					sidebar.style.display = 'none'; -				} +	multi_key_command( +		document, +		[key_codes.SLASH, key_codes.M], +		function() { +			if (sidebar.offsetParent === null) { +				sidebar.style.display = 'block'; +			} +			else { +				sidebar.style.display = 'none';  			} -			key_buffer = [];  		} -	}); +	);  }; | 
