@instockng/storefront-ui 1.0.56 → 1.0.58
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/components/ProductAddOns.d.ts +1 -2
- package/dist/components/ProductAddOns.d.ts.map +1 -1
- package/dist/components/ProductCard.d.ts +1 -1
- package/dist/components/ProductCard.d.ts.map +1 -1
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.mjs +104 -100
- package/dist/index10.mjs +147 -91
- package/dist/index100.mjs +43 -2
- package/dist/index101.mjs +2 -28
- package/dist/index102.mjs +2 -18
- package/dist/index103.mjs +26 -213
- package/dist/index104.mjs +13 -175
- package/dist/index105.mjs +210 -17
- package/dist/index106.mjs +174 -17
- package/dist/index107.mjs +14 -25
- package/dist/index108.mjs +17 -150
- package/dist/index109.mjs +26 -13
- package/dist/index11.mjs +95 -171
- package/dist/index110.mjs +149 -24
- package/dist/index111.mjs +13 -77
- package/dist/index112.mjs +20 -27
- package/dist/index113.mjs +76 -137
- package/dist/index114.mjs +33 -50
- package/dist/index115.mjs +141 -19
- package/dist/index116.mjs +50 -22
- package/dist/index117.mjs +14 -14
- package/dist/index118.mjs +20 -18
- package/dist/index119.mjs +16 -14
- package/dist/index12.mjs +90 -90
- package/dist/index120.mjs +17 -14
- package/dist/index121.mjs +12 -12
- package/dist/index122.mjs +15 -58
- package/dist/index123.mjs +14 -11
- package/dist/index124.mjs +56 -30
- package/dist/index125.mjs +9 -15
- package/dist/index126.mjs +31 -26
- package/dist/index127.mjs +13 -16
- package/dist/index128.mjs +26 -11
- package/dist/index129.mjs +17 -11
- package/dist/index13.mjs +162 -717
- package/dist/index130.mjs +12 -40
- package/dist/index131.mjs +14 -16
- package/dist/index132.mjs +42 -263
- package/dist/index133.mjs +15 -62
- package/dist/index134.mjs +267 -7
- package/dist/index135.mjs +70 -2
- package/dist/index136.mjs +8 -2
- package/dist/index137.mjs +2 -33
- package/dist/index138.mjs +2 -2
- package/dist/index139.mjs +32 -20
- package/dist/index14.mjs +94 -56
- package/dist/index140.mjs +2 -56
- package/dist/index141.mjs +18 -26
- package/dist/index142.mjs +55 -6
- package/dist/index143.mjs +28 -51
- package/dist/index144.mjs +7 -6
- package/dist/index145.mjs +51 -11
- package/dist/index146.mjs +5 -6
- package/dist/index147.mjs +12 -28
- package/dist/index148.mjs +7 -2
- package/dist/index149.mjs +27 -69
- package/dist/index15.mjs +734 -62
- package/dist/index150.mjs +2 -167
- package/dist/index151.mjs +70 -2
- package/dist/index152.mjs +167 -2
- package/dist/index153.mjs +2 -2
- package/dist/index154.mjs +2 -18
- package/dist/index155.mjs +2 -32
- package/dist/index156.mjs +14 -34
- package/dist/index157.mjs +25 -11
- package/dist/index158.mjs +34 -14
- package/dist/index159.mjs +18 -2
- package/dist/index16.mjs +50 -14
- package/dist/index160.mjs +11 -13
- package/dist/index161.mjs +2 -46
- package/dist/index162.mjs +20 -2
- package/dist/index163.mjs +41 -25
- package/dist/index164.mjs +2 -18
- package/dist/index165.mjs +30 -2
- package/dist/index166.mjs +18 -2
- package/dist/index167.mjs +2 -2
- package/dist/index168.mjs +2 -2
- package/dist/index169.mjs +2 -72
- package/dist/index17.mjs +62 -109
- package/dist/index170.mjs +2 -2
- package/dist/index171.mjs +59 -40
- package/dist/index173.mjs +48 -31
- package/dist/index174.mjs +2 -152
- package/dist/index175.mjs +36 -2
- package/dist/index176.mjs +152 -2
- package/dist/index177.mjs +2 -19
- package/dist/index178.mjs +2 -2
- package/dist/index179.mjs +19 -2
- package/dist/index18.mjs +23 -41
- package/dist/index180.mjs +2 -26
- package/dist/index181.mjs +2 -2
- package/dist/index182.mjs +26 -2
- package/dist/index183.mjs +2 -24
- package/dist/index184.mjs +2 -23
- package/dist/index185.mjs +24 -2
- package/dist/index186.mjs +23 -2
- package/dist/index187.mjs +2 -2
- package/dist/index188.mjs +2 -23
- package/dist/index19.mjs +109 -42
- package/dist/index190.mjs +16 -16
- package/dist/index191.mjs +2 -2
- package/dist/index192.mjs +23 -2
- package/dist/index193.mjs +2 -2
- package/dist/index194.mjs +2 -23
- package/dist/index195.mjs +2 -2
- package/dist/index196.mjs +15 -15
- package/dist/index198.mjs +23 -2
- package/dist/index199.mjs +2 -2
- package/dist/index2.mjs +2 -2
- package/dist/index20.mjs +42 -67
- package/dist/index200.mjs +2 -2
- package/dist/index201.mjs +2 -2
- package/dist/index203.mjs +2 -2
- package/dist/index205.mjs +2 -127
- package/dist/index206.mjs +2 -2
- package/dist/index207.mjs +123 -70
- package/dist/index208.mjs +2 -74
- package/dist/index209.mjs +74 -2
- package/dist/index21.mjs +41 -31
- package/dist/index210.mjs +73 -30
- package/dist/index211.mjs +2 -11
- package/dist/index212.mjs +30 -3
- package/dist/index213.mjs +10 -3
- package/dist/index214.mjs +4 -13
- package/dist/index215.mjs +4 -7
- package/dist/index216.mjs +13 -12
- package/dist/index217.mjs +7 -5
- package/dist/index218.mjs +12 -33
- package/dist/index219.mjs +5 -31
- package/dist/index22.mjs +64 -6
- package/dist/index220.mjs +32 -27
- package/dist/index221.mjs +28 -58
- package/dist/index222.mjs +28 -2
- package/dist/index223.mjs +55 -102
- package/dist/index224.mjs +2 -2
- package/dist/index225.mjs +2 -2
- package/dist/index226.mjs +2 -2
- package/dist/index227.mjs +2 -2
- package/dist/index228.mjs +2 -2
- package/dist/index229.mjs +2 -2
- package/dist/index23.mjs +27 -17
- package/dist/index231.mjs +2 -2
- package/dist/index232.mjs +108 -2
- package/dist/index233.mjs +2 -37
- package/dist/index235.mjs +1 -1
- package/dist/index237.mjs +3 -3
- package/dist/index238.mjs +1 -1
- package/dist/index239.mjs +2 -2
- package/dist/index24.mjs +6 -32
- package/dist/index240.mjs +2 -2
- package/dist/index241.mjs +37 -2
- package/dist/index242.mjs +2 -2
- package/dist/index243.mjs +2 -2
- package/dist/index245.mjs +2 -2
- package/dist/index248.mjs +2 -2
- package/dist/index249.mjs +2 -2
- package/dist/index25.mjs +19 -27
- package/dist/index250.mjs +2 -4
- package/dist/index253.mjs +2 -3
- package/dist/index254.mjs +4 -2
- package/dist/index255.mjs +2 -2
- package/dist/index256.mjs +2 -17
- package/dist/index257.mjs +2 -13
- package/dist/index258.mjs +2 -6
- package/dist/index259.mjs +2 -30
- package/dist/index26.mjs +34 -103
- package/dist/index260.mjs +91 -2
- package/dist/index261.mjs +2 -2
- package/dist/index262.mjs +18 -2
- package/dist/index263.mjs +47 -2
- package/dist/index264.mjs +17 -2
- package/dist/index265.mjs +12 -90
- package/dist/index266.mjs +6 -2
- package/dist/index267.mjs +29 -17
- package/dist/index268.mjs +3 -47
- package/dist/index269.mjs +2 -2
- package/dist/index27.mjs +20 -21
- package/dist/index270.mjs +2 -2
- package/dist/index271.mjs +2 -2
- package/dist/index273.mjs +5 -0
- package/dist/index274.mjs +5 -0
- package/dist/index28.mjs +101 -8
- package/dist/index29.mjs +27 -7
- package/dist/index3.mjs +5 -5
- package/dist/index30.mjs +11 -105
- package/dist/index31.mjs +11 -23
- package/dist/index32.mjs +105 -68
- package/dist/index33.mjs +23 -105
- package/dist/index34.mjs +68 -28
- package/dist/index35.mjs +99 -21
- package/dist/index36.mjs +26 -9
- package/dist/index37.mjs +25 -9
- package/dist/index38.mjs +10 -122
- package/dist/index39.mjs +9 -387
- package/dist/index4.mjs +1 -1
- package/dist/index40.mjs +116 -18
- package/dist/index41.mjs +385 -99
- package/dist/index42.mjs +24 -6
- package/dist/index43.mjs +30 -1431
- package/dist/index44.mjs +6 -69
- package/dist/index45.mjs +1433 -2
- package/dist/index46.mjs +68 -58
- package/dist/index47.mjs +2 -51
- package/dist/index48.mjs +60 -33
- package/dist/index49.mjs +49 -13
- package/dist/index5.mjs +1 -1
- package/dist/index50.mjs +32 -2262
- package/dist/index51.mjs +15 -36
- package/dist/index52.mjs +2261 -42
- package/dist/index53.mjs +36 -99
- package/dist/index54.mjs +43 -112
- package/dist/index55.mjs +99 -81
- package/dist/index56.mjs +82 -76
- package/dist/index57.mjs +54 -68
- package/dist/index58.mjs +82 -56
- package/dist/index59.mjs +74 -58
- package/dist/index6.mjs +1 -1
- package/dist/index60.mjs +77 -15
- package/dist/index61.mjs +74 -15
- package/dist/index62.mjs +15 -59
- package/dist/index63.mjs +14 -119
- package/dist/index64.mjs +46 -112
- package/dist/index65.mjs +124 -23
- package/dist/index66.mjs +129 -2
- package/dist/index67.mjs +23 -4
- package/dist/index68.mjs +2 -23
- package/dist/index69.mjs +4 -152
- package/dist/index7.mjs +6 -6
- package/dist/index70.mjs +149 -71
- package/dist/index71.mjs +23 -15
- package/dist/index72.mjs +68 -56
- package/dist/index73.mjs +15 -2
- package/dist/index74.mjs +62 -5
- package/dist/index75.mjs +2 -1134
- package/dist/index76.mjs +5 -19
- package/dist/index77.mjs +1119 -40
- package/dist/index78.mjs +14 -27
- package/dist/index79.mjs +55 -2
- package/dist/index8.mjs +34 -34
- package/dist/index80.mjs +29 -231
- package/dist/index81.mjs +2 -6
- package/dist/index82.mjs +228 -127
- package/dist/index83.mjs +4 -66
- package/dist/index84.mjs +124 -77
- package/dist/index85.mjs +65 -26
- package/dist/index86.mjs +84 -6
- package/dist/index87.mjs +26 -72
- package/dist/index88.mjs +8 -3
- package/dist/index89.mjs +75 -2
- package/dist/index9.mjs +17 -17
- package/dist/index90.mjs +3 -82
- package/dist/index91.mjs +2 -54
- package/dist/index92.mjs +82 -5
- package/dist/index93.mjs +53 -4
- package/dist/index94.mjs +5 -178
- package/dist/index95.mjs +5 -53
- package/dist/index96.mjs +178 -68
- package/dist/index97.mjs +50 -31
- package/dist/index98.mjs +69 -43
- package/dist/index99.mjs +34 -2
- package/package.json +1 -1
- package/src/components/OrderConfirmation.stories.tsx +2 -2
- package/src/components/ProductAddOns.stories.tsx +6 -6
- package/src/components/ProductAddOns.tsx +3 -4
- package/src/components/ProductCard.stories.tsx +2 -2
- package/src/components/ProductCard.tsx +3 -3
- package/src/components/ProductGrid.tsx +1 -1
- package/src/index.ts +6 -0
package/dist/index97.mjs
CHANGED
|
@@ -1,37 +1,56 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
throw new Error("__Host- Cookie must not have Domain attributes");
|
|
2
|
+
import s from "./index82.mjs";
|
|
3
|
+
import m from "./index150.mjs";
|
|
4
|
+
import u from "./index151.mjs";
|
|
5
|
+
import { getFetch as b } from "./index152.mjs";
|
|
6
|
+
import d from "./index93.mjs";
|
|
7
|
+
const p = {
|
|
8
|
+
http: m,
|
|
9
|
+
xhr: u,
|
|
10
|
+
fetch: {
|
|
11
|
+
get: b
|
|
13
12
|
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
);
|
|
19
|
-
|
|
13
|
+
};
|
|
14
|
+
s.forEach(p, (e, o) => {
|
|
15
|
+
if (e) {
|
|
16
|
+
try {
|
|
17
|
+
Object.defineProperty(e, "name", { value: o });
|
|
18
|
+
} catch {
|
|
19
|
+
}
|
|
20
|
+
Object.defineProperty(e, "adapterName", { value: o });
|
|
20
21
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
});
|
|
23
|
+
const f = (e) => `- ${e}`, g = (e) => s.isFunction(e) || e === null || e === !1, y = {
|
|
24
|
+
getAdapter: (e, o) => {
|
|
25
|
+
e = s.isArray(e) ? e : [e];
|
|
26
|
+
const { length: a } = e;
|
|
27
|
+
let i, t;
|
|
28
|
+
const c = {};
|
|
29
|
+
for (let r = 0; r < a; r++) {
|
|
30
|
+
i = e[r];
|
|
31
|
+
let n;
|
|
32
|
+
if (t = i, !g(i) && (t = p[(n = String(i)).toLowerCase()], t === void 0))
|
|
33
|
+
throw new d(`Unknown adapter '${n}'`);
|
|
34
|
+
if (t && (s.isFunction(t) || (t = t.get(o))))
|
|
35
|
+
break;
|
|
36
|
+
c[n || "#" + r] = t;
|
|
37
|
+
}
|
|
38
|
+
if (!t) {
|
|
39
|
+
const r = Object.entries(c).map(
|
|
40
|
+
([l, h]) => `adapter ${l} ` + (h === !1 ? "is not supported by the environment" : "is not available in the build")
|
|
25
41
|
);
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
42
|
+
let n = a ? r.length > 1 ? `since :
|
|
43
|
+
` + r.map(f).join(`
|
|
44
|
+
`) : " " + f(r[0]) : "as no adapter specified";
|
|
45
|
+
throw new d(
|
|
46
|
+
"There is no suitable adapter to dispatch the request " + n,
|
|
47
|
+
"ERR_NOT_SUPPORT"
|
|
48
|
+
);
|
|
49
|
+
}
|
|
50
|
+
return t;
|
|
51
|
+
},
|
|
52
|
+
adapters: p
|
|
53
|
+
};
|
|
35
54
|
export {
|
|
36
|
-
|
|
55
|
+
y as default
|
|
37
56
|
};
|
package/dist/index98.mjs
CHANGED
|
@@ -1,46 +1,72 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
2
|
+
const e = {
|
|
3
|
+
Continue: 100,
|
|
4
|
+
SwitchingProtocols: 101,
|
|
5
|
+
Processing: 102,
|
|
6
|
+
EarlyHints: 103,
|
|
7
|
+
Ok: 200,
|
|
8
|
+
Created: 201,
|
|
9
|
+
Accepted: 202,
|
|
10
|
+
NonAuthoritativeInformation: 203,
|
|
11
|
+
NoContent: 204,
|
|
12
|
+
ResetContent: 205,
|
|
13
|
+
PartialContent: 206,
|
|
14
|
+
MultiStatus: 207,
|
|
15
|
+
AlreadyReported: 208,
|
|
16
|
+
ImUsed: 226,
|
|
17
|
+
MultipleChoices: 300,
|
|
18
|
+
MovedPermanently: 301,
|
|
19
|
+
Found: 302,
|
|
20
|
+
SeeOther: 303,
|
|
21
|
+
NotModified: 304,
|
|
22
|
+
UseProxy: 305,
|
|
23
|
+
Unused: 306,
|
|
24
|
+
TemporaryRedirect: 307,
|
|
25
|
+
PermanentRedirect: 308,
|
|
26
|
+
BadRequest: 400,
|
|
27
|
+
Unauthorized: 401,
|
|
28
|
+
PaymentRequired: 402,
|
|
29
|
+
Forbidden: 403,
|
|
30
|
+
NotFound: 404,
|
|
31
|
+
MethodNotAllowed: 405,
|
|
32
|
+
NotAcceptable: 406,
|
|
33
|
+
ProxyAuthenticationRequired: 407,
|
|
34
|
+
RequestTimeout: 408,
|
|
35
|
+
Conflict: 409,
|
|
36
|
+
Gone: 410,
|
|
37
|
+
LengthRequired: 411,
|
|
38
|
+
PreconditionFailed: 412,
|
|
39
|
+
PayloadTooLarge: 413,
|
|
40
|
+
UriTooLong: 414,
|
|
41
|
+
UnsupportedMediaType: 415,
|
|
42
|
+
RangeNotSatisfiable: 416,
|
|
43
|
+
ExpectationFailed: 417,
|
|
44
|
+
ImATeapot: 418,
|
|
45
|
+
MisdirectedRequest: 421,
|
|
46
|
+
UnprocessableEntity: 422,
|
|
47
|
+
Locked: 423,
|
|
48
|
+
FailedDependency: 424,
|
|
49
|
+
TooEarly: 425,
|
|
50
|
+
UpgradeRequired: 426,
|
|
51
|
+
PreconditionRequired: 428,
|
|
52
|
+
TooManyRequests: 429,
|
|
53
|
+
RequestHeaderFieldsTooLarge: 431,
|
|
54
|
+
UnavailableForLegalReasons: 451,
|
|
55
|
+
InternalServerError: 500,
|
|
56
|
+
NotImplemented: 501,
|
|
57
|
+
BadGateway: 502,
|
|
58
|
+
ServiceUnavailable: 503,
|
|
59
|
+
GatewayTimeout: 504,
|
|
60
|
+
HttpVersionNotSupported: 505,
|
|
61
|
+
VariantAlsoNegotiates: 506,
|
|
62
|
+
InsufficientStorage: 507,
|
|
63
|
+
LoopDetected: 508,
|
|
64
|
+
NotExtended: 510,
|
|
65
|
+
NetworkAuthenticationRequired: 511
|
|
66
|
+
};
|
|
67
|
+
Object.entries(e).forEach(([t, o]) => {
|
|
68
|
+
e[o] = t;
|
|
69
|
+
});
|
|
39
70
|
export {
|
|
40
|
-
|
|
41
|
-
o as deepMerge,
|
|
42
|
-
s as mergePath,
|
|
43
|
-
l as removeIndexString,
|
|
44
|
-
p as replaceUrlParam,
|
|
45
|
-
i as replaceUrlProtocol
|
|
71
|
+
e as default
|
|
46
72
|
};
|
package/dist/index99.mjs
CHANGED
|
@@ -1,5 +1,37 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
var
|
|
2
|
+
var a = (i, t, e = {}) => {
|
|
3
|
+
let r = `${i}=${t}`;
|
|
4
|
+
if (i.startsWith("__Secure-") && !e.secure)
|
|
5
|
+
throw new Error("__Secure- Cookie must have Secure attributes");
|
|
6
|
+
if (i.startsWith("__Host-")) {
|
|
7
|
+
if (!e.secure)
|
|
8
|
+
throw new Error("__Host- Cookie must have Secure attributes");
|
|
9
|
+
if (e.path !== "/")
|
|
10
|
+
throw new Error('__Host- Cookie must have Path attributes with "/"');
|
|
11
|
+
if (e.domain)
|
|
12
|
+
throw new Error("__Host- Cookie must not have Domain attributes");
|
|
13
|
+
}
|
|
14
|
+
if (e && typeof e.maxAge == "number" && e.maxAge >= 0) {
|
|
15
|
+
if (e.maxAge > 3456e4)
|
|
16
|
+
throw new Error(
|
|
17
|
+
"Cookies Max-Age SHOULD NOT be greater than 400 days (34560000 seconds) in duration."
|
|
18
|
+
);
|
|
19
|
+
r += `; Max-Age=${e.maxAge | 0}`;
|
|
20
|
+
}
|
|
21
|
+
if (e.domain && e.prefix !== "host" && (r += `; Domain=${e.domain}`), e.path && (r += `; Path=${e.path}`), e.expires) {
|
|
22
|
+
if (e.expires.getTime() - Date.now() > 3456e7)
|
|
23
|
+
throw new Error(
|
|
24
|
+
"Cookies Expires SHOULD NOT be greater than 400 days (34560000 seconds) in the future."
|
|
25
|
+
);
|
|
26
|
+
r += `; Expires=${e.expires.toUTCString()}`;
|
|
27
|
+
}
|
|
28
|
+
if (e.httpOnly && (r += "; HttpOnly"), e.secure && (r += "; Secure"), e.sameSite && (r += `; SameSite=${e.sameSite.charAt(0).toUpperCase() + e.sameSite.slice(1)}`), e.priority && (r += `; Priority=${e.priority.charAt(0).toUpperCase() + e.priority.slice(1)}`), e.partitioned) {
|
|
29
|
+
if (!e.secure)
|
|
30
|
+
throw new Error("Partitioned Cookie must have Secure attributes");
|
|
31
|
+
r += "; Partitioned";
|
|
32
|
+
}
|
|
33
|
+
return r;
|
|
34
|
+
}, s = (i, t, e) => (t = encodeURIComponent(t), a(i, t, e));
|
|
3
35
|
export {
|
|
4
|
-
|
|
36
|
+
s as serialize
|
|
5
37
|
};
|
package/package.json
CHANGED
|
@@ -29,7 +29,7 @@ const mockOrderResponse = {
|
|
|
29
29
|
sku: 'TSHIRT-MD-BLUE',
|
|
30
30
|
product: {
|
|
31
31
|
name: 'Premium Cotton T-Shirt',
|
|
32
|
-
|
|
32
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1521572163474-6864f9cf17ab?w=400',
|
|
33
33
|
},
|
|
34
34
|
},
|
|
35
35
|
quantity: 2,
|
|
@@ -43,7 +43,7 @@ const mockOrderResponse = {
|
|
|
43
43
|
sku: 'JEANS-LG-BLACK',
|
|
44
44
|
product: {
|
|
45
45
|
name: 'Slim Fit Jeans',
|
|
46
|
-
|
|
46
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1542272604-787c3835535d?w=400',
|
|
47
47
|
},
|
|
48
48
|
},
|
|
49
49
|
quantity: 1,
|
|
@@ -18,7 +18,7 @@ const mockProducts: AddOnProduct[] = [
|
|
|
18
18
|
id: '1',
|
|
19
19
|
slug: 'travel-case',
|
|
20
20
|
name: 'Travel Case',
|
|
21
|
-
|
|
21
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1544816155-12df9643f363?w=400',
|
|
22
22
|
variants: [{ id: 'v1', price: 15.00, sku: 'CASE-01', name: 'Standard' }],
|
|
23
23
|
addonDescription: 'Keep your products safe while traveling.',
|
|
24
24
|
compareAtPrice: 25.00,
|
|
@@ -28,7 +28,7 @@ const mockProducts: AddOnProduct[] = [
|
|
|
28
28
|
id: '2',
|
|
29
29
|
slug: 'expansion-kit',
|
|
30
30
|
name: 'Expansion Kit',
|
|
31
|
-
|
|
31
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1581091226825-a6a2a5aee158?w=400',
|
|
32
32
|
variants: [{ id: 'v2', price: 49.99, sku: 'KIT-01', name: 'Full' }],
|
|
33
33
|
addonDescription: 'Adds 5 more slots to your base unit.',
|
|
34
34
|
compareAtPrice: 65.00,
|
|
@@ -38,7 +38,7 @@ const mockProducts: AddOnProduct[] = [
|
|
|
38
38
|
id: '3',
|
|
39
39
|
slug: 'cleaning-solution',
|
|
40
40
|
name: 'Cleaning Solution',
|
|
41
|
-
|
|
41
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1584622650111-993a426fbf0a?w=400',
|
|
42
42
|
variants: [{ id: 'v3', price: 9.99, sku: 'CLEAN-01', name: '100ml' }],
|
|
43
43
|
addonDescription: 'Eco-friendly formula for deep cleaning.',
|
|
44
44
|
brand: { name: 'Pure' }
|
|
@@ -47,7 +47,7 @@ const mockProducts: AddOnProduct[] = [
|
|
|
47
47
|
id: '4',
|
|
48
48
|
slug: 'extra-batteries',
|
|
49
49
|
name: 'Extra Batteries',
|
|
50
|
-
|
|
50
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1619648366548-05f476906233?w=400',
|
|
51
51
|
variants: [{ id: 'v4', price: 12.00, sku: 'BATT-01', name: '2-Pack' }],
|
|
52
52
|
brand: { name: 'PowerUp' }
|
|
53
53
|
},
|
|
@@ -55,7 +55,7 @@ const mockProducts: AddOnProduct[] = [
|
|
|
55
55
|
id: '5',
|
|
56
56
|
slug: 'replacement-straps',
|
|
57
57
|
name: 'Replacement Straps',
|
|
58
|
-
|
|
58
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1523275335684-37898b6baf30?w=400',
|
|
59
59
|
variants: [{ id: 'v5', price: 19.99, sku: 'STRAP-01', name: 'Leather' }],
|
|
60
60
|
addonDescription: 'Genuine leather replacement straps.',
|
|
61
61
|
compareAtPrice: 29.99,
|
|
@@ -65,7 +65,7 @@ const mockProducts: AddOnProduct[] = [
|
|
|
65
65
|
id: '6',
|
|
66
66
|
slug: 'protective-film',
|
|
67
67
|
name: 'Protective Film',
|
|
68
|
-
|
|
68
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1586210579191-33b45e38fa2c?w=400',
|
|
69
69
|
variants: [{ id: 'v6', price: 5.50, sku: 'FILM-01', name: 'Clear' }],
|
|
70
70
|
brand: { name: 'Shield' }
|
|
71
71
|
}
|
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
|
|
3
3
|
import { useState, useRef } from 'react';
|
|
4
4
|
import { ChevronLeft, ChevronRight } from 'lucide-react';
|
|
5
|
-
import { Button } from './ui/button';
|
|
6
5
|
import { Switch } from './ui/switch';
|
|
7
6
|
import { Badge } from './ui/badge';
|
|
8
7
|
import { cn, formatCurrency } from '../lib/utils';
|
|
@@ -17,7 +16,7 @@ export interface AddOnProduct extends ProductCardProduct {
|
|
|
17
16
|
addonDescription?: string | null;
|
|
18
17
|
}
|
|
19
18
|
|
|
20
|
-
interface ProductAddOnsProps {
|
|
19
|
+
export interface ProductAddOnsProps {
|
|
21
20
|
/** Product slug to fetch add-ons for */
|
|
22
21
|
slug?: string;
|
|
23
22
|
/** Manual product list (overrides slug fetching) */
|
|
@@ -146,9 +145,9 @@ export function ProductAddOns({
|
|
|
146
145
|
>
|
|
147
146
|
{/* Image Container */}
|
|
148
147
|
<div className="h-20 w-20 flex-shrink-0 overflow-hidden rounded-xl bg-white/40 flex items-center justify-center">
|
|
149
|
-
{product.
|
|
148
|
+
{product.thumbnailUrl ? (
|
|
150
149
|
<img
|
|
151
|
-
src={product.
|
|
150
|
+
src={product.thumbnailUrl}
|
|
152
151
|
alt={product.name}
|
|
153
152
|
className="h-full w-full object-cover"
|
|
154
153
|
/>
|
|
@@ -18,7 +18,7 @@ const mockProduct: ProductCardProduct = {
|
|
|
18
18
|
id: '1',
|
|
19
19
|
name: 'Premium Cotton T-Shirt',
|
|
20
20
|
description: 'Comfortable and stylish cotton t-shirt perfect for everyday wear',
|
|
21
|
-
|
|
21
|
+
thumbnailUrl: 'https://images.unsplash.com/photo-1521572163474-6864f9cf17ab?w=400',
|
|
22
22
|
brand: {
|
|
23
23
|
name: 'Fashion Brand',
|
|
24
24
|
logoUrl: 'https://via.placeholder.com/100x50',
|
|
@@ -99,7 +99,7 @@ export const NoImage: Story = {
|
|
|
99
99
|
args: {
|
|
100
100
|
product: {
|
|
101
101
|
...mockProduct,
|
|
102
|
-
|
|
102
|
+
thumbnailUrl: undefined,
|
|
103
103
|
},
|
|
104
104
|
},
|
|
105
105
|
};
|
|
@@ -19,7 +19,7 @@ export interface ProductCardProduct {
|
|
|
19
19
|
id: string;
|
|
20
20
|
name: string;
|
|
21
21
|
description?: string;
|
|
22
|
-
|
|
22
|
+
thumbnailUrl?: string;
|
|
23
23
|
brand?: {
|
|
24
24
|
name: string;
|
|
25
25
|
logoUrl?: string;
|
|
@@ -92,9 +92,9 @@ export function ProductCard({
|
|
|
92
92
|
>
|
|
93
93
|
{/* Product Image */}
|
|
94
94
|
<div className="relative aspect-square overflow-hidden bg-gray-100">
|
|
95
|
-
{product.
|
|
95
|
+
{product.thumbnailUrl ? (
|
|
96
96
|
<img
|
|
97
|
-
src={product.
|
|
97
|
+
src={product.thumbnailUrl}
|
|
98
98
|
alt={product.name}
|
|
99
99
|
className={cn(
|
|
100
100
|
'h-full w-full object-cover transition-transform group-hover:scale-105',
|
|
@@ -110,7 +110,7 @@ export function ProductGrid({
|
|
|
110
110
|
id: product.id,
|
|
111
111
|
name: product.name,
|
|
112
112
|
description: product.description || undefined,
|
|
113
|
-
|
|
113
|
+
thumbnailUrl: product.thumbnailUrl || undefined,
|
|
114
114
|
brand: undefined, // Brand info not included in product response
|
|
115
115
|
variants: product.variants.map((v: any) => ({
|
|
116
116
|
id: v.id,
|
package/src/index.ts
CHANGED
|
@@ -31,6 +31,12 @@ export type { ProductCardProps, ProductCardProduct } from './components/ProductC
|
|
|
31
31
|
export { ProductGrid } from './components/ProductGrid';
|
|
32
32
|
export type { ProductGridProps } from './components/ProductGrid';
|
|
33
33
|
|
|
34
|
+
export { ProductAddOns } from './components/ProductAddOns';
|
|
35
|
+
export type { ProductAddOnsProps, AddOnProduct } from './components/ProductAddOns';
|
|
36
|
+
|
|
37
|
+
export { RecommendedProducts } from './components/RecommendedProducts';
|
|
38
|
+
export type { RecommendedProductsProps } from './components/RecommendedProducts';
|
|
39
|
+
|
|
34
40
|
export { CartItem } from './components/CartItem';
|
|
35
41
|
export type { CartItemProps } from './components/CartItem';
|
|
36
42
|
|