97 lines
2.9 KiB
PHP
Executable File
97 lines
2.9 KiB
PHP
Executable File
<?php
|
||
|
||
/**
|
||
* @var \Illuminate\Database\Eloquent\Collection $contents
|
||
* @var int $page_number
|
||
* @var \kernel\CgView $view
|
||
*/
|
||
|
||
use kernel\modules\post\models\Post;
|
||
use kernel\modules\user\models\User;
|
||
use Itguild\EloquentTable\EloquentDataProvider;
|
||
use Itguild\EloquentTable\ListEloquentTable;
|
||
use kernel\widgets\IconBtn\IconBtnCreateWidget;
|
||
use kernel\widgets\IconBtn\IconBtnDeleteWidget;
|
||
use kernel\widgets\IconBtn\IconBtnEditWidget;
|
||
use kernel\widgets\IconBtn\IconBtnViewWidget;
|
||
|
||
$get = (new \kernel\Request())->get();
|
||
|
||
$table = new ListEloquentTable(new EloquentDataProvider(Post::class, [
|
||
'currentPage' => $page_number,
|
||
'perPage' => 3,
|
||
'params' => ["class" => "table table-bordered", "border" => "2"],
|
||
'baseUrl' => "/admin/post",
|
||
'searchPrefix' => "",
|
||
'searchParams' => $get,
|
||
]));
|
||
|
||
$view->setTitle("Список постов");
|
||
$view->setMeta([
|
||
'description' => 'Список постов системы'
|
||
]);
|
||
|
||
$entityRelation = new \kernel\EntityRelation();
|
||
$additionals = $entityRelation->getEntityRelationsBySlug("post");
|
||
|
||
foreach ($additionals as $additional) {
|
||
$table->addColumn($additional, $additional, function ($id) use ($entityRelation, $additional) {
|
||
return $entityRelation->getAdditionalPropertyByEntityId("post", $id, $additional);
|
||
});
|
||
}
|
||
|
||
//\kernel\helpers\Debug::dd($request);
|
||
|
||
$table->columns([
|
||
'title' => [
|
||
'filter' => [
|
||
'class' => \kernel\filters\BootstrapTextFilter::class,
|
||
'value' => $get['title'] ?? ''
|
||
]
|
||
],
|
||
'content' => [
|
||
'filter' => [
|
||
'class' => \kernel\filters\BootstrapTextFilter::class,
|
||
'value' => $get['content'] ?? ''
|
||
]
|
||
],
|
||
'created_at' => [
|
||
'format' => 'date:d-m-Y',
|
||
],
|
||
'updated_at' => function ($data) {
|
||
if (!$data) {
|
||
return null;
|
||
}
|
||
|
||
return (new DateTimeImmutable($data))->format("d-m-Y");
|
||
},
|
||
'user_id' => [
|
||
'value' => function ($data) {
|
||
return User::find($data)->username;
|
||
},
|
||
'filter' => [
|
||
'class' => \kernel\filters\BootstrapSelectFilter::class,
|
||
'params' => [
|
||
'options' => \kernel\modules\user\service\UserService::createUsernameArr(),
|
||
'prompt' => 'Не выбрано'
|
||
],
|
||
'value' => $get['user_id'] ?? '',
|
||
],
|
||
]
|
||
]);
|
||
|
||
|
||
$table->beforePrint(function () {
|
||
return IconBtnCreateWidget::create(['url' => '/admin/post/create'])->run();
|
||
});
|
||
$table->addAction(function ($row) {
|
||
return IconBtnViewWidget::create(['url' => '/admin/post/view/' . $row['id']])->run();
|
||
});
|
||
$table->addAction(function ($row) {
|
||
return IconBtnEditWidget::create(['url' => '/admin/post/update/' . $row['id']])->run();
|
||
});
|
||
$table->addAction(function ($row) {
|
||
return IconBtnDeleteWidget::create(['url' => '/admin/post/delete/' . $row['id']])->run();
|
||
});
|
||
$table->create();
|
||
$table->render(); |