[619] | 1 | /* |
---|
| 2 | * Ext JS Library 2.2.1 |
---|
| 3 | * Copyright(c) 2006-2009, Ext JS, LLC. |
---|
| 4 | * licensing@extjs.com |
---|
| 5 | * |
---|
| 6 | * http://extjs.com/license |
---|
| 7 | */ |
---|
| 8 | |
---|
| 9 | /* |
---|
| 10 | * ================ TabPanel with nested layouts ======================= |
---|
| 11 | */ |
---|
| 12 | // fake grid data used below in the tabsNestedLayouts config |
---|
| 13 | var myData = [ |
---|
| 14 | ['3m Co',71.72,0.02,0.03,'9/1 12:00am'], |
---|
| 15 | ['Alcoa Inc',29.01,0.42,1.47,'9/1 12:00am'], |
---|
| 16 | ['Altria Group Inc',83.81,0.28,0.34,'9/1 12:00am'], |
---|
| 17 | ['American Express Company',52.55,0.01,0.02,'9/1 12:00am'], |
---|
| 18 | ['American International Group, Inc.',64.13,0.31,0.49,'9/1 12:00am'], |
---|
| 19 | ['AT&T Inc.',31.61,-0.48,-1.54,'9/1 12:00am'], |
---|
| 20 | ['Boeing Co.',75.43,0.53,0.71,'9/1 12:00am'], |
---|
| 21 | ['Caterpillar Inc.',67.27,0.92,1.39,'9/1 12:00am'], |
---|
| 22 | ['Citigroup, Inc.',49.37,0.02,0.04,'9/1 12:00am'], |
---|
| 23 | ['E.I. du Pont de Nemours and Company',40.48,0.51,1.28,'9/1 12:00am'], |
---|
| 24 | ['Exxon Mobil Corp',68.1,-0.43,-0.64,'9/1 12:00am'], |
---|
| 25 | ['General Electric Company',34.14,-0.08,-0.23,'9/1 12:00am'], |
---|
| 26 | ['General Motors Corporation',30.27,1.09,3.74,'9/1 12:00am'], |
---|
| 27 | ['Hewlett-Packard Co.',36.53,-0.03,-0.08,'9/1 12:00am'], |
---|
| 28 | ['Honeywell Intl Inc',38.77,0.05,0.13,'9/1 12:00am'], |
---|
| 29 | ['Intel Corporation',19.88,0.31,1.58,'9/1 12:00am'], |
---|
| 30 | ['International Business Machines',81.41,0.44,0.54,'9/1 12:00am'], |
---|
| 31 | ['Johnson & Johnson',64.72,0.06,0.09,'9/1 12:00am'], |
---|
| 32 | ['JP Morgan & Chase & Co',45.73,0.07,0.15,'9/1 12:00am'], |
---|
| 33 | ['McDonald\'s Corporation',36.76,0.86,2.40,'9/1 12:00am'], |
---|
| 34 | ['Merck & Co., Inc.',40.96,0.41,1.01,'9/1 12:00am'], |
---|
| 35 | ['Microsoft Corporation',25.84,0.14,0.54,'9/1 12:00am'], |
---|
| 36 | ['Pfizer Inc',27.96,0.4,1.45,'9/1 12:00am'], |
---|
| 37 | ['The Coca-Cola Company',45.07,0.26,0.58,'9/1 12:00am'], |
---|
| 38 | ['The Home Depot, Inc.',34.64,0.35,1.02,'9/1 12:00am'], |
---|
| 39 | ['The Procter & Gamble Company',61.91,0.01,0.02,'9/1 12:00am'], |
---|
| 40 | ['United Technologies Corporation',63.26,0.55,0.88,'9/1 12:00am'], |
---|
| 41 | ['Verizon Communications',35.57,0.39,1.11,'9/1 12:00am'], |
---|
| 42 | ['Wal-Mart Stores, Inc.',45.45,0.73,1.63,'9/1 12:00am'] |
---|
| 43 | ]; |
---|
| 44 | |
---|
| 45 | var tabsNestedLayouts = { |
---|
| 46 | xtype: 'tabpanel', |
---|
| 47 | id: 'tabs-nested-layouts-panel', |
---|
| 48 | title: 'TabPanel with Nested Layouts', |
---|
| 49 | activeTab: 0, |
---|
| 50 | items:[{ |
---|
| 51 | title: 'Foo', |
---|
| 52 | layout: 'border', |
---|
| 53 | items: [{ |
---|
| 54 | region: 'north', |
---|
| 55 | title: 'North', |
---|
| 56 | height: 75, |
---|
| 57 | maxSize: 150, |
---|
| 58 | margins: '5 5 0 5', |
---|
| 59 | bodyStyle: 'padding:10px;', |
---|
| 60 | split: true, |
---|
| 61 | html: 'Some content' |
---|
| 62 | },{ |
---|
| 63 | xtype: 'tabpanel', |
---|
| 64 | plain: true, |
---|
| 65 | region: 'center', |
---|
| 66 | margins: '0 5 5 5', |
---|
| 67 | activeTab: 0, |
---|
| 68 | items: [{ |
---|
| 69 | title: 'Inner Tab 1', |
---|
| 70 | bodyStyle: 'padding:10px;', |
---|
| 71 | html: 'See Inner Tab 2 for another nested BorderLayout.' |
---|
| 72 | },{ |
---|
| 73 | title: 'Inner Tab 2', |
---|
| 74 | cls: 'inner-tab-custom', // custom styles in layout-browser.css |
---|
| 75 | layout: 'border', |
---|
| 76 | // Make sure IE can still calculate dimensions after a resize when the tab is not active. |
---|
| 77 | // With display mode, if the tab is rendered but hidden, IE will mess up the layout on show: |
---|
| 78 | hideMode: Ext.isIE ? 'offsets' : 'display', |
---|
| 79 | items: [{ |
---|
| 80 | title: 'West', |
---|
| 81 | region: 'west', |
---|
| 82 | collapsible: true, |
---|
| 83 | width: 150, |
---|
| 84 | minSize: 100, |
---|
| 85 | maxSize: 350, |
---|
| 86 | margins: '5 0 5 5', |
---|
| 87 | cmargins: '5 5 5 5', |
---|
| 88 | html: 'Hello', |
---|
| 89 | bodyStyle:'padding:10px;', |
---|
| 90 | split: true |
---|
| 91 | },{ |
---|
| 92 | xtype: 'tabpanel', |
---|
| 93 | region: 'center', |
---|
| 94 | margins: '5 5 5 0', |
---|
| 95 | tabPosition: 'bottom', |
---|
| 96 | activeTab: 0, |
---|
| 97 | items: [{ |
---|
| 98 | // Panels that are used as tabs do not have title bars since the tab |
---|
| 99 | // itself is the title container. If you want to have a full title |
---|
| 100 | // bar within a tab, you can easily nest another panel within the tab |
---|
| 101 | // with layout:'fit' to acheive that: |
---|
| 102 | title: 'Bottom Tab', |
---|
| 103 | layout: 'fit', |
---|
| 104 | items: { |
---|
| 105 | title: 'Interior Content', |
---|
| 106 | bodyStyle:'padding:10px;', |
---|
| 107 | border: false, |
---|
| 108 | html: 'See the next tab for a nested grid. The grid is not rendered until its tab is first accessed.' |
---|
| 109 | } |
---|
| 110 | },{ |
---|
| 111 | // A common mistake when adding grids to a layout is creating a panel first, |
---|
| 112 | // then adding the grid to it. GridPanel (xtype:'grid') is a Panel subclass, |
---|
| 113 | // so you can add it directly as an item into a container. Typically you will |
---|
| 114 | // want to specify layout:'fit' on GridPanels so that they'll size along with |
---|
| 115 | // their container and take up the available space. |
---|
| 116 | title: 'Nested Grid', |
---|
| 117 | xtype: 'grid', |
---|
| 118 | layout: 'fit', |
---|
| 119 | store: new Ext.data.SimpleStore({ |
---|
| 120 | fields: [ |
---|
| 121 | {name: 'company'}, |
---|
| 122 | {name: 'price', type: 'float'}, |
---|
| 123 | {name: 'change', type: 'float'}, |
---|
| 124 | {name: 'pctChange', type: 'float'}, |
---|
| 125 | {name: 'lastChange', type: 'date', dateFormat: 'n/j h:ia'} |
---|
| 126 | ] |
---|
| 127 | }), |
---|
| 128 | columns: [ |
---|
| 129 | {id:'company',header: "Company", width: 160, sortable: true, dataIndex: 'company'}, |
---|
| 130 | {header: "Price", width: 75, sortable: true, renderer: 'usMoney', dataIndex: 'price'}, |
---|
| 131 | {header: "Change", width: 75, sortable: true, dataIndex: 'change'}, |
---|
| 132 | {header: "% Change", width: 75, sortable: true, dataIndex: 'pctChange'}, |
---|
| 133 | {header: "Last Updated", width: 85, sortable: true, renderer: Ext.util.Format.dateRenderer('m/d/Y'), dataIndex: 'lastChange'} |
---|
| 134 | ], |
---|
| 135 | stripeRows: true, |
---|
| 136 | autoExpandColumn: 'company', |
---|
| 137 | |
---|
| 138 | // Add a listener to load the data only after the grid is rendered: |
---|
| 139 | listeners: { |
---|
| 140 | render: function(){ |
---|
| 141 | this.store.loadData(myData); |
---|
| 142 | } |
---|
| 143 | } |
---|
| 144 | }] |
---|
| 145 | }] |
---|
| 146 | }] |
---|
| 147 | }] |
---|
| 148 | },{ |
---|
| 149 | title: 'Bar', |
---|
| 150 | bodyStyle: 'padding:10px;', |
---|
| 151 | html: 'Nothing to see here.' |
---|
| 152 | }] |
---|
| 153 | }; |
---|
| 154 | |
---|
| 155 | /* |
---|
| 156 | * ================ Absolute Layout Form ======================= |
---|
| 157 | */ |
---|
| 158 | var absform = new Ext.form.FormPanel({ |
---|
| 159 | baseCls: 'x-plain', |
---|
| 160 | layout:'absolute', |
---|
| 161 | url:'save-form.php', |
---|
| 162 | border: true, |
---|
| 163 | defaultType: 'textfield', |
---|
| 164 | |
---|
| 165 | items: [{ |
---|
| 166 | x: 0, |
---|
| 167 | y: 5, |
---|
| 168 | xtype: 'label', |
---|
| 169 | text: 'From:' |
---|
| 170 | },{ |
---|
| 171 | x: 55, |
---|
| 172 | y: 0, |
---|
| 173 | name: 'from', |
---|
| 174 | anchor:'100%' // anchor width by % |
---|
| 175 | },{ |
---|
| 176 | x: 0, |
---|
| 177 | y: 32, |
---|
| 178 | xtype: 'label', |
---|
| 179 | text: 'To:' |
---|
| 180 | },{ |
---|
| 181 | // The button is not a Field subclass, so it must be |
---|
| 182 | // wrapped in a panel for proper positioning to work |
---|
| 183 | xtype: 'panel', |
---|
| 184 | x: 55, |
---|
| 185 | y: 27, |
---|
| 186 | items: { |
---|
| 187 | xtype: 'button', |
---|
| 188 | text: 'Contacts...' |
---|
| 189 | } |
---|
| 190 | },{ |
---|
| 191 | x: 135, |
---|
| 192 | y: 27, |
---|
| 193 | name: 'to', |
---|
| 194 | anchor: '100%' // anchor width by % |
---|
| 195 | },{ |
---|
| 196 | x: 0, |
---|
| 197 | y: 59, |
---|
| 198 | xtype: 'label', |
---|
| 199 | text: 'Subject:' |
---|
| 200 | },{ |
---|
| 201 | x: 55, |
---|
| 202 | y: 54, |
---|
| 203 | name: 'subject', |
---|
| 204 | anchor: '100%' // anchor width by % |
---|
| 205 | },{ |
---|
| 206 | x:0, |
---|
| 207 | y: 81, |
---|
| 208 | xtype: 'textarea', |
---|
| 209 | name: 'msg', |
---|
| 210 | anchor: '100% 100%' // anchor width and height |
---|
| 211 | }] |
---|
| 212 | }); |
---|
| 213 | |
---|
| 214 | var absoluteForm = { |
---|
| 215 | title: 'Absolute Layout Form', |
---|
| 216 | id: 'abs-form-panel', |
---|
| 217 | layout: 'fit', |
---|
| 218 | bodyStyle: 'padding:15px;', |
---|
| 219 | items: { |
---|
| 220 | title: 'New Email', |
---|
| 221 | cls: 'email-form', |
---|
| 222 | layout: 'fit', |
---|
| 223 | frame: true, |
---|
| 224 | bodyStyle: 'padding:10px 5px 5px;', |
---|
| 225 | items: absform, |
---|
| 226 | |
---|
| 227 | tbar: [{ |
---|
| 228 | text: 'Send', |
---|
| 229 | iconCls: 'icon-send' |
---|
| 230 | },'-',{ |
---|
| 231 | text: 'Save', |
---|
| 232 | iconCls: 'icon-save' |
---|
| 233 | },{ |
---|
| 234 | text: 'Check Spelling', |
---|
| 235 | iconCls: 'icon-spell' |
---|
| 236 | },'-',{ |
---|
| 237 | text: 'Print', |
---|
| 238 | iconCls: 'icon-print' |
---|
| 239 | },'->',{ |
---|
| 240 | text: 'Attach a File', |
---|
| 241 | iconCls: 'icon-attach' |
---|
| 242 | }] |
---|
| 243 | } |
---|
| 244 | }; |
---|