How can I have both validation on the same grid?
My code below does not work for adding records
<?php
//include("../../../header.php");
//require_once('../../../nav3G.php');
/**
* PHP Grid Component
*
* @author Abu Ghufran <[email protected]> – http://www.phpgrid.org
* @version 1.5.2
* @license: see license.txt included in package
*/
// include db config
include_once("../../config.php");
// set up DB
mysql_connect(PHPGRID_DBHOST, PHPGRID_DBUSER, PHPGRID_DBPASS);
mysql_select_db(PHPGRID_DBNAME);
// include and create object
include(PHPGRID_LIBPATH."inc/jqgrid_dist.php");
$col = array();
$col["name"] = "name";
$col["title"] = "name";
$col["editrules"] = array("required"=>true); // and is required
$cols[] = $col;
$col = array();
$col["name"] = "gender";
$col["title"] = "gender";
$col["editrules"] = array("required"=>true); // and is required
$cols[] = $col;
$col = array();
$col["name"] = "company";
$col["title"] = "company";
$col["editrules"] = array("required"=>true); // and is required
$cols[] = $col;
$grid = new jqgrid();
$opt["autowidth"] = true; // expand grid to screen width
$opt["caption"] = "Front Sheet";
$grid->set_options($opt);
// params are array(<function-name>,<class-object> or <null-if-global-func>,<continue-default-operation>)
// if you pass last argument as true, functions will act as a data filter, and insert/update will be performed by grid
$e["on_insert"] = array("add_client", null, false);
$e["on_delete"] = array("del_client", null, false);
$grid->set_events($e);
function add_client($data)
{
$check_sql = "SELECT count(*) as c from clients where LOWER(`name`) = '".strtolower($data["params"]["name"])."'";
$rs = mysql_fetch_assoc(mysql_query($check_sql));
if ($rs["c"] > 0)
phpgrid_error("Client already exist in database");
mysql_query("INSERT INTO clients VALUES (null,'{$data["params"]["name"]}','{$data["params"]["gender"]}','{$data["params"]["company"]}')");
}
function del_client($data)
{
/*
// to debug
ob_start();
print_r($data);
$s = ob_get_clean();
phpgrid_error($s);
*/
phpgrid_error("Access denied!");
}
$grid->table = "clients";
// pass the cooked columns to grid
$grid->set_columns($cols);
$out = $grid->render("list1");
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html>
<head>
<link rel="stylesheet" type="text/css" media="screen" href="../../lib/js/themes/redmond/jquery-ui.custom.css"></link>
<link rel="stylesheet" type="text/css" media="screen" href="../../lib/js/jqgrid/css/ui.jqgrid.css"></link>
<script src="../../lib/js/jquery.min.js" type="text/javascript"></script>
<script src="../../lib/js/jqgrid/js/i18n/grid.locale-en.js" type="text/javascript"></script>
<script src="../../lib/js/jqgrid/js/jquery.jqGrid.min.js" type="text/javascript"></script>
<script src="../../lib/js/themes/jquery-ui.custom.min.js" type="text/javascript"></script>
</head>
<body>
<div style="margin:10px">
<?php echo $out?>
</div>
</body>
</html>