X7ROOT File Manager
Current Path:
/home/gfecatvj/sites/restate/platform/plugins/blog/src/Tables
home
/
gfecatvj
/
sites
/
restate
/
platform
/
plugins
/
blog
/
src
/
Tables
/
📁
..
📄
CategoryTable.php
(5.01 KB)
📄
PostTable.php
(8.48 KB)
📄
TagTable.php
(4.71 KB)
Editing: PostTable.php
<?php namespace Botble\Blog\Tables; use Illuminate\Support\Facades\Auth; use Botble\Base\Enums\BaseStatusEnum; use Botble\Blog\Exports\PostExport; use Botble\Blog\Models\Post; use Botble\Blog\Repositories\Interfaces\CategoryInterface; use Botble\Blog\Repositories\Interfaces\PostInterface; use Botble\Table\Abstracts\TableAbstract; use Carbon\Carbon; use Html; use Illuminate\Contracts\Routing\UrlGenerator; use Yajra\DataTables\DataTables; class PostTable extends TableAbstract { /** * @var bool */ protected $hasActions = true; /** * @var bool */ protected $hasFilter = true; /** * @var CategoryInterface */ protected $categoryRepository; /** * @var string */ protected $exportClass = PostExport::class; /** * @var int */ protected $defaultSortColumn = 6; /** * PostTable constructor. * @param DataTables $table * @param UrlGenerator $urlGenerator * @param PostInterface $postRepository * @param CategoryInterface $categoryRepository */ public function __construct( DataTables $table, UrlGenerator $urlGenerator, PostInterface $postRepository, CategoryInterface $categoryRepository ) { $this->repository = $postRepository; $this->setOption('id', 'table-posts'); $this->categoryRepository = $categoryRepository; parent::__construct($table, $urlGenerator); if (Auth::check() && !Auth::user()->hasAnyPermission(['posts.edit', 'posts.destroy'])) { $this->hasOperations = false; $this->hasActions = false; } } /** * {@inheritDoc} */ public function ajax() { $data = $this->table ->eloquent($this->query()) ->editColumn('name', function ($item) { if (Auth::check() && !Auth::user()->hasPermission('posts.edit')) { return $item->name; } return Html::link(route('posts.edit', $item->id), $item->name); }) ->editColumn('image', function ($item) { if ($this->request()->input('action') === 'excel') { return get_object_image($item->image, 'thumb'); } return Html::image(get_object_image($item->image, 'thumb'), $item->name, ['width' => 50]); }) ->editColumn('checkbox', function ($item) { return table_checkbox($item->id); }) ->editColumn('created_at', function ($item) { return date_from_database($item->created_at, config('core.base.general.date_format.date')); }) ->editColumn('updated_at', function ($item) { return implode(', ', $item->categories->pluck('name')->all()); }) ->editColumn('author_id', function ($item) { return $item->author ? $item->author->getFullName() : null; }) ->editColumn('status', function ($item) { if ($this->request()->input('action') === 'excel') { return $item->status->getValue(); } return $item->status->toHtml(); }); return apply_filters(BASE_FILTER_GET_LIST_DATA, $data, $this->repository->getModel()) ->addColumn('operations', function ($item) { return table_actions('posts.edit', 'posts.destroy', $item); }) ->escapeColumns([]) ->make(true); } /** * {@inheritDoc} */ public function query() { $model = $this->repository->getModel(); $query = $model ->with(['categories']) ->select([ 'posts.id', 'posts.name', 'posts.image', 'posts.created_at', 'posts.status', 'posts.updated_at', 'posts.author_id', 'posts.author_type', ]); return $this->applyScopes(apply_filters(BASE_FILTER_TABLE_QUERY, $query, $model)); } /** * {@inheritDoc} */ public function columns() { return [ 'id' => [ 'name' => 'posts.id', 'title' => trans('core/base::tables.id'), 'width' => '20px', ], 'image' => [ 'name' => 'posts.image', 'title' => trans('core/base::tables.image'), 'width' => '70px', ], 'name' => [ 'name' => 'posts.name', 'title' => trans('core/base::tables.name'), 'class' => 'text-left', ], 'updated_at' => [ 'name' => 'posts.updated_at', 'title' => trans('plugins/blog::posts.categories'), 'width' => '150px', 'class' => 'no-sort', 'orderable' => false, ], 'author_id' => [ 'name' => 'posts.author_id', 'title' => trans('plugins/blog::posts.author'), 'width' => '150px', 'class' => 'no-sort', 'orderable' => false, ], 'created_at' => [ 'name' => 'posts.created_at', 'title' => trans('core/base::tables.created_at'), 'width' => '100px', ], 'status' => [ 'name' => 'posts.status', 'title' => trans('core/base::tables.status'), 'width' => '100px', ], ]; } /** * {@inheritDoc} */ public function buttons() { $buttons = $this->addCreateButton(route('posts.create'), 'posts.create'); return apply_filters(BASE_FILTER_TABLE_BUTTONS, $buttons, Post::class); } /** * {@inheritDoc} */ public function bulkActions(): array { return $this->addDeleteAction(route('posts.deletes'), 'posts.destroy', parent::bulkActions()); } /** * {@inheritDoc} */ public function getBulkChanges(): array { return [ 'posts.name' => [ 'title' => trans('core/base::tables.name'), 'type' => 'text', 'validate' => 'required|max:120', ], 'posts.status' => [ 'title' => trans('core/base::tables.status'), 'type' => 'select', 'choices' => BaseStatusEnum::labels(), 'validate' => 'required|in:' . implode(',', BaseStatusEnum::values()), ], 'category' => [ 'title' => trans('plugins/blog::posts.category'), 'type' => 'select-search', 'validate' => 'required', 'callback' => 'getCategories', ], 'posts.created_at' => [ 'title' => trans('core/base::tables.created_at'), 'type' => 'date', 'validate' => 'required', ], ]; } /** * @return array */ public function getCategories(): array { return $this->categoryRepository->pluck('categories.name', 'categories.id'); } /** * {@inheritDoc} */ public function applyFilterCondition($query, string $key, string $operator, ?string $value) { switch ($key) { case 'posts.created_at': $value = Carbon::createFromFormat('Y/m/d', $value)->toDateString(); return $query->whereDate($key, $operator, $value); case 'category': return $query->join('post_categories', 'post_categories.post_id', '=', 'posts.id') ->join('categories', 'post_categories.category_id', '=', 'categories.id') ->where('post_categories.category_id', '=', $value); } return parent::applyFilterCondition($query, $key, $operator, $value); } /** * {@inheritDoc} */ public function saveBulkChangeItem($item, string $inputKey, ?string $inputValue) { if ($inputKey === 'category') { $item->categories()->sync([$inputValue]); return $item; } return parent::saveBulkChangeItem($item, $inputKey, $inputValue); } /** * {@inheritDoc} */ public function getDefaultButtons(): array { return ['excel', 'reload']; } }
Upload File
Create Folder