@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.
@@ -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,a]=p.useState(n),{toggleProductFilter:c}=h.useActions(),i=p.useCallback(()=>{a(!o)},[o]);return{active:o,selectedFiltersCount:t,toggleActive:i,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,w;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,a=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,d=A=>A>=c-a&&A<=c+a,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<i?f(c+1):void 0,b=c-a-1>1?f(1):void 0,S=c+a+1<i?f(i):void 0,v=O(1,i+1).filter(d).map(f);return!b&&((y=v[0])==null?void 0:y.page)===2&&v.unshift(f(1)),!S&&((w=v[v.length-1])==null?void 0:w.page)===i-1&&v.push(f(i)),{totalPages:i,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:a,segments:c}=await o.getSearchSessionParams();r(c??[]),n((a==null?void 0:a.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]),a=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}))}},[]),i=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:a,toValueFilter:i,toRangeFilter:d}}function k(){const{filter:e}=h.useNostoAppState(i=>{var d;return{filter:((d=i.query.products)==null?void 0:d.filter)??[]}}),{updateSearch:r}=h.useActions(),{selectFilters:t,toValueFilter:n,toRangeFilter:o}=D(),a=p.useMemo(()=>e?e.filter(t).flatMap(i=>"value"in i?n(i):"range"in i?o(i):[]).filter(Boolean):[],[e,t,o,n]),c=p.useCallback(()=>{r({products:{filter:[]}})},[r]);return{filters:a,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 a=(m=(f=t.products)==null?void 0:f.filter)==null?void 0:m.find(g=>g.field===o.field),c=a!=null&&a.range?a.range[0]:void 0,i=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:[i[0]??d,i[1]??s],updateRange:l}}function B(e,r){const{min:t,max:n,range:o,updateRange:a}=x(e),{filters:c}=k(),i=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=>{a([u,o[1]])},s=u=>{a([o[0],u])},l=t!==o[0]||n!==o[1];return{min:t,max:n,range:o,updateRange:a,ranges:i,handleMinChange:d,handleMaxChange:s,isSelected:l}}function E(){const{products:e,keywords:r}=h.useNostoAppState(t=>t.response);return{products:e??{hits:[],total:0},keywords:r??{hits:[],total:0}}}function _(){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:a}=h.useActions(),c=t+n,i=[...e].reverse().filter(s=>s+r<o);return{from:t,to:c,total:o,size:n,sizeOptions:i,handleSizeChange:s=>{a({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 a,c;const r=h.useNostoAppState(i=>i.query),{updateSearch:t}=h.useActions();return{activeSort:((a=e.find(i=>{var d;return $(i.value.sort,((d=r.products)==null?void 0:d.sort)||[])}))==null?void 0:a.id)??((c=e[0])==null?void 0:c.id),setSort:i=>{const d=e.find(s=>s.id===i);d&&t({products:{sort:d.value.sort}})}}}const R=window.SpeechRecognition||window.webkitSpeechRecognition,L=!!(R&&typeof R=="function");function Z(){return{listening:!1,startListening:()=>{},stopListening:()=>{}}}function G({language:e="en-US",interimResults:r=!1}={}){const[t,n]=p.useState(!1),o=p.useRef(null),a=p.useCallback(({onResult:i,onError:d})=>{const s=new R;s.lang=e,s.interimResults=r,s.onstart=()=>n(!0),s.onresult=l=>{var f,m;const{transcript:u}=(m=(f=l.results)==null?void 0:f[0])==null?void 0:m[0];i(u)},d&&(s.onerror=l=>d(l.error)),s.onend=()=>n(!1),o.current=s,s.start()},[e,r]),c=p.useCallback(()=>{var i;(i=o.current)==null||i.stop()},[o]);return{listening:t,startListening:a,stopListening:c}}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:a,value:c})=>{const i=a.toLowerCase();r.includes(i)&&(t[i][c]=t[i][c]||[],t[i][c].push(n))})}),Object.entries(t).filter(n=>Object.keys(n[1]).length).map(([n,o])=>({field:n,options:Object.entries(o).map(([a,c])=>({value:a,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 i;const a=!((i=o.skus)!=null&&i.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:a,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,a]=[t.value,n.value].map(Q);return o<a?-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]),a=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})},[]),i=p.useMemo(()=>Object.keys(t).filter(l=>t[l]).length===0?[]:a.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))),[a,t]);return{swatches:a,toggleOption:c,matchedSkus:i}}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=E;exports.useSelectedFiltersCount=_;exports.useSizeOptions=U;exports.useSort=I;exports.useSpeechToText=H;exports.useSwatches=Y;
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;
@@ -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, u] = L(r), { toggleProductFilter: c } = x(), a = S(() => {
17
- u(!s);
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: a,
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, u = Math.max(Math.floor(s - 1) / 2, 1), c = t.size > 0 ? Math.floor(r / t.size) + 1 : 1, a = t.size > 0 ? Math.ceil(t.total / t.size) : 0, d = (R) => R >= c - u && R <= c + u, n = r + 1, l = Math.min(r + t.total, t.total), i = {
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 < a ? f(c + 1) : void 0, v = c - u - 1 > 1 ? f(1) : void 0, m = c + u + 1 < a ? f(a) : void 0, h = k(1, a + 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) === a - 1 && h.push(f(a)), {
73
- totalPages: a,
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: u, segments: c } = await s.getSearchSessionParams();
90
- o(c ?? []), r((u == null ? void 0 : u.personalizationBoost) ?? []);
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
- ), u = S((n) => "field" in n && (n.value instanceof Array || n.range instanceof Array), []), c = S((n) => {
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
- }, []), a = S(
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: u,
157
- toValueFilter: a,
156
+ selectFilters: a,
157
+ toValueFilter: u,
158
158
  toRangeFilter: d
159
159
  };
160
160
  }
161
161
  function j() {
162
- const { filter: e } = y((a) => {
162
+ const { filter: e } = y((u) => {
163
163
  var d;
164
164
  return {
165
- filter: ((d = a.query.products) == null ? void 0 : d.filter) ?? []
165
+ filter: ((d = u.query.products) == null ? void 0 : d.filter) ?? []
166
166
  };
167
- }), { updateSearch: o } = x(), { selectFilters: t, toValueFilter: r, toRangeFilter: s } = q(), u = b(() => e ? e.filter(t).flatMap((a) => "value" in a ? r(a) : "range" in a ? s(a) : []).filter(Boolean) : [], [e, t, s, r]), c = S(() => {
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: u,
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 u = (p = (f = t.products) == null ? void 0 : f.filter) == null ? void 0 : p.find((g) => g.field === s.field), c = u != null && u.range ? u.range[0] : void 0, a = 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]) => {
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: [a[0] ?? d, a[1] ?? n],
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: u } = V(e), { filters: c } = j(), a = b(() => {
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
- u([i, s[1]]);
241
+ a([i, s[1]]);
242
242
  }, n = (i) => {
243
- u([s[0], i]);
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: u,
253
+ updateRange: a,
254
254
  /** Ranges */
255
- ranges: a,
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: u } = x(), c = t + r, a = [...e].reverse().filter((n) => n + o < s);
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: a,
302
+ sizeOptions: u,
303
303
  /** Should be called when size is changed */
304
304
  handleSizeChange: (n) => {
305
- u({
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 u, c;
318
- const o = y((a) => a.query), { updateSearch: t } = x();
317
+ var a, c;
318
+ const o = y((u) => u.query), { updateSearch: t } = x();
319
319
  return {
320
320
  /** Active sort */
321
- activeSort: ((u = e.find((a) => {
321
+ activeSort: ((a = e.find((u) => {
322
322
  var d;
323
- return B(a.value.sort, ((d = o.products) == null ? void 0 : d.sort) || []);
324
- })) == null ? void 0 : u.id) ?? ((c = e[0]) == null ? void 0 : c.id),
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: (a) => {
327
- const d = e.find((n) => n.id === a);
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 [t, r] = L(!1), s = T(null), u = S(
351
- ({ onResult: a, onError: d }) => {
352
- const n = new X();
353
- n.lang = e, n.interimResults = o, n.onstart = () => r(!0), n.onresult = (l) => {
354
- var f, p;
355
- const { transcript: i } = (p = (f = l.results) == null ? void 0 : f[0]) == null ? void 0 : p[0];
356
- a(i);
357
- }, d && (n.onerror = (l) => d(l.error)), n.onend = () => r(!1), s.current = n, n.start();
358
- },
359
- [e, o]
360
- ), c = S(() => {
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: t,
364
+ listening: s,
366
365
  startListening: u,
367
- stopListening: c
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: u, value: c }) => {
377
- const a = u.toLowerCase();
378
- o.includes(a) && (t[a][c] = t[a][c] || [], t[a][c].push(r));
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(([u, c]) => ({
383
- value: u,
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 a;
395
- const u = !((a = s.skus) != null && a.some((d) => Object.entries(o).every(([n, l]) => {
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: u,
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, u] = [t.value, r.value].map(I);
417
- return s < u ? -1 : 1;
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]), u = b(() => $(s, t), [s, t]), c = S((d, n) => {
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
- }, []), a = b(() => Object.keys(t).filter((l) => t[l]).length === 0 ? [] : u.filter(({ field: l }) => t[l]).map(({ field: l, options: i }) => {
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))), [u, t]);
433
- return { swatches: u, toggleOption: c, matchedSkus: a };
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: (options: StartListeningOptions) => void;
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": "2.17.0",
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.21",
94
- "@vitest/coverage-v8": "^3.1.4",
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.27.0",
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.0",
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.32.1",
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"