philomena/assets/js/search.js

46 lines
1.5 KiB
JavaScript
Raw Permalink Normal View History

2019-10-05 02:09:52 +02:00
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 };