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>Test dojox.Grid Expand Rows</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;}.bigHello {height: 110px;line-height: 110px;text-align: center;font-weight: bold;font-size: 30px;}#grid {border: 1px solid #333;height: 30em;}</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">// grid structure// a grid view is a group of columns// a special view providing selection feedbackvar rowBar = {type: 'dojox.GridRowView', width: '20px' };// inRow is an array of subRows. we hide the summary subRow except for every nth rowfunction onBeforeRow(inDataIndex, inRow) {inRow[1].hidden = (!this.grid || !this.grid.expandedRows || !this.grid.expandedRows[inDataIndex]);}var view = {onBeforeRow: onBeforeRow,cells: [[{ name: 'Whatever', width: 4.5, get: getCheck, styles: 'text-align: center;' },{name: 'Column 0'},{name: 'Column 1'},{name: 'Column 2'},{name: 'Column 3'},{name: 'Column 4'}],[ { name: 'Detail', colSpan: 6, get: getDetail } ]]};// a grid structure is an array of views.var structure = [ rowBar, view ];// get can return data for each cell of the gridfunction get(inRowIndex) {return [this.index, inRowIndex].join(', ');}function getDetail(inRowIndex) {if (this.grid.expandedRows[inRowIndex]) {var n = (inRowIndex % 2);switch (n) {case 0:return 'Hello World!';default:return '<div class="bigHello">Hello World!</div>';}} elsereturn '';}function toggle(inIndex, inShow) {grid.expandedRows[inIndex] = inShow;grid.updateRow(inIndex);}function getCheck(inRowIndex) {if (!this.grid.expandedRows)this.grid.expandedRows = [ ];var image = (this.grid.expandedRows[inRowIndex] ? 'open.gif' : 'closed.gif');var show = (this.grid.expandedRows[inRowIndex] ? 'false' : 'true')return '<img src="images/' + image + '" onclick="toggle(' + inRowIndex + ', ' + show + ')" height="11" width="11">';}dojo.addOnLoad(function() {window["grid"] = dijit.byId("grid");});</script></head><body><div class="heading">dojox.Grid Expand Row Example</div><div id="grid" dojoType="dojox.VirtualGrid" get="get" structure="structure" rowCount="100000" autoWidth="true"></div></body></html>