src/cm/media/js/lib/yui/yui_3.0.0b1/build/yui-base/yui-base-debug.js
author raph
Mon, 23 Nov 2009 15:14:29 +0100
changeset 0 40c8f766c9b8
permissions -rw-r--r--
import from internal svn r 4007
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
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    10
    var _instances = {}, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    11
        _startTime = new Date().getTime(), 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    12
        p, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    13
        i,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    14
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    15
        add = function () {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    16
            if (window.addEventListener) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    17
                return function(el, type, fn, capture) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    18
                    el.addEventListener(type, fn, (!!capture));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    19
                };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    20
            } else if (window.attachEvent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    21
                return function(el, type, fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    22
                    el.attachEvent("on" + type, fn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    23
                };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    24
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    25
                return function(){};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    26
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    27
        }(),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    28
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    29
        remove = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    30
            if (window.removeEventListener) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
                return function (el, type, fn, capture) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
                    el.removeEventListener(type, fn, !!capture);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
                };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
            } else if (window.detachEvent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
                return function (el, type, fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
                    el.detachEvent("on" + type, fn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
                };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
                return function(){};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
        }(),
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
        globalListener = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
            YUI.Env.windowLoaded = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
            YUI.Env.DOMReady = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
            remove(window, 'load', globalListener);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
        },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
// @TODO: this needs to be created at build time from module metadata
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
        _APPLY_TO_WHITE_LIST = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
            'io.xdrReady': 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
            'io.start': 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
            'io.success': 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
            'io.failure': 1
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
        SLICE = Array.prototype.slice;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
// reduce to one or the other
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
if (typeof YUI === 'undefined' || !YUI) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
     * The YUI global namespace object.  If YUI is already defined, the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
     * existing YUI object will not be overwritten so that defined
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
     * namespaces are preserved.  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
     * @class YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
     * @constructor
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
     * @global
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
     * @uses EventTarget
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    72
     * @param o Optional configuration object.  This object is stored
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    73
     * in YUI.config.  See config for the list of supported properties.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    74
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
    /*global YUI*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
    // Make a function, disallow direct instantiation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
    YUI = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
        var Y = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
        // Allow instantiation without the new operator
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
        if (!(Y instanceof YUI)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
            return new YUI(o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
            // set up the core environment
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
            Y._init(o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
            // bind the specified additional modules for this instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
            Y._setup();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
            return Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
// The prototype contains the functions that are required to allow the external
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
// modules to be registered and for the instance to be initialized.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
YUI.prototype = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
     * Initialize this YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
     * @param o config options
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
    _init: function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
        o = o || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
        // find targeted window/frame
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
        // @TODO create facades
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
        var v = '3.0.0b1', Y = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
        o.win = o.win || window || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
        o.win = o.win.contentWindow || o.win;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
        o.doc = o.win.document;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
        o.debug = ('debug' in o) ? o.debug : true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
        o.useBrowserConsole = ('useBrowserConsole' in o) ? o.useBrowserConsole : true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   118
        o.throwFail = ('throwFail' in o) ? o.throwFail : true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   119
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   120
        // add a reference to o for anything that needs it
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   121
        // before _setup is called.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   122
        Y.config = o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   123
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   124
        Y.Env = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   125
            // @todo expand the new module metadata
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   126
            mods: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   127
            _idx: 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   128
            _used: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   129
            _attached: {},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   130
            _yidx: 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   131
            _uidx: 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   132
            _loaded: {}
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   136
        if (v.indexOf('@') > -1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   137
            v = 'test';
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
        Y.version = v;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   141
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   142
        Y.Env._loaded[v] = {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   143
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   144
        if (YUI.Env) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   145
            Y.Env._yidx = (++YUI.Env._yidx);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   146
            Y.Env._guidp = ('yui_' + this.version + '-' + Y.Env._yidx + '-' + _startTime).replace(/\./g, '_');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   147
            Y.id = Y.stamp(Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   148
            _instances[Y.id] = Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   149
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   150
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   151
        Y.constructor = YUI;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   152
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   153
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   154
        // this.log(this.id + ') init ');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   155
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   156
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   157
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   158
     * Finishes the instance setup. Attaches whatever modules were defined
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   159
     * when the yui modules was registered.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   160
     * @method _setup
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   161
     * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   162
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   163
    _setup: function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   164
        this.use("yui-base");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   165
        // @TODO eval the need to copy the config
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   166
        this.config = this.merge(this.config);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   167
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   168
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   169
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   170
     * Executes a method on a YUI instance with
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   171
     * the specified id if the specified method is whitelisted.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   172
     * @method applyTo
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   173
     * @param id {string} the YUI instance id
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   174
     * @param method {string} the name of the method to exectute.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   175
     * Ex: 'Object.keys'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   176
     * @param args {Array} the arguments to apply to the method
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   177
     * @return {object} the return value from the applied method or null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   178
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   179
    applyTo: function(id, method, args) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   180
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   181
        if (!(method in _APPLY_TO_WHITE_LIST)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   182
            this.error(method + ': applyTo not allowed');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   183
            return null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   184
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   185
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   186
        var instance = _instances[id], nest, m, i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   187
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   188
        if (instance) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   189
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   190
            nest = method.split('.'); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   191
            m = instance;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   192
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   193
            for (i=0; i<nest.length; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   194
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   195
                m = m[nest[i]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   196
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   197
                if (!m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   198
                    this.error('applyTo not found: ' + method);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   199
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   200
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   201
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   202
            return m.apply(instance, args);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   203
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   204
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   205
        return null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   206
    }, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   207
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   208
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   209
     * Register a module
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   210
     * @method add
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   211
     * @param name {string} module name
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   212
     * @param fn {Function} entry point into the module that
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   213
     * is used to bind module to the YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   214
     * @param version {string} version string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   215
     * @param details optional config data: 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   216
     * requires   - features that should be present before loading
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   217
     * optional   - optional features that should be present if load optional defined
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   218
     * use  - features that should be attached automatically
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   219
     * skinnable  -
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   220
     * rollup
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   221
     * omit - features that should not be loaded if this module is present
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   222
     * @return {YUI} the YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   223
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   224
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   225
    add: function(name, fn, version, details) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   226
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   227
        // this.log('Adding a new component ' + name);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   228
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   229
        // @todo expand this to include version mapping
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   230
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   231
        // @todo allow requires/supersedes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   232
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   233
        // @todo may want to restore the build property
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   234
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   235
        // @todo fire moduleAvailable event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   236
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   237
        var m = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   238
            name: name, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   239
            fn: fn,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   240
            version: version,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   241
            details: details || {}
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
        YUI.Env.mods[name] = m;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   245
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   246
        return this; // chain support
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   247
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   248
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   249
    _attach: function(r, fromLoader) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   250
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   251
        var mods = YUI.Env.mods,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   252
            attached = this.Env._attached,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   253
            i, l = r.length, name, m, d, req, use;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   254
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   255
        for (i=0; i<l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   256
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   257
            name = r[i]; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   258
            m    = mods[name];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   259
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   260
            if (!attached[name] && m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   261
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   262
                attached[name] = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   263
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   264
                d   = m.details; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   265
                req = d.requires; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   266
                use = d.use;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   267
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   268
                if (req) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   269
                    this._attach(this.Array(req));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   270
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   271
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   272
                // this.log('attaching ' + name, 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   273
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   274
                if (m.fn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   275
                    m.fn(this);
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
                if (use) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   279
                    this._attach(this.Array(use));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   280
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   281
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   282
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   283
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   284
    },
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
     * Bind a module to a YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   288
     * @param modules* {string} 1-n modules to bind (uses arguments array)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   289
     * @param *callback {function} callback function executed when 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   290
     * the instance has the required functionality.  If included, it
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   291
     * must be the last parameter.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   292
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   293
     * @TODO 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   294
     * Implement versioning?  loader can load different versions?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   295
     * Should sub-modules/plugins be normal modules, or do
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   296
     * we add syntax for specifying these?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   297
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   298
     * YUI().use('dragdrop')
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   299
     * YUI().use('dragdrop:2.4.0'); // specific version
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   300
     * YUI().use('dragdrop:2.4.0-'); // at least this version
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   301
     * YUI().use('dragdrop:2.4.0-2.9999.9999'); // version range
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   302
     * YUI().use('*'); // use all available modules
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   303
     * YUI().use('lang+dump+substitute'); // use lang and some plugins
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   304
     * YUI().use('lang+*'); // use lang and all known plugins
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   305
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   306
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   307
     * @return {YUI} the YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   308
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   309
    use: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   310
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   311
        if (this._loading) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   312
            this._useQueue.add(SLICE.call(arguments, 0));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   313
            return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   314
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   315
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   316
        var Y = this, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   317
            a=SLICE.call(arguments, 0), 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   318
            mods = YUI.Env.mods, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   319
            used = Y.Env._used,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   320
            loader, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   321
            firstArg = a[0], 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   322
            dynamic = false,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   323
            callback = a[a.length-1],
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   324
            k, i, l, missing = [], 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   325
            r = [], 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   326
            f = function(name) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   327
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   328
                // only attach a module once
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   329
                if (used[name]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   330
                    // Y.log(name + ' already used', 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   331
                    return;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   332
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   333
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   334
                var m = mods[name], j, req, use;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   335
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   336
                if (m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   337
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   338
                    // Y.log('USING ' + name, 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   339
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   340
                    used[name] = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   341
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   342
                    req = m.details.requires;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   343
                    use = m.details.use;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   344
                } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   345
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   346
                    // CSS files don't register themselves, see if it has been loaded
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   347
                    if (!YUI.Env._loaded[Y.version][name]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   348
                        Y.log('module not found: ' + name, 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   349
                        missing.push(name);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   350
                    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   351
                        // probably css
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   352
                        // Y.log('module not found BUT HAS BEEN LOADED: ' + name, 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   353
                        used[name] = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   354
                    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   355
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   356
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   357
                // make sure requirements are attached
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   358
                if (req) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   359
                    if (Y.Lang.isString(req)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   360
                        f(req);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   361
                    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   362
                        for (j = 0; j < req.length; j = j + 1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   363
                            // Y.log('using module\'s requirements: ' + name, 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   364
                            f(req[j]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   365
                        }
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   369
                // add this module to full list of things to attach
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   370
                // Y.log('adding to requires list: ' + name);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   371
                r.push(name);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   372
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
            onComplete = function(fromLoader) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   376
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   377
                // Y.log('Use complete');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   378
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   379
                fromLoader = fromLoader || {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   380
                    success: true,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   381
                    msg: 'not dynamic'
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   382
                };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   383
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   384
                if (Y.Env._callback) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   385
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   386
                    var cb = Y.Env._callback;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   387
                    Y.Env._callback = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   388
                    cb(Y, fromLoader);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   389
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   390
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   391
                if (Y.fire) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   392
                    Y.fire('yui:load', Y, fromLoader);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   393
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   394
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   395
                // process queued use requests as long until done 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   396
                // or dynamic load happens again.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   397
                this._loading = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   398
                while (this._useQueue && this._useQueue.size() && !this._loading) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   399
                    Y.use.apply(Y, this._useQueue.next());
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   400
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   401
            };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   402
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   403
        // Y.log(Y.id + ': use called: ' + a + ' :: ' + callback);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   404
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   405
        // The last argument supplied to use can be a load complete callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   406
        if (typeof callback === 'function') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   407
            a.pop();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   408
            Y.Env._callback = callback;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   409
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   410
            callback = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   411
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   412
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   413
        // YUI().use('*'); // bind everything available
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   414
        if (firstArg === "*") {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   415
            a = [];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   416
            for (k in mods) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   417
                if (mods.hasOwnProperty(k)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   418
                    a.push(k);
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
            // Y.log('Use *: ' + a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   423
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   424
            return Y.use.apply(Y, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   425
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
        // Y.log('loader before: ' + a.join(','));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   429
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   430
        // use loader to expand dependencies and sort the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   431
        // requirements if it is available.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   432
        if (Y.Loader) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   433
            dynamic = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   434
            this._useQueue = this._useQueue || new Y.Queue();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   435
            loader = new Y.Loader(Y.config);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   436
            loader.require(a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   437
            loader.ignoreRegistered = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   438
            loader.allowRollup = false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   439
            loader.calculate();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   440
            a = loader.sorted;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   441
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   442
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   443
        // Y.log('loader after: ' + a.join(','));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   444
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   445
        l = a.length;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   446
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   447
        // process each requirement and any additional requirements 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   448
        // the module metadata specifies
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   449
        for (i=0; i<l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   450
            f(a[i]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   451
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   452
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   453
        // Y.log('all reqs: ' + r + ' --- missing: ' + missing + ', l: ' + l + ', ' + r[0]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   454
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   455
        // dynamic load
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   456
        if (Y.Loader && missing.length) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   457
            Y.log('Attempting to dynamically load the missing modules ' + missing, 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   458
            this._loading = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   459
            loader = new Y.Loader(Y.config);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   460
            loader.onSuccess = onComplete;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   461
            loader.onFailure = onComplete;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   462
            loader.onTimeout = onComplete;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   463
            loader.attaching = a;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   464
            loader.require(missing);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   465
            loader.insert();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   466
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   467
            Y._attach(r);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   468
            onComplete();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   469
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   470
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   471
        return Y; // chain support var yui = YUI().use('dragdrop');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   472
    },
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
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   476
     * Returns the namespace specified and creates it if it doesn't exist
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   477
     * <pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   478
     * YUI.namespace("property.package");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   479
     * YUI.namespace("YAHOO.property.package");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   480
     * </pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   481
     * Either of the above would create YUI.property, then
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   482
     * YUI.property.package (YAHOO is scrubbed out, this is
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   483
     * to remain compatible with YUI2)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   484
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   485
     * Be careful when naming packages. Reserved words may work in some browsers
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   486
     * and not others. For instance, the following will fail in Safari:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   487
     * <pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   488
     * YUI.namespace("really.long.nested.namespace");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   489
     * </pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   490
     * This fails because "long" is a future reserved word in ECMAScript
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   491
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   492
     * @method namespace
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   493
     * @param  {string*} arguments 1-n namespaces to create 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   494
     * @return {object}  A reference to the last namespace object created
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   495
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   496
    namespace: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   497
        var a=arguments, o=null, i, j, d;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   498
        for (i=0; i<a.length; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   499
            d = ("" + a[i]).split(".");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   500
            o = this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   501
            for (j=(d[0] == "YAHOO") ? 1 : 0; j<d.length; j=j+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   502
                o[d[j]] = o[d[j]] || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   503
                o = o[d[j]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   504
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   505
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   506
        return o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   507
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   508
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   509
    // this is replaced if the log module is included
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   510
    log: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   511
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   512
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   513
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   514
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   515
     * Report an error.  The reporting mechanism is controled by
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   516
     * the 'throwFail' configuration attribute.  If throwFail is
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   517
     * not specified, the message is written to the Logger, otherwise
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   518
     * a JS error is thrown
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   519
     * @method error
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   520
     * @param msg {string} the error message
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   521
     * @param e {Error} Optional JS error that was caught.  If supplied
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   522
     * and throwFail is specified, this error will be re-thrown.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   523
     * @return {YUI} this YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   524
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   525
    error: function(msg, e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   526
        if (this.config.throwFail) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   527
            throw (e || new Error(msg)); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   528
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   529
            this.message(msg, "error"); // don't scrub this one
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   530
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   531
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   532
        return this;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   533
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   534
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   535
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   536
     * Generate an id that is unique among all YUI instances
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   537
     * @method guid
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   538
     * @param pre {string} optional guid prefix
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   539
     * @return {string} the guid
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   540
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   541
    guid: function(pre) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   542
        var id =  this.Env._guidp + (++this.Env._uidx);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   543
        return (pre) ? (pre + id) : id;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   544
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   545
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   546
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   547
     * Returns a guid associated with an object.  If the object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   548
     * does not have one, a new one is created unless readOnly
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   549
     * is specified.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   550
     * @method stamp
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   551
     * @param o The object to stamp
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   552
     * @param readOnly {boolean} if true, a valid guid will only
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   553
     * be returned if the object has one assigned to it.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   554
     * @return {string} The object's guid or null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   555
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   556
    stamp: function(o, readOnly) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   557
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   558
        if (!o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   559
            return o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   560
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   561
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   562
        var uid = (typeof o === 'string') ? o : o._yuid;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   563
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   564
        if (!uid) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   565
            uid = this.guid();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   566
            if (!readOnly) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   567
                try {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   568
                    o._yuid = uid;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   569
                } catch(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   570
                    uid = null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   571
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   572
            }
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
        return uid;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   576
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   577
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   578
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   579
// Give the YUI global the same properties as an instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   580
// This makes it so that the YUI global can be used like the YAHOO
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   581
// global was used prior to 3.x.  More importantly, the YUI global
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   582
// provides global metadata, so env needs to be configured.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   583
// @TODO review
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   584
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   585
    p = YUI.prototype;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   586
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   587
    // inheritance utilities are not available yet
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   588
    for (i in p) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   589
        if (true) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   590
            YUI[i] = p[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   591
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   592
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   593
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   594
    // set up the environment
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   595
    YUI._init();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   596
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   597
    // add a window load event at load time so we can capture
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   598
    // the case where it fires before dynamic loading is
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   599
    // complete.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   600
    add(window, 'load', globalListener);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   601
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   602
    YUI.Env.add = add;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   603
    YUI.Env.remove = remove;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   604
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   605
    /*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   606
     * Subscribe to an event.  The signature differs depending on the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   607
     * type of event you are attaching to.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   608
     * @method on 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   609
     * @param type {string|function|object} The type of the event.  If
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   610
     * this is a function, this is dispatched to the aop system.  If an
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   611
     * object, it is parsed for multiple subsription definitions
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   612
     * @param fn {Function} The callback
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   613
     * @param elspec {any} DOM element(s), selector string(s), and or
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   614
     * Node ref(s) to attach DOM related events to (only applies to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   615
     * DOM events).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   616
     * @param
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   617
     * @return the event target or a detach handle per 'chain' config
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
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   621
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   622
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   623
 * The config object contains all of the configuration options for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   624
 * the YUI instance.  This object is supplied by the implementer 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   625
 * when instantiating a YUI instance.  Some properties have default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   626
 * values if they are not supplied by the implementer.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   627
 * @class config
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   628
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   629
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   630
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   631
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   632
 * Turn debug statements on or off
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   633
 * @property debug
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   634
 * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   635
 * @default true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   636
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   637
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   638
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   639
 * Log to the browser console if debug is on and the browser has a
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   640
 * supported console
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   641
 * @property useBrowserConsole
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   642
 * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   643
 * @default true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   644
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   645
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   646
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   647
 * A hash of log sources that should be logged.  If specified, only log messages from these sources will be logged.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   648
 * @property logInclude
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   649
 * @type object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   650
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   651
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   652
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   653
 * A hash of log sources that should be not be logged.  If specified, all sources are logged if not on this list.</li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   654
 * @property logExclude
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   655
 * @type object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   656
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   657
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   658
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   659
 * Set to true if the yui seed file was dynamically loaded in 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   660
 * order to bootstrap components relying on the window load event 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   661
 * and onDOMReady.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   662
 * @property injected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   663
 * @type object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   664
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   665
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   666
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   667
 * If throwFail is set, Y.fail will generate or re-throw a JS Error.  Otherwise the failure is logged.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   668
 * @property throwFail
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   669
 * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   670
 * @default true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   671
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   672
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   673
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   674
 * The window/frame that this instance should operate in
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   675
 * @property win
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   676
 * @type Window
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   677
 * @default the window hosting YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   678
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   679
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   680
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   681
 * The document associated with the 'win' configuration
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   682
 * @property doc
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   683
 * @type Document
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   684
 * @default the document hosting YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   685
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   686
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   687
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   688
 * A list of modules that defines the YUI core (overrides the default)</li>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   689
 * @property core
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   690
 * @type string[]
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   691
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   692
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   693
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   694
 * The default date format
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   695
 * @property dateFormat
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   696
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   697
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   698
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   699
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   700
 * The default locale
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   701
 * @property locale
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   702
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   703
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   704
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   705
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   706
 * The default interval when polling in milliseconds.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   707
 * @property pollInterval
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   708
 * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   709
 * @default 20
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   710
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   711
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   712
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   713
 * The number of dynamic nodes to insert by default before
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   714
 * automatically removing them.  This applies to script nodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   715
 * because remove the node will not make the evaluated script
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   716
 * unavailable.  Dynamic CSS is not auto purged, because removing
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   717
 * a linked style sheet will also remove the style definitions.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   718
 * @property purgethreshold
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   719
 * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   720
 * @default 20
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   721
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   722
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   723
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   724
 * The default interval when polling in milliseconds.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   725
 * @property windowResizeDelay
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   726
 * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   727
 * @default 40
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   728
 */
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
 * Base directory for dynamic loading
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   732
 * @property base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   733
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   734
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   735
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   736
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   737
 * The secure base dir (not implemented)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   738
 * For dynamic loading.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   739
 * @property secureBase
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   740
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   741
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   742
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   743
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   744
 * The YUI combo service base dir. Ex: http://yui.yahooapis.com/combo?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   745
 * For dynamic loading.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   746
 * @property comboBase
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   747
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   748
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   749
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   750
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   751
 * The root path to prepend to module names for the combo service. Ex: 3.0.0b1/build/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   752
 * For dynamic loading.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   753
 * @property root
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   754
 * @type string
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
 * A filter to apply to result urls.  This filter will modify the default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   759
 * path for all modules.  The default path for the YUI library is the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   760
 * minified version of the files (e.g., event-min.js).  The filter property
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   761
 * can be a predefined filter or a custom filter.  The valid predefined 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   762
 * filters are:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   763
 * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   764
 *  <dt>DEBUG</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   765
 *  <dd>Selects the debug versions of the library (e.g., event-debug.js).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   766
 *      This option will automatically include the Logger widget</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   767
 *  <dt>RAW</dt>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   768
 *  <dd>Selects the non-minified version of the library (e.g., event.js).</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   769
 * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   770
 * You can also define a custom filter, which must be an object literal 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   771
 * containing a search expression and a replace string:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   772
 * <pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   773
 *  myFilter: &#123; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   774
 *      'searchExp': "-min\\.js", 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   775
 *      'replaceStr': "-debug.js"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   776
 *  &#125;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   777
 * </pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   778
 * For dynamic loading.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   779
 * @property filter
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   780
 * @type string|object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   781
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   782
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   783
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   784
 * Hash of per-component filter specification.  If specified for a given component, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   785
 * this overrides the filter config
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   786
 * For dynamic loading.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   787
 * @property filters
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   788
 * @type object
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   792
 * Use the YUI combo service to reduce the number of http connections 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   793
 * required to load your dependencies
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   794
 * For dynamic loading.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   795
 * @property combine
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   796
 * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   797
 * @default true if 'base' is not supplied, false if it is.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   798
 */
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
 * A list of modules that should never be dynamically loaded
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   802
 * @property ignore
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   803
 * @type string[]
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
 * A list of modules that should always be loaded when required, even if already 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   808
 * present on the page.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   809
 * @property force
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   810
 * @type string[]
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   811
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   812
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   813
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   814
 * Node or id for a node that should be used as the insertion point for new nodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   815
 * For dynamic loading.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   816
 * @property insertBefore
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   817
 * @type string
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   821
 * charset for dynamic nodes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   822
 * @property charset
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   823
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   824
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   825
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   826
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   827
 * Object literal containing attributes to add to dynamically loaded script nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   828
 * @property jsAttributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   829
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   830
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   831
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   832
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   833
 * Object literal containing attributes to add to dynamically loaded link nodes.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   834
 * @property cssAttributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   835
 * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   836
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   837
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   838
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   839
 * Number of milliseconds before a timeout occurs when dynamically 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   840
 * loading nodes. If not set, there is no timeout.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   841
 * @property timeout
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   842
 * @type int
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   843
 */
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
 * Callback for the 'CSSComplete' event.  When dynamically loading YUI 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   847
 * components with CSS, this property fires when the CSS is finished
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   848
 * loading but script loading is still ongoing.  This provides an
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   849
 * opportunity to enhance the presentation of a loading page a little
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   850
 * bit before the entire loading process is done.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   851
 * @property onCSS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   852
 * @type function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   853
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   854
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   855
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   856
 * A list of module definitions to add to the list of YUI components.  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   857
 * These components can then be dynamically loaded side by side with
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   858
 * YUI via the use() method.See Loader.addModule for the supported
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   859
 * module metadata.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   860
 * @property modules
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   861
 * @type function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   862
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   863
 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   864
YUI.add('yui-base', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   865
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   866
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   867
 * YUI stub
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   868
 * @module yui
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   869
 * @submodule yui-base
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   870
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   871
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   872
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   873
var instance = Y,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   874
    LOGEVENT = 'yui:log',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   875
    _published;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   876
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 the 'debug' config is true, a 'yui:log' event will be
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   879
 * dispatched, which the Console widget and anything else
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   880
 * can consume.  If the 'useBrowserConsole' config is true, it will
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   881
 * write to the browser console if available.  YUI-specific log
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   882
 * messages will only be present in the -debug versions of the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   883
 * JS files.  The build system is supposed to remove log statements
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   884
 * from the raw and minified versions of the files.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   885
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   886
 * @method log
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   887
 * @for YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   888
 * @param  {String}  msg  The message to log.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   889
 * @param  {String}  cat  The log category for the message.  Default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   890
 *                        categories are "info", "warn", "error", time".
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   891
 *                        Custom categories can be used as well. (opt)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   892
 * @param  {String}  src  The source of the the message (opt)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   893
 * @param  {boolean} silent If true, the log event won't fire
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   894
 * @return {YUI}      YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   895
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   896
instance.log = function(msg, cat, src, silent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   897
    var Y = instance, c = Y.config, bail = false, exc, inc, m, f;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   898
    // suppress log message if the config is off or the event stack
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   899
    // or the event call stack contains a consumer of the yui:log event
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   900
    if (c.debug) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   901
        // apply source filters
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   902
        if (src) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   903
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   904
            exc = c.logExclude; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   905
            inc = c.logInclude;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   906
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   907
            if (inc && !(src in inc)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   908
                bail = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   909
            } else if (exc && (src in exc)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   910
                bail = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   911
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   912
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   913
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   914
        if (!bail) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   915
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   916
            if (c.useBrowserConsole) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   917
                m = (src) ? src + ': ' + msg : msg;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   918
                if (typeof console != 'undefined') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   919
                    f = (cat && console[cat]) ? cat : 'log';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   920
                    console[f](m);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   921
                } else if (typeof opera != 'undefined') {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   922
                    opera.postError(m);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   923
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   924
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   925
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   926
            if (Y.fire && !bail && !silent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   927
                if (!_published) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   928
                    Y.publish(LOGEVENT, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   929
                        broadcast: 2,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   930
                        emitFacade: true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   931
                    });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   932
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   933
                    _published = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   934
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   935
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   936
                Y.fire(LOGEVENT, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   937
                    msg: msg, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   938
                    cat: cat, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   939
                    src: src
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   940
                });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   941
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   942
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   943
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   944
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   945
    return Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   946
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   947
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   948
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   949
 * Write a system message.  This message will be preserved in the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   950
 * minified and raw versions of the YUI files, unlike log statements.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   951
 * @method message
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   952
 * @for YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   953
 * @param  {String}  msg  The message to log.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   954
 * @param  {String}  cat  The log category for the message.  Default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   955
 *                        categories are "info", "warn", "error", time".
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   956
 *                        Custom categories can be used as well. (opt)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   957
 * @param  {String}  src  The source of the the message (opt)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   958
 * @param  {boolean} silent If true, the log event won't fire
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   959
 * @return {YUI}      YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   960
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   961
instance.message = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   962
    return instance.log.apply(instance, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   963
};
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
 * @TODO I'm not convinced the current log statement scrubbing routine can
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   967
 * be made safe with all the variations that could be supplied for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   968
 * the condition.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   969
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   970
 * Logs a message with Y.log() if the first parameter is true
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   971
 * Y.logIf((life == 'good'), 'yay'); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   972
 * logIf statements are stripped from the raw and min files.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   973
 * @method logIf
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   974
 * @for YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   975
 * @param  {boolean} condition Logging only occurs if a truthy value is provided
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   976
 * @param  {String}  msg  The message to log.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   977
 * @param  {String}  cat  The log category for the message.  Default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   978
 *                        categories are "info", "warn", "error", time".
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   979
 *                        Custom categories can be used as well. (opt)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   980
 * @param  {String}  src  The source of the the message (opt)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   981
 * @param  {boolean} silent If true, the log event won't fire
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   982
 * @return {YUI}      YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   983
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   984
// instance.logIf = function(condition, msg, cat, src, silent) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   985
//     if (condition) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   986
//         return Y.log.apply(Y, arguments);
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   990
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   991
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   992
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   993
 * Provides the language utilites and extensions used by the library
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   994
 * @class Lang
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   995
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   996
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   997
Y.Lang    = Y.Lang || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   998
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   999
var L     = Y.Lang, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1000
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1001
ARRAY     = 'array',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1002
BOOLEAN   = 'boolean',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1003
DATE      = 'date',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1004
ERROR     = 'error',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1005
FUNCTION  = 'function',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1006
NUMBER    = 'number',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1007
NULL      = 'null',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1008
OBJECT    = 'object',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1009
REGEX     = 'regexp',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1010
STRING    = 'string',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1011
TOSTRING  = Object.prototype.toString,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1012
UNDEFINED = 'undefined',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1013
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1014
TYPES     = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1015
    'undefined'         : UNDEFINED,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1016
    'number'            : NUMBER,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1017
    'boolean'           : BOOLEAN,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1018
    'string'            : STRING,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1019
    '[object Function]' : FUNCTION,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1020
    '[object RegExp]'   : REGEX,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1021
    '[object Array]'    : ARRAY,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1022
    '[object Date]'     : DATE,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1023
    '[object Error]'    : ERROR 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1024
},
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1025
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1026
TRIMREGEX = /^\s+|\s+$/g,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1027
EMPTYSTRING = '';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1028
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1029
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1030
 * Determines whether or not the provided item is an array.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1031
 * Returns false for array-like collections such as the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1032
 * function arguments collection or HTMLElement collection
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1033
 * will return false.  You can use @see Array.test if you 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1034
 * want to
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1035
 * @method isArray
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1036
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1037
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1038
 * @return {boolean} true if o is an array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1039
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1040
L.isArray = function(o) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1041
    return L.type(o) === ARRAY;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1042
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1043
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1044
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1045
 * Determines whether or not the provided item is a boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1046
 * @method isBoolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1047
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1048
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1049
 * @return {boolean} true if o is a boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1050
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1051
L.isBoolean = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1052
    return typeof o === BOOLEAN;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1053
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1054
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1055
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1056
 * Determines whether or not the provided item is a function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1057
 * Note: Internet Explorer thinks certain functions are objects:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1058
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1059
 * var obj = document.createElement("object");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1060
 * Y.Lang.isFunction(obj.getAttribute) // reports false in IE
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1061
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1062
 * var input = document.createElement("input"); // append to body
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1063
 * Y.Lang.isFunction(input.focus) // reports false in IE
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1064
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1065
 * You will have to implement additional tests if these functions
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1066
 * matter to you.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1067
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1068
 * @method isFunction
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1069
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1070
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1071
 * @return {boolean} true if o is a function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1072
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1073
L.isFunction = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1074
    return L.type(o) === FUNCTION;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1075
};
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
 * Determines whether or not the supplied item is a date instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1079
 * @method isDate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1080
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1081
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1082
 * @return {boolean} true if o is a date
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1083
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1084
L.isDate = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1085
    // return o instanceof Date;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1086
    return L.type(o) === DATE;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1087
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1088
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1089
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1090
 * Determines whether or not the provided item is null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1091
 * @method isNull
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1092
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1093
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1094
 * @return {boolean} true if o is null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1095
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1096
L.isNull = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1097
    return o === null;
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1101
 * Determines whether or not the provided item is a legal number
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1102
 * @method isNumber
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1103
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1104
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1105
 * @return {boolean} true if o is a number
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1106
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1107
L.isNumber = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1108
    return typeof o === NUMBER && isFinite(o);
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
 * Determines whether or not the provided item is of type object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1113
 * or function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1114
 * @method isObject
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1115
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1116
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1117
 * @param failfn {boolean} fail if the input is a function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1118
 * @return {boolean} true if o is an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1119
 */  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1120
L.isObject = function(o, failfn) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1121
return (o && (typeof o === OBJECT || (!failfn && L.isFunction(o)))) || false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1122
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1123
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1124
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1125
 * Determines whether or not the provided item is a string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1126
 * @method isString
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1127
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1128
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1129
 * @return {boolean} true if o is a string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1130
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1131
L.isString = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1132
    return typeof o === STRING;
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1136
 * Determines whether or not the provided item is undefined
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1137
 * @method isUndefined
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1138
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1139
 * @param o The object to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1140
 * @return {boolean} true if o is undefined
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1141
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1142
L.isUndefined = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1143
    return typeof o === UNDEFINED;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1144
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1145
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1146
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1147
 * Returns a string without any leading or trailing whitespace.  If 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1148
 * the input is not a string, the input will be returned untouched.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1149
 * @method trim
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1150
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1151
 * @param s {string} the string to trim
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1152
 * @return {string} the trimmed string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1153
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1154
L.trim = function(s){
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1155
    try {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1156
        return s.replace(TRIMREGEX, EMPTYSTRING);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1157
    } catch(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1158
        return s;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1159
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1160
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1161
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1162
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1163
 * A convenience method for detecting a legitimate non-null value.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1164
 * Returns false for null/undefined/NaN, true for other values, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1165
 * including 0/false/''
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1166
 * @method isValue
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1167
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1168
 * @param o The item to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1169
 * @return {boolean} true if it is not null/undefined/NaN || false
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1170
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1171
L.isValue = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1172
    var t = L.type(o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1173
    switch (t) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1174
        case NUMBER:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1175
            return isFinite(o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1176
        case NULL:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1177
        case UNDEFINED:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1178
            return false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1179
        default:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1180
            return !!(t);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1181
    }
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
 * Returns a string representing the type of the item passed in.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1186
 * @method type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1187
 * @param o the item to test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1188
 * @return {string} the detected type
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1189
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1190
L.type = function (o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1191
    return  TYPES[typeof o] || TYPES[TOSTRING.call(o)] || (o ? OBJECT : NULL);
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
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1195
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1196
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1197
 * Provides information about the environment hosting YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1198
 * @module yui
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1199
 * @submodule Array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1200
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1201
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1202
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1203
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1204
var L = Y.Lang, Native = Array.prototype,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1205
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1206
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1207
 * Adds the following array utilities to the YUI instance.  Additional
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1208
 * array helpers can be found in the collection component.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1209
 * @class Array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1210
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1211
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1212
/** 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1213
 * Y.Array(o) returns an array:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1214
 * - Arrays are return unmodified unless the start position is specified.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1215
 * - "Array-like" collections (@see Array.test) are converted to arrays
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1216
 * - For everything else, a new array is created with the input as the sole item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1217
 * - The start position is used if the input is or is like an array to return
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1218
 *   a subset of the collection.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1219
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1220
 *   @TODO this will not automatically convert elements that are also collections
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1221
 *   such as forms and selects.  Passing true as the third param will
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1222
 *   force a conversion.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1223
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1224
 * @method ()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1225
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1226
 *   @param o the item to arrayify
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1227
 *   @param i {int} if an array or array-like, this is the start index
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1228
 *   @param al {boolean} if true, it forces the array-like fork.  This
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1229
 *   can be used to avoid multiple array.test calls.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1230
 *   @return {Array} the resulting array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1231
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1232
YArray = function(o, startIdx, al) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1233
    var t = (al) ? 2 : Y.Array.test(o), i, l, a;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1234
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1235
    // switch (t) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1236
    //     case 1:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1237
    //         // return (startIdx) ? o.slice(startIdx) : o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1238
    //     case 2:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1239
    //         return Native.slice.call(o, startIdx || 0);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1240
    //     default:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1241
    //         return [o];
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
    if (t) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1245
        try {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1246
            return Native.slice.call(o, startIdx || 0);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1247
        // IE errors when trying to slice element collections
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1248
        } catch(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1249
            a=[];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1250
            for (i=0, l=o.length; i<l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1251
                a.push(o[i]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1252
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1253
            return a;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1254
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1255
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1256
        return [o];
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
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1260
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1261
Y.Array = YArray;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1262
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1263
/** 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1264
 * Evaluates the input to determine if it is an array, array-like, or 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1265
 * something else.  This is used to handle the arguments collection 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1266
 * available within functions, and HTMLElement collections
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1267
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1268
 * @method test
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1269
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1270
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1271
 * @todo current implementation (intenionally) will not implicitly 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1272
 * handle html elements that are array-like (forms, selects, etc).  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1273
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1274
 * @return {int} a number indicating the results:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1275
 * 0: Not an array or an array-like collection
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1276
 * 1: A real array. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1277
 * 2: array-like collection.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1278
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1279
YArray.test = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1280
    var r = 0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1281
    if (L.isObject(o)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1282
        if (L.isArray(o)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1283
            r = 1; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1284
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1285
            try {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1286
                // indexed, but no tagName (element) or alert (window)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1287
                if ("length" in o && !("tagName" in o) && !("alert" in o) && 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1288
                    (!Y.Lang.isFunction(o.size) || o.size() > 1)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1289
                    r = 2;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1290
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1291
                    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1292
            } catch(e) {}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1293
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1294
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1295
    return r;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1296
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1297
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1298
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1299
 * Executes the supplied function on each item in the array.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1300
 * @method each
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1301
 * @param a {Array} the array to iterate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1302
 * @param f {Function} the function to execute on each item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1303
 * @param o Optional context object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1304
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1305
 * @return {YUI} the YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1306
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1307
YArray.each = (Native.forEach) ?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1308
    function (a, f, o) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1309
        Native.forEach.call(a || [], f, o || Y);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1310
        return Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1311
    } :
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1312
    function (a, f, o) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1313
        var l = (a && a.length) || 0, i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1314
        for (i = 0; i < l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1315
            f.call(o || Y, a[i], i, a);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1316
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1317
        return Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1318
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1319
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1320
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1321
 * Returns an object using the first array as keys, and
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1322
 * the second as values.  If the second array is not
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1323
 * provided the value is set to true for each.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1324
 * @method hash
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1325
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1326
 * @param k {Array} keyset
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1327
 * @param v {Array} optional valueset
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1328
 * @return {object} the hash
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1329
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1330
YArray.hash = function(k, v) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1331
    var o = {}, l = k.length, vl = v && v.length, i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1332
    for (i=0; i<l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1333
        o[k[i]] = (vl && vl > i) ? v[i] : true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1334
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1335
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1336
    return o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1337
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1338
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1339
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1340
 * Returns the index of the first item in the array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1341
 * that contains the specified value, -1 if the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1342
 * value isn't found.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1343
 * @method indexOf
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1344
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1345
 * @param a {Array} the array to search
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1346
 * @param val the value to search for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1347
 * @return {int} the index of the item that contains the value or -1
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1348
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1349
YArray.indexOf = (Native.indexOf) ?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1350
    function(a, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1351
        return a.indexOf(val);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1352
    } :
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1353
    function(a, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1354
        for (var i=0; i<a.length; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1355
            if (a[i] === val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1356
                return i;
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1360
        return -1;
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1364
 * Numeric sort convenience function.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1365
 * Y.ArrayAssert.itemsAreEqual([1, 2, 3], [3, 1, 2].sort(Y.Array.numericSort));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1366
 * @method numericSort
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1367
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1368
YArray.numericSort = function(a, b) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1369
    return (a - b); 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1370
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1371
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1372
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1373
 * Executes the supplied function on each item in the array.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1374
 * Returning true from the processing function will stop the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1375
 * processing of the remaining
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1376
 * items.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1377
 * @method some
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1378
 * @param a {Array} the array to iterate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1379
 * @param f {Function} the function to execute on each item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1380
 * @param o Optional context object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1381
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1382
 * @return {boolean} true if the function returns true on
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1383
 * any of the items in the array
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1384
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1385
 YArray.some = (Native.some) ?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1386
    function (a, f, o) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1387
        return Native.some.call(a, f, o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1388
    } :
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1389
    function (a, f, o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1390
        var l = a.length, i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1391
        for (i=0; i<l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1392
            if (f.call(o, a[i], i, a)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1393
                return true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1394
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1395
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1396
        return false;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1397
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1398
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1399
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1400
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1401
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1402
var L = Y.Lang, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1403
DELIMITER = '__',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1404
// FROZEN = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1405
//     'prototype': 1,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1406
//     '_yuid': 1
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1407
// },
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
 * IE will not enumerate native functions in a derived object even if the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1411
 * function was overridden.  This is a workaround for specific functions 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1412
 * we care about on the Object prototype. 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1413
 * @property _iefix
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1414
 * @for YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1415
 * @param {Function} r  the object to receive the augmentation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1416
 * @param {Function} s  the object that supplies the properties to augment
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1417
 * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1418
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1419
_iefix = function(r, s) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1420
    var fn = s.toString;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1421
    if (L.isFunction(fn) && fn != Object.prototype.toString) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1422
        r.toString = fn;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1423
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1424
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1425
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
 * Returns a new object containing all of the properties of
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1429
 * all the supplied objects.  The properties from later objects
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1430
 * will overwrite those in earlier objects.  Passing in a
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1431
 * single object will create a shallow copy of it.  For a deep
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1432
 * copy, use clone.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1433
 * @method merge
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1434
 * @for YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1435
 * @param arguments {Object*} the objects to merge
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1436
 * @return {object} the new merged object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1437
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1438
Y.merge = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1439
    var a = arguments, o = {}, i, l = a.length;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1440
    for (i=0; i<l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1441
        Y.mix(o, a[i], true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1442
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1443
    return o;
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1447
 * Applies the supplier's properties to the receiver.  By default
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1448
 * all prototype and static propertes on the supplier are applied
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1449
 * to the corresponding spot on the receiver.  By default all
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1450
 * properties are applied, and a property that is already on the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1451
 * reciever will not be overwritten.  The default behavior can
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1452
 * be modified by supplying the appropriate parameters.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1453
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1454
 * @TODO add constants for the modes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1455
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1456
 * @method mix
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1457
 * @param {Function} r  the object to receive the augmentation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1458
 * @param {Function} s  the object that supplies the properties to augment
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1459
 * @param ov {boolean} if true, properties already on the receiver
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1460
 * will be overwritten if found on the supplier.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1461
 * @param wl {string[]} a whitelist.  If supplied, only properties in 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1462
 * this list will be applied to the receiver.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1463
 * @param {int} mode what should be copies, and to where
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1464
 *        default(0): object to object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1465
 *        1: prototype to prototype (old augment)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1466
 *        2: prototype to prototype and object props (new augment)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1467
 *        3: prototype to object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1468
 *        4: object to prototype
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1469
 * @param merge {boolean} merge objects instead of overwriting/ignoring
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1470
 * Used by Y.aggregate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1471
 * @return {object} the augmented object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1472
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1473
Y.mix = function(r, s, ov, wl, mode, merge) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1474
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1475
    if (!s||!r) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1476
        return r || Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1477
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1478
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1479
    if (mode) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1480
        switch (mode) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1481
            case 1: // proto to proto
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1482
                return Y.mix(r.prototype, s.prototype);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1483
            case 2: // object to object and proto to proto
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1484
                Y.mix(r.prototype, s.prototype);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1485
                break; // pass through 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1486
            case 3: // proto to static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1487
                return Y.mix(r, s.prototype);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1488
            case 4: // static to proto
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1489
                return Y.mix(r.prototype, s);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1490
            default:  // object to object is what happens below
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1491
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1492
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1493
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1494
    // Maybe don't even need this wl && wl.length check anymore??
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1495
    var arr = merge && L.isArray(r), i, l, p;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1496
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1497
    if (wl && wl.length) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1498
        for (i = 0, l = wl.length; i < l; ++i) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1499
            p = wl[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1500
            if (p in s) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1501
                if (merge && L.isObject(r[p], true)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1502
                    Y.mix(r[p], s[p]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1503
                } else if (!arr && (ov || !(p in r))) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1504
                    r[p] = s[p];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1505
                } else if (arr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1506
                    r.push(s[p]);
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
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1510
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1511
        for (i in s) { 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1512
            // if (s.hasOwnProperty(i) && !(i in FROZEN)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1513
                // check white list if it was supplied
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1514
                // if the receiver has this property, it is an object,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1515
                // and merge is specified, merge the two objects.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1516
                if (merge && L.isObject(r[i], true)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1517
                    Y.mix(r[i], s[i]); // recursive
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1518
                // otherwise apply the property only if overwrite
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1519
                // is specified or the receiver doesn't have one.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1520
                } else if (!arr && (ov || !(i in r))) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1521
                    r[i] = s[i];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1522
                // if merge is specified and the receiver is an array,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1523
                // append the array item
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1524
                } else if (arr) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1525
                    r.push(s[i]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1526
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1527
            // }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1528
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1529
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1530
        if (Y.UA.ie) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1531
            _iefix(r, s);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1532
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1533
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1534
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1535
    return r;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1536
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1537
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1538
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1539
 * Returns a wrapper for a function which caches the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1540
 * return value of that function, keyed off of the combined 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1541
 * argument values.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1542
 * @function cached
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1543
 * @param source {function} the function to memoize
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1544
 * @param cache an optional cache seed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1545
 * @return {Function} the wrapped function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1546
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1547
Y.cached = function(source, cache){
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1548
    cache = cache || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1549
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1550
    // I want the profiler to show me separate entries for each
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1551
    // cached function.  Is this too much to ask?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1552
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1553
    // return function cached_sourceFunction
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1554
    // return this['cached_' + source.name] = function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1555
    // var a = function(){}; a.name = 'foo'; return a;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1556
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1557
    return function cached(arg1, arg2) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1558
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1559
        // (?)()   51  5.76%   0.571ms 1.01ms  0.02ms  0.001ms 0.041ms
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1560
        // A() 76  6.58%   0.652ms 0.652ms 0.009ms 0.005ms 0.03ms
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1561
        // var key = (arg2 !== undefined) ? Y.Array(arguments, 0, true).join(DELIMITER) : arg1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1562
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1563
        // (?)()   51  8.57%   0.837ms 0.838ms 0.016ms 0.013ms 0.024ms
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1564
        // var key = (arguments.length > 1) ? Array.prototype.join.call(arguments, DELIMITER) : arg1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1565
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1566
        // (?)()   51  8.06%  0.761ms 0.762ms 0.015ms 0.002ms 0.025ms
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1567
        // var key = (arg2 !== undefined) ? Array.prototype.join.call(arguments, DELIMITER) : arg1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1568
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1569
        // (?)()   51  7.87%   0.749ms 0.751ms 0.015ms 0.001ms 0.027ms
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1570
        // A() 30  2.23%   0.214ms 0.214ms 0.007ms 0.005ms 0.009ms
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1571
        var key = (arg2) ? Array.prototype.join.call(arguments, DELIMITER) : arg1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1572
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1573
        if (!(key in cache)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1574
            cache[key] = source.apply(source, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1575
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1576
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1577
        return cache[key];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1578
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1579
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1580
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1581
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1582
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1583
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1584
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1585
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1586
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1587
 * Adds the following Object utilities to the YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1588
 * @class Object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1589
 */
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
 * Y.Object(o) returns a new object based upon the supplied object.  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1593
 * @TODO Use native Object.create() when available
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1594
 * @method ()
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1595
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1596
 * @param o the supplier object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1597
 * @return {Object} the new object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1598
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1599
Y.Object = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1600
    var F = function() {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1601
    F.prototype = o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1602
    return new F();
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
var O = Y.Object,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1606
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1607
UNDEFINED = undefined,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1608
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1609
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1610
 * Extracts the keys, values, or size from an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1611
 * 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1612
 * @method _extract
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1613
 * @param o the object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1614
 * @param what what to extract (0: keys, 1: values, 2: size)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1615
 * @return {boolean|Array} the extracted info
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1616
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1617
 * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1618
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1619
_extract = function(o, what) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1620
    var count = (what === 2), out = (count) ? 0 : [], i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1621
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1622
    for (i in o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1623
        if (count) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1624
            out++;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1625
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1626
            if (o.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1627
                out.push((what) ? o[i] : i);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1628
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1629
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1630
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1631
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1632
    return out;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1633
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1634
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1635
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1636
 * Returns an array containing the object's keys
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1637
 * @TODO use native Object.keys() if available
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1638
 * @method keys
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1639
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1640
 * @param o an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1641
 * @return {string[]} the keys
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1642
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1643
O.keys = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1644
    return _extract(o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1645
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1646
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1647
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1648
 * Returns an array containing the object's values
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1649
 * @TODO use native Object.values() if available
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1650
 * @method values
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1651
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1652
 * @param o an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1653
 * @return {Array} the values
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1654
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1655
O.values = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1656
    return _extract(o, 1);
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
 * Returns the size of an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1661
 * @TODO use native Object.size() if available
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1662
 * @method size
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1663
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1664
 * @param o an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1665
 * @return {int} the size
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1666
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1667
O.size = function(o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1668
    return _extract(o, 2);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1669
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1670
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1671
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1672
 * Returns true if the object contains a given key
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1673
 * @method hasKey
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1674
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1675
 * @param o an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1676
 * @param k the key to query
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1677
 * @return {boolean} true if the object contains the key
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1678
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1679
O.hasKey = function(o, k) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1680
    // return (o.hasOwnProperty(k));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1681
    return (k in o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1682
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1683
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1684
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1685
 * Returns true if the object contains a given value
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1686
 * @method hasValue
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1687
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1688
 * @param o an object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1689
 * @param v the value to query
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1690
 * @return {boolean} true if the object contains the value
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1691
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1692
O.hasValue = function(o, v) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1693
    return (Y.Array.indexOf(O.values(o), v) > -1);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1694
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1695
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1696
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1697
 * Determines whether or not the property was added
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1698
 * to the object instance.  Returns false if the property is not present
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1699
 * in the object, or was inherited from the prototype.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1700
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1701
 * @deprecated Safari 1.x support has been removed, so this is simply a 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1702
 * wrapper for the native implementation.  Use the native implementation
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1703
 * directly instead.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1704
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1705
 * @TODO Remove in B1
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1706
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1707
 * @method owns
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1708
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1709
 * @param o {any} The object being testing
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1710
 * @param p {string} the property to look for
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1711
 * @return {boolean} true if the object has the property on the instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1712
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1713
O.owns = function(o, k) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1714
    return (o.hasOwnProperty(k));
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
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1718
 * Executes a function on each item. The function
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1719
 * receives the value, the key, and the object
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1720
 * as paramters (in that order).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1721
 * @method each
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1722
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1723
 * @param o the object to iterate
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1724
 * @param f {function} the function to execute
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1725
 * @param c the execution context
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1726
 * @param proto {boolean} include proto
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1727
 * @return {YUI} the YUI instance
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1728
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1729
O.each = function (o, f, c, proto) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1730
    var s = c || Y, i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1731
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1732
    for (i in o) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1733
        if (proto || o.hasOwnProperty(i)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1734
            f.call(s, o[i], i, o);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1735
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1736
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1737
    return Y;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1738
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1739
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1740
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1741
 * Retrieves the sub value at the provided path,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1742
 * from the value object provided.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1743
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1744
 * @method getValue
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1745
 * @param o The object from which to extract the property value
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1746
 * @param path {Array} A path array, specifying the object traversal path
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1747
 * from which to obtain the sub value.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1748
 * @return {Any} The value stored in the path, undefined if not found.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1749
 * Returns the source object if an empty path is provided.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1750
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1751
O.getValue = function (o, path) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1752
    var p=Y.Array(path), l=p.length, i;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1753
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1754
    for (i=0; o !== UNDEFINED && i < l; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1755
        o = o[p[i]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1756
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1757
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1758
    return o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1759
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1760
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1761
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1762
 * Sets the sub-attribute value at the provided path on the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1763
 * value object.  Returns the modified value object, or 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1764
 * undefined if the path is invalid.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1765
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1766
 * @method setValue
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1767
 * @param o             The object on which to set the sub value.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1768
 * @param path {Array}  A path array, specifying the object traversal path
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1769
 *                      at which to set the sub value.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1770
 * @param val {Any}     The new value for the sub-attribute.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1771
 * @return {Object}     The modified object, with the new sub value set, or 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1772
 *                      undefined, if the path was invalid.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1773
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1774
O.setValue = function(o, path, val) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1775
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1776
    var p=Y.Array(path), leafIdx=p.length-1, i, ref=o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1777
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1778
    if (leafIdx >= 0) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1779
        for (i=0; ref !== UNDEFINED && i < leafIdx; i=i+1) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1780
            ref = ref[p[i]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1781
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1782
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1783
        if (ref !== UNDEFINED) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1784
            ref[p[i]] = val;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1785
        } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1786
            return UNDEFINED;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1787
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1788
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1789
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1790
    return o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1791
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1792
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1793
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1794
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1795
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1796
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1797
 * Provides information about the environment hosting YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1798
 * @module yui
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1799
 * @submodule UA
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1800
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1801
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1802
 * YUI user agent detection.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1803
 * Do not fork for a browser if it can be avoided.  Use feature detection when
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1804
 * you can.  Use the user agent as a last resort.  UA stores a version
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1805
 * number for the browser engine, 0 otherwise.  This value may or may not map
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1806
 * to the version number of the browser using the engine.  The value is 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1807
 * presented as a float so that it can easily be used for boolean evaluation 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1808
 * as well as for looking for a particular range of versions.  Because of this, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1809
 * some of the granularity of the version info may be lost (e.g., Gecko 1.8.0.9 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1810
 * reports 1.8).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1811
 * @class UA
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1812
 * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1813
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1814
Y.UA = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1815
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1816
    var nav = navigator,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1817
        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
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1820
         * Internet Explorer version number or 0.  Example: 6
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1821
         * @property ie
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1822
         * @type float
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1823
         * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1824
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1825
        ie:0,
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
         * Opera version number or 0.  Example: 9.2
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1829
         * @property opera
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1830
         * @type float
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1831
         * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1832
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1833
        opera:0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1834
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1835
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1836
         * Gecko engine revision number.  Will evaluate to 1 if Gecko 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1837
         * is detected but the revision could not be found. Other browsers
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1838
         * will be 0.  Example: 1.8
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1839
         * <pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1840
         * Firefox 1.0.0.4: 1.7.8   <-- Reports 1.7
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1841
         * Firefox 1.5.0.9: 1.8.0.9 <-- Reports 1.8
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1842
         * Firefox 2.0.0.3: 1.8.1.3 <-- Reports 1.8
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1843
         * Firefox 3 alpha: 1.9a4   <-- Reports 1.9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1844
         * </pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1845
         * @property gecko
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1846
         * @type float
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1847
         * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1848
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1849
        gecko:0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1850
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1851
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1852
         * AppleWebKit version.  KHTML browsers that are not WebKit browsers 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1853
         * will evaluate to 1, other browsers 0.  Example: 418.9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1854
         * <pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1855
         * Safari 1.3.2 (312.6): 312.8.1 <-- Reports 312.8 -- currently the 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1856
         *                                   latest available for Mac OSX 10.3.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1857
         * Safari 2.0.2:         416     <-- hasOwnProperty introduced
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1858
         * Safari 2.0.4:         418     <-- preventDefault fixed
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1859
         * Safari 2.0.4 (419.3): 418.9.1 <-- One version of Safari may run
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1860
         *                                   different versions of webkit
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1861
         * Safari 2.0.4 (419.3): 419     <-- Tiger installations that have been
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1862
         *                                   updated, but not updated
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1863
         *                                   to the latest patch.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1864
         * Webkit 212 nightly:   522+    <-- Safari 3.0 precursor (with native SVG
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1865
         *                                   and many major issues fixed).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1866
         * Safari 3.0.4 (523.12) 523.12  <-- First Tiger release - automatic update
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1867
         *                                   from 2.x via the 10.4.11 OS patch
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1868
         * Webkit nightly 1/2008:525+    <-- Supports DOMContentLoaded event.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1869
         *                                   yahoo.com user agent hack removed.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1870
         * </pre>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1871
         * http://en.wikipedia.org/wiki/Safari_(web_browser)#Version_history
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1872
         * @property webkit
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1873
         * @type float
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1874
         * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1875
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1876
        webkit:0,
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
         * The mobile property will be set to a string containing any relevant
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1880
         * user agent information when a modern mobile browser is detected.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1881
         * Currently limited to Safari on the iPhone/iPod Touch, Nokia N-series
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1882
         * devices with the WebKit-based browser, and Opera Mini.  
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1883
         * @property mobile 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1884
         * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1885
         * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1886
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1887
        mobile: null,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1888
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1889
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1890
         * Adobe AIR version number or 0.  Only populated if webkit is detected.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1891
         * Example: 1.0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1892
         * @property air
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1893
         * @type float
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1894
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1895
        air: 0,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1896
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1897
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1898
         * Google Caja version number or 0.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1899
         * @property caja
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1900
         * @type float
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1901
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1902
        caja: nav.cajaVersion,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1903
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1904
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1905
         * Set to true if the page appears to be in SSL
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1906
         * @property secure
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1907
         * @type boolean
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1908
         * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1909
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1910
        secure: false,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1911
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1912
        /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1913
         * The operating system.  Currently only detecting windows or macintosh
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1914
         * @property os
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1915
         * @type string
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1916
         * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1917
         */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1918
        os: null
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1919
        
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1920
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1921
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1922
    ua = nav && nav.userAgent, 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1923
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1924
    loc = Y.config.win.location,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1925
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1926
    href = loc && loc.href,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1927
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1928
    m;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1929
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1930
    o.secure = href && (href.toLowerCase().indexOf("https") === 0);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1931
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1932
    if (ua) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1933
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1934
        if ((/windows|win32/).test(ua)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1935
            o.os = 'windows';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1936
        } else if ((/macintosh/).test(ua)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1937
            o.os = 'macintosh';
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1938
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1939
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1940
        // Modern KHTML browsers should qualify as Safari X-Grade
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1941
        if ((/KHTML/).test(ua)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1942
            o.webkit=1;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1943
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1944
        // Modern WebKit browsers are at least X-Grade
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1945
        m=ua.match(/AppleWebKit\/([^\s]*)/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1946
        if (m&&m[1]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1947
            o.webkit=parseFloat(m[1]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1948
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1949
            // Mobile browser check
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1950
            if (/ Mobile\//.test(ua)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1951
                o.mobile = "Apple"; // iPhone or iPod Touch
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1952
            } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1953
                m=ua.match(/NokiaN[^\/]*/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1954
                if (m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1955
                    o.mobile = m[0]; // Nokia N-series, ex: NokiaN95
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1956
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1957
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1958
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1959
            m=ua.match(/AdobeAIR\/([^\s]*)/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1960
            if (m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1961
                o.air = m[0]; // Adobe AIR 1.0 or better
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1962
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1963
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1964
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1965
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1966
        if (!o.webkit) { // not webkit
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1967
            // @todo check Opera/8.01 (J2ME/MIDP; Opera Mini/2.0.4509/1316; fi; U; ssr)
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1968
            m=ua.match(/Opera[\s\/]([^\s]*)/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1969
            if (m&&m[1]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1970
                o.opera=parseFloat(m[1]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1971
                m=ua.match(/Opera Mini[^;]*/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1972
                if (m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1973
                    o.mobile = m[0]; // ex: Opera Mini/2.0.4509/1316
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1974
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1975
            } else { // not opera or webkit
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1976
                m=ua.match(/MSIE\s([^;]*)/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1977
                if (m&&m[1]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1978
                    o.ie=parseFloat(m[1]);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1979
                } else { // not opera, webkit, or ie
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1980
                    m=ua.match(/Gecko\/([^\s]*)/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1981
                    if (m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1982
                        o.gecko=1; // Gecko detected, look for revision
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1983
                        m=ua.match(/rv:([^\s\)]*)/);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1984
                        if (m&&m[1]) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1985
                            o.gecko=parseFloat(m[1]);
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
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1989
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1990
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1991
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1992
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1993
    return o;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1994
}();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1995
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1996
    var L = Y.Lang,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1997
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1998
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  1999
     * Executes the supplied function in the context of the supplied 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2000
     * object 'when' milliseconds later.  Executes the function a 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2001
     * single time unless periodic is set to true.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2002
     * @method later
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2003
     * @for YUI
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2004
     * @param when {int} the number of milliseconds to wait until the fn 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2005
     * is executed.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2006
     * @param o the context object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2007
     * @param fn {Function|String} the function to execute or the name of 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2008
     * the method in the 'o' object to execute.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2009
     * @param data [Array] data that is provided to the function.  This accepts
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2010
     * either a single item or an array.  If an array is provided, the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2011
     * function is executed with one parameter for each array item.  If
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2012
     * you need to pass a single array parameter, it needs to be wrapped in
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2013
     * an array [myarray].
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2014
     * @param periodic {boolean} if true, executes continuously at supplied 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2015
     * interval until canceled.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2016
     * @return {object} a timer object. Call the cancel() method on this object to 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2017
     * stop the timer.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2018
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2019
    later = function(when, o, fn, data, periodic) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2020
        when = when || 0; 
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2021
        o = o || {};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2022
        var m=fn, d=data, f, r;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2023
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2024
        if (L.isString(fn)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2025
            m = o[fn];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2026
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2027
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2028
        if (!m) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2029
            Y.error("method undefined");
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
        if (!L.isArray(d)) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2033
            d = [data];
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
        f = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2037
            m.apply(o, d);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2038
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2039
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2040
        r = (periodic) ? setInterval(f, when) : setTimeout(f, when);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2041
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2042
        return {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2043
            id: r,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2044
            interval: periodic,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2045
            cancel: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2046
                if (this.interval) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2047
                    clearInterval(r);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2048
                } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2049
                    clearTimeout(r);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2050
                }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2051
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2052
        };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2053
    };
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2054
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2055
    Y.later = later;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2056
    L.later = later;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2057
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2058
})();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2059
(function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2060
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2061
    // var min = ['yui-base', 'log', 'lang', 'array', 'core'], core, C = Y.config;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2062
    var min = ['yui-base'], core, C = Y.config;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2063
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2064
    // apply the minimal required functionality
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2065
    Y.use.apply(Y, min);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2066
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2067
    Y.log(Y.id + ' initialized', 'info', 'yui');
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2068
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2069
    if (C.core) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2070
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2071
        core = C.core;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2072
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2073
    } else {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2074
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2075
        core = ['queue-base', 'get', 'loader'];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2076
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2077
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2078
    Y.use.apply(Y, core);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2079
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
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
  2085
}, '3.0.0b1' );