@nosto/search-js 2.12.2 → 2.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/preact/hooks.cjs.js +1 -1
- package/dist/preact/hooks.es.js +237 -221
- package/dist/preact/src/hooks/useSwatches/applySelectionStates.d.ts +2 -0
- package/dist/preact/src/hooks/useSwatches/sortOptions.d.ts +2 -0
- package/package.json +6 -6
- package/dist/preact/src/hooks/useSwatches/applySwatchSelectionStates.d.ts +0 -2
package/dist/preact/hooks.cjs.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const h=require("../useLoadMore-BJWBvbZ1.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;
|
package/dist/preact/hooks.es.js
CHANGED
|
@@ -1,38 +1,38 @@
|
|
|
1
1
|
import { a as y, c as x } from "../useLoadMore-CzqfcD1v.js";
|
|
2
|
-
import { b as
|
|
3
|
-
import { a as
|
|
4
|
-
import { useState as
|
|
5
|
-
import { s as
|
|
6
|
-
import { p as
|
|
7
|
-
function
|
|
8
|
-
const o = y((
|
|
9
|
-
return e && Array.isArray(e) || e &&
|
|
2
|
+
import { b as fe } from "../useLoadMore-CzqfcD1v.js";
|
|
3
|
+
import { a as P } from "../logger-DVwg4Wor.js";
|
|
4
|
+
import { useState as L, useCallback as S, useMemo as b, useEffect as O, useRef as T } from "preact/hooks";
|
|
5
|
+
import { s as C } from "../index.es-B8mbAxS4.js";
|
|
6
|
+
import { p as M } from "../parseNumber-QA48nJLp.js";
|
|
7
|
+
function W(e) {
|
|
8
|
+
const o = y((t) => t.response);
|
|
9
|
+
return e && Array.isArray(e) || e && P(e) ? e : o;
|
|
10
10
|
}
|
|
11
|
-
function
|
|
11
|
+
function Y(e, o) {
|
|
12
12
|
var d;
|
|
13
|
-
const
|
|
14
|
-
active:
|
|
13
|
+
const t = ((d = e.data) == null ? void 0 : d.filter((n) => n.selected).length) ?? 0, { active: r } = {
|
|
14
|
+
active: t > 0,
|
|
15
15
|
...o
|
|
16
|
-
}, [
|
|
17
|
-
|
|
18
|
-
}, [
|
|
16
|
+
}, [s, u] = L(r), { toggleProductFilter: c } = x(), a = S(() => {
|
|
17
|
+
u(!s);
|
|
18
|
+
}, [s]);
|
|
19
19
|
return {
|
|
20
20
|
/** Active value */
|
|
21
|
-
active:
|
|
21
|
+
active: s,
|
|
22
22
|
/** Selected filters count */
|
|
23
|
-
selectedFiltersCount:
|
|
23
|
+
selectedFiltersCount: t,
|
|
24
24
|
/** Toggle active function */
|
|
25
|
-
toggleActive:
|
|
25
|
+
toggleActive: a,
|
|
26
26
|
/** Toggle product filter function */
|
|
27
|
-
toggleProductFilter:
|
|
27
|
+
toggleProductFilter: c
|
|
28
28
|
};
|
|
29
29
|
}
|
|
30
|
-
function
|
|
31
|
-
const { loading: e, facets: o } = y((
|
|
32
|
-
var
|
|
30
|
+
function ee() {
|
|
31
|
+
const { loading: e, facets: o } = y((t) => {
|
|
32
|
+
var r, s;
|
|
33
33
|
return {
|
|
34
|
-
loading:
|
|
35
|
-
facets: ((
|
|
34
|
+
loading: t.loading,
|
|
35
|
+
facets: ((s = (r = t.response) == null ? void 0 : r.products) == null ? void 0 : s.facets) ?? []
|
|
36
36
|
};
|
|
37
37
|
});
|
|
38
38
|
return {
|
|
@@ -43,128 +43,128 @@ function X() {
|
|
|
43
43
|
};
|
|
44
44
|
}
|
|
45
45
|
function k(e, o) {
|
|
46
|
-
const
|
|
47
|
-
return !isNaN(
|
|
46
|
+
const t = o - e;
|
|
47
|
+
return !isNaN(t) && t > 0 ? new Array(o - e).fill(void 0).map((r, s) => s + e) : [];
|
|
48
48
|
}
|
|
49
|
-
function
|
|
50
|
-
const { query: o, products:
|
|
51
|
-
query:
|
|
52
|
-
products:
|
|
49
|
+
function te(e) {
|
|
50
|
+
const { query: o, products: t } = y((r) => ({
|
|
51
|
+
query: r.query,
|
|
52
|
+
products: r.response.products
|
|
53
53
|
}));
|
|
54
54
|
return b(() => {
|
|
55
|
-
var F, w,
|
|
56
|
-
if (!
|
|
55
|
+
var F, w, A;
|
|
56
|
+
if (!t)
|
|
57
57
|
return {
|
|
58
58
|
totalPages: 0,
|
|
59
59
|
resultsFrom: 0,
|
|
60
60
|
resultsTo: 0,
|
|
61
61
|
pages: []
|
|
62
62
|
};
|
|
63
|
-
const
|
|
64
|
-
from:
|
|
65
|
-
page:
|
|
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 = {
|
|
64
|
+
from: r,
|
|
65
|
+
page: c,
|
|
66
66
|
current: !0
|
|
67
67
|
}, f = (R) => ({
|
|
68
|
-
from: (R - 1) *
|
|
68
|
+
from: (R - 1) * t.size,
|
|
69
69
|
page: R,
|
|
70
|
-
current: R ===
|
|
71
|
-
}), p =
|
|
72
|
-
return !v && ((w = h[0]) == null ? void 0 : w.page) === 2 && h.unshift(f(1)), !m && ((
|
|
73
|
-
totalPages:
|
|
74
|
-
resultsFrom:
|
|
75
|
-
resultsTo:
|
|
76
|
-
current:
|
|
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,
|
|
74
|
+
resultsFrom: n,
|
|
75
|
+
resultsTo: l,
|
|
76
|
+
current: i,
|
|
77
77
|
prev: p,
|
|
78
78
|
next: g,
|
|
79
79
|
first: v,
|
|
80
80
|
last: m,
|
|
81
81
|
pages: h
|
|
82
82
|
};
|
|
83
|
-
}, [o,
|
|
83
|
+
}, [o, t, e == null ? void 0 : e.width]);
|
|
84
84
|
}
|
|
85
|
-
function
|
|
86
|
-
const [e, o] =
|
|
87
|
-
return
|
|
88
|
-
|
|
89
|
-
const { products:
|
|
90
|
-
o(
|
|
85
|
+
function ne() {
|
|
86
|
+
const [e, o] = L([]), [t, r] = L([]);
|
|
87
|
+
return O(() => {
|
|
88
|
+
C(async (s) => {
|
|
89
|
+
const { products: u, segments: c } = await s.getSearchSessionParams();
|
|
90
|
+
o(c ?? []), r((u == null ? void 0 : u.personalizationBoost) ?? []);
|
|
91
91
|
});
|
|
92
92
|
}, []), {
|
|
93
93
|
segments: e,
|
|
94
|
-
boost:
|
|
94
|
+
boost: t
|
|
95
95
|
};
|
|
96
96
|
}
|
|
97
|
-
function
|
|
98
|
-
const { facets: e } = y((
|
|
99
|
-
var
|
|
97
|
+
function q() {
|
|
98
|
+
const { facets: e } = y((n) => {
|
|
99
|
+
var l;
|
|
100
100
|
return {
|
|
101
|
-
facets: ((
|
|
101
|
+
facets: ((l = n.response.products) == null ? void 0 : l.facets) ?? []
|
|
102
102
|
};
|
|
103
|
-
}), { replaceFilter: o, toggleProductFilter:
|
|
104
|
-
(
|
|
105
|
-
const
|
|
106
|
-
if (
|
|
107
|
-
return
|
|
103
|
+
}), { replaceFilter: o, toggleProductFilter: t } = x(), r = S(
|
|
104
|
+
(n) => {
|
|
105
|
+
const l = e == null ? void 0 : e.find((i) => i.type === "stats" && i.field === n);
|
|
106
|
+
if (l && "min" in l && "max" in l)
|
|
107
|
+
return l;
|
|
108
108
|
},
|
|
109
109
|
[e]
|
|
110
|
-
),
|
|
111
|
-
(
|
|
112
|
-
var
|
|
113
|
-
return ((
|
|
110
|
+
), s = S(
|
|
111
|
+
(n) => {
|
|
112
|
+
var l;
|
|
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
|
-
),
|
|
117
|
-
var
|
|
116
|
+
), u = S((n) => "field" in n && (n.value instanceof Array || n.range instanceof Array), []), c = S((n) => {
|
|
117
|
+
var l;
|
|
118
118
|
return {
|
|
119
|
-
...
|
|
120
|
-
range: (
|
|
121
|
-
gt:
|
|
122
|
-
gte:
|
|
123
|
-
lt:
|
|
124
|
-
lte:
|
|
119
|
+
...n,
|
|
120
|
+
range: (l = n.range) == null ? void 0 : l.map((i) => ({
|
|
121
|
+
gt: i.gt ? Number(i.gt) : i.gt,
|
|
122
|
+
gte: i.gte ? Number(i.gte) : i.gte,
|
|
123
|
+
lt: i.lt ? Number(i.lt) : i.lt,
|
|
124
|
+
lte: i.lte ? Number(i.lte) : i.lte
|
|
125
125
|
}))
|
|
126
126
|
};
|
|
127
|
-
}, []),
|
|
128
|
-
(
|
|
129
|
-
value:
|
|
130
|
-
field:
|
|
131
|
-
name:
|
|
132
|
-
filter:
|
|
127
|
+
}, []), a = S(
|
|
128
|
+
(n) => (n.value ?? []).map((i) => ({
|
|
129
|
+
value: i,
|
|
130
|
+
field: n.field,
|
|
131
|
+
name: s(n.field),
|
|
132
|
+
filter: c(n),
|
|
133
133
|
remove: () => {
|
|
134
|
-
n
|
|
134
|
+
t(n.field, i, !1);
|
|
135
135
|
}
|
|
136
136
|
})),
|
|
137
|
-
[
|
|
137
|
+
[c, s, t]
|
|
138
138
|
), d = S(
|
|
139
|
-
(
|
|
139
|
+
(n) => (n.range ?? []).map((i) => {
|
|
140
140
|
var g, v;
|
|
141
|
-
const f =
|
|
141
|
+
const f = 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);
|
|
142
142
|
if (f !== void 0 && p !== void 0)
|
|
143
143
|
return {
|
|
144
144
|
value: `${f} - ${p}`,
|
|
145
|
-
field:
|
|
146
|
-
name:
|
|
147
|
-
filter:
|
|
145
|
+
field: n.field,
|
|
146
|
+
name: s(n.field),
|
|
147
|
+
filter: c(n),
|
|
148
148
|
remove: () => {
|
|
149
|
-
o(
|
|
149
|
+
o(n.field, void 0);
|
|
150
150
|
}
|
|
151
151
|
};
|
|
152
152
|
}).filter(Boolean),
|
|
153
|
-
[
|
|
153
|
+
[c, r, s, o]
|
|
154
154
|
);
|
|
155
155
|
return {
|
|
156
|
-
selectFilters:
|
|
157
|
-
toValueFilter:
|
|
156
|
+
selectFilters: u,
|
|
157
|
+
toValueFilter: a,
|
|
158
158
|
toRangeFilter: d
|
|
159
159
|
};
|
|
160
160
|
}
|
|
161
161
|
function j() {
|
|
162
|
-
const { filter: e } = y((
|
|
162
|
+
const { filter: e } = y((a) => {
|
|
163
163
|
var d;
|
|
164
164
|
return {
|
|
165
|
-
filter: ((d =
|
|
165
|
+
filter: ((d = a.query.products) == null ? void 0 : d.filter) ?? []
|
|
166
166
|
};
|
|
167
|
-
}), { updateSearch: o } = x(), { selectFilters:
|
|
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(() => {
|
|
168
168
|
o({
|
|
169
169
|
products: {
|
|
170
170
|
filter: []
|
|
@@ -173,18 +173,18 @@ function j() {
|
|
|
173
173
|
}, [o]);
|
|
174
174
|
return {
|
|
175
175
|
/** Selected filters array. */
|
|
176
|
-
filters:
|
|
176
|
+
filters: u,
|
|
177
177
|
/** Should remove all selected filters. */
|
|
178
|
-
removeAll:
|
|
178
|
+
removeAll: c
|
|
179
179
|
};
|
|
180
180
|
}
|
|
181
181
|
function V(e) {
|
|
182
|
-
var
|
|
183
|
-
const { replaceFilter: o } = x(), { query:
|
|
182
|
+
var i, f, p;
|
|
183
|
+
const { replaceFilter: o } = x(), { query: t, products: r } = y((g) => ({
|
|
184
184
|
query: g.query,
|
|
185
185
|
products: g.response.products
|
|
186
|
-
})),
|
|
187
|
-
if (!
|
|
186
|
+
})), s = (i = r == null ? void 0 : r.facets) == null ? void 0 : i.find((g) => g.id === e);
|
|
187
|
+
if (!s)
|
|
188
188
|
return {
|
|
189
189
|
min: 0,
|
|
190
190
|
max: 0,
|
|
@@ -192,13 +192,13 @@ function V(e) {
|
|
|
192
192
|
updateRange: () => {
|
|
193
193
|
}
|
|
194
194
|
};
|
|
195
|
-
const
|
|
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]) => {
|
|
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
|
-
(d === m || !F) && (
|
|
197
|
+
(d === m || !F) && (n === h || !w) ? o(s.field, void 0) : (d === m || !F) && w ? o(s.field, {
|
|
198
198
|
lte: h.toString()
|
|
199
|
-
}) : (
|
|
199
|
+
}) : (n === h || !w) && F ? o(s.field, {
|
|
200
200
|
gte: m.toString()
|
|
201
|
-
}) : F && w && o(
|
|
201
|
+
}) : F && w && o(s.field, {
|
|
202
202
|
gte: m.toString(),
|
|
203
203
|
lte: h.toString()
|
|
204
204
|
});
|
|
@@ -207,28 +207,28 @@ function V(e) {
|
|
|
207
207
|
/** Min value */
|
|
208
208
|
min: d,
|
|
209
209
|
/** Max value */
|
|
210
|
-
max:
|
|
210
|
+
max: n,
|
|
211
211
|
/** Range value */
|
|
212
|
-
range: [
|
|
212
|
+
range: [a[0] ?? d, a[1] ?? n],
|
|
213
213
|
/** Update range function */
|
|
214
|
-
updateRange:
|
|
214
|
+
updateRange: l
|
|
215
215
|
};
|
|
216
216
|
}
|
|
217
|
-
function
|
|
218
|
-
const { min:
|
|
217
|
+
function re(e, o) {
|
|
218
|
+
const { min: t, max: r, range: s, updateRange: u } = V(e), { filters: c } = j(), a = b(() => {
|
|
219
219
|
var v;
|
|
220
|
-
const
|
|
220
|
+
const i = c.find((m) => {
|
|
221
221
|
var h;
|
|
222
222
|
return (h = m == null ? void 0 : m.filter) == null ? void 0 : h.range;
|
|
223
223
|
});
|
|
224
224
|
let f = null;
|
|
225
|
-
if (
|
|
226
|
-
const m = (v =
|
|
227
|
-
f = [
|
|
225
|
+
if (i) {
|
|
226
|
+
const m = (v = i.filter.range) == null ? void 0 : v[0];
|
|
227
|
+
f = [M(m == null ? void 0 : m.gte), M(m == null ? void 0 : m.lte)];
|
|
228
228
|
}
|
|
229
229
|
const p = [];
|
|
230
|
-
let g = Math.floor(
|
|
231
|
-
for (; g <
|
|
230
|
+
let g = Math.floor(t / o) * o;
|
|
231
|
+
for (; g < r; ) {
|
|
232
232
|
const m = g + o, h = f && f[0] === g && f[1] === m;
|
|
233
233
|
p.push({
|
|
234
234
|
min: g,
|
|
@@ -237,32 +237,32 @@ function ee(e, o) {
|
|
|
237
237
|
}), g = m;
|
|
238
238
|
}
|
|
239
239
|
return p;
|
|
240
|
-
}, [
|
|
241
|
-
|
|
242
|
-
},
|
|
243
|
-
|
|
244
|
-
},
|
|
240
|
+
}, [c, t, r, o]), d = (i) => {
|
|
241
|
+
u([i, s[1]]);
|
|
242
|
+
}, n = (i) => {
|
|
243
|
+
u([s[0], i]);
|
|
244
|
+
}, l = t !== s[0] || r !== s[1];
|
|
245
245
|
return {
|
|
246
246
|
/** Minimum value */
|
|
247
|
-
min:
|
|
247
|
+
min: t,
|
|
248
248
|
/** Maximum value */
|
|
249
|
-
max:
|
|
249
|
+
max: r,
|
|
250
250
|
/** Range value */
|
|
251
|
-
range:
|
|
251
|
+
range: s,
|
|
252
252
|
/** Update range function */
|
|
253
|
-
updateRange:
|
|
253
|
+
updateRange: u,
|
|
254
254
|
/** Ranges */
|
|
255
|
-
ranges:
|
|
255
|
+
ranges: a,
|
|
256
256
|
/** Handle min change */
|
|
257
257
|
handleMinChange: d,
|
|
258
258
|
/** Handle max change */
|
|
259
|
-
handleMaxChange:
|
|
259
|
+
handleMaxChange: n,
|
|
260
260
|
/** Is selected */
|
|
261
|
-
isSelected:
|
|
261
|
+
isSelected: l
|
|
262
262
|
};
|
|
263
263
|
}
|
|
264
|
-
function
|
|
265
|
-
const { products: e, keywords: o } = y((
|
|
264
|
+
function se() {
|
|
265
|
+
const { products: e, keywords: o } = y((t) => t.response);
|
|
266
266
|
return {
|
|
267
267
|
/** Array of products */
|
|
268
268
|
products: e ?? { hits: [], total: 0 },
|
|
@@ -270,62 +270,62 @@ function te() {
|
|
|
270
270
|
keywords: o ?? { hits: [], total: 0 }
|
|
271
271
|
};
|
|
272
272
|
}
|
|
273
|
-
function
|
|
274
|
-
const e = y((
|
|
275
|
-
var
|
|
276
|
-
return (
|
|
273
|
+
function oe() {
|
|
274
|
+
const e = y((t) => {
|
|
275
|
+
var r;
|
|
276
|
+
return (r = t.query.products) == null ? void 0 : r.filter;
|
|
277
277
|
});
|
|
278
|
-
return b(() => e ? e.reduce((
|
|
278
|
+
return b(() => e ? e.reduce((t, r) => t + (Array.isArray(r.value) ? r.value.length : 1), 0) : 0, [e]);
|
|
279
279
|
}
|
|
280
|
-
function
|
|
280
|
+
function z(e) {
|
|
281
281
|
return e && !Number.isNaN(e) ? e : 0;
|
|
282
282
|
}
|
|
283
|
-
function
|
|
284
|
-
const { from:
|
|
285
|
-
var
|
|
283
|
+
function ie(e, o) {
|
|
284
|
+
const { from: t, size: r, total: s } = y((n) => {
|
|
285
|
+
var l, i, f, p, g;
|
|
286
286
|
return {
|
|
287
|
-
from:
|
|
288
|
-
size:
|
|
289
|
-
total:
|
|
287
|
+
from: z(((l = n.query.products) == null ? void 0 : l.from) ?? 0),
|
|
288
|
+
size: z(((f = (i = n.response) == null ? void 0 : i.products) == null ? void 0 : f.size) ?? 0),
|
|
289
|
+
total: z(((g = (p = n.response) == null ? void 0 : p.products) == null ? void 0 : g.total) ?? 0)
|
|
290
290
|
};
|
|
291
|
-
}), { updateSearch:
|
|
291
|
+
}), { updateSearch: u } = x(), c = t + r, a = [...e].reverse().filter((n) => n + o < s);
|
|
292
292
|
return {
|
|
293
293
|
/** from value */
|
|
294
|
-
from:
|
|
294
|
+
from: t,
|
|
295
295
|
/** to value */
|
|
296
|
-
to:
|
|
296
|
+
to: c,
|
|
297
297
|
/** total value */
|
|
298
|
-
total:
|
|
298
|
+
total: s,
|
|
299
299
|
/** size value */
|
|
300
|
-
size:
|
|
300
|
+
size: r,
|
|
301
301
|
/** Array of size options */
|
|
302
|
-
sizeOptions:
|
|
302
|
+
sizeOptions: a,
|
|
303
303
|
/** Should be called when size is changed */
|
|
304
|
-
handleSizeChange: (
|
|
305
|
-
|
|
304
|
+
handleSizeChange: (n) => {
|
|
305
|
+
u({
|
|
306
306
|
products: {
|
|
307
|
-
size:
|
|
307
|
+
size: M(n)
|
|
308
308
|
}
|
|
309
309
|
});
|
|
310
310
|
}
|
|
311
311
|
};
|
|
312
312
|
}
|
|
313
313
|
function B(e, o) {
|
|
314
|
-
return e.length !== o.length ? !1 : e.every((
|
|
314
|
+
return e.length !== o.length ? !1 : e.every((t) => o.find((r) => t.field === r.field && t.order === r.order));
|
|
315
315
|
}
|
|
316
|
-
function
|
|
317
|
-
var
|
|
318
|
-
const o = y((
|
|
316
|
+
function ce(e) {
|
|
317
|
+
var u, c;
|
|
318
|
+
const o = y((a) => a.query), { updateSearch: t } = x();
|
|
319
319
|
return {
|
|
320
320
|
/** Active sort */
|
|
321
|
-
activeSort: ((
|
|
321
|
+
activeSort: ((u = e.find((a) => {
|
|
322
322
|
var d;
|
|
323
|
-
return B(
|
|
324
|
-
})) == null ? void 0 :
|
|
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),
|
|
325
325
|
/** Set sort function */
|
|
326
|
-
setSort: (
|
|
327
|
-
const d = e.find((
|
|
328
|
-
d &&
|
|
326
|
+
setSort: (a) => {
|
|
327
|
+
const d = e.find((n) => n.id === a);
|
|
328
|
+
d && t({
|
|
329
329
|
products: {
|
|
330
330
|
sort: d.value.sort
|
|
331
331
|
}
|
|
@@ -333,8 +333,8 @@ function se(e) {
|
|
|
333
333
|
}
|
|
334
334
|
};
|
|
335
335
|
}
|
|
336
|
-
const
|
|
337
|
-
function
|
|
336
|
+
const X = window.SpeechRecognition || window.webkitSpeechRecognition, D = !!(X && typeof X == "function");
|
|
337
|
+
function E() {
|
|
338
338
|
return {
|
|
339
339
|
listening: !1,
|
|
340
340
|
startListening: () => {
|
|
@@ -343,96 +343,112 @@ function U() {
|
|
|
343
343
|
}
|
|
344
344
|
};
|
|
345
345
|
}
|
|
346
|
-
function
|
|
346
|
+
function U({
|
|
347
347
|
language: e = "en-US",
|
|
348
348
|
interimResults: o = !1
|
|
349
349
|
} = {}) {
|
|
350
|
-
const [
|
|
351
|
-
({ onResult:
|
|
352
|
-
const
|
|
353
|
-
|
|
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
354
|
var f, p;
|
|
355
|
-
const { transcript:
|
|
356
|
-
|
|
357
|
-
}, d && (
|
|
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
358
|
},
|
|
359
359
|
[e, o]
|
|
360
|
-
),
|
|
361
|
-
var
|
|
362
|
-
(
|
|
363
|
-
}, [
|
|
360
|
+
), c = S(() => {
|
|
361
|
+
var a;
|
|
362
|
+
(a = s.current) == null || a.stop();
|
|
363
|
+
}, [s]);
|
|
364
364
|
return {
|
|
365
|
-
listening:
|
|
366
|
-
startListening:
|
|
367
|
-
stopListening:
|
|
365
|
+
listening: t,
|
|
366
|
+
startListening: u,
|
|
367
|
+
stopListening: c
|
|
368
368
|
};
|
|
369
369
|
}
|
|
370
|
-
const
|
|
371
|
-
function
|
|
370
|
+
const ae = D ? U : E;
|
|
371
|
+
function _(e, o) {
|
|
372
372
|
if (!e.length || !o.length) return [];
|
|
373
|
-
const
|
|
374
|
-
return e.forEach((
|
|
375
|
-
var
|
|
376
|
-
(
|
|
377
|
-
const
|
|
378
|
-
o.includes(
|
|
373
|
+
const t = o.reduce((r, s) => (r[s] = {}, r), {});
|
|
374
|
+
return e.forEach((r) => {
|
|
375
|
+
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));
|
|
379
379
|
});
|
|
380
|
-
}), Object.entries(
|
|
381
|
-
field:
|
|
382
|
-
options: Object.entries(
|
|
383
|
-
value:
|
|
384
|
-
skus:
|
|
380
|
+
}), Object.entries(t).filter((r) => Object.keys(r[1]).length).map(([r, s]) => ({
|
|
381
|
+
field: r,
|
|
382
|
+
options: Object.entries(s).map(([u, c]) => ({
|
|
383
|
+
value: u,
|
|
384
|
+
skus: c,
|
|
385
385
|
unavailable: !1,
|
|
386
386
|
selected: !1
|
|
387
387
|
}))
|
|
388
388
|
}));
|
|
389
389
|
}
|
|
390
|
-
function
|
|
391
|
-
return e.length ? e.map(({ field:
|
|
392
|
-
field:
|
|
393
|
-
options:
|
|
394
|
-
var
|
|
395
|
-
const
|
|
390
|
+
function $(e, o) {
|
|
391
|
+
return e.length ? e.map(({ field: t, options: r }) => ({
|
|
392
|
+
field: t,
|
|
393
|
+
options: r.map((s) => {
|
|
394
|
+
var a;
|
|
395
|
+
const u = !((a = s.skus) != null && a.some((d) => Object.entries(o).every(([n, l]) => {
|
|
396
396
|
var f, p;
|
|
397
|
-
return
|
|
398
|
-
}))),
|
|
397
|
+
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
|
+
}))), c = o[t] === s.value;
|
|
399
399
|
return {
|
|
400
|
-
...
|
|
401
|
-
unavailable:
|
|
402
|
-
selected:
|
|
400
|
+
...s,
|
|
401
|
+
unavailable: u,
|
|
402
|
+
selected: c
|
|
403
403
|
};
|
|
404
404
|
})
|
|
405
405
|
})) : [];
|
|
406
406
|
}
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
407
|
+
const N = ["4XS", "3XS", "2XS", "XXS", "XS", "S", "M", "L", "XL", "XXL", "2XL", "XXXL", "3XL", "4XL"];
|
|
408
|
+
function I(e) {
|
|
409
|
+
if (N.includes(e))
|
|
410
|
+
return 1e3 + N.indexOf(e);
|
|
411
|
+
const o = parseFloat(e);
|
|
412
|
+
return isNaN(o) ? e : o;
|
|
413
|
+
}
|
|
414
|
+
function Z(e, o) {
|
|
415
|
+
return [...o].sort((t, r) => {
|
|
416
|
+
const [s, u] = [t.value, r.value].map(I);
|
|
417
|
+
return s < u ? -1 : 1;
|
|
418
|
+
});
|
|
419
|
+
}
|
|
420
|
+
function ue(e = [], o = []) {
|
|
421
|
+
const [t, r] = L({}), s = b(() => _(e, o).map(({ field: n, options: l }) => ({
|
|
422
|
+
field: n,
|
|
423
|
+
options: Z(n, l)
|
|
424
|
+
})), [e, o]), u = b(() => $(s, t), [s, t]), c = S((d, n) => {
|
|
425
|
+
r((l) => {
|
|
426
|
+
const i = { ...l };
|
|
427
|
+
return i[d] === n ? delete i[d] : i[d] = n, i;
|
|
412
428
|
});
|
|
413
|
-
}, []),
|
|
414
|
-
const
|
|
415
|
-
return (
|
|
416
|
-
}).reduce((
|
|
417
|
-
return { swatches:
|
|
429
|
+
}, []), a = b(() => Object.keys(t).filter((l) => t[l]).length === 0 ? [] : u.filter(({ field: l }) => t[l]).map(({ field: l, options: i }) => {
|
|
430
|
+
const f = t[l], p = i.find((g) => g.value === f);
|
|
431
|
+
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 };
|
|
418
434
|
}
|
|
419
435
|
export {
|
|
420
436
|
D as speechToTextSupported,
|
|
421
437
|
x as useActions,
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
438
|
+
W as useDecoratedSearchResults,
|
|
439
|
+
Y as useFacet,
|
|
440
|
+
ee as useFacets,
|
|
441
|
+
fe as useLoadMore,
|
|
426
442
|
y as useNostoAppState,
|
|
427
|
-
|
|
428
|
-
|
|
443
|
+
te as usePagination,
|
|
444
|
+
ne as usePersonalization,
|
|
429
445
|
j as useProductFilters,
|
|
430
446
|
V as useRange,
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
447
|
+
re as useRangeSelector,
|
|
448
|
+
se as useResponse,
|
|
449
|
+
oe as useSelectedFiltersCount,
|
|
450
|
+
ie as useSizeOptions,
|
|
451
|
+
ce as useSort,
|
|
452
|
+
ae as useSpeechToText,
|
|
453
|
+
ue as useSwatches
|
|
438
454
|
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nosto/search-js",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.14.0",
|
|
4
4
|
"license": "ISC",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"files": [
|
|
@@ -90,11 +90,11 @@
|
|
|
90
90
|
"@testing-library/dom": "^10.4.0",
|
|
91
91
|
"@types/dom-speech-recognition": "^0.0.6",
|
|
92
92
|
"@types/eslint-config-prettier": "^6.11.3",
|
|
93
|
-
"@types/node": "^22.15.
|
|
94
|
-
"@vitest/coverage-v8": "^3.1.
|
|
93
|
+
"@types/node": "^22.15.19",
|
|
94
|
+
"@vitest/coverage-v8": "^3.1.4",
|
|
95
95
|
"concurrently": "^9.1.2",
|
|
96
96
|
"copyfiles": "^2.4.1",
|
|
97
|
-
"eslint": "^9.
|
|
97
|
+
"eslint": "^9.27.0",
|
|
98
98
|
"eslint-config-prettier": "^10.1.5",
|
|
99
99
|
"eslint-plugin-barrel-files": "^3.0.1",
|
|
100
100
|
"eslint-plugin-prettier": "^5.4.0",
|
|
@@ -108,9 +108,9 @@
|
|
|
108
108
|
"prettier": "^3.5.3",
|
|
109
109
|
"typedoc": "^0.28.4",
|
|
110
110
|
"typescript": "^5.8.3",
|
|
111
|
-
"typescript-eslint": "^8.32.
|
|
111
|
+
"typescript-eslint": "^8.32.1",
|
|
112
112
|
"vite": "^6.3.5",
|
|
113
|
-
"vite-plugin-dts": "^4.5.
|
|
113
|
+
"vite-plugin-dts": "^4.5.4",
|
|
114
114
|
"vitest": "^3.1.3"
|
|
115
115
|
},
|
|
116
116
|
"publishConfig": {
|