From 7db5b7698eb03b39bfbaa73b157343534c35386f Mon Sep 17 00:00:00 2001 From: Santhoshkumar <117272529+Santhosh-testsigma@users.noreply.github.com> Date: Tue, 6 Aug 2024 18:24:05 +0530 Subject: [PATCH] [Fixed] -> Search results repeating issue on typesense search (#96) --- scripts/indexr.js | 28 ++++++++++++++++++++++++++++ src/components/SearchHits.scss | 8 +++++--- src/components/SearchInputBox.jsx | 10 ++++++---- src/components/layout.jsx | 1 - 4 files changed, 39 insertions(+), 8 deletions(-) diff --git a/scripts/indexr.js b/scripts/indexr.js index d11c3a3..087b149 100644 --- a/scripts/indexr.js +++ b/scripts/indexr.js @@ -64,6 +64,34 @@ async function indexData() { apiKey: process.env.TYPESENSE_API_KEY, }); + let collectionExists = false; + try { + await client.collections(process.env.TYPESENSE_COLLECTION).retrieve(); + collectionExists = true; + } catch (error) { + if (error.httpStatus !== 404) { + throw error; + } + } + + if (collectionExists) { + await client.collections(process.env.TYPESENSE_COLLECTION).delete(); + console.log(`Collection ${process.env.TYPESENSE_COLLECTION} deleted successfully.`); + } + + await client.collections().create({ + name: process.env.TYPESENSE_COLLECTION, + fields: [ + { name: 'objectID', type: 'string' }, + { name: 'title', type: 'string' }, + { name: 'search_keyword', type: 'string' }, + { name: 'slug', type: 'string' }, + { name: 'excerpt', type: 'string' }, + { name: 'headings', type: 'string[]', facet: false } + ] + }); + console.log(`Collection ${process.env.TYPESENSE_COLLECTION} created successfully.`); + const response = await request('http://localhost:8001/___graphql', pageQuery); console.log('response', response); const data = await response; diff --git a/src/components/SearchHits.scss b/src/components/SearchHits.scss index 9241341..c32e227 100644 --- a/src/components/SearchHits.scss +++ b/src/components/SearchHits.scss @@ -1,8 +1,10 @@ @import '_variables.scss'; ais-highlight-0000000000 { - color: $grey_90; - background-color: $yellow_20; + color: $white; + background-color: #00b2bd; + padding: 0 6px; + border-radius: 4px; } .input-empty { @@ -28,7 +30,7 @@ ais-highlight-0000000000 { text-decoration: none; } p { - margin: 6px 0; + margin: 6px 0 !important; font-size: 14px; line-height: 20px; overflow-wrap: break-word; diff --git a/src/components/SearchInputBox.jsx b/src/components/SearchInputBox.jsx index e418f20..7975bb7 100644 --- a/src/components/SearchInputBox.jsx +++ b/src/components/SearchInputBox.jsx @@ -62,7 +62,7 @@ class SearchInputBox extends React.Component { searchQuery: '' }; - this.debouncedSearch = debounce(this.handleSearch, 300); + this.debouncedSearch = debounce(this.handleSearch, 500); } onClickOut = (event) => { @@ -80,9 +80,11 @@ class SearchInputBox extends React.Component { hasInput: query.length > 2, }); - this.setState({ searchQuery: '' }, () => { - this.debouncedSearch(query); - }); + if (this.state.searchQuery !== query) { + this.setState({ searchQuery: '' }, () => { + this.debouncedSearch(query); + }); + } } handleSearch = (query) => { diff --git a/src/components/layout.jsx b/src/components/layout.jsx index 1e32367..79ccb2e 100644 --- a/src/components/layout.jsx +++ b/src/components/layout.jsx @@ -52,7 +52,6 @@ class Layout extends React.Component { const navElement = document.querySelector( `.contextual-links a.dynamic-link__internal[href*="#${entry.target.id}"]`, ) - console.log(entry); if (entry.isIntersecting) { if (navElement && !navElement.classList.contains('border-red-100')) { document.querySelectorAll('.contextual-links__link a.border-red-100.border-b-2').forEach(previousActive => {