blob: 33ae27110a9a681dc6419586ae18f9d05580d879 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
/* ************************************************************************
qooxdoo - the new era of web development
http://qooxdoo.org
Copyright:
2007 Derrell Lipman
License:
LGPL: http://www.gnu.org/licenses/lgpl.html
EPL: http://www.eclipse.org/org/documents/epl-v10.php
See the LICENSE file in the project's top-level directory for details.
Authors:
* Derrell Lipman (derrell)
************************************************************************ */
/* ************************************************************************
#module(treevirtual)
************************************************************************ */
/**
* A data row renderer for a simple tree row
*/
qx.OO.defineClass("qx.ui.treevirtual.SimpleTreeDataRowRenderer",
qx.ui.table.DefaultDataRowRenderer,
function()
{
qx.ui.table.DefaultDataRowRenderer.call(this);
});
// overridden
qx.Proto.updateDataRowElement = function(rowInfo, rowElem)
{
// If the node is selected, select the row
var tree = rowInfo.table;
var rowData = rowInfo.rowData;
var tableModel = tree.getTableModel();
var treeCol = tableModel.getTreeColumn();
var node = rowData[treeCol];
// Set the row's selected state based on the data model
rowInfo.selected = node.bSelected;
if (node.bSelected)
{
// Ensure that the selection model knows it's selected
var nodeRowMap = tableModel.getNodeRowMap();
var row = nodeRowMap[node.nodeId];
tree.getSelectionModel()._addSelectionInterval(row, row);
}
// Now call our superclass
var ddrr = qx.ui.table.DefaultDataRowRenderer;
ddrr.prototype.updateDataRowElement.call(this, rowInfo, rowElem);
};
|