CodeIgniter DataTables
DataTables server-side for CodeIgniter, supported both for CodeIgniter 3 and CodeIgniter 4.
Note: This library only handle the server-side part, you still needs to configure the client side like jQuery, DataTables library and including the styles.
Requirements
If you are using CodeIgniter, you can use this library with no extra requirement.
Installation
You just need to use composer and everything is done.
composer require ngekoding/codeigniter-datatables
Usage
Here is the basic example to use this library, you are freely make any changes for the client side, like defining searchable column, orderable column, etc...
CodeIgniter 3 Example
// CodeIgniter 3 Example
// Here we will select all fields from posts table
// and make a join with categories table
// Please note: we don't need to call ->get() here
$queryBuilder = $this->db->select('p.*, c.name category')
->from('posts p')
->join('categories c', 'c.id=p.category_id');
/**
* The first parameter is the query builder instance
* and the second is the codeigniter version (3 or 4)
*/
$datatables = new Ngekoding\CodeIgniterDataTables\DataTables($queryBuilder, '3');
$datatables->generate(); // done
CodeIgniter 4 Example
// CodeIgniter 4 Example
$db = db_connect();
$queryBuilder = $db->from('posts p')
->select('p.*, c.name category')
->join('categories c', 'c.id=p.category_id');
$datatables = new Ngekoding\CodeIgniterDataTables\DataTables($queryBuilder, '4');
$datatables->generate(); // done
The above examples will give you for ajax data source (arrays), so you need to make sure the table header you makes for the client side is match with the ajax response. We will talk about the objects data source below.
Client Side Examples
You must include the jQuery and DataTables library.
<link href="https://cdn.datatables.net/1.11.5/css/jquery.dataTables.min.css" rel="stylesheet">
<table id="table-post" class="display" width="100%">
<thead>
<th>ID</th>
<th>Title</th>
<th>Category</th>
<th>Description</th>
</thead>
</table>
<script src="https://code.jquery.com/jquery-3.5.1.js"></script>
<script src="https://cdn.datatables.net/1.11.5/js/jquery.dataTables.min.js"></script>
<script>
$('#table-post').DataTable({
processing: true,
serverSide: true,
ajax: {
url: 'http://localhost/project/index.php/post/ajax_datatables', // Change with your own
method: 'GET', // You are freely to use POST or GET
}
})
</script>
Objects Data Source
As was mentioned above, the default data source we get is an arrays. It is easy also to get the objects data source.
To get objects response, you just need to call asObject()
method.
$datatables->asObject()
->generate();
And then you can configure the client side with columns option to fit your data.
$('#table-post').DataTable({
processing: true,
serverSide: true,
ajax: {
url: 'http://localhost/project/index.php/post/ajax_datatables',
method: 'GET',
},
columns: [
{ data: 'id' },
{ data: 'title' },
{ data: 'category' },
{ data: 'description' }
]
})
</script>
Some Others Settings
Some basic functionalities already available, here is the full settings you can doing to this library.
Use class for spesify the CodeIgniter version
// General, use the second param to define the version
// The default is 4
$datatables = new Ngekoding\CodeIgniterDataTables\DataTables($queryBuilder, '3');
// CodeIgniter 3
$datatables = new Ngekoding\CodeIgniterDataTables\DataTablesCodeIgniter3($queryBuilder);
// CodeIgniter 4
$datatables = new Ngekoding\CodeIgniterDataTables\DataTablesCodeIgniter4($queryBuilder);
Available Options
$datatables = new Ngekoding\CodeIgniterDataTables\DataTables($queryBuilder);
// Return the output as objects instead of arrays
$datatables->asObject();
// Only return title & category (accept string or array)
$datatables->only(['title', 'category']);
// Return all except the id
// You may use one of only or except
$datatables->except(['id']);
// Format the output
$datatables->format('title', function($value, $row) {
return '<b>'.$value.'</b>';
});
// Add extra column
$datatables->addColumn('action', function($row) {
return '<a href="url/to/delete/post/'.$row->id.'">Delete</a>';
});
// Add squence number
// The default key is `sequenceNumber`
// You can change it with give the param
$datatables->addSequenceNumber();
$datatables->addSequenceNumber('rowNumber'); // It will be rowNumber
// Don't forget ot call generate to get the results
$datatables->generate();
Another Example
I already use this library to the existing project with completed CRUD operations, you can found it here.
Please look at these files:
- application/composer.json
- application/controllers/Post.php
- application/models/M_post.php
- application/views/template.php
- application/views/posts/index-datatables.php
- application/helpers/api_helper.php
- assets/js/custom.js