Last active
June 14, 2020 19:54
-
-
Save gridphp/d4a9c61f2cd0af2dc146bbfb72cdd68c to your computer and use it in GitHub Desktop.
HTML in textarea, https://www.gridphp.com
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); | |
$grid["rowNum"] = 10; // by default 20 | |
$grid["sortname"] = 'id'; // by default sort grid by this field | |
$grid["sortorder"] = "asc"; // ASC or DESC | |
$grid["caption"] = "Invoice Data"; // caption of grid | |
$grid["autowidth"] = true; // expand grid to screen width | |
$grid["multiselect"] = false; // allow you to multi-select through checkboxes | |
$grid["add_options"] = array('width'=>'620', 'top'=>'10', 'left'=>'200'); | |
$grid["edit_options"] = array('width'=>'620', 'top'=>'10', 'left'=>'200'); | |
$grid["add_options"]["afterShowForm"] = "function(form){ | |
$('#tr_note>td:eq(1)').attr('colspan', '3'); | |
$('#tr_note>td:eq(1)>input').css('width', '95%'); | |
}"; | |
$grid["edit_options"]["afterShowForm"] = $grid["add_options"]["afterShowForm"]; | |
$g->set_options($grid); | |
$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 | |
"search" => "advance", // show single/multi field search condition (e.g. simple or advance) | |
"showhidecolumns" => false | |
) | |
); | |
// you can provide custom SQL query to display data | |
$g->select_command = "SELECT * FROM (SELECT i.id, invdate , c.name, | |
i.note, i.total, i.closed FROM invheader i | |
INNER JOIN clients c ON c.client_id = i.client_id) o"; | |
// this db table will be used for add,edit,delete | |
$g->table = "invheader"; | |
$col = array(); | |
$col["title"] = "Id"; // caption of column | |
$col["name"] = "id"; // grid column name, must be exactly same as returned column-name from sql (tablefield or field-alias) | |
$col["width"] = "10"; | |
$col["editable"] = false; // this column is not editable | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Date"; | |
$col["name"] = "invdate"; | |
$col["width"] = "35"; | |
$col["editable"] = true; // this column is editable | |
$col["editrules"] = array("required"=>true); | |
$col["formatter"] = "date"; // format as date | |
$col["formoptions"] = array("rowpos"=>"1", "colpos"=>"1"); | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Client"; | |
$col["name"] = "name"; | |
$col["width"] = "50"; | |
$col["editable"] = false; // this column is not editable | |
$col["search"] = false; // this column is not searchable | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Note"; | |
$col["name"] = "note"; | |
$col["sortable"] = false; // this column is not sortable | |
$col["search"] = false; // this column is not searchable | |
$col["editable"] = true; | |
$col["edittype"] = "textarea"; // render as textarea on edit | |
$col["editoptions"] = array("rows"=>2, "cols"=>50); // with these attributes | |
$col["formoptions"] = array("rowpos"=>"2", "colpos"=>"1"); | |
$col["formatter"] = "html"; | |
// connect tinymce | |
$col["editoptions"]["dataInit"] = "function(el){ setTimeout(function(){ link_tinymce(el); },200); }"; | |
$cols[] = $col; | |
$col = array(); | |
$col["title"] = "Total"; | |
$col["name"] = "total"; | |
$col["width"] = "30"; | |
$col["editable"] = true; | |
$col["formoptions"] = array("rowpos"=>"1", "colpos"=>"2"); | |
$col["show"]["edit"]=false; | |
$col["show"]["add"]=true; | |
$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> | |
<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> | |
<script src="//tinymce.cachefly.net/4.1/tinymce.min.js"></script> | |
</head> | |
<body> | |
<style> | |
/* form element positioning to top */ | |
.ui-jqgrid tr.jqgrow td | |
{ | |
white-space: normal !important; | |
} | |
.ui-jqdialog-content .CaptionTD | |
{ | |
vertical-align: top; | |
padding-top: 6px; | |
} | |
.ui-jqdialog-content .form-view-data | |
{ | |
white-space: normal; | |
} | |
.jqrow td div | |
{ | |
white-space:inherit; | |
} | |
</style> | |
<div style="margin:10px"> | |
<?php echo $out?> | |
</div> | |
<script type="text/javascript"> | |
function link_tinymce(el) | |
{ | |
// remove nbsp; from start of textarea | |
if(el.previousSibling) el.parentNode.removeChild(el.previousSibling); | |
$(el).parent().css('padding-left','6px'); | |
// connect tinymce, for options visit http://www.tinymce.com/wiki.php | |
try { | |
tinymce.remove("textarea#"+jQuery(el).attr('id')); | |
} catch(ex) {} | |
tinymce.init({ | |
selector: "textarea#"+jQuery(el).attr('id'), | |
menubar: false, | |
forced_root_block : "", | |
force_br_newlines : true, | |
force_p_newlines : false, | |
plugins: [ | |
"advlist autolink lists link image charmap print preview anchor", | |
"searchreplace visualblocks code fullscreen", | |
"insertdatetime media table contextmenu paste" | |
], | |
toolbar: "insertfile undo redo | styleselect | bold italic | alignleft aligncenter alignright alignjustify | bullist numlist outdent indent | link image" | |
}); | |
// bind onchange with textarea | |
var ed = tinymce.activeEditor; | |
ed.on('change', function (e) { | |
jQuery(el).val(ed.getBody().innerHTML); | |
}); | |
} | |
</script> | |
</body> | |
</html> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment