src/cm/media/js/lib/yui/yui_3.10.3/docs/promise/basic-example.html
author gibus
Tue, 16 Jul 2013 14:29:46 +0200
changeset 525 89ef5ed3c48b
permissions -rw-r--r--
Upgrades to yui 3.10.3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
525
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     1
<!DOCTYPE html>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     2
<html lang="en">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     3
<head>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     4
    <meta charset="utf-8">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     5
    <title>Example: Wrapping async transactions with promises</title>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     6
    <link rel="stylesheet" href="http://fonts.googleapis.com/css?family=PT+Sans:400,700,400italic,700italic">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     7
    <link rel="stylesheet" href="../../build/cssgrids/cssgrids-min.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     8
    <link rel="stylesheet" href="../assets/css/main.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     9
    <link rel="stylesheet" href="../assets/vendor/prettify/prettify-min.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    10
    <link rel="shortcut icon" type="image/png" href="../assets/favicon.png">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    11
    <script src="../../build/yui/yui-min.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
</head>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
<body>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
<!--
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
<a href="https://github.com/yui/yui3"><img style="position: absolute; top: 0; right: 0; border: 0;" src="https://s3.amazonaws.com/github/ribbons/forkme_right_darkblue_121621.png" alt="Fork me on GitHub"></a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
-->
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
<div id="doc">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
    <div id="hd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
        <h1><img src="http://yuilibrary.com/img/yui-logo.png"></h1>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
        <a href="#toc" class="jump">Jump to Table of Contents</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
            <h1>Example: Wrapping async transactions with promises</h1>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
    <div class="yui3-g">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
        <div class="yui3-u-3-4">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
            <div id="main">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
                <div class="content"><style scoped>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
    #demo div {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
        padding: 5px;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
        margin: 2px;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
    .success {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
        background: #BBE599;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
    .error {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
        background: #ffc5c4;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
</style>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
<div class="intro">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
    <p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
        This example shows how to create a cache for the GitHub Contributors API that returns promises representing the values you fetched. In order to access the API we use the JSONP module.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
    </p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
<div class="example yui3-skin-sam">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
    <div id="demo"></div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
    <script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
YUI().use('node', 'jsonp', 'promise', 'escape', function (Y) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
// A cache for GitHub user data
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
var GitHub = (function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
    var cache = {},
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
        githubURL = 'https://api.github.com/users/{user}?callback={callback}';
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
    function getUserURL(name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
        return Y.Lang.sub(githubURL, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
            user: name
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
    // Fetches a URL, stores a promise in the cache and returns it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
    function fetch(url) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
        var promise = new Y.Promise(function (fulfill, reject) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
            Y.jsonp(url, function (res) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
                var meta = res.meta,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
                    data = res.data;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
                // Check for a successful response, otherwise reject the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
                // promise with the message returned by the GitHub API.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
                if (meta.status >= 200 && meta.status < 300) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
                    fulfill(data);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
                } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
                    reject(new Error(data.message));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
                }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
            // Add a timeout in case the URL is completely wrong
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
            // or GitHub is too busy
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
            setTimeout(function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
                // Once a promise has been fulfilled or rejected it will never
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
                // change its state again, so we can safely call reject() after
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
                // some time. If it was already fulfilled or rejected, nothing will
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
                // happen
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
                reject(new Error('Timeout'));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
            }, 10000);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
        // store the promise in the cache object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
        cache[url] = promise;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
        return promise;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
    return {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
        getUser: function (name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
            var url = getUserURL(name);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
            if (cache[url]) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
                // If we have already stored the promise in the cache we just return it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
                return cache[url];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
                // fetch() will make a JSONP request, cache the promise and return it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
                return fetch(url);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
    };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
}());
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
var demo = Y.one('#demo'),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
    SUCCESS_TEMPLATE = '<div class="success">Loaded {name}</a>\'s data! ' +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
                        '<a href="{link}">Link to profile</a></div>',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
    FAILURE_TEMPLATE = '<div class="error">{message}</div>';
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
function renderUser(user) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
    demo.append(Y.Lang.sub(SUCCESS_TEMPLATE, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   123
        // escape the values gotten from the GitHub API to avoid unexpected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
        // HTML injection which could be an XSS vulnerability
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
        name: Y.Escape.html(user.login),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
        link: Y.Escape.html(user.html_url)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
    }));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
function showError(err) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
    demo.append(Y.Lang.sub(FAILURE_TEMPLATE, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
        message: Y.Escape.html(err.message)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
    }));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
GitHub.getUser('yui').then(renderUser, showError);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
GitHub.getUser('y u i').then(renderUser, showError);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
});
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
<h3 id="creating-a-cache">Creating a Cache</h3>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
    A cache is an object that keeps track of which operations have already been performed, stores the results and returns the stored result if the operation was already performed. In this case, since we are fetching content with JSONP, the operations are asynchronous so we will store promises representing them.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
<pre class="code prettyprint">&#x2F;&#x2F; We create a simple module with a private cache object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
var GitHub = (function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
    var cache = {};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
    return {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
        getUser: function (name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
            &#x2F;&#x2F; This method will return a promise
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
    };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
}());</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
    Given a certain function that takes a user name and returns the corresponding GitHub API URL, then a method that caches the user data will simply check the private cache object or fetch the result.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
<pre class="code prettyprint">getUser: function (name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
    var url = getUserURL(name);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
    if (cache[url]) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
        &#x2F;&#x2F; If we have already stored the promise in the cache we just return it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
        return cache[url];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
    } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
        &#x2F;&#x2F; fetch() will make a JSONP request, cache the promise and return it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
        return fetch(url);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
}</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   177
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   178
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   179
<h3 id="resolving-and-returning-promises">Resolving and Returning Promises</h3>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
<p>Our <code>fetch()</code> function will create a promise and fulfill it or reject it based on the result of the JSONP request. Following the steps described in the <a href="index.html##creating-a-promise">User Guide</a>, we create a promise and call <code>Y.jsonp</code> inside its initialization function.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
<pre class="code prettyprint">&#x2F;&#x2F; Fetches a URL, stores a promise in the cache and returns it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
function fetch(url) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
    var promise = new Y.Promise(function (fulfill, reject) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
        Y.jsonp(url, function (res) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
            var meta = res.meta,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
                data = res.data;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
            &#x2F;&#x2F; Check for a successful response, otherwise reject the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
            &#x2F;&#x2F; promise with the message returned by the GitHub API.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
            if (meta.status &gt;= 200 &amp;&amp; meta.status &lt; 300) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
                fulfill(data);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
                reject(new Error(data.message));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   197
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   198
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   199
        &#x2F;&#x2F; Add a timeout in case the URL is completely wrong
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
        &#x2F;&#x2F; or GitHub is too busy
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
        setTimeout(function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
            &#x2F;&#x2F; Once a promise has been fulfilled or rejected it will never
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
            &#x2F;&#x2F; change its state again, so we can safely call reject() after
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
            &#x2F;&#x2F; some time. If it was already fulfilled or rejected, nothing will
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
            &#x2F;&#x2F; happen
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
            reject(new Error(&#x27;Timeout&#x27;));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
        }, 10000);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
    });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
    &#x2F;&#x2F; store the promise in the cache object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
    cache[url] = promise;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
    return promise;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
}</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
<h3 id="wiring-it-all-together">Wiring It All Together</h3>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
<p>Here is the complete code for this example. You will notice that it contains a request for a user called "y u i" which likely does not exist. This illustrates how promises help you handle errors. While it may be tempting to skip adding an error callback, it is highly recommended that you add one and provide feedback to your users when things go wrong.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
<h4 id="html">HTML</h4>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
<pre class="code prettyprint">&lt;div id=&quot;demo&quot;&gt;&lt;&#x2F;div&gt;</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
<h4 id="css">CSS</h4>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
<pre class="code prettyprint">&lt;style scoped&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
    #demo div {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
        padding: 5px;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
        margin: 2px;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
    .success {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
        background: #BBE599;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   233
    .error {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
        background: #ffc5c4;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
&lt;&#x2F;style&gt;</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
<h4 id="javascript">JavaScript</h4>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
<pre class="code prettyprint">&lt;script&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
YUI().use(&#x27;node&#x27;, &#x27;jsonp&#x27;, &#x27;promise&#x27;, &#x27;escape&#x27;, function (Y) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   242
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   243
&#x2F;&#x2F; A cache for GitHub user data
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   244
var GitHub = (function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   245
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   246
    var cache = {},
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   247
        githubURL = &#x27;https:&#x2F;&#x2F;api.github.com&#x2F;users&#x2F;{user}?callback={callback}&#x27;;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   248
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   249
    function getUserURL(name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   250
        return Y.Lang.sub(githubURL, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   251
            user: name
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   252
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   253
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   254
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   255
    &#x2F;&#x2F; Fetches a URL, stores a promise in the cache and returns it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   256
    function fetch(url) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   257
        var promise = new Y.Promise(function (fulfill, reject) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   258
            Y.jsonp(url, function (res) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   259
                var meta = res.meta,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   260
                    data = res.data;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   261
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   262
                &#x2F;&#x2F; Check for a successful response, otherwise reject the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   263
                &#x2F;&#x2F; promise with the message returned by the GitHub API.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   264
                if (meta.status &gt;= 200 &amp;&amp; meta.status &lt; 300) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   265
                    fulfill(data);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   266
                } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   267
                    reject(new Error(data.message));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   268
                }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   269
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   270
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   271
            &#x2F;&#x2F; Add a timeout in case the URL is completely wrong
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   272
            &#x2F;&#x2F; or GitHub is too busy
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   273
            setTimeout(function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   274
                &#x2F;&#x2F; Once a promise has been fulfilled or rejected it will never
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   275
                &#x2F;&#x2F; change its state again, so we can safely call reject() after
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   276
                &#x2F;&#x2F; some time. If it was already fulfilled or rejected, nothing will
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   277
                &#x2F;&#x2F; happen
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   278
                reject(new Error(&#x27;Timeout&#x27;));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   279
            }, 10000);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   280
        });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   281
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   282
        &#x2F;&#x2F; store the promise in the cache object
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   283
        cache[url] = promise;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   284
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   285
        return promise;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   286
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   287
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   288
    return {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   289
        getUser: function (name) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   290
            var url = getUserURL(name);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   291
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   292
            if (cache[url]) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   293
                &#x2F;&#x2F; If we have already stored the promise in the cache we just return it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   294
                return cache[url];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   295
            } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   296
                &#x2F;&#x2F; fetch() will make a JSONP request, cache the promise and return it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   297
                return fetch(url);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   298
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   299
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   300
    };
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   301
}());
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   302
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   303
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   304
var demo = Y.one(&#x27;#demo&#x27;),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   305
    SUCCESS_TEMPLATE = &#x27;&lt;div class=&quot;success&quot;&gt;Loaded {name}&lt;&#x2F;a&gt;\&#x27;s data! &#x27; +
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   306
                        &#x27;&lt;a href=&quot;{link}&quot;&gt;Link to profile&lt;&#x2F;a&gt;&lt;&#x2F;div&gt;&#x27;,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   307
    FAILURE_TEMPLATE = &#x27;&lt;div class=&quot;error&quot;&gt;{message}&lt;&#x2F;div&gt;&#x27;;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   308
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   309
function renderUser(user) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   310
    demo.append(Y.Lang.sub(SUCCESS_TEMPLATE, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   311
        &#x2F;&#x2F; escape the values gotten from the GitHub API to avoid unexpected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   312
        &#x2F;&#x2F; HTML injection which could be an XSS vulnerability
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   313
        name: Y.Escape.html(user.login),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   314
        link: Y.Escape.html(user.html_url)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   315
    }));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   316
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   317
function showError(err) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   318
    demo.append(Y.Lang.sub(FAILURE_TEMPLATE, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   319
        message: Y.Escape.html(err.message)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   320
    }));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   321
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   322
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   323
GitHub.getUser(&#x27;yui&#x27;).then(renderUser, showError);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   324
GitHub.getUser(&#x27;y u i&#x27;).then(renderUser, showError);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   325
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   326
});
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   327
&lt;&#x2F;script&gt;</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   328
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   329
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   330
            </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   331
        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   332
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   333
        <div class="yui3-u-1-4">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   334
            <div class="sidebar">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   335
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   336
                    <div id="toc" class="sidebox">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   337
                        <div class="hd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   338
                            <h2 class="no-toc">Table of Contents</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   339
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   340
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   341
                        <div class="bd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   342
                            <ul class="toc">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   343
<li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   344
<a href="#creating-a-cache">Creating a Cache</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   345
</li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   346
<li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   347
<a href="#resolving-and-returning-promises">Resolving and Returning Promises</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   348
</li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   349
<li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   350
<a href="#wiring-it-all-together">Wiring It All Together</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   351
<ul class="toc">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   352
<li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   353
<a href="#html">HTML</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   354
</li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   355
<li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   356
<a href="#css">CSS</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   357
</li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   358
<li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   359
<a href="#javascript">JavaScript</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   360
</li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   361
</ul>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   362
</li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   363
</ul>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   364
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   365
                    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   366
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   367
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   368
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   369
                    <div class="sidebox">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   370
                        <div class="hd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   371
                            <h2 class="no-toc">Examples</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   372
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   373
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   374
                        <div class="bd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   375
                            <ul class="examples">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   376
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   377
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   378
                                        <li data-description="Wrapping async transactions with promises">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   379
                                            <a href="basic-example.html">Wrapping async transactions with promises</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   380
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   381
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   382
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   383
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   384
                                        <li data-description="Extend Y.Promise to create classes that encapsulate standard transaction logic in descriptive method names">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   385
                                            <a href="subclass-example.html">Subclassing Y.Promise</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   386
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   387
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   388
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   389
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   390
                                        <li data-description="Extend the Promise class to create your own Node plugin that chains transitions">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   391
                                            <a href="plugin-example.html">Creating a Node Plugin that chains transitions</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   392
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   393
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   394
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   395
                            </ul>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   396
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   397
                    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   398
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   399
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   400
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   401
            </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   402
        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   403
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   404
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   405
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   406
<script src="../assets/vendor/prettify/prettify-min.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   407
<script>prettyPrint();</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   408
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   409
<script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   410
YUI.Env.Tests = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   411
    examples: [],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   412
    project: '../assets',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   413
    assets: '../assets/promise',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   414
    name: 'basic-example',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   415
    title: 'Wrapping async transactions with promises',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   416
    newWindow: '',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   417
    auto:  false 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   418
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   419
YUI.Env.Tests.examples.push('basic-example');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   420
YUI.Env.Tests.examples.push('subclass-example');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   421
YUI.Env.Tests.examples.push('plugin-example');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   422
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   423
</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   424
<script src="../assets/yui/test-runner.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   425
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   426
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   427
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   428
</body>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   429
</html>