PATH:
home
/
lab2454c
/
crypto.keyreum.com
/
platform
/
plugins
/
newsletter
/
src
/
Tables
<?php namespace Botble\Newsletter\Tables; use BaseHelper; use Botble\Newsletter\Enums\NewsletterStatusEnum; use Botble\Newsletter\Repositories\Interfaces\NewsletterInterface; use Botble\Table\Abstracts\TableAbstract; use Illuminate\Contracts\Routing\UrlGenerator; use Illuminate\Support\Facades\Auth; use Illuminate\Validation\Rule; use Yajra\DataTables\DataTables; class NewsletterTable extends TableAbstract { /** * @var bool */ protected $hasActions = true; /** * @var bool */ protected $hasFilter = true; /** * NewsletterTable constructor. * @param DataTables $table * @param UrlGenerator $urlGenerator * @param NewsletterInterface $newsletterRepository */ public function __construct( DataTables $table, UrlGenerator $urlGenerator, NewsletterInterface $newsletterRepository ) { parent::__construct($table, $urlGenerator); $this->repository = $newsletterRepository; if (!Auth::user()->hasPermission('newsletter.destroy')) { $this->hasOperations = false; $this->hasActions = false; } } /** * {@inheritDoc} */ public function ajax() { $data = $this->table ->eloquent($this->query()) ->editColumn('checkbox', function ($item) { return $this->getCheckbox($item->id); }) ->editColumn('name', function ($item) { return trim($item->name) ?: '—'; }) ->editColumn('created_at', function ($item) { return BaseHelper::formatDate($item->created_at); }) ->editColumn('status', function ($item) { return $item->status->toHtml(); }) ->addColumn('operations', function ($item) { return $this->getOperations(null, 'newsletter.destroy', $item); }); return $this->toJson($data); } /** * {@inheritDoc} */ public function query() { $query = $this->repository->getModel()->select([ 'id', 'email', 'name', 'created_at', 'status', ]); return $this->applyScopes($query); } /** * {@inheritDoc} */ public function columns() { return [ 'id' => [ 'title' => trans('core/base::tables.id'), 'width' => '20px', ], 'email' => [ 'title' => trans('core/base::tables.email'), 'class' => 'text-left', ], 'name' => [ 'title' => trans('core/base::tables.name'), 'class' => 'text-left', ], 'created_at' => [ 'title' => trans('core/base::tables.created_at'), 'width' => '100px', ], 'status' => [ 'title' => trans('core/base::tables.status'), 'width' => '100px', ], ]; } /** * {@inheritDoc} */ public function bulkActions(): array { return $this->addDeleteAction(route('newsletter.deletes'), 'newsletter.destroy', parent::bulkActions()); } /** * {@inheritDoc} */ public function getBulkChanges(): array { return [ 'name' => [ 'title' => trans('core/base::tables.name'), 'type' => 'text', 'validate' => 'required|max:120', ], 'email' => [ 'title' => trans('core/base::tables.email'), 'type' => 'text', 'validate' => 'required|max:120|email', ], 'status' => [ 'title' => trans('core/base::tables.status'), 'type' => 'customSelect', 'choices' => NewsletterStatusEnum::labels(), 'validate' => 'required|' . Rule::in(NewsletterStatusEnum::values()), ], 'created_at' => [ 'title' => trans('core/base::tables.created_at'), 'type' => 'date', ], ]; } /** * {@inheritDoc} */ public function getDefaultButtons(): array { return [ 'export', 'reload', ]; } }
[-] NewsletterTable.php
[edit]
[+]
..