String Formatting
You can format table column using various string functions. For example you can make any table column content to uppercase, first letter uppercase, lowercase or you can add prefix, suffix etc.
$pdocrud->tableColFormatting("first_name", "string",array("type" =>"prefix","str"=>"Mr. "));
$pdocrud->tableColFormatting("first_name", "string",array("type" =>"uppercase"));
$pdocrud->tableColFormatting("last_name", "string",array("type" =>"lowercase"));
$pdocrud->tableColFormatting("Address", "string",array("type" =>"suffix","str"=>" "));
Formula Based Formatting
You can format table column using various formula functions. For example you can make any table column content to uppercase, first letter uppercase, lowercase or you can add prefix, suffix etc.
$pdocrud->tableColFormatting("tax", "formula",array("type" =>"round","decimalpoint"=>2));
$pdocrud->tableColFormatting("product_discount", "formula",array("type" =>"number_format","decimalpoint"=>2));
$pdocrud->tableColFormatting("product_price", "formula",array("type" =>"ceil"));
$pdocrud->tableColFormatting("product_sell_price", "formula",array("type" =>"floor"));
$pdocrud->tableColFormatting("discount", "formula",array("type" =>"percentage"));
Other Table Formatting
$pdocrud->tableColFormatting("added_date", "date",array("format" =>"m-d-Y")); // PASS DATE FORMAT
$pdocrud->tableColFormatting("prod", "html",array("type" =>"html", "str"=>"{col-name}"));
$pdocrud->tableColFormatting("product_image", "image"); //CONVERT TO IMAGE COLUMN
$pdocrud->tableColFormatting("product_image", "image",array("width" =>"100px","height"=>'100px'));
$pdocrud->tableColFormatting("product_url", "url",array("text" =>"View product","target"=>'_blank'));
$pdocrud->tableColFormatting("product_description", "readmore", array("length"=>4,"showreadmore"=>true));
$pdocrud->tableColFormatting("product_description", "dialog", array("length"=>4,"showreadmore"=>true));
$pdocrud->tableColFormatting("product_rating", "html",array("type" =>"html","str"=>"{col-name}"));
Mathematical
$pdocrud->tableColAddition("Total", "sum",array("product_price","product_sell_price"));
$pdocrud->tableColAddition("Profit", "subtract",array("product_price","product_sell_price"));
$pdocrud->tableColAddition("Sell/price", "divide",array("product_sell_price","product_price"));
$pdocrud->tableColAddition("Product Info", "merge",array("product_id","product_name"));
Replace Column Value
Many times, we need to display different value of column than the value saved for example we save status as 0,1 and display as "Approved" "Not Approved". This can be easily achieved using the PDOCrud using tableColFormatting function and replacing the value of column.
$pdocrud->tableColFormatting("order_status", "replace",array("Completed" =>""));
Conditional Logic
$pdocrud->tableDataFormatting("col", "style", array("product_price",">", "55"),array("background:#f00","color:#ff0"));
$pdocrud->tableDataFormatting("row", "style", array("product_price",">", "55"),array("background:#000","color:#ff0"));
Style
$pdocrud->colDataAttr( "customer_name", array("width"=>"70px","colspan"=>2));
Calculate Field Based on Other Field
If you want to calculate a field value based on the other field's value then you can easily do using the formFieldValue() function. You can apply basic math function e.g addition, subtraction, multiplication or division to generate the field value based on other field's value. For example, if you want to save the total field as multiplicate of qty and rate field and don't want to show this total field to user then you can easily acheive this using this function.
Please note that you need to hide that field from form that is being calculated. Also, math function can be applied to two fields only. It doesn't work with complex functions currently. We will further improve this function in next versions.
In the below example, we are dynamically calculating sale_price field based on the price field. We are adding 24 to price field to generate sale_price field.
$pdocrud = new PDOCrud();
$pdocrud->formRemoveFields(array("sale_price"));
/**
* Set a value of field
* @param string $fieldName field name to renamed
* @param string $value value of the field
* @param bool $fieldHidden Wheter that field is hidden or not
* @param string $tablename Tablename = Required only when using join table field name
* return object Object of class
*/
$pdocrud->formFieldValue("sale_price", "{price}+24", true);
//apply formula
$pdocrud->fieldFormula("sale_price", "expression",array("type" =>"math_expression"));
echo $pdocrud->dbTable("book")->render("insertform"); // call render function