/home/lnzliplg/www/wp-content/themes/lawyer-hub/assets/js/controls/range.js
jQuery(document).ready(function ($) {

    'use strict';

       // Range JS
    $('.customize-control-ms-range-slider').each(function () {
        var sliderValue = $(this).find('.ms-slider-input').val();
        var newSlider = $(this).find('.ms-range-slider');
        var sliderMinValue = parseFloat(newSlider.attr('slider-min-value'));
        var sliderMaxValue = parseFloat(newSlider.attr('slider-max-value'));
        var sliderStepValue = parseFloat(newSlider.attr('slider-step-value'));
        newSlider.slider({
            value: sliderValue,
            min: sliderMinValue,
            max: sliderMaxValue,
            step: sliderStepValue,
            range: 'min',
            slide: function (e, ui) {
                $(this).parent().find('.ms-slider-input').trigger('change');
            },
            change: function (e, ui) {
                $(this).parent().find('.ms-slider-input').trigger('change');
            }
        });
    });

    // Change the value of the input field as the slider is moved
    $('.customize-control-ms-range-slider .ms-range-slider').on('slide', function (event, ui) {
        $(this).parent().find('.ms-slider-input').val(ui.value);
    });
    
    // Reset slider and input field back to the default value
    $('.customize-control-ms-range-slider .ms-slider-reset').on('click', function () {
        var resetValue = $(this).attr('slider-reset-value');
        $(this).parents('.customize-control-ms-range-slider').find('.ms-slider-input').val(resetValue);
        $(this).parents('.customize-control-ms-range-slider').find('.ms-range-slider').slider('value', resetValue);
    });

    // Update slider if the input field loses focus as it's most likely changed
    $('.customize-control-ms-res-range-slider .ms-slider-input').blur(function () {
        var resetValue = $(this).val();
        var slider = $(this).parents('.customize-control-ms-range-slider').find('.ms-range-slider');
        var sliderMinValue = parseInt(slider.attr('slider-min-value'));
        var sliderMaxValue = parseInt(slider.attr('slider-max-value'));
        // Make sure our manual input value doesn't exceed the minimum & maxmium values
        if (resetValue < sliderMinValue) {
            resetValue = sliderMinValue;
            $(this).val(resetValue);
        }
        if (resetValue > sliderMaxValue) {
            resetValue = sliderMaxValue;
            $(this).val(resetValue);
        }
        $(this).parents('.customize-control-ms-range-slider').find('.ms-range-slider').slider('value', resetValue);
    });
});