@nosto/search-js 2.9.2 → 2.11.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.
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const m=require("../useLoadMore-BRYyWQa0.cjs"),P=require("../logger-BcHMZObS.cjs"),h=require("preact/hooks"),q=require("../index.es-DlUp67LT.cjs"),N=require("../parseNumber-FsZ8w61u.cjs");function z(e){const r=m.useNostoAppState(t=>t.response);return e&&Array.isArray(e)||e&&P.isPlainObject(e)?e:r}function k(e){var u;const r=((u=e.data)==null?void 0:u.filter(a=>a.selected).length)??0,[t,s]=h.useState(r>0),{toggleProductFilter:o}=m.useActions();return{active:t,selectedFiltersCount:r,toggleActive:()=>{s(!t)},toggleProductFilter:o}}function x(){const{loading:e,facets:r}=m.useNostoAppState(t=>{var s,o;return{loading:t.loading,facets:((o=(s=t.response)==null?void 0:s.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((s,o)=>o+e):[]}function j(e){const{query:r,products:t}=m.useNostoAppState(s=>({query:s.query,products:s.response.products}));return h.useMemo(()=>{var F,b,C;if(!t)return{totalPages:0,resultsFrom:0,resultsTo:0,pages:[]};const s=((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),u=t.size>0?Math.floor(s/t.size)+1:1,a=t.size>0?Math.ceil(t.total/t.size):0,g=y=>y>=u-i&&y<=u+i,n=s+1,l=Math.min(s+t.total,t.total),c={from:s,page:u,current:!0},f=y=>({from:(y-1)*t.size,page:y,current:y===u}),v=u>1?f(u-1):void 0,d=u<a?f(u+1):void 0,A=u-i-1>1?f(1):void 0,p=u+i+1<a?f(a):void 0,S=O(1,a+1).filter(g).map(f);return!A&&((b=S[0])==null?void 0:b.page)===2&&S.unshift(f(1)),!p&&((C=S[S.length-1])==null?void 0:C.page)===a-1&&S.push(f(a)),{totalPages:a,resultsFrom:n,resultsTo:l,current:c,prev:v,next:d,first:A,last:p,pages:S}},[r,t,e==null?void 0:e.width])}function L(){const[e,r]=h.useState([]),[t,s]=h.useState([]);return h.useEffect(()=>{q.s(async o=>{const{products:i,segments:u}=await o.getSearchSessionParams();r(u??[]),s((i==null?void 0:i.personalizationBoost)??[])})},[]),{segments:e,boost:t}}function T(){const{facets:e}=m.useNostoAppState(n=>{var l;return{facets:((l=n.response.products)==null?void 0:l.facets)??[]}}),{replaceFilter:r,toggleProductFilter:t}=m.useActions(),s=h.useCallback(n=>{const l=e==null?void 0:e.find(c=>c.type==="stats"&&c.field===n);if(l&&"min"in l&&"max"in l)return l},[e]),o=h.useCallback(n=>{var l;return((l=e==null?void 0:e.find(c=>c.field===n))==null?void 0:l.name)??n},[e]),i=h.useCallback(n=>"field"in n&&(n.value instanceof Array||n.range instanceof Array),[]),u=h.useCallback(n=>{var l;return{...n,range:(l=n.range)==null?void 0:l.map(c=>({gt:c.gt?Number(c.gt):c.gt,gte:c.gte?Number(c.gte):c.gte,lt:c.lt?Number(c.lt):c.lt,lte:c.lte?Number(c.lte):c.lte}))}},[]),a=h.useCallback(n=>(n.value??[]).map(c=>({value:c,field:n.field,name:o(n.field),filter:u(n),remove:()=>{t(n.field,c,!1)}})),[u,o,t]),g=h.useCallback(n=>(n.range??[]).map(c=>{var d,A;const f=c.gte??c.gt??((d=s(n.field))==null?void 0:d.min),v=c.lte??c.lt??((A=s(n.field))==null?void 0:A.max);if(f!==void 0&&v!==void 0)return{value:`${f} - ${v}`,field:n.field,name:o(n.field),filter:u(n),remove:()=>{r(n.field,void 0)}}}).filter(Boolean),[u,s,o,r]);return{selectFilters:i,toValueFilter:a,toRangeFilter:g}}function R(){const{filter:e}=m.useNostoAppState(a=>{var g;return{filter:((g=a.query.products)==null?void 0:g.filter)??[]}}),{updateSearch:r}=m.useActions(),{selectFilters:t,toValueFilter:s,toRangeFilter:o}=T(),i=h.useMemo(()=>e?e.filter(t).flatMap(a=>"value"in a?s(a):"range"in a?o(a):[]).filter(Boolean):[],[e,t,o,s]),u=h.useCallback(()=>{r({products:{filter:[]}})},[r]);return{filters:i,removeAll:u}}function w(e){var c,f,v;const{replaceFilter:r}=m.useActions(),{query:t,products:s}=m.useNostoAppState(d=>({query:d.query,products:d.response.products})),o=(c=s==null?void 0:s.facets)==null?void 0:c.find(d=>d.id===e);if(!o)return{min:0,max:0,range:[0,0],updateRange:()=>{}};const i=(v=(f=t.products)==null?void 0:f.filter)==null?void 0:v.find(d=>d.field===o.field),u=i!=null&&i.range?i.range[0]:void 0,a=typeof u=="object"&&("gte"in u||"lte"in u)?[N.parseNumber(u.gte),N.parseNumber(u.lte)]:[void 0,void 0],g="min"in o?Math.floor(o.min):0,n="max"in o?Math.ceil(o.max):0,l=([d,A])=>{const p=d!==void 0?Math.floor(d):void 0,S=A!==void 0?Math.ceil(A):void 0,F=p!==void 0,b=S!==void 0;(g===p||!F)&&(n===S||!b)?r(o.field,void 0):(g===p||!F)&&b?r(o.field,{lte:S.toString()}):(n===S||!b)&&F?r(o.field,{gte:p.toString()}):F&&b&&r(o.field,{gte:p.toString(),lte:S.toString()})};return{min:g,max:n,range:[a[0]??g,a[1]??n],updateRange:l}}function V(e,r){const{min:t,max:s,range:o,updateRange:i}=w(e),{filters:u}=R(),a=h.useMemo(()=>{var A;const c=u.find(p=>{var S;return(S=p==null?void 0:p.filter)==null?void 0:S.range});let f=null;if(c){const p=(A=c.filter.range)==null?void 0:A[0];f=[N.parseNumber(p==null?void 0:p.gte),N.parseNumber(p==null?void 0:p.lte)]}const v=[];let d=Math.floor(t/r)*r;for(;d<s;){const p=d+r,S=f&&f[0]===d&&f[1]===p;v.push({min:d,max:p,selected:S}),d=p}return v},[u,t,s,r]),g=c=>{i([c,o[1]])},n=c=>{i([o[0],c])},l=t!==o[0]||s!==o[1];return{min:t,max:s,range:o,updateRange:i,ranges:a,handleMinChange:g,handleMaxChange:n,isSelected:l}}function B(){const{products:e,keywords:r}=m.useNostoAppState(t=>t.response);return{products:e??{hits:[],total:0},keywords:r??{hits:[],total:0}}}function D(){const e=m.useNostoAppState(t=>{var s;return(s=t.query.products)==null?void 0:s.filter});return h.useMemo(()=>e?e.reduce((t,s)=>t+(Array.isArray(s.value)?s.value.length:1),0):0,[e])}function M(e){return e&&!Number.isNaN(e)?e:0}function E(e,r){const{from:t,size:s,total:o}=m.useNostoAppState(n=>{var l,c,f,v,d;return{from:M(((l=n.query.products)==null?void 0:l.from)??0),size:M(((f=(c=n.response)==null?void 0:c.products)==null?void 0:f.size)??0),total:M(((d=(v=n.response)==null?void 0:v.products)==null?void 0:d.total)??0)}}),{updateSearch:i}=m.useActions(),u=t+s,a=[...e].reverse().filter(n=>n+r<o);return{from:t,to:u,total:o,size:s,sizeOptions:a,handleSizeChange:n=>{i({products:{size:N.parseNumber(n)}})}}}function _(e,r){return e.length!==r.length?!1:e.every(t=>r.find(s=>t.field===s.field&&t.order===s.order))}function $(e){var i,u;const r=m.useNostoAppState(a=>a.query),{updateSearch:t}=m.useActions();return{activeSort:((i=e.find(a=>{var g;return _(a.value.sort,((g=r.products)==null?void 0:g.sort)||[])}))==null?void 0:i.id)??((u=e[0])==null?void 0:u.id),setSort:a=>{const g=e.find(n=>n.id===a);g&&t({products:{sort:g.value.sort}})}}}function I(e,r){if(!e.length||!r.length)return[];const t=r.reduce((s,o)=>(s[o]={},s),{});return e.forEach(s=>{var o;(o=s.customFields)==null||o.forEach(({key:i,value:u})=>{const a=i.toLowerCase();r.includes(a)&&(t[a][u]=t[a][u]||[],t[a][u].push(s))})}),Object.entries(t).map(([s,o])=>({field:s,options:Object.entries(o).map(([i,u])=>({value:i,skus:u,unavailable:!1,selected:!1}))}))}function U(e,r){return e.length?e.map(({field:t,options:s})=>({field:t,options:s.map(o=>{var a;const i=!((a=o.skus)!=null&&a.some(g=>Object.entries(r).every(([n,l])=>{var f,v;return n===t?!0:((v=(f=g.customFields)==null?void 0:f.find(d=>d.key.toLowerCase()===n))==null?void 0:v.value)===l}))),u=r[t]===o.value;return{...o,unavailable:i,selected:u}})})):[]}function G(e=[],r=[]){const[t,s]=h.useState({}),o=h.useMemo(()=>U(I(e,r),t),[e,r,t]),i=h.useCallback((u,a)=>{s(g=>{const n={...g};return n[u]===a?delete n[u]:n[u]=a,n})},[]);return{swatches:o,toggleOption:i}}exports.useActions=m.useActions;exports.useLoadMore=m.useLoadMore;exports.useNostoAppState=m.useNostoAppState;exports.useDecoratedSearchResults=z;exports.useFacet=k;exports.useFacets=x;exports.usePagination=j;exports.usePersonalization=L;exports.useProductFilters=R;exports.useRange=w;exports.useRangeSelector=V;exports.useResponse=B;exports.useSelectedFiltersCount=D;exports.useSizeOptions=E;exports.useSort=$;exports.useSwatches=G;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("../useLoadMore-BRYyWQa0.cjs"),z=require("../logger-BcHMZObS.cjs"),m=require("preact/hooks"),P=require("../index.es-DlUp67LT.cjs"),N=require("../parseNumber-FsZ8w61u.cjs");function T(e){const r=S.useNostoAppState(t=>t.response);return e&&Array.isArray(e)||e&&z.isPlainObject(e)?e:r}function q(e){var c;const r=((c=e.data)==null?void 0:c.filter(u=>u.selected).length)??0,[t,n]=m.useState(r>0),{toggleProductFilter:o}=S.useActions();return{active:t,selectedFiltersCount:r,toggleActive:()=>{n(!t)},toggleProductFilter:o}}function L(){const{loading:e,facets:r}=S.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}=S.useNostoAppState(n=>({query:n.query,products:n.response.products}));return m.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,l=Math.max(Math.floor(o-1)/2,1),c=t.size>0?Math.floor(n/t.size)+1:1,u=t.size>0?Math.ceil(t.total/t.size):0,g=A=>A>=c-l&&A<=c+l,s=n+1,a=Math.min(n+t.total,t.total),i={from:n,page:c,current:!0},d=A=>({from:(A-1)*t.size,page:A,current:A===c}),h=c>1?d(c-1):void 0,f=c<u?d(c+1):void 0,b=c-l-1>1?d(1):void 0,p=c+l+1<u?d(u):void 0,v=O(1,u+1).filter(g).map(d);return!b&&((y=v[0])==null?void 0:y.page)===2&&v.unshift(d(1)),!p&&((R=v[v.length-1])==null?void 0:R.page)===u-1&&v.push(d(u)),{totalPages:u,resultsFrom:s,resultsTo:a,current:i,prev:h,next:f,first:b,last:p,pages:v}},[r,t,e==null?void 0:e.width])}function V(){const[e,r]=m.useState([]),[t,n]=m.useState([]);return m.useEffect(()=>{P.s(async o=>{const{products:l,segments:c}=await o.getSearchSessionParams();r(c??[]),n((l==null?void 0:l.personalizationBoost)??[])})},[]),{segments:e,boost:t}}function B(){const{facets:e}=S.useNostoAppState(s=>{var a;return{facets:((a=s.response.products)==null?void 0:a.facets)??[]}}),{replaceFilter:r,toggleProductFilter:t}=S.useActions(),n=m.useCallback(s=>{const a=e==null?void 0:e.find(i=>i.type==="stats"&&i.field===s);if(a&&"min"in a&&"max"in a)return a},[e]),o=m.useCallback(s=>{var a;return((a=e==null?void 0:e.find(i=>i.field===s))==null?void 0:a.name)??s},[e]),l=m.useCallback(s=>"field"in s&&(s.value instanceof Array||s.range instanceof Array),[]),c=m.useCallback(s=>{var a;return{...s,range:(a=s.range)==null?void 0:a.map(i=>({gt:i.gt?Number(i.gt):i.gt,gte:i.gte?Number(i.gte):i.gte,lt:i.lt?Number(i.lt):i.lt,lte:i.lte?Number(i.lte):i.lte}))}},[]),u=m.useCallback(s=>(s.value??[]).map(i=>({value:i,field:s.field,name:o(s.field),filter:c(s),remove:()=>{t(s.field,i,!1)}})),[c,o,t]),g=m.useCallback(s=>(s.range??[]).map(i=>{var f,b;const d=i.gte??i.gt??((f=n(s.field))==null?void 0:f.min),h=i.lte??i.lt??((b=n(s.field))==null?void 0:b.max);if(d!==void 0&&h!==void 0)return{value:`${d} - ${h}`,field:s.field,name:o(s.field),filter:c(s),remove:()=>{r(s.field,void 0)}}}).filter(Boolean),[c,n,o,r]);return{selectFilters:l,toValueFilter:u,toRangeFilter:g}}function C(){const{filter:e}=S.useNostoAppState(u=>{var g;return{filter:((g=u.query.products)==null?void 0:g.filter)??[]}}),{updateSearch:r}=S.useActions(),{selectFilters:t,toValueFilter:n,toRangeFilter:o}=B(),l=m.useMemo(()=>e?e.filter(t).flatMap(u=>"value"in u?n(u):"range"in u?o(u):[]).filter(Boolean):[],[e,t,o,n]),c=m.useCallback(()=>{r({products:{filter:[]}})},[r]);return{filters:l,removeAll:c}}function k(e){var i,d,h;const{replaceFilter:r}=S.useActions(),{query:t,products:n}=S.useNostoAppState(f=>({query:f.query,products:f.response.products})),o=(i=n==null?void 0:n.facets)==null?void 0:i.find(f=>f.id===e);if(!o)return{min:0,max:0,range:[0,0],updateRange:()=>{}};const l=(h=(d=t.products)==null?void 0:d.filter)==null?void 0:h.find(f=>f.field===o.field),c=l!=null&&l.range?l.range[0]:void 0,u=typeof c=="object"&&("gte"in c||"lte"in c)?[N.parseNumber(c.gte),N.parseNumber(c.lte)]:[void 0,void 0],g="min"in o?Math.floor(o.min):0,s="max"in o?Math.ceil(o.max):0,a=([f,b])=>{const p=f!==void 0?Math.floor(f):void 0,v=b!==void 0?Math.ceil(b):void 0,F=p!==void 0,y=v!==void 0;(g===p||!F)&&(s===v||!y)?r(o.field,void 0):(g===p||!F)&&y?r(o.field,{lte:v.toString()}):(s===v||!y)&&F?r(o.field,{gte:p.toString()}):F&&y&&r(o.field,{gte:p.toString(),lte:v.toString()})};return{min:g,max:s,range:[u[0]??g,u[1]??s],updateRange:a}}function D(e,r){const{min:t,max:n,range:o,updateRange:l}=k(e),{filters:c}=C(),u=m.useMemo(()=>{var b;const i=c.find(p=>{var v;return(v=p==null?void 0:p.filter)==null?void 0:v.range});let d=null;if(i){const p=(b=i.filter.range)==null?void 0:b[0];d=[N.parseNumber(p==null?void 0:p.gte),N.parseNumber(p==null?void 0:p.lte)]}const h=[];let f=Math.floor(t/r)*r;for(;f<n;){const p=f+r,v=d&&d[0]===f&&d[1]===p;h.push({min:f,max:p,selected:v}),f=p}return h},[c,t,n,r]),g=i=>{l([i,o[1]])},s=i=>{l([o[0],i])},a=t!==o[0]||n!==o[1];return{min:t,max:n,range:o,updateRange:l,ranges:u,handleMinChange:g,handleMaxChange:s,isSelected:a}}function U(){const{products:e,keywords:r}=S.useNostoAppState(t=>t.response);return{products:e??{hits:[],total:0},keywords:r??{hits:[],total:0}}}function E(){const e=S.useNostoAppState(t=>{var n;return(n=t.query.products)==null?void 0:n.filter});return m.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 _(e,r){const{from:t,size:n,total:o}=S.useNostoAppState(s=>{var a,i,d,h,f;return{from:M(((a=s.query.products)==null?void 0:a.from)??0),size:M(((d=(i=s.response)==null?void 0:i.products)==null?void 0:d.size)??0),total:M(((f=(h=s.response)==null?void 0:h.products)==null?void 0:f.total)??0)}}),{updateSearch:l}=S.useActions(),c=t+n,u=[...e].reverse().filter(s=>s+r<o);return{from:t,to:c,total:o,size:n,sizeOptions:u,handleSizeChange:s=>{l({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 l,c;const r=S.useNostoAppState(u=>u.query),{updateSearch:t}=S.useActions();return{activeSort:((l=e.find(u=>{var g;return $(u.value.sort,((g=r.products)==null?void 0:g.sort)||[])}))==null?void 0:l.id)??((c=e[0])==null?void 0:c.id),setSort:u=>{const g=e.find(s=>s.id===u);g&&t({products:{sort:g.value.sort}})}}}const w=window.SpeechRecognition||window.webkitSpeechRecognition,x=!!(w&&typeof w=="function");function G(){return{listening:!1,startListening:()=>{},stopListening:()=>{}}}function H({language:e="en-US",interimResults:r=!1}={}){const[t,n]=m.useState(!1),o=m.useRef(null),l=m.useCallback(({onResult:u,onError:g})=>{const s=new w;s.lang=e,s.interimResults=r,s.onstart=()=>n(!0),s.onresult=a=>{var d,h;const{transcript:i}=(h=(d=a.results)==null?void 0:d[0])==null?void 0:h[0];u(i)},g&&(s.onerror=a=>g(a.error)),s.onend=()=>n(!1),o.current=s,s.start()},[e,r]),c=m.useCallback(()=>{var u;(u=o.current)==null||u.stop()},[o]);return{listening:t,startListening:l,stopListening:c}}const J=x?H:G;function K(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:l,value:c})=>{const u=l.toLowerCase();r.includes(u)&&(t[u][c]=t[u][c]||[],t[u][c].push(n))})}),Object.entries(t).map(([n,o])=>({field:n,options:Object.entries(o).map(([l,c])=>({value:l,skus:c,unavailable:!1,selected:!1}))}))}function Q(e,r){return e.length?e.map(({field:t,options:n})=>({field:t,options:n.map(o=>{var u;const l=!((u=o.skus)!=null&&u.some(g=>Object.entries(r).every(([s,a])=>{var d,h;return s===t?!0:((h=(d=g.customFields)==null?void 0:d.find(f=>f.key.toLowerCase()===s))==null?void 0:h.value)===a}))),c=r[t]===o.value;return{...o,unavailable:l,selected:c}})})):[]}function W(e=[],r=[]){const[t,n]=m.useState({}),o=m.useMemo(()=>Q(K(e,r),t),[e,r,t]),l=m.useCallback((u,g)=>{n(s=>{const a={...s};return a[u]===g?delete a[u]:a[u]=g,a})},[]),c=m.useMemo(()=>Object.keys(t).filter(s=>t[s]).length===0?[]:o.filter(({field:s})=>t[s]).map(({field:s,options:a})=>{const i=t[s],d=a.find(h=>h.value===i);return(d==null?void 0:d.skus)??[]}).reduce((s,a)=>s.filter(i=>a.includes(i))),[o,t]);return{swatches:o,toggleOption:l,matchedSkus:c}}exports.useActions=S.useActions;exports.useLoadMore=S.useLoadMore;exports.useNostoAppState=S.useNostoAppState;exports.speechToTextSupported=x;exports.useDecoratedSearchResults=T;exports.useFacet=q;exports.useFacets=L;exports.usePagination=j;exports.usePersonalization=V;exports.useProductFilters=C;exports.useRange=k;exports.useRangeSelector=D;exports.useResponse=U;exports.useSelectedFiltersCount=E;exports.useSizeOptions=_;exports.useSort=I;exports.useSpeechToText=J;exports.useSwatches=W;
@@ -14,4 +14,5 @@ export { useResponse } from './src/hooks/useResponse';
14
14
  export { useSelectedFiltersCount } from './src/hooks/useSelectedFiltersCount';
15
15
  export { useSizeOptions } from './src/hooks/useSizeOptions';
16
16
  export { useSort } from './src/hooks/useSort/useSort';
17
+ export { type SpeechToText, speechToTextSupported, useSpeechToText } from './src/hooks/useSpeechToText';
17
18
  export { useSwatches } from './src/hooks/useSwatches/useSwatches';
@@ -1,55 +1,55 @@
1
- import { a as S, c as M } from "../useLoadMore-4FYGzDwd.js";
2
- import { b as re } from "../useLoadMore-4FYGzDwd.js";
3
- import { a as N } from "../logger-DVwg4Wor.js";
4
- import { useState as z, useMemo as x, useEffect as C, useCallback as y } from "preact/hooks";
5
- import { s as q } from "../index.es-B8mbAxS4.js";
6
- import { p as R } from "../parseNumber-QA48nJLp.js";
7
- function _(e) {
8
- const s = S((t) => t.response);
9
- return e && Array.isArray(e) || e && N(e) ? e : s;
1
+ import { a as y, c as x } from "../useLoadMore-4FYGzDwd.js";
2
+ import { b as ae } from "../useLoadMore-4FYGzDwd.js";
3
+ import { a as T } from "../logger-DVwg4Wor.js";
4
+ import { useState as M, useMemo as b, useEffect as C, useCallback as S, useRef as q } from "preact/hooks";
5
+ import { s as L } from "../index.es-B8mbAxS4.js";
6
+ import { p as z } from "../parseNumber-QA48nJLp.js";
7
+ function Q(e) {
8
+ const o = y((t) => t.response);
9
+ return e && Array.isArray(e) || e && T(e) ? e : o;
10
10
  }
11
- function G(e) {
12
- var c;
13
- const s = ((c = e.data) == null ? void 0 : c.filter((i) => i.selected).length) ?? 0, [t, n] = z(s > 0), { toggleProductFilter: o } = M();
11
+ function W(e) {
12
+ var i;
13
+ const o = ((i = e.data) == null ? void 0 : i.filter((c) => c.selected).length) ?? 0, [t, r] = M(o > 0), { toggleProductFilter: s } = x();
14
14
  return {
15
15
  /** Active value */
16
16
  active: t,
17
17
  /** Selected filters count */
18
- selectedFiltersCount: s,
18
+ selectedFiltersCount: o,
19
19
  /** Toggle active function */
20
20
  toggleActive: () => {
21
- n(!t);
21
+ r(!t);
22
22
  },
23
23
  /** Toggle product filter function */
24
- toggleProductFilter: o
24
+ toggleProductFilter: s
25
25
  };
26
26
  }
27
- function H() {
28
- const { loading: e, facets: s } = S((t) => {
29
- var n, o;
27
+ function X() {
28
+ const { loading: e, facets: o } = y((t) => {
29
+ var r, s;
30
30
  return {
31
31
  loading: t.loading,
32
- facets: ((o = (n = t.response) == null ? void 0 : n.products) == null ? void 0 : o.facets) ?? []
32
+ facets: ((s = (r = t.response) == null ? void 0 : r.products) == null ? void 0 : s.facets) ?? []
33
33
  };
34
34
  });
35
35
  return {
36
36
  /** Loading state */
37
37
  loading: e,
38
38
  /** Array of facets*/
39
- facets: s
39
+ facets: o
40
40
  };
41
41
  }
42
- function O(e, s) {
43
- const t = s - e;
44
- return !isNaN(t) && t > 0 ? new Array(s - e).fill(void 0).map((n, o) => o + e) : [];
42
+ function k(e, o) {
43
+ const t = o - e;
44
+ return !isNaN(t) && t > 0 ? new Array(o - e).fill(void 0).map((r, s) => s + e) : [];
45
45
  }
46
- function J(e) {
47
- const { query: s, products: t } = S((n) => ({
48
- query: n.query,
49
- products: n.response.products
46
+ function Y(e) {
47
+ const { query: o, products: t } = y((r) => ({
48
+ query: r.query,
49
+ products: r.response.products
50
50
  }));
51
- return x(() => {
52
- var F, b, P;
51
+ return b(() => {
52
+ var F, w, N;
53
53
  if (!t)
54
54
  return {
55
55
  totalPages: 0,
@@ -57,131 +57,131 @@ function J(e) {
57
57
  resultsTo: 0,
58
58
  pages: []
59
59
  };
60
- const n = ((F = s.products) == null ? void 0 : F.from) ?? 0, o = (e == null ? void 0 : e.width) ?? 1 / 0, u = Math.max(Math.floor(o - 1) / 2, 1), c = t.size > 0 ? Math.floor(n / t.size) + 1 : 1, i = t.size > 0 ? Math.ceil(t.total / t.size) : 0, f = (w) => w >= c - u && w <= c + u, r = n + 1, l = Math.min(n + t.total, t.total), a = {
61
- from: n,
62
- page: c,
60
+ const r = ((F = o.products) == null ? void 0 : F.from) ?? 0, s = (e == null ? void 0 : e.width) ?? 1 / 0, l = Math.max(Math.floor(s - 1) / 2, 1), i = t.size > 0 ? Math.floor(r / t.size) + 1 : 1, c = t.size > 0 ? Math.ceil(t.total / t.size) : 0, f = (R) => R >= i - l && R <= i + l, n = r + 1, a = Math.min(r + t.total, t.total), u = {
61
+ from: r,
62
+ page: i,
63
63
  current: !0
64
- }, g = (w) => ({
65
- from: (w - 1) * t.size,
66
- page: w,
67
- current: w === c
68
- }), h = c > 1 ? g(c - 1) : void 0, d = c < i ? g(c + 1) : void 0, v = c - u - 1 > 1 ? g(1) : void 0, m = c + u + 1 < i ? g(i) : void 0, p = O(1, i + 1).filter(f).map(g);
69
- return !v && ((b = p[0]) == null ? void 0 : b.page) === 2 && p.unshift(g(1)), !m && ((P = p[p.length - 1]) == null ? void 0 : P.page) === i - 1 && p.push(g(i)), {
70
- totalPages: i,
71
- resultsFrom: r,
72
- resultsTo: l,
73
- current: a,
74
- prev: h,
75
- next: d,
64
+ }, d = (R) => ({
65
+ from: (R - 1) * t.size,
66
+ page: R,
67
+ current: R === i
68
+ }), p = i > 1 ? d(i - 1) : void 0, g = i < c ? d(i + 1) : void 0, v = i - l - 1 > 1 ? d(1) : void 0, m = i + l + 1 < c ? d(c) : void 0, h = k(1, c + 1).filter(f).map(d);
69
+ return !v && ((w = h[0]) == null ? void 0 : w.page) === 2 && h.unshift(d(1)), !m && ((N = h[h.length - 1]) == null ? void 0 : N.page) === c - 1 && h.push(d(c)), {
70
+ totalPages: c,
71
+ resultsFrom: n,
72
+ resultsTo: a,
73
+ current: u,
74
+ prev: p,
75
+ next: g,
76
76
  first: v,
77
77
  last: m,
78
- pages: p
78
+ pages: h
79
79
  };
80
- }, [s, t, e == null ? void 0 : e.width]);
80
+ }, [o, t, e == null ? void 0 : e.width]);
81
81
  }
82
- function K() {
83
- const [e, s] = z([]), [t, n] = z([]);
82
+ function Z() {
83
+ const [e, o] = M([]), [t, r] = M([]);
84
84
  return C(() => {
85
- q(async (o) => {
86
- const { products: u, segments: c } = await o.getSearchSessionParams();
87
- s(c ?? []), n((u == null ? void 0 : u.personalizationBoost) ?? []);
85
+ L(async (s) => {
86
+ const { products: l, segments: i } = await s.getSearchSessionParams();
87
+ o(i ?? []), r((l == null ? void 0 : l.personalizationBoost) ?? []);
88
88
  });
89
89
  }, []), {
90
90
  segments: e,
91
91
  boost: t
92
92
  };
93
93
  }
94
- function j() {
95
- const { facets: e } = S((r) => {
96
- var l;
94
+ function O() {
95
+ const { facets: e } = y((n) => {
96
+ var a;
97
97
  return {
98
- facets: ((l = r.response.products) == null ? void 0 : l.facets) ?? []
98
+ facets: ((a = n.response.products) == null ? void 0 : a.facets) ?? []
99
99
  };
100
- }), { replaceFilter: s, toggleProductFilter: t } = M(), n = y(
101
- (r) => {
102
- const l = e == null ? void 0 : e.find((a) => a.type === "stats" && a.field === r);
103
- if (l && "min" in l && "max" in l)
104
- return l;
100
+ }), { replaceFilter: o, toggleProductFilter: t } = x(), r = S(
101
+ (n) => {
102
+ const a = e == null ? void 0 : e.find((u) => u.type === "stats" && u.field === n);
103
+ if (a && "min" in a && "max" in a)
104
+ return a;
105
105
  },
106
106
  [e]
107
- ), o = y(
108
- (r) => {
109
- var l;
110
- return ((l = e == null ? void 0 : e.find((a) => a.field === r)) == null ? void 0 : l.name) ?? r;
107
+ ), s = S(
108
+ (n) => {
109
+ var a;
110
+ return ((a = e == null ? void 0 : e.find((u) => u.field === n)) == null ? void 0 : a.name) ?? n;
111
111
  },
112
112
  [e]
113
- ), u = y((r) => "field" in r && (r.value instanceof Array || r.range instanceof Array), []), c = y((r) => {
114
- var l;
113
+ ), l = S((n) => "field" in n && (n.value instanceof Array || n.range instanceof Array), []), i = S((n) => {
114
+ var a;
115
115
  return {
116
- ...r,
117
- range: (l = r.range) == null ? void 0 : l.map((a) => ({
118
- gt: a.gt ? Number(a.gt) : a.gt,
119
- gte: a.gte ? Number(a.gte) : a.gte,
120
- lt: a.lt ? Number(a.lt) : a.lt,
121
- lte: a.lte ? Number(a.lte) : a.lte
116
+ ...n,
117
+ range: (a = n.range) == null ? void 0 : a.map((u) => ({
118
+ gt: u.gt ? Number(u.gt) : u.gt,
119
+ gte: u.gte ? Number(u.gte) : u.gte,
120
+ lt: u.lt ? Number(u.lt) : u.lt,
121
+ lte: u.lte ? Number(u.lte) : u.lte
122
122
  }))
123
123
  };
124
- }, []), i = y(
125
- (r) => (r.value ?? []).map((a) => ({
126
- value: a,
127
- field: r.field,
128
- name: o(r.field),
129
- filter: c(r),
124
+ }, []), c = S(
125
+ (n) => (n.value ?? []).map((u) => ({
126
+ value: u,
127
+ field: n.field,
128
+ name: s(n.field),
129
+ filter: i(n),
130
130
  remove: () => {
131
- t(r.field, a, !1);
131
+ t(n.field, u, !1);
132
132
  }
133
133
  })),
134
- [c, o, t]
135
- ), f = y(
136
- (r) => (r.range ?? []).map((a) => {
137
- var d, v;
138
- const g = a.gte ?? a.gt ?? ((d = n(r.field)) == null ? void 0 : d.min), h = a.lte ?? a.lt ?? ((v = n(r.field)) == null ? void 0 : v.max);
139
- if (g !== void 0 && h !== void 0)
134
+ [i, s, t]
135
+ ), f = S(
136
+ (n) => (n.range ?? []).map((u) => {
137
+ var g, v;
138
+ const d = u.gte ?? u.gt ?? ((g = r(n.field)) == null ? void 0 : g.min), p = u.lte ?? u.lt ?? ((v = r(n.field)) == null ? void 0 : v.max);
139
+ if (d !== void 0 && p !== void 0)
140
140
  return {
141
- value: `${g} - ${h}`,
142
- field: r.field,
143
- name: o(r.field),
144
- filter: c(r),
141
+ value: `${d} - ${p}`,
142
+ field: n.field,
143
+ name: s(n.field),
144
+ filter: i(n),
145
145
  remove: () => {
146
- s(r.field, void 0);
146
+ o(n.field, void 0);
147
147
  }
148
148
  };
149
149
  }).filter(Boolean),
150
- [c, n, o, s]
150
+ [i, r, s, o]
151
151
  );
152
152
  return {
153
- selectFilters: u,
154
- toValueFilter: i,
153
+ selectFilters: l,
154
+ toValueFilter: c,
155
155
  toRangeFilter: f
156
156
  };
157
157
  }
158
- function k() {
159
- const { filter: e } = S((i) => {
158
+ function j() {
159
+ const { filter: e } = y((c) => {
160
160
  var f;
161
161
  return {
162
- filter: ((f = i.query.products) == null ? void 0 : f.filter) ?? []
162
+ filter: ((f = c.query.products) == null ? void 0 : f.filter) ?? []
163
163
  };
164
- }), { updateSearch: s } = M(), { selectFilters: t, toValueFilter: n, toRangeFilter: o } = j(), u = x(() => e ? e.filter(t).flatMap((i) => "value" in i ? n(i) : "range" in i ? o(i) : []).filter(Boolean) : [], [e, t, o, n]), c = y(() => {
165
- s({
164
+ }), { updateSearch: o } = x(), { selectFilters: t, toValueFilter: r, toRangeFilter: s } = O(), l = b(() => e ? e.filter(t).flatMap((c) => "value" in c ? r(c) : "range" in c ? s(c) : []).filter(Boolean) : [], [e, t, s, r]), i = S(() => {
165
+ o({
166
166
  products: {
167
167
  filter: []
168
168
  }
169
169
  });
170
- }, [s]);
170
+ }, [o]);
171
171
  return {
172
172
  /** Selected filters array. */
173
- filters: u,
173
+ filters: l,
174
174
  /** Should remove all selected filters. */
175
- removeAll: c
175
+ removeAll: i
176
176
  };
177
177
  }
178
178
  function V(e) {
179
- var a, g, h;
180
- const { replaceFilter: s } = M(), { query: t, products: n } = S((d) => ({
181
- query: d.query,
182
- products: d.response.products
183
- })), o = (a = n == null ? void 0 : n.facets) == null ? void 0 : a.find((d) => d.id === e);
184
- if (!o)
179
+ var u, d, p;
180
+ const { replaceFilter: o } = x(), { query: t, products: r } = y((g) => ({
181
+ query: g.query,
182
+ products: g.response.products
183
+ })), s = (u = r == null ? void 0 : r.facets) == null ? void 0 : u.find((g) => g.id === e);
184
+ if (!s)
185
185
  return {
186
186
  min: 0,
187
187
  max: 0,
@@ -189,139 +189,139 @@ function V(e) {
189
189
  updateRange: () => {
190
190
  }
191
191
  };
192
- const u = (h = (g = t.products) == null ? void 0 : g.filter) == null ? void 0 : h.find((d) => d.field === o.field), c = u != null && u.range ? u.range[0] : void 0, i = typeof c == "object" && ("gte" in c || "lte" in c) ? [R(c.gte), R(c.lte)] : [void 0, void 0], f = "min" in o ? Math.floor(o.min) : 0, r = "max" in o ? Math.ceil(o.max) : 0, l = ([d, v]) => {
193
- const m = d !== void 0 ? Math.floor(d) : void 0, p = v !== void 0 ? Math.ceil(v) : void 0, F = m !== void 0, b = p !== void 0;
194
- (f === m || !F) && (r === p || !b) ? s(o.field, void 0) : (f === m || !F) && b ? s(o.field, {
195
- lte: p.toString()
196
- }) : (r === p || !b) && F ? s(o.field, {
192
+ const l = (p = (d = t.products) == null ? void 0 : d.filter) == null ? void 0 : p.find((g) => g.field === s.field), i = l != null && l.range ? l.range[0] : void 0, c = typeof i == "object" && ("gte" in i || "lte" in i) ? [z(i.gte), z(i.lte)] : [void 0, void 0], f = "min" in s ? Math.floor(s.min) : 0, n = "max" in s ? Math.ceil(s.max) : 0, a = ([g, v]) => {
193
+ 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;
194
+ (f === m || !F) && (n === h || !w) ? o(s.field, void 0) : (f === m || !F) && w ? o(s.field, {
195
+ lte: h.toString()
196
+ }) : (n === h || !w) && F ? o(s.field, {
197
197
  gte: m.toString()
198
- }) : F && b && s(o.field, {
198
+ }) : F && w && o(s.field, {
199
199
  gte: m.toString(),
200
- lte: p.toString()
200
+ lte: h.toString()
201
201
  });
202
202
  };
203
203
  return {
204
204
  /** Min value */
205
205
  min: f,
206
206
  /** Max value */
207
- max: r,
207
+ max: n,
208
208
  /** Range value */
209
- range: [i[0] ?? f, i[1] ?? r],
209
+ range: [c[0] ?? f, c[1] ?? n],
210
210
  /** Update range function */
211
- updateRange: l
211
+ updateRange: a
212
212
  };
213
213
  }
214
- function Q(e, s) {
215
- const { min: t, max: n, range: o, updateRange: u } = V(e), { filters: c } = k(), i = x(() => {
214
+ function ee(e, o) {
215
+ const { min: t, max: r, range: s, updateRange: l } = V(e), { filters: i } = j(), c = b(() => {
216
216
  var v;
217
- const a = c.find((m) => {
218
- var p;
219
- return (p = m == null ? void 0 : m.filter) == null ? void 0 : p.range;
217
+ const u = i.find((m) => {
218
+ var h;
219
+ return (h = m == null ? void 0 : m.filter) == null ? void 0 : h.range;
220
220
  });
221
- let g = null;
222
- if (a) {
223
- const m = (v = a.filter.range) == null ? void 0 : v[0];
224
- g = [R(m == null ? void 0 : m.gte), R(m == null ? void 0 : m.lte)];
221
+ let d = null;
222
+ if (u) {
223
+ const m = (v = u.filter.range) == null ? void 0 : v[0];
224
+ d = [z(m == null ? void 0 : m.gte), z(m == null ? void 0 : m.lte)];
225
225
  }
226
- const h = [];
227
- let d = Math.floor(t / s) * s;
228
- for (; d < n; ) {
229
- const m = d + s, p = g && g[0] === d && g[1] === m;
230
- h.push({
231
- min: d,
226
+ const p = [];
227
+ let g = Math.floor(t / o) * o;
228
+ for (; g < r; ) {
229
+ const m = g + o, h = d && d[0] === g && d[1] === m;
230
+ p.push({
231
+ min: g,
232
232
  max: m,
233
- selected: p
234
- }), d = m;
233
+ selected: h
234
+ }), g = m;
235
235
  }
236
- return h;
237
- }, [c, t, n, s]), f = (a) => {
238
- u([a, o[1]]);
239
- }, r = (a) => {
240
- u([o[0], a]);
241
- }, l = t !== o[0] || n !== o[1];
236
+ return p;
237
+ }, [i, t, r, o]), f = (u) => {
238
+ l([u, s[1]]);
239
+ }, n = (u) => {
240
+ l([s[0], u]);
241
+ }, a = t !== s[0] || r !== s[1];
242
242
  return {
243
243
  /** Minimum value */
244
244
  min: t,
245
245
  /** Maximum value */
246
- max: n,
246
+ max: r,
247
247
  /** Range value */
248
- range: o,
248
+ range: s,
249
249
  /** Update range function */
250
- updateRange: u,
250
+ updateRange: l,
251
251
  /** Ranges */
252
- ranges: i,
252
+ ranges: c,
253
253
  /** Handle min change */
254
254
  handleMinChange: f,
255
255
  /** Handle max change */
256
- handleMaxChange: r,
256
+ handleMaxChange: n,
257
257
  /** Is selected */
258
- isSelected: l
258
+ isSelected: a
259
259
  };
260
260
  }
261
- function W() {
262
- const { products: e, keywords: s } = S((t) => t.response);
261
+ function te() {
262
+ const { products: e, keywords: o } = y((t) => t.response);
263
263
  return {
264
264
  /** Array of products */
265
265
  products: e ?? { hits: [], total: 0 },
266
266
  /** Array of keywords */
267
- keywords: s ?? { hits: [], total: 0 }
267
+ keywords: o ?? { hits: [], total: 0 }
268
268
  };
269
269
  }
270
- function X() {
271
- const e = S((t) => {
272
- var n;
273
- return (n = t.query.products) == null ? void 0 : n.filter;
270
+ function ne() {
271
+ const e = y((t) => {
272
+ var r;
273
+ return (r = t.query.products) == null ? void 0 : r.filter;
274
274
  });
275
- return x(() => e ? e.reduce((t, n) => t + (Array.isArray(n.value) ? n.value.length : 1), 0) : 0, [e]);
275
+ return b(() => e ? e.reduce((t, r) => t + (Array.isArray(r.value) ? r.value.length : 1), 0) : 0, [e]);
276
276
  }
277
277
  function A(e) {
278
278
  return e && !Number.isNaN(e) ? e : 0;
279
279
  }
280
- function Y(e, s) {
281
- const { from: t, size: n, total: o } = S((r) => {
282
- var l, a, g, h, d;
280
+ function re(e, o) {
281
+ const { from: t, size: r, total: s } = y((n) => {
282
+ var a, u, d, p, g;
283
283
  return {
284
- from: A(((l = r.query.products) == null ? void 0 : l.from) ?? 0),
285
- size: A(((g = (a = r.response) == null ? void 0 : a.products) == null ? void 0 : g.size) ?? 0),
286
- total: A(((d = (h = r.response) == null ? void 0 : h.products) == null ? void 0 : d.total) ?? 0)
284
+ from: A(((a = n.query.products) == null ? void 0 : a.from) ?? 0),
285
+ size: A(((d = (u = n.response) == null ? void 0 : u.products) == null ? void 0 : d.size) ?? 0),
286
+ total: A(((g = (p = n.response) == null ? void 0 : p.products) == null ? void 0 : g.total) ?? 0)
287
287
  };
288
- }), { updateSearch: u } = M(), c = t + n, i = [...e].reverse().filter((r) => r + s < o);
288
+ }), { updateSearch: l } = x(), i = t + r, c = [...e].reverse().filter((n) => n + o < s);
289
289
  return {
290
290
  /** from value */
291
291
  from: t,
292
292
  /** to value */
293
- to: c,
293
+ to: i,
294
294
  /** total value */
295
- total: o,
295
+ total: s,
296
296
  /** size value */
297
- size: n,
297
+ size: r,
298
298
  /** Array of size options */
299
- sizeOptions: i,
299
+ sizeOptions: c,
300
300
  /** Should be called when size is changed */
301
- handleSizeChange: (r) => {
302
- u({
301
+ handleSizeChange: (n) => {
302
+ l({
303
303
  products: {
304
- size: R(r)
304
+ size: z(n)
305
305
  }
306
306
  });
307
307
  }
308
308
  };
309
309
  }
310
- function B(e, s) {
311
- return e.length !== s.length ? !1 : e.every((t) => s.find((n) => t.field === n.field && t.order === n.order));
310
+ function B(e, o) {
311
+ return e.length !== o.length ? !1 : e.every((t) => o.find((r) => t.field === r.field && t.order === r.order));
312
312
  }
313
- function Z(e) {
314
- var u, c;
315
- const s = S((i) => i.query), { updateSearch: t } = M();
313
+ function se(e) {
314
+ var l, i;
315
+ const o = y((c) => c.query), { updateSearch: t } = x();
316
316
  return {
317
317
  /** Active sort */
318
- activeSort: ((u = e.find((i) => {
318
+ activeSort: ((l = e.find((c) => {
319
319
  var f;
320
- return B(i.value.sort, ((f = s.products) == null ? void 0 : f.sort) || []);
321
- })) == null ? void 0 : u.id) ?? ((c = e[0]) == null ? void 0 : c.id),
320
+ return B(c.value.sort, ((f = o.products) == null ? void 0 : f.sort) || []);
321
+ })) == null ? void 0 : l.id) ?? ((i = e[0]) == null ? void 0 : i.id),
322
322
  /** Set sort function */
323
- setSort: (i) => {
324
- const f = e.find((r) => r.id === i);
323
+ setSort: (c) => {
324
+ const f = e.find((n) => n.id === c);
325
325
  f && t({
326
326
  products: {
327
327
  sort: f.value.sort
@@ -330,66 +330,106 @@ function Z(e) {
330
330
  }
331
331
  };
332
332
  }
333
- function T(e, s) {
334
- if (!e.length || !s.length) return [];
335
- const t = s.reduce((n, o) => (n[o] = {}, n), {});
336
- return e.forEach((n) => {
337
- var o;
338
- (o = n.customFields) == null || o.forEach(({ key: u, value: c }) => {
339
- const i = u.toLowerCase();
340
- s.includes(i) && (t[i][c] = t[i][c] || [], t[i][c].push(n));
333
+ const P = window.SpeechRecognition || window.webkitSpeechRecognition, D = !!(P && typeof P == "function");
334
+ function U() {
335
+ return {
336
+ listening: !1,
337
+ startListening: () => {
338
+ },
339
+ stopListening: () => {
340
+ }
341
+ };
342
+ }
343
+ function E({
344
+ language: e = "en-US",
345
+ interimResults: o = !1
346
+ } = {}) {
347
+ const [t, r] = M(!1), s = q(null), l = S(
348
+ ({ onResult: c, onError: f }) => {
349
+ const n = new P();
350
+ n.lang = e, n.interimResults = o, n.onstart = () => r(!0), n.onresult = (a) => {
351
+ var d, p;
352
+ const { transcript: u } = (p = (d = a.results) == null ? void 0 : d[0]) == null ? void 0 : p[0];
353
+ c(u);
354
+ }, f && (n.onerror = (a) => f(a.error)), n.onend = () => r(!1), s.current = n, n.start();
355
+ },
356
+ [e, o]
357
+ ), i = S(() => {
358
+ var c;
359
+ (c = s.current) == null || c.stop();
360
+ }, [s]);
361
+ return {
362
+ listening: t,
363
+ startListening: l,
364
+ stopListening: i
365
+ };
366
+ }
367
+ const oe = D ? E : U;
368
+ function $(e, o) {
369
+ if (!e.length || !o.length) return [];
370
+ const t = o.reduce((r, s) => (r[s] = {}, r), {});
371
+ return e.forEach((r) => {
372
+ var s;
373
+ (s = r.customFields) == null || s.forEach(({ key: l, value: i }) => {
374
+ const c = l.toLowerCase();
375
+ o.includes(c) && (t[c][i] = t[c][i] || [], t[c][i].push(r));
341
376
  });
342
- }), Object.entries(t).map(([n, o]) => ({
343
- field: n,
344
- options: Object.entries(o).map(([u, c]) => ({
345
- value: u,
346
- skus: c,
377
+ }), Object.entries(t).map(([r, s]) => ({
378
+ field: r,
379
+ options: Object.entries(s).map(([l, i]) => ({
380
+ value: l,
381
+ skus: i,
347
382
  unavailable: !1,
348
383
  selected: !1
349
384
  }))
350
385
  }));
351
386
  }
352
- function D(e, s) {
353
- return e.length ? e.map(({ field: t, options: n }) => ({
387
+ function I(e, o) {
388
+ return e.length ? e.map(({ field: t, options: r }) => ({
354
389
  field: t,
355
- options: n.map((o) => {
356
- var i;
357
- const u = !((i = o.skus) != null && i.some((f) => Object.entries(s).every(([r, l]) => {
358
- var g, h;
359
- return r === t ? !0 : ((h = (g = f.customFields) == null ? void 0 : g.find((d) => d.key.toLowerCase() === r)) == null ? void 0 : h.value) === l;
360
- }))), c = s[t] === o.value;
390
+ options: r.map((s) => {
391
+ var c;
392
+ const l = !((c = s.skus) != null && c.some((f) => Object.entries(o).every(([n, a]) => {
393
+ var d, p;
394
+ return n === t ? !0 : ((p = (d = f.customFields) == null ? void 0 : d.find((g) => g.key.toLowerCase() === n)) == null ? void 0 : p.value) === a;
395
+ }))), i = o[t] === s.value;
361
396
  return {
362
- ...o,
363
- unavailable: u,
364
- selected: c
397
+ ...s,
398
+ unavailable: l,
399
+ selected: i
365
400
  };
366
401
  })
367
402
  })) : [];
368
403
  }
369
- function ee(e = [], s = []) {
370
- const [t, n] = z({}), o = x(() => D(T(e, s), t), [e, s, t]), u = y((c, i) => {
371
- n((f) => {
372
- const r = { ...f };
373
- return r[c] === i ? delete r[c] : r[c] = i, r;
404
+ function ce(e = [], o = []) {
405
+ const [t, r] = M({}), s = b(() => I($(e, o), t), [e, o, t]), l = S((c, f) => {
406
+ r((n) => {
407
+ const a = { ...n };
408
+ return a[c] === f ? delete a[c] : a[c] = f, a;
374
409
  });
375
- }, []);
376
- return { swatches: o, toggleOption: u };
410
+ }, []), i = b(() => Object.keys(t).filter((n) => t[n]).length === 0 ? [] : s.filter(({ field: n }) => t[n]).map(({ field: n, options: a }) => {
411
+ const u = t[n], d = a.find((p) => p.value === u);
412
+ return (d == null ? void 0 : d.skus) ?? [];
413
+ }).reduce((n, a) => n.filter((u) => a.includes(u))), [s, t]);
414
+ return { swatches: s, toggleOption: l, matchedSkus: i };
377
415
  }
378
416
  export {
379
- M as useActions,
380
- _ as useDecoratedSearchResults,
381
- G as useFacet,
382
- H as useFacets,
383
- re as useLoadMore,
384
- S as useNostoAppState,
385
- J as usePagination,
386
- K as usePersonalization,
387
- k as useProductFilters,
417
+ D as speechToTextSupported,
418
+ x as useActions,
419
+ Q as useDecoratedSearchResults,
420
+ W as useFacet,
421
+ X as useFacets,
422
+ ae as useLoadMore,
423
+ y as useNostoAppState,
424
+ Y as usePagination,
425
+ Z as usePersonalization,
426
+ j as useProductFilters,
388
427
  V as useRange,
389
- Q as useRangeSelector,
390
- W as useResponse,
391
- X as useSelectedFiltersCount,
392
- Y as useSizeOptions,
393
- Z as useSort,
394
- ee as useSwatches
428
+ ee as useRangeSelector,
429
+ te as useResponse,
430
+ ne as useSelectedFiltersCount,
431
+ re as useSizeOptions,
432
+ se as useSort,
433
+ oe as useSpeechToText,
434
+ ce as useSwatches
395
435
  };
@@ -0,0 +1,52 @@
1
+ interface SpeechToTextOptions {
2
+ language?: string;
3
+ interimResults?: boolean;
4
+ }
5
+ interface StartListeningOptions {
6
+ onResult: (value: string) => void;
7
+ onError?: (error: string) => void;
8
+ }
9
+ export type SpeechToText = {
10
+ listening: boolean;
11
+ startListening: (options: StartListeningOptions) => void;
12
+ stopListening: () => void;
13
+ };
14
+ export declare const speechToTextSupported: boolean;
15
+ declare function useSpeechToTextSupported({ language, interimResults }?: SpeechToTextOptions): SpeechToText;
16
+ /**
17
+ * Preact hook that provides speech-to-text functionality using the Web Speech API.
18
+ * @example
19
+ * ```jsx
20
+ * import { useNostoAppState, useSpeechToText, speechToTextSupported } from "@nosto/search-js/preact/hooks"
21
+ *
22
+ * export default function MyComponent() {
23
+ * const { newSearch } = useActions()
24
+ * const { startListening, stopListening, listening } = useSpeechToText()
25
+ * if (!speechToTextSupported) {
26
+ * return null
27
+ * }
28
+ *
29
+ * return (
30
+ * <button
31
+ * onClick={() => {
32
+ * if (listening) {
33
+ * stopListening()
34
+ * } else {
35
+ * startListening({
36
+ * onResult: value => {
37
+ * newSearch({
38
+ * query: value
39
+ * })
40
+ * }
41
+ * })
42
+ * }
43
+ * }}
44
+ * >
45
+ * 🎤︎︎
46
+ * </button>
47
+ * )
48
+ * }
49
+ * ```
50
+ */
51
+ export declare const useSpeechToText: typeof useSpeechToTextSupported;
52
+ export {};
@@ -5,15 +5,24 @@ import { SearchProductSku } from '@nosto/nosto-js/client';
5
5
  * This hook aggregates SKU data by specified fields (e.g., "color", "size"),
6
6
  * generates swatch options, and manages the selection state for those options.
7
7
  *
8
+ * * Use `matchedSkus` to:
9
+ * - Display preview data like images or prices from partial selections.
10
+ * - Enable actions like "Add to Cart" when exactly one matching SKU remains.
11
+ *
8
12
  * @example
9
13
  * ```jsx
10
14
  * import { useSwatches } from '@nosto/search-js/preact/hooks'
11
15
  *
12
16
  * export default () => {
13
- * const { swatches, toggleOption } = useSwatches(skus, ["color", "size"])
17
+ * const { swatches, toggleOption, matchedSkus } = useSwatches(skus, ["color", "size"])
18
+ *
19
+ * const canAddToCart = matchedSkus.length === 1
20
+ * const previewImage = matchedSkus[0]?.imageUrl || "/fallback.jpg"
14
21
  *
15
22
  * return (
16
23
  * <div>
24
+ * <img src={previewImage} alt="Product preview" width={200} />
25
+ *
17
26
  * {swatches.map(({ field, options }) => (
18
27
  * <div key={field}>
19
28
  * {options.map(({ value, unavailable, selected }) => (
@@ -22,8 +31,11 @@ import { SearchProductSku } from '@nosto/nosto-js/client';
22
31
  * disabled={unavailable}
23
32
  * onClick={() => toggleOption(field, value)}
24
33
  * style={{
25
- * background: selected ? "#0070f3" : "transparent",
34
+ * margin: "4px",
35
+ * padding: "8px 12px",
36
+ * background: selected ? "#0070f3" : "#eee",
26
37
  * color: selected ? "#fff" : "#000",
38
+ * opacity: unavailable ? 0.3 : 1
27
39
  * }}
28
40
  * >
29
41
  * {value}
@@ -31,6 +43,10 @@ import { SearchProductSku } from '@nosto/nosto-js/client';
31
43
  * ))}
32
44
  * </div>
33
45
  * ))}
46
+ *
47
+ * <button disabled={!canAddToCart}>
48
+ * Add to Cart
49
+ * </button>
34
50
  * </div>
35
51
  * )
36
52
  * }
@@ -41,4 +57,5 @@ import { SearchProductSku } from '@nosto/nosto-js/client';
41
57
  export declare function useSwatches(skus?: SearchProductSku[], fields?: string[]): {
42
58
  swatches: import('../types').SwatchField[];
43
59
  toggleOption: (field: string, value: string) => void;
60
+ matchedSkus: SearchProductSku[];
44
61
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const b=require("../deepMerge-lDscDfII.cjs"),c=require("../unique-Blp-K9zG.cjs"),t=require("../logger-BcHMZObS.cjs"),n=require("../parseNumber-FsZ8w61u.cjs"),q=require("../pick-rYi1lc2m.cjs");function k(i){i.setAttribute("autocomplete","off")}function m(i,{onClick:a,onFocus:f,onInput:d,onKeyDown:u,onSubmit:s},{form:p=i.form??void 0}={}){const o=[];function r(e,l,v){e.addEventListener(l,v),o.push(()=>e.removeEventListener(l,v))}return(u||s)&&r(i,"keydown",e=>{u==null||u(i.value,e.key),(u&&(e.key==="ArrowDown"||e.key==="ArrowUp")||s&&e.key==="Enter")&&e.preventDefault()}),s&&p&&(r(p,"submit",e=>{e.preventDefault(),s(i.value)}),p.querySelectorAll("[type=submit]").forEach(e=>{r(e,"click",l=>{l.preventDefault(),s(i.value)})})),a&&r(i,"click",()=>a(i.value)),f&&r(i,"focus",()=>f(i.value)),d&&r(i,"input",()=>d(i.value)),{destroy(){o.forEach(e=>e())}}}exports.deepMerge=b.deepMerge;exports.isBot=c.isBot;exports.measure=c.measure;exports.mergeArrays=c.mergeArrays;exports.unique=c.unique;exports.isEqual=t.isEqual;exports.isPlainObject=t.isPlainObject;exports.logger=t.logger;exports.parseNumber=n.parseNumber;exports.pick=q.pick;exports.bindInput=m;exports.disableNativeAutocomplete=k;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const q=require("../deepMerge-lDscDfII.cjs"),c=require("../unique-Blp-K9zG.cjs"),a=require("../logger-BcHMZObS.cjs"),b=require("../parseNumber-FsZ8w61u.cjs"),k=require("../pick-rYi1lc2m.cjs");function n(i){i.setAttribute("autocomplete","off")}function m(i,{onClick:f,onFocus:t,onInput:d,onKeyDown:s,onSubmit:u},{form:p=i.form??void 0}={}){const o=[];function r(e,l,v){e.addEventListener(l,v),o.push(()=>e.removeEventListener(l,v))}return(s||u)&&r(i,"keydown",e=>{s==null||s(i.value,e.key),s&&(e.key==="ArrowDown"||e.key==="ArrowUp")?e.preventDefault():u&&e.key==="Enter"&&(i.value!==""&&!e.repeat&&u(i.value),e.preventDefault())}),u&&p&&(r(p,"submit",e=>{e.preventDefault(),u(i.value)}),p.querySelectorAll("[type=submit]").forEach(e=>{r(e,"click",l=>{l.preventDefault(),u(i.value)})})),f&&r(i,"click",()=>f(i.value)),t&&r(i,"focus",()=>t(i.value)),d&&r(i,"input",()=>d(i.value)),{destroy(){o.forEach(e=>e())}}}exports.deepMerge=q.deepMerge;exports.isBot=c.isBot;exports.measure=c.measure;exports.mergeArrays=c.mergeArrays;exports.unique=c.unique;exports.isEqual=a.isEqual;exports.isPlainObject=a.isPlainObject;exports.logger=a.logger;exports.parseNumber=b.parseNumber;exports.pick=k.pick;exports.bindInput=m;exports.disableNativeAutocomplete=n;
@@ -1,4 +1,4 @@
1
- import { d as E } from "../deepMerge-CZwCJzEe.js";
1
+ import { d as t } from "../deepMerge-CZwCJzEe.js";
2
2
  import { i as A, a as b, m as q, u as y } from "../unique-m1TIDWdl.js";
3
3
  import { i as h, a as N, l as j } from "../logger-DVwg4Wor.js";
4
4
  import { p as M } from "../parseNumber-QA48nJLp.js";
@@ -6,18 +6,18 @@ import { p as P } from "../pick-DReBictn.js";
6
6
  function d(s) {
7
7
  s.setAttribute("autocomplete", "off");
8
8
  }
9
- function v(s, { onClick: l, onFocus: p, onInput: c, onKeyDown: i, onSubmit: u }, { form: a = s.form ?? void 0 } = {}) {
9
+ function m(s, { onClick: l, onFocus: p, onInput: c, onKeyDown: u, onSubmit: i }, { form: a = s.form ?? void 0 } = {}) {
10
10
  const o = [];
11
- function r(e, f, t) {
12
- e.addEventListener(f, t), o.push(() => e.removeEventListener(f, t));
11
+ function r(e, f, v) {
12
+ e.addEventListener(f, v), o.push(() => e.removeEventListener(f, v));
13
13
  }
14
- return (i || u) && r(s, "keydown", (e) => {
15
- i == null || i(s.value, e.key), (i && (e.key === "ArrowDown" || e.key === "ArrowUp") || u && e.key === "Enter") && e.preventDefault();
16
- }), u && a && (r(a, "submit", (e) => {
17
- e.preventDefault(), u(s.value);
14
+ return (u || i) && r(s, "keydown", (e) => {
15
+ u == null || u(s.value, e.key), u && (e.key === "ArrowDown" || e.key === "ArrowUp") ? e.preventDefault() : i && e.key === "Enter" && (s.value !== "" && !e.repeat && i(s.value), e.preventDefault());
16
+ }), i && a && (r(a, "submit", (e) => {
17
+ e.preventDefault(), i(s.value);
18
18
  }), a.querySelectorAll("[type=submit]").forEach((e) => {
19
19
  r(e, "click", (f) => {
20
- f.preventDefault(), u(s.value);
20
+ f.preventDefault(), i(s.value);
21
21
  });
22
22
  })), l && r(s, "click", () => l(s.value)), p && r(s, "focus", () => p(s.value)), c && r(s, "input", () => c(s.value)), {
23
23
  destroy() {
@@ -26,8 +26,8 @@ function v(s, { onClick: l, onFocus: p, onInput: c, onKeyDown: i, onSubmit: u },
26
26
  };
27
27
  }
28
28
  export {
29
- v as bindInput,
30
- E as deepMerge,
29
+ m as bindInput,
30
+ t as deepMerge,
31
31
  d as disableNativeAutocomplete,
32
32
  A as isBot,
33
33
  h as isEqual,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nosto/search-js",
3
- "version": "2.9.2",
3
+ "version": "2.11.0",
4
4
  "license": "ISC",
5
5
  "type": "module",
6
6
  "files": [
@@ -88,6 +88,7 @@
88
88
  "@commitlint/config-conventional": "^19.8.1",
89
89
  "@nosto/nosto-js": "^2.0.0",
90
90
  "@testing-library/dom": "^10.4.0",
91
+ "@types/dom-speech-recognition": "^0.0.6",
91
92
  "@types/eslint-config-prettier": "^6.11.3",
92
93
  "@types/node": "^22.15.17",
93
94
  "@vitest/coverage-v8": "^3.1.3",