@varity-labs/ui-kit 2.0.0-alpha.1 → 2.0.0-beta.10
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/LICENSE +1 -1
- package/README.md +227 -203
- package/dist/components/Analytics/DataTable.js +1 -1
- package/dist/components/Analytics/DataTable.js.map +1 -1
- package/dist/components/Analytics/EnhancedKPICard.d.ts +21 -0
- package/dist/components/Analytics/EnhancedKPICard.d.ts.map +1 -0
- package/dist/components/Analytics/EnhancedKPICard.js +135 -0
- package/dist/components/Analytics/EnhancedKPICard.js.map +1 -0
- package/dist/components/Analytics/Sparkline.d.ts +44 -0
- package/dist/components/Analytics/Sparkline.d.ts.map +1 -0
- package/dist/components/Analytics/Sparkline.js +90 -0
- package/dist/components/Analytics/Sparkline.js.map +1 -0
- package/dist/components/Analytics/index.d.ts +2 -0
- package/dist/components/Analytics/index.d.ts.map +1 -1
- package/dist/components/Analytics/index.js +2 -0
- package/dist/components/Analytics/index.js.map +1 -1
- package/dist/components/Dashboard/DashboardFooter.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardFooter.js +22 -6
- package/dist/components/Dashboard/DashboardFooter.js.map +1 -1
- package/dist/components/Dashboard/DashboardHeader.d.ts +10 -0
- package/dist/components/Dashboard/DashboardHeader.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardHeader.js +191 -58
- package/dist/components/Dashboard/DashboardHeader.js.map +1 -1
- package/dist/components/Dashboard/DashboardLayout.d.ts +13 -3
- package/dist/components/Dashboard/DashboardLayout.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardLayout.js +9 -4
- package/dist/components/Dashboard/DashboardLayout.js.map +1 -1
- package/dist/components/Dashboard/DashboardSidebar.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardSidebar.js +41 -12
- package/dist/components/Dashboard/DashboardSidebar.js.map +1 -1
- package/dist/components/Dashboard/EmptyState.js +5 -5
- package/dist/components/Dashboard/EmptyState.js.map +1 -1
- package/dist/components/Dashboard/KPICard.js +5 -5
- package/dist/components/Dashboard/KPICard.js.map +1 -1
- package/dist/components/Display/Avatar.d.ts +21 -0
- package/dist/components/Display/Avatar.d.ts.map +1 -0
- package/dist/components/Display/Avatar.js +71 -0
- package/dist/components/Display/Avatar.js.map +1 -0
- package/dist/components/Display/Badge.d.ts +22 -0
- package/dist/components/Display/Badge.d.ts.map +1 -0
- package/dist/components/Display/Badge.js +60 -0
- package/dist/components/Display/Badge.js.map +1 -0
- package/dist/components/Display/ProgressBar.d.ts +12 -0
- package/dist/components/Display/ProgressBar.d.ts.map +1 -0
- package/dist/components/Display/ProgressBar.js +33 -0
- package/dist/components/Display/ProgressBar.js.map +1 -0
- package/dist/components/Display/index.d.ts +9 -0
- package/dist/components/Display/index.d.ts.map +1 -0
- package/dist/components/Display/index.js +9 -0
- package/dist/components/Display/index.js.map +1 -0
- package/dist/components/Feedback/Skeleton.d.ts +10 -0
- package/dist/components/Feedback/Skeleton.d.ts.map +1 -0
- package/dist/components/Feedback/Skeleton.js +25 -0
- package/dist/components/Feedback/Skeleton.js.map +1 -0
- package/dist/components/Feedback/Toast.d.ts +18 -0
- package/dist/components/Feedback/Toast.d.ts.map +1 -0
- package/dist/components/Feedback/Toast.js +38 -0
- package/dist/components/Feedback/Toast.js.map +1 -0
- package/dist/components/Feedback/ToastProvider.d.ts +11 -0
- package/dist/components/Feedback/ToastProvider.d.ts.map +1 -0
- package/dist/components/Feedback/ToastProvider.js +36 -0
- package/dist/components/Feedback/ToastProvider.js.map +1 -0
- package/dist/components/Feedback/index.d.ts +11 -0
- package/dist/components/Feedback/index.d.ts.map +1 -0
- package/dist/components/Feedback/index.js +9 -0
- package/dist/components/Feedback/index.js.map +1 -0
- package/dist/components/Feedback/useToast.d.ts +3 -0
- package/dist/components/Feedback/useToast.d.ts.map +1 -0
- package/dist/components/Feedback/useToast.js +10 -0
- package/dist/components/Feedback/useToast.js.map +1 -0
- package/dist/components/Form/Button.d.ts +12 -0
- package/dist/components/Form/Button.d.ts.map +1 -0
- package/dist/components/Form/Button.js +22 -0
- package/dist/components/Form/Button.js.map +1 -0
- package/dist/components/Form/Checkbox.d.ts +13 -0
- package/dist/components/Form/Checkbox.d.ts.map +1 -0
- package/dist/components/Form/Checkbox.js +36 -0
- package/dist/components/Form/Checkbox.js.map +1 -0
- package/dist/components/Form/Input.d.ts +9 -0
- package/dist/components/Form/Input.d.ts.map +1 -0
- package/dist/components/Form/Input.js +16 -0
- package/dist/components/Form/Input.js.map +1 -0
- package/dist/components/Form/RadioGroup.d.ts +20 -0
- package/dist/components/Form/RadioGroup.d.ts.map +1 -0
- package/dist/components/Form/RadioGroup.js +43 -0
- package/dist/components/Form/RadioGroup.js.map +1 -0
- package/dist/components/Form/Select.d.ts +12 -0
- package/dist/components/Form/Select.d.ts.map +1 -0
- package/dist/components/Form/Select.js +13 -0
- package/dist/components/Form/Select.js.map +1 -0
- package/dist/components/Form/Textarea.d.ts +8 -0
- package/dist/components/Form/Textarea.d.ts.map +1 -0
- package/dist/components/Form/Textarea.js +13 -0
- package/dist/components/Form/Textarea.js.map +1 -0
- package/dist/components/Form/Toggle.d.ts +12 -0
- package/dist/components/Form/Toggle.d.ts.map +1 -0
- package/dist/components/Form/Toggle.js +48 -0
- package/dist/components/Form/Toggle.js.map +1 -0
- package/dist/components/Form/index.d.ts +13 -0
- package/dist/components/Form/index.d.ts.map +1 -0
- package/dist/components/Form/index.js +13 -0
- package/dist/components/Form/index.js.map +1 -0
- package/dist/components/InAppWallet/InAppWalletProvider.d.ts +4 -4
- package/dist/components/InAppWallet/InAppWalletProvider.d.ts.map +1 -1
- package/dist/components/InAppWallet/InAppWalletProvider.js +15 -28
- package/dist/components/InAppWallet/InAppWalletProvider.js.map +1 -1
- package/dist/components/Navigation/Breadcrumb.d.ts +15 -0
- package/dist/components/Navigation/Breadcrumb.d.ts.map +1 -0
- package/dist/components/Navigation/Breadcrumb.js +28 -0
- package/dist/components/Navigation/Breadcrumb.js.map +1 -0
- package/dist/components/Navigation/CommandPalette.d.ts +26 -0
- package/dist/components/Navigation/CommandPalette.d.ts.map +1 -0
- package/dist/components/Navigation/CommandPalette.js +172 -0
- package/dist/components/Navigation/CommandPalette.js.map +1 -0
- package/dist/components/Navigation/index.d.ts +8 -0
- package/dist/components/Navigation/index.d.ts.map +1 -0
- package/dist/components/Navigation/index.js +8 -0
- package/dist/components/Navigation/index.js.map +1 -0
- package/dist/components/Onramp/BuyUSDCButton.d.ts +9 -7
- package/dist/components/Onramp/BuyUSDCButton.d.ts.map +1 -1
- package/dist/components/Onramp/BuyUSDCButton.js +37 -47
- package/dist/components/Onramp/BuyUSDCButton.js.map +1 -1
- package/dist/components/Onramp/OnrampWidget.d.ts +7 -6
- package/dist/components/Onramp/OnrampWidget.d.ts.map +1 -1
- package/dist/components/Onramp/OnrampWidget.js +58 -37
- package/dist/components/Onramp/OnrampWidget.js.map +1 -1
- package/dist/components/Onramp/index.d.ts +3 -5
- package/dist/components/Onramp/index.d.ts.map +1 -1
- package/dist/components/Onramp/index.js +3 -5
- package/dist/components/Onramp/index.js.map +1 -1
- package/dist/components/Overlay/ConfirmDialog.d.ts +14 -0
- package/dist/components/Overlay/ConfirmDialog.d.ts.map +1 -0
- package/dist/components/Overlay/ConfirmDialog.js +11 -0
- package/dist/components/Overlay/ConfirmDialog.js.map +1 -0
- package/dist/components/Overlay/Dialog.d.ts +11 -0
- package/dist/components/Overlay/Dialog.d.ts.map +1 -0
- package/dist/components/Overlay/Dialog.js +69 -0
- package/dist/components/Overlay/Dialog.js.map +1 -0
- package/dist/components/Overlay/DropdownMenu.d.ts +17 -0
- package/dist/components/Overlay/DropdownMenu.d.ts.map +1 -0
- package/dist/components/Overlay/DropdownMenu.js +123 -0
- package/dist/components/Overlay/DropdownMenu.js.map +1 -0
- package/dist/components/Overlay/index.d.ts +9 -0
- package/dist/components/Overlay/index.d.ts.map +1 -0
- package/dist/components/Overlay/index.js +9 -0
- package/dist/components/Overlay/index.js.map +1 -0
- package/dist/components/PaymentWidget/PaymentGate.d.ts +30 -0
- package/dist/components/PaymentWidget/PaymentGate.d.ts.map +1 -0
- package/dist/components/PaymentWidget/PaymentGate.js +54 -0
- package/dist/components/PaymentWidget/PaymentGate.js.map +1 -0
- package/dist/components/PaymentWidget/PaymentWidget.d.ts +40 -0
- package/dist/components/PaymentWidget/PaymentWidget.d.ts.map +1 -0
- package/dist/components/PaymentWidget/PaymentWidget.js +195 -0
- package/dist/components/PaymentWidget/PaymentWidget.js.map +1 -0
- package/dist/components/PaymentWidget/index.d.ts +30 -0
- package/dist/components/PaymentWidget/index.d.ts.map +1 -0
- package/dist/components/PaymentWidget/index.js +32 -0
- package/dist/components/PaymentWidget/index.js.map +1 -0
- package/dist/components/PaymentWidget/types.d.ts +200 -0
- package/dist/components/PaymentWidget/types.d.ts.map +1 -0
- package/dist/components/PaymentWidget/types.js +84 -0
- package/dist/components/PaymentWidget/types.js.map +1 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.d.ts +51 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.d.ts.map +1 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.js +167 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.js.map +1 -0
- package/dist/components/PaymentWidget/useVarityPayment.d.ts +20 -0
- package/dist/components/PaymentWidget/useVarityPayment.d.ts.map +1 -0
- package/dist/components/PaymentWidget/useVarityPayment.js +164 -0
- package/dist/components/PaymentWidget/useVarityPayment.js.map +1 -0
- package/dist/components/Payments/CheckoutModal.d.ts.map +1 -1
- package/dist/components/Payments/CheckoutModal.js +16 -5
- package/dist/components/Payments/CheckoutModal.js.map +1 -1
- package/dist/components/Payments/constants.js +1 -1
- package/dist/components/Payments/constants.js.map +1 -1
- package/dist/components/Privy/InitTimeoutScreen.d.ts.map +1 -1
- package/dist/components/Privy/InitTimeoutScreen.js +1 -1
- package/dist/components/Privy/InitTimeoutScreen.js.map +1 -1
- package/dist/components/Privy/InitializingScreen.d.ts +3 -3
- package/dist/components/Privy/InitializingScreen.d.ts.map +1 -1
- package/dist/components/Privy/InitializingScreen.js +6 -6
- package/dist/components/Privy/InitializingScreen.js.map +1 -1
- package/dist/components/index.d.ts +5 -2
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +20 -4
- package/dist/components/index.js.map +1 -1
- package/dist/config/chains.d.ts +5 -5
- package/dist/config/chains.d.ts.map +1 -1
- package/dist/config/chains.js +8 -8
- package/dist/config/chains.js.map +1 -1
- package/dist/hooks/index.d.ts +1 -11
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +54 -11
- package/dist/hooks/index.js.map +1 -1
- package/dist/index.d.ts +24 -42
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +180 -43
- package/dist/index.js.map +1 -1
- package/dist/providers/PrivyProvider.js +1 -1
- package/dist/providers/PrivyProvider.js.map +1 -1
- package/dist/providers/PrivyStack.d.ts +31 -73
- package/dist/providers/PrivyStack.d.ts.map +1 -1
- package/dist/providers/PrivyStack.js +32 -160
- package/dist/providers/PrivyStack.js.map +1 -1
- package/dist/providers/VarityDashboardProvider.d.ts +7 -10
- package/dist/providers/VarityDashboardProvider.d.ts.map +1 -1
- package/dist/providers/VarityDashboardProvider.js +12 -15
- package/dist/providers/VarityDashboardProvider.js.map +1 -1
- package/dist/providers/WalletSyncProvider.d.ts +17 -24
- package/dist/providers/WalletSyncProvider.d.ts.map +1 -1
- package/dist/providers/WalletSyncProvider.js +16 -27
- package/dist/providers/WalletSyncProvider.js.map +1 -1
- package/dist/providers/ZeroDevProvider.d.ts +69 -0
- package/dist/providers/ZeroDevProvider.d.ts.map +1 -0
- package/dist/providers/ZeroDevProvider.js +208 -0
- package/dist/providers/ZeroDevProvider.js.map +1 -0
- package/dist/providers/index.d.ts +1 -0
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js +2 -0
- package/dist/providers/index.js.map +1 -1
- package/dist/wallets/SimpleSmartWallet.js +1 -1
- package/dist/wallets/SimpleSmartWallet.js.map +1 -1
- package/dist/wallets/SmartWalletProvider.js +1 -1
- package/dist/wallets/SmartWalletProvider.js.map +1 -1
- package/dist/wallets/config.d.ts +31 -8
- package/dist/wallets/config.d.ts.map +1 -1
- package/dist/wallets/config.js +33 -10
- package/dist/wallets/config.js.map +1 -1
- package/dist/wallets/index.d.ts +1 -1
- package/dist/wallets/index.d.ts.map +1 -1
- package/dist/wallets/index.js +1 -1
- package/dist/wallets/index.js.map +1 -1
- package/package.json +34 -26
- package/dist/core/VarityClient.d.ts +0 -76
- package/dist/core/VarityClient.d.ts.map +0 -1
- package/dist/core/VarityClient.js +0 -99
- package/dist/core/VarityClient.js.map +0 -1
- package/dist/core/config.d.ts +0 -136
- package/dist/core/config.d.ts.map +0 -1
- package/dist/core/config.js +0 -156
- package/dist/core/config.js.map +0 -1
- package/dist/hooks/useAnalytics.d.ts +0 -94
- package/dist/hooks/useAnalytics.d.ts.map +0 -1
- package/dist/hooks/useAnalytics.js +0 -116
- package/dist/hooks/useAnalytics.js.map +0 -1
- package/dist/hooks/useAuth.d.ts +0 -71
- package/dist/hooks/useAuth.d.ts.map +0 -1
- package/dist/hooks/useAuth.js +0 -198
- package/dist/hooks/useAuth.js.map +0 -1
- package/dist/hooks/useDashboard.d.ts +0 -110
- package/dist/hooks/useDashboard.d.ts.map +0 -1
- package/dist/hooks/useDashboard.js +0 -201
- package/dist/hooks/useDashboard.js.map +0 -1
- package/dist/hooks/useVarityAPI.d.ts +0 -88
- package/dist/hooks/useVarityAPI.d.ts.map +0 -1
- package/dist/hooks/useVarityAPI.js +0 -138
- package/dist/hooks/useVarityAPI.js.map +0 -1
- package/dist/hooks/useWalletAuth.d.ts +0 -108
- package/dist/hooks/useWalletAuth.d.ts.map +0 -1
- package/dist/hooks/useWalletAuth.js +0 -415
- package/dist/hooks/useWalletAuth.js.map +0 -1
- package/dist/modules/cache/index.d.ts +0 -2
- package/dist/modules/cache/index.d.ts.map +0 -1
- package/dist/modules/cache/index.js +0 -2
- package/dist/modules/cache/index.js.map +0 -1
- package/dist/types/api-extensions.d.ts +0 -92
- package/dist/types/api-extensions.d.ts.map +0 -1
- package/dist/types/api-extensions.js +0 -7
- package/dist/types/api-extensions.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAG9C,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,YAAY,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Payment Components Export
|
|
3
3
|
*
|
|
4
|
-
*
|
|
5
|
-
* - Credit/Debit card
|
|
4
|
+
* Seamless credit card payments for adding funds.
|
|
5
|
+
* - Credit/Debit card
|
|
6
6
|
* - Apple Pay & Google Pay
|
|
7
|
-
* - KYC verification handling
|
|
8
|
-
* - Transaction status tracking
|
|
9
7
|
*/
|
|
10
8
|
export { BuyUSDCButton } from './BuyUSDCButton';
|
|
11
9
|
export { OnrampWidget } from './OnrampWidget';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface ConfirmDialogProps {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onClose: () => void;
|
|
5
|
+
onConfirm: () => void;
|
|
6
|
+
title: string;
|
|
7
|
+
description: string;
|
|
8
|
+
confirmLabel?: string;
|
|
9
|
+
confirmVariant?: 'danger' | 'primary';
|
|
10
|
+
loading?: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare function ConfirmDialog({ open, onClose, onConfirm, title, description, confirmLabel, confirmVariant, loading, }: ConfirmDialogProps): React.JSX.Element;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=ConfirmDialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConfirmDialog.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/ConfirmDialog.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,kBAAkB;IAC1B,IAAI,EAAE,OAAO,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,QAAQ,GAAG,SAAS,CAAC;IACtC,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,aAAa,CAAC,EAC5B,IAAI,EACJ,OAAO,EACP,SAAS,EACT,KAAK,EACL,WAAW,EACX,YAAuB,EACvB,cAAyB,EACzB,OAAe,GAChB,EAAE,kBAAkB,qBAapB"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { Dialog } from './Dialog';
|
|
4
|
+
import { Button } from '../Form/Button';
|
|
5
|
+
export function ConfirmDialog({ open, onClose, onConfirm, title, description, confirmLabel = 'Delete', confirmVariant = 'danger', loading = false, }) {
|
|
6
|
+
return (React.createElement(Dialog, { open: open, onClose: onClose, title: title, description: description },
|
|
7
|
+
React.createElement("div", { className: "flex gap-2 pt-4" },
|
|
8
|
+
React.createElement(Button, { variant: confirmVariant, onClick: onConfirm, loading: loading }, confirmLabel),
|
|
9
|
+
React.createElement(Button, { variant: "secondary", onClick: onClose, disabled: loading }, "Cancel"))));
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=ConfirmDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConfirmDialog.js","sourceRoot":"","sources":["../../../src/components/Overlay/ConfirmDialog.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAaxC,MAAM,UAAU,aAAa,CAAC,EAC5B,IAAI,EACJ,OAAO,EACP,SAAS,EACT,KAAK,EACL,WAAW,EACX,YAAY,GAAG,QAAQ,EACvB,cAAc,GAAG,QAAQ,EACzB,OAAO,GAAG,KAAK,GACI;IACnB,OAAO,CACL,oBAAC,MAAM,IAAC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW;QAC1E,6BAAK,SAAS,EAAC,iBAAiB;YAC9B,oBAAC,MAAM,IAAC,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,IAClE,YAAY,CACN;YACT,oBAAC,MAAM,IAAC,OAAO,EAAC,WAAW,EAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,aAEtD,CACL,CACC,CACV,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React, { type ReactNode } from 'react';
|
|
2
|
+
interface DialogProps {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onClose: () => void;
|
|
5
|
+
title: string;
|
|
6
|
+
description?: string;
|
|
7
|
+
children: ReactNode;
|
|
8
|
+
}
|
|
9
|
+
export declare function Dialog({ open, onClose, title, description, children }: DialogProps): React.JSX.Element | null;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=Dialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Dialog.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/Dialog.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,EAAqB,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAGjE,UAAU,WAAW;IACnB,IAAI,EAAE,OAAO,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,wBAAgB,MAAM,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE,WAAW,4BAgGlF"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import React, { useEffect, useRef } from 'react';
|
|
3
|
+
import { X } from 'lucide-react';
|
|
4
|
+
export function Dialog({ open, onClose, title, description, children }) {
|
|
5
|
+
const overlayRef = useRef(null);
|
|
6
|
+
const contentRef = useRef(null);
|
|
7
|
+
useEffect(() => {
|
|
8
|
+
if (!open)
|
|
9
|
+
return;
|
|
10
|
+
const handleEscape = (e) => {
|
|
11
|
+
if (e.key === 'Escape')
|
|
12
|
+
onClose();
|
|
13
|
+
};
|
|
14
|
+
// Get all focusable elements
|
|
15
|
+
const getFocusableElements = () => {
|
|
16
|
+
return contentRef.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
|
|
17
|
+
};
|
|
18
|
+
// Focus trap handler
|
|
19
|
+
const handleTabKey = (e) => {
|
|
20
|
+
if (e.key !== 'Tab')
|
|
21
|
+
return;
|
|
22
|
+
const focusableElements = getFocusableElements();
|
|
23
|
+
if (!focusableElements || focusableElements.length === 0)
|
|
24
|
+
return;
|
|
25
|
+
const firstElement = focusableElements[0];
|
|
26
|
+
const lastElement = focusableElements[focusableElements.length - 1];
|
|
27
|
+
if (e.shiftKey && document.activeElement === firstElement) {
|
|
28
|
+
lastElement.focus();
|
|
29
|
+
e.preventDefault();
|
|
30
|
+
}
|
|
31
|
+
else if (!e.shiftKey && document.activeElement === lastElement) {
|
|
32
|
+
firstElement.focus();
|
|
33
|
+
e.preventDefault();
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
document.addEventListener('keydown', handleEscape);
|
|
37
|
+
document.addEventListener('keydown', handleTabKey);
|
|
38
|
+
document.body.style.overflow = 'hidden';
|
|
39
|
+
// Focus first focusable element
|
|
40
|
+
const timer = setTimeout(() => {
|
|
41
|
+
const focusableElements = getFocusableElements();
|
|
42
|
+
if (focusableElements && focusableElements.length > 0) {
|
|
43
|
+
focusableElements[0].focus();
|
|
44
|
+
}
|
|
45
|
+
}, 50);
|
|
46
|
+
return () => {
|
|
47
|
+
document.removeEventListener('keydown', handleEscape);
|
|
48
|
+
document.removeEventListener('keydown', handleTabKey);
|
|
49
|
+
document.body.style.overflow = '';
|
|
50
|
+
clearTimeout(timer);
|
|
51
|
+
};
|
|
52
|
+
}, [open, onClose]);
|
|
53
|
+
if (!open)
|
|
54
|
+
return null;
|
|
55
|
+
return (React.createElement("div", { ref: overlayRef, className: "fixed inset-0 z-50 flex items-center justify-center p-4", onClick: (e) => {
|
|
56
|
+
if (e.target === overlayRef.current)
|
|
57
|
+
onClose();
|
|
58
|
+
}, role: "dialog", "aria-modal": "true", "aria-labelledby": "dialog-title" },
|
|
59
|
+
React.createElement("div", { className: "fixed inset-0 bg-black/50 backdrop-blur-sm" }),
|
|
60
|
+
React.createElement("div", { ref: contentRef, className: "relative z-10 w-full max-w-lg rounded-xl border border-gray-200 bg-white p-6 shadow-2xl" },
|
|
61
|
+
React.createElement("div", { className: "mb-4 flex items-start justify-between" },
|
|
62
|
+
React.createElement("div", null,
|
|
63
|
+
React.createElement("h2", { id: "dialog-title", className: "text-lg font-semibold text-gray-900" }, title),
|
|
64
|
+
description && (React.createElement("p", { className: "mt-1 text-sm text-gray-500" }, description))),
|
|
65
|
+
React.createElement("button", { onClick: onClose, className: "rounded-lg p-1 text-gray-400 hover:bg-gray-100 hover:text-gray-600 transition-colors", "aria-label": "Close dialog" },
|
|
66
|
+
React.createElement(X, { className: "h-5 w-5" }))),
|
|
67
|
+
children)));
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=Dialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Dialog.js","sourceRoot":"","sources":["../../../src/components/Overlay/Dialog.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { LucideIcon } from 'lucide-react';
|
|
3
|
+
export interface DropdownMenuItem {
|
|
4
|
+
label: string;
|
|
5
|
+
onClick: () => void;
|
|
6
|
+
icon?: LucideIcon;
|
|
7
|
+
disabled?: boolean;
|
|
8
|
+
danger?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export interface DropdownMenuProps {
|
|
11
|
+
trigger: React.ReactNode;
|
|
12
|
+
items: (DropdownMenuItem | 'divider')[];
|
|
13
|
+
align?: 'left' | 'right';
|
|
14
|
+
className?: string;
|
|
15
|
+
}
|
|
16
|
+
export declare function DropdownMenu({ trigger, items, align, className, }: DropdownMenuProps): React.JSX.Element;
|
|
17
|
+
//# sourceMappingURL=DropdownMenu.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DropdownMenu.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/DropdownMenu.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,IAAI,CAAC,EAAE,UAAU,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,KAAK,EAAE,CAAC,gBAAgB,GAAG,SAAS,CAAC,EAAE,CAAC;IACxC,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,YAAY,CAAC,EAC3B,OAAO,EACP,KAAK,EACL,KAAe,EACf,SAAc,GACf,EAAE,iBAAiB,qBA6KnB"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import React, { useState, useRef, useEffect } from 'react';
|
|
3
|
+
export function DropdownMenu({ trigger, items, align = 'right', className = '', }) {
|
|
4
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
5
|
+
const [focusedIndex, setFocusedIndex] = useState(-1);
|
|
6
|
+
const menuRef = useRef(null);
|
|
7
|
+
const triggerRef = useRef(null);
|
|
8
|
+
// Get only the actual menu items (not dividers)
|
|
9
|
+
const menuItems = items.filter((item) => item !== 'divider');
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
const handleClickOutside = (event) => {
|
|
12
|
+
if (menuRef.current &&
|
|
13
|
+
!menuRef.current.contains(event.target) &&
|
|
14
|
+
triggerRef.current &&
|
|
15
|
+
!triggerRef.current.contains(event.target)) {
|
|
16
|
+
setIsOpen(false);
|
|
17
|
+
setFocusedIndex(-1);
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
if (isOpen) {
|
|
21
|
+
document.addEventListener('mousedown', handleClickOutside);
|
|
22
|
+
return () => document.removeEventListener('mousedown', handleClickOutside);
|
|
23
|
+
}
|
|
24
|
+
}, [isOpen]);
|
|
25
|
+
const handleKeyDown = (e) => {
|
|
26
|
+
if (!isOpen) {
|
|
27
|
+
if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {
|
|
28
|
+
e.preventDefault();
|
|
29
|
+
setIsOpen(true);
|
|
30
|
+
setFocusedIndex(0);
|
|
31
|
+
}
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
switch (e.key) {
|
|
35
|
+
case 'Escape':
|
|
36
|
+
e.preventDefault();
|
|
37
|
+
setIsOpen(false);
|
|
38
|
+
setFocusedIndex(-1);
|
|
39
|
+
triggerRef.current?.focus();
|
|
40
|
+
break;
|
|
41
|
+
case 'ArrowDown':
|
|
42
|
+
e.preventDefault();
|
|
43
|
+
setFocusedIndex((prev) => {
|
|
44
|
+
const nextIndex = prev + 1;
|
|
45
|
+
return nextIndex >= menuItems.length ? 0 : nextIndex;
|
|
46
|
+
});
|
|
47
|
+
break;
|
|
48
|
+
case 'ArrowUp':
|
|
49
|
+
e.preventDefault();
|
|
50
|
+
setFocusedIndex((prev) => {
|
|
51
|
+
const nextIndex = prev - 1;
|
|
52
|
+
return nextIndex < 0 ? menuItems.length - 1 : nextIndex;
|
|
53
|
+
});
|
|
54
|
+
break;
|
|
55
|
+
case 'Enter':
|
|
56
|
+
case ' ':
|
|
57
|
+
e.preventDefault();
|
|
58
|
+
if (focusedIndex >= 0 && focusedIndex < menuItems.length) {
|
|
59
|
+
const item = menuItems[focusedIndex];
|
|
60
|
+
if (!item.disabled) {
|
|
61
|
+
item.onClick();
|
|
62
|
+
setIsOpen(false);
|
|
63
|
+
setFocusedIndex(-1);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
break;
|
|
67
|
+
case 'Tab':
|
|
68
|
+
// Focus trap: keep focus within menu
|
|
69
|
+
e.preventDefault();
|
|
70
|
+
if (e.shiftKey) {
|
|
71
|
+
// Shift+Tab: move backwards
|
|
72
|
+
setFocusedIndex((prev) => {
|
|
73
|
+
const nextIndex = prev - 1;
|
|
74
|
+
return nextIndex < 0 ? menuItems.length - 1 : nextIndex;
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
// Tab: move forwards
|
|
79
|
+
setFocusedIndex((prev) => {
|
|
80
|
+
const nextIndex = prev + 1;
|
|
81
|
+
return nextIndex >= menuItems.length ? 0 : nextIndex;
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
break;
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
const handleItemClick = (item) => {
|
|
88
|
+
if (!item.disabled) {
|
|
89
|
+
item.onClick();
|
|
90
|
+
setIsOpen(false);
|
|
91
|
+
setFocusedIndex(-1);
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
return (React.createElement("div", { className: `relative inline-block ${className}` },
|
|
95
|
+
React.createElement("button", { ref: triggerRef, onClick: () => setIsOpen(!isOpen), onKeyDown: handleKeyDown, className: "focus:outline-none", "aria-haspopup": "true", "aria-expanded": isOpen }, trigger),
|
|
96
|
+
isOpen && (React.createElement("div", { ref: menuRef, className: `
|
|
97
|
+
absolute z-50 mt-2 w-56 rounded-md shadow-lg
|
|
98
|
+
bg-white dark:bg-gray-800
|
|
99
|
+
border border-gray-200 dark:border-gray-700
|
|
100
|
+
${align === 'right' ? 'right-0' : 'left-0'}
|
|
101
|
+
`, role: "menu", "aria-orientation": "vertical" },
|
|
102
|
+
React.createElement("div", { className: "py-1" }, items.map((item, index) => {
|
|
103
|
+
if (item === 'divider') {
|
|
104
|
+
return (React.createElement("div", { key: `divider-${index}`, className: "my-1 border-t border-gray-200 dark:border-gray-700", role: "separator" }));
|
|
105
|
+
}
|
|
106
|
+
const Icon = item.icon;
|
|
107
|
+
const menuItemIndex = menuItems.indexOf(item);
|
|
108
|
+
const isFocused = menuItemIndex === focusedIndex;
|
|
109
|
+
return (React.createElement("button", { key: index, onClick: () => handleItemClick(item), disabled: item.disabled, role: "menuitem", className: `
|
|
110
|
+
w-full flex items-center gap-3 px-4 py-2 text-sm text-left
|
|
111
|
+
transition-colors
|
|
112
|
+
${item.disabled
|
|
113
|
+
? 'opacity-50 cursor-not-allowed'
|
|
114
|
+
: item.danger
|
|
115
|
+
? 'text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20'
|
|
116
|
+
: 'text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700'}
|
|
117
|
+
${isFocused ? 'bg-gray-100 dark:bg-gray-700' : ''}
|
|
118
|
+
` },
|
|
119
|
+
Icon && React.createElement(Icon, { className: "w-4 h-4 flex-shrink-0" }),
|
|
120
|
+
React.createElement("span", null, item.label)));
|
|
121
|
+
}))))));
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=DropdownMenu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DropdownMenu.js","sourceRoot":"","sources":["../../../src/components/Overlay/DropdownMenu.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAkB3D,MAAM,UAAU,YAAY,CAAC,EAC3B,OAAO,EACP,KAAK,EACL,KAAK,GAAG,OAAO,EACf,SAAS,GAAG,EAAE,GACI;IAClB,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC5C,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAS,CAAC,CAAC,CAAC,CAAC;IAC7D,MAAM,OAAO,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAC7C,MAAM,UAAU,GAAG,MAAM,CAAoB,IAAI,CAAC,CAAC;IAEnD,gDAAgD;IAChD,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAA4B,EAAE,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC;IAEvF,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,kBAAkB,GAAG,CAAC,KAAiB,EAAE,EAAE;YAC/C,IACE,OAAO,CAAC,OAAO;gBACf,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC;gBAC/C,UAAU,CAAC,OAAO;gBAClB,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,EAClD,CAAC;gBACD,SAAS,CAAC,KAAK,CAAC,CAAC;gBACjB,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;YACtB,CAAC;QACH,CAAC,CAAC;QAEF,IAAI,MAAM,EAAE,CAAC;YACX,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;YAC3D,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;QAC7E,CAAC;IACH,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,MAAM,aAAa,GAAG,CAAC,CAAsB,EAAE,EAAE;QAC/C,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;gBAChE,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,SAAS,CAAC,IAAI,CAAC,CAAC;gBAChB,eAAe,CAAC,CAAC,CAAC,CAAC;YACrB,CAAC;YACD,OAAO;QACT,CAAC;QAED,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;YACd,KAAK,QAAQ;gBACX,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,SAAS,CAAC,KAAK,CAAC,CAAC;gBACjB,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;gBACpB,UAAU,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;gBAC5B,MAAM;YAER,KAAK,WAAW;gBACd,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,eAAe,CAAC,CAAC,IAAI,EAAE,EAAE;oBACvB,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,CAAC;oBAC3B,OAAO,SAAS,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;gBACvD,CAAC,CAAC,CAAC;gBACH,MAAM;YAER,KAAK,SAAS;gBACZ,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,eAAe,CAAC,CAAC,IAAI,EAAE,EAAE;oBACvB,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,CAAC;oBAC3B,OAAO,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;gBAC1D,CAAC,CAAC,CAAC;gBACH,MAAM;YAER,KAAK,OAAO,CAAC;YACb,KAAK,GAAG;gBACN,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,IAAI,YAAY,IAAI,CAAC,IAAI,YAAY,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC;oBACzD,MAAM,IAAI,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC;oBACrC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACnB,IAAI,CAAC,OAAO,EAAE,CAAC;wBACf,SAAS,CAAC,KAAK,CAAC,CAAC;wBACjB,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;oBACtB,CAAC;gBACH,CAAC;gBACD,MAAM;YAER,KAAK,KAAK;gBACR,qCAAqC;gBACrC,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;oBACf,4BAA4B;oBAC5B,eAAe,CAAC,CAAC,IAAI,EAAE,EAAE;wBACvB,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,CAAC;wBAC3B,OAAO,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;oBAC1D,CAAC,CAAC,CAAC;gBACL,CAAC;qBAAM,CAAC;oBACN,qBAAqB;oBACrB,eAAe,CAAC,CAAC,IAAI,EAAE,EAAE;wBACvB,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,CAAC;wBAC3B,OAAO,SAAS,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;oBACvD,CAAC,CAAC,CAAC;gBACL,CAAC;gBACD,MAAM;QACV,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,eAAe,GAAG,CAAC,IAAsB,EAAE,EAAE;QACjD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,SAAS,CAAC,KAAK,CAAC,CAAC;YACjB,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CACL,6BAAK,SAAS,EAAE,yBAAyB,SAAS,EAAE;QAClD,gCACE,GAAG,EAAE,UAAU,EACf,OAAO,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,EACjC,SAAS,EAAE,aAAa,EACxB,SAAS,EAAC,oBAAoB,mBAChB,MAAM,mBACL,MAAM,IAEpB,OAAO,CACD;QAER,MAAM,IAAI,CACT,6BACE,GAAG,EAAE,OAAO,EACZ,SAAS,EAAE;;;;cAIP,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ;WAC3C,EACD,IAAI,EAAC,MAAM,sBACM,UAAU;YAE3B,6BAAK,SAAS,EAAC,MAAM,IAClB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACzB,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;oBACvB,OAAO,CACL,6BACE,GAAG,EAAE,WAAW,KAAK,EAAE,EACvB,SAAS,EAAC,oDAAoD,EAC9D,IAAI,EAAC,WAAW,GAChB,CACH,CAAC;gBACJ,CAAC;gBAED,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;gBACvB,MAAM,aAAa,GAAG,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;gBAC9C,MAAM,SAAS,GAAG,aAAa,KAAK,YAAY,CAAC;gBAEjD,OAAO,CACL,gCACE,GAAG,EAAE,KAAK,EACV,OAAO,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,EACpC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,IAAI,EAAC,UAAU,EACf,SAAS,EAAE;;;sBAIP,IAAI,CAAC,QAAQ;wBACX,CAAC,CAAC,+BAA+B;wBACjC,CAAC,CAAC,IAAI,CAAC,MAAM;4BACX,CAAC,CAAC,yEAAyE;4BAC3E,CAAC,CAAC,2EACR;sBACE,SAAS,CAAC,CAAC,CAAC,8BAA8B,CAAC,CAAC,CAAC,EAAE;mBAClD;oBAEA,IAAI,IAAI,oBAAC,IAAI,IAAC,SAAS,EAAC,uBAAuB,GAAG;oBACnD,kCAAO,IAAI,CAAC,KAAK,CAAQ,CAClB,CACV,CAAC;YACJ,CAAC,CAAC,CACE,CACF,CACP,CACG,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Overlay/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PaymentGate Component
|
|
3
|
+
*
|
|
4
|
+
* A paywall component that shows premium content only to users who have purchased.
|
|
5
|
+
* Shows a fallback/paywall UI for non-purchasers.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* import { PaymentGate } from '@varity/ui-kit';
|
|
10
|
+
*
|
|
11
|
+
* <PaymentGate
|
|
12
|
+
* appId={123}
|
|
13
|
+
* price={9900}
|
|
14
|
+
* fallback={<LockedContent />}
|
|
15
|
+
* >
|
|
16
|
+
* <PremiumContent />
|
|
17
|
+
* </PaymentGate>
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
import React from 'react';
|
|
21
|
+
import { PaymentGateProps } from './types';
|
|
22
|
+
/**
|
|
23
|
+
* PaymentGate - Paywall component for premium content
|
|
24
|
+
*
|
|
25
|
+
* Automatically shows premium content if the user has purchased,
|
|
26
|
+
* otherwise shows the fallback UI with a purchase option.
|
|
27
|
+
*/
|
|
28
|
+
export declare const PaymentGate: React.FC<PaymentGateProps>;
|
|
29
|
+
export default PaymentGate;
|
|
30
|
+
//# sourceMappingURL=PaymentGate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PaymentGate.d.ts","sourceRoot":"","sources":["../../../src/components/PaymentWidget/PaymentGate.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAI3C;;;;;GAKG;AACH,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAoDlD,CAAC;AAEF,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PaymentGate Component
|
|
3
|
+
*
|
|
4
|
+
* A paywall component that shows premium content only to users who have purchased.
|
|
5
|
+
* Shows a fallback/paywall UI for non-purchasers.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* import { PaymentGate } from '@varity/ui-kit';
|
|
10
|
+
*
|
|
11
|
+
* <PaymentGate
|
|
12
|
+
* appId={123}
|
|
13
|
+
* price={9900}
|
|
14
|
+
* fallback={<LockedContent />}
|
|
15
|
+
* >
|
|
16
|
+
* <PremiumContent />
|
|
17
|
+
* </PaymentGate>
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
import React from 'react';
|
|
21
|
+
import { useVarityPayment } from './useVarityPayment';
|
|
22
|
+
import { PaymentWidget } from './PaymentWidget';
|
|
23
|
+
/**
|
|
24
|
+
* PaymentGate - Paywall component for premium content
|
|
25
|
+
*
|
|
26
|
+
* Automatically shows premium content if the user has purchased,
|
|
27
|
+
* otherwise shows the fallback UI with a purchase option.
|
|
28
|
+
*/
|
|
29
|
+
export const PaymentGate = ({ appId, price, fallback, children, theme = 'dark', className = '', }) => {
|
|
30
|
+
const { hasPurchased, isLoading, pricing } = useVarityPayment({ appId });
|
|
31
|
+
// Loading state
|
|
32
|
+
if (isLoading) {
|
|
33
|
+
return (React.createElement("div", { className: `flex items-center justify-center p-8 ${className}` },
|
|
34
|
+
React.createElement("div", { className: "animate-pulse flex items-center gap-2 text-gray-500" },
|
|
35
|
+
React.createElement("svg", { className: "animate-spin h-5 w-5", fill: "none", viewBox: "0 0 24 24" },
|
|
36
|
+
React.createElement("circle", { className: "opacity-25", cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "4" }),
|
|
37
|
+
React.createElement("path", { className: "opacity-75", fill: "currentColor", d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z" })),
|
|
38
|
+
React.createElement("span", null, "Loading..."))));
|
|
39
|
+
}
|
|
40
|
+
// User has purchased - show premium content
|
|
41
|
+
if (hasPurchased) {
|
|
42
|
+
return React.createElement(React.Fragment, null, children);
|
|
43
|
+
}
|
|
44
|
+
// User has not purchased - show fallback/paywall
|
|
45
|
+
return (React.createElement("div", { className: className },
|
|
46
|
+
fallback,
|
|
47
|
+
pricing?.isActive && (React.createElement("div", { className: "mt-4 text-center" },
|
|
48
|
+
React.createElement(PaymentWidget, { appId: appId, price: price, theme: theme },
|
|
49
|
+
React.createElement("button", { className: "px-6 py-3 bg-blue-600 hover:bg-blue-700 text-white font-bold rounded-lg transition-colors" },
|
|
50
|
+
"Unlock for $",
|
|
51
|
+
price ? (price / 100).toFixed(2) : (Number(pricing.priceUsdc) / 1_000_000).toFixed(2)))))));
|
|
52
|
+
};
|
|
53
|
+
export default PaymentGate;
|
|
54
|
+
//# sourceMappingURL=PaymentGate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PaymentGate.js","sourceRoot":"","sources":["../../../src/components/PaymentWidget/PaymentGate.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EACtD,KAAK,EACL,KAAK,EACL,QAAQ,EACR,QAAQ,EACR,KAAK,GAAG,MAAM,EACd,SAAS,GAAG,EAAE,GACf,EAAE,EAAE;IACH,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,gBAAgB,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IAEzE,gBAAgB;IAChB,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,CACL,6BAAK,SAAS,EAAE,wCAAwC,SAAS,EAAE;YACjE,6BAAK,SAAS,EAAC,qDAAqD;gBAClE,6BAAK,SAAS,EAAC,sBAAsB,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW;oBACnE,gCAAQ,SAAS,EAAC,YAAY,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,IAAI,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAC,GAAG,GAAG;oBAC9F,8BAAM,SAAS,EAAC,YAAY,EAAC,IAAI,EAAC,cAAc,EAAC,CAAC,EAAC,iHAAiH,GAAG,CACnK;gBACN,+CAAuB,CACnB,CACF,CACP,CAAC;IACJ,CAAC;IAED,4CAA4C;IAC5C,IAAI,YAAY,EAAE,CAAC;QACjB,OAAO,0CAAG,QAAQ,CAAI,CAAC;IACzB,CAAC;IAED,iDAAiD;IACjD,OAAO,CACL,6BAAK,SAAS,EAAE,SAAS;QAEtB,QAAQ;QAGR,OAAO,EAAE,QAAQ,IAAI,CACpB,6BAAK,SAAS,EAAC,kBAAkB;YAC/B,oBAAC,aAAa,IACZ,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK;gBAEZ,gCAAQ,SAAS,EAAC,2FAA2F;;oBAC9F,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAC3F,CACK,CACZ,CACP,CACG,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PaymentWidget Component
|
|
3
|
+
*
|
|
4
|
+
* REQUIRED in every Varity app that charges users.
|
|
5
|
+
* All payments go through the VarityPayments contract with 90/10 revenue split:
|
|
6
|
+
* - 90% to developer
|
|
7
|
+
* - 10% to Varity treasury
|
|
8
|
+
*
|
|
9
|
+
* Zero-crypto checkout: Users pay with credit card via thirdweb Pay.
|
|
10
|
+
* No wallets, no tokens, no blockchain terminology visible.
|
|
11
|
+
* The experience is identical to Stripe checkout.
|
|
12
|
+
*
|
|
13
|
+
* Flow:
|
|
14
|
+
* 1. User clicks purchase button
|
|
15
|
+
* 2. Credit card form appears (thirdweb Pay modal)
|
|
16
|
+
* 3. thirdweb converts USD → USDC on Arbitrum One
|
|
17
|
+
* 4. USDC approve + purchaseApp() execute automatically
|
|
18
|
+
* 5. User sees "Purchase complete" — never sees crypto
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```tsx
|
|
22
|
+
* import { PaymentWidget } from '@varity-labs/ui-kit';
|
|
23
|
+
*
|
|
24
|
+
* <PaymentWidget appId={123} price={9900}>
|
|
25
|
+
* <button>Buy Premium - $99</button>
|
|
26
|
+
* </PaymentWidget>
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
import React from 'react';
|
|
30
|
+
import { PaymentWidgetProps } from './types';
|
|
31
|
+
/**
|
|
32
|
+
* PaymentWidget - Required component for app monetization
|
|
33
|
+
*
|
|
34
|
+
* Wraps a trigger element and handles the full purchase flow.
|
|
35
|
+
* Automatically checks USDC allowance — skips authorize step if sufficient.
|
|
36
|
+
* Credit card payments handled seamlessly via thirdweb Pay.
|
|
37
|
+
*/
|
|
38
|
+
export declare const PaymentWidget: React.FC<PaymentWidgetProps>;
|
|
39
|
+
export default PaymentWidget;
|
|
40
|
+
//# sourceMappingURL=PaymentWidget.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PaymentWidget.d.ts","sourceRoot":"","sources":["../../../src/components/PaymentWidget/PaymentWidget.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AAEH,OAAO,KAA8B,MAAM,OAAO,CAAC;AAInD,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AA6C7C;;;;;;GAMG;AACH,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CA4KtD,CAAC;AAEF,eAAe,aAAa,CAAC"}
|