-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgoog_events.html
127 lines (98 loc) · 2.67 KB
/
goog_events.html
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
<!DOCTYPE html>
<html>
<!--
Copyright 2010 The Closure Library Authors. All Rights Reserved.
Use of this source code is governed by an Apache 2.0 License.
See the COPYING file for details.
-->
<head>
<title>goog.events.KeyHandler</title>
<link rel="stylesheet" href="http://closure-library.googlecode.com/svn/trunk/closure/goog/demos/css/demo.css">
<style>
body {
font: message-box;
}
button {
font: caption;
}
#console {
position: fixed;
right: 0;
top: 0;
left: 400px;
bottom: 0;
overflow: auto;
}
#no-tab {
border: 1px solid red;
background: pink;
float: left;
padding: 1em;
}
</style>
<script src="base.js"></script>
<script>
goog.require('goog.debug.DivConsole');
goog.require('goog.events');
goog.require('goog.events.KeyCodes');
goog.require('goog.events.KeyHandler');
</script>
</head>
<body>
<h1>goog.events.KeyHandler</h1>
<p><button onclick="console.clear()">Clear Console</button>
<p>
<label>Plain input <input></label><br>
<label>Number input <input class=number-input></label><br>
<textarea></textarea>
</p>
<div id=no-tab>
<p>No Tab inside this
<p><label>Plain input <input></label><br>
<label>Number input <input class=number-input></label><br>
<textarea></textarea>
</div>
<div id=console></div>
<script>
var console = new goog.debug.DivConsole(document.getElementById('console'));
console.setCapturing(true);
var logger = new goog.debug.Logger.getLogger('demo');
var docKh = new goog.events.KeyHandler(document);
goog.events.listen(docKh, 'key', function(e) {
logger.info('keyCode: ' + e.keyCode +
', charCode: ' + e.charCode +
', repeat: ' + e.repeat +
', target: ' + e.target);
});
var noTabKh =
new goog.events.KeyHandler(document.getElementById('no-tab'));
goog.events.listen(noTabKh, 'key', function(e) {
if (e.keyCode == goog.events.KeyCodes.TAB) {
e.preventDefault();
}
});
function numberInputKeyHandler(e) {
logger.info('isTextModifyingKeyEvent: ' +
goog.events.KeyCodes.isTextModifyingKeyEvent(e));
if (e.target.className != 'number-input' ||
e.ctrlKey ||
!e.shiftKey && e.keyCode >= goog.events.KeyCodes.ZERO &&
e.keyCode <= goog.events.KeyCodes.NINE ||
e.keyCode == goog.events.KeyCodes.TAB ||
!goog.events.KeyCodes.isTextModifyingKeyEvent(e)) {
return;
}
switch (e.keyCode) {
// Allow these
case goog.events.KeyCodes.DELETE:
case goog.events.KeyCodes.BACKSPACE:
case goog.events.KeyCodes.TAB:
return;
}
// prevent default for the rest
e.preventDefault();
}
goog.events.listen(docKh, 'key', numberInputKeyHandler);
</script>
</body>
</html>