Subversion Repositories Applications.papyrus

Rev

Blame | Last modification | View Log | RSS feed

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
        <title>dojox.Grid Change Structure Example</title>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8"></meta>
        <style type="text/css">
                @import "../_grid/Grid.css";
                body {
                        font-size: 0.9em;
                        font-family: Geneva, Arial, Helvetica, sans-serif;
                }
                .heading {
                        font-weight: bold;
                        padding-bottom: 0.25em;
                }
                                
                #grid { 
                        border: 1px solid #333;
                        width: 48em;
                        height: 30em;
                }
                
                #grid .dojoxGrid-cell {
                        text-align: center;
                }
        </style>
        <script type="text/javascript" src="../../../dojo/dojo.js" djConfig="isDebug:false, parseOnLoad: true"></script>
        <script type="text/javascript">
                dojo.require("dojox.grid.Grid");
                dojo.require("dojox.grid._data.model");
                dojo.require("dojo.parser");
        </script>
        <script type="text/javascript">

                // get can return data for a cell of the grid
                function get(inRowIndex) {
                        return [this.index, inRowIndex].join(', ');
                }

                // grid structure
                // a grid view is a group of columns
                
                // a special view providing selection feedback
                var rowBar = {type: 'dojox.GridRowView', width: '20px' };
                
                // a view without scrollbars
                var view0 = {
                        noscroll: true,
                        cells: [[
                                {name: 'Alpha', value: '<input name="" type="checkbox" value="0">'},
                                {name: 'Beta', get: get, width: 4.5}
                ]]};
                
                var view1 = {
                        cells: [[
                                {name: 'Apple', value: '<button>Apple</button>'},
                                {name: 'Banana', get: get},
                                {name: 'Beans', value: 'Happy to be grid!'},
                                {name: 'Kiwi', get: get},
                                {name: 'Orange', value: '<img src="images/flatScreen.gif" height="48" width="48">'},
                                {name: 'Pear', get: get},
                                {name: 'Tomato', width: 20, value: '<input name="" type="file">'},
                ]]};
                
                var view2 = {
                        noscroll: true,
                        cells: [
                                [
                                        {name: 'Alpha', value: '<input name="" type="checkbox" value="0">', rowSpan: 2},
                                        {name: 'Beta', get: get, width: 4.5}
                                ], [
                                        {name: 'Gamma', get: get}
                                ],
                                [
                                        {name: 'Epsilon', value: '<button>Epsilon</button>', colSpan: 2}
                                ]
                        ]       
                }
                
                var view3 = {
                        cells: [
                                [       
                                        {name: 'Apple', value: '<button>Apple</button>', rowSpan: 3},
                                        {name: 'Banana', get: get, width: 20},
                                        {name: 'Kiwi', get: get, width: 20},
                                        {name: 'Pear', get: get, width: 20},
                                ],
                                [
                                        {name: 'Beans', value: 'Happy to be grid!'},
                                        {name: 'Orange', value: '<img src="images/flatScreen.gif" height="48" width="48">'},
                                        {name: 'Tomato', value: '<input name="" type="file">'}
                                ], [
                                        {name: 'Zuchini', value: '<span style="letter-spacing: 10em;">wide</span>', colSpan: 3}
                                ]
                        ]};
                
                
                // a grid structure is an array of views.
                // By default the middle view will be 'elastic', sized to fit the remaining space left by other views
                // grid.elasticView can also be manually set
                var structure = [ rowBar, view0, view1 ];
                var structure2 = [ rowBar, view2, view3 ];
                
                
                var l2 = false;
                toggleStructure = function() {
                        l2 = !l2;
                        grid.scrollToRow(0);
                        grid.setStructure(l2 ? structure2 : structure);
                }
                
                dojo.addOnLoad(function() {
                        window["grid"] = dijit.byId("grid");
                });
</script>
</head>
<body>
<div class="heading">dojox.VirtualGrid Change Structure Example</div>
<p>
        <button onclick="toggleStructure()">Change Structure</button>
</p>    
<div id="grid" dojoType="dojox.VirtualGrid" structure="structure" rowCount="100000" elasticView="2"></div>

</body>
</html>