lpj/app/Http/Controllers/DebitureController.php

179 lines
6.4 KiB
PHP
Raw Normal View History

2024-08-13 04:50:40 +00:00
<?php
namespace Modules\Lpj\Http\Controllers;
use App\Http\Controllers\Controller;
use Exception;
use Illuminate\Http\Request;
use Maatwebsite\Excel\Facades\Excel;
use Modules\Location\Models\City;
use Modules\Location\Models\District;
use Modules\Location\Models\Province;
use Modules\Location\Models\Village;
use Modules\Lpj\Exports\DebitureExport;
use Modules\Lpj\Http\Requests\DebitureRequest;
2024-08-21 06:42:55 +00:00
use Modules\Lpj\Http\Requests\DokumenJaminanRequest;
2024-08-13 04:50:40 +00:00
use Modules\Lpj\Models\Branch;
use Modules\Lpj\Models\Debiture;
2024-08-21 06:42:55 +00:00
use Modules\Lpj\Models\DokumenJaminan;
use Modules\Lpj\Models\JenisJaminan;
use Modules\Lpj\Models\JenisLegalitasJaminan;
use Modules\Lpj\Models\PemilikJaminan;
2024-08-13 04:50:40 +00:00
class DebitureController extends Controller
{
public $user;
public function index()
{
return view('lpj::debitur.index');
}
public function store(DebitureRequest $request)
{
$validate = $request->validated();
if ($validate) {
try {
// Save to database
Debiture::create($validate);
return redirect()
->route('debitur.index')
->with('success', 'Debitur created successfully');
} catch (Exception $e) {
return redirect()
->route('debitur.create')
->with('error', 'Failed to create debitur');
}
}
}
public function create()
{
$branches = Branch::all();
$provinces = Province::all();
return view('lpj::debitur.create', compact('branches', 'provinces'));
}
public function edit($id)
{
2024-08-21 06:42:55 +00:00
$debitur = Debiture::find($id);
$branches = Branch::all();
2024-08-13 04:50:40 +00:00
$provinces = Province::all();
2024-08-21 06:42:55 +00:00
$cities = City::where('province_code', $debitur->province_code)->get();
2024-08-13 04:50:40 +00:00
$districts = District::where('city_code', $debitur->city_code)->get();
2024-08-21 06:42:55 +00:00
$villages = Village::where('district_code', $debitur->district_code)->get();
return view(
'lpj::debitur.edit',
compact('debitur', 'branches', 'provinces', 'cities', 'districts', 'villages'),
);
}
2024-08-13 04:50:40 +00:00
public function update(DebitureRequest $request, $id)
{
//print_r($request->all());exit;
2024-08-13 04:50:40 +00:00
$validate = $request->validated();
if ($validate) {
try {
// Update in database
$debitur = Debiture::find($id);
$debitur->update($validate);
return redirect()
->route('debitur.index')
->with('success', 'Debitur updated successfully');
} catch (Exception $e) {
return redirect()
->route('debitur.edit', $id)
->with('error', 'Failed to update debitur');
}
}
}
public function destroy($id)
{
try {
// Delete from database
$debitur = Debiture::find($id);
$debitur->delete();
echo json_encode(['success' => true, 'message' => 'Debitur deleted successfully']);
} catch (Exception $e) {
echo json_encode(['success' => false, 'message' => 'Failed to delete debitur']);
}
}
public function dataForDatatables(Request $request)
{
if (is_null($this->user) || !$this->user->can('debitur.view')) {
//abort(403, 'Sorry! You are not allowed to view users.');
}
// Retrieve data from the database
$query = Debiture::query();
// Apply search filter if provided
if ($request->has('search') && !empty($request->get('search'))) {
$search = $request->get('search');
$query->where(function ($q) use ($search) {
$q->where('cif', 'LIKE', "%$search%");
$q->orWhere('name', 'LIKE', "%$search%");
$q->orWhereRelation('branch', 'name', 'LIKE', "%$search%");
$q->orWhere('address', 'LIKE', "%$search%");
$q->orWhere('npwp', 'LIKE', "%$search%");
$q->orWhere('nomor_id', 'LIKE', "%$search%");
$q->orWhere('email', 'LIKE', "%$search%");
$q->orWhere('phone', 'LIKE', "%$search%");
$q->orWhere('nomor_rekening', 'LIKE', "%$search%");
});
}
// Apply sorting if provided
if ($request->has('sortOrder') && !empty($request->get('sortOrder'))) {
$order = $request->get('sortOrder');
$column = $request->get('sortField');
$query->orderBy($column, $order);
}
// Get the total count of records
$totalRecords = $query->count();
// Apply pagination if provided
if ($request->has('page') && $request->has('size')) {
$page = $request->get('page');
$size = $request->get('size');
$offset = ($page - 1) * $size; // Calculate the offset
$query->skip($offset)->take($size);
}
// Get the filtered count of records
$filteredRecords = $query->count();
// Get the data for the current page
$data = $query->with('branch')->get();
// Calculate the page count
$pageCount = ceil($totalRecords / $request->get('size'));
// Calculate the current page number
$currentPage = 0 + 1;
// Return the response data as a JSON object
return response()->json([
'draw' => $request->get('draw'),
'recordsTotal' => $totalRecords,
'recordsFiltered' => $filteredRecords,
'pageCount' => $pageCount,
'page' => $currentPage,
'totalCount' => $totalRecords,
'data' => $data,
]);
}
public function export()
{
return Excel::download(new DebitureExport, 'debitur.xlsx');
}
}