webgui/www/extras/yui/examples/datatable/contextmenu.html
2007-07-05 04:23:55 +00:00

226 lines
9.3 KiB
HTML

<!doctype html public "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Example: DataTable - Integration with ContextMenu (YUI Library)</title>
<link type="text/css" rel="stylesheet" href="../../build/reset/reset.css">
<link type="text/css" rel="stylesheet" href="../../build/fonts/fonts.css">
<link type="text/css" rel="stylesheet" href="../../build/logger/assets/logger.css">
<link type="text/css" rel="stylesheet" href="../../build/menu/assets/menu.css">
<link type="text/css" rel="stylesheet" href="../../build/datatable/assets/datatable.css">
<link type="text/css" rel="stylesheet" href="./css/examples.css">
<link type="text/css" rel="stylesheet" href="../assets/dpSyntaxHighlighter.css">
<style type="text/css">
/* custom css*/
#contextmenu {margin:1em;}
#contextmenu table {border-collapse:collapse;}
#contextmenu th, #contextmenu td {border:1px solid #000;padding:.25em;}
#contextmenu th {background-color:#696969;color:#fff;}/*dark gray*/
#contextmenu .yui-dt-odd {background-color:#eee;} /*light gray*/
</style>
</head>
<body>
<div id="hd">
<h1><img src="./img/logo.gif" class="logo" alt="Y!"/><a href="./">DataTable Widget</a> :: Integration with ContextMenu</h1>
</div>
<div id="bd">
<div id="contextmenu" class="example"></div>
<!-- Sample code begins -->
<div id="code">
<h3>Sample Code</h3>
<p>Dependencies:</p>
<textarea name="code" class="HTML" cols="60" rows="1">
&lt;!-- Required CSS --&gt;
&lt;link type="text/css" rel="stylesheet" href="build/datatable/assets/datatable.css"&gt;
&lt;!-- Dependencies --&gt;
&lt;script type="text/javascript" src="build/yahoo-dom-event/yahoo-dom-event.js"&gt;&lt;/script&gt;
&lt;!-- OPTIONAL: Connection (enables XHR) --&gt;
&lt;script type="text/javascript" src="build/connection/connection-min.js"&gt;&lt;/script&gt;
&lt;!-- OPTIONAL: Drag Drop (enables resizeable columns) --&gt;
&lt;script type="text/javascript" src="build/dragdrop/dragdrop-min.js"&gt;&lt;/script&gt;
&lt;!-- OPTIONAL: External JSON parser from http://www.json.org/ (enables JSON validation) --&gt;
&lt;script type="text/javascript" src="http://www.json.org/json.js"&gt;&lt;/script&gt;
&lt;!-- Need to also include files to enable ContextMenu --&gt;
&lt;script type="text/javascript" src="build/container/container_core.js"&gt;&lt;/script&gt;
&lt;script type="text/javascript" src="build/menu/menu.js"&gt;&lt;/script&gt;
&lt;!-- Source files --&gt;
&lt;script type="text/javascript" src="build/datasource/datasource-beta.js"&gt;&lt;/script&gt;
&lt;script type="text/javascript" src="build/datatable/datatable-beta.js"&gt;&lt;/script&gt;
</textarea>
<p>Data:</p>
<textarea name="code" class="JScript" cols="60" rows="1">
YAHOO.example.Data.inventory = [
{SKU:"23-23874", Quantity:43, Item:"Helmet", Description:"Red baseball helmet. Size: Large."},
{SKU:"48-38835", Quantity:84, Item:"Football", Description:"Leather football."},
{SKU:"84-84848", Quantity:31, Item:"Goggles", Description:"Light blue swim goggles"},
{SKU:"84-84843", Quantity:56, Item:"Badminton Set", Description:"Set of 2 badminton rackets, net, and 3 birdies."},
{SKU:"84-39321", Quantity:128, Item:"Tennis Balls", Description:"Canister of 3 tennis balls."},
{SKU:"39-48949", Quantity:55, Item:"Snowboard", Description:""},
{SKU:"99-28128", Quantity:77, Item:"Cleats", Description:"Soccer cleats. Size: 10."},
{SKU:"83-48281", Quantity:65, Item:"Volleyball", Description:""},
{SKU:"89-32811", Quantity:67, Item:"Sweatband", Description:"Blue sweatband. Size: Medium."},
{SKU:"28-22847", Quantity:43, Item:"Golf Set", Description:"Set of 9 golf clubs and bag."},
{SKU:"38-38281", Quantity:35, Item:"Basketball Shorts", Description:"Green basketball shorts. Size: Small."},
{SKU:"82-38333", Quantity:288, Item:"Lip balm", Description:"Lip balm. Flavor: Cherry."},
{SKU:"21-38485", Quantity:177, Item:"Ping Pong Ball", Description:""},
{SKU:"83-38285", Quantity:87, Item:"Hockey Puck", Description:"Glow-in-the-dark hockey puck."}
];
</textarea>
<p>CSS:</p>
<textarea name="code" class="HTML" cols="60" rows="1">
/* custom css*/
#contextmenu {margin:1em;}
#contextmenu table {border-collapse:collapse;}
#contextmenu th, #contextmenu td {border:1px solid #000;padding:.25em;}
#contextmenu th {background-color:#696969;color:#fff;}/*dark gray*/
#contextmenu .yui-dt-odd {background-color:#eee;} /*light gray*/
</textarea>
<p>Markup:</p>
<textarea name="code" class="HTML" cols="60" rows="1">
<div id="contextmenu" class="example"></div>
</textarea>
<p>JavaScript:</p>
<textarea name="code" class="JScript" cols="60" rows="1">
var myColumnHeaders = [
{key:"SKU"},
{key:"Quantity"},
{key:"Item"},
{key:"Description"}
];
var myColumnSet = new YAHOO.widget.ColumnSet(myColumnHeaders);
var myDataSource = new YAHOO.util.DataSource(YAHOO.example.Data.inventory);
myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSARRAY;
myDataSource.responseSchema = {
fields: ["SKU","Quantity","Item","Description"]
};
var myDataTable = new YAHOO.widget.DataTable("contextmenu", myColumnSet, myDataSource,{caption:"Example: Integration with ContextMenu"});
var onRowDelete = function(oArgs) {
YAHOO.log("Deleted row index " +oArgs.rowIndex);
};
myDataTable.subscribe("rowDeleteEvent", onRowDelete);
var onContextMenuClick = function(p_sType, p_aArgs, p_oMenu) {
var task = p_aArgs[1];
if(task) {
// Extract which row was context-clicked
var row = this.contextEventTarget;
while(row.tagName.toLowerCase() != "tr") {
row = row.parentNode;
if(row.tagName.toLowerCase == "body") {
row = null;
break;
}
}
if(row) {
switch(task.index) {
case 0: // Delete Item
YAHOO.log("Deleting item: " + row.cells[2].innerHTML);
myDataTable.deleteRow(row);
break;
}
}
}
};
var myContextMenu = new YAHOO.widget.ContextMenu("mycontextmenu", { trigger: myDataTable.getBody() } );
myContextMenu.addItem("Delete Item");
myContextMenu.render(document.body);
myContextMenu.clickEvent.subscribe(onContextMenuClick);
</textarea>
</div>
<!-- Code sample ends -->
</div>
<script type="text/javascript" src="../../build/yahoo/yahoo.js"></script>
<script type="text/javascript" src="../../build/dom/dom.js"></script>
<script type="text/javascript" src="../../build/event/event.js"></script>
<script type="text/javascript" src="../../build/logger/logger.js"></script>
<script type="text/javascript" src="../../build/container/container_core.js"></script>
<script type="text/javascript" src="../../build/menu/menu.js"></script>
<script type="text/javascript" src="../../build/datasource/datasource-beta-debug.js"></script>
<script type="text/javascript" src="../../build/datatable/datatable-beta-debug.js"></script>
<script type="text/javascript" src="./js/data.js"></script>
<script type="text/javascript">
var myLogger = new YAHOO.widget.LogReader();
/****************************************************************************/
/****************************************************************************/
/****************************************************************************/
var myColumnHeaders = [
{key:"SKU"},
{key:"Quantity"},
{key:"Item"},
{key:"Description"}
];
var myColumnSet = new YAHOO.widget.ColumnSet(myColumnHeaders);
var myDataSource = new YAHOO.util.DataSource(YAHOO.example.Data.inventory);
myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSARRAY;
myDataSource.responseSchema = {
fields: ["SKU","Quantity","Item","Description"]
};
var myDataTable = new YAHOO.widget.DataTable("contextmenu", myColumnSet, myDataSource,{caption:"Example: Integration with ContextMenu"});
var onRowDelete = function(oArgs) {
YAHOO.log("Deleted row indexes: " +oArgs.rowIndexes);
};
myDataTable.subscribe("rowDeleteEvent", onRowDelete);
var onContextMenuClick = function(p_sType, p_aArgs, p_oMenu) {
var task = p_aArgs[1];
if(task) {
// Extract which row was context-clicked
var row = this.contextEventTarget;
while(row.tagName.toLowerCase() != "tr") {
row = row.parentNode;
if(row.tagName.toLowerCase == "body") {
row = null;
break;
}
}
if(row) {
switch(task.index) {
case 0: // Delete Item
YAHOO.log("Deleting item: " + row.cells[2].innerHTML);
myDataTable.deleteRow(row);
break;
}
}
}
};
var myContextMenu = new YAHOO.widget.ContextMenu("mycontextmenu", { trigger: myDataTable.getBody() } );
myContextMenu.addItem("Delete Item");
myContextMenu.render(document.body);
myContextMenu.clickEvent.subscribe(onContextMenuClick);
</script>
<script type="text/javascript" src="../assets/dpSyntaxHighlighter.js"></script>
<script type="text/javascript">
dp.SyntaxHighlighter.HighlightAll('code');
</script>
</body>
</html>