Add Module Data Klaim Jamkrindo
This commit is contained in:
parent
27fc3e56dc
commit
8e9bb4b826
123
DataTables/KlaimJamkrindoDataTable.php
Normal file
123
DataTables/KlaimJamkrindoDataTable.php
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Writeoff\DataTables;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use Illuminate\Database\Eloquent\Builder as QueryBuilder;
|
||||||
|
use Modules\Writeoff\Entities\KlaimJamkrindo;
|
||||||
|
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 KlaimJamkrindoDataTable 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('tanggal_rtgs_masuk', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('jumlah_debitur_surat', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('jumlah_debitur_excel', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('dana_hasil_klaim', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('nilai_penyelesaian', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('jumlah_debitur_penyelesaian', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('sisa_dana_ksl', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('jumlah_debitur_sisa_ksl', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('is_detail_debitur', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('keterangan', 'like', "%" . $search['value'] . "%")
|
||||||
|
->orWhere('status', 'like', "%" . $search['value'] . "%");
|
||||||
|
}
|
||||||
|
})->addIndexColumn()
|
||||||
|
->editColumn('tanggal_rtgs_masuk', function ($row) {
|
||||||
|
$date = Carbon::create($row->tanggal_rtgs_masuk);
|
||||||
|
return $date->locale('id')->translatedFormat('d F Y');
|
||||||
|
})
|
||||||
|
->editColumn('jumlah_debitur', function ($row) {
|
||||||
|
return $row->jumlah_debitur_surat.'/'.$row->jumlah_debitur_excel;
|
||||||
|
})
|
||||||
|
->editColumn('dana_hasil_klaim', function ($row) {
|
||||||
|
return @rupiah($row->dana_hasil_klaim);
|
||||||
|
})
|
||||||
|
->editColumn('nilai_penyelesaian', function ($row) {
|
||||||
|
return @rupiah($row->nilai_penyelesaian).' / '.$row->jumlah_debitur_penyelesaian;
|
||||||
|
})
|
||||||
|
->editColumn('sisa_dana_ksl', function ($row) {
|
||||||
|
return @rupiah($row->sisa_dana_ksl).' / '.$row->jumlah_debitur_sis_ksl;
|
||||||
|
})
|
||||||
|
->editColumn('is_detail_debitur', function ($row) {
|
||||||
|
return $row->is_detail_debitur ? 'Ada' : 'Tidak Ada';
|
||||||
|
})
|
||||||
|
->editColumn('updated_at', function ($row) {
|
||||||
|
return $row->updated_at->locale('id')->translatedFormat('d F Y H:i:s');
|
||||||
|
})->rawColumns(['action'])->addColumn('action', function ($klaim_jamkrindo) {
|
||||||
|
return view('writeoff::parameter.klaim_jamkrindo._actions', compact('klaim_jamkrindo'));
|
||||||
|
})->setRowId('id');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the query source of dataTable.
|
||||||
|
*/
|
||||||
|
public function query(KlaimJamkrindo $model)
|
||||||
|
: QueryBuilder
|
||||||
|
{
|
||||||
|
return $model->newQuery();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Optional method if you want to use the html builder.
|
||||||
|
*/
|
||||||
|
public function html()
|
||||||
|
: HtmlBuilder
|
||||||
|
{
|
||||||
|
return $this->builder()
|
||||||
|
->setTableId('klaim-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/klaim_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('tanggal_rtgs_masuk')->title('Tanggal RTGS Masuk')->addClass('align-top'),
|
||||||
|
Column::make('jumlah_debitur')->title('Jumlah Debitur<br>(Surat / Excel)')->addClass('align-top'),
|
||||||
|
Column::make('dana_hasil_klaim')->title('Data Hasil Klaim')->addClass('align-top'),
|
||||||
|
Column::make('nilai_penyelesaian')->title('Nilai Penyelesaian / Jumlah Debitur')->addClass('align-top'),
|
||||||
|
Column::make('sisa_dana_ksl')->title('Sisa Dana KSL / Jumlah Debitur')->addClass('align-top'),
|
||||||
|
Column::make('is_detail_debitur')->title('Detail Debitur')->addClass('align-top'),
|
||||||
|
Column::computed('action')->exportable(false)->printable(false)->width(60)->addClass('text-center')->addClass('align-top')
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the filename for export.
|
||||||
|
*/
|
||||||
|
protected function filename()
|
||||||
|
: string
|
||||||
|
{
|
||||||
|
return 'KlaimJamkrindo_' . date('YmdHis');
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration {
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up()
|
||||||
|
: void
|
||||||
|
{
|
||||||
|
Schema::create('klaim_jamkrindo', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->date('tanggal_rtgs_masuk');
|
||||||
|
$table->integer('jumlah_debitur_surat', false, true);
|
||||||
|
$table->integer('jumlah_debitur_excel', false, true);
|
||||||
|
$table->float('dana_hasil_klaim', 15, 2);
|
||||||
|
$table->float('nilai_penyelesaian', 15, 2);
|
||||||
|
$table->integer('jumlah_debitur_penyelesaian', false, true);
|
||||||
|
$table->float('sisa_dana_ksl', 15, 2);
|
||||||
|
$table->integer('jumlah_debitur_sisa_ksl', false, true);
|
||||||
|
$table->char('is_detail_debitur', 1)->default('A');
|
||||||
|
$table->string('keterangan')->nullable();
|
||||||
|
$table->char('status', 1)->default('A');
|
||||||
|
$table->timestamps();
|
||||||
|
$table->timestamp('authorized_at')->nullable();
|
||||||
|
$table->char('authorized_status', 1)->nullable();
|
||||||
|
$table->softDeletes();
|
||||||
|
|
||||||
|
$table->unsignedBigInteger('created_by')->nullable();
|
||||||
|
$table->unsignedBigInteger('updated_by')->nullable();
|
||||||
|
$table->unsignedBigInteger('deleted_by')->nullable();
|
||||||
|
$table->unsignedBigInteger('authorized_by')->nullable();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down()
|
||||||
|
: void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('klaim_jamkrindo');
|
||||||
|
}
|
||||||
|
};
|
25
Entities/KlaimJamkrindo.php
Normal file
25
Entities/KlaimJamkrindo.php
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Writeoff\Entities;
|
||||||
|
|
||||||
|
class KlaimJamkrindo extends BaseModel
|
||||||
|
{
|
||||||
|
protected $table = 'klaim_jamkrindo';
|
||||||
|
protected $fillable = [
|
||||||
|
'tanggal_rtgs_masuk',
|
||||||
|
'jumlah_debitur_surat',
|
||||||
|
'jumlah_debitur_excel',
|
||||||
|
'dana_hasil_klaim',
|
||||||
|
'nilai_penyelesaian',
|
||||||
|
'jumlah_debitur_penyelesaian',
|
||||||
|
'sisa_dana_ksl',
|
||||||
|
'jumlah_debitur_sisa_ksl',
|
||||||
|
'is_detail_debitur',
|
||||||
|
'keterangan',
|
||||||
|
'status',
|
||||||
|
'registered_at',
|
||||||
|
'authorized_at',
|
||||||
|
'authorized_status',
|
||||||
|
'authorized_by',
|
||||||
|
];
|
||||||
|
}
|
37
Http/Controllers/KlaimJamkrindoController.php
Normal file
37
Http/Controllers/KlaimJamkrindoController.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\KlaimJamkrindoDataTable;
|
||||||
|
|
||||||
|
class KlaimJamkrindoController 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 KlaimJamkrindos.
|
||||||
|
*
|
||||||
|
* @param \Modules\Writeoff\DataTables\KlaimJamkrindoDataTable $dataTable
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function index(KlaimJamkrindoDataTable $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.klaim_jamkrindo.index');
|
||||||
|
}
|
||||||
|
}
|
84
Http/Requests/KlaimJamkrindo/KlaimJamkrindoRequest.php
Normal file
84
Http/Requests/KlaimJamkrindo/KlaimJamkrindoRequest.php
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Writeoff\Http\Requests\KlaimJamkrindo;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
use Illuminate\Http\Exceptions\HttpResponseException;
|
||||||
|
use Illuminate\Validation\ValidationException;
|
||||||
|
use Illuminate\Validation\Validator;
|
||||||
|
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||||
|
|
||||||
|
class KlaimJamkrindoRequest 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 [
|
||||||
|
'tanggal_rtgs_masuk' => 'required|date',
|
||||||
|
'jumlah_debitur_surat' => 'required|integer',
|
||||||
|
'jumlah_debitur_excel' => 'required|integer',
|
||||||
|
'dana_hasil_klaim' => 'required|float',
|
||||||
|
'nilai_penyelesaian' => 'required|float',
|
||||||
|
'jumlah_debitur_penyelesaian' => 'required|integer',
|
||||||
|
'sisa_dana_ksl' => 'required|float',
|
||||||
|
'jumlah_debitur_sisa_ksl' => 'required|integer',
|
||||||
|
'is_detail_debitur' => 'required|boolean',
|
||||||
|
'keterangan' => 'nullable|string',
|
||||||
|
'status' => 'required|string',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
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('parameter.branches.index')
|
||||||
|
->with('error', 'Klaim 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' => 'Klaim Jamkrindo created failed.'
|
||||||
|
], JsonResponse::HTTP_UNPROCESSABLE_ENTITY));
|
||||||
|
}
|
||||||
|
}
|
115
Livewire/KlaimJamkrindo/KlaimJamkrindoModal.php
Normal file
115
Livewire/KlaimJamkrindo/KlaimJamkrindoModal.php
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Writeoff\Livewire\KlaimJamkrindo;
|
||||||
|
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
use Livewire\Component;
|
||||||
|
use Modules\Writeoff\Entities\KlaimJamkrindo;
|
||||||
|
use Modules\Writeoff\Http\Requests\KlaimJamkrindo\KlaimJamkrindoRequest;
|
||||||
|
|
||||||
|
class KlaimJamkrindoModal extends Component
|
||||||
|
{
|
||||||
|
public $tanggal_rtgs_masuk;
|
||||||
|
public $jumlah_debitur_surat;
|
||||||
|
public $jumlah_debitur_excel;
|
||||||
|
public $dana_hasil_klaim;
|
||||||
|
public $nilai_penyelesaian;
|
||||||
|
public $jumlah_debitur_penyelesaian;
|
||||||
|
public $sisa_dana_ksl;
|
||||||
|
public $jumlah_debitur_sisa_ksl;
|
||||||
|
public $is_detail_debitur;
|
||||||
|
public $keterangan;
|
||||||
|
public $status;
|
||||||
|
|
||||||
|
public $edit_mode = false;
|
||||||
|
|
||||||
|
protected $listeners = [
|
||||||
|
'delete' => 'delete',
|
||||||
|
'update' => 'update',
|
||||||
|
];
|
||||||
|
|
||||||
|
public function render()
|
||||||
|
{
|
||||||
|
return view('writeoff::livewire.klaim-jamkrindo.klaim-jamkrindo-modal');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function submit()
|
||||||
|
{
|
||||||
|
$this->validate();
|
||||||
|
|
||||||
|
// Validate the form input data
|
||||||
|
DB::transaction(function () {
|
||||||
|
// Prepare the data for creating a new user
|
||||||
|
$data = [
|
||||||
|
'tanggal_rtgs_masuk' => $this->tanggal_rtgs_masuk,
|
||||||
|
'jumlah_debitur_surat' => $this->jumlah_debitur_surat,
|
||||||
|
'jumlah_debitur_excel' => $this->jumlah_debitur_excel,
|
||||||
|
'dana_hasil_klaim' => $this->dana_hasil_klaim,
|
||||||
|
'nilai_penyelesaian' => $this->nilai_penyelesaian,
|
||||||
|
'jumlah_debitur_penyelesaian' => $this->jumlah_debitur_penyelesaian,
|
||||||
|
'sisa_dana_ksl' => $this->sisa_dana_ksl,
|
||||||
|
'jumlah_debitur_sisa_ksl' => $this->jumlah_debitur_sisa_ksl,
|
||||||
|
'is_detail_debitur' => $this->is_detail_debitur,
|
||||||
|
'keterangan' => $this->keterangan,
|
||||||
|
'status' => $this->status,
|
||||||
|
];
|
||||||
|
|
||||||
|
if ($this->edit_mode) {
|
||||||
|
// Emit a success event with a message
|
||||||
|
$facility_type = KlaimJamkrindo::find($this->id);
|
||||||
|
$facility_type->update($data);
|
||||||
|
|
||||||
|
$this->dispatch('success', __('Facility Type updated'));
|
||||||
|
} else {
|
||||||
|
// Emit a success event with a message
|
||||||
|
KlaimJamkrindo::create($data);
|
||||||
|
$this->dispatch('success', __('New Facility Type created'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Reset the form fields after successful submission
|
||||||
|
$this->reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function update($id)
|
||||||
|
{
|
||||||
|
$this->edit_mode = true;
|
||||||
|
|
||||||
|
$klaim_jamkrindo = KlaimJamkrindo::find($id);
|
||||||
|
|
||||||
|
$this->id = $klaim_jamkrindo->id;
|
||||||
|
$this->tanggal_rtgs_masuk = $klaim_jamkrindo->tanggal_rtgs_masuk;
|
||||||
|
$this->jumlah_debitur_surat = $klaim_jamkrindo->jumlah_debitur_surat;
|
||||||
|
$this->jumlah_debitur_excel = $klaim_jamkrindo->jumlah_debitur_excel;
|
||||||
|
$this->dana_hasil_klaim = $klaim_jamkrindo->dana_hasil_klaim;
|
||||||
|
$this->nilai_penyelesaian = $klaim_jamkrindo->nilai_penyelesaian;
|
||||||
|
$this->jumlah_debitur_penyelesaian = $klaim_jamkrindo->jumlah_debitur_penyelesaian;
|
||||||
|
$this->sisa_dana_ksl = $klaim_jamkrindo->sisa_dana_ksl;
|
||||||
|
$this->jumlah_debitur_sisa_ksl = $klaim_jamkrindo->jumlah_debitur_sisa_ksl;
|
||||||
|
$this->is_detail_debitur = $klaim_jamkrindo->is_detail_debitur;
|
||||||
|
$this->keterangan = $klaim_jamkrindo->keterangan;
|
||||||
|
$this->status = $klaim_jamkrindo->status;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function delete($id)
|
||||||
|
{
|
||||||
|
KlaimJamkrindo::destroy($id);
|
||||||
|
|
||||||
|
// Emit a success event with a message
|
||||||
|
$this->dispatch('success', 'Facility Type successfully deleted');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function hydrate()
|
||||||
|
{
|
||||||
|
$this->resetErrorBag();
|
||||||
|
$this->resetValidation();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function rules()
|
||||||
|
{
|
||||||
|
$request = new KlaimJamkrindoRequest();
|
||||||
|
|
||||||
|
return $request->rules();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -4,6 +4,7 @@ namespace Modules\Writeoff\Providers;
|
|||||||
|
|
||||||
use Illuminate\Support\ServiceProvider;
|
use Illuminate\Support\ServiceProvider;
|
||||||
use Illuminate\Database\Eloquent\Factory;
|
use Illuminate\Database\Eloquent\Factory;
|
||||||
|
use Illuminate\Support\Facades\Blade;
|
||||||
|
|
||||||
class WriteoffServiceProvider extends ServiceProvider
|
class WriteoffServiceProvider extends ServiceProvider
|
||||||
{
|
{
|
||||||
@ -28,6 +29,8 @@ class WriteoffServiceProvider extends ServiceProvider
|
|||||||
$this->registerConfig();
|
$this->registerConfig();
|
||||||
$this->registerViews();
|
$this->registerViews();
|
||||||
$this->loadMigrationsFrom(module_path($this->moduleName, 'Database/Migrations'));
|
$this->loadMigrationsFrom(module_path($this->moduleName, 'Database/Migrations'));
|
||||||
|
|
||||||
|
Blade::directive('rupiah', function ( $expression ) { return "Rp. <?php echo number_format($expression,0,',','.'); ?>"; });
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -0,0 +1,72 @@
|
|||||||
|
<div class="modal fade" id="kt_modal_add_klaim_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_klaim_jamkrindo_header">
|
||||||
|
<!--begin::Modal title-->
|
||||||
|
<h2 class="fw-bold">Add Jenis Fasilitas</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_klaim_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_klaim_jamkrindo_scroll" data-kt-scroll="true" data-kt-scroll-activate="true" data-kt-scroll-max-height="auto" data-kt-scroll-dependencies="#kt_modal_add_klaim_jamkrindo_header" data-kt-scroll-wrappers="#kt_modal_add_klaim_jamkrindo_scroll" data-kt-scroll-offset="300px">
|
||||||
|
|
||||||
|
<!--begin::Input group-->
|
||||||
|
<div class="fv-row mb-7">
|
||||||
|
<!--begin::Label-->
|
||||||
|
<label class="required fw-semibold fs-6 mb-2">Kode Jenis Fasilitas</label>
|
||||||
|
<!--end::Label-->
|
||||||
|
<!--begin::Input-->
|
||||||
|
<input type="text" wire:model.defer="kode" name="kode" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Kode Jenis Fasilitas"/>
|
||||||
|
<!--end::Input-->
|
||||||
|
@error('kode')
|
||||||
|
<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">Nama Jenis Fasilitas</label>
|
||||||
|
<!--end::Label-->
|
||||||
|
<!--begin::Input-->
|
||||||
|
<input type="text" wire:model.defer="name" name="name" class="form-control form-control-solid mb-3 mb-lg-0" placeholder="Nama Jenis Fasilitas"/>
|
||||||
|
<!--end::Input-->
|
||||||
|
@error('name')
|
||||||
|
<span class="text-danger">{{ $message }}</span> @enderror
|
||||||
|
</div>
|
||||||
|
<!--end::Input group-->
|
||||||
|
|
||||||
|
</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-klaim_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>
|
@ -82,4 +82,28 @@
|
|||||||
<!--end:Menu sub-->
|
<!--end:Menu sub-->
|
||||||
</div>
|
</div>
|
||||||
<!--end:Menu item-->
|
<!--end:Menu item-->
|
||||||
|
|
||||||
|
<div data-kt-menu-trigger="click" class="menu-item menu-accordion {{ $route[0] == 'pencatatan' ? 'show' : '' }}">
|
||||||
|
<!--begin:Menu link-->
|
||||||
|
<span class="menu-link">
|
||||||
|
<span class="menu-icon">{!! getIcon('people', 'fs-2') !!}</span>
|
||||||
|
<span class="menu-title">Penctatan Data</span>
|
||||||
|
<span class="menu-arrow"></span>
|
||||||
|
</span>
|
||||||
|
<!--end:Menu link-->
|
||||||
|
<!--begin:Menu sub-->
|
||||||
|
<div class="menu-sub menu-sub-accordion">
|
||||||
|
<!--begin:Menu item-->
|
||||||
|
<div class="menu-item ">
|
||||||
|
<!--begin:Menu link-->
|
||||||
|
<a class="menu-link {{ isset($route[1]) && $route[1] == 'klaim_jamkrindo' ? 'active' : '' }}" href="{{ route('pencatatan.klaim_jamkrindo.index') }}">
|
||||||
|
<span class="menu-bullet">
|
||||||
|
<span class="bullet bullet-dot"></span>
|
||||||
|
</span>
|
||||||
|
<span class="menu-title">Data Klaim Jamkrindo</span>
|
||||||
|
</a>
|
||||||
|
<!--end:Menu link-->
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
@endcanany
|
@endcanany
|
||||||
|
@ -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="{{ $klaim_jamkrindo->id }}" data-bs-toggle="modal" data-bs-target="#kt_modal_add_klaim_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="{{ $klaim_jamkrindo->id }}" data-kt-action="delete_row">
|
||||||
|
Delete
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<!--end::Menu item-->
|
||||||
|
</div>
|
||||||
|
<!--end::Menu-->
|
37
Resources/views/pencatatan/klaim_jamkrindo/_draw-scripts.js
Normal file
37
Resources/views/pencatatan/klaim_jamkrindo/_draw-scripts.js
Normal file
@ -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['klaim-jamkrindo-table'].ajax.reload();
|
||||||
|
});
|
72
Resources/views/pencatatan/klaim_jamkrindo/index.blade.php
Normal file
72
Resources/views/pencatatan/klaim_jamkrindo/index.blade.php
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
<x-default-layout>
|
||||||
|
|
||||||
|
@section('title')
|
||||||
|
Data Klaim Jamkrindo
|
||||||
|
@endsection
|
||||||
|
|
||||||
|
@section('breadcrumbs')
|
||||||
|
{{ Breadcrumbs::render('pencatatan.klaim-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-klaim_jamkrindo-table-filter="search" class="form-control form-control-solid w-250px ps-13" placeholder="Search klaim_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-klaim_jamkrindo-table-toolbar="base">
|
||||||
|
<!--begin::Add klaim_jamkrindo-->
|
||||||
|
<button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target="#kt_modal_add_klaim_jamkrindo">
|
||||||
|
{!! getIcon('plus', 'fs-2', '', 'i') !!}
|
||||||
|
Add Jenis Fasilitas
|
||||||
|
</button>
|
||||||
|
<!--end::Add klaim_jamkrindo-->
|
||||||
|
</div>
|
||||||
|
<!--end::Toolbar-->
|
||||||
|
|
||||||
|
<!--begin::Modal-->
|
||||||
|
<livewire:writeoff::klaim-jamkrindo.klaim-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['klaim-jamkrindo-table'].search(this.value).draw();
|
||||||
|
});
|
||||||
|
document.addEventListener('livewire:initialized', function () {
|
||||||
|
Livewire.on('success', function () {
|
||||||
|
$('#kt_modal_add_klaim_jamkrindo').modal('hide');
|
||||||
|
window.LaravelDataTables['klaim-jamkrindo-table'].ajax.reload();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
@endpush
|
||||||
|
|
||||||
|
</x-default-layout>
|
@ -46,3 +46,13 @@
|
|||||||
$trail->parent('parameter');
|
$trail->parent('parameter');
|
||||||
$trail->push('Rekening', route('parameter.rekening.index'));
|
$trail->push('Rekening', route('parameter.rekening.index'));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('pencatatan', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('home');
|
||||||
|
$trail->push('Pencatatan', '#');
|
||||||
|
});
|
||||||
|
|
||||||
|
Breadcrumbs::for('pencatatan.klaim-jamkrindo', function (BreadcrumbTrail $trail) {
|
||||||
|
$trail->parent('pencatatan');
|
||||||
|
$trail->push('Data Klaim Jamkrindo', route('pencatatan.klaim_jamkrindo.index'));
|
||||||
|
});
|
||||||
|
@ -21,3 +21,7 @@ Route::name('parameter.')->prefix('parameter')->group(function() {
|
|||||||
Route::get('debitur', 'DebiturController@index')->name('debitur.index');
|
Route::get('debitur', 'DebiturController@index')->name('debitur.index');
|
||||||
Route::get('rekening', 'RekeningController@index')->name('rekening.index');
|
Route::get('rekening', 'RekeningController@index')->name('rekening.index');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Route::name('pencatatan.')->prefix('pencatatan')->group(function() {
|
||||||
|
Route::get('klaim-jamkrindo', 'KlaimJamkrindoController@index')->name('klaim_jamkrindo.index');
|
||||||
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user