From 242aa4408e0c9e642570c6fda6a1eccdabd9c4b4 Mon Sep 17 00:00:00 2001 From: fnuesse Date: Fri, 17 Aug 2018 15:05:28 +0200 Subject: [PATCH] Added fallback if searchresult contains error on initial query --- js/fulltextsearch.v1.searchbox.js | 45 +++++++++++++++++++++++++++---- 1 file changed, 40 insertions(+), 5 deletions(-) diff --git a/js/fulltextsearch.v1.searchbox.js b/js/fulltextsearch.v1.searchbox.js index 8c297083..d637e4a8 100644 --- a/js/fulltextsearch.v1.searchbox.js +++ b/js/fulltextsearch.v1.searchbox.js @@ -49,11 +49,31 @@ var searchbox = { var self = this; - // we remove old search - var search_form = $('FORM.searchbox'); - if (search_form.length > 0) { - search_form.remove(); - } + var testquery={ + providers: settings.searchProviderId, + search: "testsearch", + page: curr.page, + options: null, + size: 20 + }; + + $.ajax({ + method: 'GET', + url: OC.generateUrl('/apps/fulltextsearch/v1/search'), + data: { + request: JSON.stringify(testquery) + } + }).done(function (res) { + if (_.has(res, 'error')) { + console.log("there was an error with the search! Contact admin."); + self.removeNewSearchbox(); + return; + } + self.removeOldSearchbox(); + }).fail(function () { + console.log("the searchrequest failed! Reload page."); + self.removeNewSearchbox(); + }); var divHeaderRight = $('DIV.header-right'); var divFullTextSearch = $('
', {id: 'fulltextsearch'}); @@ -86,6 +106,21 @@ var searchbox = { }, + removeOldSearchbox: function () { + // we remove old search + var search_form = $('FORM.searchbox'); + if (search_form.length > 0) { + search_form.remove(); + } + }, + + removeNewSearchbox: function () { + $('#fulltextsearch').remove(); + var search_form = $('FORM.searchbox'); + console.log(search_form); + search_form[0].title="There is an error with the fulltextsearch! Using normal search"; + }, + generateFullTextSearchIcon: function () { var className = 'icon-fulltextsearch';