1707 lines
88 KiB
PHP
Executable File
1707 lines
88 KiB
PHP
Executable File
@extends('app.app')
|
|
|
|
@section('title')
|
|
Publish Rate & 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">Rates (<span id="count_rates">0</span>)</p>
|
|
</div>
|
|
<div class="col text-end">
|
|
<button id="btnMdlNewRate" class="btn btn-sm btn-danger">Add New Rates</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="tRates" class="table table-hover dataTable">
|
|
<thead>
|
|
<tr class="">
|
|
<th class="">#</th>
|
|
<th class="text-center">Action</th>
|
|
<th class="">Code</th>
|
|
<th class="">Origin</th>
|
|
<th class="">Via</th>
|
|
<th class="">Dest Province</th>
|
|
<th class="">Dest City</th>
|
|
<th class="">Dest District</th>
|
|
<th class="">Vendor</th>
|
|
<th class="">Vehicle</th>
|
|
<th class="text-center text-nowrap">Lead Time</th>
|
|
<th class="text-end text-nowrap">Sell KG</th>
|
|
<th class="text-end text-nowrap">Buy KG</th>
|
|
<th class="text-end text-nowrap">Margin</th>
|
|
<th class="text-end text-nowrap">Percentage</th>
|
|
<th class="text-end text-nowrap">Sell CBM</th>
|
|
<th class="text-end text-nowrap">Buy CBM</th>
|
|
<th class="text-end text-nowrap">Margin</th>
|
|
<th class="text-end text-nowrap">Percentage</th>
|
|
<th class="text-end text-nowrap">Sell FTL</th>
|
|
<th class="text-end text-nowrap">Buy FTL</th>
|
|
<th class="text-end text-nowrap">Margin</th>
|
|
<th class="text-end text-nowrap">Percentage</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="mdlNewRate"
|
|
aria-labelledby="mdlNewRateLabel" 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="mdlNewRateLabel">Add New Rate</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
<div class="modal-body">
|
|
<form>
|
|
{{-- Origin --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Origin</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-origin_prov" class="col-form-label">Origin<span class="text-danger">*</span></label>
|
|
<select name="add-origin_prov" id="add-origin_prov"
|
|
class="form-control" style="width:100%;">
|
|
<option value="">Select Origin</option>
|
|
@foreach ($provs as $prov)
|
|
<option value="{{ $prov->kodeProv }}">
|
|
{{ $prov->nmProvinsiKel }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-via" class="col-form-label">Via<span class="text-danger">*</span></label>
|
|
<select name="add-via" id="add-via" class="form-control" style="width:100%;">
|
|
<option value="">Select Via</option>
|
|
@foreach ($lanes as $lane)
|
|
<option value="{{ $lane->id }}">
|
|
{{ $lane->name }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Dest --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Destination</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-dest_prov" class="col-form-label">Dest Province<span class="text-danger">*</span></label>
|
|
<select name="add-dest_prov" id="add-dest_prov" class="form-control" style="width:100%;">
|
|
<option value="">Select Dest Province</option>
|
|
@foreach ($provs as $prov)
|
|
<option value="{{ $prov->kodeProv }}">
|
|
{{ $prov->nmProvinsiKel }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-dest_city" class="col-form-label">Dest City<span class="text-danger">*</span></label>
|
|
<select name="add-dest_city" id="add-dest_city" class="form-control" style="width:100%;">
|
|
<option value="">Select Dest City</option>
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-dest_district" class="col-form-label">Dest District (Optional)</label>
|
|
<select name="add-dest_district" id="add-dest_district"
|
|
class="form-control" style="width:100%;">
|
|
<option value="">Select Dest District</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Vendor & Vehicle --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Vendor & Vehicle</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-vendor_id" class="col-form-label">Vendor<span class="text-danger">*</span></label>
|
|
<select name="add-vendor_id" id="add-vendor_id" class="form-control" style="width:100%;">
|
|
<option value="">Select Vendor</option>
|
|
@foreach ($vendors as $vendor)
|
|
<option value="{{ $vendor->id }}">
|
|
{{ $vendor->first_name . ' (' . $vendor->email . ')' }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-vhc_type" class="col-form-label">Vehicle Type<span class="text-danger">*</span></label>
|
|
<select name="add-vhc_type" id="add-vhc_type" class="form-control" style="width:100%;">
|
|
<option value="">Select Vehicle Type</option>
|
|
@foreach ($truck_types as $truck_type)
|
|
<option value="{{ $truck_type->type_id }}">
|
|
{{ $truck_type->type_name }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Time --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Lead Time</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-fast_time" class="col-form-label">Fastest (Day)<span class="text-danger">*</span></label>
|
|
<input type="number" name="add-fast_time" id="add-fast_time" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-long_time" class="col-form-label">Longest (Day)<span class="text-danger">*</span></label>
|
|
<input type="number" name="add-long_time" id="add-long_time" class="form-control">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Pricing (KG) --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Pricing (Rp) (KG)</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-sell_kg" class="col-form-label">Sell KG (Rp)</label>
|
|
<input type="text" name="add-sell_kg" id="add-sell_kg" class="form-control" value="0">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-buy_kg" class="col-form-label">Buy KG (Rp)</label>
|
|
<input type="text" name="add-buy_kg" id="add-buy_kg" class="form-control" value="0">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-margin_kg" class="col-form-label">Margin</label>
|
|
<input type="text" name="add-margin_kg" id="add-margin_kg" class="form-control" value="0"
|
|
readonly>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-percent_kg" class="col-form-label">Percentage</label>
|
|
<div class="input-group">
|
|
<input type="number" name="add-percent_kg" id="add-percent_kg"
|
|
class="form-control" value="0" readonly>
|
|
<span class="input-group-text">%</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Pricing (CBM) --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Pricing (Rp) (CBM)</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-sell_cbm" class="col-form-label">Sell CBM (Rp)</label>
|
|
<input type="text" name="add-sell_cbm" id="add-sell_cbm" class="form-control" value="0">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-buy_cbm" class="col-form-label">Buy CBM (Rp)</label>
|
|
<input type="text" name="add-buy_cbm" id="add-buy_cbm" class="form-control" value="0">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-margin_cbm" class="col-form-label">Margin</label>
|
|
<input type="text" name="add-margin_cbm" id="add-margin_cbm" class="form-control" value="0"
|
|
readonly>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-percent_cbm" class="col-form-label">Percentage</label>
|
|
<div class="input-group">
|
|
<input type="number" name="add-percent_cbm" id="add-percent_cbm"
|
|
class="form-control" value="0" readonly>
|
|
<span class="input-group-text">%</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Pricing (FTL) --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Pricing (Rp) (FTL)</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-sell_ftl" class="col-form-label">Sell FTL (Rp)</label>
|
|
<input type="text" name="add-sell_ftl" id="add-sell_ftl" class="form-control" value="0">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-buy_ftl" class="col-form-label">Buy FTL (Rp)</label>
|
|
<input type="text" name="add-buy_ftl" id="add-buy_ftl" class="form-control" value="0">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-margin_ftl" class="col-form-label">Margin</label>
|
|
<input type="text" name="add-margin_ftl" id="add-margin_ftl" class="form-control" value="0"
|
|
readonly>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="add-percent_ftl" class="col-form-label">Percentage</label>
|
|
<div class="input-group">
|
|
<input type="number" name="add-percent_ftl" id="add-percent_ftl"
|
|
class="form-control" value="0" readonly>
|
|
<span class="input-group-text">%</span>
|
|
</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">
|
|
<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="btnSubmitNewRate" 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="mdlEdtRate"
|
|
aria-labelledby="mdlEdtRateLabel" 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="mdlEdtRateLabel">Edit Rate</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
<div class="modal-body">
|
|
<form>
|
|
{{-- Rates --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Rates</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-origin_prov" class="col-form-label">Origin<span class="text-danger">*</span></label>
|
|
<select name="updt-origin_prov" id="updt-origin_prov"
|
|
class="form-control" style="width:100%;">
|
|
<option value="">Select Origin</option>
|
|
@foreach ($provs as $prov)
|
|
<option value="{{ $prov->kodeProv }}">
|
|
{{ $prov->nmProvinsiKel }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-via" class="col-form-label">Via<span class="text-danger">*</span></label>
|
|
<select name="updt-via" id="updt-via" class="form-control" style="width:100%;">
|
|
<option value="">Select Via</option>
|
|
@foreach ($lanes as $lane)
|
|
<option value="{{ $lane->id }}">
|
|
{{ $lane->name }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Dest --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Destination</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-dest_prov" class="col-form-label">Dest Province<span class="text-danger">*</span></label>
|
|
<select name="updt-dest_prov" id="updt-dest_prov" class="form-control" style="width:100%;">
|
|
<option value="">Select Dest Province</option>
|
|
@foreach ($provs as $prov)
|
|
<option value="{{ $prov->kodeProv }}">
|
|
{{ $prov->nmProvinsiKel }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-dest_city" class="col-form-label">Dest City<span class="text-danger">*</span></label>
|
|
<select name="updt-dest_city" id="updt-dest_city" class="form-control" style="width:100%;">
|
|
<option value="">Select Dest City</option>
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-dest_district" class="col-form-label">Dest District (Optional)<span class="text-danger">*</span></label>
|
|
<select name="updt-dest_district" id="updt-dest_district"
|
|
class="form-control" style="width:100%;">
|
|
<option value="">Select Dest District</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Vendor & Vehicle --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Vendor & Vehicle</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-vendor_id" class="col-form-label">Vendor<span class="text-danger">*</span></label>
|
|
<select name="updt-vendor_id" id="updt-vendor_id" class="form-control" style="width:100%;">
|
|
<option value="">Select Vendor</option>
|
|
@foreach ($vendors as $vendor)
|
|
<option value="{{ $vendor->id }}">
|
|
{{ $vendor->first_name . ' (' . $vendor->email . ')' }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-vhc_type" class="col-form-label">Vehicle Type<span class="text-danger">*</span></label>
|
|
<select name="updt-vhc_type" id="updt-vhc_type" class="form-control" style="width:100%;">
|
|
<option value="">Select Vehicle Type</option>
|
|
@foreach ($truck_types as $truck_type)
|
|
<option value="{{ $truck_type->type_id }}">
|
|
{{ $truck_type->type_name }}</option>
|
|
@endforeach
|
|
</select>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Time --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Lead Time</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-fast_time" class="col-form-label">Fastest (Day)<span class="text-danger">*</span></label>
|
|
<input type="number" name="updt-fast_time" id="updt-fast_time" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-long_time" class="col-form-label">Longest (Day)<span class="text-danger">*</span></label>
|
|
<input type="number" name="updt-long_time" id="updt-long_time" class="form-control">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Pricing (KG) --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Pricing (Rp) (KG)</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-sell_kg" class="col-form-label">Sell KG (Rp)</label>
|
|
<input type="text" name="updt-sell_kg" id="updt-sell_kg" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-buy_kg" class="col-form-label">Buy KG (Rp)</label>
|
|
<input type="text" name="updt-buy_kg" id="updt-buy_kg" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-margin_kg" class="col-form-label">Margin</label>
|
|
<input type="text" name="updt-margin_kg" id="updt-margin_kg" class="form-control"
|
|
readonly>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-percent_kg" class="col-form-label">Percentage</label>
|
|
<div class="input-group">
|
|
<input type="number" name="updt-percent_kg" id="updt-percent_kg"
|
|
class="form-control" readonly>
|
|
<span class="input-group-text">%</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Pricing (CBM) --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Pricing (Rp) (CBM)</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-sell_cbm" class="col-form-label">Sell CBM (Rp)</label>
|
|
<input type="text" name="updt-sell_cbm" id="updt-sell_cbm" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-buy_cbm" class="col-form-label">Buy CBM (Rp)</label>
|
|
<input type="text" name="updt-buy_cbm" id="updt-buy_cbm" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-margin_cbm" class="col-form-label">Margin</label>
|
|
<input type="text" name="updt-margin_cbm" id="updt-margin_cbm" class="form-control"
|
|
readonly>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-percent_cbm" class="col-form-label">Percentage</label>
|
|
<div class="input-group">
|
|
<input type="number" name="updt-percent_cbm" id="updt-percent_cbm"
|
|
class="form-control" readonly>
|
|
<span class="input-group-text">%</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{-- Pricing (FTL) --}}
|
|
<div class="mb-3">
|
|
<div class="border-bottom">
|
|
<h6>Pricing (Rp) (FTL)</h6>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-sell_ftl" class="col-form-label">Sell FTL (Rp)</label>
|
|
<input type="text" name="updt-sell_ftl" id="updt-sell_ftl" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-buy_ftl" class="col-form-label">Buy FTL (Rp)</label>
|
|
<input type="text" name="updt-buy_ftl" id="updt-buy_ftl" class="form-control">
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-margin_ftl" class="col-form-label">Margin</label>
|
|
<input type="text" name="updt-margin_ftl" id="updt-margin_ftl" class="form-control"
|
|
readonly>
|
|
</div>
|
|
<div class="col-sm-6 col-md-3">
|
|
<label for="updt-percent_ftl" class="col-form-label">Percentage</label>
|
|
<div class="input-group">
|
|
<input type="number" name="updt-percent_ftl" id="updt-percent_ftl"
|
|
class="form-control" readonly>
|
|
<span class="input-group-text">%</span>
|
|
</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="btnDelRate_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="btnSubmitEdtRate" 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="mdlDelRate"
|
|
aria-labelledby="mdlDelRateLabel" 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="mdlDelRateLabel">Delete Rate</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 rate
|
|
<a href="#" class="text-danger">
|
|
<span id="del-code"></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="btnSubmitDelRate" 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') }}/",
|
|
stts_conf: {
|
|
active: "{{ App\Models\ConfRates::IS_ACTIVE }}",
|
|
inactive: "{{ App\Models\ConfRates::IS_INACTIVE }}",
|
|
},
|
|
unit_time: {
|
|
day: "{{ App\Models\ConfRates::UNIT_DAY }}",
|
|
},
|
|
delay_typing_front: 1000,
|
|
};
|
|
|
|
const Wrapper = {
|
|
activate: function() {
|
|
Wrapper.event();
|
|
DTable.activate();
|
|
RNew.activate();
|
|
RUpdt.activate();
|
|
RDel.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-origin_prov').select2({
|
|
dropdownParent: $('#mdlNewRate'),
|
|
});
|
|
$('#add-via').select2({
|
|
dropdownParent: $('#mdlNewRate'),
|
|
});
|
|
$('#add-dest_prov').select2({
|
|
dropdownParent: $('#mdlNewRate'),
|
|
});
|
|
$('#add-dest_city').select2({
|
|
dropdownParent: $('#mdlNewRate'),
|
|
});
|
|
$('#add-dest_district').select2({
|
|
dropdownParent: $('#mdlNewRate'),
|
|
});
|
|
$('#add-vendor_id').select2({
|
|
dropdownParent: $('#mdlNewRate'),
|
|
});
|
|
$('#add-vhc_type').select2({
|
|
dropdownParent: $('#mdlNewRate'),
|
|
});
|
|
|
|
$('#updt-origin_prov').select2({
|
|
dropdownParent: $('#mdlEdtRate'),
|
|
});
|
|
$('#updt-via').select2({
|
|
dropdownParent: $('#mdlEdtRate'),
|
|
});
|
|
$('#updt-dest_prov').select2({
|
|
dropdownParent: $('#mdlEdtRate'),
|
|
});
|
|
$('#updt-dest_city').select2({
|
|
dropdownParent: $('#mdlEdtRate'),
|
|
});
|
|
$('#updt-dest_district').select2({
|
|
dropdownParent: $('#mdlEdtRate'),
|
|
});
|
|
$('#updt-vendor_id').select2({
|
|
dropdownParent: $('#mdlEdtRate'),
|
|
});
|
|
$('#updt-vhc_type').select2({
|
|
dropdownParent: $('#mdlEdtRate'),
|
|
});
|
|
},
|
|
calcMargin: function(sell, buy) {
|
|
return (Number(sell) - Number(buy)).toFixed(2);
|
|
},
|
|
calcPercentMargin: function(margin, buy) {
|
|
return ((Number(margin) / Number(buy)) * 100).toFixed(2);
|
|
},
|
|
};
|
|
|
|
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,
|
|
});
|
|
}
|
|
})
|
|
})
|
|
},
|
|
}
|
|
|
|
const DTable = {
|
|
activate: function() {
|
|
DTable.reload();
|
|
},
|
|
reload: function() {
|
|
// $('#tRates').DataTable();
|
|
// if (Driver.Table.firstInitDataTable == 1) { loadTableSkeletonLoading() } else { Driver.Table.firstInitDataTable = 1; }
|
|
$('#tRates').DataTable({
|
|
processing: true,
|
|
serverSide: false,
|
|
bLengthChange: true,
|
|
deferRender: true,
|
|
destroy: true,
|
|
ajax: {
|
|
url: "{{ route('api_conf_list_rates') }}",
|
|
type: 'GET',
|
|
complete: function(jqXHR, textStatus, c) {
|
|
let count = jqXHR.responseJSON.count;
|
|
if (typeof count != 'undefined') {
|
|
$('#count_rates').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 btnUpdtRate">
|
|
<span class="icon ion-edit fz-16"></span>
|
|
</a>
|
|
`;
|
|
// <a href="#" class="text-decoration-none text-danger btnDelRate">
|
|
// <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,
|
|
createdCell: function(td, cellData, rowData, row, col) {
|
|
$(td).attr('data-rid', rowData.id);
|
|
$(td).attr('data-code', rowData.code);
|
|
$(td).attr('data-origin_prov_name', rowData.origin_prov_name);
|
|
$(td).attr('data-dest_prov_name', rowData.dest_prov_name);
|
|
$(td).attr('data-dest_city_name', rowData.dest_city_name);
|
|
},
|
|
},
|
|
{
|
|
data: 'origin_prov_name',
|
|
className: 'text-start text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
},
|
|
{
|
|
data: 'lane_name',
|
|
className: 'text-start text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
},
|
|
{
|
|
data: 'dest_prov_name',
|
|
className: 'text-start text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
},
|
|
{
|
|
data: 'dest_city_name',
|
|
className: 'text-start text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return data || '-';
|
|
}
|
|
},
|
|
{
|
|
data: 'dest_district_name',
|
|
className: 'text-start text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return data || '-';
|
|
}
|
|
},
|
|
{
|
|
data: 'vdr_name',
|
|
className: 'text-start text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
if (!data) {
|
|
return '-';
|
|
}
|
|
return `${data} (${row.vdr_mail})`;
|
|
}
|
|
},
|
|
{
|
|
data: 'vhc_type_name',
|
|
className: 'text-start text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
if (!data) {
|
|
return '-';
|
|
}
|
|
return data;
|
|
}
|
|
},
|
|
{
|
|
data: 'fast_time',
|
|
className: 'text-center text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
let unit_time = '';
|
|
if (row.unit_time == State.unit_time.day) {
|
|
unit_time = 'day';
|
|
}
|
|
return row.fast_time + ' - ' + row.long_time + ' ' + unit_time;
|
|
}
|
|
},
|
|
{
|
|
data: 'sell_kg',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'buy_kg',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'margin_kg',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'percent_kg',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return data + '%';
|
|
}
|
|
},
|
|
{
|
|
data: 'sell_cbm',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'buy_cbm',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'margin_cbm',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'percent_cbm',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return data + '%';
|
|
}
|
|
},
|
|
{
|
|
data: 'sell_ftl',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'buy_ftl',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'margin_ftl',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return (new Intl.NumberFormat('id-ID')).format(data);
|
|
}
|
|
},
|
|
{
|
|
data: 'percent_ftl',
|
|
className: 'text-end text-nowrap',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
return data + '%';
|
|
}
|
|
},
|
|
{
|
|
data: 'is_active',
|
|
className: 'text-center',
|
|
visible: true,
|
|
orderable: true,
|
|
searchable: true,
|
|
render: function(data, type, row, meta) {
|
|
if (data == State.stts_conf.active) {
|
|
return '<span class="badge rounded-pill bg-success">Active</span>';
|
|
} else {
|
|
return '<span class="badge rounded-pill bg-danger">Inactive</span>';
|
|
}
|
|
}
|
|
},
|
|
],
|
|
});
|
|
},
|
|
};
|
|
|
|
const RNew = {
|
|
activate: function() {
|
|
RNew.event();
|
|
},
|
|
event: function() {
|
|
// modal
|
|
$('#btnMdlNewRate').on('click', function() {
|
|
$('#mdlNewRate').modal('show');
|
|
});
|
|
$('#mdlNewRate').on('shown.bs.modal', function() {
|
|
|
|
});
|
|
// button
|
|
$('#btnSubmitNewRate').on('click', function() {
|
|
let data = RNew.getData();
|
|
RNew.submitData(data);
|
|
});
|
|
// input
|
|
$('#add-dest_prov').on('change', async function(e) {
|
|
let list_city = await Req.list_city({
|
|
kodeProv: $('#add-dest_prov').val(),
|
|
}, true);
|
|
if (list_city.type == 'success') {
|
|
$('#add-dest_city').html('<option value="">Select Dest City</option>');
|
|
for (let city of list_city.resp.data) {
|
|
$('#add-dest_city').append('<option value="' + city.kodeKab + '">' + city
|
|
.nmKotamadyaKel + '</option>');
|
|
}
|
|
}
|
|
});
|
|
$('#add-dest_city').on('change', async function(e) {
|
|
let list_district = await Req.list_district({
|
|
kodeKab: $('#add-dest_city').val(),
|
|
}, true);
|
|
if (list_district.type == 'success') {
|
|
$('#add-dest_district').html('<option value="">Select Dest District</option>');
|
|
for (let district of list_district.resp.data) {
|
|
$('#add-dest_district').append('<option value="' + district.kodeKec +
|
|
'">' + district
|
|
.nmKecamatanKel + '</option>');
|
|
}
|
|
}
|
|
});
|
|
|
|
function calcMarginNPercentKg(sell_kg, buy_kg) {
|
|
let margin = Wrapper.calcMargin(sell_kg, buy_kg);
|
|
let percent = Wrapper.calcPercentMargin(margin, buy_kg);
|
|
percent = (isNaN(percent)) ? 0 : percent;
|
|
$('#add-margin_kg').val((new Intl.NumberFormat('id-ID')).format(margin));
|
|
$('#add-percent_kg').val(percent);
|
|
}
|
|
let timeoutSellKg = null;
|
|
$('#add-sell_kg').on('keyup', function(e) {
|
|
let sell_kg = $('#add-sell_kg').val().split('.').join('');
|
|
let buy_kg = $('#add-buy_kg').val().split('.').join('');
|
|
$('#add-sell_kg').val((new Intl.NumberFormat('id-ID')).format(sell_kg));
|
|
clearTimeout(timeoutSellKg);
|
|
timeoutSellKg = setTimeout(() => {
|
|
calcMarginNPercentKg(sell_kg, buy_kg);
|
|
}, State.delay_typing_front);
|
|
});
|
|
let timeoutBuyKg = null;
|
|
$('#add-buy_kg').on('keyup', function(e) {
|
|
let sell_kg = $('#add-sell_kg').val().split('.').join('');
|
|
let buy_kg = $('#add-buy_kg').val().split('.').join('');
|
|
$('#add-buy_kg').val((new Intl.NumberFormat('id-ID')).format(buy_kg));
|
|
clearTimeout(timeoutBuyKg);
|
|
timeoutBuyKg = setTimeout(() => {
|
|
calcMarginNPercentKg(sell_kg, buy_kg);
|
|
}, State.delay_typing_front);
|
|
});
|
|
|
|
function calcMarginNPercentCbm(sell_cbm, buy_cbm) {
|
|
let margin = Wrapper.calcMargin(sell_cbm, buy_cbm);
|
|
let percent = Wrapper.calcPercentMargin(margin, buy_cbm);
|
|
percent = (isNaN(percent)) ? 0 : percent;
|
|
$('#add-margin_cbm').val((new Intl.NumberFormat('id-ID')).format(margin));
|
|
$('#add-percent_cbm').val(percent);
|
|
}
|
|
let timeoutSellCbm = null;
|
|
$('#add-sell_cbm').on('keyup', function(e) {
|
|
let sell_cbm = $('#add-sell_cbm').val().split('.').join('');
|
|
let buy_cbm = $('#add-buy_cbm').val().split('.').join('');
|
|
$('#add-sell_cbm').val((new Intl.NumberFormat('id-ID')).format(sell_cbm));
|
|
clearTimeout(timeoutSellCbm);
|
|
timeoutSellCbm = setTimeout(() => {
|
|
calcMarginNPercentCbm(sell_cbm, buy_cbm);
|
|
}, State.delay_typing_front);
|
|
});
|
|
let timeoutBuyCbm = null;
|
|
$('#add-buy_cbm').on('keyup', function(e) {
|
|
let sell_cbm = $('#add-sell_cbm').val().split('.').join('');
|
|
let buy_cbm = $('#add-buy_cbm').val().split('.').join('');
|
|
$('#add-buy_cbm').val((new Intl.NumberFormat('id-ID')).format(buy_cbm));
|
|
clearTimeout(timeoutBuyCbm);
|
|
timeoutBuyCbm = setTimeout(() => {
|
|
calcMarginNPercentCbm(sell_cbm, buy_cbm);
|
|
}, State.delay_typing_front);
|
|
});
|
|
|
|
function calcMarginNPercentFtl(sell_ftl, buy_ftl) {
|
|
let margin = Wrapper.calcMargin(sell_ftl, buy_ftl);
|
|
let percent = Wrapper.calcPercentMargin(margin, buy_ftl);
|
|
percent = (isNaN(percent)) ? 0 : percent;
|
|
$('#add-margin_ftl').val((new Intl.NumberFormat('id-ID')).format(margin));
|
|
$('#add-percent_ftl').val(percent);
|
|
}
|
|
let timeoutSellFtl = null;
|
|
$('#add-sell_ftl').on('keyup', function(e) {
|
|
let sell_ftl = $('#add-sell_ftl').val().split('.').join('');
|
|
let buy_ftl = $('#add-buy_ftl').val().split('.').join('');
|
|
$('#add-sell_ftl').val((new Intl.NumberFormat('id-ID')).format(sell_ftl));
|
|
clearTimeout(timeoutSellFtl);
|
|
timeoutSellFtl = setTimeout(() => {
|
|
calcMarginNPercentFtl(sell_ftl, buy_ftl);
|
|
}, State.delay_typing_front);
|
|
});
|
|
let timeoutBuyFtl = null;
|
|
$('#add-buy_ftl').on('keyup', function(e) {
|
|
let sell_ftl = $('#add-sell_ftl').val().split('.').join('');
|
|
let buy_ftl = $('#add-buy_ftl').val().split('.').join('');
|
|
$('#add-buy_ftl').val((new Intl.NumberFormat('id-ID')).format(buy_ftl));
|
|
clearTimeout(timeoutBuyFtl);
|
|
timeoutBuyFtl = setTimeout(() => {
|
|
calcMarginNPercentFtl(sell_ftl, buy_ftl);
|
|
}, State.delay_typing_front);
|
|
});
|
|
},
|
|
getData: function() {
|
|
let data = {};
|
|
data.origin_prov = $('#add-origin_prov').val();
|
|
data.via = $('#add-via').val();
|
|
data.dest_prov = $('#add-dest_prov').val();
|
|
data.dest_city = $('#add-dest_city').val();
|
|
data.dest_district = $('#add-dest_district').val();
|
|
|
|
data.vendor_id = $('#add-vendor_id').val();
|
|
data.vhc_type_id = $('#add-vhc_type').val();
|
|
|
|
data.fast_time = $('#add-fast_time').val();
|
|
data.long_time = $('#add-long_time').val();
|
|
|
|
data.sell_kg = $('#add-sell_kg').val().split('.').join('');
|
|
data.buy_kg = $('#add-buy_kg').val().split('.').join('');
|
|
data.margin_kg = $('#add-margin_kg').val().split('.').join('');
|
|
data.percent_kg = $('#add-percent_kg').val();
|
|
|
|
data.sell_cbm = $('#add-sell_cbm').val().split('.').join('');
|
|
data.buy_cbm = $('#add-buy_cbm').val().split('.').join('');
|
|
data.margin_cbm = $('#add-margin_cbm').val().split('.').join('');
|
|
data.percent_cbm = $('#add-percent_cbm').val();
|
|
|
|
data.sell_ftl = $('#add-sell_ftl').val().split('.').join('');
|
|
data.buy_ftl = $('#add-buy_ftl').val().split('.').join('');
|
|
data.margin_ftl = $('#add-margin_ftl').val().split('.').join('');
|
|
data.percent_ftl = $('#add-percent_ftl').val();
|
|
|
|
if ($('#add-status').prop('checked')) {
|
|
data.status = State.stts_conf.active;
|
|
} else {
|
|
data.status = State.stts_conf.inactive;
|
|
}
|
|
|
|
return data;
|
|
},
|
|
submitData: async function(data) {
|
|
return new Promise((resolve, reject) => {
|
|
if (typeof $('#btnSubmitNewRate').attr('disabed') != 'undefined') {
|
|
resolve({
|
|
type: 'fail'
|
|
});
|
|
return false;
|
|
}
|
|
$('#btnSubmitNewRate').attr('disabed', true);
|
|
$.ajax({
|
|
url: "{{ route('api_conf_add_rate') }}",
|
|
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) => {
|
|
$('#btnSubmitNewRate').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 add new rate');
|
|
$('#mdlNewRate').modal('hide');
|
|
DTable.reload();
|
|
resolve({
|
|
type: 'success'
|
|
});
|
|
},
|
|
error: (jqXHR, textStatus, error) => {
|
|
$('#btnSubmitNewRate').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 RUpdt = {
|
|
activate: function() {
|
|
RUpdt.event();
|
|
},
|
|
event: function() {
|
|
// modal
|
|
$('#tRates').on('click', '.btnUpdtRate', async function(e) {
|
|
let rid = $(e.target).closest('tr').find('td[data-rid]').data('rid');
|
|
let resp = await RUpdt.reqData({
|
|
rid
|
|
});
|
|
if (resp.type != 'success') {
|
|
Helper.toast('Rate Not Found', 'just now', 'please try again');
|
|
return false;
|
|
}
|
|
RUpdt.passDataToView(resp.data);
|
|
});
|
|
$('#mdlEdtRate').on('shown.bs.modal', function() {
|
|
|
|
});
|
|
// button
|
|
$('#btnSubmitEdtRate').on('click', function() {
|
|
let data = RUpdt.getData();
|
|
RUpdt.submitData(data);
|
|
});
|
|
// input
|
|
$('#updt-dest_prov').on('change', async function(e) {
|
|
let list_city = await Req.list_city({
|
|
kodeProv: $('#updt-dest_prov').val(),
|
|
}, true);
|
|
if (list_city.type == 'success') {
|
|
$('#updt-dest_city').html('<option value="">Select Dest City</option>');
|
|
for (let city of list_city.resp.data) {
|
|
$('#updt-dest_city').append('<option value="' + city.kodeKab + '">' + city
|
|
.nmKotamadyaKel + '</option>');
|
|
}
|
|
}
|
|
});
|
|
$('#updt-dest_city').on('change', async function(e) {
|
|
let list_district = await Req.list_district({
|
|
kodeKab: $('#updt-dest_city').val(),
|
|
}, true);
|
|
if (list_district.type == 'success') {
|
|
$('#updt-dest_district').html('<option value="">Select Dest District</option>');
|
|
for (let district of list_district.resp.data) {
|
|
$('#updt-dest_district').append('<option value="' + district.kodeKec +
|
|
'">' + district
|
|
.nmKecamatanKel + '</option>');
|
|
}
|
|
}
|
|
});
|
|
|
|
function calcMarginNPercentKg(sell_kg, buy_kg) {
|
|
let margin = Wrapper.calcMargin(sell_kg, buy_kg);
|
|
let percent = Wrapper.calcPercentMargin(margin, buy_kg);
|
|
percent = (isNaN(percent)) ? 0 : percent;
|
|
$('#updt-margin_kg').val((new Intl.NumberFormat('id-ID')).format(margin));
|
|
$('#updt-percent_kg').val(percent);
|
|
}
|
|
let timeoutSellKg = null;
|
|
$('#updt-sell_kg').on('keyup', function(e) {
|
|
let sell_kg = $('#updt-sell_kg').val().split('.').join('');
|
|
let buy_kg = $('#updt-buy_kg').val().split('.').join('');
|
|
$('#updt-sell_kg').val((new Intl.NumberFormat('id-ID')).format(sell_kg));
|
|
clearTimeout(timeoutSellKg);
|
|
timeoutSellKg = setTimeout(() => {
|
|
calcMarginNPercentKg(sell_kg, buy_kg);
|
|
}, State.delay_typing_front);
|
|
});
|
|
let timeoutBuyKg = null;
|
|
$('#updt-buy_kg').on('keyup', function(e) {
|
|
let sell_kg = $('#updt-sell_kg').val().split('.').join('');
|
|
let buy_kg = $('#updt-buy_kg').val().split('.').join('');
|
|
$('#updt-buy_kg').val((new Intl.NumberFormat('id-ID')).format(buy_kg));
|
|
clearTimeout(timeoutBuyKg);
|
|
timeoutBuyKg = setTimeout(() => {
|
|
calcMarginNPercentKg(sell_kg, buy_kg);
|
|
}, State.delay_typing_front);
|
|
});
|
|
|
|
function calcMarginNPercentCbm(sell_cbm, buy_cbm) {
|
|
let margin = Wrapper.calcMargin(sell_cbm, buy_cbm);
|
|
let percent = Wrapper.calcPercentMargin(margin, buy_cbm);
|
|
percent = (isNaN(percent)) ? 0 : percent;
|
|
$('#updt-margin_cbm').val((new Intl.NumberFormat('id-ID')).format(margin));
|
|
$('#updt-percent_cbm').val(percent);
|
|
}
|
|
let timeoutSellCbm = null;
|
|
$('#updt-sell_cbm').on('keyup', function(e) {
|
|
let sell_cbm = $('#updt-sell_cbm').val().split('.').join('');
|
|
let buy_cbm = $('#updt-buy_cbm').val().split('.').join('');
|
|
$('#updt-sell_cbm').val((new Intl.NumberFormat('id-ID')).format(sell_cbm));
|
|
clearTimeout(timeoutSellCbm);
|
|
timeoutSellCbm = setTimeout(() => {
|
|
calcMarginNPercentCbm(sell_cbm, buy_cbm);
|
|
}, State.delay_typing_front);
|
|
});
|
|
let timeoutBuyCbm = null;
|
|
$('#updt-buy_cbm').on('keyup', function(e) {
|
|
let sell_cbm = $('#updt-sell_cbm').val().split('.').join('');
|
|
let buy_cbm = $('#updt-buy_cbm').val().split('.').join('');
|
|
$('#updt-buy_cbm').val((new Intl.NumberFormat('id-ID')).format(buy_cbm));
|
|
clearTimeout(timeoutBuyCbm);
|
|
timeoutBuyCbm = setTimeout(() => {
|
|
calcMarginNPercentCbm(sell_cbm, buy_cbm);
|
|
}, State.delay_typing_front);
|
|
});
|
|
|
|
function calcMarginNPercentFtl(sell_ftl, buy_ftl) {
|
|
let margin = Wrapper.calcMargin(sell_ftl, buy_ftl);
|
|
let percent = Wrapper.calcPercentMargin(margin, buy_ftl);
|
|
percent = (isNaN(percent)) ? 0 : percent;
|
|
$('#updt-margin_ftl').val((new Intl.NumberFormat('id-ID')).format(margin));
|
|
$('#updt-percent_ftl').val(percent);
|
|
}
|
|
let timeoutSellFtl = null;
|
|
$('#updt-sell_ftl').on('keyup', function(e) {
|
|
let sell_ftl = $('#updt-sell_ftl').val().split('.').join('');
|
|
let buy_ftl = $('#updt-buy_ftl').val().split('.').join('');
|
|
$('#updt-sell_ftl').val((new Intl.NumberFormat('id-ID')).format(sell_ftl));
|
|
clearTimeout(timeoutSellFtl);
|
|
timeoutSellFtl = setTimeout(() => {
|
|
calcMarginNPercentFtl(sell_ftl, buy_ftl);
|
|
}, State.delay_typing_front);
|
|
});
|
|
let timeoutBuyFtl = null;
|
|
$('#updt-buy_ftl').on('keyup', function(e) {
|
|
let sell_ftl = $('#updt-sell_ftl').val().split('.').join('');
|
|
let buy_ftl = $('#updt-buy_ftl').val().split('.').join('');
|
|
$('#updt-buy_ftl').val((new Intl.NumberFormat('id-ID')).format(buy_ftl));
|
|
clearTimeout(timeoutBuyFtl);
|
|
timeoutBuyFtl = setTimeout(() => {
|
|
calcMarginNPercentFtl(sell_ftl, buy_ftl);
|
|
}, State.delay_typing_front);
|
|
});
|
|
},
|
|
reqData: function(params) {
|
|
return new Promise((resolve, reject) => {
|
|
$.ajax({
|
|
url: "{{ route('api_conf_show_rate', '') }}/" + params.rid,
|
|
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-origin_prov').val(data.origin_prov).trigger('change');
|
|
$('#updt-via').val(data.lane).trigger('change');
|
|
$('#updt-dest_prov').val(data.dest_prov).trigger('change');
|
|
|
|
// $('#updt-dest_city').html('<option value="">Select Dest City</option>');
|
|
// $('#updt-dest_city').append(`<option value="${data.dest_city}" selected>${data.dest_city_name}</option>`).trigger('change');
|
|
let list_city = await Req.list_city({
|
|
kodeProv: $('#updt-dest_prov').val(),
|
|
}, true);
|
|
if (list_city.type == 'success') {
|
|
$('#updt-dest_city').html('<option value="">Select Dest City</option>');
|
|
for (let city of list_city.resp.data) {
|
|
$('#updt-dest_city').append('<option value="' + city.kodeKab + '">' + city
|
|
.nmKotamadyaKel + '</option>');
|
|
}
|
|
}
|
|
$('#updt-dest_city').val(data.dest_city).trigger('change');
|
|
|
|
let list_district = await Req.list_district({
|
|
kodeKab: $('#updt-dest_city').val(),
|
|
}, true);
|
|
if (list_district.type == 'success') {
|
|
$('#updt-dest_district').html('<option value="">Select Dest District</option>');
|
|
for (let district of list_district.resp.data) {
|
|
$('#updt-dest_district').append('<option value="' + district.kodeKec +
|
|
'">' + district
|
|
.nmKecamatanKel + '</option>');
|
|
}
|
|
}
|
|
$('#updt-dest_district').val(data.dest_district).trigger('change');
|
|
|
|
$('#updt-vendor_id').val(data.vdr_id).trigger('change');
|
|
$('#updt-vhc_type').val(data.vhc_type).trigger('change');
|
|
|
|
$('#updt-fast_time').val(data.fast_time);
|
|
$('#updt-long_time').val(data.long_time);
|
|
|
|
$('#updt-sell_kg').val((new Intl.NumberFormat('id-ID')).format(data.sell_kg));
|
|
$('#updt-buy_kg').val((new Intl.NumberFormat('id-ID')).format(data.buy_kg));
|
|
$('#updt-margin_kg').val((new Intl.NumberFormat('id-ID')).format(data.margin_kg));
|
|
$('#updt-percent_kg').val(data.percent_kg);
|
|
|
|
$('#updt-sell_cbm').val((new Intl.NumberFormat('id-ID')).format(data.sell_cbm));
|
|
$('#updt-buy_cbm').val((new Intl.NumberFormat('id-ID')).format(data.buy_cbm));
|
|
$('#updt-margin_cbm').val((new Intl.NumberFormat('id-ID')).format(data.margin_cbm));
|
|
$('#updt-percent_cbm').val(data.percent_cbm);
|
|
|
|
$('#updt-sell_ftl').val((new Intl.NumberFormat('id-ID')).format(data.sell_ftl));
|
|
$('#updt-buy_ftl').val((new Intl.NumberFormat('id-ID')).format(data.buy_ftl));
|
|
$('#updt-margin_ftl').val((new Intl.NumberFormat('id-ID')).format(data.margin_ftl));
|
|
$('#updt-percent_ftl').val(data.percent_ftl);
|
|
|
|
if (data.is_active == State.stts_conf.active) {
|
|
$('#updt-status').prop('checked', true);
|
|
} else {
|
|
$('#updt-status').prop('checked', false);
|
|
}
|
|
|
|
$('#mdlEdtRate').data('id', data.id);
|
|
$('#mdlEdtRate').modal('show');
|
|
},
|
|
getData: function() {
|
|
let data = {};
|
|
data.rid = $('#mdlEdtRate').data('id');
|
|
|
|
data.origin_prov = $('#updt-origin_prov').val();
|
|
data.via = $('#updt-via').val();
|
|
data.dest_prov = $('#updt-dest_prov').val();
|
|
data.dest_city = $('#updt-dest_city').val();
|
|
data.dest_district = $('#updt-dest_district').val();
|
|
|
|
data.vendor_id = $('#updt-vendor_id').val();
|
|
data.vhc_type_id = $('#updt-vhc_type').val();
|
|
|
|
data.fast_time = $('#updt-fast_time').val();
|
|
data.long_time = $('#updt-long_time').val();
|
|
|
|
data.sell_kg = $('#updt-sell_kg').val().split('.').join('');
|
|
data.buy_kg = $('#updt-buy_kg').val().split('.').join('');
|
|
data.margin_kg = $('#updt-margin_kg').val().split('.').join('');
|
|
data.percent_kg = $('#updt-percent_kg').val();
|
|
|
|
data.sell_cbm = $('#updt-sell_cbm').val().split('.').join('');
|
|
data.buy_cbm = $('#updt-buy_cbm').val().split('.').join('');
|
|
data.margin_cbm = $('#updt-margin_cbm').val().split('.').join('');
|
|
data.percent_cbm = $('#updt-percent_cbm').val();
|
|
|
|
data.sell_ftl = $('#updt-sell_ftl').val().split('.').join('');
|
|
data.buy_ftl = $('#updt-buy_ftl').val().split('.').join('');
|
|
data.margin_ftl = $('#updt-margin_ftl').val().split('.').join('');
|
|
data.percent_ftl = $('#updt-percent_ftl').val();
|
|
|
|
if ($('#updt-status').prop('checked')) {
|
|
data.status = State.stts_conf.active;
|
|
} else {
|
|
data.status = State.stts_conf.inactive;
|
|
}
|
|
|
|
return data;
|
|
},
|
|
submitData: async function(data) {
|
|
return new Promise((resolve, reject) => {
|
|
if (typeof $('#btnSubmitEdtRate').attr('disabed') != 'undefined') {
|
|
resolve({
|
|
type: 'fail'
|
|
});
|
|
return false;
|
|
}
|
|
$('#btnSubmitEdtRate').attr('disabed', true);
|
|
$.ajax({
|
|
url: "{{ route('api_conf_edit_rate', '') }}/" + data.rid,
|
|
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) => {
|
|
$('#btnSubmitEdtRate').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 rate');
|
|
$('#mdlEdtRate').modal('hide');
|
|
DTable.reload();
|
|
resolve({
|
|
type: 'success'
|
|
});
|
|
},
|
|
error: (jqXHR, textStatus, error) => {
|
|
$('#btnSubmitEdtRate').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 RDel = {
|
|
activate: function() {
|
|
RDel.event();
|
|
},
|
|
event: function() {
|
|
// on table
|
|
$('#tRates').on('click', '.btnDelRate', function(e) {
|
|
let row = $(e.target).closest('tr');
|
|
let rid = row.find('td[data-rid]').data('rid');
|
|
let code = row.find('td[data-code]').data('code');
|
|
RDel.passDataToView({
|
|
rid,
|
|
code,
|
|
});
|
|
$('#mdlDelRate').data('id', rid);
|
|
$('#mdlDelRate').modal('show');
|
|
});
|
|
$('#btnSubmitDelRate').on('click', function() {
|
|
let data = {
|
|
rid: $('#mdlDelRate').data('id'),
|
|
};
|
|
RDel.submitData(data);
|
|
});
|
|
// on modal update
|
|
$('#btnDelRate_updt').on('click', function (e) {
|
|
let data = RUpdt.getData();
|
|
RDel.passDataToView({
|
|
rid: data.rid,
|
|
code: '',
|
|
});
|
|
$('#mdlDelRate').data('id', data.rid);
|
|
$('#mdlDelRate').modal('show');
|
|
});
|
|
},
|
|
passDataToView: function(data) {
|
|
$('#del-code').text(data.code);
|
|
},
|
|
submitData: async function(data) {
|
|
return new Promise((resolve, reject) => {
|
|
if (typeof $('#btnSubmitDelRate').attr('disabed') != 'undefined') {
|
|
resolve({
|
|
type: 'fail'
|
|
});
|
|
return false;
|
|
}
|
|
$('#btnSubmitDelRate').attr('disabed', true);
|
|
$.ajax({
|
|
url: "{{ route('api_conf_del_rate', '') }}/" + data.rid,
|
|
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) => {
|
|
$('#btnSubmitDelRate').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 rate');
|
|
$('#mdlDelRate').modal('hide');
|
|
$('#mdlEdtRate').modal('hide');
|
|
DTable.reload();
|
|
resolve({
|
|
type: 'success'
|
|
});
|
|
},
|
|
error: (jqXHR, textStatus, error) => {
|
|
$('#btnSubmitDelRate').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
|