Editing
This help topic shows how to persist the changes from create, update and destroy operations using Kendo UI Grid for PHP.
Important
The following demos are using the sample SQLite database shipped with the Telerik UI for PHP demos (
/wrappers/php/sample.db
).
Edit with PDO
This demo shows how to use PDO to perform the create, update, and destroy data operations.
Configuration
Step 1 Make sure you followed all the steps from the introductory article on Telerik UI for PHP—include the autoloader, JavaScript, and CSS files.
Step 2 Create a data source and configure it.
<?php
$transport = new \Kendo\Data\DataSourceTransport();
// Configure the remote service - a PHP file called 'products.php'
// The query string parameter 'type' specifies the type of CRUD operation
$create = new \Kendo\Data\DataSourceTransportCreate();
$create->url('products.php?type=create')
->contentType('application/json')
->type('POST');
$read = new \Kendo\Data\DataSourceTransportRead();
$read->url('products.php?type=read')
->contentType('application/json')
->type('POST');
$update = new \Kendo\Data\DataSourceTransportUpdate();
$update->url('products.php?type=update')
->contentType('application/json')
->type('POST');
$destroy = new \Kendo\Data\DataSourceTransportDestroy();
$destroy->url('products.php?type=destroy')
->contentType('application/json')
->type('POST');
// Configure the transport. Send all data source parameters as JSON using the parameterMap setting
$transport->create($create)
->read($read)
->update($update)
->destroy($destroy)
->parameterMap('function(data) {
return kendo.stringify(data);
}');
// Configure the model
$model = new \Kendo\Data\DataSourceSchemaModel();
$productIDField = new \Kendo\Data\DataSourceSchemaModelField('ProductID');
$productIDField->type('number')
->editable(false)
->nullable(true);
$productNameField = new \Kendo\Data\DataSourceSchemaModelField('ProductName');
$productNameField->type('string')
->validation(array('required' => true));
$unitPriceValidation = new \Kendo\Data\DataSourceSchemaModelFieldValidation();
$unitPriceValidation->required(true)
->min(1);
$unitPriceField = new \Kendo\Data\DataSourceSchemaModelField('UnitPrice');
$unitPriceField->type('number')
->validation($unitPriceValidation);
$unitsInStockField = new \Kendo\Data\DataSourceSchemaModelField('UnitsInStock');
$unitsInStockField->type('number');
$discontinuedField = new \Kendo\Data\DataSourceSchemaModelField('Discontinued');
$discontinuedField->type('boolean');
$model->id('ProductID')
->addField($productIDField)
->addField($productNameField)
->addField($unitPriceField)
->addField($unitsInStockField)
->addField($discontinuedField);
$schema = new \Kendo\Data\DataSourceSchema();
$schema->model($model);
$dataSource = new \Kendo\Data\DataSource();
// Configure data source - set transport, schema and enable batch mode
$dataSource->transport($transport)
->batch(true)
->schema($schema);
?>
Step 3 Create a Grid, configure its columns and set its data source.
<?php
$grid = new \Kendo\UI\Grid('grid');
$productName = new \Kendo\UI\GridColumn();
$productName->field('ProductName')
->title('Product Name');
$unitPrice = new \Kendo\UI\GridColumn();
$unitPrice->field('UnitPrice')
->format('{0:c}')
->width(150)
->title('Unit Price');
$unitsInStock = new \Kendo\UI\GridColumn();
$unitsInStock->field('UnitsInStock')
->width(150)
->title('Units In Stock');
$discontinued = new \Kendo\UI\GridColumn();
$discontinued->field('Discontinued')
->width(100);
$command = new \Kendo\UI\GridColumn();
$command->addCommandItem('destroy')
->title(' ')
->width(110);
$grid->addColumn($productName, $unitPrice, $unitsInStock, $discontinued, $command)
->dataSource($dataSource)
->addToolbarItem(new \Kendo\UI\GridToolbarItem('create'),
new \Kendo\UI\GridToolbarItem('save'), new \Kendo\UI\GridToolbarItem('cancel'))
->editable(true)
->height(400);
?>
Step 4 Output the Grid by echoing the result of the render
method.
<?php
echo $grid->render();
?>
CRUD-Performing File Creation
Step 1 Create a new PHP file called products.php
. This file will perform CRUD data operations.
Step 2 Create a PDO connection.
<?php
$db = new PDO('sqlite:../sample.db');
?>
Step 3 Read the request body and parse it as JSON. In the previous example, the Kendo UI DataSource is configured to submit its parameters as JSON via the parameterMap
.
<?php
$request = json_decode(file_get_contents('php://input'));
?>
Step 4 Get the current operation type, available as the type
query string parameter.
<?php
$type = $_GET['type'];
?>
Step 5 Declare a variable which will be returned as a result of the operation.
<?php
$result = null;
?>
Step 6 Implement create
.
<?php
if ($type == 'create') {
// In batch mode the inserted records are available in the 'models' field
$createdProducts = $request->models;
// Will store the ProductID fields of the inserted records
$result = array();
foreach($createdProducts as $product) {
// Create SQL INSERT statement
$statement = $db->prepare('INSERT INTO Products (ProductName, UnitPrice, UnitsInStock, Discontinued) VALUES (:productName, :unitPrice, :unitsInStock, :discontinued)');
// Bind parameter values
$statement->bindValue(':productName', $product->ProductName);
$statement->bindValue(':unitPrice', $product->UnitPrice);
$statement->bindValue(':unitsInStock', $product->UnitsInStock);
$statement->bindValue(':discontinued', $product->Discontinued);
// Execute the statement
$statement->execute();
// Set ProductID to the last inserted ID (ProductID is auto-incremented column)
$product->ProductID = $db->lastInsertId();
// The result of the 'create' operation is all inserted products
$result[] = $product;
}
}
?>
Step 7 Implement read
.
<?php
if ($type == 'read') {
// Create SQL SELECT statement
$statement = $db->prepare('SELECT * FROM Products');
// Execute the statement
$statement->execute();
// The result of the 'read' operation is all products from the Products table
$result = $statement->fetchAll(PDO::FETCH_ASSOC);
}
?>
Step 8 Implement update
.
<?php
if ($type == 'update') {
// in batch mode the updated records are available in the 'models' field
$updatedProducts = $request->models;
foreach($updatedProducts as $product) {
// Create UPDATE SQL statement
$statement = $db->prepare('UPDATE Products SET ProductName = :productName, UnitPrice = :unitPrice, UnitsInStock = :unitsInStock, Discontinued = :discontinued WHERE ProductID = :productID');
// Bind parameter values
$statement->bindValue(':productID', $product->ProductID);
$statement->bindValue(':productName', $product->ProductName);
$statement->bindValue(':unitPrice', $product->UnitPrice);
$statement->bindValue(':unitsInStock', $product->UnitsInStock);
$statement->bindValue(':discontinued', $product->Discontinued);
// Execute the statement
$statement->execute();
}
}
?>
Step 9 Implement destroy
.
<?php
if ($type == 'destroy') {
// in batch mode the destroyed records are available in the 'models' field
$destroyedProducts = $request->models;
foreach($destroyedProducts as $product) {
// Create DELETE SQL statement
$statement = $db->prepare('DELETE FROM Products WHERE ProductID = :productID');
// Bind parameter values
$statement->bindValue(':productID', $product->ProductID);
// Execute the statement
$statement->execute();
}
}
?>
Step 10 Return the result of the operation as JSON.
<?php
// Set response content type
header('Content-Type: application/json');
echo json_encode($result);
?>
Use DataSourceResult Helpers
The DataSourceResult
class is a helper utility on top of PDO which simplifies common CRUD operations. The DataSourceResult
can also perform paging, sorting, filtering, grouping and aggregate calculations on the server side by generating SQL executed via PDO. It is distributed with the Telerik UI for PHP demos and can be found in the /wrappers/php/lib/
directory of the Telerik UI for PHP distribution.
First, configure a Kendo UI Grid for PHP binding and then implement the remote service which will return JSON.
Configuration (DataSourceResult)
Step 1 Follow the steps from the introductory article on Telerik UI for PHP—include the autoloader, JavaScript and CSS files.
Step 2 Create a data source and configure it.
<?php
// Configure the remote service - a PHP file called 'products.php'
// The query string parameter 'type' specifies the type of CRUD operation
$transport = new \Kendo\Data\DataSourceTransport();
$create = new \Kendo\Data\DataSourceTransportCreate();
$create->url('products.php?type=create')
->contentType('application/json')
->type('POST');
$read = new \Kendo\Data\DataSourceTransportRead();
$read->url('products.php?type=read')
->contentType('application/json')
->type('POST');
$update = new \Kendo\Data\DataSourceTransportUpdate();
$update->url('products.php?type=update')
->contentType('application/json')
->type('POST');
$destroy = new \Kendo\Data\DataSourceTransportDestroy();
$destroy->url('products.php?type=destroy')
->contentType('application/json')
->type('POST');
// Configure the transport. Send all data source parameters as JSON using the parameterMap setting.
$transport->create($create)
->read($read)
->update($update)
->destroy($destroy)
->parameterMap('function(data) {
return kendo.stringify(data);
}');
$model = new \Kendo\Data\DataSourceSchemaModel();
$productIDField = new \Kendo\Data\DataSourceSchemaModelField('ProductID');
$productIDField->type('number')
->editable(false)
->nullable(true);
$productNameField = new \Kendo\Data\DataSourceSchemaModelField('ProductName');
$productNameField->type('string')
->validation(array('required' => true));
$unitPriceValidation = new \Kendo\Data\DataSourceSchemaModelFieldValidation();
$unitPriceValidation->required(true)
->min(1);
$unitPriceField = new \Kendo\Data\DataSourceSchemaModelField('UnitPrice');
$unitPriceField->type('number')
->validation($unitPriceValidation);
$unitsInStockField = new \Kendo\Data\DataSourceSchemaModelField('UnitsInStock');
$unitsInStockField->type('number');
$discontinuedField = new \Kendo\Data\DataSourceSchemaModelField('Discontinued');
$discontinuedField->type('boolean');
$model->id('ProductID')
->addField($productIDField)
->addField($productNameField)
->addField($unitPriceField)
->addField($unitsInStockField)
->addField($discontinuedField);
// Configure the schema to accept the format returned by DataSourceResult
$schema = new \Kendo\Data\DataSourceSchema();
$schema->data('data')
->errors('errors')
->model($model)
->total('total');
$dataSource = new \Kendo\Data\DataSource();
$dataSource->transport($transport)
->batch(true)
->schema($schema);
?>
Step 3 Create a Grid, configure its columns and set its data source.
<?php
$grid = new \Kendo\UI\Grid('grid');
$productName = new \Kendo\UI\GridColumn();
$productName->field('ProductName')
->title('Product Name');
$unitPrice = new \Kendo\UI\GridColumn();
$unitPrice->field('UnitPrice')
->format('{0:c}')
->width(150)
->title('Unit Price');
$unitsInStock = new \Kendo\UI\GridColumn();
$unitsInStock->field('UnitsInStock')
->width(150)
->title('Units In Stock');
$discontinued = new \Kendo\UI\GridColumn();
$discontinued->field('Discontinued')
->width(100);
$command = new \Kendo\UI\GridColumn();
$command->addCommandItem('destroy')
->title(' ')
->width(110);
$grid->addColumn($productName, $unitPrice, $unitsInStock, $discontinued, $command)
->dataSource($dataSource)
->addToolbarItem(new \Kendo\UI\GridToolbarItem('create'),
new \Kendo\UI\GridToolbarItem('save'), new \Kendo\UI\GridToolbarItem('cancel'))
->height(400)
->editable(true);
?>
Step 4 Output the Grid by echoing the result of the render
method.
<?php
echo $grid->render();
?>
CRUD-Performing File Creation (DataSourceResult)
Step 1 Create a new PHP file called products.php
. This file will return data in JSON format.
Step 2 Copy /wrappers/php/lib/DataSourceResult.php
to your website root and include it.
<?php require_once 'lib/DataSourceResult.php'; ?>
Step 3 Read the request body and parse it as JSON. In the previous example, the Kendo UI DataSource is configured to submit its parameters as JSON via the parameterMap
.
<?php
$request = json_decode(file_get_contents('php://input'));
?>
Step 4 Create a new instance of the DataSourceResult
.
<?php
$result = new DataSourceResult('sqlite:../sample.db');
?>
Step 5 Get the current operation type, available as the type
query string parameter.
<?php
$type = $_GET['type'];
?>
Step 6 Declare a variable which will be returned as a result of the operation.
<?php
$data = null;
?>
Step 7 Implement create
.
<?php
if ($type == 'create') {
// The 'create' method of DataSourceResult accepts table name, array of column names, array of models and the name of the primary key column
$data = $result->create('Products', array('ProductID', 'ProductName', 'UnitPrice', 'UnitsInStock', 'Discontinued'), $request->models, 'ProductID');
}
?>
Step 8 Implement read
.
<?php
if ($type == 'read') {
// The 'read' method accepts table name, array of columns to select and request parameters as array
$data = $result->read('Products', array('ProductID', 'ProductName', 'UnitPrice', 'UnitsInStock', 'Discontinued'), $request));
}
?>
Step 9 Implement update
.
<?php
if ($type == 'update') {
// The 'update' method of DataSourceResult accepts table name, array of column names, array of models and the name of the primary key column
$data = $result->update('Products', array('ProductID', 'ProductName', 'UnitPrice', 'UnitsInStock', 'Discontinued'), $request->models, 'ProductID');
}
?>
Step 10 Implement destroy
.
<?php
if ($type == 'destroy') {
// The 'destroy' method of DataSourceResult accepts table name, array of models and the name of the primary key column
$data = $result->update('Products', $request->models, 'ProductID');
}
?>
Step 11 Return the result of the operation as JSON.
<?php
// Set response content type
header('Content-Type: application/json');
echo json_encode($data);
?>