mirror of
https://github.com/philomena-dev/philomena.git
synced 2025-01-19 22:27:59 +01:00
Merge pull request #383 from koloml/support-minus-prefix-for-single-tags
Support suggestions when using `-tag` syntax in tag editor
This commit is contained in:
commit
38af26db71
2 changed files with 23 additions and 6 deletions
|
@ -44,7 +44,13 @@ function applySelectedValue(selection: string) {
|
|||
if (!inputField) return;
|
||||
|
||||
if (!isSearchField(inputField)) {
|
||||
inputField.value = selection;
|
||||
let resultValue = selection;
|
||||
|
||||
if (originalTerm?.startsWith('-')) {
|
||||
resultValue = `-${selection}`;
|
||||
}
|
||||
|
||||
inputField.value = resultValue;
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -121,6 +127,10 @@ function toggleSearchAutocomplete() {
|
|||
}
|
||||
}
|
||||
|
||||
function trimPrefixes(targetTerm: string): string {
|
||||
return targetTerm.trim().replace(/^-/, '');
|
||||
}
|
||||
|
||||
function listenAutocomplete() {
|
||||
let serverSideSuggestionsTimeout: number | undefined;
|
||||
|
||||
|
@ -162,7 +172,7 @@ function listenAutocomplete() {
|
|||
}
|
||||
|
||||
const suggestions = localAc
|
||||
.matchPrefix(originalTerm)
|
||||
.matchPrefix(trimPrefixes(originalTerm))
|
||||
.topK(suggestionsCount)
|
||||
.map(({ name, imageCount }) => ({ label: `${name} (${imageCount})`, value: name }));
|
||||
|
||||
|
@ -181,13 +191,13 @@ function listenAutocomplete() {
|
|||
inputField = targetedInput;
|
||||
originalTerm = inputField.value;
|
||||
|
||||
const fetchedTerm = inputField.value;
|
||||
const fetchedTerm = trimPrefixes(inputField.value);
|
||||
|
||||
if (minTermLength && fetchedTerm.length < parseInt(minTermLength, 10)) return;
|
||||
|
||||
fetchSuggestions(endpointUrl, fetchedTerm).then(suggestions => {
|
||||
// inputField could get overwritten while the suggestions are being fetched - use previously targeted input
|
||||
if (fetchedTerm === targetedInput.value) {
|
||||
if (fetchedTerm === trimPrefixes(targetedInput.value)) {
|
||||
popup.renderSuggestions(suggestions).showForField(targetedInput);
|
||||
}
|
||||
});
|
||||
|
@ -222,8 +232,12 @@ function listenAutocomplete() {
|
|||
const originalSuggestion = event.detail;
|
||||
applySelectedValue(originalSuggestion.value);
|
||||
|
||||
if (originalTerm?.startsWith('-')) {
|
||||
originalSuggestion.value = `-${originalSuggestion.value}`;
|
||||
}
|
||||
|
||||
inputField.dispatchEvent(
|
||||
new CustomEvent('autocomplete', {
|
||||
new CustomEvent<TermSuggestion>('autocomplete', {
|
||||
detail: Object.assign(
|
||||
{
|
||||
type: 'click',
|
||||
|
|
|
@ -112,7 +112,10 @@ export function setupTagsInput(tagBlock: HTMLDivElement) {
|
|||
name = name.slice(1); // eslint-disable-line no-param-reassign
|
||||
const tagLink = assertNotNull($(`[data-tag-name="${escapeCss(name)}"]`, container));
|
||||
|
||||
return removeTag(name, assertNotNull(tagLink.parentElement));
|
||||
removeTag(name, assertNotNull(tagLink.parentElement));
|
||||
inputField.value = '';
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
tags.push(name);
|
||||
|
|
Loading…
Reference in a new issue