@nextblock-cms/ecom 0.8.1 → 0.8.6
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/AddToCartButton-DsSEH9yp.cjs +1 -0
- package/AddToCartButton-ffE0DhHu.js +59 -0
- package/CouponForm-BI_5SBHQ.js +152 -0
- package/CouponForm-D_uu2bLP.cjs +1 -0
- package/CurrencyProvider-Cg-Q6ucj.cjs +1 -0
- package/CurrencyProvider-OzlRN96V.js +120 -0
- package/CurrencyProvider.cjs.js +1 -0
- package/CurrencyProvider.es.js +10 -0
- package/ProductDetailsLayout-BxJH_BxR.cjs +1 -0
- package/ProductDetailsLayout-Dg8dRTYp.js +530 -0
- package/ProductGrid-BdL7iglO.cjs +1 -0
- package/ProductGrid-D3AWM8sr.js +130 -0
- package/actions-AHmBrS5e.cjs +48 -0
- package/actions-j5fuSZX-.js +820 -0
- package/cart-store.cjs.js +1 -0
- package/cart-store.es.js +116 -0
- package/components/Cart.cjs.js +1 -0
- package/components/Cart.es.js +259 -0
- package/components/CartDrawer.cjs.js +1 -0
- package/components/CartDrawer.es.js +118 -0
- package/components/CartIcon.cjs.js +1 -0
- package/components/CartIcon.es.js +33 -0
- package/components/Checkout.cjs.js +1 -0
- package/components/Checkout.es.js +1020 -0
- package/components/CurrencySwitcher.cjs.js +1 -0
- package/components/CurrencySwitcher.es.js +17 -0
- package/components/FeaturedProduct.cjs.js +1 -0
- package/components/FeaturedProduct.es.js +71 -0
- package/components/ProductDetailsLayout.cjs.js +1 -0
- package/components/ProductDetailsLayout.es.js +19 -0
- package/components/ProductGrid.cjs.js +1 -0
- package/components/ProductGrid.es.js +6 -0
- package/components/SimpleTiptapRenderer.cjs.js +1 -0
- package/components/SimpleTiptapRenderer.es.js +187 -0
- package/coupon-server-C9ySm3I5.cjs +1 -0
- package/coupon-server-DUKVtyYs.js +248 -0
- package/currency-constants.cjs.js +1 -0
- package/currency-constants.es.js +4 -0
- package/currency.cjs.js +1 -0
- package/currency.es.js +312 -0
- package/customer-C-UPvrYN.cjs +1 -0
- package/customer-C3xccjUg.js +57 -0
- package/index.cjs.js +1 -1
- package/index.es.js +414 -3105
- package/invoice-ui-CAnJPu6n.cjs +29 -0
- package/invoice-ui-DtpbTJE1.js +2886 -0
- package/package.json +10 -5
- package/product-actions-CONBF8i6.cjs +251 -0
- package/product-actions-DjlIWCMH.js +691 -0
- package/resolver-Fz_FKsfX.cjs +7 -0
- package/resolver-cfrCaHpE.js +128 -0
- package/server-actions/product-actions.cjs.js +1 -0
- package/server-actions/product-actions.es.js +15 -0
- package/server.cjs.js +27 -27
- package/server.es.js +478 -463
- package/shipping-actions-BnHjlo2q.js +25 -0
- package/shipping-actions-D6zt20gg.cjs +1 -0
- package/states-CWYRxV4B.cjs +1 -0
- package/states-DlHJezQ1.js +200 -0
- package/tax-calculation-Dab89aHd.js +181 -0
- package/tax-calculation-MkDKOEkL.cjs +1 -0
- package/trials-DvZaOtNy.cjs +1 -0
- package/trials-RDcRAZKx.js +29 -0
- package/types.cjs.js +1 -0
- package/types.es.js +33 -0
- package/use-cart.cjs.js +1 -0
- package/use-cart.es.js +43 -0
- package/variation-utils.cjs.js +1 -0
- package/variation-utils.es.js +246 -0
- package/invoice-ui-BJZfedDd.cjs +0 -332
- package/invoice-ui-GJ1ADAjn.js +0 -5759
|
@@ -0,0 +1,530 @@
|
|
|
1
|
+
import { jsx as t, jsxs as n } from "react/jsx-runtime";
|
|
2
|
+
import le, { useState as T, useEffect as j, createContext as oe, useContext as ce, useMemo as $ } from "react";
|
|
3
|
+
import { ShoppingCart as de, Download as me, Package as ue, ShieldCheck as pe } from "lucide-react";
|
|
4
|
+
import { Badge as M } from "@nextblock-cms/ui/badge";
|
|
5
|
+
import { Button as H } from "@nextblock-cms/ui/button";
|
|
6
|
+
import { Label as fe } from "@nextblock-cms/ui/label";
|
|
7
|
+
import { Separator as ge } from "@nextblock-cms/ui/separator";
|
|
8
|
+
import { cn as q, useTranslations as Q, majorUnitAmountToMinor as E, formatPrice as D } from "@nextblock-cms/utils";
|
|
9
|
+
import { A as he } from "./AddToCartButton-ffE0DhHu.js";
|
|
10
|
+
import { Skeleton as G } from "@nextblock-cms/ui/Skeleton";
|
|
11
|
+
import { useCart as xe } from "./use-cart.es.js";
|
|
12
|
+
import { toast as K } from "sonner";
|
|
13
|
+
import { g as _e } from "./actions-j5fuSZX-.js";
|
|
14
|
+
import { u as Y } from "./CurrencyProvider-OzlRN96V.js";
|
|
15
|
+
import { convertMinorUnitAmount as U, resolveEffectivePriceForCurrency as X } from "./currency.es.js";
|
|
16
|
+
import { d as Z } from "./trials-RDcRAZKx.js";
|
|
17
|
+
import { SimpleTiptapRenderer as ve } from "./components/SimpleTiptapRenderer.es.js";
|
|
18
|
+
import { chooseInitialVariantSelections as W, normalizeSelectionsToAvailableVariants as z, findMatchingVariant as be, resolveTranslatedText as ye, getAvailableTermIdsForAttribute as Ne } from "./variation-utils.es.js";
|
|
19
|
+
import { isDigitalProduct as we } from "./types.es.js";
|
|
20
|
+
const Ce = ({ images: r = [], className: u }) => {
|
|
21
|
+
const [e, c] = T(0);
|
|
22
|
+
return j(() => {
|
|
23
|
+
c(0);
|
|
24
|
+
}, [r]), r.length ? /* @__PURE__ */ n("div", { className: q("flex flex-col gap-4", u), children: [
|
|
25
|
+
/* @__PURE__ */ t("div", { className: "relative aspect-square w-full overflow-hidden rounded-lg border bg-white", children: /* @__PURE__ */ t(
|
|
26
|
+
"img",
|
|
27
|
+
{
|
|
28
|
+
src: r[e].url,
|
|
29
|
+
alt: r[e].alt,
|
|
30
|
+
className: "h-full w-full object-cover object-center"
|
|
31
|
+
}
|
|
32
|
+
) }),
|
|
33
|
+
r.length > 1 && /* @__PURE__ */ t("div", { className: "flex gap-4 overflow-x-auto pb-2", children: r.map((f, o) => /* @__PURE__ */ t(
|
|
34
|
+
"button",
|
|
35
|
+
{
|
|
36
|
+
onClick: () => c(o),
|
|
37
|
+
className: q(
|
|
38
|
+
"relative aspect-square w-20 flex-shrink-0 overflow-hidden rounded-md border",
|
|
39
|
+
e === o ? "ring-2 ring-primary" : "ring-1 ring-transparent hover:ring-primary/50"
|
|
40
|
+
),
|
|
41
|
+
children: /* @__PURE__ */ t(
|
|
42
|
+
"img",
|
|
43
|
+
{
|
|
44
|
+
src: f.url,
|
|
45
|
+
alt: f.alt,
|
|
46
|
+
className: "h-full w-full object-cover object-center"
|
|
47
|
+
}
|
|
48
|
+
)
|
|
49
|
+
},
|
|
50
|
+
o
|
|
51
|
+
)) })
|
|
52
|
+
] }) : /* @__PURE__ */ t("div", { className: q("relative aspect-square w-full overflow-hidden rounded-lg bg-secondary", u), children: /* @__PURE__ */ t("div", { className: "flex h-full items-center justify-center text-muted-foreground", children: "No Image" }) });
|
|
53
|
+
}, ke = ({ product: r }) => {
|
|
54
|
+
const u = xe((d) => d), { t: e } = Q(), { activeCurrencyCode: c, currencies: f, defaultCurrency: o } = Y(), [I, x] = T([]), [S, L] = T(!0), [l, _] = T("annual");
|
|
55
|
+
if (j(() => {
|
|
56
|
+
async function d() {
|
|
57
|
+
try {
|
|
58
|
+
if (!r.id) return;
|
|
59
|
+
const a = await _e(r.id);
|
|
60
|
+
x(a);
|
|
61
|
+
} catch (a) {
|
|
62
|
+
console.error("Failed to load pricing:", a);
|
|
63
|
+
} finally {
|
|
64
|
+
L(!1);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
d();
|
|
68
|
+
}, [r.id]), !u)
|
|
69
|
+
return /* @__PURE__ */ t(G, { className: "h-14 w-full" });
|
|
70
|
+
const { addItem: y } = u, N = I[0], i = N?.pricing?.[0], v = () => {
|
|
71
|
+
let d = r.price, a = r.freemius_plan_id;
|
|
72
|
+
i && (l === "monthly" && i.monthly_price != null && (d = E(i.monthly_price, o.code)), l === "annual" && i.annual_price != null && (d = E(i.annual_price, o.code)), l === "lifetime" && i.lifetime_price != null && (d = E(i.lifetime_price, o.code)));
|
|
73
|
+
const A = f.reduce((m, O) => (m[O.code] = U({
|
|
74
|
+
amount: d,
|
|
75
|
+
fromCurrencyCode: o.code,
|
|
76
|
+
toCurrencyCode: O.code,
|
|
77
|
+
currencies: f,
|
|
78
|
+
applyRounding: !0
|
|
79
|
+
}), m), {}), V = A[c] ?? d;
|
|
80
|
+
N && N.id && (a = N.id);
|
|
81
|
+
const { success: k, error: P } = y({
|
|
82
|
+
id: r.id,
|
|
83
|
+
product_id: r.id,
|
|
84
|
+
title: r.title,
|
|
85
|
+
price: V,
|
|
86
|
+
prices: A,
|
|
87
|
+
image_url: r.image_url,
|
|
88
|
+
slug: r.slug,
|
|
89
|
+
sku: r.sku,
|
|
90
|
+
language_id: r.language_id,
|
|
91
|
+
translation_group_id: r.translation_group_id,
|
|
92
|
+
product_type: "digital",
|
|
93
|
+
payment_provider: "freemius",
|
|
94
|
+
provider: "freemius",
|
|
95
|
+
billing_cycle: l,
|
|
96
|
+
freemius_product_id: r.freemius_product_id,
|
|
97
|
+
freemius_plan_id: a,
|
|
98
|
+
// Overwrite if we got a real plan id
|
|
99
|
+
trial_period_days: r.trial_period_days ?? 0,
|
|
100
|
+
trial_requires_payment_method: r.trial_requires_payment_method ?? !1,
|
|
101
|
+
is_taxable: r.is_taxable,
|
|
102
|
+
currency_code: c
|
|
103
|
+
});
|
|
104
|
+
k ? K.success(e("ecommerce.added_to_cart_success", { item: r.title })) : K.error(P || e("ecommerce.added_to_cart_error"));
|
|
105
|
+
};
|
|
106
|
+
if (S)
|
|
107
|
+
return /* @__PURE__ */ t(G, { className: "h-32 w-full" });
|
|
108
|
+
if (!N || !i)
|
|
109
|
+
return /* @__PURE__ */ t("div", { className: "p-4 border border-dashed rounded-lg text-center text-muted-foreground", children: e("ecommerce.pricing_unavailable") });
|
|
110
|
+
const g = i.monthly_price != null, w = i.annual_price != null, R = i.lifetime_price != null;
|
|
111
|
+
l === "annual" && !w && (g ? _("monthly") : R && _("lifetime"));
|
|
112
|
+
const h = Z(r);
|
|
113
|
+
let C = r.price;
|
|
114
|
+
return l === "monthly" && i.monthly_price != null && (C = U({
|
|
115
|
+
amount: E(i.monthly_price, o.code),
|
|
116
|
+
fromCurrencyCode: o.code,
|
|
117
|
+
toCurrencyCode: c,
|
|
118
|
+
currencies: f,
|
|
119
|
+
applyRounding: !0
|
|
120
|
+
})), l === "annual" && i.annual_price != null && (C = U({
|
|
121
|
+
amount: E(i.annual_price, o.code),
|
|
122
|
+
fromCurrencyCode: o.code,
|
|
123
|
+
toCurrencyCode: c,
|
|
124
|
+
currencies: f,
|
|
125
|
+
applyRounding: !0
|
|
126
|
+
})), l === "lifetime" && i.lifetime_price != null && (C = U({
|
|
127
|
+
amount: E(i.lifetime_price, o.code),
|
|
128
|
+
fromCurrencyCode: o.code,
|
|
129
|
+
toCurrencyCode: c,
|
|
130
|
+
currencies: f,
|
|
131
|
+
applyRounding: !0
|
|
132
|
+
})), /* @__PURE__ */ n("div", { className: "flex flex-col gap-4", children: [
|
|
133
|
+
/* @__PURE__ */ n("div", { className: "flex bg-secondary/35 p-1 rounded-lg w-full max-w-sm mx-auto shadow-inner", children: [
|
|
134
|
+
g && /* @__PURE__ */ t(
|
|
135
|
+
"button",
|
|
136
|
+
{
|
|
137
|
+
onClick: () => _("monthly"),
|
|
138
|
+
className: `flex-1 py-1.5 text-xs font-semibold rounded-md transition-all ${l === "monthly" ? "bg-background shadow-sm text-foreground" : "text-muted-foreground hover:text-foreground"}`,
|
|
139
|
+
children: e("ecommerce.monthly")
|
|
140
|
+
}
|
|
141
|
+
),
|
|
142
|
+
w && /* @__PURE__ */ t(
|
|
143
|
+
"button",
|
|
144
|
+
{
|
|
145
|
+
onClick: () => _("annual"),
|
|
146
|
+
className: `flex-1 py-1.5 text-xs font-semibold rounded-md transition-all ${l === "annual" ? "bg-background shadow-sm text-foreground" : "text-muted-foreground hover:text-foreground"}`,
|
|
147
|
+
children: e("ecommerce.annual")
|
|
148
|
+
}
|
|
149
|
+
),
|
|
150
|
+
R && /* @__PURE__ */ t(
|
|
151
|
+
"button",
|
|
152
|
+
{
|
|
153
|
+
onClick: () => _("lifetime"),
|
|
154
|
+
className: `flex-1 py-1.5 text-xs font-semibold rounded-md transition-all ${l === "lifetime" ? "bg-background shadow-sm text-foreground" : "text-muted-foreground hover:text-foreground"}`,
|
|
155
|
+
children: e("ecommerce.lifetime")
|
|
156
|
+
}
|
|
157
|
+
)
|
|
158
|
+
] }),
|
|
159
|
+
/* @__PURE__ */ n("div", { className: "text-center", children: [
|
|
160
|
+
/* @__PURE__ */ t("span", { className: "text-3xl font-extrabold text-foreground", children: D(C, c) }),
|
|
161
|
+
l !== "lifetime" && /* @__PURE__ */ n("span", { className: "text-muted-foreground text-sm ml-1.5", children: [
|
|
162
|
+
"/ ",
|
|
163
|
+
e(l === "annual" ? "ecommerce.year" : "ecommerce.month")
|
|
164
|
+
] }),
|
|
165
|
+
h && /* @__PURE__ */ n("div", { className: "mt-1 text-xs font-medium text-emerald-600 dark:text-emerald-400", children: [
|
|
166
|
+
h.label,
|
|
167
|
+
/* @__PURE__ */ t("span", { className: "mx-2 text-muted-foreground/50", children: "|" }),
|
|
168
|
+
/* @__PURE__ */ t("span", { className: "text-muted-foreground", children: h.paymentRequirementLabel })
|
|
169
|
+
] })
|
|
170
|
+
] }),
|
|
171
|
+
/* @__PURE__ */ n(H, { onClick: v, className: "w-full h-12 text-md font-bold shadow-md transition-all hover:shadow-lg active:scale-[0.98]", children: [
|
|
172
|
+
/* @__PURE__ */ t(de, { className: "mr-2 h-4 w-4" }),
|
|
173
|
+
h?.label ? `Start ${h.label}` : e("ecommerce.get_license")
|
|
174
|
+
] })
|
|
175
|
+
] });
|
|
176
|
+
}, ee = oe(void 0), Ke = ({
|
|
177
|
+
product: r,
|
|
178
|
+
children: u
|
|
179
|
+
}) => /* @__PURE__ */ t(ee.Provider, { value: { product: r }, children: u }), Pe = () => {
|
|
180
|
+
const r = ce(ee);
|
|
181
|
+
if (!r)
|
|
182
|
+
throw new Error("useProduct must be used within a ProductProvider. Ensure the component is wrapped in a ProductProvider.");
|
|
183
|
+
return r.product;
|
|
184
|
+
};
|
|
185
|
+
function B(r, u, e, c) {
|
|
186
|
+
const f = {
|
|
187
|
+
kind: "product-field",
|
|
188
|
+
field: u,
|
|
189
|
+
input: e,
|
|
190
|
+
label: c
|
|
191
|
+
}, o = typeof window < "u" ? window.location.origin : process.env.NEXT_PUBLIC_URL || process.env.TARGET_URL || (process.env.VERCEL_URL ? `https://${process.env.VERCEL_URL}` : "") || "http://localhost:3000";
|
|
192
|
+
let x = (typeof window < "u" ? window.location.origin : process.env.NEXT_PUBLIC_URL || process.env.TARGET_URL || (process.env.VERCEL_URL ? `https://${process.env.VERCEL_URL}` : "") || "http://localhost:3000").replace(/\/+$/, "");
|
|
193
|
+
try {
|
|
194
|
+
(x.startsWith("http://") || x.startsWith("https://")) && (x = new URL(x).hostname);
|
|
195
|
+
} catch {
|
|
196
|
+
}
|
|
197
|
+
const S = process.env.NEXTBLOCK_VERCEL_PROJECT_ID || process.env.VERCEL_PROJECT_ID, L = process.env.NEXTBLOCK_VERCEL_WORKSPACE_ID || process.env.VERCEL_ORG_ID, l = {
|
|
198
|
+
origin: x,
|
|
199
|
+
editUrl: `${o}/cms/products/${r.id}/edit`,
|
|
200
|
+
data: {
|
|
201
|
+
parentType: "product",
|
|
202
|
+
parentId: r.id,
|
|
203
|
+
slug: r.slug,
|
|
204
|
+
languageId: r.language_id,
|
|
205
|
+
draftId: null,
|
|
206
|
+
target: f
|
|
207
|
+
}
|
|
208
|
+
};
|
|
209
|
+
return S && (l.projectId = S), L && (l.workspaceId = L), {
|
|
210
|
+
"data-vercel-edit-info": JSON.stringify(l),
|
|
211
|
+
"data-vercel-edit-target": JSON.stringify(f),
|
|
212
|
+
"data-nextblock-visual-edit": `product:${u}`
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
const Xe = ({
|
|
216
|
+
visualEditingEnabled: r = !1,
|
|
217
|
+
descriptionNode: u
|
|
218
|
+
}) => {
|
|
219
|
+
const e = Pe(), { t: c, lang: f } = Q(), { activeCurrencyCode: o, currencies: I } = Y(), x = r ? B(
|
|
220
|
+
e,
|
|
221
|
+
"title",
|
|
222
|
+
"plain-text",
|
|
223
|
+
"Product title"
|
|
224
|
+
) : void 0, S = r ? B(
|
|
225
|
+
e,
|
|
226
|
+
"short_description",
|
|
227
|
+
"plain-text",
|
|
228
|
+
"Short description"
|
|
229
|
+
) : void 0, L = r ? B(
|
|
230
|
+
e,
|
|
231
|
+
"description_json",
|
|
232
|
+
"tiptap",
|
|
233
|
+
"Product description"
|
|
234
|
+
) : void 0, l = (s, b, p) => {
|
|
235
|
+
const J = c(s, p);
|
|
236
|
+
return J === s ? b : J;
|
|
237
|
+
}, _ = e.images && e.images.length > 0 ? e.images : e.image_url ? [{ url: e.image_url, alt: e.title }] : [], y = e.custom_props?.provider === "freemius" || we(e), N = Z(e), i = !y && !!(e.has_variants && e.attributes?.length && e.variants?.length), v = e.attributes || [], g = e.variants || [], [w, R] = T(() => W(v, g)), [h, C] = T(1);
|
|
238
|
+
j(() => {
|
|
239
|
+
C(1);
|
|
240
|
+
}, [e.id]), j(() => {
|
|
241
|
+
i && R(W(v, g));
|
|
242
|
+
}, [v, i, e.id, g]);
|
|
243
|
+
const d = $(() => i ? z(
|
|
244
|
+
v,
|
|
245
|
+
g,
|
|
246
|
+
w
|
|
247
|
+
) : w, [v, i, w, g]);
|
|
248
|
+
j(() => {
|
|
249
|
+
JSON.stringify(d) !== JSON.stringify(w) && R(d);
|
|
250
|
+
}, [d, w]);
|
|
251
|
+
const a = $(() => i ? be(g, d) : null, [i, d, g]), A = X({
|
|
252
|
+
prices: e.prices,
|
|
253
|
+
salePrices: e.sale_prices,
|
|
254
|
+
fallbackPrice: e.price,
|
|
255
|
+
fallbackSalePrice: e.sale_price,
|
|
256
|
+
saleStartAt: e.sale_start_at,
|
|
257
|
+
saleEndAt: e.sale_end_at,
|
|
258
|
+
scheduledPrice: e.scheduled_price,
|
|
259
|
+
scheduledPrices: e.scheduled_prices,
|
|
260
|
+
scheduledPriceAt: e.scheduled_price_at,
|
|
261
|
+
currencyCode: o,
|
|
262
|
+
currencies: I
|
|
263
|
+
}), V = i && a ? X({
|
|
264
|
+
prices: a.prices,
|
|
265
|
+
salePrices: a.sale_prices,
|
|
266
|
+
fallbackPrice: a.price,
|
|
267
|
+
fallbackSalePrice: a.sale_price,
|
|
268
|
+
saleStartAt: a.sale_start_at,
|
|
269
|
+
saleEndAt: a.sale_end_at,
|
|
270
|
+
scheduledPrice: a.scheduled_price,
|
|
271
|
+
scheduledPrices: a.scheduled_prices,
|
|
272
|
+
scheduledPriceAt: a.scheduled_price_at,
|
|
273
|
+
currencyCode: o,
|
|
274
|
+
currencies: I
|
|
275
|
+
}) : null, k = V?.price ?? A.price, P = V?.sale_price ?? A.sale_price, m = i ? a?.stock_quantity ?? 0 : e.stock ?? 0, O = $(() => {
|
|
276
|
+
if (!a?.image_url)
|
|
277
|
+
return _;
|
|
278
|
+
const s = {
|
|
279
|
+
url: a.image_url,
|
|
280
|
+
alt: `${e.title} ${a.label}`
|
|
281
|
+
}, b = _.filter(
|
|
282
|
+
(p) => p.url !== a.image_url
|
|
283
|
+
);
|
|
284
|
+
return [s, ...b];
|
|
285
|
+
}, [_, e.title, a]), te = typeof P == "number" && k > 0 ? Math.round(
|
|
286
|
+
(k - P) / k * 100
|
|
287
|
+
) : 0, re = i && a ? {
|
|
288
|
+
...e,
|
|
289
|
+
sku: a.sku,
|
|
290
|
+
price: a.price,
|
|
291
|
+
prices: a.prices,
|
|
292
|
+
sale_price: typeof a.sale_price == "number" ? a.sale_price : null,
|
|
293
|
+
sale_prices: a.sale_prices,
|
|
294
|
+
image_url: a.image_url || e.image_url,
|
|
295
|
+
stock: a.stock_quantity,
|
|
296
|
+
variant_id: a.id,
|
|
297
|
+
variant_label: a.label,
|
|
298
|
+
selected_options: a.selected_options,
|
|
299
|
+
currency_code: o
|
|
300
|
+
} : {
|
|
301
|
+
...e,
|
|
302
|
+
currency_code: o
|
|
303
|
+
}, ae = (s, b) => {
|
|
304
|
+
R(
|
|
305
|
+
(p) => z(v, g, {
|
|
306
|
+
...p,
|
|
307
|
+
[s]: b
|
|
308
|
+
})
|
|
309
|
+
);
|
|
310
|
+
}, ie = l(
|
|
311
|
+
"ecommerce.in_stock",
|
|
312
|
+
`${m} in stock`,
|
|
313
|
+
{ count: String(m) }
|
|
314
|
+
), F = l(
|
|
315
|
+
"ecommerce.out_of_stock",
|
|
316
|
+
"Out of stock"
|
|
317
|
+
), ne = l(
|
|
318
|
+
"ecommerce.select_options",
|
|
319
|
+
"Select Options"
|
|
320
|
+
), se = l(
|
|
321
|
+
"ecommerce.variant_selection_required",
|
|
322
|
+
"Select one term from every dropdown to resolve a variation."
|
|
323
|
+
);
|
|
324
|
+
return /* @__PURE__ */ n("div", { className: "w-full animate-in fade-in slide-in-from-bottom-4 duration-700 ease-out", children: [
|
|
325
|
+
/* @__PURE__ */ t("div", { className: "container mx-auto px-4 md:px-6 py-12", children: /* @__PURE__ */ n("div", { className: "grid gap-12 lg:grid-cols-[2fr_3fr] items-start", children: [
|
|
326
|
+
/* @__PURE__ */ t("div", { className: "w-full max-w-2xl mx-auto lg:max-w-none", children: /* @__PURE__ */ t(Ce, { images: O, className: "w-full" }) }),
|
|
327
|
+
/* @__PURE__ */ n("div", { className: "flex flex-col gap-4 pb-2 max-w-xl mx-auto lg:mx-0 lg:max-w-none", children: [
|
|
328
|
+
/* @__PURE__ */ t("div", { className: "space-y-6", children: /* @__PURE__ */ n("div", { className: "space-y-4", children: [
|
|
329
|
+
/* @__PURE__ */ t(
|
|
330
|
+
"h1",
|
|
331
|
+
{
|
|
332
|
+
className: "text-3xl sm:text-4xl lg:text-5xl font-extrabold tracking-tight text-foreground leading-[1.1] lg:mt-0",
|
|
333
|
+
...x,
|
|
334
|
+
children: e.title
|
|
335
|
+
}
|
|
336
|
+
),
|
|
337
|
+
e.categories && e.categories.length > 0 && /* @__PURE__ */ t("div", { className: "flex flex-wrap items-center gap-1.5 text-xs font-bold uppercase tracking-widest text-amber-600 dark:text-amber-400", children: e.categories.map((s, b) => {
|
|
338
|
+
const p = ye(
|
|
339
|
+
s.name,
|
|
340
|
+
s.name_translations,
|
|
341
|
+
f
|
|
342
|
+
);
|
|
343
|
+
return /* @__PURE__ */ n(le.Fragment, { children: [
|
|
344
|
+
b > 0 && /* @__PURE__ */ t("span", { className: "text-muted-foreground/30", children: "•" }),
|
|
345
|
+
/* @__PURE__ */ t("span", { children: p })
|
|
346
|
+
] }, s.id);
|
|
347
|
+
}) }),
|
|
348
|
+
/* @__PURE__ */ t(
|
|
349
|
+
"div",
|
|
350
|
+
{
|
|
351
|
+
className: "prose prose-neutral dark:prose-invert max-w-none text-muted-foreground leading-relaxed text-left",
|
|
352
|
+
...S,
|
|
353
|
+
children: e.short_description ? /* @__PURE__ */ t(
|
|
354
|
+
"div",
|
|
355
|
+
{
|
|
356
|
+
className: "text-lg mb-4 leading-relaxed",
|
|
357
|
+
dangerouslySetInnerHTML: {
|
|
358
|
+
__html: e.short_description
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
) : r ? /* @__PURE__ */ t("p", { className: "text-lg mb-4 italic text-muted-foreground", children: "Add a short product description." }) : null
|
|
362
|
+
}
|
|
363
|
+
),
|
|
364
|
+
/* @__PURE__ */ n("div", { className: "flex items-center gap-3", children: [
|
|
365
|
+
typeof P == "number" && /* @__PURE__ */ t(
|
|
366
|
+
M,
|
|
367
|
+
{
|
|
368
|
+
variant: "destructive",
|
|
369
|
+
className: "px-2.5 py-1 text-xs font-bold uppercase tracking-wide animate-pulse shadow-sm",
|
|
370
|
+
children: c("ecommerce.sale_badge", {
|
|
371
|
+
percent: String(te)
|
|
372
|
+
})
|
|
373
|
+
}
|
|
374
|
+
),
|
|
375
|
+
!y && m > 0 && m < 10 && /* @__PURE__ */ t(
|
|
376
|
+
M,
|
|
377
|
+
{
|
|
378
|
+
variant: "outline",
|
|
379
|
+
className: "text-amber-600 border-amber-200 bg-amber-50",
|
|
380
|
+
children: c("ecommerce.low_stock", {
|
|
381
|
+
count: String(m)
|
|
382
|
+
})
|
|
383
|
+
}
|
|
384
|
+
),
|
|
385
|
+
N && /* @__PURE__ */ t(
|
|
386
|
+
M,
|
|
387
|
+
{
|
|
388
|
+
variant: "secondary",
|
|
389
|
+
className: "border border-emerald-200 bg-emerald-50 text-emerald-800",
|
|
390
|
+
children: N.label
|
|
391
|
+
}
|
|
392
|
+
)
|
|
393
|
+
] })
|
|
394
|
+
] }) }),
|
|
395
|
+
/* @__PURE__ */ n("div", { className: "p-5 rounded-2xl bg-card/60 border border-border/80 shadow-md backdrop-blur-md space-y-4", children: [
|
|
396
|
+
y ? /* @__PURE__ */ t(ke, { product: e }) : /* @__PURE__ */ n("div", { className: "space-y-3.5", children: [
|
|
397
|
+
/* @__PURE__ */ n("div", { className: "flex items-center justify-between gap-4", children: [
|
|
398
|
+
/* @__PURE__ */ n("div", { className: "space-y-1", children: [
|
|
399
|
+
/* @__PURE__ */ t("span", { className: "text-[10px] font-bold text-muted-foreground uppercase tracking-widest", children: l("ecommerce.price", "Price") }),
|
|
400
|
+
/* @__PURE__ */ n("div", { className: "flex items-baseline gap-2.5", children: [
|
|
401
|
+
/* @__PURE__ */ t("span", { className: "text-3xl font-extrabold text-foreground", children: D(
|
|
402
|
+
P ?? k,
|
|
403
|
+
o
|
|
404
|
+
) }),
|
|
405
|
+
typeof P == "number" && /* @__PURE__ */ t("span", { className: "text-lg text-muted-foreground line-through decoration-destructive/20 decoration-1", children: D(k, o) })
|
|
406
|
+
] })
|
|
407
|
+
] }),
|
|
408
|
+
!y && (a || !i) && /* @__PURE__ */ n("div", { className: "text-right space-y-1", children: [
|
|
409
|
+
/* @__PURE__ */ n("span", { className: "text-[10px] font-bold text-muted-foreground uppercase tracking-widest block", children: [
|
|
410
|
+
!i && e.sku && /* @__PURE__ */ n("span", { className: "mr-2 font-normal lowercase normal-case text-muted-foreground/70", children: [
|
|
411
|
+
"SKU: ",
|
|
412
|
+
e.sku
|
|
413
|
+
] }),
|
|
414
|
+
l("ecommerce.status", "Status")
|
|
415
|
+
] }),
|
|
416
|
+
/* @__PURE__ */ t("div", { className: (m ?? 0) > 0 ? "text-emerald-600 dark:text-emerald-400 font-semibold text-sm" : "text-destructive font-semibold text-sm", children: (m ?? 0) > 0 ? ie : F })
|
|
417
|
+
] })
|
|
418
|
+
] }),
|
|
419
|
+
i && /* @__PURE__ */ t("div", { className: "space-y-3", children: /* @__PURE__ */ t("div", { className: "grid gap-3 sm:grid-cols-2", children: v.map((s) => {
|
|
420
|
+
const b = Ne(
|
|
421
|
+
g,
|
|
422
|
+
s.id,
|
|
423
|
+
d
|
|
424
|
+
);
|
|
425
|
+
return /* @__PURE__ */ n("div", { className: "space-y-1", children: [
|
|
426
|
+
/* @__PURE__ */ n("div", { className: "flex items-center justify-between", children: [
|
|
427
|
+
/* @__PURE__ */ t(
|
|
428
|
+
fe,
|
|
429
|
+
{
|
|
430
|
+
htmlFor: `attribute-${s.id}`,
|
|
431
|
+
className: "text-[11px] font-semibold text-muted-foreground uppercase tracking-wider",
|
|
432
|
+
children: s.name
|
|
433
|
+
}
|
|
434
|
+
),
|
|
435
|
+
a?.sku && /* @__PURE__ */ t("span", { className: "text-[10px] text-muted-foreground font-mono", children: a.sku })
|
|
436
|
+
] }),
|
|
437
|
+
/* @__PURE__ */ t(
|
|
438
|
+
"select",
|
|
439
|
+
{
|
|
440
|
+
id: `attribute-${s.id}`,
|
|
441
|
+
className: "flex h-9 w-full rounded-md border border-input bg-background px-3 py-1 text-sm focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring",
|
|
442
|
+
value: d[s.id] || "",
|
|
443
|
+
onChange: (p) => ae(
|
|
444
|
+
s.id,
|
|
445
|
+
p.target.value
|
|
446
|
+
),
|
|
447
|
+
children: s.terms.map((p) => /* @__PURE__ */ t(
|
|
448
|
+
"option",
|
|
449
|
+
{
|
|
450
|
+
value: p.id,
|
|
451
|
+
disabled: !b.has(p.id),
|
|
452
|
+
children: p.value
|
|
453
|
+
},
|
|
454
|
+
p.id
|
|
455
|
+
))
|
|
456
|
+
}
|
|
457
|
+
)
|
|
458
|
+
] }, s.id);
|
|
459
|
+
}) }) }),
|
|
460
|
+
i && !a && /* @__PURE__ */ t("p", { className: "text-xs text-muted-foreground italic pt-1", children: se }),
|
|
461
|
+
/* @__PURE__ */ n("div", { className: "flex items-center gap-3 pt-1", children: [
|
|
462
|
+
!y && (m ?? 0) > 0 && /* @__PURE__ */ n("div", { className: "flex items-center border rounded-lg h-12 bg-background border-input select-none", children: [
|
|
463
|
+
/* @__PURE__ */ t(
|
|
464
|
+
"button",
|
|
465
|
+
{
|
|
466
|
+
type: "button",
|
|
467
|
+
onClick: () => C((s) => Math.max(1, s - 1)),
|
|
468
|
+
className: "px-3 h-full flex items-center justify-center text-muted-foreground hover:text-foreground active:scale-95 transition-all text-lg font-medium",
|
|
469
|
+
disabled: h <= 1,
|
|
470
|
+
children: "-"
|
|
471
|
+
}
|
|
472
|
+
),
|
|
473
|
+
/* @__PURE__ */ t("span", { className: "w-8 text-center text-sm font-semibold", children: h }),
|
|
474
|
+
/* @__PURE__ */ t(
|
|
475
|
+
"button",
|
|
476
|
+
{
|
|
477
|
+
type: "button",
|
|
478
|
+
onClick: () => C(
|
|
479
|
+
(s) => m !== null && s >= m ? s : s + 1
|
|
480
|
+
),
|
|
481
|
+
className: "px-3 h-full flex items-center justify-center text-muted-foreground hover:text-foreground active:scale-95 transition-all text-lg font-medium",
|
|
482
|
+
disabled: m !== null && h >= m,
|
|
483
|
+
children: "+"
|
|
484
|
+
}
|
|
485
|
+
)
|
|
486
|
+
] }),
|
|
487
|
+
i && (!a || (m ?? 0) <= 0) ? /* @__PURE__ */ t(
|
|
488
|
+
H,
|
|
489
|
+
{
|
|
490
|
+
disabled: !0,
|
|
491
|
+
className: "flex-1 h-12 text-md font-bold shadow-md",
|
|
492
|
+
children: a ? F : ne
|
|
493
|
+
}
|
|
494
|
+
) : /* @__PURE__ */ t(
|
|
495
|
+
he,
|
|
496
|
+
{
|
|
497
|
+
product: re,
|
|
498
|
+
quantity: h,
|
|
499
|
+
className: "flex-1 h-12 text-md font-bold shadow-md transition-all hover:shadow-lg active:scale-[0.98]"
|
|
500
|
+
}
|
|
501
|
+
)
|
|
502
|
+
] })
|
|
503
|
+
] }),
|
|
504
|
+
/* @__PURE__ */ t(ge, { className: "opacity-60 my-0.5" }),
|
|
505
|
+
/* @__PURE__ */ n("div", { className: "grid grid-cols-2 gap-4 text-center text-[11px] font-medium text-muted-foreground pt-1", children: [
|
|
506
|
+
/* @__PURE__ */ t("div", { className: "flex items-center justify-center gap-2", children: y ? /* @__PURE__ */ n("span", { className: "inline-flex items-center gap-1.5", children: [
|
|
507
|
+
/* @__PURE__ */ t(me, { className: "h-3.5 w-3.5" }),
|
|
508
|
+
c("ecommerce.instant_digital_delivery")
|
|
509
|
+
] }) : /* @__PURE__ */ n("span", { className: "inline-flex items-center gap-1.5", children: [
|
|
510
|
+
/* @__PURE__ */ t(ue, { className: "h-3.5 w-3.5" }),
|
|
511
|
+
c("ecommerce.free_shipping")
|
|
512
|
+
] }) }),
|
|
513
|
+
/* @__PURE__ */ t("div", { className: "flex items-center justify-center gap-2", children: /* @__PURE__ */ n("span", { className: "inline-flex items-center gap-1.5", children: [
|
|
514
|
+
/* @__PURE__ */ t(pe, { className: "h-3.5 w-3.5" }),
|
|
515
|
+
c("ecommerce.secure_checkout")
|
|
516
|
+
] }) })
|
|
517
|
+
] })
|
|
518
|
+
] })
|
|
519
|
+
] })
|
|
520
|
+
] }) }),
|
|
521
|
+
/* @__PURE__ */ t("div", { className: "min-w-0 w-full", ...u ? void 0 : L, children: u || (e.description_json ? /* @__PURE__ */ t("div", { className: "container mx-auto px-4 md:px-6 pb-12 prose prose-neutral dark:prose-invert max-w-none leading-relaxed", children: /* @__PURE__ */ t(ve, { content: e.description_json }) }) : /* @__PURE__ */ t("div", { className: "container mx-auto px-4 md:px-6 pb-12", children: /* @__PURE__ */ t("p", { className: "italic text-sm text-muted-foreground", children: c("ecommerce.no_description") }) })) })
|
|
522
|
+
] });
|
|
523
|
+
};
|
|
524
|
+
export {
|
|
525
|
+
Xe as P,
|
|
526
|
+
ke as S,
|
|
527
|
+
Ce as a,
|
|
528
|
+
Ke as b,
|
|
529
|
+
Pe as u
|
|
530
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";const r=require("react/jsx-runtime"),S=require("./AddToCartButton-DsSEH9yp.cjs"),l=require("@nextblock-cms/utils"),P=require("next/link"),q=require("./CurrencyProvider-Cg-Q6ucj.cjs"),n=require("./currency.cjs.js"),A=require("./trials-DvZaOtNy.cjs"),k=require("./variation-utils.cjs.js"),b=({product:e,className:o})=>{const{activeCurrencyCode:s,currencies:i}=q.useCurrency(),c=n.resolvePriceRangeForCurrency({entries:e.variants?.length?e.variants:e.product_variants?.length?e.product_variants:[],currencyCode:s,currencies:i}),x=!!(e.has_variants&&c),t=n.resolveEffectivePriceForCurrency({prices:e.prices,salePrices:e.sale_prices,fallbackPrice:e.price,fallbackSalePrice:e.sale_price,saleStartAt:e.sale_start_at,saleEndAt:e.sale_end_at,scheduledPrice:e.scheduled_price,scheduledPrices:e.scheduled_prices,scheduledPriceAt:e.scheduled_price_at,currencyCode:s,currencies:i}),j=x&&c?c.min===c.max?l.formatPrice(c.min,s):`${l.formatPrice(c.min,s)} - ${l.formatPrice(c.max,s)}`:l.formatPrice(t.sale_price??t.price,s),y=e.variants?.length?e.variants:e.product_variants?.length?e.product_variants:[],N=x?y.some(a=>n.resolveEffectivePriceForCurrency({prices:a.prices,salePrices:a.sale_prices,fallbackPrice:a.price,fallbackSalePrice:a.sale_price,saleStartAt:a.sale_start_at,saleEndAt:a.sale_end_at,scheduledPrice:a.scheduled_price,scheduledPrices:a.scheduled_prices,scheduledPriceAt:a.scheduled_price_at,currencyCode:s,currencies:i}).sale_price!=null):t.sale_price!=null,{t:f,lang:C}=l.useTranslations(),g=f("ecommerce.on_sale"),w=g==="ecommerce.on_sale"?"On Sale":g,h=A.getTrialSummary(e),d=e.freemius_plans?.[0]?.freemius_pricing?.[0],m=i.find(a=>a.is_default)?.code||"USD",_=d?.override_monthly_price??d?.api_monthly_price,v=d?.override_annual_price??d?.api_annual_price,u=typeof _=="number"?n.resolvePriceForCurrency({prices:{[m]:l.majorUnitAmountToMinor(_,m)},currencyCode:s,currencies:i}):null,p=typeof v=="number"?n.resolvePriceForCurrency({prices:{[m]:l.majorUnitAmountToMinor(v,m)},currencyCode:s,currencies:i}):null;return r.jsxs("div",{className:l.cn("group relative flex flex-col overflow-hidden rounded-lg border bg-card text-card-foreground shadow-sm transition-all hover:shadow-md",o),children:[r.jsxs(P,{href:`/product/${e.slug}`,className:"relative aspect-square overflow-hidden bg-muted",children:[N&&r.jsx("span",{className:"absolute left-3 top-3 z-10 rounded-full bg-destructive px-2.5 py-1 text-[10px] font-bold uppercase tracking-wider text-destructive-foreground shadow-sm",children:w}),e.image_url?r.jsx("img",{src:e.image_url,alt:e.title,className:"h-full w-full object-cover object-center transition-transform duration-300 group-hover:scale-105"}):r.jsx("div",{className:"flex h-full items-center justify-center text-muted-foreground",children:"No Image"})]}),r.jsxs("div",{className:"flex flex-1 flex-col p-4",children:[e.categories&&e.categories.length>0&&r.jsx("div",{className:"text-[10px] font-bold uppercase tracking-widest text-amber-600 dark:text-amber-400 mb-1",children:e.categories.map(a=>k.resolveTranslatedText(a.name,a.name_translations,C)).join(" • ")}),r.jsx(P,{href:`/product/${e.slug}`,className:"mb-2",children:r.jsx("h3",{className:"line-clamp-1 text-lg font-medium text-foreground group-hover:underline",children:e.title})}),r.jsx("div",{className:"mb-4",children:e.product_type==="digital"&&(u||p)?r.jsxs("div",{className:"flex flex-wrap items-baseline gap-x-3 gap-y-1",children:[u&&r.jsxs("div",{className:"flex items-baseline gap-0.5",children:[r.jsx("span",{className:"text-xl font-bold text-primary",children:l.formatPrice(u.price,s)}),r.jsxs("span",{className:"text-xs font-medium text-muted-foreground lowercase",children:["/ ",f("ecommerce.month")]})]}),p&&r.jsxs("div",{className:"flex items-baseline gap-0.5",children:[r.jsx("span",{className:l.cn("font-bold text-primary",u?"text-lg":"text-xl"),children:l.formatPrice(p.price,s)}),r.jsxs("span",{className:"text-xs font-medium text-muted-foreground lowercase",children:["/ ",f("ecommerce.year")]})]})]}):r.jsxs("div",{className:"flex items-baseline gap-2",children:[r.jsx("span",{className:"text-xl font-bold text-primary",children:j}),!x&&t.sale_price&&r.jsx("span",{className:"text-sm text-muted-foreground line-through",children:l.formatPrice(t.price,s)})]})}),h&&r.jsxs("div",{className:"mb-4 rounded-md border border-emerald-200 bg-emerald-50 px-3 py-2 text-xs text-emerald-900",children:[r.jsx("div",{className:"font-semibold",children:h.label}),r.jsx("div",{className:"text-emerald-700",children:h.paymentRequirementLabel})]}),r.jsx("div",{className:"mt-auto",children:r.jsx(S.AddToCartButton,{product:{...e,price:e.price,prices:e.prices,sale_price:e.sale_price,sale_prices:e.sale_prices},className:"w-full"})})]})]})},R=({products:e,columns:o=3,className:s})=>e.length?r.jsx("div",{className:l.cn("grid gap-6 sm:grid-cols-2",o===3&&"lg:grid-cols-3",o===4&&"lg:grid-cols-4",s),children:e.map(i=>r.jsx(b,{product:i},i.id))}):r.jsx("div",{className:"py-12 text-center text-muted-foreground",children:"No products found."});exports.ProductCard=b;exports.ProductGrid=R;
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { jsxs as l, jsx as r } from "react/jsx-runtime";
|
|
2
|
+
import { A as R } from "./AddToCartButton-ffE0DhHu.js";
|
|
3
|
+
import { formatPrice as t, useTranslations as T, majorUnitAmountToMinor as y, cn as x } from "@nextblock-cms/utils";
|
|
4
|
+
import N from "next/link";
|
|
5
|
+
import { u as L } from "./CurrencyProvider-OzlRN96V.js";
|
|
6
|
+
import { resolvePriceRangeForCurrency as E, resolveEffectivePriceForCurrency as P, resolvePriceForCurrency as C } from "./currency.es.js";
|
|
7
|
+
import { d as $ } from "./trials-RDcRAZKx.js";
|
|
8
|
+
import { resolveTranslatedText as F } from "./variation-utils.es.js";
|
|
9
|
+
const M = ({ product: e, className: o }) => {
|
|
10
|
+
const { activeCurrencyCode: a, currencies: i } = L(), c = E({
|
|
11
|
+
entries: e.variants?.length ? e.variants : e.product_variants?.length ? e.product_variants : [],
|
|
12
|
+
currencyCode: a,
|
|
13
|
+
currencies: i
|
|
14
|
+
}), u = !!(e.has_variants && c), n = P({
|
|
15
|
+
prices: e.prices,
|
|
16
|
+
salePrices: e.sale_prices,
|
|
17
|
+
fallbackPrice: e.price,
|
|
18
|
+
fallbackSalePrice: e.sale_price,
|
|
19
|
+
saleStartAt: e.sale_start_at,
|
|
20
|
+
saleEndAt: e.sale_end_at,
|
|
21
|
+
scheduledPrice: e.scheduled_price,
|
|
22
|
+
scheduledPrices: e.scheduled_prices,
|
|
23
|
+
scheduledPriceAt: e.scheduled_price_at,
|
|
24
|
+
currencyCode: a,
|
|
25
|
+
currencies: i
|
|
26
|
+
}), w = u && c ? c.min === c.max ? t(c.min, a) : `${t(c.min, a)} - ${t(
|
|
27
|
+
c.max,
|
|
28
|
+
a
|
|
29
|
+
)}` : t(n.sale_price ?? n.price, a), S = e.variants?.length ? e.variants : e.product_variants?.length ? e.product_variants : [], j = u ? S.some(
|
|
30
|
+
(s) => P({
|
|
31
|
+
prices: s.prices,
|
|
32
|
+
salePrices: s.sale_prices,
|
|
33
|
+
fallbackPrice: s.price,
|
|
34
|
+
fallbackSalePrice: s.sale_price,
|
|
35
|
+
saleStartAt: s.sale_start_at,
|
|
36
|
+
saleEndAt: s.sale_end_at,
|
|
37
|
+
scheduledPrice: s.scheduled_price,
|
|
38
|
+
scheduledPrices: s.scheduled_prices,
|
|
39
|
+
scheduledPriceAt: s.scheduled_price_at,
|
|
40
|
+
currencyCode: a,
|
|
41
|
+
currencies: i
|
|
42
|
+
}).sale_price != null
|
|
43
|
+
) : n.sale_price != null, { t: p, lang: A } = T(), _ = p("ecommerce.on_sale"), k = _ === "ecommerce.on_sale" ? "On Sale" : _, h = $(e), d = e.freemius_plans?.[0]?.freemius_pricing?.[0], m = i.find((s) => s.is_default)?.code || "USD", v = d?.override_monthly_price ?? d?.api_monthly_price, b = d?.override_annual_price ?? d?.api_annual_price, f = typeof v == "number" ? C({
|
|
44
|
+
prices: {
|
|
45
|
+
[m]: y(
|
|
46
|
+
v,
|
|
47
|
+
m
|
|
48
|
+
)
|
|
49
|
+
},
|
|
50
|
+
currencyCode: a,
|
|
51
|
+
currencies: i
|
|
52
|
+
}) : null, g = typeof b == "number" ? C({
|
|
53
|
+
prices: {
|
|
54
|
+
[m]: y(
|
|
55
|
+
b,
|
|
56
|
+
m
|
|
57
|
+
)
|
|
58
|
+
},
|
|
59
|
+
currencyCode: a,
|
|
60
|
+
currencies: i
|
|
61
|
+
}) : null;
|
|
62
|
+
return /* @__PURE__ */ l("div", { className: x("group relative flex flex-col overflow-hidden rounded-lg border bg-card text-card-foreground shadow-sm transition-all hover:shadow-md", o), children: [
|
|
63
|
+
/* @__PURE__ */ l(N, { href: `/product/${e.slug}`, className: "relative aspect-square overflow-hidden bg-muted", children: [
|
|
64
|
+
j && /* @__PURE__ */ r("span", { className: "absolute left-3 top-3 z-10 rounded-full bg-destructive px-2.5 py-1 text-[10px] font-bold uppercase tracking-wider text-destructive-foreground shadow-sm", children: k }),
|
|
65
|
+
e.image_url ? /* @__PURE__ */ r(
|
|
66
|
+
"img",
|
|
67
|
+
{
|
|
68
|
+
src: e.image_url,
|
|
69
|
+
alt: e.title,
|
|
70
|
+
className: "h-full w-full object-cover object-center transition-transform duration-300 group-hover:scale-105"
|
|
71
|
+
}
|
|
72
|
+
) : /* @__PURE__ */ r("div", { className: "flex h-full items-center justify-center text-muted-foreground", children: "No Image" })
|
|
73
|
+
] }),
|
|
74
|
+
/* @__PURE__ */ l("div", { className: "flex flex-1 flex-col p-4", children: [
|
|
75
|
+
e.categories && e.categories.length > 0 && /* @__PURE__ */ r("div", { className: "text-[10px] font-bold uppercase tracking-widest text-amber-600 dark:text-amber-400 mb-1", children: e.categories.map((s) => F(s.name, s.name_translations, A)).join(" • ") }),
|
|
76
|
+
/* @__PURE__ */ r(N, { href: `/product/${e.slug}`, className: "mb-2", children: /* @__PURE__ */ r("h3", { className: "line-clamp-1 text-lg font-medium text-foreground group-hover:underline", children: e.title }) }),
|
|
77
|
+
/* @__PURE__ */ r("div", { className: "mb-4", children: e.product_type === "digital" && (f || g) ? /* @__PURE__ */ l("div", { className: "flex flex-wrap items-baseline gap-x-3 gap-y-1", children: [
|
|
78
|
+
f && /* @__PURE__ */ l("div", { className: "flex items-baseline gap-0.5", children: [
|
|
79
|
+
/* @__PURE__ */ r("span", { className: "text-xl font-bold text-primary", children: t(f.price, a) }),
|
|
80
|
+
/* @__PURE__ */ l("span", { className: "text-xs font-medium text-muted-foreground lowercase", children: [
|
|
81
|
+
"/ ",
|
|
82
|
+
p("ecommerce.month")
|
|
83
|
+
] })
|
|
84
|
+
] }),
|
|
85
|
+
g && /* @__PURE__ */ l("div", { className: "flex items-baseline gap-0.5", children: [
|
|
86
|
+
/* @__PURE__ */ r("span", { className: x("font-bold text-primary", f ? "text-lg" : "text-xl"), children: t(g.price, a) }),
|
|
87
|
+
/* @__PURE__ */ l("span", { className: "text-xs font-medium text-muted-foreground lowercase", children: [
|
|
88
|
+
"/ ",
|
|
89
|
+
p("ecommerce.year")
|
|
90
|
+
] })
|
|
91
|
+
] })
|
|
92
|
+
] }) : /* @__PURE__ */ l("div", { className: "flex items-baseline gap-2", children: [
|
|
93
|
+
/* @__PURE__ */ r("span", { className: "text-xl font-bold text-primary", children: w }),
|
|
94
|
+
!u && n.sale_price && /* @__PURE__ */ r("span", { className: "text-sm text-muted-foreground line-through", children: t(n.price, a) })
|
|
95
|
+
] }) }),
|
|
96
|
+
h && /* @__PURE__ */ l("div", { className: "mb-4 rounded-md border border-emerald-200 bg-emerald-50 px-3 py-2 text-xs text-emerald-900", children: [
|
|
97
|
+
/* @__PURE__ */ r("div", { className: "font-semibold", children: h.label }),
|
|
98
|
+
/* @__PURE__ */ r("div", { className: "text-emerald-700", children: h.paymentRequirementLabel })
|
|
99
|
+
] }),
|
|
100
|
+
/* @__PURE__ */ r("div", { className: "mt-auto", children: /* @__PURE__ */ r(
|
|
101
|
+
R,
|
|
102
|
+
{
|
|
103
|
+
product: {
|
|
104
|
+
...e,
|
|
105
|
+
price: e.price,
|
|
106
|
+
prices: e.prices,
|
|
107
|
+
sale_price: e.sale_price,
|
|
108
|
+
sale_prices: e.sale_prices
|
|
109
|
+
},
|
|
110
|
+
className: "w-full"
|
|
111
|
+
}
|
|
112
|
+
) })
|
|
113
|
+
] })
|
|
114
|
+
] });
|
|
115
|
+
}, H = ({ products: e, columns: o = 3, className: a }) => e.length ? /* @__PURE__ */ r(
|
|
116
|
+
"div",
|
|
117
|
+
{
|
|
118
|
+
className: x(
|
|
119
|
+
"grid gap-6 sm:grid-cols-2",
|
|
120
|
+
o === 3 && "lg:grid-cols-3",
|
|
121
|
+
o === 4 && "lg:grid-cols-4",
|
|
122
|
+
a
|
|
123
|
+
),
|
|
124
|
+
children: e.map((i) => /* @__PURE__ */ r(M, { product: i }, i.id))
|
|
125
|
+
}
|
|
126
|
+
) : /* @__PURE__ */ r("div", { className: "py-12 text-center text-muted-foreground", children: "No products found." });
|
|
127
|
+
export {
|
|
128
|
+
M as P,
|
|
129
|
+
H as a
|
|
130
|
+
};
|