File: inputhandler.html

package info (click to toggle)
aseba-plugin-blockly 20180211%2Bgit-2
  • links: PTS
  • area: non-free
  • in suites: buster
  • size: 64,472 kB
  • sloc: xml: 7,976; python: 2,314; sh: 261; lisp: 24; makefile: 10
file content (84 lines) | stat: -rw-r--r-- 2,264 bytes parent folder | download | duplicates (8)
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
<!DOCTYPE html>
<html>
<!--
Copyright 2010 The Closure Library Authors. All Rights Reserved.

Use of this source code is governed by the Apache License, Version 2.0.
See the COPYING file for details.
-->
<head>
<title>goog.events.InputHandler</title>
<script src="../base.js"></script>
<script>
goog.require('goog.debug.DivConsole');
goog.require('goog.dom');
goog.require('goog.events');
goog.require('goog.events.InputHandler');
goog.require('goog.log');
</script>
<link rel="stylesheet" href="css/demo.css">
</head>
<body>
<h1>goog.events.InputHandler</h1>
<p><button onclick="addSome('text')">Add Some</button>
<input type="text" id="text"><span></span>

<p><button onclick="addSome('password')">Add Some</button>
<input type="password" id="password"><span></span>


<p><button onclick="addSome('textarea')">Add Some</button>
<textarea id="textarea"></textarea><span></span>

<br><br>
<fieldset class="goog-debug-panel">
  <legend>Event Log</legend>
  <div id="log" style="height: 400px;"></div>
</fieldset>

<script>
var $ = goog.dom.getElement;
var logger = goog.log.getLogger('demo');
var logconsole = new goog.debug.DivConsole(goog.dom.getElement('log'));

goog.debug.LogManager.getRoot().setLevel(goog.log.Level.FINER);
logconsole.setCapturing(true);

var DOM_EVENTS = ['keydown', 'keyup', 'keypress', 'change', 'cut', 'paste',
    'drop', 'input'];
var INPUTHANDLER_EVENTS =
    goog.object.getValues(goog.events.InputHandler.EventType);


function logEvent(src, e) {
  goog.log.info(logger, '[Event from ' + src + ']:  ' + e.type);
}

function addSome(id) {
  var el = $(id);
  el.value += '.';
}

function updateText(e) {
  var inputEl = e.target;
  var outputEl = inputEl.nextSibling;
  while (outputEl.hasChildNodes()) {
    outputEl.removeChild(outputEl.lastChild);
  }
  outputEl.appendChild(document.createTextNode(inputEl.value));
}


goog.object.forEach(['text', 'password', 'textarea'], function(id) {
  var el = $(id);
  var ih = new goog.events.InputHandler(el);

  goog.events.listen(ih, goog.events.InputHandler.EventType.INPUT, updateText);
  goog.events.listen(ih, INPUTHANDLER_EVENTS,
      goog.partial(logEvent, 'InputHandler'));
  goog.events.listen(el, DOM_EVENTS,
      goog.partial(logEvent, 'DOM'));
});
</script>
</body>
</html>