HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/quadcode/frontend/src/js/components/lp/saas_request/Range.js
const Range = () => {
  const elRange = document.querySelectorAll('[data-widget="range"]');

    elRange.forEach(range => {
      const rangeInput = document.querySelector('[data-input="range"]');
      const rangeValue = document.querySelector('[data-value="range"]');
      const itemsLabel = document.querySelectorAll('.range__item');

      rangeInput.addEventListener('input', (e) => {
        e.preventDefault();
        updateProgress(range, rangeInput);
        rangeValue.value = rangeInput.value;
      });

      itemsLabel.forEach(item => {
        item.addEventListener('click', () => {
          rangeInput.value = Number(item.dataset.value);
          rangeValue.value = Number(item.dataset.value);
          updateProgress(range, rangeInput);
        });
      });

      updateProgress(range, rangeInput);
    });
};

function updateProgress(slider, rangeInput) {
  let progress = slider.querySelector('[data-progress="range"]');
  let circles = slider.querySelectorAll('[data-circle="range"]');

  circles.forEach(item => {
    if (item.dataset.circleId <= rangeInput.value) {
      item.classList.add('active');
    } else {
      item.classList.remove('active');
    }
  });

  progress.style.width = getSliderPercent(rangeInput) * 100 + "%";
}

function getSliderPercent(slider) {
  const range = slider.max - slider.min;
  const absValue = slider.value - slider.min;
  return absValue / range;
}

export default Range;