src/cm/media/js/lib/yui/yui3-3.15.0/build/event-key/event-key.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 602 e16a97fb364a
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
602
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     1
YUI.add('event-key', function (Y, NAME) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     2
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     3
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     4
 * Functionality to listen for one or more specific key combinations.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     5
 * @module event
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     6
 * @submodule event-key
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     7
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     8
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     9
var ALT      = "+alt",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    10
    CTRL     = "+ctrl",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    11
    META     = "+meta",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    12
    SHIFT    = "+shift",
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    13
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    14
    trim     = Y.Lang.trim,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    15
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    16
    eventDef = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    17
        KEY_MAP: {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    18
            enter    : 13,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    19
            esc      : 27,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    20
            backspace: 8,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    21
            tab      : 9,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    22
            pageup   : 33,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    23
            pagedown : 34
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    24
        },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    25
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    26
        _typeRE: /^(up|down|press):/,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    27
        _keysRE: /^(?:up|down|press):|\+(alt|ctrl|meta|shift)/g,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    28
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    29
        processArgs: function (args) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    30
            var spec = args.splice(3,1)[0],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    31
                mods = Y.Array.hash(spec.match(/\+(?:alt|ctrl|meta|shift)\b/g) || []),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    32
                config = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    33
                    type: this._typeRE.test(spec) ? RegExp.$1 : null,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    34
                    mods: mods,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    35
                    keys: null
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    36
                },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    37
                // strip type and modifiers from spec, leaving only keyCodes
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    38
                bits = spec.replace(this._keysRE, ''),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    39
                chr, uc, lc, i;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    40
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    41
            if (bits) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    42
                bits = bits.split(',');
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    43
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    44
                config.keys = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    45
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    46
                // FIXME: need to support '65,esc' => keypress, keydown
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    47
                for (i = bits.length - 1; i >= 0; --i) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    48
                    chr = trim(bits[i]);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    49
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    50
                    // catch sloppy filters, trailing commas, etc 'a,,'
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    51
                    if (!chr) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    52
                        continue;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    53
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    54
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    55
                    // non-numerics are single characters or key names
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    56
                    if (+chr == chr) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    57
                        config.keys[chr] = mods;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    58
                    } else {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    59
                        lc = chr.toLowerCase();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    60
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    61
                        if (this.KEY_MAP[lc]) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    62
                            config.keys[this.KEY_MAP[lc]] = mods;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    63
                            // FIXME: '65,enter' defaults keydown for both
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    64
                            if (!config.type) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    65
                                config.type = "down"; // safest
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    66
                            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    67
                        } else {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    68
                            // FIXME: Character mapping only works for keypress
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    69
                            // events. Otherwise, it uses String.fromCharCode()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    70
                            // from the keyCode, which is wrong.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    71
                            chr = chr.charAt(0);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    72
                            uc  = chr.toUpperCase();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    73
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    74
                            if (mods["+shift"]) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    75
                                chr = uc;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    76
                            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    77
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    78
                            // FIXME: stupid assumption that
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    79
                            // the keycode of the lower case == the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    80
                            // charCode of the upper case
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    81
                            // a (key:65,char:97), A (key:65,char:65)
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    82
                            config.keys[chr.charCodeAt(0)] =
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    83
                                (chr === uc) ?
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    84
                                    // upper case chars get +shift free
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    85
                                    Y.merge(mods, { "+shift": true }) :
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    86
                                    mods;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    87
                        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    88
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    89
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    90
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    91
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    92
            if (!config.type) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    93
                config.type = "press";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    94
            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    95
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    96
            return config;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    97
        },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    98
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    99
        on: function (node, sub, notifier, filter) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   100
            var spec   = sub._extra,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   101
                type   = "key" + spec.type,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   102
                keys   = spec.keys,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   103
                method = (filter) ? "delegate" : "on";
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   104
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   105
            // Note: without specifying any keyCodes, this becomes a
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   106
            // horribly inefficient alias for 'keydown' (et al), but I
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   107
            // can't abort this subscription for a simple
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   108
            // Y.on('keypress', ...);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   109
            // Please use keyCodes or just subscribe directly to keydown,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   110
            // keyup, or keypress
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   111
            sub._detach = node[method](type, function (e) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   112
                var key = keys ? keys[e.which] : spec.mods;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   113
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   114
                if (key &&
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   115
                    (!key[ALT]   || (key[ALT]   && e.altKey)) &&
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   116
                    (!key[CTRL]  || (key[CTRL]  && e.ctrlKey)) &&
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   117
                    (!key[META]  || (key[META]  && e.metaKey)) &&
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   118
                    (!key[SHIFT] || (key[SHIFT] && e.shiftKey)))
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   119
                {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   120
                    notifier.fire(e);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   121
                }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   122
            }, filter);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   123
        },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   124
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   125
        detach: function (node, sub, notifier) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   126
            sub._detach.detach();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   127
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   128
    };
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   129
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   130
eventDef.delegate = eventDef.on;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   131
eventDef.detachDelegate = eventDef.detach;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   132
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   133
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   134
 * <p>Add a key listener.  The listener will only be notified if the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   135
 * keystroke detected meets the supplied specification.  The
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   136
 * specification is a string that is defined as:</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   137
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   138
 * <dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   139
 *   <dt>spec</dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   140
 *   <dd><code>[{type}:]{code}[,{code}]*</code></dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   141
 *   <dt>type</dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   142
 *   <dd><code>"down", "up", or "press"</code></dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   143
 *   <dt>code</dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   144
 *   <dd><code>{keyCode|character|keyName}[+{modifier}]*</code></dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   145
 *   <dt>modifier</dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   146
 *   <dd><code>"shift", "ctrl", "alt", or "meta"</code></dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   147
 *   <dt>keyName</dt>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   148
 *   <dd><code>"enter", "backspace", "esc", "tab", "pageup", or "pagedown"</code></dd>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   149
 * </dl>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   150
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   151
 * <p>Examples:</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   152
 * <ul>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   153
 *   <li><code>Y.on("key", callback, "press:12,65+shift+ctrl", "#my-input");</code></li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   154
 *   <li><code>Y.delegate("key", preventSubmit, "#forms", "enter", "input[type=text]");</code></li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   155
 *   <li><code>Y.one("doc").on("key", viNav, "j,k,l,;");</code></li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   156
 * </ul>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   157
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   158
 * @event key
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   159
 * @for YUI
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   160
 * @param type {string} 'key'
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   161
 * @param fn {function} the function to execute
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   162
 * @param id {string|HTMLElement|collection} the element(s) to bind
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   163
 * @param spec {string} the keyCode and modifier specification
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   164
 * @param o optional context object
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   165
 * @param args 0..n additional arguments to provide to the listener.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   166
 * @return {Event.Handle} the detach handle
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   167
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   168
Y.Event.define('key', eventDef, true);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   169
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   170
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   171
}, '@VERSION@', {"requires": ["event-synthetic"]});