src/cm/media/js/lib/yui/yui_3.10.3/build/app-content/app-content.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 525 89ef5ed3c48b
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
525
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     1
/*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     2
YUI 3.10.3 (build 2fb5187)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     3
Copyright 2013 Yahoo! Inc. All rights reserved.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     4
Licensed under the BSD License.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     5
http://yuilibrary.com/license/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     6
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     7
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     8
YUI.add('app-content', function (Y, NAME) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     9
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    10
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    11
`Y.App` extension that provides pjax-style content fetching and handling.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
@module app
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
@submodule app-content
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
@since 3.7.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
**/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
var PjaxContent = Y.PjaxContent;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
`Y.App` extension that provides pjax-style content fetching and handling.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
This makes it easy to fetch server rendered content for URLs using Ajax. The
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
HTML content returned from the server will be view-ified and set as the app's
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
main content, making it seamless to use a mixture of server and client rendered
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
views.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
When the `"app-content"` module is used, it will automatically mix itself into
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
`Y.App`, and it provides three main features:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
  - **`Y.App.Content.route`**: A stack of middleware which forms a pjax-style
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
    content route.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
  - **`loadContent()`**: Route middleware which load content from a server. This
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
    makes an Ajax request for the requested URL, parses the returned content and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
    puts it on the route's response object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
  - **`showContent()`**: Method which provides an easy way to view-ify HTML
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
    content which should be shown as an app's active/visible view.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
The following is an example of how these features can be used:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
    // Creates a new app and registers the `"post"` view.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
    var app = new Y.App({
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
        views: {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
            post: {type: Y.PostView}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
    });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
    // Uses a simple server rendered content route for the About page.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
    app.route('/about/', Y.App.Content.route);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
    // Uses the `loadContent()` middleware to fetch the contents of the post
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
    // from the server and shows that content in a `"post"` view.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
    app.route('/posts/:id/', 'loadContent', function (req, res, next) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
        this.showContent(res.content.node, {view: 'post'});
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
    });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
@class App.Content
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
@uses PjaxContent
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
@extensionfor App
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
@since 3.7.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
**/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
function AppContent() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
    PjaxContent.apply(this, arguments);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
A stack of middleware which forms a pjax-style content route.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
This route will load the rendered HTML content from the server, then create and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
show a new view using those contents.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
@property route
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
@type Array
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
@static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
@since 3.7.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
**/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
AppContent.route = ['loadContent', '_contentRoute'];
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
AppContent.prototype = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
    // -- Public Methods -------------------------------------------------------
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
    Sets this app's `activeView` attribute using the specified `content`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
    This provides an easy way to view-ify HTML content which should be shown as
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
    this app's active/visible view. This method will determine the appropriate
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
    view `container` node based on the specified `content`. By default, a new
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
    `Y.View` instance will be created unless `options.view` is specified.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
    Under the hood, this method calls the `showView()` method, so refer to its
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
    docs for more information.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
    @method showContent
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
    @param {HTMLElement|Node|String} content The content to show, it may be
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
        provided as a selector string, a DOM element, or a `Y.Node` instance.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
    @param {Object} [options] Optional objects containing any of the following
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
        properties in addition to any `showView()` options:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
      @param {Object|String} [options.view] The name of a view defined in this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
          app's `views`, or an object with the following properties:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
        @param {String} options.view.name The name of a view defined in this
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
            app's `views`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
        @param {Object} [options.view.config] Optional configuration to use when
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
            creating the new view instance. This config object can also be used
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
            to update an existing or preserved view's attributes when
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
            `options.update` is `true`. **Note:** If a `container` is specified,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
            it will be overridden by the `content` specified in the first
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
            argument.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
    @param {Function} [callback] Optional callback function to call after the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
        new `activeView` is ready to use. **Note:** this will override
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
        `options.callback` and it can be specified as either the second or third
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
        argument. The function will be passed the following:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
      @param {View} callback.view A reference to the new `activeView`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
    @since 3.7.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
    @see App.showView()
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
    **/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   123
    showContent: function (content, options, callback) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
        // Makes sure we have a node instance, and will query selector strings.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
        content = Y.one(content);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
        // Support the callback function being either the second or third arg.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
        if (typeof options === 'function') {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
            options  = {callback: options};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
            callback = null;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
        // Mix in default option to *not* render the view because presumably we
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
        // have pre-rendered content here. This also creates a copy so we can
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
        // modify the object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
        options = Y.merge({render: false}, options);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
        var view       = options.view || '',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
            viewName   = typeof view === 'string' ? view : view.name,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
            viewConfig = typeof view !== 'string' ? view.config : {},
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
            viewInfo   = this.getViewInfo(viewName),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
            container, template, type, ViewConstructor;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
        // Remove `view` from the `options` which will be passed along to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
        // `showView()` method.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
        delete options.view;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
        // When the specified `content` is a document fragment, we want to see
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
        // if it only contains a single node, and use that as the content. This
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
        // checks `childNodes` which will include text nodes.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
        if (content && content.isFragment() &&
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
                content.get('childNodes').size() === 1) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
            content = content.get('firstChild');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
        // When the `content` is an element node (`nodeType` 1), we can use it
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
        // as-is for the `container`. Otherwise, we'll construct a new container
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
        // based on the `options.view`'s `containerTemplate`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
        if (content && content.get('nodeType') === 1) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
            container = content;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
        } else {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
            type = (viewInfo && viewInfo.type) || Y.View;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
            // Looks for a namespaced constructor function on `Y`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
            ViewConstructor = typeof type === 'string' ?
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
                    Y.Object.getValue(Y, type.split('.')) : type;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
            // Find the correct node template for the view.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
            template  = ViewConstructor.prototype.containerTemplate;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
            container = Y.Node.create(template);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
            // Append the document fragment to the newly created `container`
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
            // node. This is the worst case where we have to create a wrapper
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
            // node around the `content`.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
            container.append(content);
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
        // Makes sure the view is created using _our_ `container` node.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
        viewConfig = Y.merge(viewConfig, {container: container});
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
        // Finally switch to the new `activeView`. We want to make sure `view`
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
        // is a string if it's falsy, that way a new view will be created.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
        return this.showView(viewName, viewConfig, options, callback);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
    // -- Protected Methods ----------------------------------------------------
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
    Provides a default content route which will show a server rendered view.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
    **Note:** This route callback assumes that it's called after the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
    `loadContent()` middleware.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
    @method _contentRoute
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
    @param {Object} req Request object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   197
    @param {Object} res Response Object.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   198
    @param {Function} next Function to pass control to the next route callback.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   199
    @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
    @since 3.7.0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
    @see Y.App.Content.route
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
    **/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
    _contentRoute: function (req, res, next) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
        var content = res.content,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
            doc     = Y.config.doc,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
            activeViewHandle;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
        // We must have some content to work with.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
        if (!(content && content.node)) { return next(); }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
        if (content.title && doc) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
            // Make sure the `activeView` does actually change before we go
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
            // messing with the page title.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
            activeViewHandle = this.onceAfter('activeViewChange', function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
                doc.title = content.title;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
            });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
        this.showContent(content.node);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
        // Detach the handle just in case.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
        if (activeViewHandle) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
            activeViewHandle.detach();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
        next();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
// Mix statics.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
AppContent.ATTRS = Y.Attribute.protectAttrs(PjaxContent.ATTRS);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   233
// Mix prototype.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
Y.mix(AppContent, PjaxContent, false, null, 1);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
// -- Namespace ----------------------------------------------------------------
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
Y.App.Content = AppContent;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
Y.Base.mix(Y.App, [AppContent]);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
}, '3.10.3', {"requires": ["app-base", "pjax-content"]});