1. Go to this page and download the library: Download riesenia/utility library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
riesenia / utility example snippets
use Riesenia\Utility\Kendo\Table;
$table = Table::create('myTableId');
// datasource can be accessed directly
$table->dataSource->addTransport('read', ['dataType' => 'json', 'url' => 'URL']);
// ... but addTransport can also be called directly on the table object
$table->addTransport('update', ['dataType' => 'json', 'url' => 'URL']);
// columns can have various types and additional options can be set
$table->addColumn('name', 'Product name')
->addColumn('price', 'Product price', 'price', ['class' => 'green'])
->addColumn('active', 'Is active?', 'checkbox')
->addColumn('stock', 'Stock', 'number');
// checkboxes for batch operations can be added
$table->addCheckboxes();
// class for table row can be added using 'addRowClass' method
$table->addRowClass('#: active ? "active" : "not-active" #');
// additional model options can be set using 'model' key
$table->addColumn('name', 'Product name', null, ['model' => ['editable' => false]]);
// you can use any custom column rendering class
// as long as it extends Riesenia\Utility\Kendo\Table\Column\Base
$table->addColumn('custom_field', 'Title', '\\Custom\\Rendering\\Class');
// link is built-in option
$table->addColumn('...', '...', '...', ['link' => 'URL']);
// any link attributes can be set
$table->addColumn('...', '...', '...', ['link' => ['href' => 'URL', 'title' => 'TITLE']]);
// the whole template can be overridden
$table->addColumn('...', '...', '...', ['template' => '# if (field) { # yes # } else { # no # } #']);
// it is possible to hide columns under certain table width
$table->addColumn('...', '...', '...', ['display' => 700]);
// actions are usually icons with links
// icons are bootstrap classes without glyphicon prefix
$table->addAction(null, [
'icon' => 'music',
'link' => 'URL',
'title' => 'Play!'
]);
// or predifined edit or delete operation
$table->addAction('delete');
// you can use any custom column action class
// as long as it extends Riesenia\Utility\Kendo\Table\Action\Base
$table->addAction('\\Custom\\Action\\Class');
// generally used classes can be aliased, so previous example is equivalent to
Table::alias('alias_name', '\\Custom\\Action\\Class');
$table->addAction('alias_name');
// condition is built-in option
$table->addAction('...', ['condition' => 'count > 0']);
// set text for no results (will be added as first colspaned row)
$table->setNoResults('NO RESULTS!');
// html element (div)
echo $table;
// generated javascript
echo '<script>' . $table->script() . '</script>';
use Riesenia\Utility\Kendo\Tree;
$tree = Tree::create('myTreeId');
// datasource can be accessed directly
$tree->dataSource->addTransport('read', ['dataType' => 'json', 'url' => 'URL']);
// ... but addTransport can also be called directly on the tree object
$tree->addTransport('delete', ['dataType' => 'json', 'url' => 'URL']);
// add hasChildren field (to allow tree expanding), default field name is 'hasChildren'
// but any field name can be passed (do not use 'children' as field name)
$tree->hasChildren();
// html element (div)
echo $tree;
// generated javascript
echo '<script>' . $tree->script() . '</script>';
use Riesenia\Utility\Kendo\Window;
$window = Window::create('myWindowId');
// html element (div)
echo $window;
// generated javascript
echo '<script>' . $window->script() . '</script>';
// method for opening window is automatically defined
echo '<script>myWindowIdOpen("WINDOW TITLE", "URL OF THE CONTENT TO LOAD");</script>';
use Riesenia\Utility\Kendo\Tabber;
$tabber = Tabber::create('myTabberId');
// adding remote tab
$tabber->addRemoteTab('First tab', 'URL');
// active tab is set using third parameter
$tabber->addRemoteTab('Second tab', 'URL', true);
// html element (div & ul)
echo $tabber;
// generated javascript
echo '<script>' . $tabber->script() . '</script>';
use Riesenia\Utility\Kendo\Upload;
$upload = Upload::create('myUploadId');
// optionally set any attribute of the input
$upload->addAttribute('name', 'NAME');
// html element (input type file)
echo $upload;
// generated javascript
echo '<script>' . $upload->script() . '</script>';
use Riesenia\Utility\Kendo\Select;
$select = Select::create('mySelectId');
// datasource can be accessed directly
$select->dataSource->addTransport('read', ['dataType' => 'json', 'url' => 'URL']);
// ... but addTransport can also be called directly on the select object
$select->addTransport('read', ['dataType' => 'json', 'url' => 'URL']);
// optionally set any attribute of the input
$select->addAttribute('name', 'NAME');
// html element (input)
echo $select;
// generated javascript
echo '<script>' . $select->script() . '</script>';
use Riesenia\Utility\Kendo\ListView;
$listView = ListView::create('myListViewId');
// datasource can be accessed directly
$listView->dataSource->addTransport('read', ['dataType' => 'json', 'url' => 'URL']);
// ... but addTransport can also be called directly on the listView object
$listView->addTransport('destroy', ['dataType' => 'json', 'url' => 'URL']);
// template can be set by id attribute
$listView->setTemplateById('ID');
// html element (div)
echo $listView;
// generated javascript
echo '<script>' . $listView->script() . '</script>';
use Riesenia\Utility\Kendo\DateTime;
$dateTime = DateTime::create('myDateTimeId');
// range can be set between two elements (two fields with ids 'from' and 'to')
DateTime::create('from')->rangeTo('to');
DateTime::create('to')->rangeFrom('from');
// optionally set any attribute of the input
$dateTime->addAttribute('name', 'NAME');
// html element (input)
// hidden input with same name is added automatically to provide MySQL datetime format
echo $dateTime;
// generated javascript
echo '<script>' . $dateTime->script() . '</script>';
use Riesenia\Utility\Condition\QueryEvaluator;
// available fields and operators are defined during consstruction
$evaluator = new QueryEvaluator([
'pid' => [
'field' => 'id',
'operators' => ['=', 'NOT', 'IN', 'NOTIN']
],
'name' => [
'field' => 'name',
'operators' => ['=', 'NOT', 'CONTAINS']
],
'price' => [
'field' => 'unit_price',
'operators' => ['>=', '>', '<', '<=']
]
]);
// simple conditions
$evaluator->parse('price >= 10'); // ['unit_price >=' => '10']
// use AND / OR operators
$evaluator->parse('pid IN 2, 3 AND price >= 10'); // ['AND' => [['id IN' => ['2', '3']], ['unit_price >=' => '10']]]
// use parenthesis for complex conditions
$evaluator->parse('pid IN 2, 3 AND ((price >= 10 OR name = x) OR name CONTAINS y)'); // ... see tests
// throws custom exception for incorrect query
use Riesenia\Utility\Condition\QueryEvaluatorException;
try {
$evaluator->parse('(pid = 56');
} catch(QueryEvaluatorException $e) {
if ($e->getCode() == QueryEvaluatorException::MISSING_CLOSING_PARENTHESIS) { // true
echo $e->getAttributes()['position']; // 0
}
}
use Riesenia\Utility\Condition\QueryEvaluatorCallable;
// using configuration from previous example
$evaluator = new QueryEvaluatorCallable([...]);
$condition = $evaluator->parse('pid IN 2, 3 AND price >= 10');
$condition(['id' => 2, 'unit_price' => 7]); // true
$condition(['id' => 4, 'unit_price' => 7]); // false
$condition(['unit_price' => 4]); // false