update module pencatatan data subrogasi jamkrindo
This commit is contained in:
parent
efc92f494e
commit
7b781ad76d
130
DataTables/SubrogasiJamkrindoDataTable.php
Normal file
130
DataTables/SubrogasiJamkrindoDataTable.php
Normal file
@ -0,0 +1,130 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Writeoff\DataTables;
|
||||
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Database\Eloquent\Builder as QueryBuilder;
|
||||
use Modules\Writeoff\Entities\SubrogasiJamkrindo;
|
||||
use Nwidart\Modules\Facades\Module;
|
||||
use Yajra\DataTables\EloquentDataTable;
|
||||
use Yajra\DataTables\Html\Builder as HtmlBuilder;
|
||||
use Yajra\DataTables\Html\Column;
|
||||
use Yajra\DataTables\Services\DataTable;
|
||||
|
||||
class SubrogasiJamkrindoDataTable extends DataTable
|
||||
{
|
||||
/**
|
||||
* Build the DataTable class.
|
||||
*
|
||||
* @param QueryBuilder $query Results from query() method.
|
||||
*/
|
||||
public function dataTable(QueryBuilder $query)
|
||||
: EloquentDataTable
|
||||
{
|
||||
return (new EloquentDataTable($query))->filter(callback: function ($query) {
|
||||
if (request()->has('search')) {
|
||||
$search = request()->get('search');
|
||||
$query->where('nomor_pinjaman', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('kode_debitur', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('nama_debitur', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('kode_cabang', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('nama_cabang', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('nomor_rekening', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('nama_rekening', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('plafond', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('tenor', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('tanggal_pengajuan_klaim', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('piutang_subrogasi', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('total_bayar_subrogasi', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('sisa_piutang_subrogasi', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('keterangan', 'like', "%" . $search['value'] . "%")
|
||||
->orWhere('status', 'like', "%" . $search['value'] . "%");
|
||||
}
|
||||
})->addIndexColumn()->editColumn('tanggal_pengajuan_klaim', function ($row) {
|
||||
$date = Carbon::create($row->tanggal_pengajuan_klaim);
|
||||
return $date->locale('id')->translatedFormat('d F Y');
|
||||
})->editColumn('plafond', function ($row) {
|
||||
return $this->rupiah($row->plafond);
|
||||
})->editColumn('piutang_subrogasi', function ($row) {
|
||||
return $this->rupiah($row->piutang_subrogasi);
|
||||
})->editColumn('sisa_piutang_subrogasi', function ($row) {
|
||||
return $this->rupiah($row->sisa_piutang_subrogasi);
|
||||
})->editColumn('is_lunas_subrogasi', function ($row) {
|
||||
return $row->is_lunas_subrogasi ? 'Lunas' : 'Belum Lunas';
|
||||
})->editColumn('updated_at', function ($row) {
|
||||
return $row->updated_at->locale('id')->translatedFormat('d F Y H:i:s');
|
||||
})->rawColumns(['action'])->addColumn('action', function ($subrogasi_jamkrindo) {
|
||||
return view('writeoff::pencatatan.subrogasi_jamkrindo._actions', compact('subrogasi_jamkrindo'));
|
||||
})->setRowId('id');
|
||||
}
|
||||
|
||||
private function rupiah($expression)
|
||||
{
|
||||
return "Rp. " . number_format($expression, 2, ',', '.');
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the query source of dataTable.
|
||||
*/
|
||||
public function query(SubrogasiJamkrindo $model)
|
||||
: QueryBuilder
|
||||
{
|
||||
return $model->newQuery();
|
||||
}
|
||||
|
||||
/**
|
||||
* Optional method if you want to use the html builder.
|
||||
*/
|
||||
public function html()
|
||||
: HtmlBuilder
|
||||
{
|
||||
return $this->builder()
|
||||
->setTableId('subrogasi-jamkrindo-table')
|
||||
->columns($this->getColumns())
|
||||
->minifiedAjax()
|
||||
->stateSave(false)
|
||||
->responsive()
|
||||
->autoWidth(true)
|
||||
->orderBy(1)
|
||||
->parameters([
|
||||
'scrollX' => false,
|
||||
'drawCallback' => 'function() { KTMenu.createInstances(); }',
|
||||
])
|
||||
->addTableClass('align-middle table-row-dashed fs-6 gy-5')
|
||||
->drawCallback("function() {" . file_get_contents(Module::getModulePath('writeoff') . 'Resources/views/pencatatan/subrogasi_jamkrindo/_draw-scripts.js') . "}");
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the dataTable columns definition.
|
||||
*/
|
||||
public function getColumns()
|
||||
: array
|
||||
{
|
||||
return [
|
||||
Column::make('DT_RowIndex')->title('No')->orderable(false)->searchable(false),
|
||||
Column::make('nomor_pinjaman')->title('Nomor Pinjaman'),
|
||||
Column::make('kode_debitur')->title('Kode Debitur'),
|
||||
Column::make('kode_cabang')->title('Kode Cabang'),
|
||||
Column::make('plafond')->title('Plafond'),
|
||||
Column::make('tenor')->title('Tenor'),
|
||||
Column::make('tanggal_pengajuan_klaim')->title('Tanggal Pengajuan Subrogasi'),
|
||||
Column::make('piutang_subrogasi')->title('Piutang Subrogasi'),
|
||||
Column::make('sisa_piutang_subrogasi')->title('Sisa Piurang Subrogasi'),
|
||||
Column::make('is_lunas_subrogasi')->title('Lunas'),
|
||||
Column::computed('action')
|
||||
->exportable(false)
|
||||
->printable(false)
|
||||
->width(60)
|
||||
->addClass('text-center')
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the filename for export.
|
||||
*/
|
||||
protected function filename()
|
||||
: string
|
||||
{
|
||||
return 'SubrogasiJamkrindo_' . date('YmdHis');
|
||||
}
|
||||
}
|
@ -14,9 +14,9 @@ return new class extends Migration
|
||||
Schema::create('subrogasi_jamkrindo', function (Blueprint $table) {
|
||||
$table->id();
|
||||
$table->integer('nomor_pinjaman', false, true);
|
||||
$table->integer('nomor_debitur', false, true);
|
||||
$table->integer('kode_debitur', false, true);
|
||||
$table->string('nama_debitur');
|
||||
$table->string('cabang');
|
||||
$table->string('kode_cabang');
|
||||
$table->string('nama_cabang');
|
||||
$table->integer('nomor_rekening', false, true);
|
||||
$table->string('nama_rekening');
|
||||
|
31
Entities/SubrogasiJamkrindo.php
Normal file
31
Entities/SubrogasiJamkrindo.php
Normal file
@ -0,0 +1,31 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Writeoff\Entities;
|
||||
|
||||
class SubrogasiJamkrindo extends BaseModel
|
||||
{
|
||||
protected $table = 'subrogasi_jamkrindo';
|
||||
|
||||
protected $fillable = [
|
||||
'nomor_pinjaman',
|
||||
'kode_debitur',
|
||||
'nama_debitur',
|
||||
'kode_cabang',
|
||||
'nama_cabang',
|
||||
'nomor_rekening',
|
||||
'nama_rekening',
|
||||
'plafond',
|
||||
'tenor',
|
||||
'tanggal_pengajuan_klaim',
|
||||
'piutang_subrogasi',
|
||||
'total_bayar_subrogasi',
|
||||
'sisa_piutang_subrogasi',
|
||||
'is_lunas_subrogasi',
|
||||
'keterangan',
|
||||
'status',
|
||||
'registered_at',
|
||||
'authorized_at',
|
||||
'authorized_status',
|
||||
'authorized_by',
|
||||
];
|
||||
}
|
37
Http/Controllers/SubrogasiJamkrindoController.php
Normal file
37
Http/Controllers/SubrogasiJamkrindoController.php
Normal file
@ -0,0 +1,37 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Writeoff\Http\Controllers;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Modules\Writeoff\DataTables\SubrogasiJamkrindoDataTable;
|
||||
|
||||
class SubrogasiJamkrindoController 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 SubrogasiJamkrindos.
|
||||
*
|
||||
* @param \Modules\Writeoff\DataTables\SubrogasiJamkrindoDataTable $dataTable
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function index(SubrogasiJamkrindoDataTable $dataTable, Request $request)
|
||||
{
|
||||
if (is_null($this->user) || !$this->user->can('master.read')) {
|
||||
abort(403, 'Sorry !! You are Unauthorized to view any master data !');
|
||||
}
|
||||
|
||||
return $dataTable->render('writeoff::pencatatan.subrogasi_jamkrindo.index');
|
||||
}
|
||||
}
|
@ -0,0 +1,101 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Writeoff\Http\Requests\SubrogasiJamkrindo;
|
||||
|
||||
use Illuminate\Foundation\Http\FormRequest;
|
||||
use Illuminate\Http\Exceptions\HttpResponseException;
|
||||
use Illuminate\Validation\ValidationException;
|
||||
use Illuminate\Validation\Validator;
|
||||
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||
|
||||
class StoreSubrogasiJamkrindoRequest extends FormRequest
|
||||
{
|
||||
/**
|
||||
* Determine if the user is authorized to make this request.
|
||||
*/
|
||||
public function authorize()
|
||||
: bool
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the validation rules that apply to the request.
|
||||
*
|
||||
* @return array<string, \Illuminate\Contracts\Validation\Rule|array|string>
|
||||
*/
|
||||
public function rules()
|
||||
: array
|
||||
{
|
||||
return [
|
||||
'nomor_pinjaman' => 'required|integer',
|
||||
'kode_debitur' => 'required|integer',
|
||||
'nama_debitur' => 'required|string',
|
||||
'kode_cabang' => 'required|string',
|
||||
'nama_cabang' => 'required|string',
|
||||
'nomor_rekening' => 'required|numeric',
|
||||
'nama_rekening' => 'required|string',
|
||||
'plafond' => 'required|numeric',
|
||||
'tenor' => 'required|integer',
|
||||
'tanggal_pengajuan_klaim' => 'required|date',
|
||||
'piutang_subrogasi' => 'required|numeric',
|
||||
'total_bayar_subrogasi' => 'required|numeric',
|
||||
'sisa_piutang_subrogasi' => 'required|numeric',
|
||||
'is_lunas_subrogasi' => 'nullable|boolean',
|
||||
'keterangan' => 'nullable|string',
|
||||
'status' => 'nullable|boolean',
|
||||
];
|
||||
}
|
||||
|
||||
public function ignored()
|
||||
: string
|
||||
{
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Configure the validator instance.
|
||||
*/
|
||||
public function withValidator(Validator $validator)
|
||||
: void
|
||||
{
|
||||
$validator->after(function (Validator $validator) {
|
||||
if ($validator->errors()->any()) {
|
||||
$errors = json_decode($validator->errors()->toJson(), true);
|
||||
|
||||
|
||||
foreach ($errors as $key => $value) {
|
||||
flash($value[0]);
|
||||
}
|
||||
return redirect()
|
||||
->route('pencatatan.subrogasi_jamkrindo.index')
|
||||
->with('error', 'Subrogasi Jamkrindo created failed.');
|
||||
}
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
protected function failedValidation(Validator|\Illuminate\Contracts\Validation\Validator $validator)
|
||||
: JsonResponse
|
||||
{
|
||||
$errors = (new ValidationException($validator))->errors();
|
||||
|
||||
throw new HttpResponseException(response()->json([
|
||||
'success' => false,
|
||||
'errors' => $errors,
|
||||
'messages' => 'Subrogasi Jamkrindo created failed.'
|
||||
], JsonResponse::HTTP_UNPROCESSABLE_ENTITY));
|
||||
}
|
||||
|
||||
protected function prepareForValidation()
|
||||
: void
|
||||
{
|
||||
|
||||
$this->merge([
|
||||
'dana_hasil_klaim' => str_replace('', '', $this->dana_hasil_klaim),
|
||||
'nilai_penyelesaian' => str_replace(',', '', $this->nilai_penyelesaian),
|
||||
'sisa_dana_ksl' => $this->dana_hasil_klaim - $this->nilai_penyelesaian,
|
||||
'jumlah_debitur_sisa_ksl' => $this->jumlah_debitur_excel - $this->jumlah_debitur_penyelesaian,
|
||||
]);
|
||||
}
|
||||
}
|
@ -0,0 +1,81 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Writeoff\Http\Requests\SubrogasiJamkrindo;
|
||||
|
||||
use Illuminate\Foundation\Http\FormRequest;
|
||||
use Illuminate\Http\Exceptions\HttpResponseException;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Validation\ValidationException;
|
||||
use Illuminate\Validation\Validator;
|
||||
|
||||
class UpdateSubrogasiJamkrindoRequest extends FormRequest
|
||||
{
|
||||
/**
|
||||
* Determine if the user is authorized to make this request.
|
||||
*/
|
||||
public function authorize()
|
||||
: bool
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the validation rules that apply to the request.
|
||||
*
|
||||
* @return array<string, \Illuminate\Contracts\Validation\Rule|array|string>
|
||||
*/
|
||||
public function rules()
|
||||
: array
|
||||
{
|
||||
return [
|
||||
'nomor_pinjaman' => 'required|integer',
|
||||
'kode_debitur' => 'required|integer',
|
||||
'nama_debitur' => 'required|string',
|
||||
'kode_cabang' => 'required|string',
|
||||
'nama_cabang' => 'required|string',
|
||||
'nomor_rekening' => 'required|integer',
|
||||
'nama_rekening' => 'required|string',
|
||||
'plafond' => 'required|numeric',
|
||||
'tenor' => 'required|integer',
|
||||
'tanggal_pengajuan_klaim' => 'required|date',
|
||||
'piutang_subrogasi' => 'required|numeric',
|
||||
'total_bayar_subrogasi' => 'required|numeric',
|
||||
'sisa_piutang_subrogasi' => 'required|numeric',
|
||||
'is_lunas_subrogasi' => 'required|boolean',
|
||||
'keterangan' => 'nullable|string',
|
||||
'status' => 'nullable|boolean',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Configure the validator instance.
|
||||
*/
|
||||
public function withValidator(Validator $validator)
|
||||
: void
|
||||
{
|
||||
$validator->after(function (Validator $validator) {
|
||||
if ($validator->errors()->any()) {
|
||||
$error = json_decode($validator->errors()->toJson(), true);
|
||||
foreach ($error as $key => $value) {
|
||||
flash($value[0]);
|
||||
}
|
||||
|
||||
return redirect()
|
||||
->route('pencatatan.subrogasi_jamkrindo.index')
|
||||
->with('error', 'Subrogasi Jamkrindo updated failed.');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
protected function failedValidation(Validator|\Illuminate\Contracts\Validation\Validator $validator)
|
||||
: JsonResponse
|
||||
{
|
||||
$errors = (new ValidationException($validator))->errors();
|
||||
|
||||
throw new HttpResponseException(response()->json([
|
||||
'success' => false,
|
||||
'errors' => $errors,
|
||||
'messages' => 'Subrogasi Jamkrindo updated failed.'
|
||||
], JsonResponse::HTTP_UNPROCESSABLE_ENTITY));
|
||||
}
|
||||
}
|
178
Livewire/SubrogasiJamkrindo/SubrogasiJamkrindoModal.php
Normal file
178
Livewire/SubrogasiJamkrindo/SubrogasiJamkrindoModal.php
Normal file
@ -0,0 +1,178 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Writeoff\Livewire\SubrogasiJamkrindo;
|
||||
|
||||
use Exception;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Livewire\Component;
|
||||
use Modules\Writeoff\Entities\Branch;
|
||||
use Modules\Writeoff\Entities\Debitur;
|
||||
use Modules\Writeoff\Entities\Rekening;
|
||||
use Modules\Writeoff\Entities\SubrogasiJamkrindo;
|
||||
use Modules\Writeoff\Http\Requests\SubrogasiJamkrindo\StoreSubrogasiJamkrindoRequest;
|
||||
use Modules\Writeoff\Http\Requests\SubrogasiJamkrindo\UpdateSubrogasiJamkrindoRequest;
|
||||
|
||||
class SubrogasiJamkrindoModal extends Component
|
||||
{
|
||||
public $id;
|
||||
public $nomor_pinjaman;
|
||||
public $kode_debitur;
|
||||
public $nama_debitur;
|
||||
public $kode_cabang;
|
||||
public $nama_cabang;
|
||||
public $nomor_rekening;
|
||||
public $nama_rekening;
|
||||
public $plafond;
|
||||
public $tenor;
|
||||
public $tanggal_pengajuan_klaim;
|
||||
public $piutang_subrogasi;
|
||||
public $total_bayar_subrogasi;
|
||||
public $sisa_piutang_subrogasi;
|
||||
public $is_lunas_subrogasi;
|
||||
public $keterangan;
|
||||
public $status;
|
||||
|
||||
public $edit_mode = false;
|
||||
|
||||
protected $listeners = [
|
||||
'delete' => 'delete',
|
||||
'update' => 'update',
|
||||
];
|
||||
|
||||
public function render()
|
||||
{
|
||||
return view('writeoff::livewire.subrogasi-jamkrindo.subrogasi-jamkrindo-modal');
|
||||
}
|
||||
|
||||
public function submit()
|
||||
{
|
||||
$this->validate();
|
||||
|
||||
// Validate the form input data
|
||||
DB::transaction(function () {
|
||||
// Prepare the data for creating a new user
|
||||
$data = [
|
||||
'nomor_pinjaman' => $this->nomor_pinjaman,
|
||||
'kode_debitur' => $this->kode_debitur,
|
||||
'nama_debitur' => $this->nama_debitur,
|
||||
'kode_cabang' => $this->kode_cabang,
|
||||
'nama_cabang' => $this->nama_cabang,
|
||||
'nomor_rekening' => $this->nomor_rekening,
|
||||
'nama_rekening' => $this->nama_rekening,
|
||||
'plafond' => $this->plafond,
|
||||
'tenor' => $this->tenor,
|
||||
'tanggal_pengajuan_klaim' => $this->tanggal_pengajuan_klaim,
|
||||
'piutang_subrogasi' => $this->piutang_subrogasi,
|
||||
'total_bayar_subrogasi' => $this->total_bayar_subrogasi,
|
||||
'sisa_piutang_subrogasi' => $this->sisa_piutang_subrogasi,
|
||||
'is_lunas_subrogasi' => $this->is_lunas_subrogasi,
|
||||
'keterangan' => $this->keterangan,
|
||||
'status' => $this->status
|
||||
];
|
||||
|
||||
if ($this->edit_mode) {
|
||||
// Emit a success event with a message
|
||||
$subrogasi_jamkrindo = SubrogasiJamkrindo::find($this->id);
|
||||
$subrogasi_jamkrindo->update($data);
|
||||
|
||||
$this->dispatch('success', __('Subrogasi Jamkrindo updated'));
|
||||
} else {
|
||||
// Emit a success event with a message
|
||||
SubrogasiJamkrindo::create($data);
|
||||
$this->dispatch('success', __('New Subrogasi Jamkrindo created'));
|
||||
}
|
||||
});
|
||||
|
||||
// Reset the form fields after successful submission
|
||||
//$this->reset();
|
||||
|
||||
}
|
||||
|
||||
public function update($id)
|
||||
{
|
||||
$this->edit_mode = true;
|
||||
|
||||
$subrogasi_jamkrindo = SubrogasiJamkrindo::find($id);
|
||||
|
||||
$this->id = $subrogasi_jamkrindo->id;
|
||||
$this->nomor_pinjaman = $subrogasi_jamkrindo->nomor_pinjaman;
|
||||
$this->kode_debitur = $subrogasi_jamkrindo->kode_debitur;
|
||||
$this->nama_debitur = $subrogasi_jamkrindo->nama_debitur;
|
||||
$this->kode_cabang = $subrogasi_jamkrindo->kode_cabang;
|
||||
$this->nama_cabang = $subrogasi_jamkrindo->nama_cabang;
|
||||
$this->nomor_rekening = $subrogasi_jamkrindo->nomor_rekening;
|
||||
$this->nama_rekening = $subrogasi_jamkrindo->nama_rekening;
|
||||
$this->plafond = $subrogasi_jamkrindo->plafond;
|
||||
$this->tenor = $subrogasi_jamkrindo->tenor;
|
||||
$this->tanggal_pengajuan_klaim = $subrogasi_jamkrindo->tanggal_pengajuan_klaim;
|
||||
$this->piutang_subrogasi = $subrogasi_jamkrindo->piutang_subrogasi;
|
||||
$this->total_bayar_subrogasi = $subrogasi_jamkrindo->total_bayar_subrogasi;
|
||||
$this->sisa_piutang_subrogasi = $subrogasi_jamkrindo->sisa_piutang_subrogasi;
|
||||
$this->is_lunas_subrogasi = $subrogasi_jamkrindo->is_lunas_subrogasi == 1;
|
||||
$this->keterangan = $subrogasi_jamkrindo->keterangan;
|
||||
$this->status = $subrogasi_jamkrindo->status == 1;
|
||||
}
|
||||
|
||||
public function getDebitur(){
|
||||
$debitur = Debitur::where('kode',$this->kode_debitur)->first();
|
||||
if($debitur) {
|
||||
$this->nama_debitur = $debitur->name;
|
||||
} else {
|
||||
$this->nama_debitur = '';
|
||||
$this->addError('nama_debitur', 'Debitur Tidak Ditemukan');
|
||||
}
|
||||
}
|
||||
|
||||
public function getBranch(){
|
||||
$branch = Branch::where('kode',$this->kode_cabang)->first();
|
||||
if($branch) {
|
||||
$this->nama_cabang = $branch->name;
|
||||
} else {
|
||||
$this->nama_cabang = '';
|
||||
$this->addError('nama_cabang', 'Cabang Tidak Ditemukan');
|
||||
}
|
||||
}
|
||||
public function getRekening(){
|
||||
$rekening = Rekening::where('nomor_rekening',$this->nomor_rekening)->first();
|
||||
if($rekening) {
|
||||
$debitur = Debitur::where('id',$rekening->debitur_id)->first();
|
||||
if($debitur) {
|
||||
$this->nama_rekening = $debitur->name;
|
||||
} else {
|
||||
$this->nama_rekening = '';
|
||||
$this->addError('nama_rekening', 'Nomor Rekening Tidak Ditemukan');
|
||||
}
|
||||
} else {
|
||||
$this->nama_rekening = '';
|
||||
$this->addError('nama_rekening', 'Nomor Rekening Tidak Ditemukan');
|
||||
}
|
||||
}
|
||||
|
||||
public function delete($id)
|
||||
{
|
||||
SubrogasiJamkrindo::destroy($id);
|
||||
|
||||
// Emit a success event with a message
|
||||
$this->dispatch('success', 'Subrogasi Jamkrindo successfully deleted');
|
||||
}
|
||||
|
||||
public function hydrate()
|
||||
{
|
||||
$this->resetErrorBag();
|
||||
$this->resetValidation();
|
||||
}
|
||||
|
||||
protected function rules()
|
||||
{
|
||||
|
||||
if ($this->edit_mode) {
|
||||
$request = new UpdateSubrogasiJamkrindoRequest();
|
||||
} else {
|
||||
$request = new StoreSubrogasiJamkrindoRequest();
|
||||
}
|
||||
|
||||
|
||||
return $request->rules();
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,245 @@
|
||||
<div class="modal fade" id="kt_modal_add_subrogasi_jamkrindo" tabindex="-1" aria-hidden="true" wire:ignore.self>
|
||||
<!--begin::Modal dialog-->
|
||||
<div class="modal-dialog modal-dialog-centered modal-fullscreen">
|
||||
<!--begin::Modal content-->
|
||||
<div class="modal-content">
|
||||
<!--begin::Modal header-->
|
||||
<div class="modal-header" id="kt_modal_add_subrogasi_jamkrindo_header">
|
||||
<!--begin::Modal title-->
|
||||
<h2 class="fw-bold">Add Subrogasi Jamkrindo</h2>
|
||||
<!--end::Modal title-->
|
||||
<!--begin::Close-->
|
||||
<div class="btn btn-icon btn-sm btn-active-icon-primary" data-bs-dismiss="modal" aria-label="Close">
|
||||
{!! getIcon('cross','fs-1') !!}
|
||||
</div>
|
||||
<!--end::Close-->
|
||||
</div>
|
||||
<!--end::Modal header-->
|
||||
<!--begin::Modal body-->
|
||||
<div class="modal-body px-5 my-7">
|
||||
<!--begin::Form-->
|
||||
<form id="kt_modal_add_subrogasi_jamkrindo_form" class="form" action="#" wire:submit.prevent="submit">
|
||||
<!--begin::Scroll-->
|
||||
<div class="d-flex flex-column scroll-y px-5 px-lg-10" id="kt_modal_add_subrogasi_jamkrindo_scroll" data-kt-scroll="true" data-kt-scroll-activate="true" data-kt-scroll-max-height="auto" data-kt-scroll-dependencies="#kt_modal_add_subrogasi_jamkrindo_header" data-kt-scroll-wrappers="#kt_modal_add_subrogasi_jamkrindo_scroll" data-kt-scroll-offset="300px">
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<label class="required fw-semibold fs-6 mb-2">Nomor Pinjaman</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="number" wire:model.defer="nomor_pinjaman" name="nomor_pinjaman" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Nomor Pinjaman"/>
|
||||
<!--end::Input-->
|
||||
@error('nomor_pinjaman')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="row mb-7">
|
||||
<div class="col-6">
|
||||
<label class="required fw-semibold fs-6 mb-2">Debitur</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="number" wire:change="getDebitur" wire:model.defer="kode_debitur" name="kode_debitur" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Kode Debitur"/>
|
||||
<!--end::Input-->
|
||||
@error('kode_debitur')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<div class="col-6">
|
||||
<label class="fw-semibold fs-6 mb-2"> </label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" wire:model.defer="nama_debitur" readonly name="nama_debitur" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Nama Debitur"/>
|
||||
<!--end::Input-->
|
||||
@error('nama_debitur')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="row mb-7">
|
||||
<div class="col-6">
|
||||
<label class="required fw-semibold fs-6 mb-2">Cabang</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" wire:change="getBranch" wire:model.defer="kode_cabang" name="kode_cabang" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Kode Cabang"/>
|
||||
<!--end::Input-->
|
||||
@error('kode_cabang')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<div class="col-6">
|
||||
<label class="fw-semibold fs-6 mb-2"> </label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" wire:model.defer="nama_cabang" readonly name="nama_cabang" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Nama Cabang"/>
|
||||
<!--end::Input-->
|
||||
@error('nama_cabang')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="row mb-7">
|
||||
<div class="col-6">
|
||||
<label class="required fw-semibold fs-6 mb-2">Nomor Rekening Tabungan</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="number" wire:change="getRekening" wire:model.defer="nomor_rekening" name="nomor_rekening" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Nomor Rekening"/>
|
||||
<!--end::Input-->
|
||||
@error('nomor_rekening')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<div class="col-6">
|
||||
<label class="fw-semibold fs-6 mb-2"> </label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" wire:model.defer="nama_rekening" readonly name="nama_rekening" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Nama Rekening"/>
|
||||
<!--end::Input-->
|
||||
@error('nama_rekening')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<!--begin::Label-->
|
||||
<label class="required fw-semibold fs-6 mb-2">Plafond</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" data-inputmask="'alias': 'currency'" wire:model.defer="plafond" name="plafond" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Plafond"/>
|
||||
<!--end::Input-->
|
||||
@error('plafond')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<!--begin::Label-->
|
||||
<label class="required fw-semibold fs-6 mb-2">Tenor</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="number" wire:model.defer="tenor" name="tenor" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Tenor"/>
|
||||
<!--end::Input-->
|
||||
@error('tenor')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<!--begin::Label-->
|
||||
<label class="required fw-semibold fs-6 mb-2">Tanggal Pengajuan Klaim</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="date" wire:model.defer="tanggal_pengajuan_klaim" name="tanggal_pengajuan_klaim" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Tanggal Pengajuan Klaim"/>
|
||||
<!--end::Input-->
|
||||
@error('tanggal_pengajuan_klaim')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<!--begin::Label-->
|
||||
<label class="required fw-semibold fs-6 mb-2">Piutang Subrogasi</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" data-inputmask="'alias': 'currency'" wire:model.defer="piutang_subrogasi" name="piutang_subrogasi" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Piutang Subrogasi"/>
|
||||
<!--end::Input-->
|
||||
@error('piutang_subrogasi')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<!--begin::Label-->
|
||||
<label class="required fw-semibold fs-6 mb-2">Total Bayar Subrogasi</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" data-inputmask="'alias': 'currency'" wire:model.defer="total_bayar_subrogasi" name="total_bayar_subrogasi" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Total Bayar Subrogasi"/>
|
||||
<!--end::Input-->
|
||||
@error('total_bayar_subrogasi')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<!--begin::Label-->
|
||||
<label class="required fw-semibold fs-6 mb-2">Sisa Piutang Subrogasi</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" data-inputmask="'alias': 'currency'" wire:model.defer="sisa_piutang_subrogasi" name="sisa_piutang_subrogasi" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Sisa Piutang Subrogasi"/>
|
||||
<!--end::Input-->
|
||||
@error('sisa_piutang_subrogasi')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
|
||||
<!--begin::Input group-->
|
||||
<div class="fv-row mb-7">
|
||||
<!--begin::Label-->
|
||||
<label class="fw-semibold fs-6 mb-2">Keterangan</label>
|
||||
<!--end::Label-->
|
||||
<!--begin::Input-->
|
||||
<input type="text" wire:model.defer="keterangan" name="keterangan" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Keterangan"/>
|
||||
<!--end::Input-->
|
||||
@error('keterangan')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
<!--end::Input group-->
|
||||
<div class="row mb-7">
|
||||
<div class="col-6">
|
||||
<label class="fw-semibold fs-6 mb-2">Lunas Subrogasi</label>
|
||||
<div class="form-check form-switch form-check-custom form-check-solid mb-5" style="display: block!important;">
|
||||
<input class="form-check-input h-20px w-30px me-5" type="checkbox" wire:model.defer="is_lunas_subrogasi" id="is_lunas_subrogasi" name="is_lunas_subrogasi"/>
|
||||
<label class="form-check-label" for="is_lunas_subrogasi">
|
||||
Lunas
|
||||
</label>
|
||||
@error('is_lunas_subrogasi')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-6">
|
||||
|
||||
<label class="fw-semibold fs-6 mb-2">Status Data</label>
|
||||
<div class="form-check form-switch form-check-custom form-check-solid" style="display: block!important;">
|
||||
<input class="form-check-input h-20px w-30px me-5" type="checkbox" wire:model.defer="status" id="status" name="status"/>
|
||||
<label class="form-check-label" for="status">
|
||||
Aktif
|
||||
</label>
|
||||
@error('status')
|
||||
<span class="text-danger">{{ $message }}</span> @enderror
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<!--end::Scroll-->
|
||||
<!--begin::Actions-->
|
||||
<div class="text-center pt-15">
|
||||
<button type="reset" class="btn btn-light me-3" data-bs-dismiss="modal" aria-label="Close" wire:loading.attr="disabled">Discard</button>
|
||||
<button type="submit" class="btn btn-primary" data-kt-subrogasi_jamkrindoes-modal-action="submit">
|
||||
<span class="indicator-label" wire:loading.remove>Submit</span>
|
||||
<span class="indicator-progress" wire:loading wire:target="submit">
|
||||
Please wait...
|
||||
<span class="spinner-border spinner-border-sm align-middle ms-2"></span>
|
||||
</span>
|
||||
</button>
|
||||
</div>
|
||||
<!--end::Actions-->
|
||||
</form>
|
||||
<!--end::Form-->
|
||||
</div>
|
||||
<!--end::Modal body-->
|
||||
</div>
|
||||
<!--end::Modal content-->
|
||||
</div>
|
||||
<!--end::Modal dialog-->
|
||||
</div>
|
@ -103,6 +103,15 @@
|
||||
<span class="menu-title">Data Klaim Jamkrindo</span>
|
||||
</a>
|
||||
<!--end:Menu link-->
|
||||
|
||||
<!--begin:Menu link-->
|
||||
<a class="menu-link {{ isset($route[1]) && $route[1] == 'subrogasi_jamkrindo' ? 'active' : '' }}" href="{{ route('pencatatan.subrogasi_jamkrindo.index') }}">
|
||||
<span class="menu-bullet">
|
||||
<span class="bullet bullet-dot"></span>
|
||||
</span>
|
||||
<span class="menu-title">Data Subrogasi Jamkrindo</span>
|
||||
</a>
|
||||
<!--end:Menu link-->
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -0,0 +1,23 @@
|
||||
<a href="#" class="btn btn-light btn-active-light-primary btn-flex btn-center btn-sm" data-kt-menu-trigger="click" data-kt-menu-placement="bottom-end">
|
||||
Actions
|
||||
<i class="ki-duotone ki-down fs-5 ms-1"></i>
|
||||
</a>
|
||||
<!--begin::Menu-->
|
||||
<div class="menu menu-sub menu-sub-dropdown menu-column menu-rounded menu-gray-600 menu-state-bg-light-primary fw-semibold fs-7 w-125px py-4" data-kt-menu="true">
|
||||
<!--begin::Menu item-->
|
||||
<div class="menu-item px-3">
|
||||
<a href="#" class="menu-link px-3" data-kt-id="{{ $subrogasi_jamkrindo->id }}" data-bs-toggle="modal" data-bs-target="#kt_modal_add_subrogasi_jamkrindo" data-kt-action="update_row">
|
||||
Edit
|
||||
</a>
|
||||
</div>
|
||||
<!--end::Menu item-->
|
||||
|
||||
<!--begin::Menu item-->
|
||||
<div class="menu-item px-3">
|
||||
<a href="#" class="menu-link px-3" data-kt-id="{{ $subrogasi_jamkrindo->id }}" data-kt-action="delete_row">
|
||||
Delete
|
||||
</a>
|
||||
</div>
|
||||
<!--end::Menu item-->
|
||||
</div>
|
||||
<!--end::Menu-->
|
@ -0,0 +1,37 @@
|
||||
// Initialize KTMenu
|
||||
KTMenu.init();
|
||||
|
||||
// Add click event listener to delete buttons
|
||||
document.querySelectorAll('[data-kt-action="delete_row"]').forEach(function (element) {
|
||||
element.addEventListener('click', function () {
|
||||
Swal.fire({
|
||||
text: 'Are you sure you want to remove?',
|
||||
icon: 'warning',
|
||||
buttonsStyling: false,
|
||||
showCancelButton: true,
|
||||
confirmButtonText: 'Yes',
|
||||
cancelButtonText: 'No',
|
||||
customClass: {
|
||||
confirmButton: 'btn btn-danger',
|
||||
cancelButton: 'btn btn-secondary',
|
||||
}
|
||||
}).then((result) => {
|
||||
if (result.isConfirmed) {
|
||||
Livewire.dispatch('delete', { id : this.getAttribute('data-kt-id') });
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
// Add click event listener to update buttons
|
||||
document.querySelectorAll('[data-kt-action="update_row"]').forEach(function (element) {
|
||||
element.addEventListener('click', function () {
|
||||
Livewire.dispatch('update', { id : this.getAttribute('data-kt-id') });
|
||||
});
|
||||
});
|
||||
|
||||
// Listen for 'success' event emitted by Livewire
|
||||
Livewire.on('success', (message) => {
|
||||
// Reload the users-table datatable
|
||||
LaravelDataTables['subrogasi-jamkrindo-table'].ajax.reload();
|
||||
});
|
@ -0,0 +1,86 @@
|
||||
<x-default-layout>
|
||||
|
||||
@section('title')
|
||||
Data Subrogasi Jamkrindo
|
||||
@endsection
|
||||
|
||||
@section('breadcrumbs')
|
||||
{{ Breadcrumbs::render('pencatatan.subrogasi-jamkrindo') }}
|
||||
@endsection
|
||||
|
||||
<div class="card">
|
||||
<!--begin::Card header-->
|
||||
<div class="card-header border-0 pt-6">
|
||||
<!--begin::Card title-->
|
||||
<div class="card-title">
|
||||
<!--begin::Search-->
|
||||
<div class="d-flex align-items-center position-relative my-1">
|
||||
{!! getIcon('magnifier', 'fs-3 position-absolute ms-5') !!}
|
||||
<input type="text" data-kt-subrogasi_jamkrindo-table-filter="search" class="form-control form-control-solid w-250px ps-13" placeholder="Search subrogasi_jamkrindo" id="mySearchInput"/>
|
||||
</div>
|
||||
<!--end::Search-->
|
||||
</div>
|
||||
<!--begin::Card title-->
|
||||
|
||||
<!--begin::Card toolbar-->
|
||||
<div class="card-toolbar">
|
||||
<!--begin::Toolbar-->
|
||||
<div class="d-flex justify-content-end" data-kt-subrogasi_jamkrindo-table-toolbar="base">
|
||||
<!--begin::Add subrogasi_jamkrindo-->
|
||||
<button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target="#kt_modal_add_subrogasi_jamkrindo">
|
||||
{!! getIcon('plus', 'fs-2', '', 'i') !!}
|
||||
Add Subrogasi Jamkrindo
|
||||
</button>
|
||||
<!--end::Add subrogasi_jamkrindo-->
|
||||
</div>
|
||||
<!--end::Toolbar-->
|
||||
|
||||
<!--begin::Modal-->
|
||||
<livewire:writeoff::subrogasi-jamkrindo.subrogasi-jamkrindo-modal/>
|
||||
<!--end::Modal-->
|
||||
</div>
|
||||
<!--end::Card toolbar-->
|
||||
</div>
|
||||
<!--end::Card header-->
|
||||
|
||||
<!--begin::Card body-->
|
||||
<div class="card-body py-4">
|
||||
<!--begin::Table-->
|
||||
<div class="table-responsive">
|
||||
{{ $dataTable->table() }}
|
||||
</div>
|
||||
<!--end::Table-->
|
||||
</div>
|
||||
<!--end::Card body-->
|
||||
</div>
|
||||
|
||||
@push('scripts')
|
||||
{{ $dataTable->scripts() }}
|
||||
<script>
|
||||
document.getElementById('mySearchInput').addEventListener('keyup', function () {
|
||||
window.LaravelDataTables['subrogasi-jamkrindo-table'].search(this.value).draw();
|
||||
});
|
||||
document.addEventListener('livewire:initialized', function () {
|
||||
Livewire.on('success', function () {
|
||||
$('#kt_modal_add_subrogasi_jamkrindo').modal('hide');
|
||||
window.LaravelDataTables['subrogasi-jamkrindo-table'].ajax.reload();
|
||||
});
|
||||
});
|
||||
|
||||
Inputmask.extendAliases({
|
||||
'currency': {
|
||||
autoUnmask: true,
|
||||
allowPlus: true,
|
||||
allowMinus: true,
|
||||
}
|
||||
});
|
||||
|
||||
$(function(){
|
||||
$('#kt_modal_add_subrogasi_jamkrindo').on('hidden.bs.modal', function () {
|
||||
$(this).find('form').trigger('reset');
|
||||
})
|
||||
});
|
||||
</script>
|
||||
@endpush
|
||||
|
||||
</x-default-layout>
|
@ -56,3 +56,8 @@
|
||||
$trail->parent('pencatatan');
|
||||
$trail->push('Data Klaim Jamkrindo', route('pencatatan.klaim_jamkrindo.index'));
|
||||
});
|
||||
|
||||
Breadcrumbs::for('pencatatan.subrogasi-jamkrindo', function (BreadcrumbTrail $trail) {
|
||||
$trail->parent('pencatatan');
|
||||
$trail->push('Data Subrogasi Jamkrindo', route('pencatatan.subrogasi_jamkrindo.index'));
|
||||
});
|
||||
|
@ -24,4 +24,5 @@ Route::name('parameter.')->prefix('parameter')->group(function() {
|
||||
|
||||
Route::name('pencatatan.')->prefix('pencatatan')->group(function() {
|
||||
Route::get('klaim-jamkrindo', 'KlaimJamkrindoController@index')->name('klaim_jamkrindo.index');
|
||||
Route::get('subrogasi-jamkrindo', 'SubrogasiJamkrindoController@index')->name('subrogasi_jamkrindo.index');
|
||||
});
|
||||
|
Loading…
Reference in New Issue
Block a user