summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortrisusilo48 <tri.susilo@altama.co.id>2024-08-09 14:28:50 +0700
committertrisusilo48 <tri.susilo@altama.co.id>2024-08-09 14:28:50 +0700
commitf04c0caea86bd5c41629de78f84e258432edb157 (patch)
tree439ff2fe8c9f80e874d3af6df9a83d7e28fe5677
parentea7e2cf8f768c3d3202c282182de6355b3ee32ee (diff)
parenta0c053de428bcf40a8435921023290a56bd7d8ea (diff)
Merge branch 'CR/tunning_query_solr' into development
-rw-r--r--src/pages/api/shop/search.js9
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