mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 08:36:12 +01:00
feat: quick search changes
This commit is contained in:
@@ -498,10 +498,7 @@ app.cacheBuster = null;
|
||||
search.quick({
|
||||
term: inputEl.val(),
|
||||
in: 'titles',
|
||||
}, {
|
||||
template: options.template,
|
||||
resultEl: quickSearchResults,
|
||||
});
|
||||
}, options);
|
||||
});
|
||||
}, 250);
|
||||
});
|
||||
@@ -511,7 +508,7 @@ app.cacheBuster = null;
|
||||
var searchButton = $('#search-button');
|
||||
var searchFields = $('#search-fields');
|
||||
var searchInput = $('#search-fields input');
|
||||
var quickSearchResults = $('#quick-search-results');
|
||||
var quickSearchContainer = $('#quick-search-container');
|
||||
|
||||
$('#search-form .advanced-search-link').off('mousedown').on('mousedown', function () {
|
||||
ajaxify.go('/search');
|
||||
@@ -522,21 +519,21 @@ app.cacheBuster = null;
|
||||
});
|
||||
searchInput.off('blur').on('blur', dismissSearch);
|
||||
searchInput.off('focus').on('focus', function () {
|
||||
if (searchInput.val() && quickSearchResults.children().length) {
|
||||
quickSearchResults.removeClass('hidden').show();
|
||||
if (searchInput.val() && quickSearchContainer.find('#quick-search-results').children().length) {
|
||||
quickSearchContainer.removeClass('hidden');
|
||||
}
|
||||
});
|
||||
|
||||
app.enableTopicSearch({
|
||||
inputEl: searchInput,
|
||||
resultEl: quickSearchResults,
|
||||
resultEl: quickSearchContainer,
|
||||
});
|
||||
|
||||
function dismissSearch() {
|
||||
searchFields.addClass('hidden');
|
||||
searchButton.removeClass('hidden');
|
||||
setTimeout(function () {
|
||||
quickSearchResults.addClass('hidden');
|
||||
quickSearchContainer.addClass('hidden');
|
||||
}, 200);
|
||||
}
|
||||
|
||||
|
||||
@@ -39,13 +39,16 @@ define('search', ['navigator', 'translator', 'storage'], function (nav, translat
|
||||
$(window).trigger('action:search.quick', { data: query });
|
||||
query.searchOnly = 1;
|
||||
Search.api(query, function (data) {
|
||||
if (options.hideOnNoMatches && !data.posts.length) {
|
||||
return options.resultEl.html('').addClass('hidden');
|
||||
}
|
||||
data.posts.forEach(function (p) {
|
||||
p.snippet = utils.escapeHTML($('<div>' + p.content + '</div>').text().slice(0, 80) + '...');
|
||||
});
|
||||
app.parseAndTranslate(template, data, function (html) {
|
||||
if (html.length) {
|
||||
html.find('.timeago').timeago();
|
||||
options.resultEl.html(html).removeClass('hidden').show();
|
||||
options.resultEl.html(html).removeClass('hidden');
|
||||
} else {
|
||||
options.resultEl.html('').addClass('hidden');
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user