2015-10-28 21:22:07 +02:00
|
|
|
<?php namespace App\Services;
|
|
|
|
|
|
2016-03-02 15:36:42 +02:00
|
|
|
use Illuminate\Foundation\Bus\DispatchesJobs;
|
2015-11-06 00:37:04 +02:00
|
|
|
use App\Services\DatatableService;
|
2015-10-28 21:22:07 +02:00
|
|
|
|
|
|
|
|
class BaseService
|
|
|
|
|
{
|
2016-03-02 15:36:42 +02:00
|
|
|
use DispatchesJobs;
|
2015-10-28 21:22:07 +02:00
|
|
|
|
|
|
|
|
protected function getRepo()
|
|
|
|
|
{
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-29 16:42:05 +02:00
|
|
|
public function bulk($ids, $action)
|
2015-10-28 21:22:07 +02:00
|
|
|
{
|
2016-03-15 22:38:42 -04:00
|
|
|
if ( ! $ids ) {
|
2015-10-28 21:22:07 +02:00
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$entities = $this->getRepo()->findByPublicIdsWithTrashed($ids);
|
|
|
|
|
|
|
|
|
|
foreach ($entities as $entity) {
|
2016-04-25 21:53:39 -04:00
|
|
|
if(Auth::user()->can('edit', $entity)){
|
2016-03-15 22:07:11 -04:00
|
|
|
$this->getRepo()->$action($entity);
|
|
|
|
|
}
|
2015-10-28 21:22:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return count($entities);
|
|
|
|
|
}
|
2015-11-06 00:37:04 +02:00
|
|
|
|
|
|
|
|
public function createDatatable($entityType, $query, $showCheckbox = true, $hideClient = false)
|
|
|
|
|
{
|
2015-11-15 12:08:32 +02:00
|
|
|
$columns = $this->getDatatableColumns($entityType, !$showCheckbox);
|
2015-11-06 00:37:04 +02:00
|
|
|
$actions = $this->getDatatableActions($entityType);
|
|
|
|
|
|
|
|
|
|
return $this->datatableService->createDatatable($entityType, $query, $columns, $actions, $showCheckbox);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getDatatableColumns($entityType, $hideClient)
|
|
|
|
|
{
|
|
|
|
|
return [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getDatatableActions($entityType)
|
|
|
|
|
{
|
|
|
|
|
return [];
|
|
|
|
|
}
|
2015-10-28 21:22:07 +02:00
|
|
|
}
|