Files
gps-frontend/resources/views/menu_v1/configs/usersMenuPermissions.blade.php
meusinfirmary 7b85e1e376 update
2025-06-17 09:44:24 +09:00

1141 lines
64 KiB
PHP
Executable File

@extends('app.app')
@php
$no_permission = App\Models\UsersMenuPermissions::IS_NOPERMISSION;
$no_permission_text = 'Ditolak';
$is_permission = App\Models\UsersMenuPermissions::IS_PERMISSION;
$is_permission_text = 'Diizinkan';
@endphp
@section('title')
Menu Permissions
@endsection
@section('customcss')
<style>
th {
border: 1px solid #bbb;
}
</style>
@endsection
@section('content')
<div class="container-fluid">
<div class="content">
<div class="card">
<div class="card-header">
<div class="row d-flex align-items-center">
<div class="col-3">
<p class="card-title text-bold mb-0">Menu Permissions (<span id="count_users_menu_permissions">0</span>)</p>
</div>
<div class="col text-end">
<button id="btnMdlNewPermission" class="btn btn-sm btn-danger">Tambah Permission Baru</button>
</div>
<div class="col-auto text-end ps-0">
{{-- <button class="btn btn-sm btn-danger">Upload</button> --}}
{{-- <button class="btn btn-sm btn-danger">Download</button> --}}
</div>
</div>
</div>
<div class="card-body">
<div class="table-responsive">
<table id="tPermissions" class="table table-hover table-border dataTable">
<thead>
<tr class="">
<th class="" rowspan="2">#</th>
<th class="text-center" rowspan="2"></th>
<th class="" rowspan="2">Nama Permission</th>
<th class="text-center" colspan="12">Menu Admin</th>
<th class="text-center" colspan="4">Menu Finance</th>
<th class="text-center" rowspan="2">Status</th>
</tr>
<tr>
{{-- menu admin --}}
<th class="">Menu Transaksi</th>
<th class="">Menu Perusahaan</th>
<th class="">Menu Zona</th>
<th class="">Menu Pengguna</th>
<th class="">Menu Konfigurasi Harga</th>
<th class="">Menu Konfigurasi Asuransi</th>
<th class="">Menu Konfigurasi Tipe Kendaraan</th>
<th class="">Menu Konfigurasi Master Devices</th>
<th class="">Menu Konfigurasi Daftar GPS</th>
<th class="">Menu Konfigurasi Additional Items</th>
<th class="">Menu Pengemudi</th>
<th class="">Menu Kendaraan</th>
{{-- menu finance --}}
<th class="">Menu Ledger Balance</th>
<th class="">Menu Pembayaran</th>
<th class="">Menu Penagihan</th>
<th class="">Menu Konfigurasi Additional Items</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
<div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlNewPermission" aria-labelledby="mdlNewPermissionLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlNewPermissionLabel">Tambah Permission Baru</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<form id="formNewPermission" method="POST">
{{-- Primary --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Primary</h6>
</div>
<div class="row">
<div class="col-sm-12 col-md-6">
<label for="add-name" class="col-form-label">Nama Permission<span class="text-danger">*</span></label>
<input type="text" name="add-name" id="add-name" class="form-control">
</div>
</div>
</div>
{{-- Menu Admin --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Menu Admin</h6>
</div>
<div class="row">
<div class="col-sm-12 col-md-6">
<label for="add-menu_trx" class="col-form-label">Menu Transaksi<span class="text-danger">*</span></label>
<select name="add-menu_trx" id="add-menu_trx" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_company" class="col-form-label">Menu Perusahaan<span class="text-danger">*</span></label>
<select name="add-menu_company" id="add-menu_company" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_zone" class="col-form-label">Menu Zona<span class="text-danger">*</span></label>
<select name="add-menu_zone" id="add-menu_zone" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_users" class="col-form-label">Menu Pengguna<span class="text-danger">*</span></label>
<select name="add-menu_users" id="add-menu_users" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_conf_rates" class="col-form-label">Menu Konfigurasi Harga<span class="text-danger">*</span></label>
<select name="add-menu_conf_rates" id="add-menu_conf_rates" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_conf_insurance" class="col-form-label">Menu Konfigurasi Asuransi<span class="text-danger">*</span></label>
<select name="add-menu_conf_insurance" id="add-menu_conf_insurance" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_conf_truck_type" class="col-form-label">Menu Konfigurasi Tipe Kendaraan<span class="text-danger">*</span></label>
<select name="add-menu_conf_truck_type" id="add-menu_conf_truck_type" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_devices" class="col-form-label">Menu Konfigurasi Master Devices<span class="text-danger">*</span></label>
<select name="add-menu_devices" id="add-menu_devices" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_logs_devices" class="col-form-label">Menu Konfigurasi Daftar GPS<span class="text-danger">*</span></label>
<select name="add-menu_logs_devices" id="add-menu_logs_devices" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_conf_adt_items" class="col-form-label">Menu Konfigurasi Additional Items<span class="text-danger">*</span></label>
<select name="add-menu_conf_adt_items" id="add-menu_conf_adt_items" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_drivers" class="col-form-label">Menu Pengemudi<span class="text-danger">*</span></label>
<select name="add-menu_drivers" id="add-menu_drivers" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_vehicles" class="col-form-label">Menu Kendaraan<span class="text-danger">*</span></label>
<select name="add-menu_vehicles" id="add-menu_vehicles" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
</div>
</div>
{{-- Menu Finance --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Menu Finance</h6>
</div>
<div class="row">
<div class="col-sm-12 col-md-6">
<label for="add-menu_fnc_ledger_balance" class="col-form-label">Menu Ledger Balance<span class="text-danger">*</span></label>
<select name="add-menu_fnc_ledger_balance" id="add-menu_fnc_ledger_balance" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_fnc_payment" class="col-form-label">Menu Pembayaran<span class="text-danger">*</span></label>
<select name="add-menu_fnc_payment" id="add-menu_fnc_payment" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_fnc_billing" class="col-form-label">Menu Penagihan<span class="text-danger">*</span></label>
<select name="add-menu_fnc_billing" id="add-menu_fnc_billing" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="add-menu_fnc_conf_adt_items" class="col-form-label">Menu Konfigurasi Additional Item<span class="text-danger">*</span></label>
<select name="add-menu_fnc_conf_adt_items" id="add-menu_fnc_conf_adt_items" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
</div>
</div>
{{-- Utilites --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Utilities</h6>
</div>
<div class="row">
<div class="col-sm-12 col-md-6">
<label for="add-status" class="form-label">Status<span class="text-danger">*</span></label>
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="add-status" name="add-status">
<label class="form-check-label" for="add-status"><span class="text-dark" id="add-txtStatus">Inactive</span></label>
</div>
</div>
</div>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Close</button>
<button id="btnSubmitNewPer" type="button" class="btn btn-sm btn-danger">Submit data</button>
</div>
</div>
</div>
</div>
<div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlUpdtPermission" aria-labelledby="mdlUpdtPermissionLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlUpdtPermissionLabel">Edit Item</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<form id="formUpdtPermission" method="PUT">
{{-- Primary --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Primary</h6>
</div>
<div class="row">
<div class="col-sm-12 col-md-6">
<label for="updt-name" class="col-form-label">Nama Permission<span class="text-danger">*</span></label>
<input type="text" name="updt-name" id="updt-name" class="form-control">
</div>
</div>
</div>
{{-- Menu Admin --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Menu Admin</h6>
</div>
<div class="row">
<div class="col-sm-12 col-md-6">
<label for="updt-menu_trx" class="col-form-label">Menu Transaksi<span class="text-danger">*</span></label>
<select name="updt-menu_trx" id="updt-menu_trx" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_company" class="col-form-label">Menu Perusahaan<span class="text-danger">*</span></label>
<select name="updt-menu_company" id="updt-menu_company" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_zone" class="col-form-label">Menu Zona<span class="text-danger">*</span></label>
<select name="updt-menu_zone" id="updt-menu_zone" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_users" class="col-form-label">Menu Pengguna<span class="text-danger">*</span></label>
<select name="updt-menu_users" id="updt-menu_users" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_conf_rates" class="col-form-label">Menu Konfigurasi Harga<span class="text-danger">*</span></label>
<select name="updt-menu_conf_rates" id="updt-menu_conf_rates" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_conf_insurance" class="col-form-label">Menu Konfigurasi Asuransi<span class="text-danger">*</span></label>
<select name="updt-menu_conf_insurance" id="updt-menu_conf_insurance" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_conf_truck_type" class="col-form-label">Menu Konfigurasi Tipe Kendaraan<span class="text-danger">*</span></label>
<select name="updt-menu_conf_truck_type" id="updt-menu_conf_truck_type" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_devices" class="col-form-label">Menu Konfigurasi Master Devices<span class="text-danger">*</span></label>
<select name="updt-menu_devices" id="updt-menu_devices" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_logs_devices" class="col-form-label">Menu Konfigurasi Daftar GPS<span class="text-danger">*</span></label>
<select name="updt-menu_logs_devices" id="updt-menu_logs_devices" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_conf_adt_items" class="col-form-label">Menu Konfigurasi Additional Items<span class="text-danger">*</span></label>
<select name="updt-menu_conf_adt_items" id="updt-menu_conf_adt_items" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_drivers" class="col-form-label">Menu Pengemudi<span class="text-danger">*</span></label>
<select name="updt-menu_drivers" id="updt-menu_drivers" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_vehicles" class="col-form-label">Menu Kendaraan<span class="text-danger">*</span></label>
<select name="updt-menu_vehicles" id="updt-menu_vehicles" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
</div>
</div>
{{-- Menu Finance --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Menu Finance</h6>
</div>
<div class="row">
<div class="col-sm-12 col-md-6">
<label for="updt-menu_fnc_ledger_balance" class="col-form-label">Menu Ledger Balance<span class="text-danger">*</span></label>
<select name="updt-menu_fnc_ledger_balance" id="updt-menu_fnc_ledger_balance" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_fnc_payment" class="col-form-label">Menu Pembayaran<span class="text-danger">*</span></label>
<select name="updt-menu_fnc_payment" id="updt-menu_fnc_payment" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_fnc_billing" class="col-form-label">Menu Penagihan<span class="text-danger">*</span></label>
<select name="updt-menu_fnc_billing" id="updt-menu_fnc_billing" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
<div class="col-sm-12 col-md-6">
<label for="updt-menu_fnc_conf_adt_items" class="col-form-label">Menu Konfigurasi Additional Item<span class="text-danger">*</span></label>
<select name="updt-menu_fnc_conf_adt_items" id="updt-menu_fnc_conf_adt_items" class="form-control" style="width:100%;">
<option value="{{ $no_permission }}">{{ $no_permission_text }}</option>
<option value="{{ $is_permission }}">{{ $is_permission_text }}</option>
</select>
</div>
</div>
</div>
{{-- Utilites --}}
<div class="mb-3">
<div class="border-bottom">
<h6>Utilities</h6>
</div>
<div class="row">
<div class="col-sm-12">
<label for="updt-status" class="form-label">Status<span class="text-danger">*</span></label>
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="updt-status" name="updt-status">
<label class="form-check-label" for="updt-status"><span class="text-dark" id="updt-txtStatus">Inactive</span></label>
</div>
</div>
</div>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" id="btnDelPer_updt" class="btn btn-sm btn-warning">Hapus ?</button>
<button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Close</button>
<button id="btnSubmitUpdtPer" type="button" class="btn btn-sm btn-danger">Ubah data</button>
</div>
</div>
</div>
</div>
<div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlDelPer" aria-labelledby="mdlDelPerLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-sm">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="mdlDelPerLabel">Delete Item</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<div class="d-flex justify-content-center">
<p class="mb-0">
Kamu yakin ingin menghapus item
<a href="#" class="text-danger">
<span id="del-name"></span>
</a>
?
</p>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-sm btn-danger" data-bs-dismiss="modal">Close</button>
<button id="btnSubmitDelPer" type="button" class="btn btn-sm btn-secondary">Iya, hapus</button>
</div>
</div>
</div>
</div>
@endsection
@section('customjs')
<script src="{{ asset('assets/js/load-image.all.min.js') }}"></script>
<script>
'use strict';
const State = {
file_jimp_worker: "{{ asset('assets/js/worker/jimp.js') }}",
storage_lara: "{{ asset('storage') }}/",
stts_isact: {
active: "{{ App\Models\UsersMenuPermissions::IS_ACTIVE }}",
inactive: "{{ App\Models\UsersMenuPermissions::IS_INACTIVE }}",
},
stts_permis: {
permis: "{{ App\Models\UsersMenuPermissions::IS_PERMISSION }}",
permis_text: "{{ $is_permission_text }}",
no_permis: "{{ App\Models\UsersMenuPermissions::IS_NOPERMISSION }}",
no_permis_text: "{{ $no_permission_text }}",
},
delay_typing_front: 1000,
};
const Wrapper = {
activate: function() {
Wrapper.event();
DTable.activate();
PerNew.activate();
PerUpdt.activate();
PerDel.activate();
},
event: function() {
$('#add-status').bind('change', function() {
if ($(this).is(':checked'))
$('#add-txtStatus').html('Active')
else
$('#add-txtStatus').html('Inactive')
});
$('#updt-status').bind('change', function() {
if ($(this).is(':checked'))
$('#updt-txtStatus').html('Active')
else
$('#updt-txtStatus').html('Inactive')
});
// fix modal select2
$('#add-type').select2({
dropdownParent: $('#mdlNewPermission'),
});
$('#updt-type').select2({
dropdownParent: $('#mdlUpdtPermission'),
});
},
};
const DTable = {
activate: function() {
DTable.reload();
},
reload: function() {
// $('#tPermissions').DataTable();
// if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
$('#tPermissions').DataTable({
processing: true,
serverSide: false,
bLengthChange: true,
deferRender: true,
destroy: true,
ajax: {
url: "{{ route('api_list_menu_permissions') }}",
type: 'GET',
complete: function(jqXHR, textStatus, c) {
let count = jqXHR.responseJSON.count;
if (typeof count != 'undefined') {
$('#count_users_menu_permissions').text(count);
}
// removeTableSkeletonLoading()
},
},
deferRender: true,
columns: [{
data: 'DT_RowIndex',
className: 'text-end',
visible: true,
orderable: true,
searchable: true,
},
{
data: 'action',
className: 'text-center',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
let action = `
<a href="#" class="text-decoration-none me-1 btnUpdtPer">
<span class="icon ion-edit fz-16"></span>
</a>
`;
// <a href="#" class="text-decoration-none text-danger btnDelPer">
// <span class="icon ion-trash-b fz-16"></span>
// </a>
return action;
}
},
{
data: 'name',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
createdCell: function(td, cellData, rowData, row, col) {
$(td).attr('data-id', rowData.id);
$(td).attr('data-name', rowData.name);
},
},
{
data: 'is_trx',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_trx == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_company',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_company == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_zone',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_zone == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_users',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_users == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_conf_rates',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_conf_rates == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_conf_insurance',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_conf_insurance == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_conf_truck_type',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_conf_truck_type == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_devices',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_devices == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_logs_devices',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_logs_devices == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_conf_adt_items',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_conf_adt_items == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_drivers',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_drivers == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_vehicles',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_vehicles == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_fnc_ledger_balance',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_fnc_ledger_balance == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_fnc_payment',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_fnc_payment == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_fnc_billing',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_fnc_billing == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_fnc_conf_adt_items',
className: 'text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (row.is_fnc_conf_adt_items == State.stts_permis.permis) {
return State.stts_permis.permis_text;
}
return State.stts_permis.no_permis_text;
},
},
{
data: 'is_active',
className: 'text-center text-nowrap',
visible: true,
orderable: true,
searchable: true,
render: function(data, type, row, meta) {
if (data == State.stts_isact.active) return '<span class="badge rounded-pill bg-success">Active</span>';
return '<span class="badge rounded-pill bg-danger">Inactive</span>';
}
},
],
});
},
};
const PerNew = {
activate: function() {
PerNew.event();
},
event: function() {
// modal
$('#btnMdlNewPermission').on('click', function() {
$('#mdlNewPermission').modal('show');
});
$('#mdlNewPermission').on('shown.bs.modal', function() {
});
// button
$('#btnSubmitNewPer').on('click', function() {
let data = PerNew.getData();
PerNew.submitData(data);
});
},
getData: function() {
let data = {};
$.map($('#formNewPermission').serializeArray(), function(n, i) {
let key = n['name'].replace('add-', '');
data[key] = n['value'];
});
if ($('#add-status').prop('checked')) {
data.status = State.stts_isact.active;
} else {
data.status = State.stts_isact.inactive;
}
return data;
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitNewPer').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitNewPer').attr('disabed', true);
$('#btnSubmitNewPer').addClass('d-none');
$.ajax({
url: "{{ route('api_add_menu_permissions') }}",
method: 'POST',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitNewPer').removeAttr('disabed');
$('#btnSubmitNewPer').removeClass('d-none');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success menambahkan permission baru');
$('#mdlNewPermission').modal('hide');
DTable.reload();
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitNewPer').removeAttr('disabed');
$('#btnSubmitNewPer').removeClass('d-none');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
}
const PerUpdt = {
activate: function() {
PerUpdt.event();
},
event: function() {
// modal
$('#tPermissions').on('click', '.btnUpdtPer', async function(e) {
let id = $(e.target).closest('tr').find('td[data-id]').data('id');
let resp = await PerUpdt.reqData({
id
});
if (resp.type != 'success') {
Helper.toast('Permission Not Found', 'just now', 'please try again');
return false;
}
PerUpdt.passDataToView(resp.data);
});
$('#mdlUpdtPermission').on('shown.bs.modal', function() {
});
// button
$('#btnSubmitUpdtPer').on('click', function() {
let data = PerUpdt.getData();
PerUpdt.submitData(data);
});
},
reqData: function(params) {
return new Promise((resolve, reject) => {
$.ajax({
url: "{{ route('api_show_menu_permissions', '') }}/" + params.id,
method: 'GET',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
},
data: params,
success: (data, textStatus, jqXHR) => {
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
resolve({
type: 'success',
data: data.data
});
},
error: (jqXHR, textStatus, error) => {
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
});
},
passDataToView: async function(data) {
$('#updt-name').val(data.name);
$('#updt-menu_company').val(data.is_company).trigger('change');
$('#updt-menu_conf_adt_items').val(data.is_conf_adt_items).trigger('change');
$('#updt-menu_conf_insurance').val(data.is_conf_insurance).trigger('change');
$('#updt-menu_conf_rates').val(data.is_conf_rates).trigger('change');
$('#updt-menu_conf_truck_type').val(data.is_conf_truck_type).trigger('change');
$('#updt-menu_devices').val(data.is_devices).trigger('change');
$('#updt-menu_drivers').val(data.is_drivers).trigger('change');
$('#updt-menu_logs_devices').val(data.is_logs_devices).trigger('change');
$('#updt-menu_trx').val(data.is_trx).trigger('change');
$('#updt-menu_users').val(data.is_users).trigger('change');
$('#updt-menu_vehicles').val(data.is_vehicles).trigger('change');
$('#updt-menu_zone').val(data.is_zone).trigger('change');
if (data.is_active == State.stts_isact.active) {
$('#updt-status').prop('checked', true).trigger('change');
} else {
$('#updt-status').prop('checked', false).trigger('change');
}
$('#mdlUpdtPermission').data('id', data.id);
$('#mdlUpdtPermission').modal('show');
},
getData: function() {
let data = {};
data.id = $('#mdlUpdtPermission').data('id');
$.map($('#formUpdtPermission').serializeArray(), function(n, i) {
let key = n['name'].replace('updt-', '');
data[key] = n['value'];
});
if ($('#updt-status').prop('checked')) {
data.status = State.stts_isact.active;
} else {
data.status = State.stts_isact.inactive;
}
return data;
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitUpdtPer').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitUpdtPer').attr('disabed', true);
$('#btnSubmitUpdtPer').addClass('d-none');
$.ajax({
url: "{{ route('api_updt_menu_permissions', '') }}/" + data.id,
method: 'PUT',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitUpdtPer').removeAttr('disabed');
$('#btnSubmitUpdtPer').removeClass('d-none');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success update permissions');
$('#mdlUpdtPermission').modal('hide');
DTable.reload();
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitUpdtPer').removeAttr('disabed');
$('#btnSubmitUpdtPer').removeClass('d-none');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
}
const PerDel = {
activate: function() {
PerDel.event();
},
event: function() {
// on table
$('#tPermissions').on('click', '.btnDelPer', function(e) {
let row = $(e.target).closest('tr');
let id = row.find('td[data-id]').data('id');
let name = row.find('td[data-name]').data('name');
PerDel.passDataToView({
id,
name,
});
$('#mdlDelPer').data('id', id);
$('#mdlDelPer').modal('show');
});
$('#btnSubmitDelPer').on('click', function() {
let data = {
id: $('#mdlDelPer').data('id'),
};
PerDel.submitData(data);
});
// on modal update
$('#btnDelPer_updt').on('click', function(e) {
const {
id,
name
} = PerUpdt.getData();
PerDel.passDataToView({
id,
name,
});
$('#mdlDelPer').data('id', id);
$('#mdlDelPer').modal('show');
});
},
passDataToView: function(data) {
$('#del-name').text(data.name);
$('#del-price').text(data.price);
},
submitData: async function(data) {
return new Promise((resolve, reject) => {
if (typeof $('#btnSubmitDelPer').attr('disabed') != 'undefined') {
resolve({
type: 'fail'
});
return false;
}
$('#btnSubmitDelPer').attr('disabed', true);
$.ajax({
url: "{{ route('api_del_menu_permissions', '') }}/" + data.id,
method: 'DELETE',
crossDomain: true,
processData: true,
headers: {
'x-api-key': Helper.getCookie('_trtk'),
'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
},
data: data,
success: (data, textStatus, jqXHR) => {
$('#btnSubmitDelPer').removeAttr('disabed');
if (data.meta.type != 'success') {
resolve({
type: 'fail'
});
Helper.toast('Warning', 'just now', data.meta.message);
return false;
}
Helper.toast('Success', 'just now', 'success delete permission');
$('#mdlDelPer').modal('hide');
$('#mdlUpdtPermission').modal('hide');
DTable.reload();
resolve({
type: 'success'
});
},
error: (jqXHR, textStatus, error) => {
$('#btnSubmitDelPer').removeAttr('disabed');
if (jqXHR.status >= 500) {
Helper.toast('Error', 'just now', 'Please try again');
} else {
Helper.toast('Error', 'just now', jqXHR.responseJSON.meta
.message);
}
resolve({
type: 'error'
});
}
})
})
},
}
Wrapper.activate();
</script>
@endsection