2013-02-22 23:19:40 +00:00
|
|
|
|
2013-03-09 06:50:46 +00:00
|
|
|
Elm.Native.Keyboard = function(elm) {
|
2013-02-21 08:40:41 +00:00
|
|
|
'use strict';
|
2013-03-09 04:17:01 +00:00
|
|
|
elm.Native = elm.Native || {};
|
2013-03-09 06:50:46 +00:00
|
|
|
if (elm.Native.Keyboard) return elm.Native.Keyboard;
|
2013-03-09 04:17:01 +00:00
|
|
|
|
|
|
|
var Signal = Elm.Signal(elm);
|
2013-03-11 17:38:52 +00:00
|
|
|
var NList = Elm.Native.List(elm);
|
|
|
|
var Maybe = Elm.Maybe(elm);
|
|
|
|
|
|
|
|
var keysDown = Signal.constant(NList.Nil);
|
|
|
|
var charPressed = Signal.constant(Maybe.Nothing);
|
|
|
|
|
|
|
|
function down(e) {
|
|
|
|
if (NList.member(e.keyCode)(keysDown.value)) return;
|
|
|
|
var list = NList.Cons(e.keyCode, keysDown.value);
|
|
|
|
var hasListener = elm.notify(keysDown.id, list);
|
|
|
|
if (!hasListener) elm.node.removeEventListener('keydown', down);
|
|
|
|
}
|
|
|
|
function up(e) {
|
|
|
|
function notEq(kc) { return kc !== e.keyCode; }
|
|
|
|
var codes = NList.filter(notEq)(keysDown.value);
|
|
|
|
var hasListener = elm.notify(keysDown.id, codes);
|
|
|
|
if (!hasListener) elm.node.removeEventListener('keyup', up);
|
|
|
|
}
|
|
|
|
function blur(e) {
|
|
|
|
var hasListener = elm.notify(keysDown.id, NList.Nil);
|
|
|
|
if (!hasListener) elm.node.removeEventListener('blur', blur);
|
|
|
|
}
|
|
|
|
function press(e) {
|
|
|
|
var next = Maybe.Just(e.charCode || e.keyCode);
|
|
|
|
var hasListener = elm.notify(charPressed.id, next);
|
|
|
|
elm.notify(charPressed.id, Maybe.Nothing);
|
|
|
|
if (!hasListener) elm.node.removeEventListener('keypress', press);
|
|
|
|
}
|
|
|
|
|
|
|
|
elm.node.addEventListener('keydown' , down );
|
|
|
|
elm.node.addEventListener('keyup' , up );
|
|
|
|
elm.node.addEventListener('blur' , blur );
|
|
|
|
elm.node.addEventListener('keypress', press);
|
2013-02-21 08:40:41 +00:00
|
|
|
|
2013-02-20 22:36:16 +00:00
|
|
|
function keySignal(f) {
|
2013-03-09 06:50:46 +00:00
|
|
|
var signal = A2( Signal.lift, f, elm.Keyboard.Raw.keysDown );
|
2013-03-11 17:38:52 +00:00
|
|
|
keysDown.defaultNumberOfKids += 1;
|
2013-02-20 22:36:16 +00:00
|
|
|
signal.defaultNumberOfKids = 0;
|
|
|
|
return signal;
|
|
|
|
}
|
|
|
|
|
2013-03-02 17:18:36 +00:00
|
|
|
function dir(up, down, left, right) {
|
2013-02-20 22:36:16 +00:00
|
|
|
function f(ks) {
|
|
|
|
var x = 0, y = 0;
|
2013-02-21 08:40:41 +00:00
|
|
|
while (ks.ctor == "Cons") {
|
|
|
|
switch (ks._0) {
|
2013-02-20 22:36:16 +00:00
|
|
|
case left : --x; break;
|
|
|
|
case right: ++x; break;
|
|
|
|
case up : ++y; break;
|
|
|
|
case down : --y; break;
|
|
|
|
}
|
2013-02-21 08:40:41 +00:00
|
|
|
ks = ks._1;
|
2013-02-20 22:36:16 +00:00
|
|
|
}
|
2013-02-21 08:40:41 +00:00
|
|
|
return { _:{}, x:x, y:y };
|
2013-02-20 22:36:16 +00:00
|
|
|
}
|
|
|
|
return keySignal(f);
|
|
|
|
}
|
|
|
|
|
2013-03-11 17:38:52 +00:00
|
|
|
function is(key) { return keySignal(NList.member(key)); }
|
2013-02-20 22:36:16 +00:00
|
|
|
|
2013-03-11 17:38:52 +00:00
|
|
|
return elm.Native.Keyboard = {
|
|
|
|
isDown:is,
|
|
|
|
directions:F4(dir),
|
|
|
|
keysDown:keysDown,
|
|
|
|
charPressed:charPressed
|
|
|
|
};
|
2013-02-20 22:36:16 +00:00
|
|
|
|
2013-03-09 04:17:01 +00:00
|
|
|
};
|