Cetaklabel/Http/Controllers/JobController.php

213 lines
6.7 KiB
PHP
Raw Normal View History

2023-05-15 10:03:46 +00:00
<?php
2023-05-20 14:09:49 +00:00
namespace Modules\Cetaklabel\Http\Controllers;
2023-05-15 10:03:46 +00:00
use App\Http\Controllers\Controller;
use Exception;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
2023-07-21 09:37:07 +00:00
use Modules\Cetaklabel\Entities\Approval;
2023-05-20 14:09:49 +00:00
use Modules\Cetaklabel\DataTables\JobDataTable;
use Modules\Cetaklabel\Entities\Directorat;
use Modules\Cetaklabel\Entities\Job;
use Modules\Cetaklabel\Http\Requests\Job\StoreJobRequest;
use Modules\Cetaklabel\Http\Requests\Job\UpdateJobRequest;
2023-05-15 10:03:46 +00:00
class JobController extends Controller
{
public $user;
public function __construct()
{
$this->middleware(function ($request, $next) {
$this->user = Auth::guard('web')->user();
return $next($request);
});
}
/**
* Display a listing of the Jobs.
*
2023-05-20 14:09:49 +00:00
* @param \Modules\Cetaklabel\DataTables\JobDataTable $dataTable
2023-05-15 10:03:46 +00:00
* @param \Illuminate\Http\Request $request
*
* @return mixed|void
*/
public function index(JobDataTable $dataTable, Request $request)
{
2023-07-20 02:42:53 +00:00
if (isset($request->sub_directorat_id) && !empty($request->sub_directorat_id)) {
$this->show($request);
return;
}
if (is_null($this->user) || !$this->user->can('master.read')) {
2023-05-15 10:03:46 +00:00
abort(403, 'Sorry !! You are Unauthorized to view any master data !');
}
// Add Vendor
addVendor('chained-select');
$directorat = Directorat::all();
return $dataTable->render('cetaklabel::masters.job.index', compact('directorat'));
}
/**
* Lists the specified Job by Sub Directorat ID.
*
* @param \Illuminate\Http\Request $request
*
* @return void
*/
public function show(Request $request)
{
$jobs = Job::where('sub_directorat_id', $request->sub_directorat_id)->get();
$data = [];
foreach ($jobs as $row) {
$result = [
$row->id => $row->name,
];
$data[] = $result;
}
echo json_encode($data);
}
/**
* Store a newly created Job in storage.
*
2023-05-20 14:09:49 +00:00
* @param \Modules\Cetaklabel\Http\Requests\Job\StoreJobRequest $request
2023-05-15 10:03:46 +00:00
*
* @return void
*/
public function store(StoreJobRequest $request)
{
if (is_null($this->user) || !$this->user->can('master.create')) {
2023-05-15 10:03:46 +00:00
abort(403, 'Sorry !! You are Unauthorized to create any master data !');
}
// Validate the request...
$validated = $request->validated();
// Store the Job...
if ($validated) {
try {
2023-07-20 02:42:53 +00:00
$approval = [
'method' => 'create',
2023-08-10 04:35:07 +00:00
'menu' => 'Job',
2023-07-20 02:42:53 +00:00
'new_request' => json_encode($validated),
'description' => 'Create new Job',
'status' => '0',
];
Approval::create($approval);
2023-05-15 10:03:46 +00:00
echo json_encode(['status' => 'success', 'message' => 'Job created successfully.']);
} catch (Exception $e) {
echo json_encode(['status' => 'error', 'message' => 'Job created failed.']);
}
return;
}
echo json_encode(['status' => 'error', 'message' => 'Job created failed.']);
}
/**
* Show the form for creating a new Job.
*/
public function create()
{
if (is_null($this->user) || !$this->user->can('master.create')) {
2023-05-15 10:03:46 +00:00
abort(403, 'Sorry !! You are Unauthorized to create any master data !');
}
abort(404);
}
/**
* Show the form for editing the specified Job.
*
* @param $id
*
* @return void
*/
public function edit($id)
{
if (is_null($this->user) || !$this->user->can('master.update')) {
2023-05-15 10:03:46 +00:00
abort(403, 'Sorry !! You are Unauthorized to update any master data !');
}
$job = Job::find($id);
echo json_encode($job);
}
/**
* Update the specified Job in storage.
*
2023-05-20 14:09:49 +00:00
* @param \Modules\Cetaklabel\Http\Requests\Job\UpdateJobRequest $request
* @param \Modules\Cetaklabel\Entities\Job $job
2023-05-15 10:03:46 +00:00
*
* @return void
*/
public function update(UpdateJobRequest $request, Job $job)
{
if (is_null($this->user) || !$this->user->can('master.update')) {
2023-05-15 10:03:46 +00:00
abort(403, 'Sorry !! You are Unauthorized to update any master data !');
}
// Validate the request...
$validated = $request->validated();
// Update the Job...
if ($validated) {
try {
2023-07-20 02:42:53 +00:00
$approval = [
'method' => 'update',
2023-08-10 04:35:07 +00:00
'menu' => 'Job',
2023-07-20 02:42:53 +00:00
'new_request' => json_encode($validated),
'old_request' => json_encode($job),
'description' => 'Update Job',
'status' => '0',
];
Approval::create($approval);
2023-05-15 10:03:46 +00:00
echo json_encode(['status' => 'success', 'message' => 'Job updated successfully.']);
} catch (Exception $e) {
echo json_encode(['status' => 'error', 'message' => 'Job updated failed.']);
}
return;
}
echo json_encode(['status' => 'error', 'message' => 'Job updated failed.']);
}
/**
* Remove the specified Job from storage.
*
2023-05-20 14:09:49 +00:00
* @param \Modules\Cetaklabel\Entities\Job $job
2023-05-15 10:03:46 +00:00
*
* @return void
*/
public function destroy(Job $job)
{
if (is_null($this->user) || !$this->user->can('master.delete')) {
2023-05-15 10:03:46 +00:00
abort(403, 'Sorry !! You are Unauthorized to delete any master data !');
}
2023-07-20 02:42:53 +00:00
$approval = [
'method' => 'delete',
2023-08-10 04:35:07 +00:00
'menu' => 'Job',
2023-07-20 02:42:53 +00:00
'old_request' => json_encode($job),
'description' => 'Delete Job',
'status' => '0',
];
Approval::create($approval);
2023-05-15 10:03:46 +00:00
echo json_encode(['status' => 'success', 'message' => 'Job deleted successfully.']);
}
}