forked from DefinitelyTyped/DefinitelyTyped
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkeyboardjs.d.ts
132 lines (115 loc) · 4.85 KB
/
keyboardjs.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
// Type definitions for KeyboardJS v2.2.0
// Project: https://github.com/RobertWHurst/KeyboardJS
// Definitions by: Vincent Bortone <https://github.com/vbortone/>,
// David Asmuth <https://github.com/piranha771>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
// KeyboardJS is a library for use in the browser (node.js compatible).
// It Allows developers to easily setup key bindings. Use key combos to setup complex bindings.
// KeyboardJS also provides contexts. Contexts are great for single page applications.
// They allow you to scope your bindings to various parts of your application.
// Out of the box keyboardJS uses a US keyboard locale. If you need support for
// a different type of keyboard KeyboardJS provides custom locale support so you can create
// with a locale that better matches your needs.
declare namespace keyboardjs {
/**
* Information and functions in the current callback.
*/
interface KeyEvent{
preventRepeat(): void;
}
/**
* Callback function when a keyCombo is triggered.
* @see KeyEvent
*/
interface Callback {
/**
* Keyevent
*/
(e?: KeyEvent): void;
}
// ---------- Key Binding ---------- //
/**
* Binds a keyCombo to specific callback functions.
* @param keyCombo String of keys to be pressed to execute callbacks.
* @param pressed Callback that gets executed when the keyComboState is 'pressed', can be null.
* @param released Callback that gets executed when the keyComboState is 'released'
* @param preventRepeatByDefault Whether or not to prevent repeat by default. Defaults to false.
*/
export function bind(keyCombo: string | string[], pressed: Callback, released?: Callback, preventRepeatByDefault?: boolean): void;
/**
* Unbinds a keyCombo completely or only specific pressed & released callback combos.
* @param keyCombo String of keys to be pressed to execute callbacks.
* @param pressed Callback that gets executed when the keyComboState is 'pressed', can be null.
* @param released Callback that gets executed when the keyComboState is 'released', can be null.
*/
export function unbind(keyCombo: string | string[], pressed?: Callback, released?: Callback): void;
// ---------- Context ---------- //
/**
* Sets the context KeyboardJS operates in. Default is global context.
* Bindings in global context will execute in all contexts.
* @param identifier The name of the context. If the context doesn't exists, it will be created.
* Use 'global' to switch to global context.
*/
export function setContext(identifier: string): void;
/**
* Executes a Callback without loosing the current context.
* @param identifier The name of the context the callback should be in. If the context doesn't exists, it will be created.
* @param inContextCallBack The callback function. Will be executed in the given context.
*/
export function withContext(identifier: string, inContextCallBack: () => void): void;
/**
* Returns the context KeyboardJS currently operates in.
*/
export function getContext(): string;
// ---------- KeyboardJS Control ---------- //
/**
* The keyboard will no longer trigger bindings.
*/
export function pause(): void;
/**
* The keyboard will once again trigger bindings.
*/
export function resume(): void;
/**
* All active bindings will released and unbound.
*/
export function reset(): void;
// ---------- Virtual Key Press ---------- //
/**
* Triggers a key press. Stays in pressed state until released.
* @param keyCombo String of keys to be pressed to execute 'pressed' callbacks.
*/
export function pressKey(keyCombo: string): void
/**
* Triggers a key release.
* @param keyCombo String of keys to be released to execute 'released' callbacks.
*/
export function releaseKey(keyCombo: string): void;
/**
* Releases all keys.
*/
export function releaseAllKeys(): void;
// ---------- Attachment ---------- //
/**
* Attaches keyboardJS a specific window and a specific document or form.
* @param myWin The window to attach to.
* @param myDoc The document or form to attach to.
*/
export function watch(myWin: Window, myDoc: Document | HTMLFormElement): void;
/**
* Attaches keyboardJS to the current window and a specific document or form.
* @param myDoc The document or form to attach to.
*/
export function watch(myDoc: Document | HTMLFormElement): void;
/**
* Attaches keyboardJS to the current window an document.
*/
export function watch(): void;
/**
* Detaches KeyboardJS from the window and document/element
*/
export function stop(): void;
}
declare module 'keyboardjs' {
export = keyboardjs;
}