@carlonicora/nextjs-jsonapi 1.39.2 → 1.40.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{BlockNoteEditor-WQXQPLMX.js → BlockNoteEditor-4G3L3LSF.js} +14 -14
- package/dist/{BlockNoteEditor-WQXQPLMX.js.map → BlockNoteEditor-4G3L3LSF.js.map} +1 -1
- package/dist/{BlockNoteEditor-CITC7I2Z.mjs → BlockNoteEditor-EKY4AHVK.mjs} +4 -4
- package/dist/billing/index.js +346 -346
- package/dist/billing/index.mjs +3 -3
- package/dist/{chunk-LDH2FGJY.mjs → chunk-BAOP6PTD.mjs} +689 -34
- package/dist/chunk-BAOP6PTD.mjs.map +1 -0
- package/dist/{chunk-2RBYXY6T.js → chunk-GKY5DAIH.js} +1228 -573
- package/dist/chunk-GKY5DAIH.js.map +1 -0
- package/dist/{chunk-TQ5GRRTM.mjs → chunk-GVN7XC3U.mjs} +278 -2
- package/dist/chunk-GVN7XC3U.mjs.map +1 -0
- package/dist/{chunk-XLMJPA4N.mjs → chunk-RRIYLEY6.mjs} +22 -2
- package/dist/chunk-RRIYLEY6.mjs.map +1 -0
- package/dist/{chunk-2PHWAL6Q.js → chunk-T5YYOT4Z.js} +22 -2
- package/dist/chunk-T5YYOT4Z.js.map +1 -0
- package/dist/{chunk-3EZX4G2E.js → chunk-ZNGEVB5M.js} +279 -3
- package/dist/chunk-ZNGEVB5M.js.map +1 -0
- package/dist/client/index.js +4 -4
- package/dist/client/index.mjs +3 -3
- package/dist/components/index.d.mts +28 -4
- package/dist/components/index.d.ts +28 -4
- package/dist/components/index.js +16 -4
- package/dist/components/index.js.map +1 -1
- package/dist/components/index.mjs +15 -3
- package/dist/contexts/index.js +4 -4
- package/dist/contexts/index.mjs +3 -3
- package/dist/core/index.d.mts +127 -3
- package/dist/core/index.d.ts +127 -3
- package/dist/core/index.js +12 -2
- package/dist/core/index.js.map +1 -1
- package/dist/core/index.mjs +11 -1
- package/dist/index.d.mts +5 -2
- package/dist/index.d.ts +5 -2
- package/dist/index.js +17 -3
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +16 -2
- package/dist/{s3.service-hnTPVTm2.d.mts → s3.service-BoOF5-ln.d.mts} +1 -0
- package/dist/{s3.service-DXkDoMf1.d.ts → s3.service-Mxo-7wQ6.d.ts} +1 -0
- package/dist/server/index.d.mts +1 -1
- package/dist/server/index.d.ts +1 -1
- package/dist/server/index.js +3 -3
- package/dist/server/index.mjs +1 -1
- package/dist/waitlist.config-kPfjImle.d.mts +26 -0
- package/dist/waitlist.config-kPfjImle.d.ts +26 -0
- package/package.json +1 -1
- package/src/components/forms/FormCheckbox.tsx +1 -1
- package/src/components/forms/FormSelect.tsx +1 -1
- package/src/components/index.ts +1 -0
- package/src/core/index.ts +3 -0
- package/src/core/registry/ModuleRegistry.ts +3 -0
- package/src/features/auth/components/forms/Register.tsx +180 -1
- package/src/features/auth/data/auth.interface.ts +1 -0
- package/src/features/auth/data/auth.ts +1 -0
- package/src/features/index.ts +1 -0
- package/src/features/waitlist/components/forms/WaitlistForm.tsx +186 -0
- package/src/features/waitlist/components/forms/WaitlistQuestionnaireRenderer.tsx +110 -0
- package/src/features/waitlist/components/forms/index.ts +2 -0
- package/src/features/waitlist/components/index.ts +3 -0
- package/src/features/waitlist/components/lists/WaitlistList.tsx +145 -0
- package/src/features/waitlist/components/lists/index.ts +1 -0
- package/src/features/waitlist/components/sections/WaitlistConfirmation.tsx +68 -0
- package/src/features/waitlist/components/sections/WaitlistHeroSection.tsx +49 -0
- package/src/features/waitlist/components/sections/WaitlistSuccessState.tsx +19 -0
- package/src/features/waitlist/components/sections/index.ts +3 -0
- package/src/features/waitlist/config/waitlist.config.ts +35 -0
- package/src/features/waitlist/data/Waitlist.ts +104 -0
- package/src/features/waitlist/data/WaitlistInterface.ts +32 -0
- package/src/features/waitlist/data/WaitlistService.ts +153 -0
- package/src/features/waitlist/data/index.ts +5 -0
- package/src/features/waitlist/data/waitlist-stats.interface.ts +9 -0
- package/src/features/waitlist/data/waitlist-stats.ts +47 -0
- package/src/features/waitlist/hooks/useWaitlistTableStructure.tsx +121 -0
- package/src/features/waitlist/index.ts +28 -0
- package/src/features/waitlist/waitlist-stats.module.ts +8 -0
- package/src/features/waitlist/waitlist.module.ts +9 -0
- package/src/index.ts +9 -0
- package/src/login/config.ts +9 -0
- package/dist/chunk-2PHWAL6Q.js.map +0 -1
- package/dist/chunk-2RBYXY6T.js.map +0 -1
- package/dist/chunk-3EZX4G2E.js.map +0 -1
- package/dist/chunk-LDH2FGJY.mjs.map +0 -1
- package/dist/chunk-TQ5GRRTM.mjs.map +0 -1
- package/dist/chunk-XLMJPA4N.mjs.map +0 -1
- /package/dist/{BlockNoteEditor-CITC7I2Z.mjs.map → BlockNoteEditor-EKY4AHVK.mjs.map} +0 -0
package/dist/billing/index.js
CHANGED
|
@@ -47,11 +47,11 @@
|
|
|
47
47
|
|
|
48
48
|
|
|
49
49
|
|
|
50
|
-
var
|
|
50
|
+
var _chunkGKY5DAIHjs = require('../chunk-GKY5DAIH.js');
|
|
51
51
|
|
|
52
52
|
|
|
53
53
|
|
|
54
|
-
var
|
|
54
|
+
var _chunkT5YYOT4Zjs = require('../chunk-T5YYOT4Z.js');
|
|
55
55
|
|
|
56
56
|
|
|
57
57
|
|
|
@@ -62,7 +62,7 @@ var _chunk2PHWAL6Qjs = require('../chunk-2PHWAL6Q.js');
|
|
|
62
62
|
|
|
63
63
|
|
|
64
64
|
|
|
65
|
-
var
|
|
65
|
+
var _chunkZNGEVB5Mjs = require('../chunk-ZNGEVB5M.js');
|
|
66
66
|
require('../chunk-LXKSUWAV.js');
|
|
67
67
|
require('../chunk-IBS6NI7D.js');
|
|
68
68
|
require('../chunk-FM6WRAN5.js');
|
|
@@ -113,41 +113,41 @@ function SubscriptionSummaryCard({
|
|
|
113
113
|
onManageClick
|
|
114
114
|
}) {
|
|
115
115
|
if (loading) {
|
|
116
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
117
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
118
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
116
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
117
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
118
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Subscriptions" }),
|
|
119
119
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.CreditCard, { className: "h-4 w-4 text-muted-foreground" })
|
|
120
120
|
] }),
|
|
121
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
122
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
123
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
124
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
121
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: [
|
|
122
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-6 w-32 mb-2" }),
|
|
123
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-24 mb-1" }),
|
|
124
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-40" })
|
|
125
125
|
] })
|
|
126
126
|
] });
|
|
127
127
|
}
|
|
128
128
|
if (error) {
|
|
129
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
130
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
131
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
129
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
130
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
131
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Subscriptions" }),
|
|
132
132
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.CreditCard, { className: "h-4 w-4 text-muted-foreground" })
|
|
133
133
|
] }),
|
|
134
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
134
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-destructive", children: error }) })
|
|
135
135
|
] });
|
|
136
136
|
}
|
|
137
137
|
const activeSubscriptions = subscriptions.filter(
|
|
138
138
|
(sub) => sub.status === "active" /* ACTIVE */ || sub.status === "trialing" /* TRIALING */
|
|
139
139
|
);
|
|
140
140
|
const primarySubscription = activeSubscriptions[0];
|
|
141
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
142
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
143
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
141
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { className: "cursor-pointer hover:bg-accent/50 transition-colors", onClick: onManageClick, children: [
|
|
142
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
143
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Subscriptions" }),
|
|
144
144
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.CreditCard, { className: "h-4 w-4 text-muted-foreground" })
|
|
145
145
|
] }),
|
|
146
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
146
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: subscriptions.length === 0 ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
147
147
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold text-muted-foreground", children: "No active plan" }),
|
|
148
148
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xs text-muted-foreground", children: "Subscribe to get started" }),
|
|
149
149
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
150
|
-
|
|
150
|
+
_chunkGKY5DAIHjs.Button,
|
|
151
151
|
{
|
|
152
152
|
variant: "outline",
|
|
153
153
|
size: "sm",
|
|
@@ -166,7 +166,7 @@ function SubscriptionSummaryCard({
|
|
|
166
166
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-2", children: [
|
|
167
167
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold", children: formatPlanName(primarySubscription) }),
|
|
168
168
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
169
|
-
|
|
169
|
+
_chunkGKY5DAIHjs.Badge,
|
|
170
170
|
{
|
|
171
171
|
variant: primarySubscription.cancelAtPeriodEnd ? "secondary" : getStatusBadgeVariant(primarySubscription.status),
|
|
172
172
|
children: primarySubscription.cancelAtPeriodEnd ? "Canceling" : primarySubscription.status
|
|
@@ -208,37 +208,37 @@ function PaymentMethodSummaryCard({
|
|
|
208
208
|
onManageClick
|
|
209
209
|
}) {
|
|
210
210
|
if (loading) {
|
|
211
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
212
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
213
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
211
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
212
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
213
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Payment Method" }),
|
|
214
214
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Wallet, { className: "h-4 w-4 text-muted-foreground" })
|
|
215
215
|
] }),
|
|
216
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
217
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
218
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
216
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: [
|
|
217
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-6 w-32 mb-2" }),
|
|
218
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-24" })
|
|
219
219
|
] })
|
|
220
220
|
] });
|
|
221
221
|
}
|
|
222
222
|
if (error) {
|
|
223
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
224
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
225
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
223
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
224
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
225
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Payment Method" }),
|
|
226
226
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Wallet, { className: "h-4 w-4 text-muted-foreground" })
|
|
227
227
|
] }),
|
|
228
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
228
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-destructive", children: error }) })
|
|
229
229
|
] });
|
|
230
230
|
}
|
|
231
231
|
const defaultMethod = paymentMethods.find((pm) => pm.id === defaultPaymentMethodId) || paymentMethods[0];
|
|
232
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
233
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
234
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
232
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { className: "cursor-pointer hover:bg-accent/50 transition-colors", onClick: onManageClick, children: [
|
|
233
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
234
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Payment Method" }),
|
|
235
235
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Wallet, { className: "h-4 w-4 text-muted-foreground" })
|
|
236
236
|
] }),
|
|
237
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
237
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: paymentMethods.length === 0 ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
238
238
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold text-muted-foreground", children: "No payment method" }),
|
|
239
239
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xs text-muted-foreground", children: "Add a card to enable subscriptions" }),
|
|
240
240
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
241
|
-
|
|
241
|
+
_chunkGKY5DAIHjs.Button,
|
|
242
242
|
{
|
|
243
243
|
variant: "outline",
|
|
244
244
|
size: "sm",
|
|
@@ -302,7 +302,7 @@ function CustomerInfoCard({ customer, loading, error }) {
|
|
|
302
302
|
e.stopPropagation();
|
|
303
303
|
setPortalLoading(true);
|
|
304
304
|
try {
|
|
305
|
-
const { url } = await
|
|
305
|
+
const { url } = await _chunkZNGEVB5Mjs.StripeCustomerService.createPortalSession();
|
|
306
306
|
window.open(url, "_blank");
|
|
307
307
|
} catch (err) {
|
|
308
308
|
console.error("[CustomerInfoCard] Failed to create portal session:", err);
|
|
@@ -311,52 +311,52 @@ function CustomerInfoCard({ customer, loading, error }) {
|
|
|
311
311
|
}
|
|
312
312
|
}, "handlePortalClick");
|
|
313
313
|
if (loading) {
|
|
314
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
315
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
316
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
314
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
315
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
316
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Billing Account" }),
|
|
317
317
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.User, { className: "h-4 w-4 text-muted-foreground" })
|
|
318
318
|
] }),
|
|
319
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
320
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
321
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
322
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
319
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: [
|
|
320
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-6 w-32 mb-2" }),
|
|
321
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-48 mb-1" }),
|
|
322
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-24" })
|
|
323
323
|
] })
|
|
324
324
|
] });
|
|
325
325
|
}
|
|
326
326
|
if (error) {
|
|
327
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
328
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
329
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
327
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
328
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
329
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Billing Account" }),
|
|
330
330
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.User, { className: "h-4 w-4 text-muted-foreground" })
|
|
331
331
|
] }),
|
|
332
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
332
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-destructive", children: error }) })
|
|
333
333
|
] });
|
|
334
334
|
}
|
|
335
335
|
if (!customer) {
|
|
336
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
337
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
338
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
336
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
337
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
338
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Billing Account" }),
|
|
339
339
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.User, { className: "h-4 w-4 text-muted-foreground" })
|
|
340
340
|
] }),
|
|
341
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
341
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: [
|
|
342
342
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold text-muted-foreground", children: "Not set up" }),
|
|
343
343
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xs text-muted-foreground", children: "Billing account will be created when you subscribe" })
|
|
344
344
|
] })
|
|
345
345
|
] });
|
|
346
346
|
}
|
|
347
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
348
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
349
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
347
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
348
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
349
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Billing Account" }),
|
|
350
350
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.User, { className: "h-4 w-4 text-muted-foreground" })
|
|
351
351
|
] }),
|
|
352
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
352
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
353
353
|
customer.name && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold", children: customer.name }),
|
|
354
354
|
customer.email && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-muted-foreground", children: customer.email }),
|
|
355
355
|
customer.balance !== void 0 && customer.balance !== 0 && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "p", { className: "text-sm", children: [
|
|
356
356
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: "text-muted-foreground", children: "Credit Balance: " }),
|
|
357
357
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: customer.balance < 0 ? "text-green-600" : "text-destructive", children: formatBalance(customer.balance, customer.currency) })
|
|
358
358
|
] }),
|
|
359
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
359
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", size: "sm", className: "mt-2", onClick: handlePortalClick, disabled: portalLoading, children: [
|
|
360
360
|
portalLoading ? "Loading..." : "Manage in Stripe Portal",
|
|
361
361
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.ExternalLink, { className: "h-4 w-4 ml-1" })
|
|
362
362
|
] })
|
|
@@ -400,42 +400,42 @@ function formatAmount(amount, currency) {
|
|
|
400
400
|
_chunk7QVYU63Ejs.__name.call(void 0, formatAmount, "formatAmount");
|
|
401
401
|
function InvoicesSummaryCard({ invoices, loading, error, onViewAllClick }) {
|
|
402
402
|
if (loading) {
|
|
403
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
404
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
405
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
403
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
404
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
405
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Recent Invoices" }),
|
|
406
406
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.ReceiptIcon, { className: "h-4 w-4 text-muted-foreground" })
|
|
407
407
|
] }),
|
|
408
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
409
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
410
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
411
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
408
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: [
|
|
409
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-6 w-24 mb-2" }),
|
|
410
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-32 mb-1" }),
|
|
411
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-20" })
|
|
412
412
|
] })
|
|
413
413
|
] });
|
|
414
414
|
}
|
|
415
415
|
if (error) {
|
|
416
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
417
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
418
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
416
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
417
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
418
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Recent Invoices" }),
|
|
419
419
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.ReceiptIcon, { className: "h-4 w-4 text-muted-foreground" })
|
|
420
420
|
] }),
|
|
421
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
421
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-destructive", children: error }) })
|
|
422
422
|
] });
|
|
423
423
|
}
|
|
424
424
|
const latestInvoice = invoices[0];
|
|
425
425
|
const paidInvoices = invoices.filter((inv) => inv.status === "paid" /* PAID */);
|
|
426
426
|
const openInvoices = invoices.filter((inv) => inv.status === "open" /* OPEN */);
|
|
427
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
428
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
429
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
427
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { className: "cursor-pointer hover:bg-accent/50 transition-colors", onClick: onViewAllClick, children: [
|
|
428
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
429
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Recent Invoices" }),
|
|
430
430
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.ReceiptIcon, { className: "h-4 w-4 text-muted-foreground" })
|
|
431
431
|
] }),
|
|
432
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
432
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: invoices.length === 0 ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
433
433
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold text-muted-foreground", children: "No invoices yet" }),
|
|
434
434
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xs text-muted-foreground", children: "Invoices will appear after your first billing cycle" })
|
|
435
435
|
] }) : latestInvoice ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
436
436
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-2", children: [
|
|
437
437
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold", children: formatAmount(latestInvoice.total, latestInvoice.currency) }),
|
|
438
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
438
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Badge, { variant: getStatusBadgeVariant2(latestInvoice.status), children: latestInvoice.status })
|
|
439
439
|
] }),
|
|
440
440
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-muted-foreground", children: latestInvoice.stripeInvoiceNumber || `Invoice from ${formatDate2(latestInvoice.periodStart)}` }),
|
|
441
441
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-4 text-xs text-muted-foreground", children: [
|
|
@@ -475,24 +475,24 @@ function BillingUsageSummaryCard({
|
|
|
475
475
|
onViewDetailsClick
|
|
476
476
|
}) {
|
|
477
477
|
if (loading) {
|
|
478
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
479
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
480
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
478
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
479
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
480
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Usage This Month" }),
|
|
481
481
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Activity, { className: "h-4 w-4 text-muted-foreground" })
|
|
482
482
|
] }),
|
|
483
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
484
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
485
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
483
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: [
|
|
484
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-6 w-24 mb-2" }),
|
|
485
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-32" })
|
|
486
486
|
] })
|
|
487
487
|
] });
|
|
488
488
|
}
|
|
489
489
|
if (error) {
|
|
490
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
491
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
492
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
490
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
491
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
492
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Usage This Month" }),
|
|
493
493
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Activity, { className: "h-4 w-4 text-muted-foreground" })
|
|
494
494
|
] }),
|
|
495
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
495
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-destructive", children: error }) })
|
|
496
496
|
] });
|
|
497
497
|
}
|
|
498
498
|
const totalUsage = Object.values(summaries).reduce((acc, summary) => {
|
|
@@ -500,12 +500,12 @@ function BillingUsageSummaryCard({
|
|
|
500
500
|
}, 0);
|
|
501
501
|
const primaryMeter = meters.find((m) => _optionalChain([summaries, 'access', _17 => _17[m.id], 'optionalAccess', _18 => _18.aggregatedValue]));
|
|
502
502
|
const primarySummary = primaryMeter ? summaries[primaryMeter.id] : null;
|
|
503
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
504
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
505
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
503
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { className: "cursor-pointer hover:bg-accent/50 transition-colors", onClick: onViewDetailsClick, children: [
|
|
504
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
|
|
505
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { className: "text-sm font-medium", children: "Usage This Month" }),
|
|
506
506
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Activity, { className: "h-4 w-4 text-muted-foreground" })
|
|
507
507
|
] }),
|
|
508
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
508
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: meters.length === 0 ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
509
509
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xl font-bold text-muted-foreground", children: "No meters" }),
|
|
510
510
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xs text-muted-foreground", children: "No usage meters are configured" })
|
|
511
511
|
] }) : /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
@@ -557,7 +557,7 @@ function PaymentMethodForm({ onSuccess, onCancel, isLoading = false }) {
|
|
|
557
557
|
const fetchSetupIntent = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
558
558
|
setLoading(true);
|
|
559
559
|
try {
|
|
560
|
-
const intent = await
|
|
560
|
+
const intent = await _chunkZNGEVB5Mjs.StripeCustomerService.createSetupIntent();
|
|
561
561
|
setSetupIntent(intent);
|
|
562
562
|
} catch (err) {
|
|
563
563
|
console.error("[PaymentMethodForm] Failed to create setup intent:", err);
|
|
@@ -595,7 +595,7 @@ function PaymentMethodForm({ onSuccess, onCancel, isLoading = false }) {
|
|
|
595
595
|
return;
|
|
596
596
|
}
|
|
597
597
|
if (setAsDefault && _optionalChain([confirmedSetupIntent, 'optionalAccess', _19 => _19.payment_method])) {
|
|
598
|
-
await
|
|
598
|
+
await _chunkZNGEVB5Mjs.StripeCustomerService.setDefaultPaymentMethod({
|
|
599
599
|
paymentMethodId: typeof confirmedSetupIntent.payment_method === "string" ? confirmedSetupIntent.payment_method : confirmedSetupIntent.payment_method.id
|
|
600
600
|
});
|
|
601
601
|
}
|
|
@@ -611,7 +611,7 @@ function PaymentMethodForm({ onSuccess, onCancel, isLoading = false }) {
|
|
|
611
611
|
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "flex items-center justify-center py-8", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-muted-foreground", children: "Loading payment form..." }) });
|
|
612
612
|
}
|
|
613
613
|
if (!setupIntent && error) {
|
|
614
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
614
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Alert, { variant: "destructive", className: "bg-red-50 border-red-200", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDescription, { children: error }) });
|
|
615
615
|
}
|
|
616
616
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "form", { onSubmit: handleSubmit, className: "flex flex-col gap-y-4", children: [
|
|
617
617
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "rounded-md border border-gray-300 p-3", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
@@ -634,13 +634,13 @@ function PaymentMethodForm({ onSuccess, onCancel, isLoading = false }) {
|
|
|
634
634
|
}
|
|
635
635
|
) }),
|
|
636
636
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-x-2", children: [
|
|
637
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
638
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
637
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Checkbox, { id: "setAsDefault", checked: setAsDefault, onCheckedChange: (checked) => setSetAsDefault(!!checked) }),
|
|
638
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Label, { htmlFor: "setAsDefault", className: "text-sm font-normal", children: "Set as default payment method" })
|
|
639
639
|
] }),
|
|
640
|
-
error && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
640
|
+
error && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Alert, { variant: "destructive", className: "bg-red-50 border-red-200", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDescription, { children: error }) }),
|
|
641
641
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex justify-end gap-x-2", children: [
|
|
642
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
643
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
642
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { type: "button", variant: "outline", onClick: onCancel, disabled: isSubmitting || isLoading, children: "Cancel" }),
|
|
643
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { type: "submit", disabled: !stripe || isSubmitting || isLoading, children: isSubmitting ? "Processing..." : "Add Card" })
|
|
644
644
|
] })
|
|
645
645
|
] });
|
|
646
646
|
}
|
|
@@ -656,10 +656,10 @@ function PaymentMethodEditor({ open, onOpenChange, onSuccess }) {
|
|
|
656
656
|
const handleCancel = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, () => {
|
|
657
657
|
onOpenChange(false);
|
|
658
658
|
}, "handleCancel");
|
|
659
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
660
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
661
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
662
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
659
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: "max-w-md", children: [
|
|
660
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: [
|
|
661
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: "Add Payment Method" }),
|
|
662
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogDescription, { children: "Add a new payment method to your account. Your card information is securely processed by Stripe." })
|
|
663
663
|
] }),
|
|
664
664
|
open && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, PaymentMethodForm, { onSuccess: handleSuccess, onCancel: handleCancel })
|
|
665
665
|
] }) });
|
|
@@ -683,7 +683,7 @@ function PaymentMethodCard({ paymentMethod, onUpdate }) {
|
|
|
683
683
|
_react.useEffect.call(void 0, () => {
|
|
684
684
|
const loadCustomer = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
685
685
|
try {
|
|
686
|
-
const fetchedCustomer = await
|
|
686
|
+
const fetchedCustomer = await _chunkZNGEVB5Mjs.StripeCustomerService.getCustomer();
|
|
687
687
|
setCustomer(fetchedCustomer);
|
|
688
688
|
} catch (error) {
|
|
689
689
|
console.error("[PaymentMethodCard] Failed to load customer:", error);
|
|
@@ -700,7 +700,7 @@ function PaymentMethodCard({ paymentMethod, onUpdate }) {
|
|
|
700
700
|
const handleSetDefault = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
701
701
|
setLoading(true);
|
|
702
702
|
try {
|
|
703
|
-
await
|
|
703
|
+
await _chunkZNGEVB5Mjs.StripeCustomerService.setDefaultPaymentMethod({ paymentMethodId: paymentMethod.id });
|
|
704
704
|
onUpdate();
|
|
705
705
|
} catch (error) {
|
|
706
706
|
console.error("[PaymentMethodCard] Failed to set as default:", error);
|
|
@@ -711,7 +711,7 @@ function PaymentMethodCard({ paymentMethod, onUpdate }) {
|
|
|
711
711
|
const handleRemove = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
712
712
|
setLoading(true);
|
|
713
713
|
try {
|
|
714
|
-
await
|
|
714
|
+
await _chunkZNGEVB5Mjs.StripeCustomerService.removePaymentMethod({ paymentMethodId: paymentMethod.id });
|
|
715
715
|
setShowRemoveDialog(false);
|
|
716
716
|
onUpdate();
|
|
717
717
|
} catch (error) {
|
|
@@ -720,16 +720,16 @@ function PaymentMethodCard({ paymentMethod, onUpdate }) {
|
|
|
720
720
|
}
|
|
721
721
|
}, "handleRemove");
|
|
722
722
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
|
|
723
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
724
|
-
isDefault && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
725
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
723
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { className: "relative", children: [
|
|
724
|
+
isDefault && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Badge, { className: "absolute right-2 top-2 bg-green-100 text-green-800 hover:bg-green-100", children: "Default" }),
|
|
725
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center justify-between pb-2", children: [
|
|
726
726
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-x-2", children: [
|
|
727
727
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: "text-2xl", children: brandIcon }),
|
|
728
728
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: "text-sm font-medium capitalize", children: brand })
|
|
729
729
|
] }),
|
|
730
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
731
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
732
|
-
|
|
730
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DropdownMenu, { children: [
|
|
731
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DropdownMenuTrigger, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
732
|
+
_chunkGKY5DAIHjs.Button,
|
|
733
733
|
{
|
|
734
734
|
render: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", {}),
|
|
735
735
|
nativeButton: false,
|
|
@@ -740,13 +740,13 @@ function PaymentMethodCard({ paymentMethod, onUpdate }) {
|
|
|
740
740
|
children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.MoreVertical, { className: "h-4 w-4" })
|
|
741
741
|
}
|
|
742
742
|
) }),
|
|
743
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
744
|
-
!isDefault && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
745
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
743
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DropdownMenuContent, { align: "end", children: [
|
|
744
|
+
!isDefault && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DropdownMenuItem, { onClick: handleSetDefault, disabled: loading, children: "Set as Default" }),
|
|
745
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DropdownMenuItem, { onClick: () => setShowRemoveDialog(true), disabled: loading, className: "text-red-600", children: "Remove" })
|
|
746
746
|
] })
|
|
747
747
|
] })
|
|
748
748
|
] }),
|
|
749
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
749
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-col gap-y-1", children: [
|
|
750
750
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "p", { className: "text-lg font-semibold", children: [
|
|
751
751
|
"\u2022\u2022\u2022\u2022 ",
|
|
752
752
|
last4
|
|
@@ -759,17 +759,17 @@ function PaymentMethodCard({ paymentMethod, onUpdate }) {
|
|
|
759
759
|
] })
|
|
760
760
|
] }) })
|
|
761
761
|
] }),
|
|
762
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
763
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
764
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
765
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
762
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialog, { open: showRemoveDialog, onOpenChange: setShowRemoveDialog, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogContent, { children: [
|
|
763
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogHeader, { children: [
|
|
764
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogTitle, { children: "Remove Payment Method" }),
|
|
765
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogDescription, { children: [
|
|
766
766
|
"Are you sure you want to remove this payment method? This action cannot be undone.",
|
|
767
767
|
isDefault && " This is your default payment method."
|
|
768
768
|
] })
|
|
769
769
|
] }),
|
|
770
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
771
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
772
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
770
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogFooter, { children: [
|
|
771
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogCancel, { disabled: loading, children: "Cancel" }),
|
|
772
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogAction, { onClick: handleRemove, disabled: loading, className: "bg-red-600 hover:bg-red-700", children: loading ? "Removing..." : "Remove" })
|
|
773
773
|
] })
|
|
774
774
|
] }) })
|
|
775
775
|
] });
|
|
@@ -792,7 +792,7 @@ function PaymentMethodsContainer() {
|
|
|
792
792
|
const loadPaymentMethods = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
793
793
|
setLoading(true);
|
|
794
794
|
try {
|
|
795
|
-
const fetchedPaymentMethods = await
|
|
795
|
+
const fetchedPaymentMethods = await _chunkZNGEVB5Mjs.StripeCustomerService.listPaymentMethods();
|
|
796
796
|
setPaymentMethods(fetchedPaymentMethods);
|
|
797
797
|
} catch (error) {
|
|
798
798
|
console.error("[PaymentMethodsContainer] Failed to load payment methods:", error);
|
|
@@ -812,14 +812,14 @@ function PaymentMethodsContainer() {
|
|
|
812
812
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.CreditCard, { className: "h-8 w-8" }),
|
|
813
813
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h1", { className: "text-3xl font-bold", children: "Payment Methods" })
|
|
814
814
|
] }),
|
|
815
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
815
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: () => setShowAddPaymentMethod(true), children: "Add Payment Method" })
|
|
816
816
|
] }),
|
|
817
817
|
paymentMethods.length === 0 && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-col items-center justify-center gap-y-4 rounded-lg border-2 border-dashed border-gray-300 bg-muted/50 p-12", children: [
|
|
818
818
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.CreditCard, { className: "h-16 w-16 text-muted-foreground" }),
|
|
819
819
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "text-center", children: [
|
|
820
820
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h3", { className: "mb-2 text-xl font-semibold", children: "No payment methods" }),
|
|
821
821
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "mb-4 text-muted-foreground", children: "Add a payment method to enable subscriptions and secure checkout." }),
|
|
822
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
822
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: () => setShowAddPaymentMethod(true), children: "Add Your First Card" })
|
|
823
823
|
] })
|
|
824
824
|
] }),
|
|
825
825
|
paymentMethods.length > 0 && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, PaymentMethodsList, { paymentMethods, onUpdate: loadPaymentMethods }),
|
|
@@ -948,13 +948,13 @@ function InvoiceDetails({
|
|
|
948
948
|
return invoice.stripeInvoiceId.slice(-8);
|
|
949
949
|
}, "getInvoiceNumber");
|
|
950
950
|
const productName = _optionalChain([invoice, 'access', _29 => _29.subscription, 'optionalAccess', _30 => _30.price, 'optionalAccess', _31 => _31.product, 'optionalAccess', _32 => _32.name]) || "Subscription";
|
|
951
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
952
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
953
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
951
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: "max-w-2xl", children: [
|
|
952
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: [
|
|
953
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: [
|
|
954
954
|
"Invoice ",
|
|
955
955
|
getInvoiceNumber()
|
|
956
956
|
] }),
|
|
957
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
957
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogDescription, { children: formatDate3(invoice.periodStart) })
|
|
958
958
|
] }),
|
|
959
959
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-6", children: [
|
|
960
960
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-x-3", children: [
|
|
@@ -1019,15 +1019,15 @@ function InvoiceDetails({
|
|
|
1019
1019
|
] })
|
|
1020
1020
|
] }),
|
|
1021
1021
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-wrap gap-2 pt-4 border-t", children: [
|
|
1022
|
-
invoice.stripePdfUrl && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1022
|
+
invoice.stripePdfUrl && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: handleDownloadPDF, children: [
|
|
1023
1023
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Download, { className: "mr-2 h-4 w-4" }),
|
|
1024
1024
|
"Download PDF"
|
|
1025
1025
|
] }),
|
|
1026
|
-
invoice.status === "open" /* OPEN */ && invoice.attempted && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1026
|
+
invoice.status === "open" /* OPEN */ && invoice.attempted && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "default", onClick: handleRetryPayment, children: [
|
|
1027
1027
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.RefreshCw, { className: "mr-2 h-4 w-4" }),
|
|
1028
1028
|
"Retry Payment"
|
|
1029
1029
|
] }),
|
|
1030
|
-
invoice.stripeHostedInvoiceUrl && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1030
|
+
invoice.stripeHostedInvoiceUrl && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: handleViewInStripe, children: [
|
|
1031
1031
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.ExternalLink, { className: "mr-2 h-4 w-4" }),
|
|
1032
1032
|
"View in Stripe"
|
|
1033
1033
|
] })
|
|
@@ -1051,30 +1051,30 @@ function InvoicesList({ invoices, onInvoicesChange }) {
|
|
|
1051
1051
|
return invoice.stripeInvoiceId.slice(-8);
|
|
1052
1052
|
}, "getInvoiceNumber");
|
|
1053
1053
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
|
|
1054
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "border rounded-lg overflow-clip", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1055
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1056
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1057
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1058
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1059
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1060
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1054
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "border rounded-lg overflow-clip", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Table, { children: [
|
|
1055
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHeader, { className: "bg-muted", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.TableRow, { children: [
|
|
1056
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Invoice #" }),
|
|
1057
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Date" }),
|
|
1058
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Status" }),
|
|
1059
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { className: "text-right", children: "Amount" }),
|
|
1060
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Period" })
|
|
1061
1061
|
] }) }),
|
|
1062
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1062
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableBody, { children: invoices.map((invoice) => {
|
|
1063
1063
|
const invoiceNumber = getInvoiceNumber(invoice);
|
|
1064
1064
|
const date = formatDate3(invoice.periodStart);
|
|
1065
1065
|
const amount = formatCurrency(invoice.total, invoice.currency);
|
|
1066
1066
|
const period = `${formatDate3(invoice.periodStart)} - ${formatDate3(invoice.periodEnd)}`;
|
|
1067
1067
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1068
|
-
|
|
1068
|
+
_chunkGKY5DAIHjs.TableRow,
|
|
1069
1069
|
{
|
|
1070
1070
|
onClick: () => handleRowClick(invoice),
|
|
1071
1071
|
className: "cursor-pointer hover:bg-muted/50",
|
|
1072
1072
|
children: [
|
|
1073
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1074
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1075
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1076
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1077
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1073
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "font-medium", children: invoiceNumber }),
|
|
1074
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-muted-foreground text-sm", children: date }),
|
|
1075
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, InvoiceStatusBadge, { status: invoice.status }) }),
|
|
1076
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-right font-medium", children: amount }),
|
|
1077
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-muted-foreground text-sm", children: period })
|
|
1078
1078
|
]
|
|
1079
1079
|
},
|
|
1080
1080
|
invoice.id
|
|
@@ -1107,7 +1107,7 @@ function InvoicesContainer() {
|
|
|
1107
1107
|
setLoading(true);
|
|
1108
1108
|
try {
|
|
1109
1109
|
const params = statusFilter !== "all" ? { status: statusFilter } : void 0;
|
|
1110
|
-
const data = await
|
|
1110
|
+
const data = await _chunkZNGEVB5Mjs.StripeInvoiceService.listInvoices(params);
|
|
1111
1111
|
setInvoices(data);
|
|
1112
1112
|
} catch (error) {
|
|
1113
1113
|
console.error("[InvoicesContainer] Failed to load invoices:", error);
|
|
@@ -1123,12 +1123,12 @@ function InvoicesContainer() {
|
|
|
1123
1123
|
setStatusFilter(value);
|
|
1124
1124
|
}, "handleFilterChange");
|
|
1125
1125
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-4", children: [
|
|
1126
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1127
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1128
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1129
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1130
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1131
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1126
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Tabs, { value: statusFilter, onValueChange: handleFilterChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.TabsList, { children: [
|
|
1127
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TabsTrigger, { value: "all", children: "All" }),
|
|
1128
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TabsTrigger, { value: "paid" /* PAID */, children: "Paid" }),
|
|
1129
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TabsTrigger, { value: "open" /* OPEN */, children: "Open" }),
|
|
1130
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TabsTrigger, { value: "void" /* VOID */, children: "Void" }),
|
|
1131
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TabsTrigger, { value: "uncollectible" /* UNCOLLECTIBLE */, children: "Uncollectible" })
|
|
1132
1132
|
] }) }),
|
|
1133
1133
|
loading && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "text-center py-8 text-muted-foreground", children: "Loading invoices..." }),
|
|
1134
1134
|
!loading && invoices.length === 0 && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "border border-dashed border-gray-300 rounded-lg p-8 text-center", children: [
|
|
@@ -1175,7 +1175,7 @@ function CancelSubscriptionDialog({
|
|
|
1175
1175
|
const onSubmit = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async (_values) => {
|
|
1176
1176
|
setIsSubmitting(true);
|
|
1177
1177
|
try {
|
|
1178
|
-
await
|
|
1178
|
+
await _chunkZNGEVB5Mjs.StripeSubscriptionService.cancelSubscription({
|
|
1179
1179
|
id: subscription.id,
|
|
1180
1180
|
cancelImmediately: false
|
|
1181
1181
|
});
|
|
@@ -1188,19 +1188,19 @@ function CancelSubscriptionDialog({
|
|
|
1188
1188
|
}
|
|
1189
1189
|
}, "onSubmit");
|
|
1190
1190
|
const periodEndDate = formatDate3(subscription.currentPeriodEnd);
|
|
1191
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1192
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1193
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1194
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1191
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: "max-w-md", children: [
|
|
1192
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: [
|
|
1193
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: "Cancel Subscription" }),
|
|
1194
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogDescription, { children: "Are you sure you want to cancel this subscription? This action cannot be undone." })
|
|
1195
1195
|
] }),
|
|
1196
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1196
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Form, { ...form, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "form", { onSubmit: form.handleSubmit(onSubmit), className: "flex flex-col gap-y-4", children: [
|
|
1197
1197
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "bg-blue-50 border border-blue-200 rounded-lg p-3 text-sm text-blue-800", children: [
|
|
1198
1198
|
"Your subscription will remain active until ",
|
|
1199
1199
|
periodEndDate,
|
|
1200
1200
|
". You can continue using the service until then."
|
|
1201
1201
|
] }),
|
|
1202
1202
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1203
|
-
|
|
1203
|
+
_chunkGKY5DAIHjs.FormTextarea,
|
|
1204
1204
|
{
|
|
1205
1205
|
form,
|
|
1206
1206
|
id: "reason",
|
|
@@ -1210,8 +1210,8 @@ function CancelSubscriptionDialog({
|
|
|
1210
1210
|
}
|
|
1211
1211
|
),
|
|
1212
1212
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex gap-x-2 justify-end pt-2", children: [
|
|
1213
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1214
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1213
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { type: "button", variant: "outline", onClick: () => onOpenChange(false), disabled: isSubmitting, children: "Keep Subscription" }),
|
|
1214
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { type: "submit", variant: "destructive", disabled: isSubmitting, children: isSubmitting ? "Canceling..." : "Confirm Cancellation" })
|
|
1215
1215
|
] })
|
|
1216
1216
|
] }) })
|
|
1217
1217
|
] }) });
|
|
@@ -1302,7 +1302,7 @@ function SubscriptionDetails({
|
|
|
1302
1302
|
const handlePause = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
1303
1303
|
setIsProcessing(true);
|
|
1304
1304
|
try {
|
|
1305
|
-
await
|
|
1305
|
+
await _chunkZNGEVB5Mjs.StripeSubscriptionService.pauseSubscription({ subscriptionId: subscription.id });
|
|
1306
1306
|
onSubscriptionChange();
|
|
1307
1307
|
} catch (error) {
|
|
1308
1308
|
console.error("[SubscriptionDetails] Failed to pause subscription:", error);
|
|
@@ -1313,7 +1313,7 @@ function SubscriptionDetails({
|
|
|
1313
1313
|
const handleResume = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
1314
1314
|
setIsProcessing(true);
|
|
1315
1315
|
try {
|
|
1316
|
-
await
|
|
1316
|
+
await _chunkZNGEVB5Mjs.StripeSubscriptionService.resumeSubscription({ subscriptionId: subscription.id });
|
|
1317
1317
|
onSubscriptionChange();
|
|
1318
1318
|
} catch (error) {
|
|
1319
1319
|
console.error("[SubscriptionDetails] Failed to resume subscription:", error);
|
|
@@ -1323,7 +1323,7 @@ function SubscriptionDetails({
|
|
|
1323
1323
|
}, "handleResume");
|
|
1324
1324
|
const handleManageViaPortal = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
1325
1325
|
try {
|
|
1326
|
-
const { url } = await
|
|
1326
|
+
const { url } = await _chunkZNGEVB5Mjs.StripeCustomerService.createPortalSession();
|
|
1327
1327
|
window.open(url, "_blank");
|
|
1328
1328
|
} catch (error) {
|
|
1329
1329
|
console.error("[SubscriptionDetails] Failed to create portal session:", error);
|
|
@@ -1333,10 +1333,10 @@ function SubscriptionDetails({
|
|
|
1333
1333
|
const canResume = subscription.status === "paused" /* PAUSED */;
|
|
1334
1334
|
const canCancel = subscription.status === "active" /* ACTIVE */ || subscription.status === "trialing" /* TRIALING */ || subscription.status === "paused" /* PAUSED */;
|
|
1335
1335
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
|
|
1336
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1337
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1338
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1339
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1336
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: "max-w-2xl", children: [
|
|
1337
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: [
|
|
1338
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: "Subscription Details" }),
|
|
1339
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogDescription, { children: "View and manage your subscription" })
|
|
1340
1340
|
] }),
|
|
1341
1341
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-6", children: [
|
|
1342
1342
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-x-3", children: [
|
|
@@ -1378,11 +1378,11 @@ function SubscriptionDetails({
|
|
|
1378
1378
|
"."
|
|
1379
1379
|
] }) }),
|
|
1380
1380
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-wrap gap-2 pt-4 border-t", children: [
|
|
1381
|
-
onChangePlan && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1382
|
-
canPause && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1383
|
-
canResume && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1384
|
-
canCancel && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1385
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1381
|
+
onChangePlan && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "default", onClick: () => onChangePlan(subscription), children: "Change Plan" }),
|
|
1382
|
+
canPause && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: handlePause, disabled: isProcessing, children: isProcessing ? "Pausing..." : "Pause" }),
|
|
1383
|
+
canResume && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: handleResume, disabled: isProcessing, children: isProcessing ? "Resuming..." : "Resume" }),
|
|
1384
|
+
canCancel && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "destructive", onClick: () => setShowCancel(true), children: "Cancel" }),
|
|
1385
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: handleManageViaPortal, children: "Manage via Portal" })
|
|
1386
1386
|
] })
|
|
1387
1387
|
] })
|
|
1388
1388
|
] }) }),
|
|
@@ -1429,36 +1429,36 @@ function SubscriptionsList({ subscriptions, onSubscriptionsChange, onChangePlan
|
|
|
1429
1429
|
setSelectedSub(subscription);
|
|
1430
1430
|
}, "handleRowClick");
|
|
1431
1431
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
|
|
1432
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "border rounded-lg overflow-clip", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1433
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1434
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1435
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1436
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1437
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1438
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1432
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "border rounded-lg overflow-clip", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Table, { children: [
|
|
1433
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHeader, { className: "bg-muted", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.TableRow, { children: [
|
|
1434
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Status" }),
|
|
1435
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Plan" }),
|
|
1436
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Period" }),
|
|
1437
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { className: "text-right", children: "Amount" }),
|
|
1438
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { className: "text-right", children: "Actions" })
|
|
1439
1439
|
] }) }),
|
|
1440
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1440
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableBody, { children: subscriptions.map((subscription) => {
|
|
1441
1441
|
const price = subscription.price;
|
|
1442
1442
|
const amount = _optionalChain([price, 'optionalAccess', _42 => _42.unitAmount]) ? formatCurrency(price.unitAmount, price.currency) : "0";
|
|
1443
1443
|
const period = `${formatDate3(subscription.currentPeriodStart)} - ${formatDate3(subscription.currentPeriodEnd)}`;
|
|
1444
1444
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1445
|
-
|
|
1445
|
+
_chunkGKY5DAIHjs.TableRow,
|
|
1446
1446
|
{
|
|
1447
1447
|
onClick: () => handleRowClick(subscription),
|
|
1448
1448
|
className: "cursor-pointer hover:bg-muted/50",
|
|
1449
1449
|
children: [
|
|
1450
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1450
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1451
1451
|
SubscriptionStatusBadge,
|
|
1452
1452
|
{
|
|
1453
1453
|
status: subscription.status,
|
|
1454
1454
|
cancelAtPeriodEnd: subscription.cancelAtPeriodEnd
|
|
1455
1455
|
}
|
|
1456
1456
|
) }),
|
|
1457
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1458
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1459
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1460
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1461
|
-
|
|
1457
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "font-medium", children: formatPlanName3(price) }),
|
|
1458
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-muted-foreground text-sm", children: period }),
|
|
1459
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-right font-medium", children: amount }),
|
|
1460
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-right", children: (subscription.status === "active" /* ACTIVE */ || subscription.status === "trialing" /* TRIALING */) && onChangePlan && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1461
|
+
_chunkGKY5DAIHjs.Button,
|
|
1462
1462
|
{
|
|
1463
1463
|
size: "sm",
|
|
1464
1464
|
variant: "outline",
|
|
@@ -1503,7 +1503,7 @@ function SubscriptionsContainer({ onOpenWizard, hasActiveRecurringSubscription }
|
|
|
1503
1503
|
const loadSubscriptions = _react.useCallback.call(void 0, async () => {
|
|
1504
1504
|
setLoading(true);
|
|
1505
1505
|
try {
|
|
1506
|
-
const fetchedSubscriptions = await
|
|
1506
|
+
const fetchedSubscriptions = await _chunkZNGEVB5Mjs.StripeSubscriptionService.listSubscriptions();
|
|
1507
1507
|
setSubscriptions(fetchedSubscriptions);
|
|
1508
1508
|
} catch (error) {
|
|
1509
1509
|
console.error("[SubscriptionsContainer] Failed to load subscriptions:", error);
|
|
@@ -1526,7 +1526,7 @@ function SubscriptionsContainer({ onOpenWizard, hasActiveRecurringSubscription }
|
|
|
1526
1526
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.CreditCard, { className: "h-8 w-8" }),
|
|
1527
1527
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h1", { className: "text-3xl font-bold", children: "Subscriptions" })
|
|
1528
1528
|
] }),
|
|
1529
|
-
subscriptions.length > 0 && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1529
|
+
subscriptions.length > 0 && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: () => _optionalChain([onOpenWizard, 'optionalCall', _43 => _43()]), children: hasActiveRecurringSubscription ? "Purchase Add-ons" : "Subscribe to a Plan" })
|
|
1530
1530
|
] }),
|
|
1531
1531
|
criticalSubscriptions.map((subscription) => /* @__PURE__ */ _jsxruntime.jsx.call(void 0, BillingAlertBanner, { subscription }, subscription.id)),
|
|
1532
1532
|
subscriptions.length === 0 && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-col items-center justify-center py-12 space-y-4", children: [
|
|
@@ -1534,7 +1534,7 @@ function SubscriptionsContainer({ onOpenWizard, hasActiveRecurringSubscription }
|
|
|
1534
1534
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "text-center", children: [
|
|
1535
1535
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h3", { className: "text-xl font-semibold mb-2", children: "No Active Subscriptions" }),
|
|
1536
1536
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-muted-foreground mb-6", children: "Choose a subscription plan to get started with our services." }),
|
|
1537
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1537
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: () => _optionalChain([onOpenWizard, 'optionalCall', _44 => _44()]), children: "Subscribe to a Plan" })
|
|
1538
1538
|
] })
|
|
1539
1539
|
] }),
|
|
1540
1540
|
subscriptions.length > 0 && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
@@ -1555,9 +1555,9 @@ function IntervalToggle({ value, onChange, hasMonthly, hasYearly }) {
|
|
|
1555
1555
|
if (!hasMonthly || !hasYearly) {
|
|
1556
1556
|
return null;
|
|
1557
1557
|
}
|
|
1558
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1559
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1560
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1558
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Tabs, { value, onValueChange: (v) => onChange(v), children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.TabsList, { children: [
|
|
1559
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TabsTrigger, { value: "month", children: "Monthly" }),
|
|
1560
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TabsTrigger, { value: "year", children: "Yearly" })
|
|
1561
1561
|
] }) });
|
|
1562
1562
|
}
|
|
1563
1563
|
_chunk7QVYU63Ejs.__name.call(void 0, IntervalToggle, "IntervalToggle");
|
|
@@ -1589,7 +1589,7 @@ function PricingCard({
|
|
|
1589
1589
|
}
|
|
1590
1590
|
}, "handleClick");
|
|
1591
1591
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1592
|
-
|
|
1592
|
+
_chunkGKY5DAIHjs.Card,
|
|
1593
1593
|
{
|
|
1594
1594
|
role: "radio",
|
|
1595
1595
|
"aria-checked": isSelected,
|
|
@@ -1597,7 +1597,7 @@ function PricingCard({
|
|
|
1597
1597
|
tabIndex: isDisabled ? -1 : 0,
|
|
1598
1598
|
onKeyDown: handleKeyDown,
|
|
1599
1599
|
onClick: handleClick,
|
|
1600
|
-
className:
|
|
1600
|
+
className: _chunkZNGEVB5Mjs.cn.call(void 0,
|
|
1601
1601
|
"relative cursor-pointer transition-all duration-200 flex flex-col h-full",
|
|
1602
1602
|
"focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",
|
|
1603
1603
|
isCurrentPlan && "bg-muted/30",
|
|
@@ -1607,9 +1607,9 @@ function PricingCard({
|
|
|
1607
1607
|
isLoading && "pointer-events-none"
|
|
1608
1608
|
),
|
|
1609
1609
|
children: [
|
|
1610
|
-
isCurrentPlan && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1611
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1612
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
1610
|
+
isCurrentPlan && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Badge, { variant: "secondary", className: "absolute top-2 right-2", children: "Current" }),
|
|
1611
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "pb-2", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h3", { className: "font-semibold text-lg", children: description }) }),
|
|
1612
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { className: "pb-4 grow", children: [
|
|
1613
1613
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "mb-4", children: [
|
|
1614
1614
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: "text-3xl font-bold", children: formattedPrice }),
|
|
1615
1615
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: "text-muted-foreground ml-1", children: interval })
|
|
@@ -1619,8 +1619,8 @@ function PricingCard({
|
|
|
1619
1619
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: "text-sm text-muted-foreground", children: feature })
|
|
1620
1620
|
] }, index)) })
|
|
1621
1621
|
] }),
|
|
1622
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1623
|
-
|
|
1622
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardFooter, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1623
|
+
_chunkGKY5DAIHjs.Button,
|
|
1624
1624
|
{
|
|
1625
1625
|
variant: isCurrentPlan ? "secondary" : isSelected ? "default" : "outline",
|
|
1626
1626
|
className: "w-full",
|
|
@@ -1748,15 +1748,15 @@ function ProductPricingList({
|
|
|
1748
1748
|
_chunk7QVYU63Ejs.__name.call(void 0, ProductPricingList, "ProductPricingList");
|
|
1749
1749
|
function ProductPricingListSkeleton() {
|
|
1750
1750
|
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "space-y-6", children: [1, 2].map((rowIndex) => /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-3", children: [
|
|
1751
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1751
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-6 w-32" }),
|
|
1752
1752
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 gap-4", children: [1, 2, 3].map((cardIndex) => /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "p-4 rounded-lg border animate-pulse space-y-3", children: [
|
|
1753
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1754
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1753
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-6 w-24" }),
|
|
1754
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-8 w-32" }),
|
|
1755
1755
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
1756
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1757
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1756
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-full" }),
|
|
1757
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-4 w-3/4" })
|
|
1758
1758
|
] }),
|
|
1759
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1759
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Skeleton, { className: "h-10 w-full" })
|
|
1760
1760
|
] }, cardIndex)) })
|
|
1761
1761
|
] }, rowIndex)) });
|
|
1762
1762
|
}
|
|
@@ -1811,8 +1811,8 @@ function SubscriptionConfirmation({ price, isLoading, onConfirm, onCancel }) {
|
|
|
1811
1811
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { children: feature })
|
|
1812
1812
|
] }, index)) }),
|
|
1813
1813
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex justify-end gap-3 pt-2 border-t border-accent/30", children: [
|
|
1814
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1815
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
1814
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: onCancel, disabled: isLoading, children: "Cancel" }),
|
|
1815
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: onConfirm, disabled: isLoading, children: isLoading ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
|
|
1816
1816
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Loader2, { className: "h-4 w-4 animate-spin mr-2" }),
|
|
1817
1817
|
"Processing..."
|
|
1818
1818
|
] }) : "Subscribe" })
|
|
@@ -1883,7 +1883,7 @@ function useSubscriptionWizard({ subscription, onSuccess, onClose }) {
|
|
|
1883
1883
|
onCloseRef.current = onClose;
|
|
1884
1884
|
const checkPaymentMethod = _react.useCallback.call(void 0, async () => {
|
|
1885
1885
|
try {
|
|
1886
|
-
const methods = await
|
|
1886
|
+
const methods = await _chunkZNGEVB5Mjs.StripeCustomerService.listPaymentMethods();
|
|
1887
1887
|
dispatch({ type: "SET_HAS_PAYMENT_METHOD", hasMethod: methods.length > 0 });
|
|
1888
1888
|
} catch (error) {
|
|
1889
1889
|
console.error("[useSubscriptionWizard] Failed to check payment methods:", error);
|
|
@@ -1907,7 +1907,7 @@ function useSubscriptionWizard({ subscription, onSuccess, onClose }) {
|
|
|
1907
1907
|
const isTrialUpgrade = _optionalChain([subscription, 'optionalAccess', _55 => _55.status]) === "trialing" /* TRIALING */;
|
|
1908
1908
|
dispatch({ type: "SET_IS_TRIAL_SUBSCRIPTION", isTrial: isTrialUpgrade });
|
|
1909
1909
|
if (isTrialUpgrade && !state.hasPaymentMethod) {
|
|
1910
|
-
const methods = await
|
|
1910
|
+
const methods = await _chunkZNGEVB5Mjs.StripeCustomerService.listPaymentMethods();
|
|
1911
1911
|
if (methods.length === 0) {
|
|
1912
1912
|
dispatch({ type: "SET_STEP", step: "payment-method" });
|
|
1913
1913
|
dispatch({
|
|
@@ -1918,7 +1918,7 @@ function useSubscriptionWizard({ subscription, onSuccess, onClose }) {
|
|
|
1918
1918
|
}
|
|
1919
1919
|
}
|
|
1920
1920
|
if (subscription && state.selectedPrice.id !== _optionalChain([subscription, 'access', _56 => _56.price, 'optionalAccess', _57 => _57.id])) {
|
|
1921
|
-
const preview = await
|
|
1921
|
+
const preview = await _chunkZNGEVB5Mjs.StripeSubscriptionService.getProrationPreview({
|
|
1922
1922
|
subscriptionId: subscription.id,
|
|
1923
1923
|
newPriceId: state.selectedPrice.id
|
|
1924
1924
|
});
|
|
@@ -1947,7 +1947,7 @@ function useSubscriptionWizard({ subscription, onSuccess, onClose }) {
|
|
|
1947
1947
|
promotionCode: _optionalChain([state, 'access', _61 => _61.promotionCode, 'optionalAccess', _62 => _62.promotionCodeId])
|
|
1948
1948
|
};
|
|
1949
1949
|
console.log("[useSubscriptionWizard] changePlan params:", JSON.stringify(changePlanParams, null, 2));
|
|
1950
|
-
await
|
|
1950
|
+
await _chunkZNGEVB5Mjs.StripeSubscriptionService.changePlan(changePlanParams);
|
|
1951
1951
|
} else {
|
|
1952
1952
|
const createParams = {
|
|
1953
1953
|
id: _uuid.v4.call(void 0, ),
|
|
@@ -1955,7 +1955,7 @@ function useSubscriptionWizard({ subscription, onSuccess, onClose }) {
|
|
|
1955
1955
|
promotionCode: _optionalChain([state, 'access', _63 => _63.promotionCode, 'optionalAccess', _64 => _64.promotionCodeId])
|
|
1956
1956
|
};
|
|
1957
1957
|
console.log("[useSubscriptionWizard] createSubscription params:", JSON.stringify(createParams, null, 2));
|
|
1958
|
-
await
|
|
1958
|
+
await _chunkZNGEVB5Mjs.StripeSubscriptionService.createSubscription(createParams);
|
|
1959
1959
|
}
|
|
1960
1960
|
onSuccessRef.current();
|
|
1961
1961
|
onCloseRef.current();
|
|
@@ -1990,7 +1990,7 @@ function useSubscriptionWizard({ subscription, onSuccess, onClose }) {
|
|
|
1990
1990
|
dispatch({ type: "SET_VALIDATING_PROMO_CODE", isValidating: true });
|
|
1991
1991
|
dispatch({ type: "SET_PROMO_CODE_ERROR", error: null });
|
|
1992
1992
|
try {
|
|
1993
|
-
const result = await
|
|
1993
|
+
const result = await _chunkZNGEVB5Mjs.StripePromotionCodeService.validatePromotionCode({
|
|
1994
1994
|
code,
|
|
1995
1995
|
stripePriceId: _optionalChain([state, 'access', _72 => _72.selectedPrice, 'optionalAccess', _73 => _73.id])
|
|
1996
1996
|
});
|
|
@@ -2097,7 +2097,7 @@ function WizardStepPlanSelection({
|
|
|
2097
2097
|
_react.useEffect.call(void 0, () => {
|
|
2098
2098
|
const loadProducts = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
2099
2099
|
try {
|
|
2100
|
-
const fetchedProducts = await
|
|
2100
|
+
const fetchedProducts = await _chunkZNGEVB5Mjs.StripeProductService.listProducts({ active: true });
|
|
2101
2101
|
setProducts(fetchedProducts);
|
|
2102
2102
|
} catch (error) {
|
|
2103
2103
|
console.error("[WizardStepPlanSelection] Failed to load products:", error);
|
|
@@ -2148,7 +2148,7 @@ function WizardStepPlanSelection({
|
|
|
2148
2148
|
onSelectPrice: handleSelectPrice
|
|
2149
2149
|
}
|
|
2150
2150
|
),
|
|
2151
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "flex justify-end pt-4 border-t", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2151
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "flex justify-end pt-4 border-t", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: onNext, disabled: !selectedPrice || isProcessing, children: isProcessing ? "Loading..." : "Next: Review" }) })
|
|
2152
2152
|
] });
|
|
2153
2153
|
}
|
|
2154
2154
|
_chunk7QVYU63Ejs.__name.call(void 0, WizardStepPlanSelection, "WizardStepPlanSelection");
|
|
@@ -2209,7 +2209,7 @@ function PromoCodeInput({
|
|
|
2209
2209
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "span", { className: "text-sm text-green-600", children: formatDiscount(appliedCode) })
|
|
2210
2210
|
] }),
|
|
2211
2211
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2212
|
-
|
|
2212
|
+
_chunkGKY5DAIHjs.Button,
|
|
2213
2213
|
{
|
|
2214
2214
|
variant: "ghost",
|
|
2215
2215
|
size: "sm",
|
|
@@ -2226,7 +2226,7 @@ function PromoCodeInput({
|
|
|
2226
2226
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
2227
2227
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex gap-2", children: [
|
|
2228
2228
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2229
|
-
|
|
2229
|
+
_chunkGKY5DAIHjs.Input,
|
|
2230
2230
|
{
|
|
2231
2231
|
placeholder: "Enter promo code",
|
|
2232
2232
|
value: code,
|
|
@@ -2236,7 +2236,7 @@ function PromoCodeInput({
|
|
|
2236
2236
|
className: "flex-1"
|
|
2237
2237
|
}
|
|
2238
2238
|
),
|
|
2239
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2239
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: handleApply, disabled: disabled || isValidating || !code.trim(), children: isValidating ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Loader2, { className: "h-4 w-4 animate-spin" }) : "Apply" })
|
|
2240
2240
|
] }),
|
|
2241
2241
|
error && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-red-500", children: error })
|
|
2242
2242
|
] });
|
|
@@ -2360,15 +2360,15 @@ function WizardStepReview({
|
|
|
2360
2360
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h4", { className: "font-medium", children: "Payment Method" }),
|
|
2361
2361
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-muted-foreground", children: hasPaymentMethod ? "A payment method is on file" : "No payment method on file" })
|
|
2362
2362
|
] }),
|
|
2363
|
-
!hasPaymentMethod && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2363
|
+
!hasPaymentMethod && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: onAddPaymentMethod, children: "Add Payment Method" })
|
|
2364
2364
|
] }) }),
|
|
2365
|
-
error && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2365
|
+
error && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Alert, { variant: "destructive", children: [
|
|
2366
2366
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.AlertCircle, { className: "h-4 w-4" }),
|
|
2367
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2367
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDescription, { children: error })
|
|
2368
2368
|
] }),
|
|
2369
2369
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex justify-between pt-4 border-t", children: [
|
|
2370
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2371
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2370
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", onClick: onBack, disabled: isProcessing, children: "Back" }),
|
|
2371
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: hasPaymentMethod ? onConfirm : onAddPaymentMethod, disabled: isProcessing, children: isProcessing ? "Processing..." : hasPaymentMethod ? isChangingPlan ? "Confirm Plan Change" : "Subscribe Now" : "Add Payment Method" })
|
|
2372
2372
|
] })
|
|
2373
2373
|
] });
|
|
2374
2374
|
}
|
|
@@ -2421,10 +2421,10 @@ function SubscriptionWizard({
|
|
|
2421
2421
|
const isChangePlanMode = !!subscription;
|
|
2422
2422
|
const dialogTitle = subscription ? "Change Subscription Plan" : isPurchasingAddons ? "Purchase Add-ons" : "Subscribe to a Plan";
|
|
2423
2423
|
const dialogDescription = subscription ? "Select a new plan for your subscription" : isPurchasingAddons ? "Select one-time products to purchase" : "Choose a subscription plan to get started";
|
|
2424
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2425
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2426
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2427
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2424
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: "max-w-2xl", children: [
|
|
2425
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: [
|
|
2426
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: dialogTitle }),
|
|
2427
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogDescription, { children: dialogDescription })
|
|
2428
2428
|
] }),
|
|
2429
2429
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, WizardProgressIndicator, { currentStep: state.step }),
|
|
2430
2430
|
state.step === "plan-selection" && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
@@ -2507,15 +2507,15 @@ function UsageSummaryCard({ meter, summary }) {
|
|
|
2507
2507
|
const progressWidth = percentage !== null ? Math.min(percentage, 100) : 0;
|
|
2508
2508
|
const displayName = meter.displayName || meter.eventName;
|
|
2509
2509
|
const hasLimit = limit !== null && limit !== void 0;
|
|
2510
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2511
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2510
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
2511
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "flex flex-row items-center gap-x-3 pb-3", children: [
|
|
2512
2512
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "flex h-10 w-10 items-center justify-center rounded-lg bg-blue-100 text-blue-600", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Activity, { className: "h-5 w-5" }) }),
|
|
2513
2513
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-col", children: [
|
|
2514
2514
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h3", { className: "font-semibold", children: displayName }),
|
|
2515
2515
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-xs text-gray-500", children: meter.id })
|
|
2516
2516
|
] })
|
|
2517
2517
|
] }),
|
|
2518
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2518
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardContent, { className: "flex flex-col gap-y-4", children: [
|
|
2519
2519
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { children: [
|
|
2520
2520
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-3xl font-bold", children: currentUsage.toLocaleString() }),
|
|
2521
2521
|
hasLimit && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "p", { className: "text-sm text-gray-500", children: [
|
|
@@ -2562,14 +2562,14 @@ function UsageContainer() {
|
|
|
2562
2562
|
const loadUsageData = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
2563
2563
|
setLoading(true);
|
|
2564
2564
|
try {
|
|
2565
|
-
const fetchedSubscriptions = await
|
|
2565
|
+
const fetchedSubscriptions = await _chunkZNGEVB5Mjs.StripeSubscriptionService.listSubscriptions();
|
|
2566
2566
|
setSubscriptions(fetchedSubscriptions);
|
|
2567
2567
|
const hasMeteredSubscriptions2 = fetchedSubscriptions.some((sub) => _optionalChain([sub, 'access', _101 => _101.price, 'optionalAccess', _102 => _102.recurring, 'optionalAccess', _103 => _103.usageType]) === "metered");
|
|
2568
2568
|
if (!hasMeteredSubscriptions2) {
|
|
2569
2569
|
setLoading(false);
|
|
2570
2570
|
return;
|
|
2571
2571
|
}
|
|
2572
|
-
const fetchedMeters = await
|
|
2572
|
+
const fetchedMeters = await _chunkZNGEVB5Mjs.StripeUsageService.listMeters();
|
|
2573
2573
|
setMeters(fetchedMeters);
|
|
2574
2574
|
const summariesMap = {};
|
|
2575
2575
|
const now = /* @__PURE__ */ new Date();
|
|
@@ -2577,7 +2577,7 @@ function UsageContainer() {
|
|
|
2577
2577
|
const endOfMonth = new Date(now.getFullYear(), now.getMonth() + 1, 0, 23, 59, 59, 999);
|
|
2578
2578
|
for (const meter of fetchedMeters) {
|
|
2579
2579
|
try {
|
|
2580
|
-
const meterSummaries = await
|
|
2580
|
+
const meterSummaries = await _chunkZNGEVB5Mjs.StripeUsageService.getMeterSummaries({
|
|
2581
2581
|
meterId: meter.id,
|
|
2582
2582
|
startTime: startOfMonth,
|
|
2583
2583
|
endTime: endOfMonth
|
|
@@ -2643,21 +2643,21 @@ function UsageHistoryTable({ usageRecords }) {
|
|
|
2643
2643
|
}
|
|
2644
2644
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex w-full flex-col gap-y-4", children: [
|
|
2645
2645
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h2", { className: "text-xl font-semibold", children: "Usage History" }),
|
|
2646
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "overflow-clip rounded-lg border", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2647
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2648
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2649
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2650
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2651
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2646
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "overflow-clip rounded-lg border", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Table, { children: [
|
|
2647
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHeader, { className: "bg-muted", children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.TableRow, { children: [
|
|
2648
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Date & Time" }),
|
|
2649
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Meter Event" }),
|
|
2650
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { className: "text-right", children: "Quantity" }),
|
|
2651
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableHead, { children: "Event ID" })
|
|
2652
2652
|
] }) }),
|
|
2653
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2653
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableBody, { children: usageRecords.map((record) => {
|
|
2654
2654
|
const dateTime = formatDateTime(record.timestamp);
|
|
2655
2655
|
const quantity = record.quantity.toLocaleString();
|
|
2656
|
-
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2657
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2658
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2659
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2660
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2656
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.TableRow, { children: [
|
|
2657
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "font-medium", children: dateTime }),
|
|
2658
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-muted-foreground", children: record.meterEventName }),
|
|
2659
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-right font-medium", children: quantity }),
|
|
2660
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.TableCell, { className: "text-muted-foreground text-sm font-mono", children: record.stripeEventId })
|
|
2661
2661
|
] }, record.id);
|
|
2662
2662
|
}) })
|
|
2663
2663
|
] }) })
|
|
@@ -2668,8 +2668,8 @@ _chunk7QVYU63Ejs.__name.call(void 0, UsageHistoryTable, "UsageHistoryTable");
|
|
|
2668
2668
|
// src/features/billing/components/modals/BillingDetailModal.tsx
|
|
2669
2669
|
|
|
2670
2670
|
function BillingDetailModal({ open, onOpenChange, title, children, className }) {
|
|
2671
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2672
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2671
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: _nullishCoalesce(className, () => ( "max-w-4xl max-h-[90vh] overflow-y-auto")), children: [
|
|
2672
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: title }) }),
|
|
2673
2673
|
children
|
|
2674
2674
|
] }) });
|
|
2675
2675
|
}
|
|
@@ -2686,7 +2686,7 @@ function BillingAlertBanner({ subscription, onUpdatePayment, onAddPayment }) {
|
|
|
2686
2686
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h3", { className: "font-semibold text-red-900", children: "Payment Failed" }),
|
|
2687
2687
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-sm text-red-700 mt-1", children: "Your last payment failed. Please update your payment method to avoid service interruption." })
|
|
2688
2688
|
] }),
|
|
2689
|
-
onUpdatePayment && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2689
|
+
onUpdatePayment && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", size: "sm", onClick: onUpdatePayment, className: "border-red-300 text-red-700", children: "Update Payment Method" })
|
|
2690
2690
|
] });
|
|
2691
2691
|
}
|
|
2692
2692
|
if (subscription.status === "trialing" /* TRIALING */ && subscription.trialEnd) {
|
|
@@ -2706,7 +2706,7 @@ function BillingAlertBanner({ subscription, onUpdatePayment, onAddPayment }) {
|
|
|
2706
2706
|
". Add a payment method to continue your subscription."
|
|
2707
2707
|
] })
|
|
2708
2708
|
] }),
|
|
2709
|
-
onAddPayment && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2709
|
+
onAddPayment && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", size: "sm", onClick: onAddPayment, className: "border-yellow-300 text-yellow-700", children: "Add Payment Method" })
|
|
2710
2710
|
] });
|
|
2711
2711
|
}
|
|
2712
2712
|
}
|
|
@@ -2757,7 +2757,7 @@ function BillingDashboardContainer() {
|
|
|
2757
2757
|
setNoCustomerExists(false);
|
|
2758
2758
|
let customer = null;
|
|
2759
2759
|
try {
|
|
2760
|
-
customer = await
|
|
2760
|
+
customer = await _chunkZNGEVB5Mjs.StripeCustomerService.getCustomer();
|
|
2761
2761
|
setData((prev) => ({ ...prev, customer }));
|
|
2762
2762
|
setErrors((prev) => ({ ...prev, customer: null }));
|
|
2763
2763
|
setNoCustomerExists(false);
|
|
@@ -2782,7 +2782,7 @@ function BillingDashboardContainer() {
|
|
|
2782
2782
|
if (customer) {
|
|
2783
2783
|
const fetchSubscriptions = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
2784
2784
|
try {
|
|
2785
|
-
const subscriptions2 = await
|
|
2785
|
+
const subscriptions2 = await _chunkZNGEVB5Mjs.StripeSubscriptionService.listSubscriptions();
|
|
2786
2786
|
setData((prev) => ({ ...prev, subscriptions: subscriptions2 }));
|
|
2787
2787
|
setErrors((prev) => ({ ...prev, subscriptions: null }));
|
|
2788
2788
|
return subscriptions2;
|
|
@@ -2796,7 +2796,7 @@ function BillingDashboardContainer() {
|
|
|
2796
2796
|
}, "fetchSubscriptions");
|
|
2797
2797
|
const fetchPaymentMethods = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
2798
2798
|
try {
|
|
2799
|
-
const paymentMethods = await
|
|
2799
|
+
const paymentMethods = await _chunkZNGEVB5Mjs.StripeCustomerService.listPaymentMethods();
|
|
2800
2800
|
setData((prev) => ({ ...prev, paymentMethods }));
|
|
2801
2801
|
setErrors((prev) => ({ ...prev, paymentMethods: null }));
|
|
2802
2802
|
} catch (error) {
|
|
@@ -2808,7 +2808,7 @@ function BillingDashboardContainer() {
|
|
|
2808
2808
|
}, "fetchPaymentMethods");
|
|
2809
2809
|
const fetchInvoices = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
2810
2810
|
try {
|
|
2811
|
-
const invoices = await
|
|
2811
|
+
const invoices = await _chunkZNGEVB5Mjs.StripeInvoiceService.listInvoices();
|
|
2812
2812
|
setData((prev) => ({ ...prev, invoices }));
|
|
2813
2813
|
setErrors((prev) => ({ ...prev, invoices: null }));
|
|
2814
2814
|
} catch (error) {
|
|
@@ -2832,7 +2832,7 @@ function BillingDashboardContainer() {
|
|
|
2832
2832
|
const handleCreateCustomer = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
2833
2833
|
setCreatingCustomer(true);
|
|
2834
2834
|
try {
|
|
2835
|
-
await
|
|
2835
|
+
await _chunkZNGEVB5Mjs.StripeCustomerService.createCustomer();
|
|
2836
2836
|
setNoCustomerExists(false);
|
|
2837
2837
|
await fetchAllData();
|
|
2838
2838
|
} catch (error) {
|
|
@@ -2844,7 +2844,7 @@ function BillingDashboardContainer() {
|
|
|
2844
2844
|
}, "handleCreateCustomer");
|
|
2845
2845
|
const fetchUsageData = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
2846
2846
|
try {
|
|
2847
|
-
const meters = await
|
|
2847
|
+
const meters = await _chunkZNGEVB5Mjs.StripeUsageService.listMeters();
|
|
2848
2848
|
setData((prev) => ({ ...prev, meters }));
|
|
2849
2849
|
const summariesMap = {};
|
|
2850
2850
|
const now = /* @__PURE__ */ new Date();
|
|
@@ -2852,7 +2852,7 @@ function BillingDashboardContainer() {
|
|
|
2852
2852
|
const endOfMonth = new Date(now.getFullYear(), now.getMonth() + 1, 0, 23, 59, 59, 999);
|
|
2853
2853
|
for (const meter of meters) {
|
|
2854
2854
|
try {
|
|
2855
|
-
const meterSummaries = await
|
|
2855
|
+
const meterSummaries = await _chunkZNGEVB5Mjs.StripeUsageService.getMeterSummaries({
|
|
2856
2856
|
meterId: meter.id,
|
|
2857
2857
|
startTime: startOfMonth,
|
|
2858
2858
|
endTime: endOfMonth
|
|
@@ -2930,18 +2930,18 @@ function BillingDashboardContainer() {
|
|
|
2930
2930
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Wallet, { className: "h-8 w-8" }),
|
|
2931
2931
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h1", { className: "text-3xl font-bold", children: "Billing" })
|
|
2932
2932
|
] }),
|
|
2933
|
-
isInitialLoading && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2934
|
-
noCustomerExists && !isInitialLoading && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2935
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
2933
|
+
isInitialLoading && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Card, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { className: "flex items-center justify-center py-12", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Loader2, { className: "h-8 w-8 animate-spin text-muted-foreground" }) }) }),
|
|
2934
|
+
noCustomerExists && !isInitialLoading && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Card, { children: [
|
|
2935
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.CardHeader, { className: "text-center", children: [
|
|
2936
2936
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "mx-auto mb-4 flex h-16 w-16 items-center justify-center rounded-full bg-primary/10", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.CreditCard, { className: "h-8 w-8 text-primary" }) }),
|
|
2937
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2938
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2937
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardTitle, { children: "Set Up Billing" }),
|
|
2938
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardDescription, { children: "Your company doesn't have a billing account yet. Set one up to manage subscriptions, payment methods, and view invoices." })
|
|
2939
2939
|
] }),
|
|
2940
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2940
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { className: "flex justify-center pb-8", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: handleCreateCustomer, disabled: creatingCustomer, size: "lg", children: creatingCustomer ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
|
|
2941
2941
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Loader2, { className: "mr-2 h-4 w-4 animate-spin" }),
|
|
2942
2942
|
"Setting up..."
|
|
2943
2943
|
] }) : "Set Up Billing Account" }) }),
|
|
2944
|
-
errors.customer && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
2944
|
+
errors.customer && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CardContent, { className: "pt-0", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-center text-sm text-destructive", children: errors.customer }) })
|
|
2945
2945
|
] }),
|
|
2946
2946
|
!noCustomerExists && !isInitialLoading && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _jsxruntime.Fragment, { children: [
|
|
2947
2947
|
criticalSubscriptions.map((subscription) => /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
@@ -3083,7 +3083,7 @@ function getStripePromise(publishableKey) {
|
|
|
3083
3083
|
}
|
|
3084
3084
|
_chunk7QVYU63Ejs.__name.call(void 0, getStripePromise, "getStripePromise");
|
|
3085
3085
|
function StripeProvider({ children }) {
|
|
3086
|
-
const publishableKey =
|
|
3086
|
+
const publishableKey = _chunkT5YYOT4Zjs.getStripePublishableKey.call(void 0, );
|
|
3087
3087
|
const stripePromise = _react.useMemo.call(void 0, () => getStripePromise(publishableKey), [publishableKey]);
|
|
3088
3088
|
const options = _react.useMemo.call(void 0, () => ({}), []);
|
|
3089
3089
|
if (!publishableKey) {
|
|
@@ -3093,7 +3093,7 @@ function StripeProvider({ children }) {
|
|
|
3093
3093
|
}
|
|
3094
3094
|
_chunk7QVYU63Ejs.__name.call(void 0, StripeProvider, "StripeProvider");
|
|
3095
3095
|
function isStripeConfigured() {
|
|
3096
|
-
return !!
|
|
3096
|
+
return !!_chunkT5YYOT4Zjs.getStripePublishableKey.call(void 0, );
|
|
3097
3097
|
}
|
|
3098
3098
|
_chunk7QVYU63Ejs.__name.call(void 0, isStripeConfigured, "isStripeConfigured");
|
|
3099
3099
|
|
|
@@ -3111,7 +3111,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3111
3111
|
_react.useEffect.call(void 0, () => {
|
|
3112
3112
|
const fetchFeatures = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
3113
3113
|
try {
|
|
3114
|
-
const features = await
|
|
3114
|
+
const features = await _chunkZNGEVB5Mjs.FeatureService.findMany({});
|
|
3115
3115
|
setAllFeatures(features);
|
|
3116
3116
|
} catch (error) {
|
|
3117
3117
|
console.error("[PriceEditor] Failed to fetch features:", error);
|
|
@@ -3189,7 +3189,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3189
3189
|
try {
|
|
3190
3190
|
const unitAmountInCents = Math.round(values.unitAmount * 100);
|
|
3191
3191
|
if (isEditMode) {
|
|
3192
|
-
await
|
|
3192
|
+
await _chunkZNGEVB5Mjs.StripePriceService.updatePrice({
|
|
3193
3193
|
id: price.id,
|
|
3194
3194
|
nickname: values.nickname || void 0,
|
|
3195
3195
|
description: values.description || void 0,
|
|
@@ -3231,7 +3231,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3231
3231
|
createInput.featureIds = values.featureIds;
|
|
3232
3232
|
}
|
|
3233
3233
|
}
|
|
3234
|
-
await
|
|
3234
|
+
await _chunkZNGEVB5Mjs.StripePriceService.createPrice(createInput);
|
|
3235
3235
|
}
|
|
3236
3236
|
onSuccess();
|
|
3237
3237
|
onOpenChange(false);
|
|
@@ -3257,10 +3257,10 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3257
3257
|
{ id: "licensed", text: "Licensed (per unit)" },
|
|
3258
3258
|
{ id: "metered", text: "Metered (usage-based)" }
|
|
3259
3259
|
];
|
|
3260
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3261
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3262
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3263
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3260
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: "max-w-2xl", children: [
|
|
3261
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: [
|
|
3262
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: isEditMode ? "Edit Price" : "Create Price" }),
|
|
3263
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogDescription, { children: isEditMode ? "Update the price details. Note: Only nickname and active status can be changed." : "Create a new price for this product" })
|
|
3264
3264
|
] }),
|
|
3265
3265
|
isEditMode && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "bg-blue-50 border border-blue-200 rounded-lg p-4 flex gap-x-3", children: [
|
|
3266
3266
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.AlertCircle, { className: "h-5 w-5 text-blue-600 flex-shrink-0 mt-0.5" }),
|
|
@@ -3269,10 +3269,10 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3269
3269
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { children: "Due to Stripe's architecture, only the nickname and active status can be modified after creation. To change amount, currency, or billing interval, create a new price." })
|
|
3270
3270
|
] })
|
|
3271
3271
|
] }),
|
|
3272
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3272
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Form, { ...form, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "form", { onSubmit: form.handleSubmit(onSubmit), className: "flex flex-col gap-y-4", children: [
|
|
3273
3273
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "grid grid-cols-2 gap-x-4", children: [
|
|
3274
3274
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3275
|
-
|
|
3275
|
+
_chunkGKY5DAIHjs.FormInput,
|
|
3276
3276
|
{
|
|
3277
3277
|
form,
|
|
3278
3278
|
id: "unitAmount",
|
|
@@ -3282,10 +3282,10 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3282
3282
|
isRequired: true
|
|
3283
3283
|
}
|
|
3284
3284
|
),
|
|
3285
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3285
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.FormSelect, { form, id: "currency", name: "Currency", values: currencyOptions, disabled: isEditMode })
|
|
3286
3286
|
] }),
|
|
3287
3287
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3288
|
-
|
|
3288
|
+
_chunkGKY5DAIHjs.FormSelect,
|
|
3289
3289
|
{
|
|
3290
3290
|
form,
|
|
3291
3291
|
id: "interval",
|
|
@@ -3296,7 +3296,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3296
3296
|
),
|
|
3297
3297
|
isRecurring && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "grid grid-cols-2 gap-x-4", children: [
|
|
3298
3298
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3299
|
-
|
|
3299
|
+
_chunkGKY5DAIHjs.FormInput,
|
|
3300
3300
|
{
|
|
3301
3301
|
form,
|
|
3302
3302
|
id: "intervalCount",
|
|
@@ -3307,7 +3307,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3307
3307
|
}
|
|
3308
3308
|
),
|
|
3309
3309
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3310
|
-
|
|
3310
|
+
_chunkGKY5DAIHjs.FormSelect,
|
|
3311
3311
|
{
|
|
3312
3312
|
form,
|
|
3313
3313
|
id: "usageType",
|
|
@@ -3318,7 +3318,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3318
3318
|
)
|
|
3319
3319
|
] }),
|
|
3320
3320
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3321
|
-
|
|
3321
|
+
_chunkGKY5DAIHjs.FormInput,
|
|
3322
3322
|
{
|
|
3323
3323
|
form,
|
|
3324
3324
|
id: "nickname",
|
|
@@ -3327,7 +3327,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3327
3327
|
}
|
|
3328
3328
|
),
|
|
3329
3329
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3330
|
-
|
|
3330
|
+
_chunkGKY5DAIHjs.FormTextarea,
|
|
3331
3331
|
{
|
|
3332
3332
|
form,
|
|
3333
3333
|
id: "description",
|
|
@@ -3336,13 +3336,13 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3336
3336
|
className: "min-h-24"
|
|
3337
3337
|
}
|
|
3338
3338
|
),
|
|
3339
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3339
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.FormInput, { form, id: "token", name: "Token (optional)", placeholder: "Enter token value" }),
|
|
3340
3340
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
3341
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3341
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Label, { children: "Features (optional)" }),
|
|
3342
3342
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
3343
3343
|
form.watch("features").map((_, index) => /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex gap-2", children: [
|
|
3344
3344
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3345
|
-
|
|
3345
|
+
_chunkGKY5DAIHjs.Input,
|
|
3346
3346
|
{
|
|
3347
3347
|
...form.register(`features.${index}`),
|
|
3348
3348
|
placeholder: `Feature ${index + 1}`,
|
|
@@ -3350,7 +3350,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3350
3350
|
}
|
|
3351
3351
|
),
|
|
3352
3352
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3353
|
-
|
|
3353
|
+
_chunkGKY5DAIHjs.Button,
|
|
3354
3354
|
{
|
|
3355
3355
|
type: "button",
|
|
3356
3356
|
variant: "outline",
|
|
@@ -3367,7 +3367,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3367
3367
|
)
|
|
3368
3368
|
] }, index)),
|
|
3369
3369
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3370
|
-
|
|
3370
|
+
_chunkGKY5DAIHjs.Button,
|
|
3371
3371
|
{
|
|
3372
3372
|
type: "button",
|
|
3373
3373
|
variant: "outline",
|
|
@@ -3386,7 +3386,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3386
3386
|
] })
|
|
3387
3387
|
] }),
|
|
3388
3388
|
isRecurring && allFeatures.length > 0 && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-2", children: [
|
|
3389
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3389
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Label, { children: "Platform Features" }),
|
|
3390
3390
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "border rounded-md p-4 space-y-2 max-h-48 overflow-y-auto", children: allFeatures.map((feature) => {
|
|
3391
3391
|
const isCore = feature.isCore;
|
|
3392
3392
|
const isChecked = form.watch("featureIds").includes(feature.id);
|
|
@@ -3428,9 +3428,9 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3428
3428
|
] }, feature.id);
|
|
3429
3429
|
}) })
|
|
3430
3430
|
] }),
|
|
3431
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3431
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.FormCheckbox, { form, id: "active", name: "Active" }),
|
|
3432
3432
|
isRecurring && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3433
|
-
|
|
3433
|
+
_chunkGKY5DAIHjs.FormCheckbox,
|
|
3434
3434
|
{
|
|
3435
3435
|
form,
|
|
3436
3436
|
id: "isTrial",
|
|
@@ -3438,7 +3438,7 @@ function PriceEditor({ productId, price, open, onOpenChange, onSuccess }) {
|
|
|
3438
3438
|
description: "Mark this as the trial subscription plan (only one price should be marked as trial)"
|
|
3439
3439
|
}
|
|
3440
3440
|
),
|
|
3441
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3441
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CommonEditorButtons, { isEdit: isEditMode, form, disabled: isSubmitting, setOpen: onOpenChange })
|
|
3442
3442
|
] }) })
|
|
3443
3443
|
] }) });
|
|
3444
3444
|
}
|
|
@@ -3460,7 +3460,7 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3460
3460
|
const loadPrices = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
3461
3461
|
setLoading(true);
|
|
3462
3462
|
try {
|
|
3463
|
-
const fetchedPrices = await
|
|
3463
|
+
const fetchedPrices = await _chunkZNGEVB5Mjs.StripePriceService.listPrices({ productId });
|
|
3464
3464
|
setPrices(fetchedPrices);
|
|
3465
3465
|
} catch (error) {
|
|
3466
3466
|
console.error("[PricesList] Failed to load prices:", error);
|
|
@@ -3477,7 +3477,7 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3477
3477
|
}
|
|
3478
3478
|
setArchivingPriceId(priceToArchive.id);
|
|
3479
3479
|
try {
|
|
3480
|
-
await
|
|
3480
|
+
await _chunkZNGEVB5Mjs.StripePriceService.archivePrice({ id: priceToArchive.id });
|
|
3481
3481
|
setPriceToArchive(null);
|
|
3482
3482
|
await loadPrices();
|
|
3483
3483
|
onPricesChange();
|
|
@@ -3493,7 +3493,7 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3493
3493
|
}
|
|
3494
3494
|
setReactivatingPriceId(priceToReactivate.id);
|
|
3495
3495
|
try {
|
|
3496
|
-
await
|
|
3496
|
+
await _chunkZNGEVB5Mjs.StripePriceService.reactivatePrice({ id: priceToReactivate.id });
|
|
3497
3497
|
setPriceToReactivate(null);
|
|
3498
3498
|
await loadPrices();
|
|
3499
3499
|
onPricesChange();
|
|
@@ -3524,12 +3524,12 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3524
3524
|
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-col gap-y-4", children: [
|
|
3525
3525
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center justify-between mb-4", children: [
|
|
3526
3526
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h4", { className: "text-lg font-semibold", children: "Prices" }),
|
|
3527
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3527
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { size: "sm", onClick: () => setShowCreatePrice(true), children: "Add Price" })
|
|
3528
3528
|
] }),
|
|
3529
3529
|
prices.length === 0 && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "bg-background flex flex-col items-center justify-center gap-y-3 rounded-lg border border-dashed p-8", children: [
|
|
3530
3530
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.DollarSign, { className: "text-muted-foreground h-12 w-12" }),
|
|
3531
3531
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-muted-foreground text-sm", children: "No prices yet. Add a price to enable subscriptions." }),
|
|
3532
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3532
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { size: "sm", onClick: () => setShowCreatePrice(true), children: "Add Price" })
|
|
3533
3533
|
] }),
|
|
3534
3534
|
prices.length > 0 && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4", children: prices.map((price) => {
|
|
3535
3535
|
const isArchiving = archivingPriceId === price.id;
|
|
@@ -3538,9 +3538,9 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3538
3538
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-start justify-between mb-3", children: [
|
|
3539
3539
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.DollarSign, { className: "h-5 w-5 text-primary" }),
|
|
3540
3540
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex gap-1", children: [
|
|
3541
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3541
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "ghost", size: "sm", onClick: () => setEditingPrice(price), className: "h-8 w-8 p-0", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Edit, { className: "h-4 w-4" }) }),
|
|
3542
3542
|
price.active ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3543
|
-
|
|
3543
|
+
_chunkGKY5DAIHjs.Button,
|
|
3544
3544
|
{
|
|
3545
3545
|
variant: "ghost",
|
|
3546
3546
|
size: "sm",
|
|
@@ -3550,7 +3550,7 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3550
3550
|
children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Archive, { className: "h-4 w-4" })
|
|
3551
3551
|
}
|
|
3552
3552
|
) : /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3553
|
-
|
|
3553
|
+
_chunkGKY5DAIHjs.Button,
|
|
3554
3554
|
{
|
|
3555
3555
|
variant: "ghost",
|
|
3556
3556
|
size: "sm",
|
|
@@ -3601,20 +3601,20 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3601
3601
|
}
|
|
3602
3602
|
}
|
|
3603
3603
|
),
|
|
3604
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3605
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3606
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3607
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3604
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialog, { open: !!priceToArchive, onOpenChange: (open) => !open && setPriceToArchive(null), children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogContent, { children: [
|
|
3605
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogHeader, { children: [
|
|
3606
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogTitle, { children: "Archive Price" }),
|
|
3607
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogDescription, { children: [
|
|
3608
3608
|
"Are you sure you want to archive the price for",
|
|
3609
3609
|
" ",
|
|
3610
3610
|
priceToArchive && `${formatCurrency(priceToArchive.unitAmount, priceToArchive.currency)} ${formatInterval2(priceToArchive)}`,
|
|
3611
3611
|
"? This will prevent new subscriptions but existing ones will continue."
|
|
3612
3612
|
] })
|
|
3613
3613
|
] }),
|
|
3614
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3615
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3614
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogFooter, { children: [
|
|
3615
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogCancel, { disabled: !!archivingPriceId, children: "Cancel" }),
|
|
3616
3616
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3617
|
-
|
|
3617
|
+
_chunkGKY5DAIHjs.AlertDialogAction,
|
|
3618
3618
|
{
|
|
3619
3619
|
onClick: handleArchive,
|
|
3620
3620
|
disabled: !!archivingPriceId,
|
|
@@ -3624,20 +3624,20 @@ function PricesList({ productId, onPricesChange }) {
|
|
|
3624
3624
|
)
|
|
3625
3625
|
] })
|
|
3626
3626
|
] }) }),
|
|
3627
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3628
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3629
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3630
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3627
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialog, { open: !!priceToReactivate, onOpenChange: (open) => !open && setPriceToReactivate(null), children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogContent, { children: [
|
|
3628
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogHeader, { children: [
|
|
3629
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogTitle, { children: "Reactivate Price" }),
|
|
3630
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogDescription, { children: [
|
|
3631
3631
|
"Are you sure you want to reactivate the price for",
|
|
3632
3632
|
" ",
|
|
3633
3633
|
priceToReactivate && `${formatCurrency(priceToReactivate.unitAmount, priceToReactivate.currency)} ${formatInterval2(priceToReactivate)}`,
|
|
3634
3634
|
"? This will allow new subscriptions again."
|
|
3635
3635
|
] })
|
|
3636
3636
|
] }),
|
|
3637
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3638
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3637
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogFooter, { children: [
|
|
3638
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogCancel, { disabled: !!reactivatingPriceId, children: "Cancel" }),
|
|
3639
3639
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3640
|
-
|
|
3640
|
+
_chunkGKY5DAIHjs.AlertDialogAction,
|
|
3641
3641
|
{
|
|
3642
3642
|
onClick: handleReactivate,
|
|
3643
3643
|
disabled: !!reactivatingPriceId,
|
|
@@ -3681,14 +3681,14 @@ function ProductEditor({ product, open, onOpenChange, onSuccess }) {
|
|
|
3681
3681
|
setIsSubmitting(true);
|
|
3682
3682
|
try {
|
|
3683
3683
|
if (product) {
|
|
3684
|
-
await
|
|
3684
|
+
await _chunkZNGEVB5Mjs.StripeProductService.updateProduct({
|
|
3685
3685
|
id: product.id,
|
|
3686
3686
|
name: values.name,
|
|
3687
3687
|
description: values.description,
|
|
3688
3688
|
active: values.active
|
|
3689
3689
|
});
|
|
3690
3690
|
} else {
|
|
3691
|
-
await
|
|
3691
|
+
await _chunkZNGEVB5Mjs.StripeProductService.createProduct({
|
|
3692
3692
|
id: _uuid.v4.call(void 0, ),
|
|
3693
3693
|
name: values.name,
|
|
3694
3694
|
description: values.description,
|
|
@@ -3703,15 +3703,15 @@ function ProductEditor({ product, open, onOpenChange, onSuccess }) {
|
|
|
3703
3703
|
setIsSubmitting(false);
|
|
3704
3704
|
}
|
|
3705
3705
|
}, "onSubmit");
|
|
3706
|
-
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3707
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3708
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3709
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3706
|
+
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Dialog, { open, onOpenChange, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogContent, { className: "max-w-2xl", children: [
|
|
3707
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.DialogHeader, { children: [
|
|
3708
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogTitle, { children: product ? "Edit Product" : "Create Product" }),
|
|
3709
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.DialogDescription, { children: product ? `Update the details for ${product.name}` : "Create a new product to offer to your customers" })
|
|
3710
3710
|
] }),
|
|
3711
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3712
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3711
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Form, { ...form, children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "form", { onSubmit: form.handleSubmit(onSubmit), className: "flex flex-col gap-y-4", children: [
|
|
3712
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.FormInput, { form, id: "name", name: "Product Name", placeholder: "Enter product name", isRequired: true }),
|
|
3713
3713
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3714
|
-
|
|
3714
|
+
_chunkGKY5DAIHjs.FormTextarea,
|
|
3715
3715
|
{
|
|
3716
3716
|
form,
|
|
3717
3717
|
id: "description",
|
|
@@ -3720,8 +3720,8 @@ function ProductEditor({ product, open, onOpenChange, onSuccess }) {
|
|
|
3720
3720
|
className: "min-h-32"
|
|
3721
3721
|
}
|
|
3722
3722
|
),
|
|
3723
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3724
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3723
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.FormCheckbox, { form, id: "active", name: "Active" }),
|
|
3724
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.CommonEditorButtons, { isEdit: !!product, form, disabled: isSubmitting, setOpen: onOpenChange })
|
|
3725
3725
|
] }) })
|
|
3726
3726
|
] }) });
|
|
3727
3727
|
}
|
|
@@ -3744,7 +3744,7 @@ function ProductsList({ products, onProductsChange }) {
|
|
|
3744
3744
|
}
|
|
3745
3745
|
setArchivingProductId(productToArchive.id);
|
|
3746
3746
|
try {
|
|
3747
|
-
const _archivedProduct = await
|
|
3747
|
+
const _archivedProduct = await _chunkZNGEVB5Mjs.StripeProductService.archiveProduct({ id: productToArchive.id });
|
|
3748
3748
|
setProductToArchive(null);
|
|
3749
3749
|
onProductsChange();
|
|
3750
3750
|
} catch (_error) {
|
|
@@ -3759,7 +3759,7 @@ function ProductsList({ products, onProductsChange }) {
|
|
|
3759
3759
|
}
|
|
3760
3760
|
setReactivatingProductId(productToReactivate.id);
|
|
3761
3761
|
try {
|
|
3762
|
-
const _reactivatedProduct = await
|
|
3762
|
+
const _reactivatedProduct = await _chunkZNGEVB5Mjs.StripeProductService.reactivateProduct({ id: productToReactivate.id });
|
|
3763
3763
|
setProductToReactivate(null);
|
|
3764
3764
|
onProductsChange();
|
|
3765
3765
|
} catch (_error) {
|
|
@@ -3788,12 +3788,12 @@ function ProductsList({ products, onProductsChange }) {
|
|
|
3788
3788
|
] })
|
|
3789
3789
|
] }),
|
|
3790
3790
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex items-center gap-x-2", children: [
|
|
3791
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3791
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "outline", size: "sm", onClick: () => setEditingProduct(product), children: [
|
|
3792
3792
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Edit, { className: "h-4 w-4 mr-1" }),
|
|
3793
3793
|
"Edit"
|
|
3794
3794
|
] }),
|
|
3795
3795
|
product.active ? /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3796
|
-
|
|
3796
|
+
_chunkGKY5DAIHjs.Button,
|
|
3797
3797
|
{
|
|
3798
3798
|
variant: "outline",
|
|
3799
3799
|
size: "sm",
|
|
@@ -3805,7 +3805,7 @@ function ProductsList({ products, onProductsChange }) {
|
|
|
3805
3805
|
]
|
|
3806
3806
|
}
|
|
3807
3807
|
) : /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3808
|
-
|
|
3808
|
+
_chunkGKY5DAIHjs.Button,
|
|
3809
3809
|
{
|
|
3810
3810
|
variant: "outline",
|
|
3811
3811
|
size: "sm",
|
|
@@ -3817,7 +3817,7 @@ function ProductsList({ products, onProductsChange }) {
|
|
|
3817
3817
|
]
|
|
3818
3818
|
}
|
|
3819
3819
|
),
|
|
3820
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3820
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { variant: "ghost", size: "sm", onClick: () => toggleExpand(product.id), children: isExpanded ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.ChevronUp, { className: "h-5 w-5" }) : /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.ChevronDown, { className: "h-5 w-5" }) })
|
|
3821
3821
|
] })
|
|
3822
3822
|
] }),
|
|
3823
3823
|
isExpanded && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "border-t bg-muted/30 p-6", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, PricesList, { productId: product.id, onPricesChange: onProductsChange }) })
|
|
@@ -3835,19 +3835,19 @@ function ProductsList({ products, onProductsChange }) {
|
|
|
3835
3835
|
}
|
|
3836
3836
|
}
|
|
3837
3837
|
),
|
|
3838
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3839
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3840
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3841
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3838
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialog, { open: !!productToArchive, onOpenChange: (open) => !open && setProductToArchive(null), children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogContent, { children: [
|
|
3839
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogHeader, { children: [
|
|
3840
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogTitle, { children: "Archive Product" }),
|
|
3841
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogDescription, { children: [
|
|
3842
3842
|
'Are you sure you want to archive "',
|
|
3843
3843
|
_optionalChain([productToArchive, 'optionalAccess', _167 => _167.name]),
|
|
3844
3844
|
'"? This will deactivate it and it will no longer be available for new subscriptions.'
|
|
3845
3845
|
] })
|
|
3846
3846
|
] }),
|
|
3847
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3848
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3847
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogFooter, { children: [
|
|
3848
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogCancel, { disabled: !!archivingProductId, children: "Cancel" }),
|
|
3849
3849
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3850
|
-
|
|
3850
|
+
_chunkGKY5DAIHjs.AlertDialogAction,
|
|
3851
3851
|
{
|
|
3852
3852
|
onClick: handleArchive,
|
|
3853
3853
|
disabled: !!archivingProductId,
|
|
@@ -3857,19 +3857,19 @@ function ProductsList({ products, onProductsChange }) {
|
|
|
3857
3857
|
)
|
|
3858
3858
|
] })
|
|
3859
3859
|
] }) }),
|
|
3860
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3861
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3862
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3863
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3860
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialog, { open: !!productToReactivate, onOpenChange: (open) => !open && setProductToReactivate(null), children: /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogContent, { children: [
|
|
3861
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogHeader, { children: [
|
|
3862
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogTitle, { children: "Reactivate Product" }),
|
|
3863
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogDescription, { children: [
|
|
3864
3864
|
'Are you sure you want to reactivate "',
|
|
3865
3865
|
_optionalChain([productToReactivate, 'optionalAccess', _168 => _168.name]),
|
|
3866
3866
|
'"? This will make it available for new subscriptions again.'
|
|
3867
3867
|
] })
|
|
3868
3868
|
] }),
|
|
3869
|
-
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
|
|
3870
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3869
|
+
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _chunkGKY5DAIHjs.AlertDialogFooter, { children: [
|
|
3870
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.AlertDialogCancel, { disabled: !!reactivatingProductId, children: "Cancel" }),
|
|
3871
3871
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3872
|
-
|
|
3872
|
+
_chunkGKY5DAIHjs.AlertDialogAction,
|
|
3873
3873
|
{
|
|
3874
3874
|
onClick: handleReactivate,
|
|
3875
3875
|
disabled: !!reactivatingProductId,
|
|
@@ -3886,17 +3886,17 @@ _chunk7QVYU63Ejs.__name.call(void 0, ProductsList, "ProductsList");
|
|
|
3886
3886
|
// src/features/billing/stripe-product/components/containers/ProductsAdminContainer.tsx
|
|
3887
3887
|
|
|
3888
3888
|
function ProductsAdminContainer() {
|
|
3889
|
-
const { hasRole } =
|
|
3889
|
+
const { hasRole } = _chunkGKY5DAIHjs.useCurrentUserContext.call(void 0, );
|
|
3890
3890
|
const [products, setProducts] = _react.useState.call(void 0, []);
|
|
3891
3891
|
const [loading, setLoading] = _react.useState.call(void 0, true);
|
|
3892
3892
|
const [showCreateProduct, setShowCreateProduct] = _react.useState.call(void 0, false);
|
|
3893
|
-
if (!hasRole(
|
|
3893
|
+
if (!hasRole(_chunkT5YYOT4Zjs.getRoleId.call(void 0, ).Administrator)) {
|
|
3894
3894
|
return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "flex h-64 items-center justify-center", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-red-600 font-semibold", children: "Permission denied. Administrator access required." }) });
|
|
3895
3895
|
}
|
|
3896
3896
|
const loadProducts = /* @__PURE__ */ _chunk7QVYU63Ejs.__name.call(void 0, async () => {
|
|
3897
3897
|
setLoading(true);
|
|
3898
3898
|
try {
|
|
3899
|
-
const fetchedProducts = await
|
|
3899
|
+
const fetchedProducts = await _chunkZNGEVB5Mjs.StripeProductService.listProducts();
|
|
3900
3900
|
setProducts(fetchedProducts);
|
|
3901
3901
|
} catch (error) {
|
|
3902
3902
|
console.error("[ProductsAdminContainer] Failed to load products:", error);
|
|
@@ -3916,14 +3916,14 @@ function ProductsAdminContainer() {
|
|
|
3916
3916
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Package, { className: "h-8 w-8" }),
|
|
3917
3917
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h1", { className: "text-3xl font-bold", children: "Product & Price Management" })
|
|
3918
3918
|
] }),
|
|
3919
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3919
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: () => setShowCreateProduct(true), children: "Create Product" })
|
|
3920
3920
|
] }),
|
|
3921
3921
|
products.length === 0 && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "bg-muted/50 flex flex-col items-center justify-center gap-y-4 rounded-lg border-2 border-dashed p-12", children: [
|
|
3922
3922
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _lucidereact.Package, { className: "text-muted-foreground h-16 w-16" }),
|
|
3923
3923
|
/* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "text-center", children: [
|
|
3924
3924
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h3", { className: "mb-2 text-xl font-semibold", children: "No products yet" }),
|
|
3925
3925
|
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-muted-foreground mb-4", children: "Create your first product to start offering subscriptions to your customers." }),
|
|
3926
|
-
/* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
3926
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkGKY5DAIHjs.Button, { onClick: () => setShowCreateProduct(true), children: "Create Your First Product" })
|
|
3927
3927
|
] })
|
|
3928
3928
|
] }),
|
|
3929
3929
|
products.length > 0 && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, ProductsList, { products, onProductsChange: loadProducts }),
|