
Миграция с AjaxForm 
В данном разделе представлена информация о миграции с AjaxForm на FetchIt.
Стили 
FetchIt не регистрирует никакие стили. Поэтому в вашей вёрстке уже должны быть предусмотрены стили отвечающие за невалидное состояние полей и должны быть добавлены в системную настройки fetchit.frontend.input.invalid.class и fetchit.frontend.custom.invalid.class.
Всплывающие сообщения 
В отличии от AjaxForm у которого в коробке идёт зависимость в виде jGrowl, мы предоставляем возможность добавить любую готовую библиотеку или вашу собственную несколькими строчками кода.
В этой документации есть целый раздел с подключением всех популярных и не очень библиотек.
Вызов сниппета 
Сниппет FetchIt сохранил основные параметры нетронутыми, но мы перенесли некоторые из них в системные настройки.
[[!FetchIt?
  &form=`название чанка`
  &snippet=`FormIt`
  &actionUrl=`[[+assetsUrl]]action.php`
  &clearFieldsOnSuccess=`1`
  &frontend_js=`` // [!code warning] Системная настройка: fetchit.frontend.js
  &objectName=`` // [!code warning] Системная настройка: fetchit.frontend.js.classname
  &frontend_css=``
  &formSelector=``
]]{'!FetchIt' | snippet : [
  'form' => 'название чанка',
  'snippet' => 'FormIt',
  'actionUrl' => '[[+assetsUrl]]action.php',
  'clearFieldsOnSuccess' => true,
  'frontend_js' => '', // [!code warning] Системная настройка: fetchit.frontend.js
  'objectName' => '', // [!code warning] Системная настройка: fetchit.frontend.js.classname
  'frontend_css' => '', 
  'formSelector' => '', 
]}Разметка формы 
Сама разметка формы не изменилась, а лишь изменились селекторы. Посмотрим на чанк с формой, который идёт в комплекте с AjaxForm и наглядно покажем изменения:
<form action="[[~[[*id]]]]" method="post" class="ajax_form"> 
<form action="[[~[[*id]]]]" method="post"> 
  <div class="form-group">
    <label class="control-label">Имя</label>
    <div class="controls">
      <input type="text" name="name" value="[[+fi.name]]" class="form-control"/>
      <span class="error_name">[[+fi.error.name]]</span> 
      <span data-error="name">[[+fi.error.name]]</span> 
    </div>
  </div>
  <div class="form-group">
    <label class="control-label">Email</label>
    <div class="controls">
      <input type="email" name="email" value="[[+fi.email]]" class="form-control"/>
      <span class="error_email">[[+fi.error.email]]</span> 
      <span data-error="email">[[+fi.error.email]]</span> 
    </div>
  </div>
  <div class="form-group">
    <label class="control-label">Сообщение</label>
    <div class="controls">
      <textarea name="message" class="form-control" rows="5">[[+fi.message]]</textarea>
      <span class="error_message">[[+fi.error.message]]</span> 
      <span data-error="message">[[+fi.error.message]]</span> 
    </div>
  </div>
  <div class="form-group">
    <div class="controls">
      <button type="reset" class="btn btn-default">Сбросить</button>
      <button type="submit" class="btn btn-primary">Отправить</button>
    </div>
  </div>
</form>Валидация на стороне клиента 
Если у вас была валидация на стороне клиента в таком виде:
$(document).on('submit', '.ajax_form', function() {
  // Код валидации
  afValidated = false;
});То вам нужно переписать ваш код так:
document.addEventListener('fetchit:before', (e) => {
  const { form, fetchit } = e.detail; // Получаем форму и экземпляр класса FetchIt
  // Код валидации
  // Если не прошла валидация
  fetchit.setError('название_поля', 'Выводимое сообщение'); // Необязательно
  e.preventDefault();
  // Если прошла, то можем ничего не делать
});Важно!
Валидация на стороне клиента небезопасна и должна быть реализована только для удобства пользователя.
Событие af_complete 
У AjaxForm есть одно событие, и оно срабатывает после ответа сервера. Аналогичным событием является fetchit:after.
Помните
Событие fetchit:after срабатывает в любом случае после ответа сервера, вне зависимости от её статуса.
Если вам необходимо реализовать функционал в зависимости от статуса, то воспользуйтесь событиями fetchit:success и fetchit:error.
Было:
$(document).on('af_complete', function(event, response) {
  var form = response.form;
  // Если у формы определённый id
  if (form.attr('id') == 'my_form_3') {
    // Скрываем её!
    form.hide();
  }
  // Иначе печатаем в консоль весь ответ
  else {
    console.log(response)
  }
});Стало:
document.addEventListener('fetchit:after', (e) => {
  const { form, response } = e.detail;
  // Если у формы определённый id
  if (form.getAttribute('id') === 'my_form_3') {
    // Скрываем её!
    form.style.display = 'none';
  }
  // Иначе печатаем в консоль весь ответ
  else {
    console.log(response);
  }
});Обратите внимание
События компонента FetchIt не возвращают jQuery Object и не имеют ничего общего с jQuery и поэтому у form естественно не будет методов attr() или hide().
