File "StatusController.php"
Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/app/Http/Controllers/Admin/StatusController.php
File size: 3.07 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Http\Requests\Admin\MassDestroyStatusRequest;
use App\Http\Requests\Admin\StoreStatusRequest;
use App\Http\Requests\Admin\UpdateStatusRequest;
use App\Models\Status;
use Gate;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
use Yajra\DataTables\Facades\DataTables;
class StatusController extends Controller
{
public function index(Request $request)
{
abort_if(Gate::denies('status_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
if ($request->ajax()) {
$query = Status::query()->select(sprintf('%s.*', (new Status())->table));
$table = Datatables::of($query);
$table->addColumn('placeholder', ' ');
$table->addColumn('actions', ' ');
$table->editColumn('actions', function ($row) {
$viewGate = 'status_show';
$editGate = 'status_edit';
$deleteGate = 'status_delete';
$crudRoutePart = 'statuses';
return view('partials.datatablesActions', compact(
'viewGate',
'editGate',
'deleteGate',
'crudRoutePart',
'row'
));
});
$table->editColumn('id', function ($row) {
return $row->id ? $row->id : '';
});
$table->editColumn('name', function ($row) {
return $row->name ? $row->name : '';
});
$table->rawColumns(['actions', 'placeholder']);
return $table->make(true);
}
return view('admin.statuses.index');
}
public function create()
{
abort_if(Gate::denies('status_create'), Response::HTTP_FORBIDDEN, '403 Forbidden');
return view('admin.statuses.create');
}
public function store(StoreStatusRequest $request)
{
$status = Status::create($request->all());
return redirect()->route('admin.statuses.index');
}
public function edit(Status $status)
{
abort_if(Gate::denies('status_edit'), Response::HTTP_FORBIDDEN, '403 Forbidden');
return view('admin.statuses.edit', compact('status'));
}
public function update(UpdateStatusRequest $request, Status $status)
{
$status->update($request->all());
return redirect()->route('admin.statuses.index');
}
public function show(Status $status)
{
abort_if(Gate::denies('status_show'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$status->load('currentStatusOrders');
return view('admin.statuses.show', compact('status'));
}
public function destroy(Status $status)
{
abort_if(Gate::denies('status_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$status->delete();
return back();
}
public function massDestroy(MassDestroyStatusRequest $request)
{
Status::whereIn('id', request('ids'))->delete();
return response(null, Response::HTTP_NO_CONTENT);
}
}