198 lines
5.3 KiB
PHP
198 lines
5.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Backend;
|
|
|
|
use Exception;
|
|
use App\Models\Jati;
|
|
use App\Constant\Constant;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Support\Facades\Log;
|
|
use App\Http\Controllers\BaseController;
|
|
use App\Http\Requests\Jati\StoreJatiRequest;
|
|
use App\Http\Requests\Jati\UpdateJatiRequest;
|
|
use App\Models\Dharma;
|
|
use App\Repositories\Backend\Jati\JatiService;
|
|
|
|
class JatiController extends BaseController
|
|
{
|
|
/**
|
|
* @var JatiService
|
|
*/
|
|
protected $jatiService;
|
|
|
|
/**
|
|
* JatiController constructor.
|
|
* @param JatiService $jatiService
|
|
*/
|
|
public function __construct(JatiService $jatiService)
|
|
{
|
|
$this->jatiService = $jatiService;
|
|
}
|
|
|
|
/**
|
|
* This function is returning the Datatable columns response
|
|
*
|
|
* @param Request $request
|
|
* @return array|object
|
|
*/
|
|
public function getJatiListing(Request $request)
|
|
{
|
|
$response = [];
|
|
try {
|
|
$response = $this->jatiService->getForDataTable($request->all());
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
|
|
return $response;
|
|
}
|
|
|
|
/**
|
|
* Display a listing of the resource.
|
|
*
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function index()
|
|
{
|
|
try {
|
|
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
|
|
return view('backend.jati.list');
|
|
}
|
|
|
|
/**
|
|
* Show the form for creating a new resource.
|
|
*
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function create()
|
|
{
|
|
try {
|
|
$dharma = Dharma::pluck('name', 'id');
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
return view('backend.jati.create', compact('dharma'));
|
|
}
|
|
|
|
/**
|
|
* Store a newly created resource in storage.
|
|
*
|
|
* @param \App\Http\Requests\StoreJatiRequest $request
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function store(StoreJatiRequest $request)
|
|
{
|
|
try {
|
|
$response = $this->jatiService->create($request->all());
|
|
if ($response) {
|
|
return redirect(route('admin.jati.index'))
|
|
->with('flash_success', __('message.create_jati_success'));
|
|
}
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
|
|
return redirect()->back()->with('flash_error', __('message.create_jati_error'));
|
|
}
|
|
|
|
/**
|
|
* Display the specified resource.
|
|
*
|
|
* @param \App\Models\Jati $jati
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function show(Jati $jati)
|
|
{
|
|
//
|
|
}
|
|
|
|
/**
|
|
* Show the form for editing the specified resource.
|
|
*
|
|
* @param \App\Models\Jati $jati
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function edit(Jati $jati)
|
|
{
|
|
try {
|
|
$dharma = Dharma::pluck('name', 'id');
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
|
|
return view('backend.jati.edit', compact('jati', 'dharma'));
|
|
}
|
|
|
|
/**
|
|
* Update the specified resource in storage.
|
|
*
|
|
* @param \App\Http\Requests\UpdateJatiRequest $request
|
|
* @param \App\Models\Jati $jati
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function update(UpdateJatiRequest $request, Jati $jati)
|
|
{
|
|
try {
|
|
$response = $this->jatiService->update($jati, $request->all());
|
|
|
|
if ($response) {
|
|
return redirect(route('admin.jati.index'))
|
|
->with('flash_success', __('message.update_jati_success'));
|
|
}
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
|
|
return redirect()->back()->with('flash_error', __('message.update_jati_error'));
|
|
}
|
|
|
|
/**
|
|
* Remove the specified resource from storage.
|
|
*
|
|
* @param \App\Models\Jati $jati
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function destroy(Jati $jati)
|
|
{
|
|
try {
|
|
|
|
$response = $jati->delete();
|
|
if ($response) {
|
|
return response()->json(['success' => Constant::STATUS_TRUE, 'message' => __('message.delete_jati_success')]);
|
|
}
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
|
|
return response()->json(['error' => Constant::STATUS_TRUE, 'message' => __('message.delete_jati_error')]);
|
|
}
|
|
|
|
/**
|
|
* This function is for the grid checkbox multiple records actions
|
|
*
|
|
* @param Request $request
|
|
* @return JsonResponse
|
|
*/
|
|
public function gridRecordsAction(Request $request): JsonResponse
|
|
{
|
|
try {
|
|
$actionType = $request->action_type ?? Constant::NULL;
|
|
$checkedRecords = $request->checked_records ?? [];
|
|
$updateStatus = $this->jatiService->gridActions($actionType, $checkedRecords);
|
|
|
|
if ($updateStatus) {
|
|
return response()->json(['success' => Constant::STATUS_TRUE, 'message' => __('message.update_jati_success')]);
|
|
}
|
|
} catch (Exception $ex) {
|
|
Log::error($ex->getMessage());
|
|
}
|
|
|
|
return response()->json(['error' => Constant::STATUS_TRUE, 'message' => __('message.something_went_wrong')]);
|
|
}
|
|
}
|