@nosto/search-js 2.9.2 → 2.10.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 h=require("../useLoadMore-BRYyWQa0.cjs"),P=require("../logger-BcHMZObS.cjs"),m=require("preact/hooks"),k=require("../index.es-DlUp67LT.cjs"),N=require("../parseNumber-FsZ8w61u.cjs");function q(e){const r=h.useNostoAppState(t=>t.response);return e&&Array.isArray(e)||e&&P.isPlainObject(e)?e:r}function z(e){var u;const r=((u=e.data)==null?void 0:u.filter(c=>c.selected).length)??0,[t,n]=m.useState(r>0),{toggleProductFilter:o}=h.useActions();return{active:t,selectedFiltersCount:r,toggleActive:()=>{n(!t)},toggleProductFilter:o}}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 m.useMemo(()=>{var A,b,C;if(!t)return{totalPages:0,resultsFrom:0,resultsTo:0,pages:[]};const n=((A=r.products)==null?void 0:A.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(n/t.size)+1:1,c=t.size>0?Math.ceil(t.total/t.size):0,g=y=>y>=u-i&&y<=u+i,s=n+1,l=Math.min(n+t.total,t.total),a={from:n,page:u,current:!0},d=y=>({from:(y-1)*t.size,page:y,current:y===u}),S=u>1?d(u-1):void 0,f=u<c?d(u+1):void 0,F=u-i-1>1?d(1):void 0,p=u+i+1<c?d(c):void 0,v=O(1,c+1).filter(g).map(d);return!F&&((b=v[0])==null?void 0:b.page)===2&&v.unshift(d(1)),!p&&((C=v[v.length-1])==null?void 0:C.page)===c-1&&v.push(d(c)),{totalPages:c,resultsFrom:s,resultsTo:l,current:a,prev:S,next:f,first:F,last:p,pages:v}},[r,t,e==null?void 0:e.width])}function L(){const[e,r]=m.useState([]),[t,n]=m.useState([]);return m.useEffect(()=>{k.s(async o=>{const{products:i,segments:u}=await o.getSearchSessionParams();r(u??[]),n((i==null?void 0:i.personalizationBoost)??[])})},[]),{segments:e,boost:t}}function V(){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=m.useCallback(s=>{const l=e==null?void 0:e.find(a=>a.type==="stats"&&a.field===s);if(l&&"min"in l&&"max"in l)return l},[e]),o=m.useCallback(s=>{var l;return((l=e==null?void 0:e.find(a=>a.field===s))==null?void 0:l.name)??s},[e]),i=m.useCallback(s=>"field"in s&&(s.value instanceof Array||s.range instanceof Array),[]),u=m.useCallback(s=>{var l;return{...s,range:(l=s.range)==null?void 0:l.map(a=>({gt:a.gt?Number(a.gt):a.gt,gte:a.gte?Number(a.gte):a.gte,lt:a.lt?Number(a.lt):a.lt,lte:a.lte?Number(a.lte):a.lte}))}},[]),c=m.useCallback(s=>(s.value??[]).map(a=>({value:a,field:s.field,name:o(s.field),filter:u(s),remove:()=>{t(s.field,a,!1)}})),[u,o,t]),g=m.useCallback(s=>(s.range??[]).map(a=>{var f,F;const d=a.gte??a.gt??((f=n(s.field))==null?void 0:f.min),S=a.lte??a.lt??((F=n(s.field))==null?void 0:F.max);if(d!==void 0&&S!==void 0)return{value:`${d} - ${S}`,field:s.field,name:o(s.field),filter:u(s),remove:()=>{r(s.field,void 0)}}}).filter(Boolean),[u,n,o,r]);return{selectFilters:i,toValueFilter:c,toRangeFilter:g}}function R(){const{filter:e}=h.useNostoAppState(c=>{var g;return{filter:((g=c.query.products)==null?void 0:g.filter)??[]}}),{updateSearch:r}=h.useActions(),{selectFilters:t,toValueFilter:n,toRangeFilter:o}=V(),i=m.useMemo(()=>e?e.filter(t).flatMap(c=>"value"in c?n(c):"range"in c?o(c):[]).filter(Boolean):[],[e,t,o,n]),u=m.useCallback(()=>{r({products:{filter:[]}})},[r]);return{filters:i,removeAll:u}}function w(e){var a,d,S;const{replaceFilter:r}=h.useActions(),{query:t,products:n}=h.useNostoAppState(f=>({query:f.query,products:f.response.products})),o=(a=n==null?void 0:n.facets)==null?void 0:a.find(f=>f.id===e);if(!o)return{min:0,max:0,range:[0,0],updateRange:()=>{}};const i=(S=(d=t.products)==null?void 0:d.filter)==null?void 0:S.find(f=>f.field===o.field),u=i!=null&&i.range?i.range[0]:void 0,c=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,s="max"in o?Math.ceil(o.max):0,l=([f,F])=>{const p=f!==void 0?Math.floor(f):void 0,v=F!==void 0?Math.ceil(F):void 0,A=p!==void 0,b=v!==void 0;(g===p||!A)&&(s===v||!b)?r(o.field,void 0):(g===p||!A)&&b?r(o.field,{lte:v.toString()}):(s===v||!b)&&A?r(o.field,{gte:p.toString()}):A&&b&&r(o.field,{gte:p.toString(),lte:v.toString()})};return{min:g,max:s,range:[c[0]??g,c[1]??s],updateRange:l}}function T(e,r){const{min:t,max:n,range:o,updateRange:i}=w(e),{filters:u}=R(),c=m.useMemo(()=>{var F;const a=u.find(p=>{var v;return(v=p==null?void 0:p.filter)==null?void 0:v.range});let d=null;if(a){const p=(F=a.filter.range)==null?void 0:F[0];d=[N.parseNumber(p==null?void 0:p.gte),N.parseNumber(p==null?void 0:p.lte)]}const S=[];let f=Math.floor(t/r)*r;for(;f<n;){const p=f+r,v=d&&d[0]===f&&d[1]===p;S.push({min:f,max:p,selected:v}),f=p}return S},[u,t,n,r]),g=a=>{i([a,o[1]])},s=a=>{i([o[0],a])},l=t!==o[0]||n!==o[1];return{min:t,max:n,range:o,updateRange:i,ranges:c,handleMinChange:g,handleMaxChange:s,isSelected:l}}function B(){const{products:e,keywords:r}=h.useNostoAppState(t=>t.response);return{products:e??{hits:[],total:0},keywords:r??{hits:[],total:0}}}function D(){const e=h.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(e,r){const{from:t,size:n,total:o}=h.useNostoAppState(s=>{var l,a,d,S,f;return{from:M(((l=s.query.products)==null?void 0:l.from)??0),size:M(((d=(a=s.response)==null?void 0:a.products)==null?void 0:d.size)??0),total:M(((f=(S=s.response)==null?void 0:S.products)==null?void 0:f.total)??0)}}),{updateSearch:i}=h.useActions(),u=t+n,c=[...e].reverse().filter(s=>s+r<o);return{from:t,to:u,total:o,size:n,sizeOptions:c,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 $(e){var i,u;const r=h.useNostoAppState(c=>c.query),{updateSearch:t}=h.useActions();return{activeSort:((i=e.find(c=>{var g;return _(c.value.sort,((g=r.products)==null?void 0:g.sort)||[])}))==null?void 0:i.id)??((u=e[0])==null?void 0:u.id),setSort:c=>{const g=e.find(s=>s.id===c);g&&t({products:{sort:g.value.sort}})}}}function I(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:u})=>{const c=i.toLowerCase();r.includes(c)&&(t[c][u]=t[c][u]||[],t[c][u].push(n))})}),Object.entries(t).map(([n,o])=>({field:n,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:n})=>({field:t,options:n.map(o=>{var c;const i=!((c=o.skus)!=null&&c.some(g=>Object.entries(r).every(([s,l])=>{var d,S;return s===t?!0:((S=(d=g.customFields)==null?void 0:d.find(f=>f.key.toLowerCase()===s))==null?void 0:S.value)===l}))),u=r[t]===o.value;return{...o,unavailable:i,selected:u}})})):[]}function G(e=[],r=[]){const[t,n]=m.useState({}),o=m.useMemo(()=>U(I(e,r),t),[e,r,t]),i=m.useCallback((c,g)=>{n(s=>{const l={...s};return l[c]===g?delete l[c]:l[c]=g,l})},[]),u=m.useMemo(()=>Object.keys(t).filter(s=>t[s]).length===0?[]:o.filter(({field:s})=>t[s]).map(({field:s,options:l})=>{const a=t[s],d=l.find(S=>S.value===a);return(d==null?void 0:d.skus)??[]}).reduce((s,l)=>s.filter(a=>l.includes(a))),[o,t]);return{swatches:o,toggleOption:i,matchedSkus:u}}exports.useActions=h.useActions;exports.useLoadMore=h.useLoadMore;exports.useNostoAppState=h.useNostoAppState;exports.useDecoratedSearchResults=q;exports.useFacet=z;exports.useFacets=x;exports.usePagination=j;exports.usePersonalization=L;exports.useProductFilters=R;exports.useRange=w;exports.useRangeSelector=T;exports.useResponse=B;exports.useSelectedFiltersCount=D;exports.useSizeOptions=E;exports.useSort=$;exports.useSwatches=G;
@@ -1,55 +1,55 @@
1
- import { a as S, c as M } from "../useLoadMore-4FYGzDwd.js";
1
+ import { a as F, c as R } from "../useLoadMore-4FYGzDwd.js";
2
2
  import { b as re } from "../useLoadMore-4FYGzDwd.js";
3
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";
4
+ import { useState as z, useMemo as M, useEffect as C, useCallback as S } from "preact/hooks";
5
5
  import { s as q } from "../index.es-B8mbAxS4.js";
6
- import { p as R } from "../parseNumber-QA48nJLp.js";
6
+ import { p as x } from "../parseNumber-QA48nJLp.js";
7
7
  function _(e) {
8
- const s = S((t) => t.response);
9
- return e && Array.isArray(e) || e && N(e) ? e : s;
8
+ const o = F((t) => t.response);
9
+ return e && Array.isArray(e) || e && N(e) ? e : o;
10
10
  }
11
11
  function G(e) {
12
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();
13
+ const o = ((c = e.data) == null ? void 0 : c.filter((a) => a.selected).length) ?? 0, [t, r] = z(o > 0), { toggleProductFilter: s } = R();
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
27
  function H() {
28
- const { loading: e, facets: s } = S((t) => {
29
- var n, o;
28
+ const { loading: e, facets: o } = F((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
46
  function J(e) {
47
- const { query: s, products: t } = S((n) => ({
48
- query: n.query,
49
- products: n.response.products
47
+ const { query: o, products: t } = F((r) => ({
48
+ query: r.query,
49
+ products: r.response.products
50
50
  }));
51
- return x(() => {
52
- var F, b, P;
51
+ return M(() => {
52
+ var y, b, P;
53
53
  if (!t)
54
54
  return {
55
55
  totalPages: 0,
@@ -57,117 +57,117 @@ 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,
60
+ const r = ((y = o.products) == null ? void 0 : y.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, f = (w) => w >= c - u && w <= c + u, n = r + 1, l = Math.min(r + t.total, t.total), i = {
61
+ from: r,
62
62
  page: c,
63
63
  current: !0
64
- }, g = (w) => ({
64
+ }, d = (w) => ({
65
65
  from: (w - 1) * t.size,
66
66
  page: w,
67
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,
68
+ }), p = c > 1 ? d(c - 1) : void 0, g = c < a ? d(c + 1) : void 0, v = c - u - 1 > 1 ? d(1) : void 0, m = c + u + 1 < a ? d(a) : void 0, h = k(1, a + 1).filter(f).map(d);
69
+ return !v && ((b = h[0]) == null ? void 0 : b.page) === 2 && h.unshift(d(1)), !m && ((P = h[h.length - 1]) == null ? void 0 : P.page) === a - 1 && h.push(d(a)), {
70
+ totalPages: a,
71
+ resultsFrom: n,
72
72
  resultsTo: l,
73
- current: a,
74
- prev: h,
75
- next: d,
73
+ current: i,
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
82
  function K() {
83
- const [e, s] = z([]), [t, n] = z([]);
83
+ const [e, o] = z([]), [t, r] = z([]);
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
+ q(async (s) => {
86
+ const { products: u, segments: c } = await s.getSearchSessionParams();
87
+ o(c ?? []), r((u == null ? void 0 : u.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) => {
94
+ function O() {
95
+ const { facets: e } = F((n) => {
96
96
  var l;
97
97
  return {
98
- facets: ((l = r.response.products) == null ? void 0 : l.facets) ?? []
98
+ facets: ((l = n.response.products) == null ? void 0 : l.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);
100
+ }), { replaceFilter: o, toggleProductFilter: t } = R(), r = S(
101
+ (n) => {
102
+ const l = e == null ? void 0 : e.find((i) => i.type === "stats" && i.field === n);
103
103
  if (l && "min" in l && "max" in l)
104
104
  return l;
105
105
  },
106
106
  [e]
107
- ), o = y(
108
- (r) => {
107
+ ), s = S(
108
+ (n) => {
109
109
  var l;
110
- return ((l = e == null ? void 0 : e.find((a) => a.field === r)) == null ? void 0 : l.name) ?? r;
110
+ return ((l = e == null ? void 0 : e.find((i) => i.field === n)) == null ? void 0 : l.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) => {
113
+ ), u = S((n) => "field" in n && (n.value instanceof Array || n.range instanceof Array), []), c = S((n) => {
114
114
  var l;
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: (l = n.range) == null ? void 0 : l.map((i) => ({
118
+ gt: i.gt ? Number(i.gt) : i.gt,
119
+ gte: i.gte ? Number(i.gte) : i.gte,
120
+ lt: i.lt ? Number(i.lt) : i.lt,
121
+ lte: i.lte ? Number(i.lte) : i.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
+ }, []), a = S(
125
+ (n) => (n.value ?? []).map((i) => ({
126
+ value: i,
127
+ field: n.field,
128
+ name: s(n.field),
129
+ filter: c(n),
130
130
  remove: () => {
131
- t(r.field, a, !1);
131
+ t(n.field, i, !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
+ [c, s, t]
135
+ ), f = S(
136
+ (n) => (n.range ?? []).map((i) => {
137
+ var g, v;
138
+ const d = i.gte ?? i.gt ?? ((g = r(n.field)) == null ? void 0 : g.min), p = i.lte ?? i.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: c(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
+ [c, r, s, o]
151
151
  );
152
152
  return {
153
153
  selectFilters: u,
154
- toValueFilter: i,
154
+ toValueFilter: a,
155
155
  toRangeFilter: f
156
156
  };
157
157
  }
158
- function k() {
159
- const { filter: e } = S((i) => {
158
+ function j() {
159
+ const { filter: e } = F((a) => {
160
160
  var f;
161
161
  return {
162
- filter: ((f = i.query.products) == null ? void 0 : f.filter) ?? []
162
+ filter: ((f = a.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 } = R(), { selectFilters: t, toValueFilter: r, toRangeFilter: s } = O(), u = M(() => e ? e.filter(t).flatMap((a) => "value" in a ? r(a) : "range" in a ? s(a) : []).filter(Boolean) : [], [e, t, s, r]), c = 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
173
  filters: u,
@@ -176,12 +176,12 @@ function k() {
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 i, d, p;
180
+ const { replaceFilter: o } = R(), { query: t, products: r } = F((g) => ({
181
+ query: g.query,
182
+ products: g.response.products
183
+ })), s = (i = r == null ? void 0 : r.facets) == null ? void 0 : i.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 u = (p = (d = t.products) == null ? void 0 : d.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) ? [x(c.gte), x(c.lte)] : [void 0, void 0], f = "min" in s ? Math.floor(s.min) : 0, n = "max" in s ? Math.ceil(s.max) : 0, l = ([g, v]) => {
193
+ const m = g !== void 0 ? Math.floor(g) : void 0, h = v !== void 0 ? Math.ceil(v) : void 0, y = m !== void 0, b = h !== void 0;
194
+ (f === m || !y) && (n === h || !b) ? o(s.field, void 0) : (f === m || !y) && b ? o(s.field, {
195
+ lte: h.toString()
196
+ }) : (n === h || !b) && y ? o(s.field, {
197
197
  gte: m.toString()
198
- }) : F && b && s(o.field, {
198
+ }) : y && b && 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: [a[0] ?? f, a[1] ?? n],
210
210
  /** Update range function */
211
211
  updateRange: l
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 Q(e, o) {
215
+ const { min: t, max: r, range: s, updateRange: u } = V(e), { filters: c } = j(), a = M(() => {
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 i = c.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 (i) {
223
+ const m = (v = i.filter.range) == null ? void 0 : v[0];
224
+ d = [x(m == null ? void 0 : m.gte), x(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
+ }, [c, t, r, o]), f = (i) => {
238
+ u([i, s[1]]);
239
+ }, n = (i) => {
240
+ u([s[0], i]);
241
+ }, l = 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
250
  updateRange: u,
251
251
  /** Ranges */
252
- ranges: i,
252
+ ranges: a,
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
258
  isSelected: l
259
259
  };
260
260
  }
261
261
  function W() {
262
- const { products: e, keywords: s } = S((t) => t.response);
262
+ const { products: e, keywords: o } = F((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
270
  function X() {
271
- const e = S((t) => {
272
- var n;
273
- return (n = t.query.products) == null ? void 0 : n.filter;
271
+ const e = F((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 M(() => 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 Y(e, o) {
281
+ const { from: t, size: r, total: s } = F((n) => {
282
+ var l, i, 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(((l = n.query.products) == null ? void 0 : l.from) ?? 0),
285
+ size: A(((d = (i = n.response) == null ? void 0 : i.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: u } = R(), c = t + r, a = [...e].reverse().filter((n) => n + o < s);
289
289
  return {
290
290
  /** from value */
291
291
  from: t,
292
292
  /** to value */
293
293
  to: c,
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: a,
300
300
  /** Should be called when size is changed */
301
- handleSizeChange: (r) => {
301
+ handleSizeChange: (n) => {
302
302
  u({
303
303
  products: {
304
- size: R(r)
304
+ size: x(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 L(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
313
  function Z(e) {
314
314
  var u, c;
315
- const s = S((i) => i.query), { updateSearch: t } = M();
315
+ const o = F((a) => a.query), { updateSearch: t } = R();
316
316
  return {
317
317
  /** Active sort */
318
- activeSort: ((u = e.find((i) => {
318
+ activeSort: ((u = e.find((a) => {
319
319
  var f;
320
- return B(i.value.sort, ((f = s.products) == null ? void 0 : f.sort) || []);
320
+ return L(a.value.sort, ((f = o.products) == null ? void 0 : f.sort) || []);
321
321
  })) == null ? void 0 : u.id) ?? ((c = e[0]) == null ? void 0 : c.id),
322
322
  /** Set sort function */
323
- setSort: (i) => {
324
- const f = e.find((r) => r.id === i);
323
+ setSort: (a) => {
324
+ const f = e.find((n) => n.id === a);
325
325
  f && t({
326
326
  products: {
327
327
  sort: f.value.sort
@@ -330,18 +330,18 @@ 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
+ function B(e, o) {
334
+ if (!e.length || !o.length) return [];
335
+ const t = o.reduce((r, s) => (r[s] = {}, r), {});
336
+ return e.forEach((r) => {
337
+ var s;
338
+ (s = r.customFields) == null || s.forEach(({ key: u, value: c }) => {
339
+ const a = u.toLowerCase();
340
+ o.includes(a) && (t[a][c] = t[a][c] || [], t[a][c].push(r));
341
341
  });
342
- }), Object.entries(t).map(([n, o]) => ({
343
- field: n,
344
- options: Object.entries(o).map(([u, c]) => ({
342
+ }), Object.entries(t).map(([r, s]) => ({
343
+ field: r,
344
+ options: Object.entries(s).map(([u, c]) => ({
345
345
  value: u,
346
346
  skus: c,
347
347
  unavailable: !1,
@@ -349,42 +349,45 @@ function T(e, s) {
349
349
  }))
350
350
  }));
351
351
  }
352
- function D(e, s) {
353
- return e.length ? e.map(({ field: t, options: n }) => ({
352
+ function T(e, o) {
353
+ return e.length ? e.map(({ field: t, options: r }) => ({
354
354
  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;
355
+ options: r.map((s) => {
356
+ var a;
357
+ const u = !((a = s.skus) != null && a.some((f) => Object.entries(o).every(([n, l]) => {
358
+ var d, p;
359
+ return n === t ? !0 : ((p = (d = f.customFields) == null ? void 0 : d.find((g) => g.key.toLowerCase() === n)) == null ? void 0 : p.value) === l;
360
+ }))), c = o[t] === s.value;
361
361
  return {
362
- ...o,
362
+ ...s,
363
363
  unavailable: u,
364
364
  selected: c
365
365
  };
366
366
  })
367
367
  })) : [];
368
368
  }
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;
369
+ function ee(e = [], o = []) {
370
+ const [t, r] = z({}), s = M(() => T(B(e, o), t), [e, o, t]), u = S((a, f) => {
371
+ r((n) => {
372
+ const l = { ...n };
373
+ return l[a] === f ? delete l[a] : l[a] = f, l;
374
374
  });
375
- }, []);
376
- return { swatches: o, toggleOption: u };
375
+ }, []), c = M(() => Object.keys(t).filter((n) => t[n]).length === 0 ? [] : s.filter(({ field: n }) => t[n]).map(({ field: n, options: l }) => {
376
+ const i = t[n], d = l.find((p) => p.value === i);
377
+ return (d == null ? void 0 : d.skus) ?? [];
378
+ }).reduce((n, l) => n.filter((i) => l.includes(i))), [s, t]);
379
+ return { swatches: s, toggleOption: u, matchedSkus: c };
377
380
  }
378
381
  export {
379
- M as useActions,
382
+ R as useActions,
380
383
  _ as useDecoratedSearchResults,
381
384
  G as useFacet,
382
385
  H as useFacets,
383
386
  re as useLoadMore,
384
- S as useNostoAppState,
387
+ F as useNostoAppState,
385
388
  J as usePagination,
386
389
  K as usePersonalization,
387
- k as useProductFilters,
390
+ j as useProductFilters,
388
391
  V as useRange,
389
392
  Q as useRangeSelector,
390
393
  W as useResponse,
@@ -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.10.0",
4
4
  "license": "ISC",
5
5
  "type": "module",
6
6
  "files": [