Upgrade to ExtJS 4.0.7 - Released 10/19/2011
[extjs.git] / examples / core / spotlight-example.js
index e77cf7f..3662124 100644 (file)
-/*!
- * Ext JS Library 3.2.2
- * Copyright(c) 2006-2010 Ext JS, Inc.
- * licensing@extjs.com
- * http://www.extjs.com/license
- */
-Ext.onReady(function(){
-
-    var spot = new Ext.ux.Spotlight({
+/*
+
+This file is part of Ext JS 4
+
+Copyright (c) 2011 Sencha Inc
+
+Contact:  http://www.sencha.com/contact
+
+GNU General Public License Usage
+This file may be used under the terms of the GNU General Public License version 3.0 as published by the Free Software Foundation and appearing in the file LICENSE included in the packaging of this file.  Please review the following information to ensure the GNU General Public License version 3.0 requirements will be met: http://www.gnu.org/copyleft/gpl.html.
+
+If you are unsure which license is appropriate for your use, please contact the sales department at http://www.sencha.com/contact.
+
+*/
+Ext.require(['Ext.panel.Panel', 'Ext.layout.container.Table']);
+
+Ext.onReady(function() {
+    //Create the spotlight component
+    var spot = Ext.create('Ext.ux.Spotlight', {
         easing: 'easeOut',
-        duration: .3
+        duration: 300
     });
 
-    var DemoPanel = Ext.extend(Ext.Panel, {
+    //Create a DemoPanel which is the base for each panel in the example
+    Ext.define('DemoPanel', {
+        extend: 'Ext.panel.Panel',
+
         title: 'Demo Panel',
         frame: true,
         width: 200,
         height: 150,
         html: 'Some panel content goes here!',
-        bodyStyle: 'padding:10px 15px;',
+        bodyStyle: 'padding:5px;',
 
-        toggle: function(on){
-            this.buttons[0].setDisabled(!on);
+        /**
+         * Custom method which toggles a Ext.Button for the current panel on/off depending on the only argument
+         */
+        toggle: function(on) {
+            var btns = this.dockedItems.last(),
+                btn = btns.items.first();
+
+            if (btn) {
+                btn.setDisabled(!on);
+            }
         }
     });
 
     var p1, p2, p3;
-    var updateSpot = function(id){
-        if(typeof id == 'string'){
+
+    /**
+     * Method which changes the spotlight to be active on a spefied panel
+     */
+    var updateSpot = function(id) {
+        if (typeof id == 'string') {
             spot.show(id);
-        }else if (!id && spot.active){
+        } else if (!id && spot.active) {
             spot.hide();
         }
-        p1.toggle(id==p1.id);
-        p2.toggle(id==p2.id);
-        p3.toggle(id==p3.id);
+
+        p1.toggle(id == p1.id);
+        p2.toggle(id == p2.id);
+        p3.toggle(id == p3.id);
     };
 
-    new Ext.Panel({
+    Ext.createWidget('panel', {
         renderTo: Ext.getBody(),
+
         layout: 'table',
         id: 'demo-ct',
         border: false,
+
         layoutConfig: {
             columns: 3
         },
-        items: [p1 = new DemoPanel({
+
+        items: [
+        p1 = Ext.create('DemoPanel', {
             id: 'panel1',
             buttons: [{
                 text: 'Next Panel',
-                handler: updateSpot.createDelegate(this, ['panel2'])
+                disabled: true,
+                handler: function() {
+                    updateSpot('panel2');
+                }
             }]
-        }),
-        p2 = new DemoPanel({
+        }), p2 = Ext.create('DemoPanel', {
             id: 'panel2',
             buttons: [{
                 text: 'Next Panel',
-                handler: updateSpot.createDelegate(this, ['panel3'])
+                disabled: true,
+                handler: function() {
+                    updateSpot('panel3');
+                }
             }]
-        }),
-        p3 = new DemoPanel({
+        }), p3 = Ext.create('DemoPanel', {
             id: 'panel3',
             buttons: [{
                 text: 'Done',
-                handler: updateSpot.createDelegate(this, [false])
+                disabled: true,
+                handler: function() {
+                    updateSpot(false);
+                }
             }]
         })]
     });
 
-    new Ext.Button({
+    //The start button, which starts everything
+    Ext.create('Ext.button.Button', {
         text: 'Start',
         renderTo: 'start-ct',
-        handler: updateSpot.createDelegate(this, ['panel1'])
+        handler: function() {
+            updateSpot('panel1');
+        }
     });
+});
 
-    updateSpot(false);
-});
\ No newline at end of file