HOME


Mini Shell 1.0
Redirecting to https://devs.lapieza.net/iniciar-sesion Redirecting to https://devs.lapieza.net/iniciar-sesion.
DIR: /var/www/devs.lapieza.net/resources/views/backend/setup_configurations/carriers/
Upload File :
Current File : /var/www/devs.lapieza.net/resources/views/backend/setup_configurations/carriers/edit.blade.php
@extends('backend.layouts.app')



@section('content')

    <div class="aiz-titlebar text-left mt-2 mb-3">

        <div class="row align-items-center">

            <div class="col-md-6">

                <h1 class="h3">{{ translate('Carrier Informations') }}</h1>

            </div>

            <div class="col-md-6 text-md-right">

                <a href="{{ route('carriers.index') }}" class="btn btn-primary">

                    <span>{{ translate('Back') }}</span>

                </a>

            </div>

        </div>

    </div>



    <div class="row">

        <div class="col-lg-12">

            <div class="card">

                <div class="card-header">

                    <h5 class="mb-0 h6">{{ translate('Carrier Information') }}</h5>

                </div>

                <div class="card-body">

                   <form  id="carrier-form">

                        <div class="alert alert-danger print-error-msg" style="display:none">

                            <ul class="m-0"></ul>

                        </div>



                        <input name="_method" type="hidden" value="PATCH">

                        @csrf

                        <div class="form-group row">

                            <label class="col-md-2 col-from-label">{{translate('Carrier Name')}} <span class="text-danger">*</span></label>

                            <div class="col-md-9">

                                <input type="text" class="form-control" name="carrier_name" value="{{ $carrier->name }}" placeholder="{{ translate('Carrier Name') }}" required>

                            </div>

                        </div>

                        <div class="form-group row">

                            <label class="col-md-2 col-from-label">{{translate('Transit Time')}} <span class="text-danger">*</span></label>

                            <div class="col-md-9">

                                <input type="text" class="form-control" name="transit_time" value="{{ $carrier->transit_time }}" placeholder="{{ translate('Transit Name') }}" required>

                            </div>

                        </div>

                        <div class="form-group row">

                            <label class="col-md-2 col-from-label">{{translate('Logo')}} <span class="text-danger">*</span></label>

                            <div class="col-md-9">

                                <div class="input-group" data-toggle="aizuploader" data-type="image">

                                    <div class="input-group-prepend">

                                        <div class="input-group-text bg-soft-secondary font-weight-medium">{{ translate('Browse')}}</div>

                                    </div>

                                    <div class="form-control file-amount">{{ translate('Choose File') }}</div>

                                    <input type="hidden" name="logo" class="selected-files" value="{{ $carrier->logo }}">

                                </div>

                                <div class="file-preview box sm">

                                </div>

                            </div>

                        </div>

                        <div class="form-group row">

                            <label class="col-md-2 col-from-label">{{translate('Free Shipping')}} ? </label>

                            <div class="col-md-9">

                                <label class="aiz-switch aiz-switch-success mb-0">

                                    <input type="checkbox" name="shipping_type" onchange="freeShipping(this)" id="shipping_type" @if($carrier->free_shipping == 1) checked @endif>

                                    <span></span>

                                </label>

                            </div>

                        </div>

                        

                        <div class="form-group row" id="billing_type_section">

                            <label class="col-md-2 col-from-label">{{translate('Billing Type')}} <span class="text-danger">*</span></label>

                            <div class="col-md-9">

                                <select class="form-control aiz-selectpicker" name="billing_type" onchange="update_price_range_form()" data-selected="{{ $carrier->carrier_ranges->first()->billing_type ?? '' }}"  id="billing_type" data-live-search="true">

                                    <option value="weight_based">{{ translate('According to Weight') }}</option>

                                    <option value="price_based">{{ translate('According to Price') }}</option>

                                </select>

                            </div>

                        </div>



                        {{-- carrier Price Range form --}}

                        <div id="price_range_form">

                            <div class="card-header mb-2 pl-0">

                                <h3 class="h6 carrier_range_form_header_text"></h3>

                            </div>

                            <table id="price-range-table" class="table table-responsive mb-0">

                                <tbody>

                                    

                                    <tr style="background-color: #c9c9d4">

                                        <td class="price_range_text"></td>

                            

                                        <td> >= </td>

                                        @foreach($carrier->carrier_ranges as $carrier_range)

                                            <td>

                                                <div class="input-group mb-2">

                                                    <div class="input-group-prepend">

                                                        <div class="input-group-text bill_based_on"></div>

                                                    </div>

                                                    <input type="number" class="form-control delimiter1" name="delimiter1[]" value="{{ $carrier_range->delimiter1 }}" step="0.01">

                                                </div>

                                            </td>

                                        @endforeach

                                        @if (count($carrier->carrier_ranges)==0)

                                            <td>

                                                <div class="input-group mb-2">

                                                    <div class="input-group-prepend">

                                                        <div class="input-group-text bill_based_on"></div>

                                                    </div>

                                                    <input type="number" class="form-control delimiter1" name="delimiter1[]"

                                                        value="0.00" step="0.01">

                                                </div>

                                            </td>

                                        @endif

                                    </tr>

                                    <tr style="background-color: #c9c9d1">

                                        <td class="price_range_text"></td>

                                        <td> < </td>

                                        @foreach($carrier->carrier_ranges as $carrier_range)

                                            <td>

                                                <div class="input-group mb-2">

                                                    <div class="input-group-prepend">

                                                        <div class="input-group-text bill_based_on"></div>

                                                    </div>

                                                    <input type="number" class="form-control delimiter2" name="delimiter2[]" value="{{ $carrier_range->delimiter2 }}" step="0.01">

                                                </div>

                                            </td>

                                        @endforeach

                                        @if (count($carrier->carrier_ranges)==0)

                                            <td>

                                                <div class="input-group mb-2">

                                                    <div class="input-group-prepend">

                                                        <div class="input-group-text bill_based_on"></div>

                                                    </div>

                                                    <input type="number" class="form-control delimiter2" name="delimiter2[]"

                                                        value="0.00" step="0.01">

                                                </div>

                                            </td>

                                        @endif

                                    </tr>

                            

                                    @foreach ($zones as $key => $zone)

                                        <tr>

                                            <td>

                                                <span class="mt-2">{{ $zone->name }}</span>

                                            </td>

                                            @php 

                                                $selected_zones = $carrier->carrier_range_prices->unique('zone_id')->pluck('zone_id')->toArray();

                                            @endphp

                                            <td>

                                                <input class="aiz-square-check zone_enable mt-2" type="checkbox" name="zones[]" value="{{ $zone->id }}" @if(in_array($zone->id, $selected_zones)) checked @endif>

                                            </td>

                                            @foreach($carrier->carrier_ranges as $key => $carrier_range)

                                                @php

                                                    $carrier_range_price = $carrier_range->carrier_range_prices->where('zone_id',$zone->id)->first(); 

                                                @endphp

                                                <td>

                                                    <div class="input-group mb-2">

                                                        <div class="input-group-prepend">

                                                        <div class="input-group-text">$</div>

                                                        </div>

                                                        <input type="number" class="form-control shipping_cost" name="carrier_price[{{ $zone->id }}][]" value="{{ $carrier_range_price->price ?? null }}" placeholder="{{ translate('cost') }}" @if(! in_array($zone->id, $selected_zones)) disabled @endif required>

                                                    </div>

                                                </td>

                                            @endforeach

                                            @if (count($carrier->carrier_ranges)==0)

                                                <td>

                                                    <div class="input-group mb-2">

                                                        <div class="input-group-prepend">

                                                            <div class="input-group-text">$</div>

                                                        </div>

                                                        <input type="number" class="form-control shipping_cost"

                                                            name="carrier_price[{{ $zone->id }}][]"

                                                            placeholder="{{ translate('cost') }}" disabled required>

                                                    </div>

                                                </td>

                                            @endif

                                        </tr>

                                        @endforeach

                                        <tr>

                                            <td></td>

                                            <td></td>

                                            @foreach($carrier->carrier_ranges as $key => $carrier_range)

                                            <td>

                                                @if($key == 0) 

                                                    @continue

                                                @endif

                                                <button type="button" id="disablebtn" class="btn btn-primary btn-sm delete-range">Delete</button>

                                            </td>

                                            @endforeach

                                        </tr>

                                </tbody>

                            </table>

                            <button type="button" class="btn btn-primary btn-sm" id="addNewRange">{{ translate('Add new range') }}</button>

                        </div>

                       



                        <div class="form-group mb-0 text-right">

                            <button type="button" class="btn btn-primary" id="carrier-submit-btn">{{translate('Update Carrier Informations')}}</button>

                        </div>

                    </form>



                </div>

            </div>

        </div>

    </div>

@endsection



@section('script')

<script type="text/javascript">



    $(document).ready(function(){

        update_price_range_form();

        freeShipping();

    });



    function freeShipping(){

        var billing_type = "{{ $carrier->carrier_ranges->first()->billing_type ?? 'weight_based' }}";

        if($('#shipping_type').is(":checked")){

            $("#billing_type_section").hide();

            $("#price_range_form").hide();

            $("#billing_type").val().change();

        }

        else{

            $("#billing_type_section").show();

            $("#price_range_form").show();

            $("#billing_type").val(billing_type).change();

        }

    }

    

    // update price range form data based on billing type

    function update_price_range_form(){

        var billing_type = $('#billing_type').val();

        

        $(".carrier_range_form_header_text").html(billing_type === 'weight_based' 

            ? "{{translate('Weight based carrier price range')}}" 

            : "{{translate('Price based carrier price range')}}");

        $(".price_range_text").html(billing_type === 'weight_based' 

            ? "{{ translate('Will be applied when the weight is') }}" 

            : "{{ translate('Will be applied when the price is') }}");

        $(".bill_based_on").html(billing_type === 'weight_based' ? "{{ translate('kg') }}" : "$");

     

    }



    // disabled untill check

    $(document).on("change", ".zone_enable", function() {

        $(this).closest("tr").find('.shipping_cost').prop("disabled", !this.checked);

    });





    $(document).on("click", "#addNewRange", function() {

        //table body

        var tablebody = $("#price-range-table").find("tbody");

        var tdlenght = tablebody.find("tr td").length;

        // console.log(tdlenght);





        // last td input 

        var first_lasttd = $("#price-range-table").find("tr:nth-child(1)").find("td:last").find("input").val();

        var second_lasttd = $("#price-range-table").find("tr:nth-child(2)").find("td:last").find("input").val();



        if ((second_lasttd == 0) || (second_lasttd == first_lasttd) ||

            ((second_lasttd - first_lasttd) < 0)) {

            alert('Please validate the last range before creating a new one.')

        } else {

            // clonning last tds

            fnclone(tablebody, second_lasttd);

        }



    });



    // last td remove

    $(document).on("click", ".delete-range", function() {

        var iIndex = $(this).closest("td").prevAll("td").length;

        $(this).parents("#price-range-table").find("tr").each(function() {

            $(this).find("td:eq(" + iIndex + ")").remove();

        });

    });





    // last td clone function

    function fnclone(tablebody, second_lasttd) {

        tablebody.find("td:nth-last-child(1)").each(function() {

            $(this).clone()

            .find("input").val("").end()

            .insertAfter(this);

        }); 



        $('#price-range-table tr:last td:last').html('<button type="button" id="disablebtn" class="btn btn-primary btn-sm delete-range">Delete</button>');



        var first_lasttd = $("#price-range-table").find("tr:nth-child(1)").find("td:last").find("input");

        first_lasttd.val(parseFloat(second_lasttd).toFixed(2));

    }



    $("#carrier-submit-btn").click(function() {

            var data = new FormData($('#carrier-form')[0]);

            if(!$('input[name=shipping_type]').prop('checked')){

                var delimiter1 = $('.delimiter1');

                var delimiter2 = $('.delimiter2');



                for (let i = 0; i < delimiter1.length; i++) {

                    if (delimiter1[i].value && delimiter2[i].value) {

                        if (parseFloat(delimiter1[i].value) >= parseFloat(delimiter2[i].value)) {

                            alert('Please put the last range greater than first range.');

                            delimiter2[i].focus();

                            return false

                        }

                        if (i>0 && (parseFloat(delimiter1[i].value) != parseFloat(delimiter2[(i-1)].value))) {

                            alert('Please put the first range equal to the previous last range.');

                            delimiter1[(i)].focus();

                            return false

                        }

                    }

                }

            }



            $.ajax({

                headers: {

                    'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')

                },

                method: "POST",

                url: "{{ route('carriers.update', $carrier->id) }}",

                data: data,

                cache: false,

                contentType: false,

                processData: false,

                success: function(data, textStatus, jqXHR) {



                }

            }).done(function(data) {

                window.location.replace("{{ route('carriers.index') }}");

            }).fail(function(jqXHR, textStatus, errorThrown) {

                $(".print-error-msg").find("ul").html('');

                $(".print-error-msg").css('display', 'block');

                $.each(jqXHR.responseJSON.errors, function(key, value) {

                    $(".print-error-msg").find("ul").append('<li>' + value[0] + '</li>');

                });



                $("html, body").animate({scrollTop: 0}, 800);

            });

        })



</script>

@endsection