summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorit-fixcomart <it@fixcomart.co.id>2024-08-09 14:36:33 +0700
committerit-fixcomart <it@fixcomart.co.id>2024-08-09 14:36:33 +0700
commit0efb4f3aad012439a706e6704b781bb510478c6c (patch)
tree6306d16aad4c0f2781108b9b13e86103256a52fc /src
parent8dd5502ca3ed4f2d74f74ea396b9424bd1390e5e (diff)
parentf04c0caea86bd5c41629de78f84e258432edb157 (diff)
Merge branch 'development' of https://bitbucket.org/altafixco/next-indoteknik into development
Diffstat (limited to 'src')
-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