@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.
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-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;
|
package/dist/preact/hooks.es.js
CHANGED
|
@@ -1,55 +1,55 @@
|
|
|
1
|
-
import { a as
|
|
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
|
|
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
|
|
6
|
+
import { p as x } from "../parseNumber-QA48nJLp.js";
|
|
7
7
|
function _(e) {
|
|
8
|
-
const
|
|
9
|
-
return e && Array.isArray(e) || e && N(e) ? e :
|
|
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
|
|
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:
|
|
18
|
+
selectedFiltersCount: o,
|
|
19
19
|
/** Toggle active function */
|
|
20
20
|
toggleActive: () => {
|
|
21
|
-
|
|
21
|
+
r(!t);
|
|
22
22
|
},
|
|
23
23
|
/** Toggle product filter function */
|
|
24
|
-
toggleProductFilter:
|
|
24
|
+
toggleProductFilter: s
|
|
25
25
|
};
|
|
26
26
|
}
|
|
27
27
|
function H() {
|
|
28
|
-
const { loading: e, facets:
|
|
29
|
-
var
|
|
28
|
+
const { loading: e, facets: o } = F((t) => {
|
|
29
|
+
var r, s;
|
|
30
30
|
return {
|
|
31
31
|
loading: t.loading,
|
|
32
|
-
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:
|
|
39
|
+
facets: o
|
|
40
40
|
};
|
|
41
41
|
}
|
|
42
|
-
function
|
|
43
|
-
const t =
|
|
44
|
-
return !isNaN(t) && t > 0 ? new Array(
|
|
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:
|
|
48
|
-
query:
|
|
49
|
-
products:
|
|
47
|
+
const { query: o, products: t } = F((r) => ({
|
|
48
|
+
query: r.query,
|
|
49
|
+
products: r.response.products
|
|
50
50
|
}));
|
|
51
|
-
return
|
|
52
|
-
var
|
|
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
|
|
61
|
-
from:
|
|
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
|
-
},
|
|
64
|
+
}, d = (w) => ({
|
|
65
65
|
from: (w - 1) * t.size,
|
|
66
66
|
page: w,
|
|
67
67
|
current: w === c
|
|
68
|
-
}),
|
|
69
|
-
return !v && ((b =
|
|
70
|
-
totalPages:
|
|
71
|
-
resultsFrom:
|
|
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:
|
|
74
|
-
prev:
|
|
75
|
-
next:
|
|
73
|
+
current: i,
|
|
74
|
+
prev: p,
|
|
75
|
+
next: g,
|
|
76
76
|
first: v,
|
|
77
77
|
last: m,
|
|
78
|
-
pages:
|
|
78
|
+
pages: h
|
|
79
79
|
};
|
|
80
|
-
}, [
|
|
80
|
+
}, [o, t, e == null ? void 0 : e.width]);
|
|
81
81
|
}
|
|
82
82
|
function K() {
|
|
83
|
-
const [e,
|
|
83
|
+
const [e, o] = z([]), [t, r] = z([]);
|
|
84
84
|
return C(() => {
|
|
85
|
-
q(async (
|
|
86
|
-
const { products: u, segments: c } = await
|
|
87
|
-
|
|
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
|
|
95
|
-
const { facets: e } =
|
|
94
|
+
function O() {
|
|
95
|
+
const { facets: e } = F((n) => {
|
|
96
96
|
var l;
|
|
97
97
|
return {
|
|
98
|
-
facets: ((l =
|
|
98
|
+
facets: ((l = n.response.products) == null ? void 0 : l.facets) ?? []
|
|
99
99
|
};
|
|
100
|
-
}), { replaceFilter:
|
|
101
|
-
(
|
|
102
|
-
const l = e == null ? void 0 : e.find((
|
|
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
|
-
),
|
|
108
|
-
(
|
|
107
|
+
), s = S(
|
|
108
|
+
(n) => {
|
|
109
109
|
var l;
|
|
110
|
-
return ((l = e == null ? void 0 : e.find((
|
|
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 =
|
|
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
|
-
...
|
|
117
|
-
range: (l =
|
|
118
|
-
gt:
|
|
119
|
-
gte:
|
|
120
|
-
lt:
|
|
121
|
-
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
|
-
}, []),
|
|
125
|
-
(
|
|
126
|
-
value:
|
|
127
|
-
field:
|
|
128
|
-
name:
|
|
129
|
-
filter: c(
|
|
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(
|
|
131
|
+
t(n.field, i, !1);
|
|
132
132
|
}
|
|
133
133
|
})),
|
|
134
|
-
[c,
|
|
135
|
-
), f =
|
|
136
|
-
(
|
|
137
|
-
var
|
|
138
|
-
const
|
|
139
|
-
if (
|
|
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: `${
|
|
142
|
-
field:
|
|
143
|
-
name:
|
|
144
|
-
filter: c(
|
|
141
|
+
value: `${d} - ${p}`,
|
|
142
|
+
field: n.field,
|
|
143
|
+
name: s(n.field),
|
|
144
|
+
filter: c(n),
|
|
145
145
|
remove: () => {
|
|
146
|
-
|
|
146
|
+
o(n.field, void 0);
|
|
147
147
|
}
|
|
148
148
|
};
|
|
149
149
|
}).filter(Boolean),
|
|
150
|
-
[c,
|
|
150
|
+
[c, r, s, o]
|
|
151
151
|
);
|
|
152
152
|
return {
|
|
153
153
|
selectFilters: u,
|
|
154
|
-
toValueFilter:
|
|
154
|
+
toValueFilter: a,
|
|
155
155
|
toRangeFilter: f
|
|
156
156
|
};
|
|
157
157
|
}
|
|
158
|
-
function
|
|
159
|
-
const { filter: e } =
|
|
158
|
+
function j() {
|
|
159
|
+
const { filter: e } = F((a) => {
|
|
160
160
|
var f;
|
|
161
161
|
return {
|
|
162
|
-
filter: ((f =
|
|
162
|
+
filter: ((f = a.query.products) == null ? void 0 : f.filter) ?? []
|
|
163
163
|
};
|
|
164
|
-
}), { updateSearch:
|
|
165
|
-
|
|
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
|
-
}, [
|
|
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
|
|
180
|
-
const { replaceFilter:
|
|
181
|
-
query:
|
|
182
|
-
products:
|
|
183
|
-
})),
|
|
184
|
-
if (!
|
|
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 = (
|
|
193
|
-
const m =
|
|
194
|
-
(f === m || !
|
|
195
|
-
lte:
|
|
196
|
-
}) : (
|
|
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
|
-
}) :
|
|
198
|
+
}) : y && b && o(s.field, {
|
|
199
199
|
gte: m.toString(),
|
|
200
|
-
lte:
|
|
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:
|
|
207
|
+
max: n,
|
|
208
208
|
/** Range value */
|
|
209
|
-
range: [
|
|
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,
|
|
215
|
-
const { min: t, max:
|
|
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
|
|
218
|
-
var
|
|
219
|
-
return (
|
|
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
|
|
222
|
-
if (
|
|
223
|
-
const m = (v =
|
|
224
|
-
|
|
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
|
|
227
|
-
let
|
|
228
|
-
for (;
|
|
229
|
-
const m =
|
|
230
|
-
|
|
231
|
-
min:
|
|
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:
|
|
234
|
-
}),
|
|
233
|
+
selected: h
|
|
234
|
+
}), g = m;
|
|
235
235
|
}
|
|
236
|
-
return
|
|
237
|
-
}, [c, t,
|
|
238
|
-
u([
|
|
239
|
-
},
|
|
240
|
-
u([
|
|
241
|
-
}, l = t !==
|
|
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:
|
|
246
|
+
max: r,
|
|
247
247
|
/** Range value */
|
|
248
|
-
range:
|
|
248
|
+
range: s,
|
|
249
249
|
/** Update range function */
|
|
250
250
|
updateRange: u,
|
|
251
251
|
/** Ranges */
|
|
252
|
-
ranges:
|
|
252
|
+
ranges: a,
|
|
253
253
|
/** Handle min change */
|
|
254
254
|
handleMinChange: f,
|
|
255
255
|
/** Handle max change */
|
|
256
|
-
handleMaxChange:
|
|
256
|
+
handleMaxChange: n,
|
|
257
257
|
/** Is selected */
|
|
258
258
|
isSelected: l
|
|
259
259
|
};
|
|
260
260
|
}
|
|
261
261
|
function W() {
|
|
262
|
-
const { products: e, keywords:
|
|
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:
|
|
267
|
+
keywords: o ?? { hits: [], total: 0 }
|
|
268
268
|
};
|
|
269
269
|
}
|
|
270
270
|
function X() {
|
|
271
|
-
const e =
|
|
272
|
-
var
|
|
273
|
-
return (
|
|
271
|
+
const e = F((t) => {
|
|
272
|
+
var r;
|
|
273
|
+
return (r = t.query.products) == null ? void 0 : r.filter;
|
|
274
274
|
});
|
|
275
|
-
return
|
|
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,
|
|
281
|
-
const { from: t, size:
|
|
282
|
-
var l,
|
|
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 =
|
|
285
|
-
size: A(((
|
|
286
|
-
total: A(((
|
|
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 } =
|
|
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:
|
|
295
|
+
total: s,
|
|
296
296
|
/** size value */
|
|
297
|
-
size:
|
|
297
|
+
size: r,
|
|
298
298
|
/** Array of size options */
|
|
299
|
-
sizeOptions:
|
|
299
|
+
sizeOptions: a,
|
|
300
300
|
/** Should be called when size is changed */
|
|
301
|
-
handleSizeChange: (
|
|
301
|
+
handleSizeChange: (n) => {
|
|
302
302
|
u({
|
|
303
303
|
products: {
|
|
304
|
-
size:
|
|
304
|
+
size: x(n)
|
|
305
305
|
}
|
|
306
306
|
});
|
|
307
307
|
}
|
|
308
308
|
};
|
|
309
309
|
}
|
|
310
|
-
function
|
|
311
|
-
return e.length !==
|
|
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
|
|
315
|
+
const o = F((a) => a.query), { updateSearch: t } = R();
|
|
316
316
|
return {
|
|
317
317
|
/** Active sort */
|
|
318
|
-
activeSort: ((u = e.find((
|
|
318
|
+
activeSort: ((u = e.find((a) => {
|
|
319
319
|
var f;
|
|
320
|
-
return
|
|
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: (
|
|
324
|
-
const f = e.find((
|
|
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
|
|
334
|
-
if (!e.length || !
|
|
335
|
-
const t =
|
|
336
|
-
return e.forEach((
|
|
337
|
-
var
|
|
338
|
-
(
|
|
339
|
-
const
|
|
340
|
-
|
|
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(([
|
|
343
|
-
field:
|
|
344
|
-
options: Object.entries(
|
|
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
|
|
353
|
-
return e.length ? e.map(({ field: t, options:
|
|
352
|
+
function T(e, o) {
|
|
353
|
+
return e.length ? e.map(({ field: t, options: r }) => ({
|
|
354
354
|
field: t,
|
|
355
|
-
options:
|
|
356
|
-
var
|
|
357
|
-
const u = !((
|
|
358
|
-
var
|
|
359
|
-
return
|
|
360
|
-
}))), c =
|
|
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
|
-
...
|
|
362
|
+
...s,
|
|
363
363
|
unavailable: u,
|
|
364
364
|
selected: c
|
|
365
365
|
};
|
|
366
366
|
})
|
|
367
367
|
})) : [];
|
|
368
368
|
}
|
|
369
|
-
function ee(e = [],
|
|
370
|
-
const [t,
|
|
371
|
-
|
|
372
|
-
const
|
|
373
|
-
return
|
|
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
|
-
|
|
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
|
-
|
|
382
|
+
R as useActions,
|
|
380
383
|
_ as useDecoratedSearchResults,
|
|
381
384
|
G as useFacet,
|
|
382
385
|
H as useFacets,
|
|
383
386
|
re as useLoadMore,
|
|
384
|
-
|
|
387
|
+
F as useNostoAppState,
|
|
385
388
|
J as usePagination,
|
|
386
389
|
K as usePersonalization,
|
|
387
|
-
|
|
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
|
-
*
|
|
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
|
};
|
package/dist/utils/utils.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 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;
|
package/dist/utils/utils.es.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { d as
|
|
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
|
|
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,
|
|
12
|
-
e.addEventListener(f,
|
|
11
|
+
function r(e, f, v) {
|
|
12
|
+
e.addEventListener(f, v), o.push(() => e.removeEventListener(f, v));
|
|
13
13
|
}
|
|
14
|
-
return (
|
|
15
|
-
|
|
16
|
-
}),
|
|
17
|
-
e.preventDefault(),
|
|
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(),
|
|
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
|
-
|
|
30
|
-
|
|
29
|
+
m as bindInput,
|
|
30
|
+
t as deepMerge,
|
|
31
31
|
d as disableNativeAutocomplete,
|
|
32
32
|
A as isBot,
|
|
33
33
|
h as isEqual,
|