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