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/one-time-popup/src/scripts/form/error-handler.ts
interface IError {
  [key: string]: string;
}

export const handle = (errors: IError = {}, form: HTMLFormElement, formName: string) => {
  if (!formName) {
    console.error('Error handling cannot be done due to missing the form name');
    return;
  }

  resetError(form);

  for (const inputName in errors) {
    const input = form.querySelector(`#${formName}-${inputName}`);

    if (!input) continue;

    const field = input.closest('.form-field') || input.closest('.checkbox');
    const error =
      field?.querySelector('.form-field__error') || field?.querySelector('.checkbox__error');

    if (error) {
      error.innerHTML = errors[inputName];
    }

    if (!field) continue;

    field.classList.add('error');
  }
};

export const resetError = (form?: HTMLFormElement) => {
  if (!form) return false;
  const field = form.querySelectorAll('.form-field.error');
  const checkbox = form.querySelectorAll('.checkbox.error');

  if (checkbox.length !== 0) {
    Array.from(checkbox).forEach((el) => el.classList.remove('error'));
  }

  if (field.length !== 0) {
    Array.from(field).forEach((el) => el.classList.remove('error'));
  }
};