@nosto/search-js 2.17.0 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/preact/hooks.cjs.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const h=require("../useLoadMore-CeqFdxt1.cjs"),z=require("../logger-BcHMZObS.cjs"),p=require("preact/hooks"),P=require("../index.es-DlUp67LT.cjs"),N=require("../parseNumber-FsZ8w61u.cjs");function T(e){const r=h.useNostoAppState(t=>t.response);return e&&Array.isArray(e)||e&&z.isPlainObject(e)?e:r}function q(e,r){var d;const t=((d=e.data)==null?void 0:d.filter(s=>s.selected).length)??0,{active:n}={active:t>0,...r},[o,
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const h=require("../useLoadMore-CeqFdxt1.cjs"),z=require("../logger-BcHMZObS.cjs"),p=require("preact/hooks"),P=require("../index.es-DlUp67LT.cjs"),N=require("../parseNumber-FsZ8w61u.cjs");function T(e){const r=h.useNostoAppState(t=>t.response);return e&&Array.isArray(e)||e&&z.isPlainObject(e)?e:r}function q(e,r){var d;const t=((d=e.data)==null?void 0:d.filter(s=>s.selected).length)??0,{active:n}={active:t>0,...r},[o,i]=p.useState(n),{toggleProductFilter:c}=h.useActions(),a=p.useCallback(()=>{i(!o)},[o]);return{active:o,selectedFiltersCount:t,toggleActive:a,toggleProductFilter:c}}function X(){const{loading:e,facets:r}=h.useNostoAppState(t=>{var n,o;return{loading:t.loading,facets:((o=(n=t.response)==null?void 0:n.products)==null?void 0:o.facets)??[]}});return{loading:e,facets:r}}function O(e,r){const t=r-e;return!isNaN(t)&&t>0?new Array(r-e).fill(void 0).map((n,o)=>o+e):[]}function j(e){const{query:r,products:t}=h.useNostoAppState(n=>({query:n.query,products:n.response.products}));return p.useMemo(()=>{var F,y,R;if(!t)return{totalPages:0,resultsFrom:0,resultsTo:0,pages:[]};const n=((F=r.products)==null?void 0:F.from)??0,o=(e==null?void 0:e.width)??1/0,i=Math.max(Math.floor(o-1)/2,1),c=t.size>0?Math.floor(n/t.size)+1:1,a=t.size>0?Math.ceil(t.total/t.size):0,d=A=>A>=c-i&&A<=c+i,s=n+1,l=Math.min(n+t.total,t.total),u={from:n,page:c,current:!0},f=A=>({from:(A-1)*t.size,page:A,current:A===c}),m=c>1?f(c-1):void 0,g=c<a?f(c+1):void 0,b=c-i-1>1?f(1):void 0,S=c+i+1<a?f(a):void 0,v=O(1,a+1).filter(d).map(f);return!b&&((y=v[0])==null?void 0:y.page)===2&&v.unshift(f(1)),!S&&((R=v[v.length-1])==null?void 0:R.page)===a-1&&v.push(f(a)),{totalPages:a,resultsFrom:s,resultsTo:l,current:u,prev:m,next:g,first:b,last:S,pages:v}},[r,t,e==null?void 0:e.width])}function V(){const[e,r]=p.useState([]),[t,n]=p.useState([]);return p.useEffect(()=>{P.s(async o=>{const{products:i,segments:c}=await o.getSearchSessionParams();r(c??[]),n((i==null?void 0:i.personalizationBoost)??[])})},[]),{segments:e,boost:t}}function D(){const{facets:e}=h.useNostoAppState(s=>{var l;return{facets:((l=s.response.products)==null?void 0:l.facets)??[]}}),{replaceFilter:r,toggleProductFilter:t}=h.useActions(),n=p.useCallback(s=>{const l=e==null?void 0:e.find(u=>u.type==="stats"&&u.field===s);if(l&&"min"in l&&"max"in l)return l},[e]),o=p.useCallback(s=>{var l;return((l=e==null?void 0:e.find(u=>u.field===s))==null?void 0:l.name)??s},[e]),i=p.useCallback(s=>"field"in s&&(s.value instanceof Array||s.range instanceof Array),[]),c=p.useCallback(s=>{var l;return{...s,range:(l=s.range)==null?void 0:l.map(u=>({gt:u.gt?Number(u.gt):u.gt,gte:u.gte?Number(u.gte):u.gte,lt:u.lt?Number(u.lt):u.lt,lte:u.lte?Number(u.lte):u.lte}))}},[]),a=p.useCallback(s=>(s.value??[]).map(u=>({value:u,field:s.field,name:o(s.field),filter:c(s),remove:()=>{t(s.field,u,!1)}})),[c,o,t]),d=p.useCallback(s=>(s.range??[]).map(u=>{var g,b;const f=u.gte??u.gt??((g=n(s.field))==null?void 0:g.min),m=u.lte??u.lt??((b=n(s.field))==null?void 0:b.max);if(f!==void 0&&m!==void 0)return{value:`${f} - ${m}`,field:s.field,name:o(s.field),filter:c(s),remove:()=>{r(s.field,void 0)}}}).filter(Boolean),[c,n,o,r]);return{selectFilters:i,toValueFilter:a,toRangeFilter:d}}function k(){const{filter:e}=h.useNostoAppState(a=>{var d;return{filter:((d=a.query.products)==null?void 0:d.filter)??[]}}),{updateSearch:r}=h.useActions(),{selectFilters:t,toValueFilter:n,toRangeFilter:o}=D(),i=p.useMemo(()=>e?e.filter(t).flatMap(a=>"value"in a?n(a):"range"in a?o(a):[]).filter(Boolean):[],[e,t,o,n]),c=p.useCallback(()=>{r({products:{filter:[]}})},[r]);return{filters:i,removeAll:c}}function x(e){var u,f,m;const{replaceFilter:r}=h.useActions(),{query:t,products:n}=h.useNostoAppState(g=>({query:g.query,products:g.response.products})),o=(u=n==null?void 0:n.facets)==null?void 0:u.find(g=>g.id===e);if(!o)return{min:0,max:0,range:[0,0],updateRange:()=>{}};const i=(m=(f=t.products)==null?void 0:f.filter)==null?void 0:m.find(g=>g.field===o.field),c=i!=null&&i.range?i.range[0]:void 0,a=typeof c=="object"&&("gte"in c||"lte"in c)?[N.parseNumber(c.gte),N.parseNumber(c.lte)]:[void 0,void 0],d="min"in o?Math.floor(o.min):0,s="max"in o?Math.ceil(o.max):0,l=([g,b])=>{const S=g!==void 0?Math.floor(g):void 0,v=b!==void 0?Math.ceil(b):void 0,F=S!==void 0,y=v!==void 0;(d===S||!F)&&(s===v||!y)?r(o.field,void 0):(d===S||!F)&&y?r(o.field,{lte:v.toString()}):(s===v||!y)&&F?r(o.field,{gte:S.toString()}):F&&y&&r(o.field,{gte:S.toString(),lte:v.toString()})};return{min:d,max:s,range:[a[0]??d,a[1]??s],updateRange:l}}function B(e,r){const{min:t,max:n,range:o,updateRange:i}=x(e),{filters:c}=k(),a=p.useMemo(()=>{var b;const u=c.find(S=>{var v;return(v=S==null?void 0:S.filter)==null?void 0:v.range});let f=null;if(u){const S=(b=u.filter.range)==null?void 0:b[0];f=[N.parseNumber(S==null?void 0:S.gte),N.parseNumber(S==null?void 0:S.lte)]}const m=[];let g=Math.floor(t/r)*r;for(;g<n;){const S=g+r,v=f&&f[0]===g&&f[1]===S;m.push({min:g,max:S,selected:v}),g=S}return m},[c,t,n,r]),d=u=>{i([u,o[1]])},s=u=>{i([o[0],u])},l=t!==o[0]||n!==o[1];return{min:t,max:n,range:o,updateRange:i,ranges:a,handleMinChange:d,handleMaxChange:s,isSelected:l}}function _(){const{products:e,keywords:r}=h.useNostoAppState(t=>t.response);return{products:e??{hits:[],total:0},keywords:r??{hits:[],total:0}}}function E(){const e=h.useNostoAppState(t=>{var n;return(n=t.query.products)==null?void 0:n.filter});return p.useMemo(()=>e?e.reduce((t,n)=>t+(Array.isArray(n.value)?n.value.length:1),0):0,[e])}function M(e){return e&&!Number.isNaN(e)?e:0}function U(e,r){const{from:t,size:n,total:o}=h.useNostoAppState(s=>{var l,u,f,m,g;return{from:M(((l=s.query.products)==null?void 0:l.from)??0),size:M(((f=(u=s.response)==null?void 0:u.products)==null?void 0:f.size)??0),total:M(((g=(m=s.response)==null?void 0:m.products)==null?void 0:g.total)??0)}}),{updateSearch:i}=h.useActions(),c=t+n,a=[...e].reverse().filter(s=>s+r<o);return{from:t,to:c,total:o,size:n,sizeOptions:a,handleSizeChange:s=>{i({products:{size:N.parseNumber(s)}})}}}function $(e,r){return e.length!==r.length?!1:e.every(t=>r.find(n=>t.field===n.field&&t.order===n.order))}function I(e){var i,c;const r=h.useNostoAppState(a=>a.query),{updateSearch:t}=h.useActions();return{activeSort:((i=e.find(a=>{var d;return $(a.value.sort,((d=r.products)==null?void 0:d.sort)||[])}))==null?void 0:i.id)??((c=e[0])==null?void 0:c.id),setSort:a=>{const d=e.find(s=>s.id===a);d&&t({products:{sort:d.value.sort}})}}}const w=window.SpeechRecognition||window.webkitSpeechRecognition,L=!!(w&&typeof w=="function");function Z(){return{listening:!1,startListening:()=>{},stopListening:()=>{}}}function G({language:e="en-US",interimResults:r=!1,onResult:t,onError:n}={}){const[o,i]=p.useState(!1),c=p.useRef(null),a=p.useCallback(()=>{const s=new w;s.lang=e,s.interimResults=r,s.onstart=()=>i(!0),t&&(s.onresult=l=>{var f,m;const{transcript:u}=(m=(f=l.results)==null?void 0:f[0])==null?void 0:m[0];t(u)}),n&&(s.onerror=l=>n(l.error)),s.onend=()=>i(!1),c.current=s,s.start()},[e,r,n,t]),d=p.useCallback(()=>{var s;(s=c.current)==null||s.stop()},[c]);return{listening:o,startListening:a,stopListening:d}}const H=L?G:Z;function J(e,r){if(!e.length||!r.length)return[];const t=r.reduce((n,o)=>(n[o]={},n),{});return e.forEach(n=>{var o;(o=n.customFields)==null||o.forEach(({key:i,value:c})=>{const a=i.toLowerCase();r.includes(a)&&(t[a][c]=t[a][c]||[],t[a][c].push(n))})}),Object.entries(t).filter(n=>Object.keys(n[1]).length).map(([n,o])=>({field:n,options:Object.entries(o).map(([i,c])=>({value:i,skus:c,unavailable:!1,selected:!1}))}))}function K(e,r){return e.length?e.map(({field:t,options:n})=>({field:t,options:n.map(o=>{var a;const i=!((a=o.skus)!=null&&a.some(d=>Object.entries(r).every(([s,l])=>{var f,m;return s===t?!0:((m=(f=d.customFields)==null?void 0:f.find(g=>g.key.toLowerCase()===s))==null?void 0:m.value)===l}))),c=r[t]===o.value;return{...o,unavailable:i,selected:c}})})):[]}const C=["4XS","3XS","2XS","XXS","XS","S","M","L","XL","XXL","2XL","XXXL","3XL","4XL"];function Q(e){if(C.includes(e))return 1e3+C.indexOf(e);const r=parseFloat(e);return isNaN(r)?e:r}function W(e,r){return[...r].sort((t,n)=>{const[o,i]=[t.value,n.value].map(Q);return o<i?-1:1})}function Y(e=[],r=[]){const[t,n]=p.useState({}),o=p.useMemo(()=>J(e,r).map(({field:s,options:l})=>({field:s,options:W(s,l)})),[e,r]),i=p.useMemo(()=>K(o,t),[o,t]),c=p.useCallback((d,s)=>{n(l=>{const u={...l};return u[d]===s?delete u[d]:u[d]=s,u})},[]),a=p.useMemo(()=>Object.keys(t).filter(l=>t[l]).length===0?[]:i.filter(({field:l})=>t[l]).map(({field:l,options:u})=>{const f=t[l],m=u.find(g=>g.value===f);return(m==null?void 0:m.skus)??[]}).reduce((l,u)=>l.filter(f=>u.includes(f))),[i,t]);return{swatches:i,toggleOption:c,matchedSkus:a}}exports.useActions=h.useActions;exports.useLoadMore=h.useLoadMore;exports.useNostoAppState=h.useNostoAppState;exports.speechToTextSupported=L;exports.useDecoratedSearchResults=T;exports.useFacet=q;exports.useFacets=X;exports.usePagination=j;exports.usePersonalization=V;exports.useProductFilters=k;exports.useRange=x;exports.useRangeSelector=B;exports.useResponse=_;exports.useSelectedFiltersCount=E;exports.useSizeOptions=U;exports.useSort=I;exports.useSpeechToText=H;exports.useSwatches=Y;
|
package/dist/preact/hooks.es.js
CHANGED
|
@@ -13,8 +13,8 @@ function Y(e, o) {
|
|
|
13
13
|
const t = ((d = e.data) == null ? void 0 : d.filter((n) => n.selected).length) ?? 0, { active: r } = {
|
|
14
14
|
active: t > 0,
|
|
15
15
|
...o
|
|
16
|
-
}, [s,
|
|
17
|
-
|
|
16
|
+
}, [s, a] = L(r), { toggleProductFilter: c } = x(), u = S(() => {
|
|
17
|
+
a(!s);
|
|
18
18
|
}, [s]);
|
|
19
19
|
return {
|
|
20
20
|
/** Active value */
|
|
@@ -22,7 +22,7 @@ function Y(e, o) {
|
|
|
22
22
|
/** Selected filters count */
|
|
23
23
|
selectedFiltersCount: t,
|
|
24
24
|
/** Toggle active function */
|
|
25
|
-
toggleActive:
|
|
25
|
+
toggleActive: u,
|
|
26
26
|
/** Toggle product filter function */
|
|
27
27
|
toggleProductFilter: c
|
|
28
28
|
};
|
|
@@ -60,7 +60,7 @@ function te(e) {
|
|
|
60
60
|
resultsTo: 0,
|
|
61
61
|
pages: []
|
|
62
62
|
};
|
|
63
|
-
const r = ((F = o.products) == null ? void 0 : F.from) ?? 0, s = (e == null ? void 0 : e.width) ?? 1 / 0,
|
|
63
|
+
const r = ((F = o.products) == null ? void 0 : F.from) ?? 0, s = (e == null ? void 0 : e.width) ?? 1 / 0, a = Math.max(Math.floor(s - 1) / 2, 1), c = t.size > 0 ? Math.floor(r / t.size) + 1 : 1, u = t.size > 0 ? Math.ceil(t.total / t.size) : 0, d = (R) => R >= c - a && R <= c + a, n = r + 1, l = Math.min(r + t.total, t.total), i = {
|
|
64
64
|
from: r,
|
|
65
65
|
page: c,
|
|
66
66
|
current: !0
|
|
@@ -68,9 +68,9 @@ function te(e) {
|
|
|
68
68
|
from: (R - 1) * t.size,
|
|
69
69
|
page: R,
|
|
70
70
|
current: R === c
|
|
71
|
-
}), p = c > 1 ? f(c - 1) : void 0, g = c <
|
|
72
|
-
return !v && ((w = h[0]) == null ? void 0 : w.page) === 2 && h.unshift(f(1)), !m && ((A = h[h.length - 1]) == null ? void 0 : A.page) ===
|
|
73
|
-
totalPages:
|
|
71
|
+
}), p = c > 1 ? f(c - 1) : void 0, g = c < u ? f(c + 1) : void 0, v = c - a - 1 > 1 ? f(1) : void 0, m = c + a + 1 < u ? f(u) : void 0, h = k(1, u + 1).filter(d).map(f);
|
|
72
|
+
return !v && ((w = h[0]) == null ? void 0 : w.page) === 2 && h.unshift(f(1)), !m && ((A = h[h.length - 1]) == null ? void 0 : A.page) === u - 1 && h.push(f(u)), {
|
|
73
|
+
totalPages: u,
|
|
74
74
|
resultsFrom: n,
|
|
75
75
|
resultsTo: l,
|
|
76
76
|
current: i,
|
|
@@ -86,8 +86,8 @@ function ne() {
|
|
|
86
86
|
const [e, o] = L([]), [t, r] = L([]);
|
|
87
87
|
return O(() => {
|
|
88
88
|
C(async (s) => {
|
|
89
|
-
const { products:
|
|
90
|
-
o(c ?? []), r((
|
|
89
|
+
const { products: a, segments: c } = await s.getSearchSessionParams();
|
|
90
|
+
o(c ?? []), r((a == null ? void 0 : a.personalizationBoost) ?? []);
|
|
91
91
|
});
|
|
92
92
|
}, []), {
|
|
93
93
|
segments: e,
|
|
@@ -113,7 +113,7 @@ function q() {
|
|
|
113
113
|
return ((l = e == null ? void 0 : e.find((i) => i.field === n)) == null ? void 0 : l.name) ?? n;
|
|
114
114
|
},
|
|
115
115
|
[e]
|
|
116
|
-
),
|
|
116
|
+
), a = S((n) => "field" in n && (n.value instanceof Array || n.range instanceof Array), []), c = S((n) => {
|
|
117
117
|
var l;
|
|
118
118
|
return {
|
|
119
119
|
...n,
|
|
@@ -124,7 +124,7 @@ function q() {
|
|
|
124
124
|
lte: i.lte ? Number(i.lte) : i.lte
|
|
125
125
|
}))
|
|
126
126
|
};
|
|
127
|
-
}, []),
|
|
127
|
+
}, []), u = S(
|
|
128
128
|
(n) => (n.value ?? []).map((i) => ({
|
|
129
129
|
value: i,
|
|
130
130
|
field: n.field,
|
|
@@ -153,18 +153,18 @@ function q() {
|
|
|
153
153
|
[c, r, s, o]
|
|
154
154
|
);
|
|
155
155
|
return {
|
|
156
|
-
selectFilters:
|
|
157
|
-
toValueFilter:
|
|
156
|
+
selectFilters: a,
|
|
157
|
+
toValueFilter: u,
|
|
158
158
|
toRangeFilter: d
|
|
159
159
|
};
|
|
160
160
|
}
|
|
161
161
|
function j() {
|
|
162
|
-
const { filter: e } = y((
|
|
162
|
+
const { filter: e } = y((u) => {
|
|
163
163
|
var d;
|
|
164
164
|
return {
|
|
165
|
-
filter: ((d =
|
|
165
|
+
filter: ((d = u.query.products) == null ? void 0 : d.filter) ?? []
|
|
166
166
|
};
|
|
167
|
-
}), { updateSearch: o } = x(), { selectFilters: t, toValueFilter: r, toRangeFilter: s } = q(),
|
|
167
|
+
}), { updateSearch: o } = x(), { selectFilters: t, toValueFilter: r, toRangeFilter: s } = q(), a = b(() => e ? e.filter(t).flatMap((u) => "value" in u ? r(u) : "range" in u ? s(u) : []).filter(Boolean) : [], [e, t, s, r]), c = S(() => {
|
|
168
168
|
o({
|
|
169
169
|
products: {
|
|
170
170
|
filter: []
|
|
@@ -173,7 +173,7 @@ function j() {
|
|
|
173
173
|
}, [o]);
|
|
174
174
|
return {
|
|
175
175
|
/** Selected filters array. */
|
|
176
|
-
filters:
|
|
176
|
+
filters: a,
|
|
177
177
|
/** Should remove all selected filters. */
|
|
178
178
|
removeAll: c
|
|
179
179
|
};
|
|
@@ -192,7 +192,7 @@ function V(e) {
|
|
|
192
192
|
updateRange: () => {
|
|
193
193
|
}
|
|
194
194
|
};
|
|
195
|
-
const
|
|
195
|
+
const a = (p = (f = t.products) == null ? void 0 : f.filter) == null ? void 0 : p.find((g) => g.field === s.field), c = a != null && a.range ? a.range[0] : void 0, u = typeof c == "object" && ("gte" in c || "lte" in c) ? [M(c.gte), M(c.lte)] : [void 0, void 0], d = "min" in s ? Math.floor(s.min) : 0, n = "max" in s ? Math.ceil(s.max) : 0, l = ([g, v]) => {
|
|
196
196
|
const m = g !== void 0 ? Math.floor(g) : void 0, h = v !== void 0 ? Math.ceil(v) : void 0, F = m !== void 0, w = h !== void 0;
|
|
197
197
|
(d === m || !F) && (n === h || !w) ? o(s.field, void 0) : (d === m || !F) && w ? o(s.field, {
|
|
198
198
|
lte: h.toString()
|
|
@@ -209,13 +209,13 @@ function V(e) {
|
|
|
209
209
|
/** Max value */
|
|
210
210
|
max: n,
|
|
211
211
|
/** Range value */
|
|
212
|
-
range: [
|
|
212
|
+
range: [u[0] ?? d, u[1] ?? n],
|
|
213
213
|
/** Update range function */
|
|
214
214
|
updateRange: l
|
|
215
215
|
};
|
|
216
216
|
}
|
|
217
217
|
function re(e, o) {
|
|
218
|
-
const { min: t, max: r, range: s, updateRange:
|
|
218
|
+
const { min: t, max: r, range: s, updateRange: a } = V(e), { filters: c } = j(), u = b(() => {
|
|
219
219
|
var v;
|
|
220
220
|
const i = c.find((m) => {
|
|
221
221
|
var h;
|
|
@@ -238,9 +238,9 @@ function re(e, o) {
|
|
|
238
238
|
}
|
|
239
239
|
return p;
|
|
240
240
|
}, [c, t, r, o]), d = (i) => {
|
|
241
|
-
|
|
241
|
+
a([i, s[1]]);
|
|
242
242
|
}, n = (i) => {
|
|
243
|
-
|
|
243
|
+
a([s[0], i]);
|
|
244
244
|
}, l = t !== s[0] || r !== s[1];
|
|
245
245
|
return {
|
|
246
246
|
/** Minimum value */
|
|
@@ -250,9 +250,9 @@ function re(e, o) {
|
|
|
250
250
|
/** Range value */
|
|
251
251
|
range: s,
|
|
252
252
|
/** Update range function */
|
|
253
|
-
updateRange:
|
|
253
|
+
updateRange: a,
|
|
254
254
|
/** Ranges */
|
|
255
|
-
ranges:
|
|
255
|
+
ranges: u,
|
|
256
256
|
/** Handle min change */
|
|
257
257
|
handleMinChange: d,
|
|
258
258
|
/** Handle max change */
|
|
@@ -288,7 +288,7 @@ function ie(e, o) {
|
|
|
288
288
|
size: z(((f = (i = n.response) == null ? void 0 : i.products) == null ? void 0 : f.size) ?? 0),
|
|
289
289
|
total: z(((g = (p = n.response) == null ? void 0 : p.products) == null ? void 0 : g.total) ?? 0)
|
|
290
290
|
};
|
|
291
|
-
}), { updateSearch:
|
|
291
|
+
}), { updateSearch: a } = x(), c = t + r, u = [...e].reverse().filter((n) => n + o < s);
|
|
292
292
|
return {
|
|
293
293
|
/** from value */
|
|
294
294
|
from: t,
|
|
@@ -299,10 +299,10 @@ function ie(e, o) {
|
|
|
299
299
|
/** size value */
|
|
300
300
|
size: r,
|
|
301
301
|
/** Array of size options */
|
|
302
|
-
sizeOptions:
|
|
302
|
+
sizeOptions: u,
|
|
303
303
|
/** Should be called when size is changed */
|
|
304
304
|
handleSizeChange: (n) => {
|
|
305
|
-
|
|
305
|
+
a({
|
|
306
306
|
products: {
|
|
307
307
|
size: M(n)
|
|
308
308
|
}
|
|
@@ -314,17 +314,17 @@ function B(e, o) {
|
|
|
314
314
|
return e.length !== o.length ? !1 : e.every((t) => o.find((r) => t.field === r.field && t.order === r.order));
|
|
315
315
|
}
|
|
316
316
|
function ce(e) {
|
|
317
|
-
var
|
|
318
|
-
const o = y((
|
|
317
|
+
var a, c;
|
|
318
|
+
const o = y((u) => u.query), { updateSearch: t } = x();
|
|
319
319
|
return {
|
|
320
320
|
/** Active sort */
|
|
321
|
-
activeSort: ((
|
|
321
|
+
activeSort: ((a = e.find((u) => {
|
|
322
322
|
var d;
|
|
323
|
-
return B(
|
|
324
|
-
})) == null ? void 0 :
|
|
323
|
+
return B(u.value.sort, ((d = o.products) == null ? void 0 : d.sort) || []);
|
|
324
|
+
})) == null ? void 0 : a.id) ?? ((c = e[0]) == null ? void 0 : c.id),
|
|
325
325
|
/** Set sort function */
|
|
326
|
-
setSort: (
|
|
327
|
-
const d = e.find((n) => n.id ===
|
|
326
|
+
setSort: (u) => {
|
|
327
|
+
const d = e.find((n) => n.id === u);
|
|
328
328
|
d && t({
|
|
329
329
|
products: {
|
|
330
330
|
sort: d.value.sort
|
|
@@ -345,26 +345,25 @@ function E() {
|
|
|
345
345
|
}
|
|
346
346
|
function U({
|
|
347
347
|
language: e = "en-US",
|
|
348
|
-
interimResults: o = !1
|
|
348
|
+
interimResults: o = !1,
|
|
349
|
+
onResult: t,
|
|
350
|
+
onError: r
|
|
349
351
|
} = {}) {
|
|
350
|
-
const [
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
var a;
|
|
362
|
-
(a = s.current) == null || a.stop();
|
|
363
|
-
}, [s]);
|
|
352
|
+
const [s, a] = L(!1), c = T(null), u = S(() => {
|
|
353
|
+
const n = new X();
|
|
354
|
+
n.lang = e, n.interimResults = o, n.onstart = () => a(!0), t && (n.onresult = (l) => {
|
|
355
|
+
var f, p;
|
|
356
|
+
const { transcript: i } = (p = (f = l.results) == null ? void 0 : f[0]) == null ? void 0 : p[0];
|
|
357
|
+
t(i);
|
|
358
|
+
}), r && (n.onerror = (l) => r(l.error)), n.onend = () => a(!1), c.current = n, n.start();
|
|
359
|
+
}, [e, o, r, t]), d = S(() => {
|
|
360
|
+
var n;
|
|
361
|
+
(n = c.current) == null || n.stop();
|
|
362
|
+
}, [c]);
|
|
364
363
|
return {
|
|
365
|
-
listening:
|
|
364
|
+
listening: s,
|
|
366
365
|
startListening: u,
|
|
367
|
-
stopListening:
|
|
366
|
+
stopListening: d
|
|
368
367
|
};
|
|
369
368
|
}
|
|
370
369
|
const ae = D ? U : E;
|
|
@@ -373,14 +372,14 @@ function _(e, o) {
|
|
|
373
372
|
const t = o.reduce((r, s) => (r[s] = {}, r), {});
|
|
374
373
|
return e.forEach((r) => {
|
|
375
374
|
var s;
|
|
376
|
-
(s = r.customFields) == null || s.forEach(({ key:
|
|
377
|
-
const
|
|
378
|
-
o.includes(
|
|
375
|
+
(s = r.customFields) == null || s.forEach(({ key: a, value: c }) => {
|
|
376
|
+
const u = a.toLowerCase();
|
|
377
|
+
o.includes(u) && (t[u][c] = t[u][c] || [], t[u][c].push(r));
|
|
379
378
|
});
|
|
380
379
|
}), Object.entries(t).filter((r) => Object.keys(r[1]).length).map(([r, s]) => ({
|
|
381
380
|
field: r,
|
|
382
|
-
options: Object.entries(s).map(([
|
|
383
|
-
value:
|
|
381
|
+
options: Object.entries(s).map(([a, c]) => ({
|
|
382
|
+
value: a,
|
|
384
383
|
skus: c,
|
|
385
384
|
unavailable: !1,
|
|
386
385
|
selected: !1
|
|
@@ -391,14 +390,14 @@ function $(e, o) {
|
|
|
391
390
|
return e.length ? e.map(({ field: t, options: r }) => ({
|
|
392
391
|
field: t,
|
|
393
392
|
options: r.map((s) => {
|
|
394
|
-
var
|
|
395
|
-
const
|
|
393
|
+
var u;
|
|
394
|
+
const a = !((u = s.skus) != null && u.some((d) => Object.entries(o).every(([n, l]) => {
|
|
396
395
|
var f, p;
|
|
397
396
|
return n === t ? !0 : ((p = (f = d.customFields) == null ? void 0 : f.find((g) => g.key.toLowerCase() === n)) == null ? void 0 : p.value) === l;
|
|
398
397
|
}))), c = o[t] === s.value;
|
|
399
398
|
return {
|
|
400
399
|
...s,
|
|
401
|
-
unavailable:
|
|
400
|
+
unavailable: a,
|
|
402
401
|
selected: c
|
|
403
402
|
};
|
|
404
403
|
})
|
|
@@ -413,24 +412,24 @@ function I(e) {
|
|
|
413
412
|
}
|
|
414
413
|
function Z(e, o) {
|
|
415
414
|
return [...o].sort((t, r) => {
|
|
416
|
-
const [s,
|
|
417
|
-
return s <
|
|
415
|
+
const [s, a] = [t.value, r.value].map(I);
|
|
416
|
+
return s < a ? -1 : 1;
|
|
418
417
|
});
|
|
419
418
|
}
|
|
420
419
|
function ue(e = [], o = []) {
|
|
421
420
|
const [t, r] = L({}), s = b(() => _(e, o).map(({ field: n, options: l }) => ({
|
|
422
421
|
field: n,
|
|
423
422
|
options: Z(n, l)
|
|
424
|
-
})), [e, o]),
|
|
423
|
+
})), [e, o]), a = b(() => $(s, t), [s, t]), c = S((d, n) => {
|
|
425
424
|
r((l) => {
|
|
426
425
|
const i = { ...l };
|
|
427
426
|
return i[d] === n ? delete i[d] : i[d] = n, i;
|
|
428
427
|
});
|
|
429
|
-
}, []),
|
|
428
|
+
}, []), u = b(() => Object.keys(t).filter((l) => t[l]).length === 0 ? [] : a.filter(({ field: l }) => t[l]).map(({ field: l, options: i }) => {
|
|
430
429
|
const f = t[l], p = i.find((g) => g.value === f);
|
|
431
430
|
return (p == null ? void 0 : p.skus) ?? [];
|
|
432
|
-
}).reduce((l, i) => l.filter((f) => i.includes(f))), [
|
|
433
|
-
return { swatches:
|
|
431
|
+
}).reduce((l, i) => l.filter((f) => i.includes(f))), [a, t]);
|
|
432
|
+
return { swatches: a, toggleOption: c, matchedSkus: u };
|
|
434
433
|
}
|
|
435
434
|
export {
|
|
436
435
|
D as speechToTextSupported,
|
|
@@ -1,18 +1,16 @@
|
|
|
1
1
|
interface SpeechToTextOptions {
|
|
2
2
|
language?: string;
|
|
3
3
|
interimResults?: boolean;
|
|
4
|
-
|
|
5
|
-
interface StartListeningOptions {
|
|
6
|
-
onResult: (value: string) => void;
|
|
4
|
+
onResult?: (value: string) => void;
|
|
7
5
|
onError?: (error: string) => void;
|
|
8
6
|
}
|
|
9
7
|
export type SpeechToText = {
|
|
10
8
|
listening: boolean;
|
|
11
|
-
startListening: (
|
|
9
|
+
startListening: () => void;
|
|
12
10
|
stopListening: () => void;
|
|
13
11
|
};
|
|
14
12
|
export declare const speechToTextSupported: boolean;
|
|
15
|
-
declare function useSpeechToTextSupported({ language, interimResults }?: SpeechToTextOptions): SpeechToText;
|
|
13
|
+
declare function useSpeechToTextSupported({ language, interimResults, onResult, onError }?: SpeechToTextOptions): SpeechToText;
|
|
16
14
|
/**
|
|
17
15
|
* Preact hook that provides speech-to-text functionality using the Web Speech API.
|
|
18
16
|
* @example
|
|
@@ -21,7 +19,10 @@ declare function useSpeechToTextSupported({ language, interimResults }?: SpeechT
|
|
|
21
19
|
*
|
|
22
20
|
* export default function MyComponent() {
|
|
23
21
|
* const { newSearch } = useActions()
|
|
24
|
-
* const { startListening, stopListening, listening } = useSpeechToText(
|
|
22
|
+
* const { startListening, stopListening, listening } = useSpeechToText({
|
|
23
|
+
* onResult: query => newSearch({ query }),
|
|
24
|
+
* onError: error => console.error("Speech recognition error:", error)
|
|
25
|
+
* })
|
|
25
26
|
* if (!speechToTextSupported) {
|
|
26
27
|
* return null
|
|
27
28
|
* }
|
|
@@ -32,13 +33,7 @@ declare function useSpeechToTextSupported({ language, interimResults }?: SpeechT
|
|
|
32
33
|
* if (listening) {
|
|
33
34
|
* stopListening()
|
|
34
35
|
* } else {
|
|
35
|
-
* startListening(
|
|
36
|
-
* onResult: value => {
|
|
37
|
-
* newSearch({
|
|
38
|
-
* query: value
|
|
39
|
-
* })
|
|
40
|
-
* }
|
|
41
|
-
* })
|
|
36
|
+
* startListening()
|
|
42
37
|
* }
|
|
43
38
|
* }}
|
|
44
39
|
* >
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nosto/search-js",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "3.0.0",
|
|
4
4
|
"license": "ISC",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"files": [
|
|
@@ -90,14 +90,14 @@
|
|
|
90
90
|
"@testing-library/dom": "^10.4.0",
|
|
91
91
|
"@types/dom-speech-recognition": "^0.0.6",
|
|
92
92
|
"@types/eslint-config-prettier": "^6.11.3",
|
|
93
|
-
"@types/node": "^22.15.
|
|
94
|
-
"@vitest/coverage-v8": "^3.
|
|
93
|
+
"@types/node": "^22.15.29",
|
|
94
|
+
"@vitest/coverage-v8": "^3.2.0",
|
|
95
95
|
"concurrently": "^9.1.2",
|
|
96
96
|
"copyfiles": "^2.4.1",
|
|
97
|
-
"eslint": "^9.
|
|
97
|
+
"eslint": "^9.28.0",
|
|
98
98
|
"eslint-config-prettier": "^10.1.5",
|
|
99
99
|
"eslint-plugin-barrel-files": "^3.0.1",
|
|
100
|
-
"eslint-plugin-prettier": "^5.4.
|
|
100
|
+
"eslint-plugin-prettier": "^5.4.1",
|
|
101
101
|
"eslint-plugin-react": "^7.37.5",
|
|
102
102
|
"eslint-plugin-react-hooks": "^5.2.0",
|
|
103
103
|
"eslint-plugin-simple-import-sort": "^12.1.1",
|
|
@@ -108,7 +108,7 @@
|
|
|
108
108
|
"prettier": "^3.5.3",
|
|
109
109
|
"typedoc": "^0.28.5",
|
|
110
110
|
"typescript": "^5.8.3",
|
|
111
|
-
"typescript-eslint": "^8.
|
|
111
|
+
"typescript-eslint": "^8.33.0",
|
|
112
112
|
"vite": "^6.3.5",
|
|
113
113
|
"vite-plugin-dts": "^4.5.4",
|
|
114
114
|
"vitest": "^3.1.3"
|