1575 lines
		
	
	
		
			78 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			1575 lines
		
	
	
		
			78 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| @extends('app.app')
 | |
| 
 | |
| @section('title')
 | |
|     Publish Pocket & Duration
 | |
| @endsection
 | |
| 
 | |
| @section('customcss')
 | |
|     <style>
 | |
|         /* .select2-container {
 | |
|             z-index: 99999;
 | |
|         } */
 | |
| 
 | |
|     </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">Uang Saku (<span id="count_pocket">0</span>)</p>
 | |
|                         </div>
 | |
|                         <div class="col text-end">
 | |
|                             <button id="btnMdlNewPocket" class="btn btn-sm btn-danger">Tambah Uang Saku</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="tPocket" class="table table-hover dataTable">
 | |
|                             <thead>
 | |
|                                 <tr class="">
 | |
|                                     <th class="">#</th>
 | |
|                                     <th class="text-center">Action</th>
 | |
|                                     {{-- <th class="text-end">Code</th> --}}
 | |
|                                     <th class="">Nama</th>
 | |
|                                     <th class="">Pickup</th>
 | |
|                                     {{-- <th class="">Drop</th> --}}
 | |
|                                     <th class="">Type</th>
 | |
|                                     {{-- <th class="">Flow</th> --}}
 | |
|                                     <th class="text-center">Status</th>
 | |
|                                 </tr>
 | |
|                             </thead>
 | |
|                             <tbody>
 | |
| 
 | |
|                             </tbody>
 | |
|                         </table>
 | |
|                     </div>
 | |
|                 </div>
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlNewPocket"
 | |
|         aria-labelledby="mdlNewPocketLabel" aria-hidden="true">
 | |
|         <div class="modal-dialog modal-dialog modal-dialog-centered modal-dialog-scrollable modal-xl">
 | |
|             <div class="modal-content">
 | |
|                 <div class="modal-header">
 | |
|                     <h5 class="modal-title" id="mdlNewPocketLabel">Tambah Uang Saku</h5>
 | |
|                     <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
 | |
|                 </div>
 | |
|                 <div class="modal-body">
 | |
|                     <form id="formAdd">
 | |
|                         <div class="mb-3">
 | |
|                             {{-- <div class="border-bottom">
 | |
|                                 <h6>Uang Saku</h6>
 | |
|                             </div> --}}
 | |
|                             <div class="row">
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <label for="add_name" class="col-form-label">Nama<span class="text-danger">*</span></label>
 | |
|                                     <input type="text" name="add_name" id="add_name" class="form-control" placeholder="FREE_E-TOL02">
 | |
|                                 </div>
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <label for="add_type" class="col-form-label">Type<span class="text-danger">*</span></label>
 | |
|                                     <select name="add_type" id="add_type" class="form-control" style="width:100%;">
 | |
|                                         {{-- <option value="">Pilih Type</option> --}}
 | |
|                                         @foreach ($types as $type)
 | |
|                                             <option value="{{ $type->id }}">{{ $type->name }}</option>
 | |
|                                         @endforeach
 | |
|                                     </select>  
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                             <div class="row">
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <div class="row">
 | |
|                                         <div class="col-12 mb-1">
 | |
|                                             <label for="add_pck" class="col-form-label">Pickup<span class="text-danger">*</span></label>
 | |
|                                             <select name="add_pck" id="add_pck"
 | |
|                                                 class="form-control" style="width:100%;">
 | |
|                                                 <option value="">Lokasi Pickup</option>
 | |
|                                                 {{-- @foreach ($pickups as $pck)
 | |
|                                                     <option value="{{ $pck->id }}" data-name="{{ $pck->name }}" data-fulladdress="{{ $pck->fulladdress }}">{{ $pck->name }}</option>
 | |
|                                                 @endforeach --}}
 | |
|                                             </select>
 | |
|                                             <p id="add_pck_location" class="mb-0"> </p>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <div class="row">
 | |
|                                         <div class="col-12 mb-1">
 | |
|                                             <label for="add_drop" class="col-form-label">Drop<span class="text-danger">*</span></label>
 | |
|                                             <select name="add_drop" id="add_drop" class="form-control" style="width:100%;">
 | |
|                                                 <option value="">Lokasi Drop</option>
 | |
|                                                 {{-- @foreach ($drops as $drop)
 | |
|                                                     <option value="{{ $drop->id }}" data-name="{{ $drop->name }}" data-fulladdress="{{ $drop->fulladdress }}">{{ $drop->name }}</option>
 | |
|                                                 @endforeach --}}
 | |
|                                             </select>
 | |
|                                             <p id="add_drop_location" class="mb-0"> </p>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                                 <div class="col-sm-6 col-md-4 groupAddPrice">
 | |
|                                     <label for="add_price" class="col-form-label">Harga (Rp)<span class="text-danger">*</span></label>
 | |
|                                     <input type="text" name="add_price" id="add_price" class="form-control" value="0">
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                         </div>
 | |
|                         {{-- Checkpoint --}}
 | |
|                         <div class="mb-3 groupAddCheckpoint">
 | |
|                             <div class="border-bottom">
 | |
|                                 <div class="row">
 | |
|                                     <div class="col-11">
 | |
|                                         <h6>Checkpoints</h6>
 | |
|                                     </div>
 | |
|                                     <div class="col-1 text-start">
 | |
|                                         <button id="point-add-row" type="button" class="btn btn-sm btn-danger">
 | |
|                                             <span class="ion-plus"></span>
 | |
|                                         </button>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                             <div id="divAddCheckpoint">
 | |
|                                 <div id="divRowAddCheckpoint${nextIdx}" class="row divRowAddCheckpoint" data-idx="${nextIdx}">
 | |
|                                     <div class="col-sm-6 col-md-6">
 | |
|                                         <div class="row">
 | |
|                                             <div class="col-12 mb-1">
 | |
|                                                 <label for="add_start_checkpoints[]" class="col-form-label">Titik Lokasi<span class="text-danger">*</span></label>
 | |
|                                                 <select name="add_start_checkpoints[]" class="form-control" style="width:100%;" data-idx="${nextIdx}">
 | |
|                                                     <option value="">Pilih Checkpoint</option>
 | |
|                                                     ${pck_checkpoints}
 | |
|                                                 </select>
 | |
|                                                 <p class="add_pck_location_checkpoints mb-0"> </p>
 | |
|                                             </div>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                     {{-- <div class="col-sm-6 col-md-4">
 | |
|                                         <div class="row">
 | |
|                                             <div class="col-12 mb-1">
 | |
|                                                 <label for="add_end_checkpoints[]" class="col-form-label">Titik Akhir<span class="text-danger">*</span></label>
 | |
|                                                 <select name="add_end_checkpoints[]" class="form-control" style="width:100%;" data-idx="${nextIdx}">
 | |
|                                                     <option value="">Pilih Checkpoint</option>
 | |
|                                                     ${drop_checkpoints}
 | |
|                                                 </select>
 | |
|                                                 <p class="add_drop_location_checkpoints mb-0"> </p>
 | |
|                                             </div>
 | |
|                                         </div>
 | |
|                                     </div> --}}
 | |
|                                     <div class="col-sm-6 col-md-3">
 | |
|                                         <label for="add_price_checkpoints[]" class="col-form-label">Harga (Rp)<span class="text-danger">*</span></label>
 | |
|                                         <input type="text" name="add_price_checkpoints[]" class="form-control" value="0">
 | |
|                                     </div>
 | |
|                                     <div class="col-sm-6 col-md-1 text-center d-flex align-items-center">
 | |
|                                         <button type="button" class="btn btn-sm btn-secondary point-minus">
 | |
|                                             <span class="ion-minus"></span>
 | |
|                                         </button>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                         </div>
 | |
|                         {{-- Utilites --}}
 | |
|                         <div class="mb-3">
 | |
|                             <div class="border-bottom">
 | |
|                                 <h6>Utilities</h6>
 | |
|                             </div>
 | |
|                             <div class="row">
 | |
|                                 <div class="col-sm-6 col-md-3">
 | |
|                                     <label for="add_status" class="form-label">Status</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="btnSubmitNewPocket" 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="mdlEdtPocket"
 | |
|         aria-labelledby="mdlEdtPocketLabel" aria-hidden="true">
 | |
|         <div class="modal-dialog modal-dialog modal-dialog-centered modal-dialog-scrollable modal-xl">
 | |
|             <div class="modal-content">
 | |
|                 <div class="modal-header">
 | |
|                     <h5 class="modal-title" id="mdlEdtPocketLabel">Edit Pocket</h5>
 | |
|                     <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
 | |
|                 </div>
 | |
|                 <div class="modal-body">
 | |
|                     <form id="formUpdt">
 | |
|                         <div class="mb-3">
 | |
|                             {{-- <div class="border-bottom">
 | |
|                                 <h6>Uang Saku</h6>
 | |
|                             </div> --}}
 | |
|                             <div class="row">
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <label for="updt_name" class="col-form-label">Nama<span class="text-danger">*</span></label>
 | |
|                                     <input type="text" name="updt_name" id="updt_name" class="form-control" placeholder="FREE_E-TOL02">
 | |
|                                 </div>
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <label for="updt_type" class="col-form-label">Type<span class="text-danger">*</span></label>
 | |
|                                     <select name="updt_type" id="updt_type" class="form-control" style="width:100%;">
 | |
|                                         {{-- <option value="">Pilih Type</option> --}}
 | |
|                                         @foreach ($types as $type)
 | |
|                                             <option value="{{ $type->id }}">{{ $type->name }}</option>
 | |
|                                         @endforeach
 | |
|                                     </select>  
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                             <div class="row">
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <div class="row">
 | |
|                                         <div class="col-12 mb-1">
 | |
|                                             <label for="updt_pck" class="col-form-label">Pickup<span class="text-danger">*</span></label>
 | |
|                                             <select name="updt_pck" id="updt_pck"
 | |
|                                                 class="form-control" style="width:100%;">
 | |
|                                                 <option value="">Lokasi Pickup</option>
 | |
|                                                 {{-- @foreach ($pickups as $pck)
 | |
|                                                     <option value="{{ $pck->id }}" data-name="{{ $pck->name }}" data-fulladdress="{{ $pck->fulladdress }}">{{ $pck->name }}</option>
 | |
|                                                 @endforeach --}}
 | |
|                                             </select>
 | |
|                                             <p id="updt_pck_location" class="mb-0"> </p>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                                 <div class="col-sm-6 col-md-4">
 | |
|                                     <div class="row">
 | |
|                                         <div class="col-12 mb-1">
 | |
|                                             <label for="updt_drop" class="col-form-label">Drop<span class="text-danger">*</span></label>
 | |
|                                             <select name="updt_drop" id="updt_drop" class="form-control" style="width:100%;">
 | |
|                                                 <option value="">Lokasi Drop</option>
 | |
|                                                 {{-- @foreach ($drops as $drop)
 | |
|                                                     <option value="{{ $drop->id }}" data-name="{{ $drop->name }}" data-fulladdress="{{ $drop->fulladdress }}">{{ $drop->name }}</option>
 | |
|                                                 @endforeach --}}
 | |
|                                             </select>
 | |
|                                             <p id="updt_drop_location" class="mb-0"> </p>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                                 <div class="col-sm-6 col-md-3 groupUpdtPrice">
 | |
|                                     <label for="updt_price" class="col-form-label">Harga (Rp)<span class="text-danger">*</span></label>
 | |
|                                     <input type="text" name="updt_price" id="updt_price" class="form-control" value="0">
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                         </div>
 | |
|                         {{-- Checkpoint --}}
 | |
|                         <div class="mb-3 groupUpdtCheckpoint">
 | |
|                             <div class="border-bottom">
 | |
|                                 <div class="row">
 | |
|                                     <div class="col-11">
 | |
|                                         <h6>Checkpoints</h6>
 | |
|                                     </div>
 | |
|                                     <div class="col-1 text-start">
 | |
|                                         <button id="updt-point-add-row" type="button" class="btn btn-sm btn-danger">
 | |
|                                             <span class="ion-plus"></span>
 | |
|                                         </button>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                             <div id="divUpdtCheckpoint">
 | |
|                                 <div id="divRowUpdtCheckpoint${nextIdx}" class="row divRowUpdtCheckpoint" data-idx="${nextIdx}">
 | |
|                                     <div class="col-sm-6 col-md-6">
 | |
|                                         <div class="row">
 | |
|                                             <div class="col-12 mb-1">
 | |
|                                                 <label for="updt_start_checkpoints[]" class="col-form-label">Titik Lokasi<span class="text-danger">*</span></label>
 | |
|                                                 <select name="updt_start_checkpoints[]" class="form-control" style="width:100%;" data-idx="${nextIdx}">
 | |
|                                                     <option value="">Pilih Checkpoint</option>
 | |
|                                                     ${pck_checkpoints}
 | |
|                                                 </select>
 | |
|                                                 <p class="updt_pck_location_checkpoints mb-0"> </p>
 | |
|                                             </div>
 | |
|                                         </div>
 | |
|                                     </div>
 | |
|                                     {{-- <div class="col-sm-6 col-md-4">
 | |
|                                         <div class="row">
 | |
|                                             <div class="col-12 mb-1">
 | |
|                                                 <label for="updt_end_checkpoints[]" class="col-form-label">Titik Akhir<span class="text-danger">*</span></label>
 | |
|                                                 <select name="updt_end_checkpoints[]" class="form-control" style="width:100%;" data-idx="${nextIdx}">
 | |
|                                                     <option value="">Pilih Checkpoint</option>
 | |
|                                                     ${drop_checkpoints}
 | |
|                                                 </select>
 | |
|                                                 <p class="updt_drop_location_checkpoints mb-0"> </p>
 | |
|                                             </div>
 | |
|                                         </div>
 | |
|                                     </div> --}}
 | |
|                                     <div class="col-sm-6 col-md-5">
 | |
|                                         <label for="updt_price_checkpoints[]" class="col-form-label">Harga (Rp)<span class="text-danger">*</span></label>
 | |
|                                         <input type="text" name="updt_price_checkpoints[]" class="form-control" value="0">
 | |
|                                     </div>
 | |
|                                     <div class="col-sm-6 col-md-1 text-center d-flex align-items-center">
 | |
|                                         <button type="button" class="btn btn-sm btn-secondary updt-point-minus">
 | |
|                                             <span class="ion-minus"></span>
 | |
|                                         </button>
 | |
|                                     </div>
 | |
|                                 </div>
 | |
|                             </div>
 | |
|                         </div>
 | |
|                         {{-- Utilites --}}
 | |
|                         <div class="mb-3">
 | |
|                             <div class="border-bottom">
 | |
|                                 <h6>Utilities</h6>
 | |
|                             </div>
 | |
|                             <div class="row">
 | |
|                                 <div class="col-sm-6 col-md-3">
 | |
|                                     <label for="updt_status" class="form-label">Status</label>
 | |
|                                     <div class="form-check form-switch">
 | |
|                                         <input class="form-check-input" type="checkbox" id="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="btnDelPocket_updt" class="btn btn-sm btn-warning">Delete ?</button>
 | |
|                     <button type="button" class="btn btn-sm btn-secondary" data-bs-dismiss="modal">Close</button>
 | |
|                     <button id="btnSubmitEdtPocket" type="button" class="btn btn-sm btn-danger">Update data</button>
 | |
|                 </div>
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="modal fade" data-bs-backdrop="static" data-bs-keyboard="false" id="mdlDelPocket"
 | |
|         aria-labelledby="mdlDelPocketLabel" 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="mdlDelPocketLabel">Delete Pocket</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">
 | |
|                             Are you sure want to delete this pocket
 | |
|                             <a href="#" class="text-danger">
 | |
|                                 <span id="del-pck_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="btnSubmitDelPocket" type="button" class="btn btn-sm btn-secondary">Yes, delete</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') }}/",
 | |
|             is_active: {
 | |
|                 active: "{{ App\Models\PocketMoney::IS_ACTIVE }}",
 | |
|                 inactive: "{{ App\Models\PocketMoney::IS_INACTIVE }}",
 | |
|             },
 | |
|             pocket_type: {
 | |
|                 bundle: "{{ App\Models\PocketMoney::TYPE_BUNDLE }}",
 | |
|                 bundle_text: "{{ App\Models\PocketMoney::TYPE_BUNDLE_TEXT }}",
 | |
|                 checkpoints: "{{ App\Models\PocketMoney::TYPE_CHECKPOINTS }}",
 | |
|                 checkpoints_text: "{{ App\Models\PocketMoney::TYPE_CHECKPOINTS_TEXT }}",
 | |
|             },
 | |
|             pocket_flow: {
 | |
|                 departure: "{{ App\Models\PocketMoney::FLOW_DEPARTURE }}",
 | |
|                 departure_text: "{{ App\Models\PocketMoney::FLOW_DEPARTURE_TEXT }}",
 | |
|                 arrival: "{{ App\Models\PocketMoney::FLOW_ARRIVAL }}",
 | |
|                 arrival_text: "{{ App\Models\PocketMoney::FLOW_ARRIVAL_TEXT }}",
 | |
|                 hybrid: "{{ App\Models\PocketMoney::FLOW_HYBRID }}",
 | |
|                 hybrid_text: "{{ App\Models\PocketMoney::FLOW_HYBRID_TEXT }}",
 | |
|             },
 | |
|             workflow_type: {
 | |
|                 pickup: "{{ App\Models\Zone::ZONE_WORKFLOW_PICKUP }}",
 | |
|                 drop: "{{ App\Models\Zone::ZONE_WORKFLOW_DEST }}",
 | |
|             },
 | |
|             l_pickups: [],
 | |
|             l_drops: [],
 | |
|             pck_checkpoints: [],
 | |
|             drop_checkpoints: [],
 | |
|             delay_typing_front: 1000,
 | |
|         };
 | |
| 
 | |
|         const Wrapper = {
 | |
|             activate: function() {
 | |
|                 Wrapper.event();
 | |
|                 DTable.activate();
 | |
|                 PNew.activate();
 | |
|                 PNewCheckpoint.activate();
 | |
|                 PUpdt.activate();
 | |
|                 PUpdtCheckpoint.activate();
 | |
|                 PDel.activate();
 | |
|                 Filter.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')
 | |
|                 });
 | |
| 
 | |
|                 $('#add_pck').select2({
 | |
|                     dropdownParent: $('#mdlNewPocket'),
 | |
|                 });
 | |
|                 $('#add_drop').select2({
 | |
|                     dropdownParent: $('#mdlNewPocket'),
 | |
|                 });
 | |
|                 $('#add_type').select2({
 | |
|                     dropdownParent: $('#mdlNewPocket'),
 | |
|                 });
 | |
| 
 | |
|                 $('#updt_pck').select2({
 | |
|                     dropdownParent: $('#mdlEdtPocket'),
 | |
|                 });
 | |
|                 $('#updt_drop').select2({
 | |
|                     dropdownParent: $('#mdlEdtPocket'),
 | |
|                 });
 | |
|                 $('#updt_type').select2({
 | |
|                     dropdownParent: $('#mdlEdtPocket'),
 | |
|                 });
 | |
|             },
 | |
|         };
 | |
| 
 | |
|         const Req = {
 | |
|             list_city: function(data, isAlert = false, cb = null) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_region_list_city') }}",
 | |
|                         method: 'GET',
 | |
|                         crossDomain: true,
 | |
|                         processData: true,
 | |
|                         headers: {
 | |
|                             'x-api-key': Helper.getCookie('_trtk'),
 | |
|                             'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
 | |
|                         },
 | |
|                         data: data,
 | |
|                         success: (resp, textStatus, jqXHR) => {
 | |
|                             if (cb) cb(resp);
 | |
|                             if (resp.meta.type != 'success') {
 | |
|                                 resolve({
 | |
|                                     type: 'fail',
 | |
|                                     msg: resp.meta.message,
 | |
|                                 });
 | |
|                                 if (isAlert) Helper.toast('Warning', 'just now', resp.meta
 | |
|                                     .message);
 | |
|                                 return false;
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'success',
 | |
|                                 resp: resp,
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             if (cb) cb(jqXHR.responseJSON);
 | |
|                             if (jqXHR.status >= 500) {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now',
 | |
|                                     'please try again');
 | |
|                             } else {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now', jqXHR
 | |
|                                     .responseJSON.meta.message);
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'error',
 | |
|                                 msg: jqXHR.responseJSON.meta.message,
 | |
|                             });
 | |
|                         }
 | |
|                     })
 | |
|                 })
 | |
|             },
 | |
|             list_district: function(data, isAlert = false, cb = null) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_region_list_district') }}",
 | |
|                         method: 'GET',
 | |
|                         crossDomain: true,
 | |
|                         processData: true,
 | |
|                         headers: {
 | |
|                             'x-api-key': Helper.getCookie('_trtk'),
 | |
|                             'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
 | |
|                         },
 | |
|                         data: data,
 | |
|                         success: (resp, textStatus, jqXHR) => {
 | |
|                             if (cb) cb(resp);
 | |
|                             if (resp.meta.type != 'success') {
 | |
|                                 resolve({
 | |
|                                     type: 'fail',
 | |
|                                     msg: resp.meta.message,
 | |
|                                 });
 | |
|                                 if (isAlert) Helper.toast('Warning', 'just now', resp.meta
 | |
|                                     .message);
 | |
|                                 return false;
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'success',
 | |
|                                 resp: resp,
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             if (cb) cb(jqXHR.responseJSON);
 | |
|                             if (jqXHR.status >= 500) {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now',
 | |
|                                     'please try again');
 | |
|                             } else {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now', jqXHR
 | |
|                                     .responseJSON.meta.message);
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'error',
 | |
|                                 msg: jqXHR.responseJSON.meta.message,
 | |
|                             });
 | |
|                         }
 | |
|                     })
 | |
|                 })
 | |
|             },
 | |
|             list_village: function(data, isAlert = false, cb = null) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_region_list_village') }}",
 | |
|                         method: 'GET',
 | |
|                         crossDomain: true,
 | |
|                         processData: true,
 | |
|                         headers: {
 | |
|                             'x-api-key': Helper.getCookie('_trtk'),
 | |
|                             'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
 | |
|                         },
 | |
|                         data: data,
 | |
|                         success: (resp, textStatus, jqXHR) => {
 | |
|                             if (cb) cb(resp);
 | |
|                             if (resp.meta.type != 'success') {
 | |
|                                 resolve({
 | |
|                                     type: 'fail',
 | |
|                                     msg: resp.meta.message,
 | |
|                                 });
 | |
|                                 if (isAlert) Helper.toast('Warning', 'just now', resp.meta
 | |
|                                     .message);
 | |
|                                 return false;
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'success',
 | |
|                                 resp: resp,
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             if (cb) cb(jqXHR.responseJSON);
 | |
|                             if (jqXHR.status >= 500) {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now',
 | |
|                                     'please try again');
 | |
|                             } else {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now', jqXHR
 | |
|                                     .responseJSON.meta.message);
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'error',
 | |
|                                 msg: jqXHR.responseJSON.meta.message,
 | |
|                             });
 | |
|                         }
 | |
|                     })
 | |
|                 })
 | |
|             },
 | |
|             list_client_zone: function(data, isAlert = false, cb = null) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_list_client_zones') }}",
 | |
|                         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: (resp, textStatus, jqXHR) => {
 | |
|                             if (cb) cb(resp);
 | |
|                             if (resp.meta.type != 'success') {
 | |
|                                 resolve({
 | |
|                                     type: 'fail',
 | |
|                                     msg: resp.meta.message,
 | |
|                                 });
 | |
|                                 if (isAlert) Helper.toast('Warning', 'just now', resp.meta
 | |
|                                     .message);
 | |
|                                 return false;
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'success',
 | |
|                                 resp: resp,
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             if (cb) cb(jqXHR.responseJSON);
 | |
|                             if (jqXHR.status >= 500) {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now',
 | |
|                                     'please try again');
 | |
|                             } else {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now', jqXHR
 | |
|                                     .responseJSON.meta.message);
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'error',
 | |
|                                 msg: jqXHR.responseJSON.meta.message,
 | |
|                             });
 | |
|                         }
 | |
|                     })
 | |
|                 })
 | |
|             },
 | |
|             list_checkpoints: function(data, isAlert = false, cb = null) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_list_checkpoints') }}",
 | |
|                         method: 'GET',
 | |
|                         crossDomain: true,
 | |
|                         processData: true,
 | |
|                         headers: {
 | |
|                             'x-api-key': Helper.getCookie('_trtk'),
 | |
|                             'x-csrf-token': $('meta[name="csrf-token"]').attr('content'),
 | |
|                         },
 | |
|                         data: data,
 | |
|                         success: (resp, textStatus, jqXHR) => {
 | |
|                             if (cb) cb(resp);
 | |
|                             if (resp.meta.type != 'success') {
 | |
|                                 resolve({
 | |
|                                     type: 'fail',
 | |
|                                     msg: resp.meta.message,
 | |
|                                 });
 | |
|                                 if (isAlert) Helper.toast('Warning', 'just now', resp.meta
 | |
|                                     .message);
 | |
|                                 return false;
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'success',
 | |
|                                 resp: resp,
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             if (cb) cb(jqXHR.responseJSON);
 | |
|                             if (jqXHR.status >= 500) {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now',
 | |
|                                     'please try again');
 | |
|                             } else {
 | |
|                                 if (isAlert) Helper.toast('Error', 'just now', jqXHR
 | |
|                                     .responseJSON.meta.message);
 | |
|                             }
 | |
|                             resolve({
 | |
|                                 type: 'error',
 | |
|                                 msg: jqXHR.responseJSON.meta.message,
 | |
|                             });
 | |
|                         }
 | |
|                     })
 | |
|                 })
 | |
|             },
 | |
|         }
 | |
| 
 | |
|         const Filter = {
 | |
|             activate: function() {
 | |
|                 Filter.event();
 | |
|                 Filter.zones();
 | |
|             },
 | |
|             event: function() {
 | |
|             },
 | |
|             triggerFilterCompany: function() {
 | |
|                 DTable.reload();
 | |
|                 Filter.zones();
 | |
|             },
 | |
|             zones: async function() {
 | |
|                 State.l_pickups = [];
 | |
|                 State.l_drops = [];
 | |
|                 State.pck_checkpoints = [];
 | |
|                 State.drop_checkpoints = [];
 | |
|                 PNew.reDataZone();
 | |
|                 PUpdt.reDataZone();
 | |
| 
 | |
|                 let cptid = (AppState.current_company == 0) ? undefined : AppState.current_company;
 | |
|                 const respPickups = await Req.list_client_zone({cptid, workflow_type: State.workflow_type.pickup}, false, null);
 | |
|                 if (respPickups.type !== 'success') {
 | |
|                     Helper.toast('Warning', 'just now', 'Client belum mempunyai zona pickup');
 | |
|                     return false;
 | |
|                 }
 | |
|                 State.l_pickups = respPickups.resp.data;
 | |
|                 const respDrops = await Req.list_client_zone({cptid, workflow_type: State.workflow_type.drop}, false, null);
 | |
|                 if (respDrops.type !== 'success') {
 | |
|                     Helper.toast('Warning', 'just now', 'Client belum mempunyai zona drop');
 | |
|                     return false;
 | |
|                 }
 | |
|                 State.l_drops = respDrops.resp.data;
 | |
|                 PNew.reDataZone();
 | |
|                 PUpdt.reDataZone();
 | |
| 
 | |
|                 const pckCheckpoints = await Req.list_checkpoints({}, true, null);
 | |
|                 if (pckCheckpoints.type === 'success') {
 | |
|                     State.pck_checkpoints = pckCheckpoints.resp.data;
 | |
|                     State.drop_checkpoints = pckCheckpoints.resp.data;
 | |
|                 }
 | |
|                 // const dropCheckpoints = await Req.list_checkpoints({}, true, null);
 | |
|                 // if (dropCheckpoints.type === 'success') {
 | |
|                 //     State.drop_checkpoints = dropCheckpoints.resp.data;
 | |
|                 // }
 | |
|             },
 | |
|         }
 | |
| 
 | |
|         const DTable = {
 | |
|             activate: function() {
 | |
|                 DTable.reload();
 | |
|             },
 | |
|             reload: function() {
 | |
|                 // $('#tPocket').DataTable();
 | |
|                 // if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
 | |
|                 $('#tPocket').DataTable({
 | |
|                     processing: true,
 | |
|                     serverSide: false,
 | |
|                     bLengthChange: true,
 | |
|                     deferRender: true,
 | |
|                     destroy: true,
 | |
|                     ajax: {
 | |
|                         url: "{{ route('api_list_pockets') }}?cptid="+AppState.current_company,
 | |
|                         type: 'GET',
 | |
|                         complete: function(jqXHR, textStatus, c) {
 | |
|                             let count = jqXHR.responseJSON.count;
 | |
|                             if (typeof count != 'undefined') {
 | |
|                                 $('#count_pocket').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,
 | |
|                             createdCell: function(td, cellData, rowData, row, col) {
 | |
|                                 $(td).attr('data-id', rowData.id);
 | |
|                                 // $(td).attr('data-code', rowData.code);
 | |
|                                 $(td).attr('data-pck_name', rowData.pck_name);
 | |
|                                 $(td).attr('data-pck_fulladdress', rowData.pck_fulladdress);
 | |
|                                 // $(td).attr('data-drop_name', rowData.drp_name);
 | |
|                                 // $(td).attr('data-drop_fulladdress', rowData.drop_fulladdress);
 | |
|                             },
 | |
|                             render: function(data, type, row, meta) {
 | |
|                                 let action = `
 | |
| 									<a href="#" class="text-decoration-none me-1 btnUpdtPocket">
 | |
| 										<span class="icon ion-edit fz-16"></span>
 | |
| 									</a>
 | |
| 								`;
 | |
|                                 // <a href="#" class="text-decoration-none text-danger btnDelPocket">
 | |
|                                 //     <span class="icon ion-trash-b fz-16"></span>
 | |
|                                 // </a>
 | |
|                                 return action;
 | |
|                             }
 | |
|                         },
 | |
|                         // {
 | |
|                         //     data: 'code',
 | |
|                         //     className: 'text-end text-nowrap',
 | |
|                         //     visible: true,
 | |
|                         //     orderable: true,
 | |
|                         //     searchable: true,
 | |
|                         // },
 | |
|                         {
 | |
|                             data: 'name',
 | |
|                             className: 'text-start text-wrap',
 | |
|                             visible: true,
 | |
|                             orderable: true,
 | |
|                             searchable: true,
 | |
|                         },
 | |
| 						{
 | |
|                             data: 'pck_name',
 | |
|                             className: 'text-start text-wrap',
 | |
|                             visible: true,
 | |
|                             orderable: true,
 | |
|                             searchable: true,
 | |
|                             render: function(data, type, row, meta) {
 | |
|                                 if (data) {
 | |
|                                     return data + '<br>' + row.pck_fulladdress;
 | |
|                                 }
 | |
|                                 return '-';
 | |
|                             }
 | |
|                         },
 | |
|                         // {
 | |
|                         //     data: 'drop_name',
 | |
|                         //     className: 'text-start text-wrap',
 | |
|                         //     visible: true,
 | |
|                         //     orderable: true,
 | |
|                         //     searchable: true,
 | |
|                         //     render: function(data, type, row, meta) {
 | |
|                         //         if (data) {
 | |
|                         //             return data + '<br>' + row.drop_fulladdress;
 | |
|                         //         }
 | |
|                         //         return '-';
 | |
|                         //     }
 | |
|                         // },
 | |
|                         {
 | |
|                             data: 'type',
 | |
|                             className: 'text-start text-nowrap',
 | |
|                             visible: true,
 | |
|                             orderable: true,
 | |
|                             searchable: true,
 | |
|                             render: function(data, type, row, meta) {
 | |
|                                 if (data == State.pocket_type.bundle) {
 | |
|                                     return State.pocket_type.bundle_text;
 | |
|                                 } else if (data == State.pocket_type.checkpoints) {
 | |
|                                     return State.pocket_type.checkpoints_text;
 | |
|                                 } else {
 | |
|                                     return '-';
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                         // {
 | |
|                         //     data: 'flow',
 | |
|                         //     className: 'text-start text-nowrap',
 | |
|                         //     visible: true,
 | |
|                         //     orderable: true,
 | |
|                         //     searchable: true,
 | |
|                         //     render: function(data, type, row, meta) {
 | |
|                         //         if (data == State.pocket_flow.departure) {
 | |
|                         //             return State.pocket_flow.departure_text;
 | |
|                         //         } else if (data == State.pocket_flow.arrival) {
 | |
|                         //             return State.pocket_flow.arrival_text;
 | |
|                         //         } else if (data == State.pocket_flow.hybrid) {
 | |
|                         //             return State.pocket_flow.hybrid_text;
 | |
|                         //         } else {
 | |
|                         //             return '-';
 | |
|                         //         }
 | |
|                         //     }
 | |
|                         // },
 | |
|                         {
 | |
|                             data: 'is_active',
 | |
|                             className: 'text-center',
 | |
|                             visible: true,
 | |
|                             orderable: true,
 | |
|                             searchable: true,
 | |
|                             render: function(data, type, row, meta) {
 | |
|                                 if (data == State.is_active.active) {
 | |
|                                     return '<span class="badge rounded-pill bg-success">Active</span>';
 | |
|                                 } else {
 | |
|                                     return '<span class="badge rounded-pill bg-danger">Inactive</span>';
 | |
|                                 }
 | |
|                             }
 | |
|                         },
 | |
|                     ],
 | |
|                 });
 | |
|             },
 | |
|         };
 | |
| 
 | |
|         const PNew = {
 | |
|             activate: function() {
 | |
|                 PNew.event();
 | |
|             },
 | |
|             event: function() {
 | |
|                 // modal
 | |
|                 $('#btnMdlNewPocket').on('click', function() {
 | |
|                     $('#mdlNewPocket').modal('show');
 | |
|                 });
 | |
|                 $('#mdlNewPocket').on('shown.bs.modal', function() {
 | |
|                     
 | |
|                 });
 | |
|                 // button
 | |
|                 $('#btnSubmitNewPocket').on('click', function() {
 | |
|                     let data = PNew.getData();
 | |
|                     let isValid = PNew.checkData(data, true);
 | |
|                     if (!isValid) return false;
 | |
|                     PNew.submitData(data);
 | |
|                 });
 | |
|                 // select
 | |
|                 $('#add_type').on('change', function() {
 | |
|                     let type = $('#add_type').val();
 | |
|                     if (type == State.pocket_type.bundle) {
 | |
|                         PNewCheckpoint.removeAll();
 | |
| 
 | |
|                         $('.groupAddPrice').removeClass('d-none');
 | |
|                         $('.groupAddCheckpoint').addClass('d-none');
 | |
|                     } else if (type == State.pocket_type.checkpoints) {
 | |
|                         PNewCheckpoint.removeAll();
 | |
|                         PNewCheckpoint.add();
 | |
|                         PNewCheckpoint.reTriggerSel2();
 | |
| 
 | |
|                         $('.groupAddPrice').addClass('d-none');
 | |
|                         $('.groupAddCheckpoint').removeClass('d-none');
 | |
|                     } else {
 | |
|                         PNewCheckpoint.removeAll();
 | |
| 
 | |
|                         $('.groupAddPrice').addClass('d-none');
 | |
|                         $('.groupAddCheckpoint').addClass('d-none');
 | |
|                     }
 | |
|                     $('#add_price').val('0');
 | |
|                 });
 | |
|                 $('#add_pck').on('change', function() {
 | |
|                     let pck = $('#add_pck :selected');
 | |
|                     if (pck && pck != '') {
 | |
|                         $('#add_pck_location').text(pck.data('fulladdress'));
 | |
|                     } else {
 | |
|                         $('#add_pck_location').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 $('#add_drop').on('change', function() {
 | |
|                     let drop = $('#add_drop :selected');
 | |
|                     if (drop && drop != '') {
 | |
|                         $('#add_drop_location').text(drop.data('fulladdress'));
 | |
|                     } else {
 | |
|                         $('#add_drop_location').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 $('#divAddCheckpoint').on('change', 'select[name="add_start_checkpoints[]"]', function (e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     let idx = trgt.data('idx');
 | |
|                     if (trgt && trgt.val() != '') {
 | |
|                         $(`#divRowAddCheckpoint${idx}`).find('.add_pck_location_checkpoints').text(trgt.children(':selected').data('fulladdress'));
 | |
|                     } else {
 | |
|                         $(`#divRowAddCheckpoint${idx}`).find('.add_pck_location_checkpoints').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 $('#divAddCheckpoint').on('change', 'select[name="add_end_checkpoints[]"]', function (e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     let idx = trgt.data('idx');
 | |
|                     if (trgt && trgt.val() != '') {
 | |
|                         $(`#divRowAddCheckpoint${idx}`).find('.add_drop_location_checkpoints').text(trgt.children(':selected').data('fulladdress'));
 | |
|                     } else {
 | |
|                         $(`#divRowAddCheckpoint${idx}`).find('.add_drop_location_checkpoints').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 // input
 | |
|                 $('#add_price').on('keyup', function() {
 | |
|                     let price = Number($('#add_price').val().split('.').join('').split(',').join('.'));
 | |
|                     $('#add_price').val((new Intl.NumberFormat('id-ID')).format(price));
 | |
|                 });
 | |
|                 $('#divAddCheckpoint').on('keyup', 'input[name="add_price_checkpoints[]"]', function(e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     let price = Number(trgt.val().split('.').join('').split(',').join('.'));
 | |
|                     trgt.val((new Intl.NumberFormat('id-ID')).format(price));
 | |
|                 });
 | |
|                 // trigger select
 | |
|                 $('#add_type').val(State.pocket_type.bundle).trigger('change');
 | |
|             },
 | |
|             reDataZone: function() {
 | |
|                 $('#add_pck').html('<option value="">Lokasi Pickup</option>');
 | |
|                 for (let pck of State.l_pickups) {
 | |
|                     $('#add_pck').append(`<option value="${pck.id}">${pck.name}</option>`);
 | |
|                 }
 | |
|                 $('#add_pck').select2({
 | |
|                     dropdownParent: $('#mdlNewPocket'),
 | |
|                 });
 | |
|                 $('#add_drop').html('<option value="">Lokasi Drop</option>');
 | |
|                 for (let drop of State.l_drops) {
 | |
|                     $('#add_drop').append(`<option value="${drop.id}">${drop.name}</option>`);
 | |
|                 }
 | |
|                 $('#add_drop').select2({
 | |
|                     dropdownParent: $('#mdlNewPocket'),
 | |
|                 });
 | |
|             },
 | |
|             getData: function() {
 | |
|                 let data = Helper.objectifyForm($('#formAdd').serializeArray());
 | |
|                 data.add_price = Number(data.add_price.split('.').join('').split(',').join('.'));
 | |
| 
 | |
|                 if (typeof data.add_price_checkpoints !== 'undefined') {
 | |
|                     for (let i in data.add_price_checkpoints) {
 | |
|                         data.add_price_checkpoints[i] = Number(data.add_price_checkpoints[i].split('.').join('').split(',').join('.'));
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 if ($('#add_status').prop('checked')) {
 | |
|                     data.status = State.is_active.active;
 | |
|                 } else {
 | |
|                     data.status = State.is_active.inactive;
 | |
|                 }
 | |
| 
 | |
|                 return data;
 | |
|             },
 | |
|             checkData: function(data, isAlert = false) {
 | |
|                 if (typeof data.add_name === 'undefined') {
 | |
|                     if (isAlert) Helper.toast('Warning', 'just now', 'Nama wajib diisi');
 | |
|                     return false;
 | |
|                 }
 | |
| 
 | |
|                 return true;
 | |
|             },
 | |
|             submitData: async function(data) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     if (typeof $('#btnSubmitNewPocket').attr('disabed') != 'undefined') {
 | |
|                         resolve({
 | |
|                             type: 'fail'
 | |
|                         });
 | |
|                         return false;
 | |
|                     }
 | |
|                     $('#btnSubmitNewPocket').attr('disabed', true);
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_add_pocket') }}",
 | |
|                         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) => {
 | |
|                             $('#btnSubmitNewPocket').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 menambahkan uang saku');
 | |
|                             $('#mdlNewPocket').modal('hide');
 | |
|                             DTable.reload();
 | |
|                             resolve({
 | |
|                                 type: 'success'
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             $('#btnSubmitNewPocket').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'
 | |
|                             });
 | |
|                         }
 | |
|                     })
 | |
|                 })
 | |
|             },
 | |
|         }
 | |
| 
 | |
|         const PNewCheckpoint = {
 | |
|             activate: async function() {
 | |
|                 PNewCheckpoint.event();
 | |
|             },
 | |
|             event: function () {
 | |
|                 // crud checkpoint
 | |
|                 $('#divAddCheckpoint').on('click', '.point-minus', function(e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     if ($('.point-minus').length <= 1) {
 | |
|                         Helper.toast('Warning', 'just now', 'minimal terdapat 1 checkpoint');
 | |
|                         return false;
 | |
|                     }
 | |
|                     trgt.closest('.divRowAddCheckpoint').remove();
 | |
|                 });
 | |
|                 $('#point-add-row').on('click', function() {
 | |
|                     PNewCheckpoint.add();
 | |
|                 });
 | |
|             },
 | |
|             reTriggerSel2: function () {
 | |
|                 $('select[name="add_start_checkpoints[]"]').select2({
 | |
|                     dropdownParent: $('#mdlNewPocket'),
 | |
|                 });
 | |
|                 $('select[name="add_end_checkpoints[]"]').select2({
 | |
|                     dropdownParent: $('#mdlNewPocket'),
 | |
|                 });
 | |
|             },
 | |
|             add: function () {
 | |
|                 let pck_checkpoints = '', drop_checkpoints = '';
 | |
| 
 | |
|                 for (let pck of State.pck_checkpoints) {
 | |
|                     pck_checkpoints += `<option value="${pck.id}" data-name="${pck.name}" data-fulladdress="${pck.fulladdress}">${pck.name}</option>`;
 | |
|                 }
 | |
| 
 | |
|                 // for (let drop of State.drop_checkpoints) {
 | |
|                 //     drop_checkpoints += `<option value="${drop.id}" data-name="${drop.name}" data-fulladdress="${drop.fulladdress}">${drop.name}</option>`;
 | |
|                 // }
 | |
| 
 | |
|                 // start from 0
 | |
|                 let nextIdx = $('.point-minus').length;
 | |
| 
 | |
|                 let template = `
 | |
|                 <div id="divRowAddCheckpoint${nextIdx}" class="row divRowAddCheckpoint" data-idx="${nextIdx}">
 | |
|                     <div class="col-sm-6 col-md-6">
 | |
|                         <div class="row">
 | |
|                             <div class="col-12 mb-1">
 | |
|                                 <label for="add_start_checkpoints[]" class="col-form-label">Titik Lokasi<span class="text-danger">*</span></label>
 | |
|                                 <select name="add_start_checkpoints[]" class="form-control" style="width:100%;" data-idx="${nextIdx}">
 | |
|                                     <option value="">Pilih Checkpoint</option>
 | |
|                                     ${pck_checkpoints}
 | |
|                                 </select>
 | |
|                                 <p class="add_pck_location_checkpoints mb-0"> </p>
 | |
|                             </div>
 | |
|                         </div>
 | |
|                     </div>
 | |
|                     <div class="col-sm-6 col-md-5">
 | |
|                         <label for="add_price_checkpoints[]" class="col-form-label">Harga</label>
 | |
|                         <input type="text" name="add_price_checkpoints[]" class="form-control" value="0">
 | |
|                     </div>
 | |
|                     <div class="col-sm-6 col-md-1 text-center d-flex align-items-center">
 | |
|                         <button type="button" class="btn btn-sm btn-secondary point-minus">
 | |
|                             <span class="ion-minus"></span>
 | |
|                         </button>
 | |
|                     </div>
 | |
|                 </div>
 | |
|                 `;
 | |
|                 $('#divAddCheckpoint').append(template);
 | |
| 
 | |
|                 PNewCheckpoint.reTriggerSel2();
 | |
|             },
 | |
|             removeAll: function () {
 | |
|                 $('#divAddCheckpoint').html('');
 | |
|             },
 | |
|         }
 | |
| 
 | |
|         const PUpdt = {
 | |
|             activate: function() {
 | |
|                 PUpdt.event();
 | |
|             },
 | |
|             event: function() {
 | |
|                 // modal
 | |
|                 $('#tPocket').on('click', '.btnUpdtPocket', async function(e) {
 | |
|                     let id = $(e.target).closest('tr').find('td[data-id]').data('id');
 | |
|                     let resp = await PUpdt.reqData({
 | |
|                         pocket_id: id,
 | |
|                     });
 | |
|                     if (resp.type != 'success') {
 | |
|                         Helper.toast('Pocket Not Found', 'just now', 'please try again');
 | |
|                         return false;
 | |
|                     }
 | |
|                     PUpdt.passDataToView(resp.data);
 | |
|                 });
 | |
|                 $('#mdlEdtPocket').on('shown.bs.modal', function() {
 | |
|                     
 | |
|                 });
 | |
|                 // button
 | |
|                 $('#btnSubmitEdtPocket').on('click', function() {
 | |
|                     let data = PUpdt.getData();
 | |
|                     let isValid = PUpdt.checkData(data, true);
 | |
|                     if (!isValid) return false;
 | |
|                     PUpdt.submitData(data);
 | |
|                 });
 | |
|                 // select
 | |
|                 $('#updt_type').on('change', function() {
 | |
|                     let type = $('#updt_type').val();
 | |
|                     if (type == State.pocket_type.bundle) {
 | |
|                         PUpdtCheckpoint.removeAll();
 | |
| 
 | |
|                         $('.groupUpdtPrice').removeClass('d-none');
 | |
|                         $('.groupUpdtCheckpoint').addClass('d-none');
 | |
|                     } else if (type == State.pocket_type.checkpoints) {
 | |
|                         PUpdtCheckpoint.removeAll();
 | |
|                         PUpdtCheckpoint.add();
 | |
|                         PUpdtCheckpoint.reTriggerSel2();
 | |
| 
 | |
|                         $('.groupUpdtPrice').addClass('d-none');
 | |
|                         $('.groupUpdtCheckpoint').removeClass('d-none');
 | |
|                     } else {
 | |
|                         PUpdtCheckpoint.removeAll();
 | |
| 
 | |
|                         $('.groupUpdtPrice').addClass('d-none');
 | |
|                         $('.groupUpdtCheckpoint').addClass('d-none');
 | |
|                     }
 | |
|                     $('#updt_price').val('0');
 | |
|                 });
 | |
|                 $('#updt_pck').on('change', function() {
 | |
|                     let pck = $('#updt_pck :selected');
 | |
|                     if (pck && pck != '') {
 | |
|                         $('#updt_pck_location').text(pck.data('fulladdress'));
 | |
|                     } else {
 | |
|                         $('#updt_pck_location').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 $('#updt_drop').on('change', function() {
 | |
|                     let drop = $('#updt_drop :selected');
 | |
|                     if (drop && drop != '') {
 | |
|                         $('#updt_drop_location').text(drop.data('fulladdress'));
 | |
|                     } else {
 | |
|                         $('#updt_drop_location').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 $('#divUpdtCheckpoint').on('change', 'select[name="updt_start_checkpoints[]"]', function (e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     let idx = trgt.data('idx');
 | |
|                     if (trgt && trgt.val() != '') {
 | |
|                         $(`#divRowUpdtCheckpoint${idx}`).find('.updt_pck_location_checkpoints').text(trgt.children(':selected').data('fulladdress'));
 | |
|                     } else {
 | |
|                         $(`#divRowUpdtCheckpoint${idx}`).find('.updt_pck_location_checkpoints').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 $('#divUpdtCheckpoint').on('change', 'select[name="updt_end_checkpoints[]"]', function (e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     let idx = trgt.data('idx');
 | |
|                     if (trgt && trgt.val() != '') {
 | |
|                         $(`#divRowUpdtCheckpoint${idx}`).find('.updt_drop_location_checkpoints').text(trgt.children(':selected').data('fulladdress'));
 | |
|                     } else {
 | |
|                         $(`#divRowUpdtCheckpoint${idx}`).find('.updt_drop_location_checkpoints').text('');
 | |
|                     }
 | |
|                 });
 | |
|                 // input
 | |
|                 $('#updt_price').on('keyup', function() {
 | |
|                     let price = Number($('#updt_price').val().split('.').join('').split(',').join('.'));
 | |
|                     $('#updt_price').val((new Intl.NumberFormat('id-ID')).format(price));
 | |
|                 });
 | |
|                 $('#divUpdtCheckpoint').on('keyup', 'input[name="updt_price_checkpoints[]"]', function(e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     let price = Number(trgt.val().split('.').join('').split(',').join('.'));
 | |
|                     trgt.val((new Intl.NumberFormat('id-ID')).format(price));
 | |
|                 });
 | |
|             },
 | |
|             reDataZone: function() {
 | |
|                 $('#updt_pck').html('<option value="">Lokasi Pickup</option>');
 | |
|                 for (let pck of State.l_pickups) {
 | |
|                     $('#updt_pck').append(`<option value="${pck.id}">${pck.name}</option>`);
 | |
|                 }
 | |
|                 $('#updt_pck').select2({
 | |
|                     dropdownParent: $('#mdlEdtPocket'),
 | |
|                 });
 | |
|                 $('#updt_drop').html('<option value="">Lokasi Drop</option>');
 | |
|                 for (let drop of State.l_drops) {
 | |
|                     $('#updt_drop').append(`<option value="${drop.id}">${drop.name}</option>`);
 | |
|                 }
 | |
|                 $('#updt_drop').select2({
 | |
|                     dropdownParent: $('#mdlEdtPocket'),
 | |
|                 });
 | |
|             },
 | |
|             reqData: function(params) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_show_pocket', '') }}/" + params.pocket_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_type').val(data.type).trigger('change');
 | |
|                 $('#updt_pck').val(data.pck_id).trigger('change');
 | |
|                 // $('#updt_pck_location').val(data.pck_fulladdress).trigger('change');
 | |
|                 $('#updt_drop').val(data.drop_id).trigger('change');
 | |
|                 // $('#updt_drop_location').val(data.drop_fulladdress).trigger('change');
 | |
| 
 | |
|                 if (data.type == State.pocket_type.bundle) {
 | |
|                     $('#updt_price').val(data.checkpoints[0].total).trigger('keyup');
 | |
|                 } else {
 | |
|                     $('#updt_price').val(0);
 | |
|                 }
 | |
| 
 | |
|                 if (data.type == State.pocket_type.checkpoints) {
 | |
|                     for (let i in data.checkpoints) {
 | |
|                         if (i != 0) {
 | |
|                             PUpdtCheckpoint.add();
 | |
|                             PUpdtCheckpoint.reTriggerSel2();
 | |
|                         }
 | |
|                         $($('select[name="updt_start_checkpoints[]"]')[i]).val(data.checkpoints[i].pck_id).trigger('change');
 | |
|                         $($('input[name="updt_price_checkpoints[]"]')[i]).val(data.checkpoints[i].total).trigger('keyup');
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 if (data.is_active == State.is_active.active) {
 | |
|                     $('#updt_status').prop('checked', true);
 | |
|                 } else {
 | |
|                     $('#updt_status').prop('checked', false);
 | |
|                 }
 | |
| 
 | |
|                 $('#mdlEdtPocket').data('id', data.id);
 | |
|                 $('#mdlEdtPocket').modal('show');
 | |
|             },
 | |
|             getData: function() {
 | |
|                 let data = Helper.objectifyForm($('#formUpdt').serializeArray());
 | |
|                 data.updt_price = Number(data.updt_price.split('.').join('').split(',').join('.'));
 | |
| 
 | |
|                 if (typeof data.updt_price_checkpoints !== 'undefined') {
 | |
|                     for (let i in data.updt_price_checkpoints) {
 | |
|                         data.updt_price_checkpoints[i] = Number(data.updt_price_checkpoints[i].split('.').join('').split(',').join('.'));
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 if ($('#updt_status').prop('checked')) {
 | |
|                     data.status = State.is_active.active;
 | |
|                 } else {
 | |
|                     data.status = State.is_active.inactive;
 | |
|                 }
 | |
| 
 | |
|                 data.pocket_id = $('#mdlEdtPocket').data('id');
 | |
| 
 | |
|                 return data;
 | |
|             },
 | |
|             checkData: function(data, isAlert = false) {
 | |
|                 if (typeof data.updt_name === 'undefined') {
 | |
|                     if (isAlert) Helper.toast('Warning', 'just now', 'Nama wajib diisi');
 | |
|                     return false;
 | |
|                 }
 | |
| 
 | |
|                 return true;
 | |
|             },
 | |
|             submitData: async function(data) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     if (typeof $('#btnSubmitEdtPocket').attr('disabed') != 'undefined') {
 | |
|                         resolve({
 | |
|                             type: 'fail'
 | |
|                         });
 | |
|                         return false;
 | |
|                     }
 | |
|                     $('#btnSubmitEdtPocket').attr('disabed', true);
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_edit_pocket', '') }}/" + data.pocket_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) => {
 | |
|                             $('#btnSubmitEdtPocket').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 update pocket');
 | |
|                             $('#mdlEdtPocket').modal('hide');
 | |
|                             DTable.reload();
 | |
|                             resolve({
 | |
|                                 type: 'success'
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             $('#btnSubmitEdtPocket').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'
 | |
|                             });
 | |
|                         }
 | |
|                     })
 | |
|                 })
 | |
|             },
 | |
|         }
 | |
| 
 | |
|         const PUpdtCheckpoint = {
 | |
|             activate: async function() {
 | |
|                 PUpdtCheckpoint.event();
 | |
|             },
 | |
|             event: function () {
 | |
|                 // crud checkpoint
 | |
|                 $('#divUpdtCheckpoint').on('click', '.updt-point-minus', function(e) {
 | |
|                     let trgt = $(e.target);
 | |
|                     if ($('.updt-point-minus').length <= 1) {
 | |
|                         Helper.toast('Warning', 'just now', 'minimal terdapat 1 checkpoint');
 | |
|                         return false;
 | |
|                     }
 | |
|                     trgt.closest('.divRowUpdtCheckpoint').remove();
 | |
|                 });
 | |
|                 $('#updt-point-add-row').on('click', function() {
 | |
|                     PUpdtCheckpoint.add();
 | |
|                 });
 | |
|             },
 | |
|             reTriggerSel2: function () {
 | |
|                 $('select[name="updt_start_checkpoints[]"]').select2({
 | |
|                     dropdownParent: $('#mdlEdtPocket'),
 | |
|                 });
 | |
|                 $('select[name="updt_end_checkpoints[]"]').select2({
 | |
|                     dropdownParent: $('#mdlEdtPocket'),
 | |
|                 });
 | |
|             },
 | |
|             add: function () {
 | |
|                 let pck_checkpoints = '', drop_checkpoints = '';
 | |
| 
 | |
|                 for (let pck of State.pck_checkpoints) {
 | |
|                     pck_checkpoints += `<option value="${pck.id}" data-name="${pck.name}" data-fulladdress="${pck.fulladdress}">${pck.name}</option>`;
 | |
|                 }
 | |
| 
 | |
|                 // for (let drop of State.drop_checkpoints) {
 | |
|                 //     drop_checkpoints += `<option value="${drop.id}" data-name="${drop.name}" data-fulladdress="${drop.fulladdress}">${drop.name}</option>`;
 | |
|                 // }
 | |
| 
 | |
|                 // start from 0
 | |
|                 let nextIdx = $('.updt-point-minus').length;
 | |
| 
 | |
|                 let template = `
 | |
|                 <div id="divRowUpdtCheckpoint${nextIdx}" class="row divRowUpdtCheckpoint" data-idx="${nextIdx}">
 | |
|                     <div class="col-sm-6 col-md-6">
 | |
|                         <div class="row">
 | |
|                             <div class="col-12 mb-1">
 | |
|                                 <label for="updt_start_checkpoints[]" class="col-form-label">Titik Lokasi<span class="text-danger">*</span></label>
 | |
|                                 <select name="updt_start_checkpoints[]" class="form-control" style="width:100%;" data-idx="${nextIdx}">
 | |
|                                     <option value="">Pilih Checkpoint</option>
 | |
|                                     ${pck_checkpoints}
 | |
|                                 </select>
 | |
|                                 <p class="updt_pck_location_checkpoints mb-0"> </p>
 | |
|                             </div>
 | |
|                         </div>
 | |
|                     </div>
 | |
|                     <div class="col-sm-6 col-md-5">
 | |
|                         <label for="updt_price_checkpoints[]" class="col-form-label">Harga</label>
 | |
|                         <input type="text" name="updt_price_checkpoints[]" class="form-control" value="0">
 | |
|                     </div>
 | |
|                     <div class="col-sm-6 col-md-1 text-center d-flex align-items-center">
 | |
|                         <button type="button" class="btn btn-sm btn-secondary updt-point-minus">
 | |
|                             <span class="ion-minus"></span>
 | |
|                         </button>
 | |
|                     </div>
 | |
|                 </div>
 | |
|                 `;
 | |
|                 $('#divUpdtCheckpoint').append(template);
 | |
| 
 | |
|                 PUpdtCheckpoint.reTriggerSel2();
 | |
|             },
 | |
|             removeAll: function () {
 | |
|                 $('#divUpdtCheckpoint').html('');
 | |
|             },
 | |
|         }
 | |
| 
 | |
|         const PDel = {
 | |
|             activate: function() {
 | |
|                 PDel.event();
 | |
|             },
 | |
|             event: function() {
 | |
|                 // on table
 | |
|                 $('#tPocket').on('click', '.btnDelPocket', function(e) {
 | |
|                     let row = $(e.target).closest('tr');
 | |
|                     let id = row.find('td[data-id]').data('id');
 | |
|                     let pck_name = row.find('td[data-pck_name]').data('pck_name');
 | |
|                     let pck_fulladdress = row.find('td[data-pck_fulladdress]').data('pck_fulladdress');
 | |
|                     // let drop_name = row.find('td[data-drop_name]').data('drop_name');
 | |
|                     // let drop_fulladdress = row.find('td[data-drop_fulladdress]').data('drop_fulladdress');
 | |
|                     PDel.passDataToView({
 | |
|                         pocket_id: id,
 | |
|                         pck_name,
 | |
|                         pck_fulladdress,
 | |
|                         // drop_name,
 | |
|                         // drop_fulladdress,
 | |
|                     });
 | |
|                     $('#mdlDelPocket').data('id', id);
 | |
|                     $('#mdlDelPocket').modal('show');
 | |
|                 });
 | |
|                 $('#btnSubmitDelPocket').on('click', function() {
 | |
|                     let data = {
 | |
|                         pocket_id: $('#mdlDelPocket').data('id'),
 | |
|                     };
 | |
|                     PDel.submitData(data);
 | |
|                 });
 | |
|                 // on modal update
 | |
|                 $('#btnDelPocket_updt').on('click', function (e) {
 | |
|                     let data = PUpdt.getData();
 | |
|                     PDel.passDataToView({
 | |
|                         pocket_id: data.pocket_id,
 | |
|                         // code: '',
 | |
|                     });
 | |
|                     $('#mdlDelPocket').data('id', data.pocket_id);
 | |
|                     $('#mdlDelPocket').modal('show');
 | |
|                 });
 | |
|             },
 | |
|             passDataToView: function(data) {
 | |
|                 $('#del-pck_name').text(data.pck_name);
 | |
|             },
 | |
|             submitData: async function(data) {
 | |
|                 return new Promise((resolve, reject) => {
 | |
|                     if (typeof $('#btnSubmitDelPocket').attr('disabed') != 'undefined') {
 | |
|                         resolve({
 | |
|                             type: 'fail'
 | |
|                         });
 | |
|                         return false;
 | |
|                     }
 | |
|                     $('#btnSubmitDelPocket').attr('disabed', true);
 | |
|                     $.ajax({
 | |
|                         url: "{{ route('api_del_pocket', '') }}/" + data.pocket_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) => {
 | |
|                             $('#btnSubmitDelPocket').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 pocket');
 | |
|                             $('#mdlDelPocket').modal('hide');
 | |
|                             $('#mdlEdtPocket').modal('hide');
 | |
|                             DTable.reload();
 | |
|                             resolve({
 | |
|                                 type: 'success'
 | |
|                             });
 | |
|                         },
 | |
|                         error: (jqXHR, textStatus, error) => {
 | |
|                             $('#btnSubmitDelPocket').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
 | 
