src/cm/media/js/lib/yui/yui_3.0.0b1/build/event-custom/event-custom-debug.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 0 40c8f766c9b8
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     1
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     2
Copyright (c) 2009, Yahoo! Inc. All rights reserved.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     3
Code licensed under the BSD License:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     4
http://developer.yahoo.net/yui/license.txt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     5
version: 3.0.0b1
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     6
build: 1163
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     7
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     8
YUI.add('event-custom', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    10
Y.Env.evt = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    11
    handles: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    12
    plugins: {}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    13
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    14
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    15
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    16
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    17
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    18
 * Allows for the insertion of methods that are executed before or after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    19
 * a specified method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    20
 * @class Do
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    21
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    22
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    23
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    24
var BEFORE = 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    25
    AFTER = 1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    26
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    27
Y.Do = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    28
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    29
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    30
     * Cache of objects touched by the utility
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
     * @property objs
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
    objs: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
     * Execute the supplied method before the specified function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
     * @method before
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
     * @param fn {Function} the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
     * @param obj the object hosting the method to displace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
     * @param sFn {string} the name of the method to displace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
     * @param c The execution context for fn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
     * @return {string} handle for the subscription
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
    before: function(fn, obj, sFn, c) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
        // Y.log('Do before: ' + sFn, 'info', 'event');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
        var f = fn, a;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
        if (c) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
            a = [fn, c].concat(Y.Array(arguments, 4, true));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
            f = Y.rbind.apply(Y, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
        return this._inject(BEFORE, f, obj, sFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    56
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    57
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    58
     * Execute the supplied method after the specified function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
     * @method after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
     * @param fn {Function} the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
     * @param obj the object hosting the method to displace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
     * @param sFn {string} the name of the method to displace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
     * @param c The execution context for fn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
     * @return {string} handle for the subscription
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
    after: function(fn, obj, sFn, c) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
        var f = fn, a;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
        if (c) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
            a = [fn, c].concat(Y.Array(arguments, 4, true));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
            f = Y.rbind.apply(Y, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    72
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    73
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    74
        return this._inject(AFTER, f, obj, sFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
     * Execute the supplied method after the specified function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
     * @method _inject
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
     * @param when {string} before or after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
     * @param fn {Function} the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
     * @param obj the object hosting the method to displace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
     * @param sFn {string} the name of the method to displace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
     * @param c The execution context for fn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
     * @return {string} handle for the subscription
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
    _inject: function(when, fn, obj, sFn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
        // object id
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
        var id = Y.stamp(obj), o, sid;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
        if (! this.objs[id]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
            // create a map entry for the obj if it doesn't exist
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
            this.objs[id] = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
        o = this.objs[id];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
        if (! o[sFn]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
            // create a map entry for the method if it doesn't exist
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
            o[sFn] = new Y.Do.Method(obj, sFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
            // re-route the method to our wrapper
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
            obj[sFn] = 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
                function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
                    return o[sFn].exec.apply(o[sFn], arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
                };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
        // subscriber id
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
        sid = id + Y.stamp(fn) + sFn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
        // register the callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
        o[sFn].register(sid, fn, when);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   118
        return new Y.EventHandle(o[sFn], sid);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   119
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   120
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   121
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   122
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   123
     * Detach a before or after subscription
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   124
     * @method detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   125
     * @param handle {string} the subscription handle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   126
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   127
    detach: function(handle) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   128
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   129
        if (handle.detach) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   130
            handle.detach();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   131
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   132
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   133
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   134
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   135
    _unload: function(e, me) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   136
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   137
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   138
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   139
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   140
//////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   141
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   142
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   143
 * Wrapper for a displaced method with aop enabled
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   144
 * @class Do.Method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   145
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   146
 * @param obj The object to operate on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   147
 * @param sFn The name of the method to displace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   148
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   149
Y.Do.Method = function(obj, sFn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   150
    this.obj = obj;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   151
    this.methodName = sFn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   152
    this.method = obj[sFn];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   153
    // this.before = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   154
    // this.after = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   155
    this.before = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   156
    this.after = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   157
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   158
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   159
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   160
 * Register a aop subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   161
 * @method register
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   162
 * @param sid {string} the subscriber id
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   163
 * @param fn {Function} the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   164
 * @param when {string} when to execute the function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   165
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   166
Y.Do.Method.prototype.register = function (sid, fn, when) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   167
    if (when) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   168
        // this.after.push(fn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   169
        this.after[sid] = fn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   170
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   171
        // this.before.push(fn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   172
        this.before[sid] = fn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   173
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   174
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   175
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   176
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   177
 * Unregister a aop subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   178
 * @method delete
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   179
 * @param sid {string} the subscriber id
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   180
 * @param fn {Function} the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   181
 * @param when {string} when to execute the function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   182
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   183
Y.Do.Method.prototype._delete = function (sid) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   184
    // Y.log('Y.Do._delete: ' + sid, 'info', 'Event');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   185
    delete this.before[sid];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   186
    delete this.after[sid];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   187
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   188
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   189
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   190
 * Execute the wrapped method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   191
 * @method exec
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   192
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   193
Y.Do.Method.prototype.exec = function () {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   194
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   195
    var args = Y.Array(arguments, 0, true), 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   196
        i, ret, newRet, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   197
        bf = this.before,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   198
        af = this.after,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   199
        prevented = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   200
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   201
    // execute before
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   202
    for (i in bf) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   203
        if (bf.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   204
            ret = bf[i].apply(this.obj, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   205
            if (ret) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   206
                switch (ret.constructor) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   207
                    case Y.Do.Halt:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   208
                        return ret.retVal;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   209
                    case Y.Do.AlterArgs:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   210
                        args = ret.newArgs;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   211
                        break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   212
                    case Y.Do.Prevent:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   213
                        prevented = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   214
                        break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   215
                    default:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   216
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   217
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   218
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   219
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   220
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   221
    // execute method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   222
    if (!prevented) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   223
        ret = this.method.apply(this.obj, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   224
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   225
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   226
    // execute after methods.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   227
    for (i in af) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   228
        if (af.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   229
            newRet = af[i].apply(this.obj, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   230
            // Stop processing if a Halt object is returned
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   231
            if (newRet && newRet.constructor == Y.Do.Halt) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   232
                return newRet.retVal;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   233
            // Check for a new return value
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   234
            } else if (newRet && newRet.constructor == Y.Do.AlterReturn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   235
                ret = newRet.newRetVal;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   236
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   237
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   238
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   239
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   240
    return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   241
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   242
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   243
//////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   244
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   245
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   246
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   247
 * Return an AlterArgs object when you want to change the arguments that
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   248
 * were passed into the function.  An example would be a service that scrubs
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   249
 * out illegal characters prior to executing the core business logic.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   250
 * @class Do.AlterArgs
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   251
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   252
Y.Do.AlterArgs = function(msg, newArgs) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   253
    this.msg = msg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   254
    this.newArgs = newArgs;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   255
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   256
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   257
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   258
 * Return an AlterReturn object when you want to change the result returned
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   259
 * from the core method to the caller
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   260
 * @class Do.AlterReturn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   261
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   262
Y.Do.AlterReturn = function(msg, newRetVal) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   263
    this.msg = msg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   264
    this.newRetVal = newRetVal;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   265
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   266
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   267
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   268
 * Return a Halt object when you want to terminate the execution
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   269
 * of all subsequent subscribers as well as the wrapped method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   270
 * if it has not exectued yet.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   271
 * @class Do.Halt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   272
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   273
Y.Do.Halt = function(msg, retVal) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   274
    this.msg = msg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   275
    this.retVal = retVal;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   276
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   277
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   278
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   279
 * Return a Prevent object when you want to prevent the wrapped function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   280
 * from executing, but want the remaining listeners to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   281
 * @class Do.Prevent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   282
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   283
Y.Do.Prevent = function(msg) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   284
    this.msg = msg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   285
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   286
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   287
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   288
 * Return an Error object when you want to terminate the execution
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   289
 * of all subsequent method calls.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   290
 * @class Do.Error
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   291
 * @deprecated use Y.Do.Halt or Y.Do.Prevent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   292
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   293
Y.Do.Error = Y.Do.Halt;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   294
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   295
//////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   296
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   297
// Y["Event"] && Y.Event.addListener(window, "unload", Y.Do._unload, Y.Do);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   298
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   299
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   300
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   301
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   302
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   303
 * Wraps and protects a custom event for use when emitFacade is set to true.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   304
 * @class EventFacade
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   305
 * @param e {Event} the custom event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   306
 * @param currentTarget {HTMLElement} the element the listener was attached to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   307
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   308
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   309
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   310
var PROPS = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   311
    details: 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   312
    type: 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   313
    target: 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   314
    currentTarget: 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   315
    stopPropagation: 2,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   316
    stopImmediatePropagation: 2,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   317
    preventDefault: 2,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   318
    halt: 2
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   319
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   320
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   321
Y.EventFacade = function(e, currentTarget) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   322
    if (e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   323
        Y.Object.each(PROPS, function(v, k) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   324
            //this[k] = (v == 2) ? e[k].apply(e, arguments) : e[k];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   325
            var val = e[k];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   326
            if (val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   327
                this[k] = (v == 2) ? function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   328
                    if (val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   329
                        val.apply(e, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   330
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   331
                } : val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   332
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   333
                console.log('missing ' + k);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   334
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   335
        });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   336
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   337
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   338
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   339
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   340
Y.EventFacade = function(e, currentTarget) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   341
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   342
    e = e || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   343
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   344
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   345
     * The arguments passed to fire 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   346
     * @property details
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   347
     * @type Array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   348
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   349
    this.details = e.details;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   350
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   351
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   352
     * The event type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   353
     * @property type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   354
     * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   355
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   356
    this.type = e.type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   357
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   358
    //////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   359
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   360
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   361
     * Node reference for the targeted eventtarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   362
     * @propery target
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   363
     * @type Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   364
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   365
    this.target = e.target;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   366
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   367
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   368
     * Node reference for the element that the listener was attached to.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   369
     * @propery currentTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   370
     * @type Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   371
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   372
    this.currentTarget = currentTarget;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   373
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   374
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   375
     * Node reference to the relatedTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   376
     * @propery relatedTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   377
     * @type Node
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   378
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   379
    this.relatedTarget = e.relatedTarget;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   380
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   381
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   382
     * Stops the propagation to the next bubble target
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   383
     * @method stopPropagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   384
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   385
    this.stopPropagation = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   386
        e.stopPropagation();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   387
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   388
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   389
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   390
     * Stops the propagation to the next bubble target and
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   391
     * prevents any additional listeners from being exectued
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   392
     * on the current target.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   393
     * @method stopImmediatePropagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   394
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   395
    this.stopImmediatePropagation = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   396
        e.stopImmediatePropagation();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   397
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   398
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   399
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   400
     * Prevents the event's default behavior
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   401
     * @method preventDefault
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   402
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   403
    this.preventDefault = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   404
        e.preventDefault();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   405
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   406
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   407
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   408
     * Stops the event propagation and prevents the default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   409
     * event behavior.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   410
     * @method halt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   411
     * @param immediate {boolean} if true additional listeners
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   412
     * on the current target will not be executed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   413
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   414
    this.halt = function(immediate) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   415
        e.halt(immediate);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   416
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   417
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   418
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   419
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   420
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   421
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   422
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   423
 * Custom event engine, DOM event listener abstraction layer, synthetic DOM 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   424
 * events.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   425
 * @module event-custom
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   426
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   427
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   428
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   429
 * Return value from all subscribe operations
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   430
 * @class EventHandle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   431
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   432
 * @param evt {CustomEvent} the custom event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   433
 * @param sub {Subscriber} the subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   434
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   435
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   436
// var onsubscribeType = "_event:onsub",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   437
var AFTER = 'after', 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   438
    CONFIGS = [
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   439
        'broadcast',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   440
        'bubbles',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   441
        'context',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   442
        'contextFn',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   443
        'configured',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   444
        'currentTarget',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   445
        'defaultFn',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   446
        'details',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   447
        'emitFacade',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   448
        'fireOnce',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   449
        'host',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   450
        'preventable',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   451
        'preventedFn',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   452
        'queuable',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   453
        'silent',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   454
        'stoppedFn',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   455
        'target',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   456
        'type'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   457
    ],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   458
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   459
    FACADE = new Y.EventFacade(),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   460
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   461
    FACADE_KEYS = Y.Object.keys(FACADE),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   462
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   463
    YUI3_SIGNATURE = 9,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   464
    YUI_LOG = 'yui:log';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   465
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   466
Y.EventHandle = function(evt, sub) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   467
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   468
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   469
     * The custom event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   470
     * @type CustomEvent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   471
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   472
    this.evt = evt;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   473
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   474
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   475
     * The subscriber object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   476
     * @type Subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   477
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   478
    this.sub = sub;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   479
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   480
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   481
Y.EventHandle.prototype = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   482
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   483
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   484
     * Detaches this subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   485
     * @method detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   486
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   487
    detach: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   488
        if (this.evt) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   489
            // Y.log('EventHandle.detach: ' + this.sub, 'info', 'Event');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   490
            this.evt._delete(this.sub);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   491
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   492
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   493
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   494
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   495
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   496
 * The CustomEvent class lets you define events for your application
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   497
 * that can be subscribed to by one or more independent component.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   498
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   499
 * @param {String}  type The type of event, which is passed to the callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   500
 *                  when the event fires
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   501
 * @param o configuration object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   502
 * @class CustomEvent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   503
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   504
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   505
Y.CustomEvent = function(type, o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   506
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   507
    // if (arguments.length > 2) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   508
// this.log('CustomEvent context and silent are now in the config', 'warn', 'Event');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   509
    // }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   510
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   511
    o = o || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   512
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   513
    this.id = Y.stamp(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   514
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   515
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   516
     * The type of event, returned to subscribers when the event fires
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   517
     * @property type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   518
     * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   519
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   520
    this.type = type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   521
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   522
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   523
     * The context the the event will fire from by default.  Defaults to the YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   524
     * instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   525
     * @property context
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   526
     * @type object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   527
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   528
    this.context = Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   529
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   530
    this.logSystem = (type == YUI_LOG);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   531
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   532
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   533
     * If 0, this event does not broadcast.  If 1, the YUI instance is notified
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   534
     * every time this event fires.  If 2, the YUI instance and the YUI global
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   535
     * (if event is enabled on the global) are notified every time this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   536
     * fires.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   537
     * @property broadcast
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   538
     * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   539
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   540
    // this.broadcast = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   541
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   542
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   543
     * By default all custom events are logged in the debug build, set silent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   544
     * to true to disable debug outpu for this event.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   545
     * @property silent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   546
     * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   547
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   548
    this.silent = this.logSystem;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   549
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   550
    // this.queuable = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   551
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   552
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   553
     * The subscribers to this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   554
     * @property subscribers
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   555
     * @type Subscriber{}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   556
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   557
    this.subscribers = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   558
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   559
    /*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   560
     * The publisher has configured this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   561
     * @property configured
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   562
     * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   563
     * @default true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   564
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   565
    // this.configured = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   566
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   567
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   568
     * 'After' subscribers
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   569
     * @property afters
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   570
     * @type Subscriber{}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   571
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   572
    this.afters = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   573
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   574
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   575
     * This event has fired if true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   576
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   577
     * @property fired
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   578
     * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   579
     * @default false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   580
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   581
    // this.fired = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   582
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   583
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   584
     * This event should only fire one time if true, and if
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   585
     * it has fired, any new subscribers should be notified
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   586
     * immediately.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   587
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   588
     * @property fireOnce
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   589
     * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   590
     * @default false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   591
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   592
    // this.fireOnce = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   593
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   594
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   595
     * Flag for stopPropagation that is modified during fire()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   596
     * 1 means to stop propagation to bubble targets.  2 means
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   597
     * to also stop additional subscribers on this target.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   598
     * @property stopped
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   599
     * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   600
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   601
    // this.stopped = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   602
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   603
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   604
     * Flag for preventDefault that is modified during fire().
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   605
     * if it is not 0, the default behavior for this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   606
     * @property prevented
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   607
     * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   608
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   609
    // this.prevented = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   610
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   611
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   612
     * Specifies the host for this custom event.  This is used
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   613
     * to enable event bubbling
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   614
     * @property host
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   615
     * @type EventTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   616
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   617
    // this.host = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   618
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   619
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   620
     * The default function to execute after event listeners
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   621
     * have fire, but only if the default action was not
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   622
     * prevented.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   623
     * @property defaultFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   624
     * @type Function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   625
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   626
    // this.defaultFn = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   627
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   628
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   629
     * The function to execute if a subscriber calls
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   630
     * stopPropagation or stopImmediatePropagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   631
     * @property stoppedFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   632
     * @type Function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   633
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   634
    // this.stoppedFn = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   635
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   636
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   637
     * The function to execute if a subscriber calls
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   638
     * preventDefault
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   639
     * @property preventedFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   640
     * @type Function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   641
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   642
    // this.preventedFn = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   643
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   644
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   645
     * Specifies whether or not this event's default function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   646
     * can be cancelled by a subscriber by executing preventDefault() 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   647
     * on the event facade 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   648
     * @property preventable 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   649
     * @type boolean 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   650
     * @default true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   651
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   652
    this.preventable = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   653
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   654
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   655
     * Specifies whether or not a subscriber can stop the event propagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   656
     * via stopPropagation(), stopImmediatePropagation(), or halt()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   657
     * @property bubbles
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   658
     * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   659
     * @default true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   660
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   661
    this.bubbles = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   662
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   663
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   664
     * Supports multiple options for listener signatures in order to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   665
     * port YUI 2 apps.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   666
     * @property signature
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   667
     * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   668
     * @default 9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   669
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   670
    this.signature = YUI3_SIGNATURE;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   671
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   672
    // this.hasSubscribers = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   673
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   674
    // this.hasAfters = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   675
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   676
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   677
     * If set to true, the custom event will deliver an EventFacade object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   678
     * that is similar to a DOM event object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   679
     * @property emitFacade
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   680
     * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   681
     * @default false
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   682
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   683
    // this.emitFacade = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   684
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   685
    this.applyConfig(o, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   686
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   687
    // this.log("Creating " + this.type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   688
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   689
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   690
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   691
Y.CustomEvent.prototype = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   692
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   693
    _YUI_EVENT: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   694
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   695
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   696
     * Apply configuration properties.  Only applies the CONFIG whitelist
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   697
     * @method applyConfig
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   698
     * @param o hash of properties to apply
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   699
     * @param force {boolean} if true, properties that exist on the event 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   700
     * will be overwritten.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   701
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   702
    applyConfig: function(o, force) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   703
        if (o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   704
            Y.mix(this, o, force, CONFIGS);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   705
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   706
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   707
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   708
    _on: function(fn, context, args, when) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   709
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   710
        if (!fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   711
            Y.error("Invalid callback for CE: " + this.type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   712
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   713
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   714
        var s = new Y.Subscriber(fn, context, args, when);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   715
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   716
        if (this.fireOnce && this.fired) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   717
            Y.later(0, this, this._notify, s);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   718
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   719
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   720
        if (when == AFTER) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   721
            this.afters[s.id] = s;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   722
            this.hasAfters = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   723
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   724
            this.subscribers[s.id] = s;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   725
            this.hasSubscribers = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   726
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   727
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   728
        return new Y.EventHandle(this, s);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   729
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   730
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   731
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   732
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   733
     * Listen for this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   734
     * @method subscribe
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   735
     * @param {Function} fn        The function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   736
     * @return {EventHandle|EventTarget} unsubscribe handle or a
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   737
     * chainable event target depending on the 'chain' config.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   738
     * @deprecated use on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   739
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   740
    subscribe: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   741
        var a = (arguments.length > 2) ? Y.Array(arguments, 2, true): null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   742
        return this._on(fn, context, a, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   743
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   744
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   745
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   746
     * Listen for this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   747
     * @method on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   748
     * @param {Function} fn        The function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   749
     * @return {EventHandle|EventTarget} unsubscribe handle or a
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   750
     * chainable event target depending on the 'chain' config.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   751
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   752
    on: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   753
        var a = (arguments.length > 2) ? Y.Array(arguments, 2, true): null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   754
        return this._on(fn, context, a, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   755
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   756
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   757
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   758
     * Listen for this event after the normal subscribers have been notified and
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   759
     * the default behavior has been applied.  If a normal subscriber prevents the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   760
     * default behavior, it also prevents after listeners from firing.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   761
     * @method after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   762
     * @param {Function} fn        The function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   763
     * @return {EventHandle|EventTarget} unsubscribe handle or a
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   764
     * chainable event target depending on the 'chain' config.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   765
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   766
    after: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   767
        var a = (arguments.length > 2) ? Y.Array(arguments, 2, true): null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   768
        return this._on(fn, context, a, AFTER);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   769
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   770
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   771
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   772
     * Detach listeners.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   773
     * @method detach 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   774
     * @param {Function} fn  The subscribed function to remove, if not supplied
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   775
     *                       all will be removed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   776
     * @param {Object}   context The context object passed to subscribe.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   777
     * @return {boolean|EventTarget} returns a chainable event target
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   778
     * or a boolean for legacy detach support.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   779
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   780
    detach: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   781
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   782
        // if arg[0] typeof unsubscribe handle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   783
        if (fn && fn.detach) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   784
            return fn.detach();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   785
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   786
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   787
        if (!fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   788
            return this.unsubscribeAll();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   789
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   790
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   791
        var found = false, subs = this.subscribers, i, s;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   792
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   793
        for (i in subs) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   794
            if (subs.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   795
                s = subs[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   796
                if (s && s.contains(fn, context)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   797
                    this._delete(s);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   798
                    found = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   799
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   800
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   801
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   802
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   803
        return found;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   804
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   805
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   806
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   807
     * Detach listeners.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   808
     * @method unsubscribe
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   809
     * @param {Function} fn  The subscribed function to remove, if not supplied
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   810
     *                       all will be removed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   811
     * @param {Object}   context The context object passed to subscribe.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   812
     * @return {boolean|EventTarget} returns a chainable event target
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   813
     * or a boolean for legacy detach support.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   814
     * @deprecated use detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   815
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   816
    unsubscribe: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   817
        return this.detach.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   818
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   819
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   820
    _getFacade: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   821
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   822
        var ef = this._facade, o, args = this.details, o2;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   823
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   824
        if (!ef) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   825
            ef = new Y.EventFacade(this, this.currentTarget);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   826
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   827
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   828
        // if the first argument is an object literal, apply the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   829
        // properties to the event facade
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   830
        o = args && args[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   831
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   832
        if (Y.Lang.isObject(o, true)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   833
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   834
            o2 = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   835
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   836
            // protect the event facade properties
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   837
            Y.mix(o2, ef, true, FACADE_KEYS);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   838
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   839
            // mix the data
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   840
            Y.mix(ef, o, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   841
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   842
            // restore ef
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   843
            Y.mix(ef, o2, true, FACADE_KEYS);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   844
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   845
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   846
        // update the details field with the arguments
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   847
        // ef.type = this.type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   848
        ef.details = this.details;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   849
        ef.target = this.target;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   850
        ef.currentTarget = this.currentTarget;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   851
        ef.stopped = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   852
        ef.prevented = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   853
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   854
        this._facade = ef;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   855
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   856
        return this._facade;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   857
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   858
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   859
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   860
     * Notify a single subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   861
     * @method _notify
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   862
     * @param s {Subscriber} the subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   863
     * @param args {Array} the arguments array to apply to the listener
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   864
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   865
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   866
    _notify: function(s, args, ef) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   867
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   868
        this.log(this.type + "->" + ": " +  s);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   869
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   870
        var ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   871
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   872
        // emit an EventFacade if this is that sort of event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   873
        if (this.emitFacade) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   874
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   875
            // @TODO object literal support to fire makes it possible for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   876
            // config info to be passed if we wish.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   877
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   878
            if (!ef) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   879
                ef = this._getFacade(args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   880
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   881
                if (Y.Lang.isObject(args[0])) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   882
                    args[0] = ef;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   883
                } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   884
                    args.unshift(ef);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   885
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   886
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   887
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   888
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   889
        ret = s.notify(args, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   890
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   891
        if (false === ret || this.stopped > 1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   892
            this.log(this.type + " cancelled by subscriber");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   893
            return false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   894
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   895
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   896
        return true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   897
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   898
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   899
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   900
     * Logger abstraction to centralize the application of the silent flag
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   901
     * @method log
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   902
     * @param msg {string} message to log
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   903
     * @param cat {string} log category
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   904
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   905
    log: function(msg, cat) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   906
        if (!this.silent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   907
            Y.log(this.id + ': ' + msg, cat || "info", "event");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   908
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   909
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   910
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   911
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   912
     * Notifies the subscribers.  The callback functions will be executed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   913
     * from the context specified when the event was created, and with the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   914
     * following parameters:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   915
     *   <ul>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   916
     *   <li>The type of event</li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   917
     *   <li>All of the arguments fire() was executed with as an array</li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   918
     *   <li>The custom object (if any) that was passed into the subscribe() 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   919
     *       method</li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   920
     *   </ul>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   921
     * @method fire 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   922
     * @param {Object*} arguments an arbitrary set of parameters to pass to 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   923
     *                            the handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   924
     * @return {boolean} false if one of the subscribers returned false, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   925
     *                   true otherwise
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   926
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   927
    fire: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   928
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   929
        var es = Y.Env._eventstack,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   930
            subs, s, args, i, ef, q, queue, ce, hasSub,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   931
            ret = true, events;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   932
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   933
        // @TODO find a better way to short circuit this.  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   934
        // if (!this.broadcast && !this.defaultFn && !this.hasSubscribers && !this.hasAfters) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   935
        //     return true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   936
        // }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   937
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   938
        if (es) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   939
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   940
            // queue this event if the current item in the queue bubbles
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   941
            // if (b && this.queuable && this.type != es.next.type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   942
            if (this.queuable && this.type != es.next.type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   943
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   944
                this.log('queue ' + this.type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   945
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   946
                es.queue.push([this, arguments]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   947
                return true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   948
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   949
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   950
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   951
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   952
            Y.Env._eventstack = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   953
               // id of the first event in the stack
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   954
               id: this.id,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   955
               next: this,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   956
               silent: this.silent,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   957
               logging: (this.type === YUI_LOG),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   958
               stopped: 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   959
               prevented: 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   960
               queue: []
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   961
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   962
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   963
            es = Y.Env._eventstack;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   964
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   965
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   966
        if (this.fireOnce && this.fired) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   967
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   968
            this.log('fireOnce event: ' + this.type + ' already fired');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   969
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   970
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   971
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   972
            args = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   973
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   974
            this.stopped = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   975
            this.prevented = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   976
            this.target = this.target || this.host;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   977
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   978
            events = new Y.EventTarget({
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   979
                fireOnce: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   980
                context: this.host
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   981
            });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   982
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   983
            this.events = events;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   984
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   985
            if (this.preventedFn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   986
                events.on('prevented', this.preventedFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   987
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   988
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   989
            if (this.stoppedFn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   990
                events.on('stopped', this.stoppedFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   991
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   992
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   993
            this.currentTarget = this.host || this.currentTarget;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   994
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   995
            this.fired = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   996
            this.details = args.slice(); // original arguments in the details
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   997
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   998
            // this.log("Firing " + this  + ", " + "args: " + args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   999
            this.log("Firing " + this.type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1000
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1001
            hasSub = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1002
            es.lastLogState = es.logging;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1003
            ef = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1004
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1005
            if (this.emitFacade) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1006
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1007
                // this.fire({
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1008
                //   foo: 1
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1009
                //   bar: 2
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1010
                // }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1011
                // this.fire({
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1012
                //   bar: 2
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1013
                // } // foo is still 1 unless we create a new facade
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1014
                this._facade = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1015
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1016
                ef = this._getFacade(args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1017
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1018
                if (Y.Lang.isObject(args[0])) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1019
                    args[0] = ef;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1020
                } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1021
                    args.unshift(ef);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1022
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1023
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1024
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1025
            if (this.hasSubscribers) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1026
                subs = Y.merge(this.subscribers);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1027
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1028
                for (i in subs) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1029
                    if (subs.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1030
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1031
                        if (!hasSub) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1032
                            es.logging = (es.logging || (this.type === YUI_LOG));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1033
                            hasSub = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1034
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1035
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1036
                        // stopImmediatePropagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1037
                        if (this.stopped == 2) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1038
                            break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1039
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1040
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1041
                        s = subs[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1042
                        if (s && s.fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1043
                            ret = this._notify(s, args, ef);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1044
                            if (false === ret) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1045
                                this.stopped = 2;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1046
                            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1047
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1048
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1049
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1050
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1051
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1052
            es.logging = (es.lastLogState);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1053
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1054
            // bubble if this is hosted in an event target and propagation has not been stopped
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1055
            if (this.bubbles && this.host && !this.stopped) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1056
                es.stopped = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1057
                es.prevented = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1058
                ret = this.host.bubble(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1059
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1060
                this.stopped = Math.max(this.stopped, es.stopped);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1061
                this.prevented = Math.max(this.prevented, es.prevented);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1062
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1063
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1064
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1065
            // execute the default behavior if not prevented
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1066
            if (this.defaultFn && !this.prevented) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1067
                this.defaultFn.apply(this.host || this, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1068
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1069
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1070
            // broadcast listeners are fired as discreet events on the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1071
            // YUI instance and potentially the YUI global.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1072
            if (!this.stopped && this.broadcast) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1073
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1074
                if (this.host !== Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1075
                    Y.fire.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1076
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1077
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1078
                if (this.broadcast == 2) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1079
                    Y.Global.fire.apply(Y.Global, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1080
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1081
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1082
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1083
            // process after listeners.  If the default behavior was
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1084
            // prevented, the after events don't fire.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1085
            if (this.hasAfters && !this.prevented && this.stopped < 2) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1086
                subs = Y.merge(this.afters);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1087
                for (i in subs) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1088
                    if (subs.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1089
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1090
                        if (!hasSub) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1091
                            es.logging = (es.logging || (this.type === YUI_LOG));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1092
                            hasSub = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1093
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1094
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1095
                        // stopImmediatePropagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1096
                        if (this.stopped == 2) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1097
                            break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1098
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1099
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1100
                        s = subs[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1101
                        if (s && s.fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1102
                            ret = this._notify(s, args, ef);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1103
                            if (false === ret) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1104
                                this.stopped = 2;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1105
                            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1106
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1107
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1108
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1109
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1110
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1111
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1112
        if (es.id === this.id) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1113
// console.log('clearing stack: ' + es.id + ', ' + this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1114
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1115
// reset propragation properties while processing the rest of the queue
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1116
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1117
// process queued events
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1118
            queue = es.queue;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1119
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1120
            while (queue.length) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1121
                // q[0] = the event, q[1] = arguments to fire
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1122
                q = queue.pop(); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1123
                ce = q[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1124
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1125
// Y.log('firing queued event ' + ce.type + ', from ' + this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1126
                es.stopped = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1127
                es.prevented = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1128
                
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1129
// set up stack to allow the next item to be processed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1130
                es.next = ce;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1131
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1132
                ret = ce.fire.apply(ce, q[1]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1133
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1134
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1135
            Y.Env._eventstack = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1136
        } 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1137
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1138
        return (ret !== false);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1139
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1140
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1141
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1142
     * Removes all listeners
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1143
     * @method unsubscribeAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1144
     * @return {int} The number of listeners unsubscribed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1145
     * @deprecated use detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1146
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1147
    unsubscribeAll: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1148
        return this.detachAll.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1149
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1150
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1151
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1152
     * Removes all listeners
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1153
     * @method detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1154
     * @return {int} The number of listeners unsubscribed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1155
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1156
    detachAll: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1157
        var subs = this.subscribers, i, l=0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1158
        for (i in subs) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1159
            if (subs.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1160
                this._delete(subs[i]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1161
                l++;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1162
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1163
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1164
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1165
        this.subscribers={};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1166
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1167
        return l;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1168
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1169
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1170
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1171
     * @method _delete
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1172
     * @param subscriber object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1173
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1174
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1175
    _delete: function(s) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1176
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1177
        if (s) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1178
            delete s.fn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1179
            delete s.context;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1180
            delete this.subscribers[s.id];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1181
            delete this.afters[s.id];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1182
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1183
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1184
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1185
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1186
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1187
     * @method toString
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1188
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1189
    toString: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1190
         return this.type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1191
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1192
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1193
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1194
     * Stop propagation to bubble targets
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1195
     * @method stopPropagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1196
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1197
    stopPropagation: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1198
        this.stopped = 1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1199
        Y.Env._eventstack.stopped = 1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1200
        this.events.fire('stopped', this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1201
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1202
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1203
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1204
     * Stops propagation to bubble targets, and prevents any remaining
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1205
     * subscribers on the current target from executing.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1206
     * @method stopImmediatePropagation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1207
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1208
    stopImmediatePropagation: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1209
        this.stopped = 2;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1210
        Y.Env._eventstack.stopped = 2;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1211
        this.events.fire('stopped', this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1212
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1213
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1214
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1215
     * Prevents the execution of this event's defaultFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1216
     * @method preventDefault
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1217
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1218
    preventDefault: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1219
        if (this.preventable) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1220
            this.prevented = 1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1221
            Y.Env._eventstack.prevented = 1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1222
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1223
            this.events.fire('prevented', this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1224
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1225
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1226
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1227
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1228
     * Stops the event propagation and prevents the default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1229
     * event behavior.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1230
     * @method halt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1231
     * @param immediate {boolean} if true additional listeners
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1232
     * on the current target will not be executed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1233
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1234
    halt: function(immediate) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1235
        if (immediate) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1236
            this.stopImmediatePropagation();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1237
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1238
            this.stopPropagation();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1239
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1240
        this.preventDefault();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1241
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1242
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1243
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1244
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1245
/////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1246
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1247
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1248
 * Stores the subscriber information to be used when the event fires.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1249
 * @param {Function} fn       The wrapped function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1250
 * @param {Object}   context  The value of the keyword 'this' in the listener
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1251
 * @param {Array} args*       0..n additional arguments to supply the listener
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1252
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1253
 * @class Subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1254
 * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1255
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1256
Y.Subscriber = function(fn, context, args) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1257
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1258
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1259
     * The callback that will be execute when the event fires
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1260
     * This is wrapped by Y.rbind if obj was supplied.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1261
     * @property fn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1262
     * @type Function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1263
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1264
    this.fn = fn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1265
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1266
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1267
     * Optional 'this' keyword for the listener
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1268
     * @property context
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1269
     * @type Object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1270
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1271
    this.context = context;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1272
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1273
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1274
     * Unique subscriber id
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1275
     * @property id
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1276
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1277
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1278
    this.id = Y.stamp(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1279
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1280
    /*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1281
     * }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1282
     * fn bound to obj with additional arguments applied via Y.rbind
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1283
     * @property wrappedFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1284
     * @type Function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1285
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1286
    // this.wrappedFn = fn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1287
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1288
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1289
     * Additional arguments to propagate to the subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1290
     * @property args
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1291
     * @type Array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1292
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1293
    this.args = args;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1294
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1295
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1296
     * Custom events for a given fire transaction.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1297
     * @property events
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1298
     * @type {EventTarget}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1299
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1300
    this.events = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1301
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1302
    // if (context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1303
    //     this.wrappedFn = Y.rbind.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1304
    // }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1305
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1306
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1307
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1308
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1309
Y.Subscriber.prototype = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1310
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1311
    _notify: function(c, args, ce) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1312
        var a = this.args, ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1313
        switch (ce.signature) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1314
            case 0:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1315
                ret = this.fn.call(c, ce.type, args, c);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1316
                break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1317
            case 1:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1318
                ret = this.fn.call(c, args[0] || null, c);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1319
                break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1320
            default:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1321
                if (a || args) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1322
                    args = args || [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1323
                    a = (a) ? args.concat(a) : args;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1324
                    ret = this.fn.apply(c, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1325
                } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1326
                    ret = this.fn.call(c);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1327
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1328
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1329
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1330
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1331
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1332
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1333
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1334
     * Executes the subscriber.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1335
     * @method notify
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1336
     * @param args {Array} Arguments array for the subscriber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1337
     * @param ce {CustomEvent} The custom event that sent the notification
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1338
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1339
    notify: function(args, ce) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1340
        var c = this.context,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1341
            ret = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1342
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1343
        if (!c) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1344
            c = (ce.contextFn) ? ce.contextFn() : ce.context;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1345
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1346
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1347
        // Ease debugging by only catching errors if we will not re-throw
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1348
        // them.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1349
        if (Y.config.throwFail) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1350
            ret = this._notify(c, args, ce);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1351
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1352
            try {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1353
                ret = this._notify(c, args, ce);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1354
            } catch(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1355
                Y.error(this + ' failed: ' + e.message, e);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1356
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1357
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1358
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1359
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1360
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1361
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1362
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1363
     * Returns true if the fn and obj match this objects properties.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1364
     * Used by the unsubscribe method to match the right subscriber.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1365
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1366
     * @method contains
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1367
     * @param {Function} fn the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1368
     * @param {Object} context optional 'this' keyword for the listener
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1369
     * @return {boolean} true if the supplied arguments match this 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1370
     *                   subscriber's signature.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1371
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1372
    contains: function(fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1373
        if (context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1374
            return ((this.fn == fn) && this.context == context);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1375
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1376
            return (this.fn == fn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1377
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1378
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1379
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1380
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1381
     * @method toString
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1382
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1383
    toString: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1384
        return "Subscriber " + this.id;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1385
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1386
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1387
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1388
// FACADE = new Y.EventFacade(new Y.CustomEvent('x'));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1389
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1390
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1391
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1392
 * EventTarget provides the implementation for any object to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1393
 * publish, subscribe and fire to custom events, and also
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1394
 * alows other EventTargets to target the object with events
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1395
 * sourced from the other object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1396
 * EventTarget is designed to be used with Y.augment to wrap 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1397
 * EventCustom in an interface that allows events to be listened to 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1398
 * and fired by name.  This makes it possible for implementing code to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1399
 * subscribe to an event that either has not been created yet, or will
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1400
 * not be created at all.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1401
 * @class EventTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1402
 * @param opts a configuration object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1403
 * @config emitFacade {boolean} if true, all events will emit event 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1404
 * facade payloads by default (default false)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1405
 * @config prefix {string} the prefix to apply to non-prefixed event names 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1406
 * @config chain {boolean} if true, on/after/detach return the host to allow 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1407
 * chaining, otherwise they return an EventHandle (default false)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1408
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1409
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1410
var L = Y.Lang,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1411
    PREFIX_DELIMITER = ':',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1412
    CATEGORY_DELIMITER = '|',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1413
    AFTER_PREFIX = '~AFTER~',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1414
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1415
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1416
     * If the instance has a prefix attribute and the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1417
     * event type is not prefixed, the instance prefix is
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1418
     * applied to the supplied type.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1419
     * @method _getType
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1420
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1421
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1422
    _getType = Y.cached(function(type, pre) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1423
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1424
        if (!pre || !L.isString(type) || type.indexOf(PREFIX_DELIMITER) > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1425
            return type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1426
        } 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1427
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1428
        return pre + PREFIX_DELIMITER + type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1429
    }),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1430
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1431
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1432
     * Returns an array with the detach key (if provided),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1433
     * and the prefixed event name from _getType
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1434
     * Y.on('detachcategory, menu:click', fn)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1435
     * @method _parseType
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1436
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1437
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1438
    _parseType = Y.cached(function(type, pre) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1439
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1440
        var t = type, detachcategory, after, i, full_t;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1441
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1442
        if (!L.isString(t)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1443
            return t;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1444
        } 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1445
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1446
        i = t.indexOf(AFTER_PREFIX);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1447
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1448
        if (i > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1449
            after = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1450
            t = t.substr(AFTER_PREFIX.length);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1451
            // Y.log(t);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1452
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1453
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1454
        // parts = t.split(DETACH_PREFIX_SPLITTER);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1455
        // if (parts.length > 1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1456
        //     detachcategory = parts[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1457
        //     t = parts[1];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1458
        //     if (t == '*') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1459
        //          t = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1460
        //     }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1461
        // }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1462
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1463
        i = t.indexOf(CATEGORY_DELIMITER);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1464
        if (i > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1465
            detachcategory = t.substr(0, (i));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1466
            t = t.substr(i+1);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1467
            if (t == '*') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1468
                t = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1469
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1470
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1471
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1472
        full_t = _getType(t, pre);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1473
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1474
        return [detachcategory, full_t, after, t];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1475
    }),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1476
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1477
    ET = function(opts) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1478
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1479
        // console.log('EventTarget constructor executed: ' + this._yuid);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1480
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1481
        var o = (L.isObject(opts)) ? opts : {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1482
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1483
        this._yuievt = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1484
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1485
            id: Y.guid(),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1486
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1487
            events: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1488
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1489
            targets: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1490
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1491
            config: o,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1492
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1493
            chain: ('chain' in o) ? o.chain : Y.config.chain,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1494
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1495
            defaults: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1496
                context: o.context || this, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1497
                host: this,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1498
                emitFacade: o.emitFacade,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1499
                fireOnce: o.fireOnce,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1500
                queuable: o.queuable,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1501
                broadcast: o.broadcast,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1502
                bubbles: ('bubbles' in o) ? o.bubbles : true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1503
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1504
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1505
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1506
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1507
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1508
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1509
ET.prototype = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1510
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1511
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1512
     * Subscribe to a custom event hosted by this object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1513
     * @method on 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1514
     * @param type    {string}   The type of the event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1515
     * @param fn {Function} The callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1516
     * @return the event target or a detach handle per 'chain' config
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1517
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1518
    on: function(type, fn, context, x) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1519
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1520
        var parts = _parseType(type, this._yuievt.config.prefix), f, c, args, ret, ce,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1521
            detachcategory, handle, store = Y.Env.evt.handles, after, adapt, shorttype,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1522
            Node = Y.Node, n;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1523
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1524
        if (L.isObject(type, true)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1525
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1526
            f = fn; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1527
            c = context; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1528
            args = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1529
            ret = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1530
            after = type._after;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1531
            delete type._after;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1532
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1533
            Y.each(type, function(v, k) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1534
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1535
                if (v) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1536
                    f = v.fn || ((Y.Lang.isFunction(v)) ? v : f);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1537
                    c = v.context || c;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1538
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1539
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1540
                args[0] = (after) ? AFTER_PREFIX + k : k;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1541
                args[1] = f;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1542
                args[2] = c;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1543
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1544
                ret[k] = this.on.apply(this, args); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1545
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1546
            }, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1547
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1548
            return (this._yuievt.chain) ? this : ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1549
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1550
        } else if (L.isFunction(type)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1551
            return Y.Do.before.apply(Y.Do, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1552
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1553
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1554
        detachcategory = parts[0];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1555
        after = parts[2];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1556
        shorttype = parts[3];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1557
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1558
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1559
        // extra redirection so we catch adaptor events too.  take a look at this.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1560
        if (Node && (this instanceof Node) && (shorttype in Node.DOM_EVENTS)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1561
            args = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1562
            args.splice(2, 0, Node.getDOMNode(this));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1563
            return Y.on.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1564
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1565
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1566
        type = parts[1];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1567
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1568
        if (this instanceof YUI) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1569
            adapt = Y.Env.evt.plugins[type];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1570
            args  = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1571
            args[0] = shorttype;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1572
            // check for the existance of an event adaptor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1573
            if (adapt && adapt.on) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1574
                n = args[2];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1575
                Y.log('Using adaptor for ' + shorttype + ', ' + n, 'info', 'event');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1576
                if (Node && n && (n instanceof Node)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1577
                    args[2] = Node.getDOMNode(n);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1578
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1579
                handle = adapt.on.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1580
            // check to see if the target is an EventTarget.  If so,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1581
            // delegate to it (the EventTarget should handle whether
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1582
            // or not the prefix was included);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1583
            // } else if (o && !(o instanceof YUI) && o.getEvent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1584
            //     a = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1585
            //     a.splice(2, 1);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1586
            //     return o.on.apply(o, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1587
            // } else if ((!type) || (!adapt && type.indexOf(':') == -1)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1588
            } else if ((!type) || (!adapt && Node && (shorttype in Node.DOM_EVENTS))) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1589
                handle = Y.Event._attach(args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1590
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1591
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1592
        } 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1593
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1594
        if (!handle) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1595
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1596
            // Y.log('parts: ' + parts);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1597
            ce     = this._yuievt.events[type] || this.publish(type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1598
            // args   = Y.Array(arguments, 1, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1599
            // f = (after) ? ce.after : ce.on;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1600
            // handle = f.apply(ce, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1601
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1602
            handle = ce._on(fn, context, (arguments.length > 3) ? Y.Array(arguments, 3, true) : null, (after) ? 'after' : true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1603
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1604
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1605
        if (detachcategory) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1606
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1607
            store[detachcategory] = store[detachcategory] || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1608
            store[detachcategory][type] = store[detachcategory][type] || [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1609
            store[detachcategory][type].push(handle);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1610
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1611
            // Y.log('storing: ' + key);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1612
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1613
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1614
        return (this._yuievt.chain) ? this : handle;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1615
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1616
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1617
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1618
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1619
     * subscribe to an event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1620
     * @method subscribe
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1621
     * @deprecated use on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1622
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1623
    subscribe: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1624
        return this.on.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1625
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1626
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1627
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1628
     * Detach one or more listeners the from the specified event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1629
     * @method detach 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1630
     * @param type {string|Object}   Either the handle to the subscriber or the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1631
     *                        type of event.  If the type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1632
     *                        is not specified, it will attempt to remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1633
     *                        the listener from all hosted events.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1634
     * @param fn   {Function} The subscribed function to unsubscribe, if not
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1635
     *                          supplied, all subscribers will be removed.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1636
     * @param context  {Object}   The custom object passed to subscribe.  This is
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1637
     *                        optional, but if supplied will be used to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1638
     *                        disambiguate multiple listeners that are the same
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1639
     *                        (e.g., you subscribe many object using a function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1640
     *                        that lives on the prototype)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1641
     * @return {EventTarget} the host
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1642
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1643
    detach: function(type, fn, context) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1644
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1645
        var parts = _parseType(type, this._yuievt.config.prefix), 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1646
        detachcategory = L.isArray(parts) ? parts[0] : null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1647
        shorttype = (parts) ? parts[3] : null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1648
        handle, adapt, store = Y.Env.evt.handles, cat, args,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1649
        evts = this._yuievt.events, ce, i, ret = true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1650
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1651
        keyDetacher = function(lcat, ltype) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1652
            var handles = lcat[ltype];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1653
            if (handles) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1654
                while (handles.length) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1655
                    handle = handles.pop();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1656
                    handle.detach();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1657
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1658
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1659
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1660
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1661
        if (detachcategory) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1662
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1663
            cat = store[detachcategory];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1664
            type = parts[1];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1665
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1666
            if (cat) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1667
                if (type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1668
                    keyDetacher(cat, type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1669
                } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1670
                    for (i in cat) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1671
                        if (cat.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1672
                            keyDetacher(cat, i);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1673
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1674
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1675
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1676
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1677
                return (this._yuievt.chain) ? this : true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1678
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1679
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1680
        // If this is an event handle, use it to detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1681
        } else if (L.isObject(type) && type.detach) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1682
            ret = type.detach();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1683
            return (this._yuievt.chain) ? this : true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1684
        // extra redirection so we catch adaptor events too.  take a look at this.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1685
        } else if (Y.Node && (this instanceof Y.Node) && ((!shorttype) || (shorttype in Y.Node.DOM_EVENTS))) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1686
            args = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1687
            args[2] = Y.Node.getDOMNode(this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1688
            return Y.detach.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1689
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1690
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1691
        adapt = Y.Env.evt.plugins[shorttype];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1692
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1693
        // The YUI instance handles DOM events and adaptors
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1694
        if (this instanceof YUI) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1695
            args = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1696
            // use the adaptor specific detach code if
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1697
            if (adapt && adapt.detach) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1698
                return adapt.detach.apply(Y, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1699
            // DOM event fork
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1700
            } else if (!type || (!adapt && type.indexOf(':') == -1)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1701
                args[0] = type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1702
                return Y.Event.detach.apply(Y.Event, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1703
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1704
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1705
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1706
        if (type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1707
            ce = evts[type];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1708
            if (ce) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1709
                return ce.detach(fn, context);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1710
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1711
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1712
            for (i in evts) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1713
                if (evts.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1714
                    ret = ret && evts[i].detach(fn, context);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1715
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1716
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1717
            return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1718
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1719
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1720
        return (this._yuievt.chain) ? this : false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1721
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1722
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1723
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1724
     * detach a listener
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1725
     * @method unsubscribe
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1726
     * @deprecated use detach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1727
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1728
    unsubscribe: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1729
        return this.detach.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1730
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1731
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1732
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1733
     * Removes all listeners from the specified event.  If the event type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1734
     * is not specified, all listeners from all hosted custom events will
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1735
     * be removed.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1736
     * @method detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1737
     * @param type {string}   The type, or name of the event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1738
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1739
    detachAll: function(type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1740
        type = _getType(type, this._yuievt.config.prefix);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1741
        return this.detach(type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1742
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1743
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1744
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1745
     * Removes all listeners from the specified event.  If the event type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1746
     * is not specified, all listeners from all hosted custom events will
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1747
     * be removed.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1748
     * @method unsubscribeAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1749
     * @param type {string}   The type, or name of the event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1750
     * @deprecated use detachAll
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1751
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1752
    unsubscribeAll: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1753
        return this.detachAll.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1754
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1755
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1756
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1757
     * Creates a new custom event of the specified type.  If a custom event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1758
     * by that name already exists, it will not be re-created.  In either
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1759
     * case the custom event is returned. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1760
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1761
     * @method publish
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1762
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1763
     * @param type {string} the type, or name of the event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1764
     * @param opts {object} optional config params.  Valid properties are:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1765
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1766
     *  <ul>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1767
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1768
     *   'broadcast': whether or not the YUI instance and YUI global are notified when the event is fired (false)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1769
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1770
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1771
     *   'bubbles': whether or not this event bubbles (true)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1772
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1773
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1774
     *   'context': the default execution context for the listeners (this)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1775
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1776
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1777
     *   'defaultFn': the default function to execute when this event fires if preventDefault was not called
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1778
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1779
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1780
     *   'emitFacade': whether or not this event emits a facade (false)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1781
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1782
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1783
     *   'prefix': the prefix for this targets events, e.g., 'menu' in 'menu:click' 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1784
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1785
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1786
     *   'fireOnce': if an event is configured to fire once, new subscribers after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1787
     *   the fire will be notified immediately.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1788
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1789
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1790
     *   'preventable': whether or not preventDefault() has an effect (true)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1791
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1792
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1793
     *   'preventedFn': a function that is executed when preventDefault is called
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1794
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1795
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1796
     *   'queuable': whether or not this event can be queued during bubbling (false)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1797
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1798
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1799
     *   'silent': if silent is true, debug messages are not provided for this event.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1800
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1801
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1802
     *   'stoppedFn': a function that is executed when stopPropagation is called
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1803
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1804
     *    <li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1805
     *   'type': the event type (valid option if not provided as the first parameter to publish)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1806
     *    </li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1807
     *  </ul>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1808
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1809
     *  @return {Event.Custom} the custom event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1810
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1811
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1812
    publish: function(type, opts) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1813
        // this._yuievt.config.prefix
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1814
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1815
        type = _getType(type, this._yuievt.config.prefix);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1816
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1817
        var events, ce, ret, o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1818
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1819
        if (L.isObject(type)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1820
            ret = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1821
            Y.each(type, function(v, k) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1822
                ret[k] = this.publish(k, v || opts); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1823
            }, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1824
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1825
            return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1826
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1827
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1828
        events = this._yuievt.events; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1829
        ce = events[type];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1830
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1831
        //if (ce && !ce.configured) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1832
        if (ce) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1833
// ce.log("publish applying new config to published event: '"+type+"' exists", 'info', 'event');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1834
            if (opts) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1835
                ce.applyConfig(opts, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1836
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1837
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1838
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1839
            o = (opts) ?  Y.mix(opts, this._yuievt.defaults) : this._yuievt.defaults;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1840
            // apply defaults
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1841
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1842
            ce = new Y.CustomEvent(type, o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1843
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1844
            events[type] = ce;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1845
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1846
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1847
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1848
        // make sure we turn the broadcast flag off if this
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1849
        // event was published as a result of bubbling
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1850
        if (opts instanceof Y.CustomEvent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1851
            events[type].broadcast = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1852
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1853
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1854
        return events[type];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1855
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1856
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1857
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1858
     * Registers another EventTarget as a bubble target.  Bubble order
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1859
     * is determined by the order registered.  Multiple targets can
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1860
     * be specified.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1861
     * @method addTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1862
     * @param o {EventTarget} the target to add
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1863
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1864
    addTarget: function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1865
        this._yuievt.targets[Y.stamp(o)] = o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1866
        this._yuievt.hasTargets = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1867
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1868
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1869
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1870
     * Removes a bubble target
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1871
     * @method removeTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1872
     * @param o {EventTarget} the target to remove
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1873
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1874
    removeTarget: function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1875
        delete this._yuievt.targets[Y.stamp(o)];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1876
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1877
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1878
   /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1879
     * Fire a custom event by name.  The callback functions will be executed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1880
     * from the context specified when the event was created, and with the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1881
     * following parameters.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1882
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1883
     * If the custom event object hasn't been created, then the event hasn't 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1884
     * been published and it has no subscribers.  For performance sake, we 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1885
     * immediate exit in this case.  This means the event won't bubble, so 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1886
     * if the intention is that a bubble target be notified, the event must 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1887
     * be published on this object first.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1888
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1889
     * @method fire
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1890
     * @param type {String|Object} The type of the event, or an object that contains
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1891
     * a 'type' property.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1892
     * @param arguments {Object*} an arbitrary set of parameters to pass to 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1893
     * the handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1894
     * @return {boolean} the return value from Event.Custom.fire
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1895
     *                   
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1896
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1897
    fire: function(type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1898
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1899
        var typeIncluded = L.isString(type),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1900
            t = (typeIncluded) ? type : (type && type.type),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1901
            ce, a, ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1902
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1903
        t = _getType(t, this._yuievt.config.prefix);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1904
        ce = this.getEvent(t);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1905
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1906
        // this event has not been published or subscribed to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1907
        if (!ce) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1908
            
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1909
            // if this object has bubble targets, we need to publish the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1910
            // event in order for it to bubble.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1911
            if (this._yuievt.hasTargets) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1912
                // ce = this.publish(t);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1913
                // ce.details = Y.Array(arguments, (typeIncluded) ? 1 : 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1914
                
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1915
                a = (typeIncluded) ? arguments : Y.Array(arguments, 0, true).unshift(t);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1916
                return this.bubble(null, a, this);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1917
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1918
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1919
            // otherwise there is nothing to be done
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1920
            ret = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1921
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1922
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1923
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1924
            a = Y.Array(arguments, (typeIncluded) ? 1 : 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1925
            ret = ce.fire.apply(ce, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1926
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1927
            // clear target for next fire()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1928
            ce.target = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1929
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1930
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1931
        return (this._yuievt.chain) ? this : ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1932
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1933
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1934
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1935
     * Returns the custom event of the provided type has been created, a
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1936
     * falsy value otherwise
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1937
     * @method getEvent
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1938
     * @param type {string} the type, or name of the event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1939
     * @return {Event.Custom} the custom event or null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1940
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1941
    getEvent: function(type) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1942
        type = _getType(type, this._yuievt.config.prefix);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1943
        var e = this._yuievt.events;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1944
        return (e && type in e) ? e[type] : null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1945
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1946
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1947
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1948
     * Propagate an event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1949
     * @method bubble
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1950
     * @param evt {Event.Custom} the custom event to propagate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1951
     * @return {boolean} the aggregated return value from Event.Custom.fire
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1952
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1953
    bubble: function(evt, args, target) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1954
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1955
        var targs = this._yuievt.targets, ret = true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1956
            t, type, ce, i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1957
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1958
        if (!evt || ((!evt.stopped) && targs)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1959
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1960
            // Y.log('Bubbling ' + evt.type);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1961
            for (i in targs) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1962
                if (targs.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1963
                    t = targs[i]; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1964
                    type = evt && evt.type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1965
                    ce = t.getEvent(type); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1966
                        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1967
                    // if this event was not published on the bubble target,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1968
                    // publish it with sensible default properties
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1969
                    if (!ce) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1970
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1971
                        // publish the event on the bubble target using this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1972
                        // for its configuration
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1973
                        // ce = t.publish(type, evt);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1974
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1975
                        // set the host and context appropriately
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1976
                        // ce.context = (evt.host === evt.context) ? t : evt.context;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1977
                        // ce.host = t;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1978
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1979
                        // clear handlers if specified on this event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1980
                        // ce.defaultFn = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1981
                        // ce.preventedFn = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1982
                        // ce.stoppedFn = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1983
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1984
                        if (t._yuievt.hasTargets) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1985
                            t.bubble.call(t, evt, args, target);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1986
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1987
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1988
                    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1989
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1990
                        ce.target = target || (evt && evt.target) || this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1991
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1992
                        ce.currentTarget = t;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1993
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1994
                        ret = ret && ce.fire.apply(ce, args || evt.details);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1995
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1996
                        // stopPropagation() was called
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1997
                        if (ce.stopped) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1998
                            break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1999
                        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2000
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2001
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2002
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2003
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2004
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2005
        return ret;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2006
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2007
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2008
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2009
     * Subscribe to a custom event hosted by this object.  The
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2010
     * supplied callback will execute after any listeners add
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2011
     * via the subscribe method, and after the default function,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2012
     * if configured for the event, has executed.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2013
     * @method after
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2014
     * @param type    {string}   The type of the event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2015
     * @param fn {Function} The callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2016
     * @return the event target or a detach handle per 'chain' config
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2017
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2018
    after: function(type, fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2019
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2020
        var a = Y.Array(arguments, 0, true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2021
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2022
        switch (L.type(type)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2023
            case 'function':
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2024
                return Y.Do.after.apply(Y.Do, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2025
            case 'object':
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2026
                a[0]._after = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2027
                break;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2028
            default:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2029
                a[0] = AFTER_PREFIX + type;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2030
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2031
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2032
        return this.on.apply(this, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2033
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2034
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2035
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2036
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2037
     * Executes the callback before a DOM event, custom event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2038
     * or method.  If the first argument is a function, it
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2039
     * is assumed the target is a method.  For DOM and custom
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2040
     * events, this is an alias for Y.on.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2041
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2042
     * For DOM and custom events:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2043
     * type, callback, context, 1-n arguments
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2044
     *  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2045
     * For methods:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2046
     * callback, object (method host), methodName, context, 1-n arguments
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2047
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2048
     * @method before
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2049
     * @return detach handle
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2050
     * @deprecated use the on method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2051
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2052
    before: function() { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2053
        return this.on.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2054
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2055
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2056
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2057
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2058
Y.EventTarget = ET;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2059
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2060
// make Y an event target
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2061
Y.mix(Y, ET.prototype, false, false, { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2062
    bubbles: false 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2063
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2064
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2065
ET.call(Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2066
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2067
YUI.Env.globalEvents = YUI.Env.globalEvents || new ET();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2068
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2069
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2070
 * Hosts YUI page level events.  This is where events bubble to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2071
 * when the broadcast config is set to 2.  This property is
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2072
 * only available if the custom event module is loaded.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2073
 * @property Global
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2074
 * @type EventTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2075
 * @for YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2076
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2077
Y.Global = YUI.Env.globalEvents;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2078
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2079
// @TODO implement a global namespace function on Y.Global?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2080
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2081
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2082
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2083
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2084
}, '3.0.0b1' ,{requires:['oop']});