src/cm/media/js/lib/yui/yui3-3.15.0/build/jsonp/jsonp.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 602 e16a97fb364a
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
602
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     1
YUI.add('jsonp', function (Y, NAME) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     2
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     3
var isFunction = Y.Lang.isFunction;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     4
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     5
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     6
 * <p>Provides a JSONPRequest class for repeated JSONP calls, and a convenience
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     7
 * method Y.jsonp(url, callback) to instantiate and send a JSONP request.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     8
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
     9
 * <p>Both the constructor as well as the convenience function take two
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    10
 * parameters: a url string and a callback.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    11
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    12
 * <p>The url provided must include the placeholder string
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    13
 * &quot;{callback}&quot; which will be replaced by a dynamically
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    14
 * generated routing function to pass the data to your callback function.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    15
 * An example url might look like
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    16
 * &quot;http://example.com/service?callback={callback}&quot;.</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    17
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    18
 * <p>The second parameter can be a callback function that accepts the JSON
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    19
 * payload as its argument, or a configuration object supporting the keys:</p>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    20
 * <ul>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    21
 *   <li>on - map of callback subscribers
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    22
 *      <ul>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    23
 *         <li>success - function handler for successful transmission</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    24
 *         <li>failure - function handler for failed transmission</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    25
 *         <li>timeout - function handler for transactions that timeout</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    26
 *      </ul>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    27
 *  </li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    28
 *  <li>format  - override function for inserting the proxy name in the url</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    29
 *  <li>timeout - the number of milliseconds to wait before giving up</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    30
 *  <li>context - becomes <code>this</code> in the callbacks</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    31
 *  <li>args    - array of subsequent parameters to pass to the callbacks</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    32
 *  <li>allowCache - use the same proxy name for all requests? (boolean)</li>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    33
 * </ul>
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    34
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    35
 * @module jsonp
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    36
 * @class JSONPRequest
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    37
 * @constructor
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    38
 * @param url {String} the url of the JSONP service
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    39
 * @param callback {Object|Function} the default callback configuration or
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    40
 *                                   success handler
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    41
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    42
function JSONPRequest() {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    43
    this._init.apply(this, arguments);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    44
}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    45
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    46
JSONPRequest.prototype = {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    47
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    48
     * Set up the success and failure handlers and the regex pattern used
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    49
     * to insert the temporary callback name in the url.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    50
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    51
     * @method _init
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    52
     * @param url {String} the url of the JSONP service
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    53
     * @param callback {Object|Function} Optional success callback or config
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    54
     *                  object containing success and failure functions and
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    55
     *                  the url regex.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    56
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    57
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    58
    _init : function (url, callback) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    59
        this.url = url;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    60
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    61
        /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    62
         * Map of the number of requests currently pending responses per
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    63
         * generated proxy.  Used to ensure the proxy is not flushed if the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    64
         * request times out and there is a timeout handler and success
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    65
         * handler, and used by connections configured to allowCache to make
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    66
         * sure the proxy isn't deleted until the last response has returned.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    67
         *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    68
         * @property _requests
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    69
         * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    70
         * @type {Object}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    71
         */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    72
        this._requests = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    73
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    74
        /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    75
         * Map of the number of timeouts received from the destination url
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    76
         * by generated proxy.  Used to ensure the proxy is not flushed if the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    77
         * request times out and there is a timeout handler and success
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    78
         * handler, and used by connections configured to allowCache to make
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    79
         * sure the proxy isn't deleted until the last response has returned.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    80
         *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    81
         * @property _timeouts
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    82
         * @private
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    83
         * @type {Object}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    84
         */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    85
        this._timeouts = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    86
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    87
        // Accept a function, an object, or nothing
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    88
        callback = (isFunction(callback)) ?
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    89
            { on: { success: callback } } :
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    90
            callback || {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    91
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    92
        var subs = callback.on || {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    93
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    94
        if (!subs.success) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    95
            subs.success = this._defaultCallback(url, callback);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    96
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    97
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    98
        // Apply defaults and store
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
    99
        this._config = Y.merge({
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   100
                context: this,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   101
                args   : [],
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   102
                format : this._format,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   103
                allowCache: false
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   104
            }, callback, { on: subs });
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   105
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   106
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   107
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   108
     * Override this method to provide logic to default the success callback if
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   109
     * it is not provided at construction.  This is overridden by jsonp-url to
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   110
     * parse the callback from the url string.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   111
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   112
     * @method _defaultCallback
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   113
     * @param url {String} the url passed at construction
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   114
     * @param config {Object} (optional) the config object passed at
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   115
     *                        construction
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   116
     * @return {Function}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   117
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   118
    _defaultCallback: function () {},
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   119
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   120
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   121
     * Issues the JSONP request.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   122
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   123
     * @method send
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   124
     * @param args* {any} any additional arguments to pass to the url formatter
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   125
     *              beyond the base url and the proxy function name
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   126
     * @chainable
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   127
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   128
    send : function () {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   129
        var self   = this,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   130
            args   = Y.Array(arguments, 0, true),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   131
            config = self._config,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   132
            proxy  = self._proxy || Y.guid(),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   133
            url;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   134
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   135
        // TODO: support allowCache as time value
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   136
        if (config.allowCache) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   137
            self._proxy = proxy;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   138
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   139
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   140
        if (self._requests[proxy] === undefined) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   141
            self._requests[proxy] = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   142
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   143
        if (self._timeouts[proxy] === undefined) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   144
            self._timeouts[proxy] = 0;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   145
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   146
        self._requests[proxy]++;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   147
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   148
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   149
        args.unshift(self.url, 'YUI.Env.JSONP.' + proxy);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   150
        url = config.format.apply(self, args);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   151
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   152
        if (!config.on.success) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   153
            return self;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   154
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   155
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   156
        function wrap(fn, isTimeout) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   157
            return (isFunction(fn)) ?
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   158
                function (data) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   159
                    var execute = true,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   160
                        counter = '_requests';
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   161
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   162
                    //if (config.allowCache) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   163
                        // A lot of wrangling to make sure timeouts result in
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   164
                        // fewer success callbacks, but the proxy is properly
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   165
                        // cleaned up.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   166
                        if (isTimeout) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   167
                            ++self._timeouts[proxy];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   168
                            --self._requests[proxy];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   169
                        } else {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   170
                            if (!self._requests[proxy]) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   171
                                execute = false;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   172
                                counter = '_timeouts';
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   173
                            }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   174
                            --self[counter][proxy];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   175
                        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   176
                    //}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   177
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   178
                    if (!self._requests[proxy] && !self._timeouts[proxy]) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   179
                        delete YUI.Env.JSONP[proxy];
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   180
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   181
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   182
                    if (execute) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   183
                        fn.apply(config.context, [data].concat(config.args));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   184
                    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   185
                } :
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   186
                null;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   187
        }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   188
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   189
        // Temporary un-sandboxed function alias
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   190
        // TODO: queuing
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   191
        YUI.Env.JSONP[proxy] = wrap(config.on.success);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   192
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   193
        // Y.Get transactions block each other by design, but can easily
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   194
        //  be made non-blocking by just calling execute() on the transaction.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   195
        // https://github.com/yui/yui3/pull/393#issuecomment-11961608
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   196
        Y.Get.js(url, {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   197
            onFailure : wrap(config.on.failure),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   198
            onTimeout : wrap(config.on.timeout, true),
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   199
            timeout   : config.timeout,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   200
            charset   : config.charset,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   201
            attributes: config.attributes,
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   202
            async     : config.async
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   203
        }).execute();
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   204
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   205
        return self;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   206
    },
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   207
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   208
    /**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   209
     * Default url formatter.  Looks for callback= in the url and appends it
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   210
     * if not present.  The supplied proxy name will be assigned to the query
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   211
     * param.  Override this method by passing a function as the
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   212
     * &quot;format&quot; property in the config object to the constructor.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   213
     *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   214
     * @method _format
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   215
     * @param url { String } the original url
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   216
     * @param proxy {String} the function name that will be used as a proxy to
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   217
     *      the configured callback methods.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   218
     * @param args* {any} additional args passed to send()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   219
     * @return {String} fully qualified JSONP url
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   220
     * @protected
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   221
     */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   222
    _format: function (url, proxy) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   223
        return url.replace(/\{callback\}/, proxy);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   224
    }
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   225
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   226
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   227
Y.JSONPRequest = JSONPRequest;
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   228
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   229
/**
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   230
 *
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   231
 * @method jsonp
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   232
 * @param url {String} the url of the JSONP service with the {callback}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   233
 *          placeholder where the callback function name typically goes.
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   234
 * @param c {Function|Object} Callback function accepting the JSON payload
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   235
 *          as its argument, or a configuration object (see above).
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   236
 * @param args* {any} additional arguments to pass to send()
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   237
 * @return {JSONPRequest}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   238
 * @static
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   239
 * @for YUI
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   240
 */
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   241
Y.jsonp = function (url,c) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   242
    var req = new Y.JSONPRequest(url,c);
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   243
    return req.send.apply(req, Y.Array(arguments, 2, true));
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   244
};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   245
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   246
if (!YUI.Env.JSONP) {
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   247
    YUI.Env.JSONP = {};
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   248
}
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   249
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   250
e16a97fb364a Use YUI 3.15
gibus
parents:
diff changeset
   251
}, '@VERSION@', {"requires": ["get", "oop"]});