@nosto/nosto-react 0.4.1 → 0.5.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.
Files changed (33) hide show
  1. package/README.md +5 -2
  2. package/dist/index.d.ts +519 -0
  3. package/dist/index.es.js +1117 -0
  4. package/dist/index.umd.js +25 -0
  5. package/package.json +20 -13
  6. package/src/components/Nosto404.tsx +47 -0
  7. package/src/components/{Category/index.client.tsx → NostoCategory.tsx} +18 -39
  8. package/src/components/NostoCheckout.tsx +47 -0
  9. package/src/components/{Home/index.client.tsx → NostoHome.tsx} +17 -36
  10. package/src/components/NostoOrder.tsx +55 -0
  11. package/src/components/NostoOther.tsx +46 -0
  12. package/src/components/{Placement/index.client.tsx → NostoPlacement.tsx} +5 -8
  13. package/src/components/{Product/index.client.tsx → NostoProduct.tsx} +37 -81
  14. package/src/components/NostoProvider.tsx +220 -0
  15. package/src/components/{Search/index.client.tsx → NostoSearch.tsx} +18 -39
  16. package/src/components/{Session/index.client.tsx → NostoSession.tsx} +14 -17
  17. package/src/components/context.ts +55 -0
  18. package/src/components/index.ts +14 -0
  19. package/src/index.ts +3 -0
  20. package/src/types.ts +112 -97
  21. package/src/utils/compare.ts +9 -9
  22. package/src/utils/hooks.ts +28 -8
  23. package/src/utils/object.ts +10 -11
  24. package/src/utils/snakeize.ts +11 -11
  25. package/dist/index.es.client.js +0 -660
  26. package/dist/index.umd.client.js +0 -9
  27. package/src/components/Checkout/index.client.tsx +0 -66
  28. package/src/components/Fohofo/index.client.tsx +0 -66
  29. package/src/components/Order/index.client.tsx +0 -72
  30. package/src/components/Other/index.client.tsx +0 -64
  31. package/src/components/Provider/context.client.ts +0 -45
  32. package/src/components/Provider/index.client.tsx +0 -222
  33. package/src/index.client.ts +0 -33
@@ -0,0 +1,1117 @@
1
+ import z, { createContext as Cr, useContext as br, useEffect as ae, useRef as ve, useMemo as Er, isValidElement as wr, useState as Sr } from "react";
2
+ import { createRoot as Tr } from "react-dom/client";
3
+ const Je = Cr({
4
+ account: "",
5
+ currentVariation: "",
6
+ pageType: "",
7
+ responseMode: "HTML",
8
+ clientScriptLoaded: !1,
9
+ useRenderCampaigns: () => ({
10
+ renderCampaigns: () => {
11
+ },
12
+ pageTypeUpdated: !1
13
+ })
14
+ });
15
+ function x() {
16
+ const o = br(Je);
17
+ if (!o)
18
+ throw new Error("No nosto context found");
19
+ return o;
20
+ }
21
+ const qe = (o) => String(o) === "[object Object]";
22
+ function Be(o) {
23
+ if (!qe(o))
24
+ return !1;
25
+ const s = o.constructor;
26
+ if (s === void 0)
27
+ return !0;
28
+ const r = s.prototype;
29
+ return !(!qe(r) || !r.hasOwnProperty("isPrototypeOf"));
30
+ }
31
+ function ye(o, s) {
32
+ if (o === s)
33
+ return !0;
34
+ if (o instanceof Date && s instanceof Date)
35
+ return o.getTime() === s.getTime();
36
+ if (o instanceof Array && s instanceof Array)
37
+ return o.length !== s.length ? !1 : o.every((r, d) => ye(r, s[d]));
38
+ if (Be(o) && Be(s)) {
39
+ const r = Object.entries(o);
40
+ return r.length !== Object.keys(s).length ? !1 : r.every(([d, m]) => ye(m, s[d]));
41
+ }
42
+ return !1;
43
+ }
44
+ function ze(o, s) {
45
+ return ae(o, Pr(s));
46
+ }
47
+ function Pr(o) {
48
+ const s = ve(o), r = ve(0);
49
+ return ye(o, s.current) || (s.current = o, r.current += 1), Er(() => s.current, [r.current]);
50
+ }
51
+ function U(o, s, r) {
52
+ const { clientScriptLoaded: d, currentVariation: m, responseMode: u } = x();
53
+ (r != null && r.deep ? ze : ae)(() => {
54
+ d && window.nostojs((y) => {
55
+ y.defaultSession().setVariation(m).setResponseMode(u), o(y);
56
+ });
57
+ }, [d, m, u, ...s ?? []]);
58
+ }
59
+ var he = { exports: {} }, H = {};
60
+ /**
61
+ * @license React
62
+ * react-jsx-runtime.production.min.js
63
+ *
64
+ * Copyright (c) Facebook, Inc. and its affiliates.
65
+ *
66
+ * This source code is licensed under the MIT license found in the
67
+ * LICENSE file in the root directory of this source tree.
68
+ */
69
+ var Ge;
70
+ function gr() {
71
+ if (Ge)
72
+ return H;
73
+ Ge = 1;
74
+ var o = z, s = Symbol.for("react.element"), r = Symbol.for("react.fragment"), d = Object.prototype.hasOwnProperty, m = o.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, u = { key: !0, ref: !0, __self: !0, __source: !0 };
75
+ function l(y, n, R) {
76
+ var w, T = {}, F = null, L = null;
77
+ R !== void 0 && (F = "" + R), n.key !== void 0 && (F = "" + n.key), n.ref !== void 0 && (L = n.ref);
78
+ for (w in n)
79
+ d.call(n, w) && !u.hasOwnProperty(w) && (T[w] = n[w]);
80
+ if (y && y.defaultProps)
81
+ for (w in n = y.defaultProps, n)
82
+ T[w] === void 0 && (T[w] = n[w]);
83
+ return { $$typeof: s, type: y, key: F, ref: L, props: T, _owner: m.current };
84
+ }
85
+ return H.Fragment = r, H.jsx = l, H.jsxs = l, H;
86
+ }
87
+ var J = {};
88
+ /**
89
+ * @license React
90
+ * react-jsx-runtime.development.js
91
+ *
92
+ * Copyright (c) Facebook, Inc. and its affiliates.
93
+ *
94
+ * This source code is licensed under the MIT license found in the
95
+ * LICENSE file in the root directory of this source tree.
96
+ */
97
+ var He;
98
+ function Or() {
99
+ return He || (He = 1, process.env.NODE_ENV !== "production" && function() {
100
+ var o = z, s = Symbol.for("react.element"), r = Symbol.for("react.portal"), d = Symbol.for("react.fragment"), m = Symbol.for("react.strict_mode"), u = Symbol.for("react.profiler"), l = Symbol.for("react.provider"), y = Symbol.for("react.context"), n = Symbol.for("react.forward_ref"), R = Symbol.for("react.suspense"), w = Symbol.for("react.suspense_list"), T = Symbol.for("react.memo"), F = Symbol.for("react.lazy"), L = Symbol.for("react.offscreen"), X = Symbol.iterator, oe = "@@iterator";
101
+ function j(e) {
102
+ if (e === null || typeof e != "object")
103
+ return null;
104
+ var t = X && e[X] || e[oe];
105
+ return typeof t == "function" ? t : null;
106
+ }
107
+ var P = o.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
108
+ function b(e) {
109
+ {
110
+ for (var t = arguments.length, a = new Array(t > 1 ? t - 1 : 0), c = 1; c < t; c++)
111
+ a[c - 1] = arguments[c];
112
+ _("error", e, a);
113
+ }
114
+ }
115
+ function _(e, t, a) {
116
+ {
117
+ var c = P.ReactDebugCurrentFrame, v = c.getStackAddendum();
118
+ v !== "" && (t += "%s", a = a.concat([v]));
119
+ var h = a.map(function(p) {
120
+ return String(p);
121
+ });
122
+ h.unshift("Warning: " + t), Function.prototype.apply.call(console[e], console, h);
123
+ }
124
+ }
125
+ var g = !1, O = !1, $ = !1, V = !1, se = !1, Z;
126
+ Z = Symbol.for("react.module.reference");
127
+ function Q(e) {
128
+ return !!(typeof e == "string" || typeof e == "function" || e === d || e === u || se || e === m || e === R || e === w || V || e === L || g || O || $ || typeof e == "object" && e !== null && (e.$$typeof === F || e.$$typeof === T || e.$$typeof === l || e.$$typeof === y || e.$$typeof === n || // This needs to include all possible module reference object
129
+ // types supported by any Flight configuration anywhere since
130
+ // we don't know which Flight build this will end up being used
131
+ // with.
132
+ e.$$typeof === Z || e.getModuleId !== void 0));
133
+ }
134
+ function Re(e, t, a) {
135
+ var c = e.displayName;
136
+ if (c)
137
+ return c;
138
+ var v = t.displayName || t.name || "";
139
+ return v !== "" ? a + "(" + v + ")" : a;
140
+ }
141
+ function Ce(e) {
142
+ return e.displayName || "Context";
143
+ }
144
+ function A(e) {
145
+ if (e == null)
146
+ return null;
147
+ if (typeof e.tag == "number" && b("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."), typeof e == "function")
148
+ return e.displayName || e.name || null;
149
+ if (typeof e == "string")
150
+ return e;
151
+ switch (e) {
152
+ case d:
153
+ return "Fragment";
154
+ case r:
155
+ return "Portal";
156
+ case u:
157
+ return "Profiler";
158
+ case m:
159
+ return "StrictMode";
160
+ case R:
161
+ return "Suspense";
162
+ case w:
163
+ return "SuspenseList";
164
+ }
165
+ if (typeof e == "object")
166
+ switch (e.$$typeof) {
167
+ case y:
168
+ var t = e;
169
+ return Ce(t) + ".Consumer";
170
+ case l:
171
+ var a = e;
172
+ return Ce(a._context) + ".Provider";
173
+ case n:
174
+ return Re(e, e.render, "ForwardRef");
175
+ case T:
176
+ var c = e.displayName || null;
177
+ return c !== null ? c : A(e.type) || "Memo";
178
+ case F: {
179
+ var v = e, h = v._payload, p = v._init;
180
+ try {
181
+ return A(p(h));
182
+ } catch {
183
+ return null;
184
+ }
185
+ }
186
+ }
187
+ return null;
188
+ }
189
+ var W = Object.assign, B = 0, be, Ee, we, Se, Te, Pe, ge;
190
+ function Oe() {
191
+ }
192
+ Oe.__reactDisabledLog = !0;
193
+ function Ke() {
194
+ {
195
+ if (B === 0) {
196
+ be = console.log, Ee = console.info, we = console.warn, Se = console.error, Te = console.group, Pe = console.groupCollapsed, ge = console.groupEnd;
197
+ var e = {
198
+ configurable: !0,
199
+ enumerable: !0,
200
+ value: Oe,
201
+ writable: !0
202
+ };
203
+ Object.defineProperties(console, {
204
+ info: e,
205
+ log: e,
206
+ warn: e,
207
+ error: e,
208
+ group: e,
209
+ groupCollapsed: e,
210
+ groupEnd: e
211
+ });
212
+ }
213
+ B++;
214
+ }
215
+ }
216
+ function Xe() {
217
+ {
218
+ if (B--, B === 0) {
219
+ var e = {
220
+ configurable: !0,
221
+ enumerable: !0,
222
+ writable: !0
223
+ };
224
+ Object.defineProperties(console, {
225
+ log: W({}, e, {
226
+ value: be
227
+ }),
228
+ info: W({}, e, {
229
+ value: Ee
230
+ }),
231
+ warn: W({}, e, {
232
+ value: we
233
+ }),
234
+ error: W({}, e, {
235
+ value: Se
236
+ }),
237
+ group: W({}, e, {
238
+ value: Te
239
+ }),
240
+ groupCollapsed: W({}, e, {
241
+ value: Pe
242
+ }),
243
+ groupEnd: W({}, e, {
244
+ value: ge
245
+ })
246
+ });
247
+ }
248
+ B < 0 && b("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
249
+ }
250
+ }
251
+ var ie = P.ReactCurrentDispatcher, ce;
252
+ function k(e, t, a) {
253
+ {
254
+ if (ce === void 0)
255
+ try {
256
+ throw Error();
257
+ } catch (v) {
258
+ var c = v.stack.trim().match(/\n( *(at )?)/);
259
+ ce = c && c[1] || "";
260
+ }
261
+ return `
262
+ ` + ce + e;
263
+ }
264
+ }
265
+ var le = !1, ee;
266
+ {
267
+ var Ze = typeof WeakMap == "function" ? WeakMap : Map;
268
+ ee = new Ze();
269
+ }
270
+ function Ne(e, t) {
271
+ if (!e || le)
272
+ return "";
273
+ {
274
+ var a = ee.get(e);
275
+ if (a !== void 0)
276
+ return a;
277
+ }
278
+ var c;
279
+ le = !0;
280
+ var v = Error.prepareStackTrace;
281
+ Error.prepareStackTrace = void 0;
282
+ var h;
283
+ h = ie.current, ie.current = null, Ke();
284
+ try {
285
+ if (t) {
286
+ var p = function() {
287
+ throw Error();
288
+ };
289
+ if (Object.defineProperty(p.prototype, "props", {
290
+ set: function() {
291
+ throw Error();
292
+ }
293
+ }), typeof Reflect == "object" && Reflect.construct) {
294
+ try {
295
+ Reflect.construct(p, []);
296
+ } catch (D) {
297
+ c = D;
298
+ }
299
+ Reflect.construct(e, [], p);
300
+ } else {
301
+ try {
302
+ p.call();
303
+ } catch (D) {
304
+ c = D;
305
+ }
306
+ e.call(p.prototype);
307
+ }
308
+ } else {
309
+ try {
310
+ throw Error();
311
+ } catch (D) {
312
+ c = D;
313
+ }
314
+ e();
315
+ }
316
+ } catch (D) {
317
+ if (D && c && typeof D.stack == "string") {
318
+ for (var f = D.stack.split(`
319
+ `), S = c.stack.split(`
320
+ `), C = f.length - 1, E = S.length - 1; C >= 1 && E >= 0 && f[C] !== S[E]; )
321
+ E--;
322
+ for (; C >= 1 && E >= 0; C--, E--)
323
+ if (f[C] !== S[E]) {
324
+ if (C !== 1 || E !== 1)
325
+ do
326
+ if (C--, E--, E < 0 || f[C] !== S[E]) {
327
+ var N = `
328
+ ` + f[C].replace(" at new ", " at ");
329
+ return e.displayName && N.includes("<anonymous>") && (N = N.replace("<anonymous>", e.displayName)), typeof e == "function" && ee.set(e, N), N;
330
+ }
331
+ while (C >= 1 && E >= 0);
332
+ break;
333
+ }
334
+ }
335
+ } finally {
336
+ le = !1, ie.current = h, Xe(), Error.prepareStackTrace = v;
337
+ }
338
+ var M = e ? e.displayName || e.name : "", Me = M ? k(M) : "";
339
+ return typeof e == "function" && ee.set(e, Me), Me;
340
+ }
341
+ function Qe(e, t, a) {
342
+ return Ne(e, !1);
343
+ }
344
+ function ke(e) {
345
+ var t = e.prototype;
346
+ return !!(t && t.isReactComponent);
347
+ }
348
+ function re(e, t, a) {
349
+ if (e == null)
350
+ return "";
351
+ if (typeof e == "function")
352
+ return Ne(e, ke(e));
353
+ if (typeof e == "string")
354
+ return k(e);
355
+ switch (e) {
356
+ case R:
357
+ return k("Suspense");
358
+ case w:
359
+ return k("SuspenseList");
360
+ }
361
+ if (typeof e == "object")
362
+ switch (e.$$typeof) {
363
+ case n:
364
+ return Qe(e.render);
365
+ case T:
366
+ return re(e.type, t, a);
367
+ case F: {
368
+ var c = e, v = c._payload, h = c._init;
369
+ try {
370
+ return re(h(v), t, a);
371
+ } catch {
372
+ }
373
+ }
374
+ }
375
+ return "";
376
+ }
377
+ var te = Object.prototype.hasOwnProperty, je = {}, xe = P.ReactDebugCurrentFrame;
378
+ function ne(e) {
379
+ if (e) {
380
+ var t = e._owner, a = re(e.type, e._source, t ? t.type : null);
381
+ xe.setExtraStackFrame(a);
382
+ } else
383
+ xe.setExtraStackFrame(null);
384
+ }
385
+ function er(e, t, a, c, v) {
386
+ {
387
+ var h = Function.call.bind(te);
388
+ for (var p in e)
389
+ if (h(e, p)) {
390
+ var f = void 0;
391
+ try {
392
+ if (typeof e[p] != "function") {
393
+ var S = Error((c || "React class") + ": " + a + " type `" + p + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof e[p] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");
394
+ throw S.name = "Invariant Violation", S;
395
+ }
396
+ f = e[p](t, p, c, a, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED");
397
+ } catch (C) {
398
+ f = C;
399
+ }
400
+ f && !(f instanceof Error) && (ne(v), b("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).", c || "React class", a, p, typeof f), ne(null)), f instanceof Error && !(f.message in je) && (je[f.message] = !0, ne(v), b("Failed %s type: %s", a, f.message), ne(null));
401
+ }
402
+ }
403
+ }
404
+ var rr = Array.isArray;
405
+ function ue(e) {
406
+ return rr(e);
407
+ }
408
+ function tr(e) {
409
+ {
410
+ var t = typeof Symbol == "function" && Symbol.toStringTag, a = t && e[Symbol.toStringTag] || e.constructor.name || "Object";
411
+ return a;
412
+ }
413
+ }
414
+ function nr(e) {
415
+ try {
416
+ return Fe(e), !1;
417
+ } catch {
418
+ return !0;
419
+ }
420
+ }
421
+ function Fe(e) {
422
+ return "" + e;
423
+ }
424
+ function Ae(e) {
425
+ if (nr(e))
426
+ return b("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", tr(e)), Fe(e);
427
+ }
428
+ var G = P.ReactCurrentOwner, ar = {
429
+ key: !0,
430
+ ref: !0,
431
+ __self: !0,
432
+ __source: !0
433
+ }, De, Ie, de;
434
+ de = {};
435
+ function or(e) {
436
+ if (te.call(e, "ref")) {
437
+ var t = Object.getOwnPropertyDescriptor(e, "ref").get;
438
+ if (t && t.isReactWarning)
439
+ return !1;
440
+ }
441
+ return e.ref !== void 0;
442
+ }
443
+ function sr(e) {
444
+ if (te.call(e, "key")) {
445
+ var t = Object.getOwnPropertyDescriptor(e, "key").get;
446
+ if (t && t.isReactWarning)
447
+ return !1;
448
+ }
449
+ return e.key !== void 0;
450
+ }
451
+ function ir(e, t) {
452
+ if (typeof e.ref == "string" && G.current && t && G.current.stateNode !== t) {
453
+ var a = A(G.current.type);
454
+ de[a] || (b('Component "%s" contains the string ref "%s". Support for string refs will be removed in a future major release. This case cannot be automatically converted to an arrow function. We ask you to manually fix this case by using useRef() or createRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref', A(G.current.type), e.ref), de[a] = !0);
455
+ }
456
+ }
457
+ function cr(e, t) {
458
+ {
459
+ var a = function() {
460
+ De || (De = !0, b("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", t));
461
+ };
462
+ a.isReactWarning = !0, Object.defineProperty(e, "key", {
463
+ get: a,
464
+ configurable: !0
465
+ });
466
+ }
467
+ }
468
+ function lr(e, t) {
469
+ {
470
+ var a = function() {
471
+ Ie || (Ie = !0, b("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", t));
472
+ };
473
+ a.isReactWarning = !0, Object.defineProperty(e, "ref", {
474
+ get: a,
475
+ configurable: !0
476
+ });
477
+ }
478
+ }
479
+ var ur = function(e, t, a, c, v, h, p) {
480
+ var f = {
481
+ // This tag allows us to uniquely identify this as a React Element
482
+ $$typeof: s,
483
+ // Built-in properties that belong on the element
484
+ type: e,
485
+ key: t,
486
+ ref: a,
487
+ props: p,
488
+ // Record the component responsible for creating this element.
489
+ _owner: h
490
+ };
491
+ return f._store = {}, Object.defineProperty(f._store, "validated", {
492
+ configurable: !1,
493
+ enumerable: !1,
494
+ writable: !0,
495
+ value: !1
496
+ }), Object.defineProperty(f, "_self", {
497
+ configurable: !1,
498
+ enumerable: !1,
499
+ writable: !1,
500
+ value: c
501
+ }), Object.defineProperty(f, "_source", {
502
+ configurable: !1,
503
+ enumerable: !1,
504
+ writable: !1,
505
+ value: v
506
+ }), Object.freeze && (Object.freeze(f.props), Object.freeze(f)), f;
507
+ };
508
+ function dr(e, t, a, c, v) {
509
+ {
510
+ var h, p = {}, f = null, S = null;
511
+ a !== void 0 && (Ae(a), f = "" + a), sr(t) && (Ae(t.key), f = "" + t.key), or(t) && (S = t.ref, ir(t, v));
512
+ for (h in t)
513
+ te.call(t, h) && !ar.hasOwnProperty(h) && (p[h] = t[h]);
514
+ if (e && e.defaultProps) {
515
+ var C = e.defaultProps;
516
+ for (h in C)
517
+ p[h] === void 0 && (p[h] = C[h]);
518
+ }
519
+ if (f || S) {
520
+ var E = typeof e == "function" ? e.displayName || e.name || "Unknown" : e;
521
+ f && cr(p, E), S && lr(p, E);
522
+ }
523
+ return ur(e, f, S, v, c, G.current, p);
524
+ }
525
+ }
526
+ var fe = P.ReactCurrentOwner, Le = P.ReactDebugCurrentFrame;
527
+ function Y(e) {
528
+ if (e) {
529
+ var t = e._owner, a = re(e.type, e._source, t ? t.type : null);
530
+ Le.setExtraStackFrame(a);
531
+ } else
532
+ Le.setExtraStackFrame(null);
533
+ }
534
+ var pe;
535
+ pe = !1;
536
+ function me(e) {
537
+ return typeof e == "object" && e !== null && e.$$typeof === s;
538
+ }
539
+ function Ue() {
540
+ {
541
+ if (fe.current) {
542
+ var e = A(fe.current.type);
543
+ if (e)
544
+ return `
545
+
546
+ Check the render method of \`` + e + "`.";
547
+ }
548
+ return "";
549
+ }
550
+ }
551
+ function fr(e) {
552
+ return "";
553
+ }
554
+ var $e = {};
555
+ function pr(e) {
556
+ {
557
+ var t = Ue();
558
+ if (!t) {
559
+ var a = typeof e == "string" ? e : e.displayName || e.name;
560
+ a && (t = `
561
+
562
+ Check the top-level render call using <` + a + ">.");
563
+ }
564
+ return t;
565
+ }
566
+ }
567
+ function Ve(e, t) {
568
+ {
569
+ if (!e._store || e._store.validated || e.key != null)
570
+ return;
571
+ e._store.validated = !0;
572
+ var a = pr(t);
573
+ if ($e[a])
574
+ return;
575
+ $e[a] = !0;
576
+ var c = "";
577
+ e && e._owner && e._owner !== fe.current && (c = " It was passed a child from " + A(e._owner.type) + "."), Y(e), b('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', a, c), Y(null);
578
+ }
579
+ }
580
+ function We(e, t) {
581
+ {
582
+ if (typeof e != "object")
583
+ return;
584
+ if (ue(e))
585
+ for (var a = 0; a < e.length; a++) {
586
+ var c = e[a];
587
+ me(c) && Ve(c, t);
588
+ }
589
+ else if (me(e))
590
+ e._store && (e._store.validated = !0);
591
+ else if (e) {
592
+ var v = j(e);
593
+ if (typeof v == "function" && v !== e.entries)
594
+ for (var h = v.call(e), p; !(p = h.next()).done; )
595
+ me(p.value) && Ve(p.value, t);
596
+ }
597
+ }
598
+ }
599
+ function mr(e) {
600
+ {
601
+ var t = e.type;
602
+ if (t == null || typeof t == "string")
603
+ return;
604
+ var a;
605
+ if (typeof t == "function")
606
+ a = t.propTypes;
607
+ else if (typeof t == "object" && (t.$$typeof === n || // Note: Memo only checks outer props here.
608
+ // Inner props are checked in the reconciler.
609
+ t.$$typeof === T))
610
+ a = t.propTypes;
611
+ else
612
+ return;
613
+ if (a) {
614
+ var c = A(t);
615
+ er(a, e.props, "prop", c, e);
616
+ } else if (t.PropTypes !== void 0 && !pe) {
617
+ pe = !0;
618
+ var v = A(t);
619
+ b("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", v || "Unknown");
620
+ }
621
+ typeof t.getDefaultProps == "function" && !t.getDefaultProps.isReactClassApproved && b("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.");
622
+ }
623
+ }
624
+ function vr(e) {
625
+ {
626
+ for (var t = Object.keys(e.props), a = 0; a < t.length; a++) {
627
+ var c = t[a];
628
+ if (c !== "children" && c !== "key") {
629
+ Y(e), b("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", c), Y(null);
630
+ break;
631
+ }
632
+ }
633
+ e.ref !== null && (Y(e), b("Invalid attribute `ref` supplied to `React.Fragment`."), Y(null));
634
+ }
635
+ }
636
+ function Ye(e, t, a, c, v, h) {
637
+ {
638
+ var p = Q(e);
639
+ if (!p) {
640
+ var f = "";
641
+ (e === void 0 || typeof e == "object" && e !== null && Object.keys(e).length === 0) && (f += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");
642
+ var S = fr();
643
+ S ? f += S : f += Ue();
644
+ var C;
645
+ e === null ? C = "null" : ue(e) ? C = "array" : e !== void 0 && e.$$typeof === s ? (C = "<" + (A(e.type) || "Unknown") + " />", f = " Did you accidentally export a JSX literal instead of a component?") : C = typeof e, b("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", C, f);
646
+ }
647
+ var E = dr(e, t, a, v, h);
648
+ if (E == null)
649
+ return E;
650
+ if (p) {
651
+ var N = t.children;
652
+ if (N !== void 0)
653
+ if (c)
654
+ if (ue(N)) {
655
+ for (var M = 0; M < N.length; M++)
656
+ We(N[M], e);
657
+ Object.freeze && Object.freeze(N);
658
+ } else
659
+ b("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");
660
+ else
661
+ We(N, e);
662
+ }
663
+ return e === d ? vr(E) : mr(E), E;
664
+ }
665
+ }
666
+ function yr(e, t, a) {
667
+ return Ye(e, t, a, !0);
668
+ }
669
+ function hr(e, t, a) {
670
+ return Ye(e, t, a, !1);
671
+ }
672
+ var _r = hr, Rr = yr;
673
+ J.Fragment = d, J.jsx = _r, J.jsxs = Rr;
674
+ }()), J;
675
+ }
676
+ process.env.NODE_ENV === "production" ? he.exports = gr() : he.exports = Or();
677
+ var _e = he.exports;
678
+ const i = _e.jsx, q = _e.jsxs, I = _e.Fragment;
679
+ function Ar(o) {
680
+ const {
681
+ recommendationComponent: s,
682
+ useRenderCampaigns: r
683
+ } = x(), {
684
+ renderCampaigns: d,
685
+ pageTypeUpdated: m
686
+ } = r("404");
687
+ return U(async (u) => {
688
+ const l = await u.defaultSession().viewNotFound().setPlacements(o.placements || u.placements.getPlacements()).load();
689
+ d(l, u);
690
+ }, [s, m]), /* @__PURE__ */ i(I, {
691
+ children: /* @__PURE__ */ i("div", {
692
+ className: "nosto_page_type",
693
+ style: {
694
+ display: "none"
695
+ },
696
+ children: "notfound"
697
+ })
698
+ });
699
+ }
700
+ function Dr(o) {
701
+ const {
702
+ recommendationComponent: s,
703
+ useRenderCampaigns: r
704
+ } = x(), {
705
+ renderCampaigns: d,
706
+ pageTypeUpdated: m
707
+ } = r("other");
708
+ return U(async (u) => {
709
+ const l = await u.defaultSession().viewOther().setPlacements(o.placements || u.placements.getPlacements()).load();
710
+ d(l, u);
711
+ }, [s, m]), /* @__PURE__ */ i(I, {
712
+ children: /* @__PURE__ */ i("div", {
713
+ className: "nosto_page_type",
714
+ style: {
715
+ display: "none"
716
+ },
717
+ children: "other"
718
+ })
719
+ });
720
+ }
721
+ function Ir(o) {
722
+ const {
723
+ recommendationComponent: s,
724
+ useRenderCampaigns: r
725
+ } = x(), {
726
+ renderCampaigns: d,
727
+ pageTypeUpdated: m
728
+ } = r("checkout");
729
+ return U(async (u) => {
730
+ const l = await u.defaultSession().viewCart().setPlacements(o.placements || u.placements.getPlacements()).load();
731
+ d(l, u);
732
+ }, [s, m]), /* @__PURE__ */ i(I, {
733
+ children: /* @__PURE__ */ i("div", {
734
+ className: "nosto_page_type",
735
+ style: {
736
+ display: "none"
737
+ },
738
+ children: "cart"
739
+ })
740
+ });
741
+ }
742
+ function Lr(o) {
743
+ const {
744
+ product: s,
745
+ tagging: r,
746
+ placements: d
747
+ } = o, {
748
+ recommendationComponent: m,
749
+ useRenderCampaigns: u
750
+ } = x(), {
751
+ renderCampaigns: l,
752
+ pageTypeUpdated: y
753
+ } = u("product");
754
+ return U(async (n) => {
755
+ const R = await n.defaultSession().viewProduct(s).setPlacements(d || n.placements.getPlacements()).load();
756
+ l(R, n);
757
+ }, [s, m, y], {
758
+ deep: !0
759
+ }), /* @__PURE__ */ q(I, {
760
+ children: [/* @__PURE__ */ i("div", {
761
+ className: "nosto_page_type",
762
+ style: {
763
+ display: "none"
764
+ },
765
+ children: "product"
766
+ }), /* @__PURE__ */ q("div", {
767
+ className: "nosto_product",
768
+ style: {
769
+ display: "none"
770
+ },
771
+ children: [(r == null ? void 0 : r.variationId) && /* @__PURE__ */ i("span", {
772
+ className: "variation_id",
773
+ children: r.variationId
774
+ }), s && /* @__PURE__ */ i("span", {
775
+ className: "product_id",
776
+ children: s
777
+ }), (r == null ? void 0 : r.name) && /* @__PURE__ */ i("span", {
778
+ className: "name",
779
+ children: r.name
780
+ }), (r == null ? void 0 : r.url) && /* @__PURE__ */ i("span", {
781
+ className: "url",
782
+ children: r.url.toString()
783
+ }), (r == null ? void 0 : r.imageUrl) && /* @__PURE__ */ i("span", {
784
+ className: "image_url",
785
+ children: r.imageUrl.toString()
786
+ }), (r == null ? void 0 : r.availability) && /* @__PURE__ */ i("span", {
787
+ className: "availability",
788
+ children: r.availability
789
+ }), (r == null ? void 0 : r.price) && /* @__PURE__ */ i("span", {
790
+ className: "price",
791
+ children: r.price
792
+ }), (r == null ? void 0 : r.listPrice) && /* @__PURE__ */ i("span", {
793
+ className: "list_price",
794
+ children: r.listPrice
795
+ }), (r == null ? void 0 : r.priceCurrencyCode) && /* @__PURE__ */ i("span", {
796
+ className: "price_currency_code",
797
+ children: r.priceCurrencyCode
798
+ }), (r == null ? void 0 : r.brand) && /* @__PURE__ */ i("span", {
799
+ className: "brand",
800
+ children: r.brand
801
+ }), (r == null ? void 0 : r.description) && /* @__PURE__ */ i("span", {
802
+ className: "description",
803
+ children: r.description
804
+ }), (r == null ? void 0 : r.googleCategory) && /* @__PURE__ */ i("span", {
805
+ className: "description",
806
+ children: r.googleCategory
807
+ }), (r == null ? void 0 : r.condition) && /* @__PURE__ */ i("span", {
808
+ className: "condition",
809
+ children: r.condition
810
+ }), (r == null ? void 0 : r.gender) && /* @__PURE__ */ i("span", {
811
+ className: "gender",
812
+ children: r.gender
813
+ }), (r == null ? void 0 : r.ageGroup) && /* @__PURE__ */ i("span", {
814
+ className: "age_group",
815
+ children: r.ageGroup
816
+ }), (r == null ? void 0 : r.gtin) && /* @__PURE__ */ i("span", {
817
+ className: "gtin",
818
+ children: r.gtin
819
+ }), (r == null ? void 0 : r.category) && (r == null ? void 0 : r.category.map((n, R) => /* @__PURE__ */ i("span", {
820
+ className: "category",
821
+ children: n
822
+ }, R))), (r == null ? void 0 : r.tags1) && r.tags1.map((n, R) => /* @__PURE__ */ i("span", {
823
+ className: "tag1",
824
+ children: n
825
+ }, R)), (r == null ? void 0 : r.tags2) && r.tags2.map((n, R) => /* @__PURE__ */ i("span", {
826
+ className: "tag2",
827
+ children: n
828
+ }, R)), (r == null ? void 0 : r.tags3) && r.tags3.map((n, R) => /* @__PURE__ */ i("span", {
829
+ className: "tag3",
830
+ children: n
831
+ }, R)), (r == null ? void 0 : r.ratingValue) && /* @__PURE__ */ i("span", {
832
+ className: "rating_value",
833
+ children: r.ratingValue
834
+ }), (r == null ? void 0 : r.reviewCount) && /* @__PURE__ */ i("span", {
835
+ className: "review_count",
836
+ children: r.reviewCount
837
+ }), (r == null ? void 0 : r.alternateImageUrls) && r.alternateImageUrls.map((n, R) => /* @__PURE__ */ i("span", {
838
+ className: "alternate_image_url",
839
+ children: n.toString()
840
+ }, R)), (r == null ? void 0 : r.customFields) && Object.keys(r.customFields).map((n, R) => r.customFields && r.customFields[n] && /* @__PURE__ */ i("span", {
841
+ className: n,
842
+ children: r.customFields[n]
843
+ }, R)), (r == null ? void 0 : r.skus) && r.skus.map((n, R) => /* @__PURE__ */ q("span", {
844
+ className: "nosto_sku",
845
+ children: [(n == null ? void 0 : n.id) && /* @__PURE__ */ i("span", {
846
+ className: "product_id",
847
+ children: n.id
848
+ }), (n == null ? void 0 : n.name) && /* @__PURE__ */ i("span", {
849
+ className: "name",
850
+ children: n.name
851
+ }), (n == null ? void 0 : n.price) && /* @__PURE__ */ i("span", {
852
+ className: "price",
853
+ children: n.price
854
+ }), (n == null ? void 0 : n.listPrice) && /* @__PURE__ */ i("span", {
855
+ className: "list_price",
856
+ children: n.listPrice
857
+ }), (n == null ? void 0 : n.url) && /* @__PURE__ */ i("span", {
858
+ className: "url",
859
+ children: n.url.toString()
860
+ }), (n == null ? void 0 : n.imageUrl) && /* @__PURE__ */ i("span", {
861
+ className: "image_url",
862
+ children: n.imageUrl.toString()
863
+ }), (n == null ? void 0 : n.gtin) && /* @__PURE__ */ i("span", {
864
+ className: "gtin",
865
+ children: n.gtin
866
+ }), (n == null ? void 0 : n.availability) && /* @__PURE__ */ i("span", {
867
+ className: "availability",
868
+ children: n.availability
869
+ }), (n == null ? void 0 : n.customFields) && Object.keys(n.customFields).map((w, T) => n.customFields && n.customFields[w] && /* @__PURE__ */ i("span", {
870
+ className: w,
871
+ children: n.customFields[w]
872
+ }, T))]
873
+ }, R))]
874
+ })]
875
+ });
876
+ }
877
+ function Ur(o) {
878
+ const {
879
+ category: s,
880
+ placements: r
881
+ } = o, {
882
+ recommendationComponent: d,
883
+ useRenderCampaigns: m
884
+ } = x(), {
885
+ renderCampaigns: u,
886
+ pageTypeUpdated: l
887
+ } = m("home");
888
+ return U(async (y) => {
889
+ const n = await y.defaultSession().viewCategory(s).setPlacements(r || y.placements.getPlacements()).load();
890
+ u(n, y);
891
+ }, [s, d, l]), /* @__PURE__ */ q(I, {
892
+ children: [/* @__PURE__ */ i("div", {
893
+ className: "nosto_page_type",
894
+ style: {
895
+ display: "none"
896
+ },
897
+ children: "category"
898
+ }), /* @__PURE__ */ i("div", {
899
+ className: "nosto_category",
900
+ style: {
901
+ display: "none"
902
+ },
903
+ children: s
904
+ })]
905
+ });
906
+ }
907
+ function $r(o) {
908
+ const {
909
+ query: s,
910
+ placements: r
911
+ } = o, {
912
+ recommendationComponent: d,
913
+ useRenderCampaigns: m
914
+ } = x(), {
915
+ renderCampaigns: u,
916
+ pageTypeUpdated: l
917
+ } = m("search");
918
+ return U(async (y) => {
919
+ const n = await y.defaultSession().viewSearch(s).setPlacements(r || y.placements.getPlacements()).load();
920
+ u(n, y);
921
+ }, [s, d, l]), /* @__PURE__ */ q(I, {
922
+ children: [/* @__PURE__ */ i("div", {
923
+ className: "nosto_page_type",
924
+ style: {
925
+ display: "none"
926
+ },
927
+ children: "search"
928
+ }), /* @__PURE__ */ i("div", {
929
+ className: "nosto_search",
930
+ style: {
931
+ display: "none"
932
+ },
933
+ children: s
934
+ })]
935
+ });
936
+ }
937
+ function K(o) {
938
+ return !o || typeof o != "object" || Nr(o) || jr(o) ? o : Array.isArray(o) ? o.map(K) : Object.keys(o).reduce((s, r) => {
939
+ const d = r[0].toLowerCase() + r.slice(1).replace(/([A-Z]+)/g, (m, u) => "_" + u.toLowerCase());
940
+ return s[d] = K(o[r]), s;
941
+ }, {});
942
+ }
943
+ function Nr(o) {
944
+ return Object.prototype.toString.call(o) === "[object Date]";
945
+ }
946
+ function jr(o) {
947
+ return Object.prototype.toString.call(o) === "[object RegExp]";
948
+ }
949
+ function Vr(o) {
950
+ const {
951
+ order: s,
952
+ placements: r
953
+ } = o, {
954
+ recommendationComponent: d,
955
+ useRenderCampaigns: m
956
+ } = x(), {
957
+ renderCampaigns: u,
958
+ pageTypeUpdated: l
959
+ } = m("order");
960
+ return U(async (y) => {
961
+ const n = await y.defaultSession().addOrder(K(s)).setPlacements(r || y.placements.getPlacements()).load();
962
+ u(n, y);
963
+ }, [d, l]), /* @__PURE__ */ q(I, {
964
+ children: [/* @__PURE__ */ i("div", {
965
+ className: "nosto_page_type",
966
+ style: {
967
+ display: "none"
968
+ },
969
+ children: "order"
970
+ }), /* @__PURE__ */ i("div", {
971
+ className: "nosto_order",
972
+ style: {
973
+ display: "none"
974
+ },
975
+ children: s.purchase.number
976
+ })]
977
+ });
978
+ }
979
+ function Wr(o) {
980
+ const {
981
+ recommendationComponent: s,
982
+ useRenderCampaigns: r
983
+ } = x(), {
984
+ renderCampaigns: d,
985
+ pageTypeUpdated: m
986
+ } = r("home");
987
+ return U(async (u) => {
988
+ const l = await u.defaultSession().viewFrontPage().setPlacements(o.placements || u.placements.getPlacements()).load();
989
+ d(l, u);
990
+ }, [s, m]), /* @__PURE__ */ i(I, {
991
+ children: /* @__PURE__ */ i("div", {
992
+ className: "nosto_page_type",
993
+ style: {
994
+ display: "none"
995
+ },
996
+ children: "front"
997
+ })
998
+ });
999
+ }
1000
+ function Yr(o) {
1001
+ const {
1002
+ id: s,
1003
+ pageType: r
1004
+ } = o;
1005
+ return /* @__PURE__ */ i("div", {
1006
+ className: "nosto_element",
1007
+ id: s
1008
+ }, s + (r || ""));
1009
+ }
1010
+ function Mr(o) {
1011
+ const {
1012
+ account: s,
1013
+ multiCurrency: r = !1,
1014
+ host: d,
1015
+ children: m,
1016
+ recommendationComponent: u,
1017
+ shopifyMarkets: l
1018
+ } = o, [y, n] = z.useState(!1), R = z.useMemo(() => y, [y]), w = r ? o.currentVariation : "", T = wr(u) ? "JSON_ORIGINAL" : "HTML";
1019
+ function F(j) {
1020
+ return z.cloneElement(u, {
1021
+ // eslint-disable-next-line react/prop-types
1022
+ nostoRecommendation: j.nostoRecommendation
1023
+ });
1024
+ }
1025
+ const [L, X] = Sr("");
1026
+ function oe(j = "") {
1027
+ const P = ve({});
1028
+ ae(() => {
1029
+ L !== j && X(j);
1030
+ }, []);
1031
+ const b = j === L;
1032
+ function _(g, O) {
1033
+ if (T == "HTML")
1034
+ O.placements.injectCampaigns(g.recommendations);
1035
+ else {
1036
+ const $ = g.campaigns.recommendations;
1037
+ for (const V in $) {
1038
+ const se = $[V], Z = "#" + V, Q = () => document.querySelector(Z);
1039
+ Q() && (P.current[V] || (P.current[V] = Tr(Q())), P.current[V].render(/* @__PURE__ */ i(F, {
1040
+ nostoRecommendation: se
1041
+ })));
1042
+ }
1043
+ }
1044
+ }
1045
+ return {
1046
+ renderCampaigns: _,
1047
+ pageTypeUpdated: b
1048
+ };
1049
+ }
1050
+ return ae(() => {
1051
+ var j, P, b;
1052
+ if (window.nostojs || (window.nostojs = (_) => {
1053
+ (window.nostojs.q = window.nostojs.q || []).push(_);
1054
+ }, window.nostojs((_) => _.setAutoLoad(!1))), !document.querySelectorAll("[nosto-client-script]").length && !l) {
1055
+ const _ = document.createElement("script");
1056
+ _.type = "text/javascript", _.src = "//" + (d || "connect.nosto.com") + "/include/" + s, _.async = !0, _.setAttribute("nosto-client-script", ""), _.onload = () => {
1057
+ var g;
1058
+ typeof jest < "u" && ((g = window.nosto) == null || g.reload({
1059
+ site: "localhost"
1060
+ })), n(!0);
1061
+ }, document.body.appendChild(_);
1062
+ }
1063
+ if (l) {
1064
+ const _ = document.querySelector("[nosto-client-script]"), g = document.querySelector("#nosto-sandbox");
1065
+ if (!_ || (_ == null ? void 0 : _.getAttribute("nosto-language")) !== (l == null ? void 0 : l.language) || (_ == null ? void 0 : _.getAttribute("nosto-market-id")) !== (l == null ? void 0 : l.marketId)) {
1066
+ y && n(!1), (j = _ == null ? void 0 : _.parentNode) == null || j.removeChild(_), (P = g == null ? void 0 : g.parentNode) == null || P.removeChild(g);
1067
+ const O = document.createElement("script");
1068
+ O.type = "text/javascript", O.src = "//" + (d || "connect.nosto.com") + `/script/shopify/market/nosto.js?merchant=${s}&market=${l.marketId || ""}&locale=${((b = l == null ? void 0 : l.language) == null ? void 0 : b.toLowerCase()) || ""}`, O.async = !0, O.setAttribute("nosto-client-script", ""), O.setAttribute("nosto-language", (l == null ? void 0 : l.language) || ""), O.setAttribute("nosto-market-id", String(l == null ? void 0 : l.marketId)), O.onload = () => {
1069
+ var $;
1070
+ typeof jest < "u" && (($ = window.nosto) == null || $.reload({
1071
+ site: "localhost"
1072
+ })), n(!0);
1073
+ }, document.body.appendChild(O);
1074
+ }
1075
+ }
1076
+ }, [y, l]), /* @__PURE__ */ i(Je.Provider, {
1077
+ value: {
1078
+ account: s,
1079
+ clientScriptLoaded: R,
1080
+ currentVariation: w,
1081
+ responseMode: T,
1082
+ recommendationComponent: u,
1083
+ useRenderCampaigns: oe,
1084
+ pageType: L
1085
+ },
1086
+ children: m
1087
+ });
1088
+ }
1089
+ function qr(o) {
1090
+ const {
1091
+ cart: s,
1092
+ customer: r
1093
+ } = o, {
1094
+ clientScriptLoaded: d
1095
+ } = x();
1096
+ return ze(() => {
1097
+ const m = s ? K(s) : void 0, u = r ? K(r) : void 0;
1098
+ d && window.nostojs((l) => {
1099
+ l.defaultSession().setResponseMode("HTML").setCart(m).setCustomer(u).viewOther().load();
1100
+ });
1101
+ }, [d, s, r]), /* @__PURE__ */ i(I, {});
1102
+ }
1103
+ export {
1104
+ Ar as Nosto404,
1105
+ Ur as NostoCategory,
1106
+ Ir as NostoCheckout,
1107
+ Je as NostoContext,
1108
+ Wr as NostoHome,
1109
+ Vr as NostoOrder,
1110
+ Dr as NostoOther,
1111
+ Yr as NostoPlacement,
1112
+ Lr as NostoProduct,
1113
+ Mr as NostoProvider,
1114
+ $r as NostoSearch,
1115
+ qr as NostoSession,
1116
+ x as useNostoContext
1117
+ };