diff options
| author | trisusilo48 <tri.susilo@altama.co.id> | 2024-08-09 14:28:50 +0700 |
|---|---|---|
| committer | trisusilo48 <tri.susilo@altama.co.id> | 2024-08-09 14:28:50 +0700 |
| commit | f04c0caea86bd5c41629de78f84e258432edb157 (patch) | |
| tree | 439ff2fe8c9f80e874d3af6df9a83d7e28fe5677 /src | |
| parent | ea7e2cf8f768c3d3202c282182de6355b3ee32ee (diff) | |
| parent | a0c053de428bcf40a8435921023290a56bd7d8ea (diff) | |
Merge branch 'CR/tunning_query_solr' into development
Diffstat (limited to 'src')
| -rw-r--r-- | src/pages/api/shop/search.js | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/pages/api/shop/search.js b/src/pages/api/shop/search.js index 87d62a1a..7b7a80b5 100644 --- a/src/pages/api/shop/search.js +++ b/src/pages/api/shop/search.js @@ -47,7 +47,7 @@ export default async function handler(req, res) { break; } - let checkQ = q.trim().split(/\s+/); + let checkQ = q.trim().split(/[\s\+\-\!\(\)\{\}\[\]\^"~\*\?:\\\/]+/); let newQ = checkQ.length > 1 ? escapeSolrQuery(q) + '*' : escapeSolrQuery(q); let offset = (page - 1) * limit; @@ -132,12 +132,14 @@ export default async function handler(req, res) { const escapeSolrQuery = (query) => { if (query == '*') return query; + + query = query.replace(/-/g, ' '); - const specialChars = /([\+\-\!\(\)\{\}\[\]\^"~\*\?:\\\/])/g; + const specialChars = /([\+\!\(\)\{\}\[\]\^"~\*\?:\\\/])/g; const words = query.split(/\s+/); const escapedWords = words.map((word) => { if (specialChars.test(word)) { - return `"${word.replace(specialChars, '\\$1')}"`; + return word.replace(specialChars, '\\$1'); } return word; }); @@ -145,6 +147,7 @@ const escapeSolrQuery = (query) => { return escapedWords.join(' '); }; + /*const productResponseMap = (products, pricelist) => { return products.map((product) => { let price = product.price_tier1_v2_f || 0 |
