2024-07-24 17:22:59 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \Illuminate\Database\Eloquent\Collection $users
|
2024-07-30 15:49:07 +03:00
|
|
|
* @var int $page_id
|
2024-07-24 17:22:59 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
use app\models\User;
|
2024-07-25 16:15:18 +03:00
|
|
|
use app\tables\columns\UserDeleteActionColumn;
|
2024-07-24 17:22:59 +03:00
|
|
|
use app\tables\columns\UserEditActionColumn;
|
|
|
|
use app\tables\columns\UserViewActionColumn;
|
|
|
|
use Itguild\Tables\ListJsonTable;
|
|
|
|
use kernel\IGTabel\btn\PrimaryBtn;
|
|
|
|
use kernel\IGTabel\ListJsonTableEloquentCollection;
|
|
|
|
|
2024-07-30 15:49:07 +03:00
|
|
|
$perPage = 3;
|
|
|
|
$chunks = $users->forPage($page_id, $perPage);
|
|
|
|
$dataProvider = new ListJsonTableEloquentCollection($chunks, [
|
2024-07-24 17:22:59 +03:00
|
|
|
'model' => User::class,
|
|
|
|
'perPage' => 5,
|
|
|
|
'params' => ["class" => "table table-bordered", "border" => "2"],
|
|
|
|
'baseUrl' => "/admin/user",
|
|
|
|
]);
|
|
|
|
$table = new ListJsonTable($dataProvider->getJson());
|
2024-07-30 12:27:44 +03:00
|
|
|
$table->beforePrint(function () {
|
2024-07-24 17:22:59 +03:00
|
|
|
return PrimaryBtn::create("Создать", "/admin/user/create")->fetch();
|
|
|
|
//return (new PrimaryBtn("Создать", "/admin/user/create"))->fetch();
|
|
|
|
});
|
2024-07-30 15:49:07 +03:00
|
|
|
$table->afterPrint(function () use ($page_id, $users, $perPage) {
|
|
|
|
$pagination = new \Itguild\Tables\Pagination($users->count(), $perPage, $page_id, "/admin/user/page");
|
2024-07-30 12:27:44 +03:00
|
|
|
$pagination->create();
|
|
|
|
return $pagination->fetch();
|
|
|
|
});
|
2024-07-24 17:22:59 +03:00
|
|
|
$table->addAction(UserViewActionColumn::class);
|
|
|
|
$table->addAction(UserEditActionColumn::class);
|
2024-07-25 16:15:18 +03:00
|
|
|
$table->addAction(UserDeleteActionColumn::class);
|
2024-07-24 17:22:59 +03:00
|
|
|
$table->create();
|
|
|
|
$table->render();
|