https://github.com/imerr/laravel-query-table
Laravel plugin for displaying query results as a table with built-in filtering/sorting/pagination
https://github.com/imerr/laravel-query-table
Last synced: 3 months ago
JSON representation
Laravel plugin for displaying query results as a table with built-in filtering/sorting/pagination
- Host: GitHub
- URL: https://github.com/imerr/laravel-query-table
- Owner: imerr
- Created: 2023-06-29T03:13:18.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2025-05-17T13:48:05.000Z (8 months ago)
- Last Synced: 2025-09-13T13:26:41.730Z (4 months ago)
- Language: PHP
- Size: 14.6 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# QueryTable
A laravel plugin for displaying query results as a table with built-in filtering/sorting/pagination.
Views use bootstrap and font-awesome, but can be published and modified via `php artisan vendor:publish --provider="imer\QueryTable\QueryTableProvider"` command
While this package is still in early stages the api might still change for better usability
Example:
```php
use imer\QueryTable;
use imer\QueryTable\HtmlString;
// ...
$countries = ["de" => "Germany", "gb" => "United Kingdom", "us" => "United States"];
$customers = (new QueryTable($request, Customer::query()))
->addField(
(new QueryTable\Field("customer_number"))
->sortable()
->filter(new QueryTable\TextFilter())
->formatAsLink(function (Customer $r) {
return route("customer.show", ["id" => $r->id]);
})
)
->addField(
(new QueryTable\Field("company"))
->sortable()
->filter(new QueryTable\TextFilter())
)
->addField((new QueryTable\Field("name"))->sortable()->filter(new QueryTable\TextFilter()))
->addField((new QueryTable\Field("email"))->sortable()->filter(new QueryTable\TextFilter()))
->addField(
// Filter by yes/no
(new QueryTable\Field("tax_exempt"))
->sortable()
->filter(new QueryTable\BoolFilter())
->formatter(function ($v) {
return $v ? trans("misc.yes") : trans("misc.no");
})
)
->addField(
// Country field with a dropdown filter
(new QueryTable\Field("country"))
->sortable()
->filter(new QueryTable\DropdownFilter($countries))
->formatter(function ($v) use ($countries) {
return $countries[$v] ?? "n/a";
})
)
->addField((new QueryTable\ViewField("customer._table_actions"))
->nameText(new HtmlString('')));
// pass $customers to your view and simply output the table:
// {!! $customers !!}
```
Turns into: 
Filter demo: https://github.com/imerr/laravel-query-table/assets/1426904/000197cf-09ff-41bc-acf6-eb01bd1a98e8