| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 | "use strict";// Copyright 2012 United States Government, as represented by the Secretary of Defense, Under// Secretary of Defense (Personnel & Readiness).// // Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except// in compliance with the License. You may obtain a copy of the License at// //   http://www.apache.org/licenses/LICENSE-2.0// // Unless required by applicable law or agreed to in writing, software distributed under the License// is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express// or implied. See the License for the specific language governing permissions and limitations under// the License./// vwf/view/document extends a view interface up to the browser document. When vwf/view/document/// is active, scripts on the main page may make (reflected) kernel calls:/// ///     window.vwf_view.kernel.createChild( nodeID, childName, childComponent, childURI, function( childID ) {///         ...///     } );/// /// And receive view calls:/// ///     window.vwf_view.createdNode = function( nodeID, childID, childExtendsID, childImplementsIDs,///         childSource, childType, childIndex, childName, callback /- ( ready ) -/ ) {///         ...///     }/// /// @module vwf/view/document/// @requires vwf/viewdefine( [ "module", "vwf/view", "vwf/utility", "jquery" ], function( module, view, utility, jQuery ) {    return view.load( module, {        // == Module Definition ====================================================================        initialize: function() {            window.vwf_view = this;        },        // == Model API ============================================================================        createdNode: function( nodeID, childID, childExtendsID, childImplementsIDs,                childSource, childType, childURI, childName, callback /* ( ready ) */ ) {            var self = this;            // At the root node of the application, load the UI chrome if available.            if ( childID == this.kernel.application() &&                    ( window.location.protocol == "http:" || window.location.protocol == "https:" ) ) {                // Suspend the queue.                callback( false );                // Load the file and insert it into the main page.                var container = jQuery( "body" ).append( "<div />" ).children( ":last" );                container.load( "admin/chrome", function( responseText, textStatus ) {                    // If the overlay attached a `createdNode` handler, forward this first call                    // since the overlay will have missed it.                    if ( self.createdNode !== Object.getPrototypeOf( self ).createdNode ) {                        self.createdNode( nodeID, childID, childExtendsID, childImplementsIDs,                            childSource, childType, childURI, childName );                    }                    // Remove the container div if an error occurred or if we received an empty                    // result. The server sends an empty document when the application doesn't                    // provide a chrome file.                    if ( ! ( textStatus == "success" || textStatus == "notmodified" ) || responseText == "" ) {                        container.remove();                    }                    // Resume the queue.                    callback( true );                } );            }        },    }, function( viewFunctionName ) {        // == View API =============================================================================    } );} );
 |