mirror of
https://github.com/philomena-dev/philomena.git
synced 2024-11-27 13:47:58 +01:00
45 lines
1.5 KiB
JavaScript
45 lines
1.5 KiB
JavaScript
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 };
|