merkeleon / laravel-table
Table functionality for Laravel collections
1.5.12
2020-01-15 11:29 UTC
Requires
- php: >=5.3.0
- doctrine/dbal: ~2.3
- laravel/framework: 5.*|6.*
- maatwebsite/excel: ^3.0
- dev-master
- 1.5.12
- 1.5.11
- 1.5.10
- 1.5.9
- 1.5.8
- 1.5.7
- 1.5.6
- 1.5.5
- 1.5.0
- 1.4.6
- 1.4.5
- 1.4.4
- 1.4.3
- 1.4.2
- 1.4.1
- 1.4.0
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.1
- 1.2.0
- 1.1.5
- 1.1.4
- 1.1.0
- 1.0.18
- 1.0.17
- 1.0.16
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- v1.0.1
- v1.0.0
- dev-dev
- dev-dev-add-options-to-callback-filter
This package is auto-updated.
Last update: 2024-10-29 05:22:18 UTC
README
Laravel module for table rendering
Installation
First, require the package using Composer:
composer require merkeleon/laravel-table
Add to your config/app.php providers section
Merkeleon\Table\Providers\TableServiceProvider::class
and to facades section
'Table' => Merkeleon\Table\Facades\Table::class
Add the views and the localization files:
php artisan vendor:publish --provider="Merkeleon\Table\Providers\TableServiceProvider"
Examples
Translations
Soon
Table class
<?php
namespace App\Tables\Admin;
use App\Models\User;
use App\Models\Role;
use Table;
use Merkeleon\Table\Filter\SelectFilter;
class UsersTable extends Table
{
public static function create() {
$roles = Role::all()->pluck('name', 'id');
$table = self::from(new User())
->columns([
'id' => 'Id',
'name' => 'Name',
'email' => 'Email',
'balance' => 'Balance',
'created_at' => 'Created at'
])
/*
For filters allowed types: string, range, date
*/
->filters([
'name' => 'string',
/*
String filter can be strict (key=value) or not (key like %value%)
*/
'email' => 'string|strict:true',
'role_id' => (new SelectFilter('role_id'))
->options($roles)
->label('Role'),
/*
You can specify settings for some of the filters.
Eg: range filter can take multiplier as the argument
*/
'balance' => 'range|multiplier:10000',
'created_at' => 'date'
])
/*
For totals allowed types: sum, count
*/
->totals([
'balance' => 'sum',
'id' => 'count'
])
/*
Sometimes you need to filter results without input
If User with moderation role can't view admin users
*/
->filterCallback(function($model) {
if (auth()->user() && auth()->user()->role->type == Role::TYPE_MODERATOR) {
$model = $model->whereHas('role', function($query) {
$query->where('type', '<>', Role::TYPE_ADMIN);
});
}
return $model;
})
/*
Group operations for query
Label for delete batch action is: trans('table::batch.labels.delete');
*/
->batchActions([
'delete' => function ($queryBuilder) {
$queryBuilder->delete();
}
])
->sortables([
'id'
])
->exporters(['csv'])
/*
Route name -> Link name in last column
*/
->actions([
'admin.users.view' => 'View'
])
->orderBy('id', 'asc')
->paginate(20);
return $table;
}
}
Controller
<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Tables\Admin\UsersTable;
class UsersController extends Controller
{
public function index() {
$table = UsersTable::create();
return view('admin.users.index', [
'table' => $table
]);
}
}
View
@extends('admin.layout')
@section('content')
{!! $table->render() !!}
@stop
Sample Sass based on bootstrap v4
.table {
tbody {
.ctable-total-content {
border: none;
background-color: transparent !important;
td {
border: none;
background-color: transparent;
font-size: 80%;
padding-top: 0;
}
}
.ctable-total-heading {
border: none;
background-color: transparent !important;
td {
border: none;
background-color: transparent;
font-size: 80%;
font-weight: bold;
}
}
tr:nth-of-type(even) {
td.ctable-ordered {
background-color: rgba(0, 0, 0, 0.10);
}
}
tr:nth-of-type(odd) {
td.ctable-ordered {
background-color: rgba(0, 0, 0, 0.17);
}
}
}
thead {
a {
text-decoration: none;
}
}
.table-arrow-up:before {
font: normal normal normal 16px/1 "Material Design Icons";
content: mdi('arrow-up');
text-decoration: none;
}
.table-arrow-down:before {
font: normal normal normal 16px/1 "Material Design Icons";
content: mdi('arrow-down');
text-decoration: none;
}
}
Some recommendations for JS
Use Flatpickr library for datepicker
require('flatpickr')('[data-toggle=datepicker]');