Last active
August 7, 2021 21:04
-
-
Save gridphp/48d5f7be375ecdbab9195b1091cfc480 to your computer and use it in GitHub Desktop.
Dropdown onload sql on 2.6.5. In this demo on line 79
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/** | |
* PHP Grid Component | |
* | |
* @author Abu Ghufran <gridphp@gmail.com> - http://www.phpgrid.org | |
* @version 2.0.0 | |
* @license: see license.txt included in package | |
*/ | |
// include db config | |
include_once("../../config.php"); | |
// include and create object | |
include(PHPGRID_LIBPATH."inc/jqgrid_dist.php"); | |
// Database config file to be passed in phpgrid constructor | |
$db_conf = array( | |
"type" => PHPGRID_DBTYPE, | |
"server" => PHPGRID_DBHOST, | |
"user" => PHPGRID_DBUSER, | |
"password" => PHPGRID_DBPASS, | |
"database" => PHPGRID_DBNAME | |
); | |
$g = new jqgrid($db_conf); | |
$opt["sortname"] = 'id'; // by default sort grid by this field | |
$opt["sortorder"] = "asc"; // ASC or DESC | |
$opt["caption"] = "Invoice Data"; // caption of grid | |
#$opt["autowidth"] = true; // expand grid to screen width | |
$opt["multiselect"] = false; // allow you to multi-select through checkboxes | |
$g->set_options($opt); | |
$g->set_actions(array( | |
"add"=>true, // allow/disallow add | |
"edit"=>true, // allow/disallow edit | |
"delete"=>true, // allow/disallow delete | |
"rowactions"=>true, // show/hide row wise edit/del/save option | |
"autofilter" => true, // show/hide autofilter for search | |
) | |
); | |
$g->select_command = "SELECT id, invdate, invheader.client_id, invheader.client_id as cid, amount, note FROM invheader | |
INNER JOIN clients on clients.client_id = invheader.client_id | |
"; | |
// this db table will be used for add,edit,delete | |
$g->table = "invheader"; | |
$col = array(); | |
$col["title"] = "Id"; // caption of column | |
$col["name"] = "id"; | |
$col["width"] = "10"; | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Client"; | |
$col["name"] = "client_id"; | |
$col["dbname"] = "clients.client_id"; // this is required as we need to search in name field, not id | |
$col["width"] = "100"; | |
$col["align"] = "left"; | |
$col["search"] = true; | |
$col["editable"] = true; | |
$col["edittype"] = "select"; // render as select | |
# fetch data from database, with alias k for key, v for value | |
# on change, update other dropdown | |
$str = $g->get_dropdown_values("select distinct client_id as k, name as v from clients"); | |
$col["editoptions"] = array( | |
"value"=>":Select...;".$str, | |
"onchange" => array( "update_field" => "note", | |
"sql" => "select distinct note as k, note as v from invheader WHERE client_id = '{client_id}'" | |
) | |
); | |
// Load dropdown to select client where gender is female | |
$col["editoptions"]["onload"]["sql"] = "select distinct client_id as k, name as v from clients where gender='female' OR client_id = {client_id}"; | |
$col["formatter"] = "select"; // display label, not value | |
$col["stype"] = "select"; // enable dropdown search | |
$col["searchoptions"] = array("value" => ":;".$str); | |
$col["editrules"] = array("required"=>true); // and is required | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Invoices"; | |
$col["name"] = "note"; | |
$col["width"] = "100"; | |
$col["search"] = true; | |
$col["editable"] = true; | |
$col["edittype"] = "select"; // render as select | |
$str = $g->get_dropdown_values("select distinct note as k, note as v from invheader"); | |
$col["editoptions"] = array("value"=>$str); | |
$col["formatter"] = "select"; // display label, not value | |
$col["stype"] = "select"; // enable dropdown search | |
$col["searchoptions"] = array("value" => ":;".$str); | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Date"; | |
$col["name"] = "invdate"; | |
$col["width"] = "50"; | |
$col["editable"] = true; // this column is editable | |
$col["editoptions"] = array("size"=>20); // with default display of textbox with size 20 | |
$col["editrules"] = array("required"=>true); // and is required | |
$col["formatter"] = "date"; // format as date | |
$col["search"] = false; | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Amount"; | |
$col["name"] = "amount"; | |
$col["width"] = "50"; | |
$col["editable"] = true; // this column is editable | |
$col["editoptions"] = array("size"=>20); // with default display of textbox with size 20 | |
$col["editrules"] = array("required"=>true); // and is required | |
$cols[] = $col; | |
// pass the cooked columns to grid | |
$g->set_columns($cols); | |
// generate grid output, with unique grid name as 'list1' | |
$out = $g->render("list1"); | |
?> | |
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | |
<html> | |
<head> | |
<meta name="viewport" content="width=device-width, initial-scale=1"> | |
<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> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment