import { $, $$ } from './utils/dom';
import { addTag } from './tagsinput';

function showHelp(subject, type) {
  $$('[data-search-help]').forEach(helpBox => {
    if (helpBox.getAttribute('data-search-help') === type) {
      $('.js-search-help-subject', helpBox).textContent = subject;
      helpBox.classList.remove('hidden');
    }
    else {
      helpBox.classList.add('hidden');
    }
  });
}

function prependToLast(field, value) {
  const separatorIndex = field.value.lastIndexOf(',');
  const advanceBy = field.value[separatorIndex + 1] === ' ' ? 2 : 1;
  field.value = field.value.slice(0, separatorIndex + advanceBy) + value + field.value.slice(separatorIndex + advanceBy);
}

function selectLast(field, characterCount) {
  field.focus();

  field.selectionStart = field.value.length - characterCount;
  field.selectionEnd = field.value.length;
}

function executeFormHelper(e) {
  const searchField = $('.js-search-field');
  const attr = name => e.target.getAttribute(name);

  attr('data-search-add') && addTag(searchField, attr('data-search-add'));
  attr('data-search-show-help') && showHelp(e.target.textContent, attr('data-search-show-help'));
  attr('data-search-select-last') && selectLast(searchField, parseInt(attr('data-search-select-last'), 10));
  attr('data-search-prepend') && prependToLast(searchField, attr('data-search-prepend'));
}

function setupSearch() {
  const form = $('.js-search-form');

  form && form.addEventListener('click', executeFormHelper);
}

export { setupSearch };