2015-10-28 20:22:07 +01:00
|
|
|
<?php namespace App\Services;
|
|
|
|
|
|
|
|
use Illuminate\Foundation\Bus\DispatchesCommands;
|
2015-11-05 23:37:04 +01:00
|
|
|
use App\Services\DatatableService;
|
2015-10-28 20:22:07 +01:00
|
|
|
|
|
|
|
class BaseService
|
|
|
|
{
|
|
|
|
use DispatchesCommands;
|
|
|
|
|
|
|
|
protected function getRepo()
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2015-10-29 15:42:05 +01:00
|
|
|
public function bulk($ids, $action)
|
2015-10-28 20:22:07 +01:00
|
|
|
{
|
|
|
|
if ( ! $ids) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$entities = $this->getRepo()->findByPublicIdsWithTrashed($ids);
|
|
|
|
|
|
|
|
foreach ($entities as $entity) {
|
2015-10-29 15:42:05 +01:00
|
|
|
$this->getRepo()->$action($entity);
|
2015-10-28 20:22:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return count($entities);
|
|
|
|
}
|
2015-11-05 23:37:04 +01:00
|
|
|
|
|
|
|
public function createDatatable($entityType, $query, $showCheckbox = true, $hideClient = false)
|
|
|
|
{
|
2015-11-15 11:08:32 +01:00
|
|
|
$columns = $this->getDatatableColumns($entityType, !$showCheckbox);
|
2015-11-05 23:37:04 +01: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 20:22:07 +01:00
|
|
|
}
|