Remove Basicdata Branch and Currency from LPJ
- Basicdata Branch and currency move to module Basicdaata
This commit is contained in:
@@ -1,49 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Exports;
|
|
||||||
|
|
||||||
use Maatwebsite\Excel\Concerns\FromCollection;
|
|
||||||
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
|
|
||||||
use Maatwebsite\Excel\Concerns\WithHeadings;
|
|
||||||
use Maatwebsite\Excel\Concerns\WithMapping;
|
|
||||||
use Modules\Lpj\Models\Branch;
|
|
||||||
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
|
|
||||||
|
|
||||||
class BranchExport implements WithColumnFormatting, WithHeadings, FromCollection, withMapping
|
|
||||||
{
|
|
||||||
public function collection()
|
|
||||||
{
|
|
||||||
return Branch::all();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function map($row)
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
$row->id,
|
|
||||||
$row->code,
|
|
||||||
$row->name,
|
|
||||||
$row->created_at
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
public function headings()
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'ID',
|
|
||||||
'Code',
|
|
||||||
'Name',
|
|
||||||
'Created At'
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
public function columnFormats()
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'A' => NumberFormat::FORMAT_NUMBER,
|
|
||||||
'D' => NumberFormat::FORMAT_DATE_DATETIME
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Exports;
|
|
||||||
|
|
||||||
use Maatwebsite\Excel\Concerns\FromCollection;
|
|
||||||
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
|
|
||||||
use Maatwebsite\Excel\Concerns\WithHeadings;
|
|
||||||
use Maatwebsite\Excel\Concerns\WithMapping;
|
|
||||||
use Modules\Lpj\Models\Currency;
|
|
||||||
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
|
|
||||||
|
|
||||||
class CurrencyExport implements WithColumnFormatting, WithHeadings, FromCollection, withMapping
|
|
||||||
{
|
|
||||||
public function collection()
|
|
||||||
{
|
|
||||||
return Currency::all();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function map($row)
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
$row->id,
|
|
||||||
$row->code,
|
|
||||||
$row->name,
|
|
||||||
$row->decimal_places,
|
|
||||||
$row->updated_at,
|
|
||||||
$row->deleted_at,
|
|
||||||
$row->created_at
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
public function headings()
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'ID',
|
|
||||||
'Code',
|
|
||||||
'Name',
|
|
||||||
'Decimal Places',
|
|
||||||
'Created At'
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
public function columnFormats()
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
'A' => NumberFormat::FORMAT_NUMBER,
|
|
||||||
'B' => NumberFormat::FORMAT_NUMBER,
|
|
||||||
'E' => NumberFormat::FORMAT_DATE_DATETIME
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,200 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Http\Controllers;
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Exception;
|
|
||||||
use Illuminate\Http\Request;
|
|
||||||
use Maatwebsite\Excel\Facades\Excel;
|
|
||||||
use Modules\Lpj\Exports\BranchExport;
|
|
||||||
use Modules\Lpj\Http\Requests\BranchRequest;
|
|
||||||
use Illuminate\Support\Facades\DB;
|
|
||||||
|
|
||||||
use Modules\Lpj\Models\Permohonan;
|
|
||||||
|
|
||||||
class AuthorizationController extends Controller
|
|
||||||
{
|
|
||||||
public $user;
|
|
||||||
|
|
||||||
public function index()
|
|
||||||
{// dd('hai');
|
|
||||||
// return view('lpj::branch.index');
|
|
||||||
// $permohonan = Permohonan::find(2);
|
|
||||||
// dd($permohonan->get());
|
|
||||||
return view('lpj::authorization.index');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function store(BranchRequest $request)
|
|
||||||
{
|
|
||||||
$validate = $request->validated();
|
|
||||||
|
|
||||||
if ($validate) {
|
|
||||||
try {
|
|
||||||
// Save to database
|
|
||||||
Branch::create($validate);
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.index')
|
|
||||||
->with('success', 'Branch created successfully');
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.create')
|
|
||||||
->with('error', 'Failed to create branch');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function create()
|
|
||||||
{
|
|
||||||
return view('lpj::branch.create');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function edit($id)
|
|
||||||
{
|
|
||||||
$branch = Branch::find($id);
|
|
||||||
return view('lpj::branch.create', compact('branch'));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function update(BranchRequest $request, $id)
|
|
||||||
{
|
|
||||||
$validate = $request->validated();
|
|
||||||
|
|
||||||
if ($validate) {
|
|
||||||
try {
|
|
||||||
// Update in database
|
|
||||||
$branch = Branch::find($id);
|
|
||||||
$branch->update($validate);
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.index')
|
|
||||||
->with('success', 'Branch updated successfully');
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.edit', $id)
|
|
||||||
->with('error', 'Failed to update branch');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function destroy($id)
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
// Delete from database
|
|
||||||
$branch = Branch::find($id);
|
|
||||||
$branch->delete();
|
|
||||||
|
|
||||||
echo json_encode(['success' => true, 'message' => 'Branch deleted successfully']);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
echo json_encode(['success' => false, 'message' => 'Failed to delete branch']);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function dataForDatatables(Request $request)
|
|
||||||
{
|
|
||||||
// if (is_null($this->user) || !$this->user->can('branch.view')) {
|
|
||||||
//abort(403, 'Sorry! You are not allowed to view users.');
|
|
||||||
// }
|
|
||||||
|
|
||||||
// Retrieve data from the database
|
|
||||||
$query = Permohonan::query();
|
|
||||||
// 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->get();
|
|
||||||
$data = $query->select('permohonan.id', 'permohonan.nomor_registrasi'
|
|
||||||
, 'branches.name AS branche_name'
|
|
||||||
, 'debitures.name AS debiture_name'
|
|
||||||
// , 'tujuan_penilaian.name AS debiture_name'
|
|
||||||
, DB::raw("CONCAT(tujuan_penilaian.code,' - ', tujuan_penilaian.name) AS nama_tujuan_penilaian")
|
|
||||||
, 'users.name AS account_officer')
|
|
||||||
->leftJoin('branches', 'branches.id', '=', 'permohonan.branch_id')
|
|
||||||
->leftJoin('debitures', 'debitures.id', '=', 'permohonan.debiture_id')
|
|
||||||
->leftJoin('tujuan_penilaian', 'tujuan_penilaian.id', '=', 'permohonan.tujuan_penilaian_id')
|
|
||||||
->leftJoin('users', 'users.id', '=', 'permohonan.user_id')
|
|
||||||
->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,
|
|
||||||
]);
|
|
||||||
/*
|
|
||||||
// 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('code', 'LIKE', "%$search%");
|
|
||||||
$q->orWhere('name', '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->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 BranchExport, 'branch.xlsx');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,150 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Http\Controllers;
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Exception;
|
|
||||||
use Illuminate\Http\Request;
|
|
||||||
use Maatwebsite\Excel\Facades\Excel;
|
|
||||||
use Modules\Lpj\Exports\BranchExport;
|
|
||||||
use Modules\Lpj\Http\Requests\BranchRequest;
|
|
||||||
use Modules\Lpj\Models\Branch;
|
|
||||||
|
|
||||||
class BranchController extends Controller
|
|
||||||
{
|
|
||||||
public $user;
|
|
||||||
|
|
||||||
public function index()
|
|
||||||
{
|
|
||||||
return view('lpj::branch.index');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function store(BranchRequest $request)
|
|
||||||
{
|
|
||||||
$validate = $request->validated();
|
|
||||||
|
|
||||||
if ($validate) {
|
|
||||||
try {
|
|
||||||
// Save to database
|
|
||||||
Branch::create($validate);
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.index')
|
|
||||||
->with('success', 'Branch created successfully');
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.create')
|
|
||||||
->with('error', 'Failed to create branch');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function create()
|
|
||||||
{
|
|
||||||
return view('lpj::branch.create');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function edit($id)
|
|
||||||
{
|
|
||||||
$branch = Branch::find($id);
|
|
||||||
return view('lpj::branch.create', compact('branch'));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function update(BranchRequest $request, $id)
|
|
||||||
{
|
|
||||||
$validate = $request->validated();
|
|
||||||
|
|
||||||
if ($validate) {
|
|
||||||
try {
|
|
||||||
// Update in database
|
|
||||||
$branch = Branch::find($id);
|
|
||||||
$branch->update($validate);
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.index')
|
|
||||||
->with('success', 'Branch updated successfully');
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.branch.edit', $id)
|
|
||||||
->with('error', 'Failed to update branch');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function destroy($id)
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
// Delete from database
|
|
||||||
$branch = Branch::find($id);
|
|
||||||
$branch->delete();
|
|
||||||
|
|
||||||
echo json_encode(['success' => true, 'message' => 'Branch deleted successfully']);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
echo json_encode(['success' => false, 'message' => 'Failed to delete branch']);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function dataForDatatables(Request $request)
|
|
||||||
{
|
|
||||||
if (is_null($this->user) || !$this->user->can('branch.view')) {
|
|
||||||
//abort(403, 'Sorry! You are not allowed to view users.');
|
|
||||||
}
|
|
||||||
|
|
||||||
// Retrieve data from the database
|
|
||||||
$query = Branch::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('code', 'LIKE', "%$search%");
|
|
||||||
$q->orWhere('name', '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->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 BranchExport, 'branch.xlsx');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,150 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Http\Controllers;
|
|
||||||
|
|
||||||
use App\Http\Controllers\Controller;
|
|
||||||
use Exception;
|
|
||||||
use Illuminate\Http\Request;
|
|
||||||
use Maatwebsite\Excel\Facades\Excel;
|
|
||||||
use Modules\Lpj\Exports\CurrencyExport;
|
|
||||||
use Modules\Lpj\Http\Requests\CurrencyRequest;
|
|
||||||
use Modules\Lpj\Models\Currency;
|
|
||||||
|
|
||||||
class CurrencyController extends Controller
|
|
||||||
{
|
|
||||||
public $user;
|
|
||||||
|
|
||||||
public function index()
|
|
||||||
{
|
|
||||||
return view('lpj::currency.index');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function store(CurrencyRequest $request)
|
|
||||||
{
|
|
||||||
$validate = $request->validated();
|
|
||||||
|
|
||||||
if ($validate) {
|
|
||||||
try {
|
|
||||||
// Save to database
|
|
||||||
Currency::create($validate);
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.currency.index')
|
|
||||||
->with('success', 'Currency created successfully');
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.currency.create')
|
|
||||||
->with('error', 'Failed to create currency');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function create()
|
|
||||||
{
|
|
||||||
return view('lpj::currency.create');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function edit($id)
|
|
||||||
{
|
|
||||||
$currency = Currency::find($id);
|
|
||||||
return view('lpj::currency.create', compact('currency'));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function update(CurrencyRequest $request, $id)
|
|
||||||
{
|
|
||||||
$validate = $request->validated();
|
|
||||||
|
|
||||||
if ($validate) {
|
|
||||||
try {
|
|
||||||
// Update in database
|
|
||||||
$currency = Currency::find($id);
|
|
||||||
$currency->update($validate);
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.currency.index')
|
|
||||||
->with('success', 'Currency updated successfully');
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return redirect()
|
|
||||||
->route('basicdata.currency.edit', $id)
|
|
||||||
->with('error', 'Failed to update currency');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function destroy($id)
|
|
||||||
{
|
|
||||||
try {
|
|
||||||
// Delete from database
|
|
||||||
$currency = Currency::find($id);
|
|
||||||
$currency->delete();
|
|
||||||
|
|
||||||
echo json_encode(['success' => true, 'message' => 'Currency deleted successfully']);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
echo json_encode(['success' => false, 'message' => 'Failed to delete currency']);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function dataForDatatables(Request $request)
|
|
||||||
{
|
|
||||||
if (is_null($this->user) || !$this->user->can('currency.view')) {
|
|
||||||
//abort(403, 'Sorry! You are not allowed to view users.');
|
|
||||||
}
|
|
||||||
|
|
||||||
// Retrieve data from the database
|
|
||||||
$query = Currency::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('code', 'LIKE', "%$search%");
|
|
||||||
$q->orWhere('name', '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->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 CurrencyExport, 'currency.xlsx');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -13,7 +13,6 @@
|
|||||||
|
|
||||||
class JenisFasilitasKreditController extends Controller
|
class JenisFasilitasKreditController extends Controller
|
||||||
{
|
{
|
||||||
use LpjHelpers; // <---- Using the LpjHelpers Trait
|
|
||||||
public $user;
|
public $user;
|
||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
@@ -28,12 +27,6 @@
|
|||||||
if ($validate) {
|
if ($validate) {
|
||||||
try {
|
try {
|
||||||
// Save to database
|
// Save to database
|
||||||
// andy add
|
|
||||||
$lastNumberCodeJFK = LpjHelpers::onLastCodeJFK();
|
|
||||||
|
|
||||||
$validate['name'] =strtoupper($request->name);
|
|
||||||
$validate['code'] =$lastNumberCodeJFK;
|
|
||||||
// andy add
|
|
||||||
|
|
||||||
JenisFasilitasKredit::create($validate);
|
JenisFasilitasKredit::create($validate);
|
||||||
return redirect()
|
return redirect()
|
||||||
|
|||||||
@@ -1,40 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Http\Requests;
|
|
||||||
|
|
||||||
use Illuminate\Foundation\Http\FormRequest;
|
|
||||||
|
|
||||||
class BranchRequest extends FormRequest
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Get the validation rules that apply to the request.
|
|
||||||
*/
|
|
||||||
public function rules()
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
$rules = [
|
|
||||||
'name' => 'required|string|max:255',
|
|
||||||
'status' => 'nullable|boolean',
|
|
||||||
'authorized_at' => 'nullable|datetime',
|
|
||||||
'authorized_status' => 'nullable|string|max:1',
|
|
||||||
'authorized_by' => 'nullable|exists:users,id',
|
|
||||||
];
|
|
||||||
|
|
||||||
if ($this->method() == 'PUT') {
|
|
||||||
$rules['code'] = 'required|string|max:3|unique:branches,code,' . $this->id;
|
|
||||||
} else {
|
|
||||||
$rules['code'] = 'required|string|max:3|unique:branches,code';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $rules;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determine if the user is authorized to make this request.
|
|
||||||
*/
|
|
||||||
public function authorize()
|
|
||||||
: bool
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,41 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Http\Requests;
|
|
||||||
|
|
||||||
use Illuminate\Foundation\Http\FormRequest;
|
|
||||||
|
|
||||||
class CurrencyRequest extends FormRequest
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Get the validation rules that apply to the request.
|
|
||||||
*/
|
|
||||||
public function rules()
|
|
||||||
: array
|
|
||||||
{
|
|
||||||
$rules = [
|
|
||||||
'name' => 'required|string|max:255',
|
|
||||||
'decimal_places' => 'nullable|integer|between:0,3',
|
|
||||||
'status' => 'nullable|boolean',
|
|
||||||
'authorized_at' => 'nullable|datetime',
|
|
||||||
'authorized_status' => 'nullable|string|max:1',
|
|
||||||
'authorized_by' => 'nullable|exists:users,id',
|
|
||||||
];
|
|
||||||
|
|
||||||
if ($this->method() == 'PUT') {
|
|
||||||
$rules['code'] = 'required|string|max:3|unique:currencies,code,' . $this->id;
|
|
||||||
} else {
|
|
||||||
$rules['code'] = 'required|string|max:3|unique:currencies,code';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $rules;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determine if the user is authorized to make this request.
|
|
||||||
*/
|
|
||||||
public function authorize()
|
|
||||||
: bool
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -2,13 +2,10 @@
|
|||||||
|
|
||||||
namespace Modules\Lpj\Models;
|
namespace Modules\Lpj\Models;
|
||||||
|
|
||||||
use Modules\Lpj\Database\Factories\BranchFactory;
|
use Modules\Basicdata\Models\Branch as BasicdataBranch;
|
||||||
|
|
||||||
class Branch extends Base
|
class Branch extends BasicdataBranch
|
||||||
{
|
{
|
||||||
protected $table = 'branches';
|
|
||||||
protected $fillable = ['code', 'name', 'status', 'authorized_at', 'authorized_status', 'authorized_by'];
|
|
||||||
|
|
||||||
public function debitures()
|
public function debitures()
|
||||||
{
|
{
|
||||||
return $this->hasMany(Debiture::class, 'branch_id', 'id');
|
return $this->hasMany(Debiture::class, 'branch_id', 'id');
|
||||||
|
|||||||
@@ -1,20 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Modules\Lpj\Models;
|
|
||||||
|
|
||||||
use Modules\Lpj\Database\Factories\CurrencyFactory;
|
|
||||||
|
|
||||||
class Currency extends Base
|
|
||||||
{
|
|
||||||
protected $table = 'currencies';
|
|
||||||
|
|
||||||
protected $fillable = [
|
|
||||||
'code',
|
|
||||||
'name',
|
|
||||||
'decimal_places',
|
|
||||||
'status',
|
|
||||||
'authorized_at',
|
|
||||||
'authorized_status',
|
|
||||||
'authorized_by'
|
|
||||||
];
|
|
||||||
}
|
|
||||||
@@ -1,86 +1,82 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace Modules\Lpj\Models;
|
namespace Modules\Lpj\Models;
|
||||||
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Modules\Lpj\Database\Factories\PermohonanFactory;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Modules\Usermanagement\Models\User;
|
||||||
use Modules\Lpj\Database\Factories\PermohonanFactory;
|
|
||||||
use Modules\Usermanagement\Models\User;
|
|
||||||
use Modules\Lpj\Models\TujuanPenilaian;
|
|
||||||
use Modules\Lpj\Models\JenisFasilitasKredit;
|
|
||||||
|
|
||||||
class Permohonan extends Base
|
class Permohonan extends Base
|
||||||
{
|
|
||||||
protected $table = 'permohonan';
|
|
||||||
protected $fillable = [
|
|
||||||
'nomor_registrasi',
|
|
||||||
'tanggal_permohonan',
|
|
||||||
'user_id',
|
|
||||||
'branch_id',
|
|
||||||
'tujuan_penilaian_id',
|
|
||||||
'debiture_id',
|
|
||||||
'keterangan',
|
|
||||||
'dokumen',
|
|
||||||
'jenis_fasilitas_kredit_id',
|
|
||||||
'nilai_plafond_id',
|
|
||||||
'status',
|
|
||||||
'authorized_at',
|
|
||||||
'authorized_status',
|
|
||||||
'authorized_by',
|
|
||||||
// andy add
|
|
||||||
'registrasi_catatan',
|
|
||||||
'registrasi_by',
|
|
||||||
'registrasi_at',
|
|
||||||
'jenis_penilaian_id',
|
|
||||||
'region_id',
|
|
||||||
// andy add
|
|
||||||
'status_bayar',
|
|
||||||
'nilai_njop',
|
|
||||||
// andy add
|
|
||||||
'registrasi_catatan',
|
|
||||||
'registrasi_by',
|
|
||||||
'registrasi_at',
|
|
||||||
'jenis_penilaian_id',
|
|
||||||
'region_id'
|
|
||||||
];
|
|
||||||
|
|
||||||
public function user()
|
|
||||||
{
|
{
|
||||||
return $this->belongsTo(User::class);
|
protected $table = 'permohonan';
|
||||||
}
|
protected $fillable = [
|
||||||
|
'nomor_registrasi',
|
||||||
|
'tanggal_permohonan',
|
||||||
|
'user_id',
|
||||||
|
'branch_id',
|
||||||
|
'tujuan_penilaian_id',
|
||||||
|
'debiture_id',
|
||||||
|
'keterangan',
|
||||||
|
'dokumen',
|
||||||
|
'jenis_fasilitas_kredit_id',
|
||||||
|
'nilai_plafond_id',
|
||||||
|
'status',
|
||||||
|
'authorized_at',
|
||||||
|
'authorized_status',
|
||||||
|
'authorized_by',
|
||||||
|
// andy add
|
||||||
|
'registrasi_catatan',
|
||||||
|
'registrasi_by',
|
||||||
|
'registrasi_at',
|
||||||
|
'jenis_penilaian_id',
|
||||||
|
'region_id',
|
||||||
|
// andy add
|
||||||
|
'status_bayar',
|
||||||
|
'nilai_njop',
|
||||||
|
// andy add
|
||||||
|
'registrasi_catatan',
|
||||||
|
'registrasi_by',
|
||||||
|
'registrasi_at',
|
||||||
|
'jenis_penilaian_id',
|
||||||
|
'region_id',
|
||||||
|
];
|
||||||
|
|
||||||
public function branch()
|
public function user()
|
||||||
{
|
{
|
||||||
return $this->belongsTo(Branch::class);
|
return $this->belongsTo(User::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function tujuanPenilaian()
|
public function branch()
|
||||||
{
|
{
|
||||||
return $this->belongsTo(TujuanPenilaian::class);
|
return $this->belongsTo(Branch::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function debiture()
|
public function tujuanPenilaian()
|
||||||
{
|
{
|
||||||
return $this->belongsTo(Debiture::class);
|
return $this->belongsTo(TujuanPenilaian::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function documents()
|
public function debiture()
|
||||||
{
|
{
|
||||||
return $this->hasMany(DokumenJaminan::class);
|
return $this->belongsTo(Debiture::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function nilaiPlafond()
|
public function documents()
|
||||||
{
|
{
|
||||||
return $this->belongsTo(NilaiPlafond::class);
|
return $this->hasMany(DokumenJaminan::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function jenisFasilitasKredit()
|
public function nilaiPlafond()
|
||||||
{
|
{
|
||||||
return $this->belongsTo(JenisFasilitasKredit::class);
|
return $this->belongsTo(NilaiPlafond::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function penilaian()
|
public function jenisFasilitasKredit()
|
||||||
{
|
{
|
||||||
return $this->belongsTo(Penilaian::class, 'nomor_registrasi', 'nomor_registrasi');
|
return $this->belongsTo(JenisFasilitasKredit::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function penilaian()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Penilaian::class, 'nomor_registrasi', 'nomor_registrasi');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|||||||
19
module.json
19
module.json
@@ -246,22 +246,7 @@
|
|||||||
"attributes": [],
|
"attributes": [],
|
||||||
"permission": "",
|
"permission": "",
|
||||||
"roles": ["administrator", "pemohon-ao", "pemohon-eo", "admin", "surveyor"],
|
"roles": ["administrator", "pemohon-ao", "pemohon-eo", "admin", "surveyor"],
|
||||||
"sub": [{
|
"sub": [
|
||||||
"title": "Cabang",
|
|
||||||
"path": "basicdata.branch",
|
|
||||||
"classes": "",
|
|
||||||
"attributes": [],
|
|
||||||
"permission": "",
|
|
||||||
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"title": "Mata Uang",
|
|
||||||
"path": "basicdata.currency",
|
|
||||||
"classes": "",
|
|
||||||
"attributes": [],
|
|
||||||
"permission": "",
|
|
||||||
"roles": ["administrator", "pemohon-ao", "pemohon-eo"]
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"title": "Jenis Fasilitas Kredit",
|
"title": "Jenis Fasilitas Kredit",
|
||||||
"path": "basicdata.jenis-fasilitas-kredit",
|
"path": "basicdata.jenis-fasilitas-kredit",
|
||||||
@@ -476,4 +461,4 @@
|
|||||||
}],
|
}],
|
||||||
"system": []
|
"system": []
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,58 +0,0 @@
|
|||||||
@extends('layouts.main')
|
|
||||||
|
|
||||||
@section('breadcrumbs')
|
|
||||||
{{ Breadcrumbs::render(request()->route()->getName()) }}
|
|
||||||
@endsection
|
|
||||||
|
|
||||||
@section('content')
|
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
|
||||||
@if(isset($branch->id))
|
|
||||||
<form action="{{ route('basicdata.branch.update', $branch->id) }}" method="POST">
|
|
||||||
<input type="hidden" name="id" value="{{ $branch->id }}">
|
|
||||||
@method('PUT')
|
|
||||||
@else
|
|
||||||
<form method="POST" action="{{ route('basicdata.branch.store') }}">
|
|
||||||
@endif
|
|
||||||
@csrf
|
|
||||||
<div class="card pb-2.5">
|
|
||||||
<div class="card-header" id="basic_settings">
|
|
||||||
<h3 class="card-title">
|
|
||||||
{{ isset($branch->id) ? 'Edit' : 'Tambah' }} Branch
|
|
||||||
</h3>
|
|
||||||
<div class="flex items-center gap-2">
|
|
||||||
<a href="{{ route('basicdata.branch.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card-body grid gap-5">
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Code
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('code') border-danger bg-danger-light @enderror" type="text" name="code" value="{{ $branch->code ?? '' }}">
|
|
||||||
@error('code')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Name
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('name') border-danger bg-danger-light @enderror" type="text" name="name" value="{{ $branch->name ?? '' }}">
|
|
||||||
@error('name')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="flex justify-end">
|
|
||||||
<button type="submit" class="btn btn-primary">
|
|
||||||
Save
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
@endsection
|
|
||||||
@@ -1,147 +0,0 @@
|
|||||||
@extends('layouts.main')
|
|
||||||
|
|
||||||
@section('breadcrumbs')
|
|
||||||
{{ Breadcrumbs::render('basicdata.branch') }}
|
|
||||||
@endsection
|
|
||||||
|
|
||||||
@section('content')
|
|
||||||
<div class="grid">
|
|
||||||
<div class="card card-grid min-w-full" data-datatable="false" data-datatable-page-size="5" data-datatable-state-save="false" id="branch-table" data-api-url="{{ route('basicdata.branch.datatables') }}">
|
|
||||||
<div class="card-header py-5 flex-wrap">
|
|
||||||
<h3 class="card-title">
|
|
||||||
Daftar Cabang
|
|
||||||
</h3>
|
|
||||||
<div class="flex flex-wrap gap-2 lg:gap-5">
|
|
||||||
<div class="flex">
|
|
||||||
<label class="input input-sm"> <i class="ki-filled ki-magnifier"> </i>
|
|
||||||
<input placeholder="Search Branch" id="search" type="text" value="">
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
<div class="flex flex-wrap gap-2.5">
|
|
||||||
<div class="h-[24px] border border-r-gray-200"></div>
|
|
||||||
<a class="btn btn-sm btn-light" href="{{ route('basicdata.branch.export') }}"> Export to Excel </a>
|
|
||||||
<a class="btn btn-sm btn-primary" href="{{ route('basicdata.branch.create') }}"> Tambah Cabang </a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card-body">
|
|
||||||
<div class="scrollable-x-auto">
|
|
||||||
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th class="w-14">
|
|
||||||
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[250px]" data-datatable-column="code">
|
|
||||||
<span class="sort"> <span class="sort-label"> Code </span>
|
|
||||||
<span class="sort-icon"> </span> </span>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[250px]" data-datatable-column="name">
|
|
||||||
<span class="sort"> <span class="sort-label"> Cabang </span>
|
|
||||||
<span class="sort-icon"> </span> </span>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[50px] text-center" data-datatable-column="actions">Action</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
|
||||||
<div class="flex items-center gap-2">
|
|
||||||
Show
|
|
||||||
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
|
||||||
</div>
|
|
||||||
<div class="flex items-center gap-4">
|
|
||||||
<span data-datatable-info="true"> </span>
|
|
||||||
<div class="pagination" data-datatable-pagination="true">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
@endsection
|
|
||||||
|
|
||||||
@push('scripts')
|
|
||||||
<script type="text/javascript">
|
|
||||||
function deleteData(data) {
|
|
||||||
Swal.fire({
|
|
||||||
title: 'Are you sure?',
|
|
||||||
text: "You won't be able to revert this!",
|
|
||||||
icon: 'warning',
|
|
||||||
showCancelButton: true,
|
|
||||||
confirmButtonColor: '#3085d6',
|
|
||||||
cancelButtonColor: '#d33',
|
|
||||||
confirmButtonText: 'Yes, delete it!'
|
|
||||||
}).then((result) => {
|
|
||||||
if (result.isConfirmed) {
|
|
||||||
$.ajaxSetup({
|
|
||||||
headers: {
|
|
||||||
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$.ajax(`basic-data/cabang/${data}`, {
|
|
||||||
type: 'DELETE'
|
|
||||||
}).then((response) => {
|
|
||||||
swal.fire('Deleted!', 'User has been deleted.', 'success').then(() => {
|
|
||||||
window.location.reload();
|
|
||||||
});
|
|
||||||
}).catch((error) => {
|
|
||||||
console.error('Error:', error);
|
|
||||||
Swal.fire('Error!', 'An error occurred while deleting the file.', 'error');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
<script type="module">
|
|
||||||
const element = document.querySelector('#branch-table');
|
|
||||||
const searchInput = document.getElementById('search');
|
|
||||||
|
|
||||||
const apiUrl = element.getAttribute('data-api-url');
|
|
||||||
const dataTableOptions = {
|
|
||||||
apiEndpoint: apiUrl,
|
|
||||||
pageSize: 5,
|
|
||||||
columns: {
|
|
||||||
select: {
|
|
||||||
render: (item, data, context) => {
|
|
||||||
const checkbox = document.createElement('input');
|
|
||||||
checkbox.className = 'checkbox checkbox-sm';
|
|
||||||
checkbox.type = 'checkbox';
|
|
||||||
checkbox.value = data.id.toString();
|
|
||||||
checkbox.setAttribute('data-datatable-row-check', 'true');
|
|
||||||
return checkbox.outerHTML.trim();
|
|
||||||
},
|
|
||||||
},
|
|
||||||
code: {
|
|
||||||
title: 'Code',
|
|
||||||
},
|
|
||||||
name: {
|
|
||||||
title: 'Cabang',
|
|
||||||
},
|
|
||||||
actions: {
|
|
||||||
title: 'Status',
|
|
||||||
render: (item, data) => {
|
|
||||||
return `<div class="flex flex-nowrap justify-center">
|
|
||||||
<a class="btn btn-sm btn-icon btn-clear btn-info" href="basic-data/cabang/${data.id}/edit">
|
|
||||||
<i class="ki-outline ki-notepad-edit"></i>
|
|
||||||
</a>
|
|
||||||
<a onclick="deleteData(${data.id})" class="delete btn btn-sm btn-icon btn-clear btn-danger">
|
|
||||||
<i class="ki-outline ki-trash"></i>
|
|
||||||
</a>
|
|
||||||
</div>`;
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
let dataTable = new KTDataTable(element, dataTableOptions);
|
|
||||||
// Custom search functionality
|
|
||||||
searchInput.addEventListener('input', function () {
|
|
||||||
const searchValue = this.value.trim();
|
|
||||||
dataTable.search(searchValue, true);
|
|
||||||
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
@endpush
|
|
||||||
|
|
||||||
@@ -1,69 +0,0 @@
|
|||||||
@extends('layouts.main')
|
|
||||||
|
|
||||||
@section('breadcrumbs')
|
|
||||||
{{ Breadcrumbs::render(request()->route()->getName()) }}
|
|
||||||
@endsection
|
|
||||||
|
|
||||||
@section('content')
|
|
||||||
<div class="w-full grid gap-5 lg:gap-7.5 mx-auto">
|
|
||||||
@if(isset($currency->id))
|
|
||||||
<form action="{{ route('basicdata.currency.update', $currency->id) }}" method="POST">
|
|
||||||
<input type="hidden" name="id" value="{{ $currency->id }}">
|
|
||||||
@method('PUT')
|
|
||||||
@else
|
|
||||||
<form method="POST" action="{{ route('basicdata.currency.store') }}">
|
|
||||||
@endif
|
|
||||||
@csrf
|
|
||||||
<div class="card pb-2.5">
|
|
||||||
<div class="card-header" id="basic_settings">
|
|
||||||
<h3 class="card-title">
|
|
||||||
{{ isset($currency->id) ? 'Edit' : 'Tambah' }} Currency
|
|
||||||
</h3>
|
|
||||||
<div class="flex items-center gap-2">
|
|
||||||
<a href="{{ route('basicdata.currency.index') }}" class="btn btn-xs btn-info"><i class="ki-filled ki-exit-left"></i> Back</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card-body grid gap-5">
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Code
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('code') border-danger bg-danger-light @enderror" type="text" name="code" value="{{ $currency->code ?? '' }}">
|
|
||||||
@error('code')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Name
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('name') border-danger bg-danger-light @enderror" type="text" name="name" value="{{ $currency->name ?? '' }}">
|
|
||||||
@error('name')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="flex items-baseline flex-wrap lg:flex-nowrap gap-2.5">
|
|
||||||
<label class="form-label max-w-56">
|
|
||||||
Decimal Places
|
|
||||||
</label>
|
|
||||||
<div class="flex flex-wrap items-baseline w-full">
|
|
||||||
<input class="input @error('decimal_places') border-danger bg-danger-light @enderror" type="number" min="0" max="3" name="decimal_places" value="{{ $currency->decimal_places ?? '' }}">
|
|
||||||
@error('decimal_places')
|
|
||||||
<em class="alert text-danger text-sm">{{ $message }}</em>
|
|
||||||
@enderror
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="flex justify-end">
|
|
||||||
<button type="submit" class="btn btn-primary">
|
|
||||||
Save
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
@endsection
|
|
||||||
@@ -1,154 +0,0 @@
|
|||||||
@extends('layouts.main')
|
|
||||||
|
|
||||||
@section('breadcrumbs')
|
|
||||||
{{ Breadcrumbs::render('basicdata.currency') }}
|
|
||||||
@endsection
|
|
||||||
|
|
||||||
@section('content')
|
|
||||||
<div class="grid">
|
|
||||||
<div class="card card-grid min-w-full" data-datatable="false" data-datatable-page-size="5" data-datatable-state-save="false" id="currency-table" data-api-url="{{ route('basicdata.currency.datatables') }}">
|
|
||||||
<div class="card-header py-5 flex-wrap">
|
|
||||||
<h3 class="card-title">
|
|
||||||
Daftar Mata Uang
|
|
||||||
</h3>
|
|
||||||
<div class="flex flex-wrap gap-2 lg:gap-5">
|
|
||||||
<div class="flex">
|
|
||||||
<label class="input input-sm"> <i class="ki-filled ki-magnifier"> </i>
|
|
||||||
<input placeholder="Search Currency" id="search" type="text" value="">
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
<div class="flex flex-wrap gap-2.5">
|
|
||||||
<div class="h-[24px] border border-r-gray-200"></div>
|
|
||||||
<a class="btn btn-sm btn-light" href="{{ route('basicdata.currency.export') }}"> Export to Excel </a>
|
|
||||||
<a class="btn btn-sm btn-primary" href="{{ route('basicdata.currency.create') }}"> Tambah Mata Uang </a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card-body">
|
|
||||||
<div class="scrollable-x-auto">
|
|
||||||
<table class="table table-auto table-border align-middle text-gray-700 font-medium text-sm" data-datatable-table="true">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th class="w-14">
|
|
||||||
<input class="checkbox checkbox-sm" data-datatable-check="true" type="checkbox"/>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[250px]" data-datatable-column="code">
|
|
||||||
<span class="sort"> <span class="sort-label"> Code </span>
|
|
||||||
<span class="sort-icon"> </span> </span>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[250px]" data-datatable-column="name">
|
|
||||||
<span class="sort"> <span class="sort-label"> Mata Uang </span>
|
|
||||||
<span class="sort-icon"> </span> </span>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[50px]" data-datatable-column="decimal_places">
|
|
||||||
<span class="sort"> <span class="sort-label"> Decimal Places </span>
|
|
||||||
<span class="sort-icon"> </span> </span>
|
|
||||||
</th>
|
|
||||||
<th class="min-w-[50px] text-center" data-datatable-column="actions">Action</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
<div class="card-footer justify-center md:justify-between flex-col md:flex-row gap-3 text-gray-600 text-2sm font-medium">
|
|
||||||
<div class="flex items-center gap-2">
|
|
||||||
Show
|
|
||||||
<select class="select select-sm w-16" data-datatable-size="true" name="perpage"> </select> per page
|
|
||||||
</div>
|
|
||||||
<div class="flex items-center gap-4">
|
|
||||||
<span data-datatable-info="true"> </span>
|
|
||||||
<div class="pagination" data-datatable-pagination="true">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
@endsection
|
|
||||||
|
|
||||||
@push('scripts')
|
|
||||||
<script type="text/javascript">
|
|
||||||
function deleteData(data) {
|
|
||||||
Swal.fire({
|
|
||||||
title: 'Are you sure?',
|
|
||||||
text: "You won't be able to revert this!",
|
|
||||||
icon: 'warning',
|
|
||||||
showCancelButton: true,
|
|
||||||
confirmButtonColor: '#3085d6',
|
|
||||||
cancelButtonColor: '#d33',
|
|
||||||
confirmButtonText: 'Yes, delete it!'
|
|
||||||
}).then((result) => {
|
|
||||||
if (result.isConfirmed) {
|
|
||||||
$.ajaxSetup({
|
|
||||||
headers: {
|
|
||||||
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$.ajax(`basic-data/mata-uang/${data}`, {
|
|
||||||
type: 'DELETE'
|
|
||||||
}).then((response) => {
|
|
||||||
swal.fire('Deleted!', 'User has been deleted.', 'success').then(() => {
|
|
||||||
window.location.reload();
|
|
||||||
});
|
|
||||||
}).catch((error) => {
|
|
||||||
console.error('Error:', error);
|
|
||||||
Swal.fire('Error!', 'An error occurred while deleting the file.', 'error');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
<script type="module">
|
|
||||||
const element = document.querySelector('#currency-table');
|
|
||||||
const searchInput = document.getElementById('search');
|
|
||||||
|
|
||||||
const apiUrl = element.getAttribute('data-api-url');
|
|
||||||
const dataTableOptions = {
|
|
||||||
apiEndpoint: apiUrl,
|
|
||||||
pageSize: 5,
|
|
||||||
columns: {
|
|
||||||
select: {
|
|
||||||
render: (item, data, context) => {
|
|
||||||
const checkbox = document.createElement('input');
|
|
||||||
checkbox.className = 'checkbox checkbox-sm';
|
|
||||||
checkbox.type = 'checkbox';
|
|
||||||
checkbox.value = data.id.toString();
|
|
||||||
checkbox.setAttribute('data-datatable-row-check', 'true');
|
|
||||||
return checkbox.outerHTML.trim();
|
|
||||||
},
|
|
||||||
},
|
|
||||||
code: {
|
|
||||||
title: 'Code',
|
|
||||||
},
|
|
||||||
name: {
|
|
||||||
title: 'Mata Uang',
|
|
||||||
},
|
|
||||||
decimal_places: {
|
|
||||||
title: 'Decimal Places',
|
|
||||||
},
|
|
||||||
actions: {
|
|
||||||
title: 'Status',
|
|
||||||
render: (item, data) => {
|
|
||||||
return `<div class="flex flex-nowrap justify-center">
|
|
||||||
<a class="btn btn-sm btn-icon btn-clear btn-info" href="basic-data/mata-uang/${data.id}/edit">
|
|
||||||
<i class="ki-outline ki-notepad-edit"></i>
|
|
||||||
</a>
|
|
||||||
<a onclick="deleteData(${data.id})" class="delete btn btn-sm btn-icon btn-clear btn-danger">
|
|
||||||
<i class="ki-outline ki-trash"></i>
|
|
||||||
</a>
|
|
||||||
</div>`;
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
let dataTable = new KTDataTable(element, dataTableOptions);
|
|
||||||
// Custom search functionality
|
|
||||||
searchInput.addEventListener('input', function () {
|
|
||||||
const searchValue = this.value.trim();
|
|
||||||
dataTable.search(searchValue, true);
|
|
||||||
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
@endpush
|
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -3,8 +3,6 @@
|
|||||||
use Illuminate\Support\Facades\Route;
|
use Illuminate\Support\Facades\Route;
|
||||||
use Modules\Lpj\Http\Controllers\ActivityController;
|
use Modules\Lpj\Http\Controllers\ActivityController;
|
||||||
use Modules\Lpj\Http\Controllers\ArahMataAnginController;
|
use Modules\Lpj\Http\Controllers\ArahMataAnginController;
|
||||||
use Modules\Lpj\Http\Controllers\BranchController;
|
|
||||||
use Modules\Lpj\Http\Controllers\CurrencyController;
|
|
||||||
use Modules\Lpj\Http\Controllers\DebitureController;
|
use Modules\Lpj\Http\Controllers\DebitureController;
|
||||||
use Modules\Lpj\Http\Controllers\DokumenJaminanController;
|
use Modules\Lpj\Http\Controllers\DokumenJaminanController;
|
||||||
use Modules\Lpj\Http\Controllers\HubunganPemilikJaminanController;
|
use Modules\Lpj\Http\Controllers\HubunganPemilikJaminanController;
|
||||||
@@ -95,29 +93,7 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
Route::get('export', [JenisDokumenController::class, 'export'])->name('export');
|
Route::get('export', [JenisDokumenController::class, 'export'])->name('export');
|
||||||
});
|
});
|
||||||
Route::resource('jenis-dokumen', JenisDokumenController::class);
|
Route::resource('jenis-dokumen', JenisDokumenController::class);
|
||||||
Route::name('currency.')->prefix('mata-uang')->group(function () {
|
|
||||||
Route::get('restore/{id}', [CurrencyController::class, 'restore'])->name('restore');
|
|
||||||
Route::get('datatables', [CurrencyController::class, 'dataForDatatables'])->name('datatables');
|
|
||||||
Route::get('export', [CurrencyController::class, 'export'])->name('export');
|
|
||||||
});
|
|
||||||
|
|
||||||
Route::name('branch.')->prefix('cabang')->group(function () {
|
|
||||||
Route::get('restore/{id}', [BranchController::class, 'restore'])->name('restore');
|
|
||||||
Route::get('datatables', [BranchController::class, 'dataForDatatables'])->name('datatables');
|
|
||||||
Route::get('export', [BranchController::class, 'export'])->name('export');
|
|
||||||
});
|
|
||||||
|
|
||||||
Route::resource('cabang', BranchController::class, [
|
|
||||||
'names' => [
|
|
||||||
'index' => 'branch.index',
|
|
||||||
'show' => 'branch.show',
|
|
||||||
'create' => 'branch.create',
|
|
||||||
'store' => 'branch.store',
|
|
||||||
'edit' => 'branch.edit',
|
|
||||||
'update' => 'branch.update',
|
|
||||||
'destroy' => 'branch.destroy',
|
|
||||||
],
|
|
||||||
]);
|
|
||||||
|
|
||||||
Route::name('nilai-plafond.')->prefix('nilai-plafond')->group(function () {
|
Route::name('nilai-plafond.')->prefix('nilai-plafond')->group(function () {
|
||||||
Route::get('restore/{id}', [NilaiPlafondController::class, 'restore'])->name('restore');
|
Route::get('restore/{id}', [NilaiPlafondController::class, 'restore'])->name('restore');
|
||||||
@@ -217,35 +193,6 @@ Route::middleware(['auth'])->group(function () {
|
|||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
Route::resource('mata-uang', CurrencyController::class, [
|
|
||||||
'names' => [
|
|
||||||
'index' => 'currency.index',
|
|
||||||
'show' => 'currency.show',
|
|
||||||
'create' => 'currency.create',
|
|
||||||
'store' => 'currency.store',
|
|
||||||
'edit' => 'currency.edit',
|
|
||||||
'update' => 'currency.update',
|
|
||||||
'destroy' => 'currency.destroy',
|
|
||||||
],
|
|
||||||
]);
|
|
||||||
|
|
||||||
Route::name('branch.')->prefix('cabang')->group(function () {
|
|
||||||
Route::get('restore/{id}', [BranchController::class, 'restore'])->name('restore');
|
|
||||||
Route::get('datatables', [BranchController::class, 'dataForDatatables'])->name('datatables');
|
|
||||||
Route::get('export', [BranchController::class, 'export'])->name('export');
|
|
||||||
});
|
|
||||||
|
|
||||||
Route::resource('cabang', BranchController::class, [
|
|
||||||
'names' => [
|
|
||||||
'index' => 'branch.index',
|
|
||||||
'show' => 'branch.show',
|
|
||||||
'create' => 'branch.create',
|
|
||||||
'store' => 'branch.store',
|
|
||||||
'edit' => 'branch.edit',
|
|
||||||
'update' => 'branch.update',
|
|
||||||
'destroy' => 'branch.destroy',
|
|
||||||
],
|
|
||||||
]);
|
|
||||||
|
|
||||||
Route::name('nilai-plafond.')->prefix('nilai-plafond')->group(function () {
|
Route::name('nilai-plafond.')->prefix('nilai-plafond')->group(function () {
|
||||||
Route::get('restore/{id}', [NilaiPlafondController::class, 'restore'])->name('restore');
|
Route::get('restore/{id}', [NilaiPlafondController::class, 'restore'])->name('restore');
|
||||||
|
|||||||
Reference in New Issue
Block a user