| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189 | <!DOCTYPE html><html><head>  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  <title>The source code</title>  <link href="../resources/prettify/prettify.css" type="text/css" rel="stylesheet" />  <script type="text/javascript" src="../resources/prettify/prettify.js"></script>  <style type="text/css">    .highlight { display: block; background-color: #ddd; }  </style>  <script type="text/javascript">    function highlight() {      document.getElementById(location.hash.replace(/#/, "")).className = "highlight";    }  </script></head><body onload="prettyPrint(); highlight();">  <pre class="prettyprint lang-js"><span id='Ext-container-Viewport'>/**</span> * A specialized container representing the viewable application area (the browser viewport). * * The Viewport renders itself to the document body, and automatically sizes itself to the size of * the browser viewport and manages window resizing. There may only be one Viewport created * in a page. * * Like any {@link Ext.container.Container Container}, a Viewport will only perform sizing and positioning * on its child Components if you configure it with a {@link #layout}. * * A Common layout used with Viewports is {@link Ext.layout.container.Border border layout}, but if the * required layout is simpler, a different layout should be chosen. * * For example, to simply make a single child item occupy all available space, use * {@link Ext.layout.container.Fit fit layout}. * * To display one "active" item at full size from a choice of several child items, use * {@link Ext.layout.container.Card card layout}. * * Inner layouts are available because all {@link Ext.panel.Panel Panel}s * added to the Viewport, either through its {@link #cfg-items}, or the {@link #method-add} * method of any of its child Panels may themselves have a layout. * * The Viewport does not provide scrolling, so child Panels within the Viewport should provide * for scrolling if needed using the {@link #autoScroll} config. * * An example showing a classic application border layout: * *     @example *     Ext.create('Ext.container.Viewport', { *         layout: 'border', *         items: [{ *             region: 'north', *             html: '<h1 class="x-panel-header">Page Title</h1>', *             border: false, *             margins: '0 0 5 0' *         }, { *             region: 'west', *             collapsible: true, *             title: 'Navigation', *             width: 150 *             // could use a TreePanel or AccordionLayout for navigational items *         }, { *             region: 'south', *             title: 'South Panel', *             collapsible: true, *             html: 'Information goes here', *             split: true, *             height: 100, *             minHeight: 100 *         }, { *             region: 'east', *             title: 'East Panel', *             collapsible: true, *             split: true, *             width: 150 *         }, { *             region: 'center', *             xtype: 'tabpanel', // TabPanel itself has no title *             activeTab: 0,      // First tab active by default *             items: { *                 title: 'Default Tab', *                 html: 'The first tab\'s content. Others may be added dynamically' *             } *         }] *     }); */Ext.define('Ext.container.Viewport', {    extend: 'Ext.container.Container',    alias: 'widget.viewport',    requires: ['Ext.EventManager'],    alternateClassName: 'Ext.Viewport',    // Privatize config options which, if used, would interfere with the    // correct operation of the Viewport as the sole manager of the    // layout of the document body.<span id='Ext-container-Viewport-cfg-applyTo'>    /**</span>     * @cfg {String/HTMLElement/Ext.Element} applyTo     * @private     */<span id='Ext-container-Viewport-cfg-allowDomMove'>    /**</span>     * @cfg {Boolean} allowDomMove     * @private     */<span id='Ext-container-Viewport-cfg-renderTo'>    /**</span>     * @cfg {String/HTMLElement/Ext.Element} renderTo     * Always renders to document body.     * @private     */<span id='Ext-container-Viewport-cfg-height'>    /**</span>     * @cfg {Number} height     * Sets itself to viewport width.     * @private     */<span id='Ext-container-Viewport-cfg-width'>    /**</span>     * @cfg {Number} width     * Sets itself to viewport height.     * @private     */<span id='Ext-container-Viewport-property-isViewport'>    /**</span>     * @property {Boolean} isViewport     * `true` in this class to identify an object as an instantiated Viewport, or subclass thereof.     */    isViewport: true,    ariaRole: 'application',        preserveElOnDestroy: true,    initComponent : function() {        var me = this,            html = document.body.parentNode,            el;        // Get the DOM disruption over with beforfe the Viewport renders and begins a layout        Ext.getScrollbarSize();                // Clear any dimensions, we will size later on        me.width = me.height = undefined;        me.callParent(arguments);        Ext.fly(html).addCls(Ext.baseCSSPrefix + 'viewport');        if (me.autoScroll) {            delete me.autoScroll;            Ext.fly(html).setStyle('overflow', 'auto');        }        me.el = el = Ext.getBody();        el.setHeight = Ext.emptyFn;        el.setWidth = Ext.emptyFn;        el.setSize = Ext.emptyFn;        el.dom.scroll = 'no';        me.allowDomMove = false;        me.renderTo = me.el;    },        onRender: function() {        var me = this;        me.callParent(arguments);        // Important to start life as the proper size (to avoid extra layouts)        // But after render so that the size is not stamped into the body        me.width = Ext.Element.getViewportWidth();        me.height = Ext.Element.getViewportHeight();    },    afterFirstLayout: function() {        var me = this;        me.callParent(arguments);        setTimeout(function() {            Ext.EventManager.onWindowResize(me.fireResize, me);        }, 1);    },    fireResize : function(width, height){        // In IE we can get resize events that have our current size, so we ignore them        // to avoid the useless layout...        if (width != this.width || height != this.height) {            this.setSize(width, height);        }    }});</pre></body></html>
 |