Subversion Repositories Applications.papyrus

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2150 mathias 1
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
2
<html>
3
<head>
4
	<title>Test dojox.Grid Basic</title>
5
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8"></meta>
6
	<style type="text/css">
7
		@import "../_grid/Grid.css";
8
		@import "../../../dojo/resources/dojo.css";
9
		@import "../../../dijit/tests/css/dijitTests.css";
10
		body {
11
			font-size: 0.9em;
12
			font-family: Geneva, Arial, Helvetica, sans-serif;
13
		}
14
		.heading {
15
			font-weight: bold;
16
			padding-bottom: 0.25em;
17
		}
18
 
19
		#grid {
20
			border: 1px solid #333;
21
			width: 35em;
22
			height: 30em;
23
		}
24
	</style>
25
	<script type="text/javascript" src="../../../dojo/dojo.js" djConfig="isDebug:false, parseOnLoad: true"></script>
26
	<script type="text/javascript" src="../../../dijit/tests/_testCommon.js"></script>
27
	<script type="text/javascript">
28
		dojo.require("dojox.grid.Grid");
29
		dojo.require("dojox.grid._data.model");
30
		dojo.require("dijit.Tooltip");
31
		dojo.require("dijit.Menu");
32
		dojo.require("dijit.ColorPalette");
33
		dojo.require("dojo.parser");
34
	</script>
35
	<script type="text/javascript" src="support/test_data.js"></script>
36
	<script type="text/javascript">
37
		// a grid view is a group of columns
38
		var view1 = {
39
			cells: [[
40
				{name: 'Column 0'}, {name: 'Column 1'}, {name: 'Column 2'}, {name: 'Column 3', width: "150px"}, {name: 'Column 4'}
41
			],[
42
				{name: 'Column 5'}, {name: 'Column 6'}, {name: 'Column 7'}, {name: 'Column 8', field: 3, colSpan: 2}
43
			]]
44
		};
45
		// a grid layout is an array of views.
46
		var layout = [ view1 ];
47
 
48
		dojo.addOnLoad(function() {
49
			window["grid"] = dijit.byId("grid");
50
			var
51
				showTooltip = function(e) {
52
					if(gridTooltipEnabled){
53
						var msg = "This is cell " + e.rowIndex + ", " + e.cellIndex;
54
						dijit.showTooltip(msg, e.cellNode);
55
					}
56
				},
57
				hideTooltip = function(e) {
58
					dijit.hideTooltip(e.cellNode);
59
					// FIXME: make sure that pesky tooltip doesn't reappear!
60
					// would be nice if there were a way to hide tooltip without regard to aroundNode.
61
					dijit._masterTT._onDeck=null;
62
				}
63
 
64
			// cell tooltip
65
			dojo.connect(grid, "onCellMouseOver", showTooltip);
66
			dojo.connect(grid, "onCellMouseOut", hideTooltip);
67
			// header cell tooltip
68
			dojo.connect(grid, "onHeaderCellMouseOver", showTooltip);
69
			dojo.connect(grid, "onHeaderCellMouseOut", hideTooltip);
70
 
71
			// grid menu
72
			window["gridMenu"] = dijit.byId("gridMenu");
73
			gridMenu.bindDomNode(grid.domNode);
74
			// prevent grid methods from killing the context menu event by implementing our own handler
75
			grid.onCellContextMenu = function(e) {
76
				cellNode = e.cellNode;
77
			};
78
			grid.onHeaderContextMenu = function(e) {
79
				cellNode = e.cellNode;
80
			};
81
		});
82
 
83
		function reportCell() {
84
			if(cellNode){
85
				alert("Cell contents:  " + cellNode.innerHTML);
86
				cellNode = null;
87
			}
88
		}
89
 
90
		gridTooltipEnabled = true;
91
		function toggleTooltip(button){
92
			gridTooltipEnabled = !gridTooltipEnabled;
93
			button.value = gridTooltipEnabled ? "Disable Grid Tooltip" : "Enable Grid Tooltip";
94
		}
95
 
96
		gridMenuEnabled = true;
97
		function toggleMenu(button){
98
			gridMenuEnabled = !gridMenuEnabled;
99
			button.value = gridMenuEnabled ? "Disable Grid Menu" : "Enable Grid Menu";
100
			gridMenu[gridMenuEnabled ? "bindDomNode" : "unBindDomNode"](grid.domNode);
101
		}
102
</script>
103
</head>
104
<body>
105
<div dojoType="dijit.Menu" id="gridMenu"  style="display: none;">
106
	<div dojoType="dijit.MenuItem" onClick="reportCell">See cell text...</div>
107
	<div dojoType="dijit.MenuItem" disabled="true">Disabled Item</div>
108
	<div dojoType="dijit.MenuSeparator"></div>
109
	<div dojoType="dijit.MenuItem" iconClass="dijitEditorIcon dijitEditorIconCut"
110
		onClick="alert('not actually cutting anything, just a test!')">Cut</div>
111
	<div dojoType="dijit.MenuItem" iconClass="dijitEditorIcon dijitEditorIconCopy"
112
		onClick="alert('not actually copying anything, just a test!')">Copy</div>
113
	<div dojoType="dijit.MenuItem" iconClass="dijitEditorIcon dijitEditorIconPaste"
114
		onClick="alert('not actually pasting anything, just a test!')">Paste</div>
115
	<div dojoType="dijit.MenuSeparator"></div>
116
</div>
117
<div dojoType="dijit.Menu" id="submenu1" contextMenuForWindow="true" style="display: none;">
118
	<div dojoType="dijit.MenuItem" onClick="alert('Hello world');">Enabled Item</div>
119
	<div dojoType="dijit.MenuItem" disabled="true">Disabled Item</div>
120
	<div dojoType="dijit.MenuSeparator"></div>
121
	<div dojoType="dijit.MenuItem" iconClass="dijitEditorIcon dijitEditorIconCut"
122
		onClick="alert('not actually cutting anything, just a test!')">Cut</div>
123
	<div dojoType="dijit.MenuItem" iconClass="dijitEditorIcon dijitEditorIconCopy"
124
		onClick="alert('not actually copying anything, just a test!')">Copy</div>
125
	<div dojoType="dijit.MenuItem" iconClass="dijitEditorIcon dijitEditorIconPaste"
126
		onClick="alert('not actually pasting anything, just a test!')">Paste</div>
127
	<div dojoType="dijit.MenuSeparator"></div>
128
	<div dojoType="dijit.PopupMenuItem">
129
		<span>Enabled Submenu</span>
130
		<div dojoType="dijit.Menu" id="submenu2">
131
			<div dojoType="dijit.MenuItem" onClick="alert('Submenu 1!')">Submenu Item One</div>
132
			<div dojoType="dijit.MenuItem" onClick="alert('Submenu 2!')">Submenu Item Two</div>
133
			<div dojoType="dijit.PopupMenuItem">
134
				<span>Deeper Submenu</span>
135
				<div dojoType="dijit.Menu" id="submenu4"">
136
					<div dojoType="dijit.MenuItem" onClick="alert('Sub-submenu 1!')">Sub-sub-menu Item One</div>
137
					<div dojoType="dijit.MenuItem" onClick="alert('Sub-submenu 2!')">Sub-sub-menu Item Two</div>
138
				</div>
139
			</div>
140
		</div>
141
	</div>
142
	<div dojoType="dijit.PopupMenuItem" disabled="true">
143
		<span>Disabled Submenu</span>
144
		<div dojoType="dijit.Menu" id="submenu3" style="display: none;">
145
			<div dojoType="dijit.MenuItem" onClick="alert('Submenu 1!')">Submenu Item One</div>
146
			<div dojoType="dijit.MenuItem" onClick="alert('Submenu 2!')">Submenu Item Two</div>
147
		</div>
148
	</div>
149
	<div dojoType="dijit.PopupMenuItem">
150
		<span>Different popup</span>
151
		<div dojoType="dijit.ColorPalette"></div>
152
	</div>
153
</div>
154
<div class="heading">dojox.Grid Basic Test</div>
155
<p>
156
	<input type="button" onclick="toggleTooltip(this)" value="Disable Grid Tooltip">&nbsp;&nbsp;
157
	<input type="button" onclick="toggleMenu(this)" value="Disable Grid Menu">&nbsp;&nbsp;<br />
158
	Note: when the grid menu is disabled, the document's dijit context menu should be shown over the grid.
159
</p>
160
<div id="grid" dojoType="dojox.Grid" model="model" structure="layout"></div>
161
</body>
162
</html>