@rovela-ai/sdk 0.1.2 → 0.1.4
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/admin/api/auth.d.ts +32 -0
- package/dist/admin/api/auth.d.ts.map +1 -0
- package/dist/admin/api/auth.js +43 -0
- package/dist/admin/api/auth.js.map +1 -0
- package/dist/admin/api/categories.d.ts +68 -0
- package/dist/admin/api/categories.d.ts.map +1 -0
- package/dist/admin/api/categories.js +247 -0
- package/dist/admin/api/categories.js.map +1 -0
- package/dist/admin/api/customers.d.ts +41 -0
- package/dist/admin/api/customers.d.ts.map +1 -0
- package/dist/admin/api/customers.js +113 -0
- package/dist/admin/api/customers.js.map +1 -0
- package/dist/admin/api/index.d.ts +56 -0
- package/dist/admin/api/index.d.ts.map +1 -0
- package/dist/admin/api/index.js +87 -0
- package/dist/admin/api/index.js.map +1 -0
- package/dist/admin/api/orders.d.ts +59 -0
- package/dist/admin/api/orders.d.ts.map +1 -0
- package/dist/admin/api/orders.js +209 -0
- package/dist/admin/api/orders.js.map +1 -0
- package/dist/admin/api/products.d.ts +103 -0
- package/dist/admin/api/products.d.ts.map +1 -0
- package/dist/admin/api/products.js +329 -0
- package/dist/admin/api/products.js.map +1 -0
- package/dist/admin/api/refund.d.ts +29 -0
- package/dist/admin/api/refund.d.ts.map +1 -0
- package/dist/admin/api/refund.js +136 -0
- package/dist/admin/api/refund.js.map +1 -0
- package/dist/admin/api/stats.d.ts +40 -0
- package/dist/admin/api/stats.d.ts.map +1 -0
- package/dist/admin/api/stats.js +74 -0
- package/dist/admin/api/stats.js.map +1 -0
- package/dist/admin/components/AdminGuard.d.ts +40 -0
- package/dist/admin/components/AdminGuard.d.ts.map +1 -0
- package/dist/admin/components/AdminGuard.js +97 -0
- package/dist/admin/components/AdminGuard.js.map +1 -0
- package/dist/admin/components/AdminHeader.d.ts +18 -0
- package/dist/admin/components/AdminHeader.d.ts.map +1 -0
- package/dist/admin/components/AdminHeader.js +33 -0
- package/dist/admin/components/AdminHeader.js.map +1 -0
- package/dist/admin/components/AdminLayout.d.ts +50 -0
- package/dist/admin/components/AdminLayout.d.ts.map +1 -0
- package/dist/admin/components/AdminLayout.js +46 -0
- package/dist/admin/components/AdminLayout.js.map +1 -0
- package/dist/admin/components/AdminLoginForm.d.ts +18 -0
- package/dist/admin/components/AdminLoginForm.d.ts.map +1 -0
- package/dist/admin/components/AdminLoginForm.js +58 -0
- package/dist/admin/components/AdminLoginForm.js.map +1 -0
- package/dist/admin/components/AdminNav.d.ts +34 -0
- package/dist/admin/components/AdminNav.d.ts.map +1 -0
- package/dist/admin/components/AdminNav.js +61 -0
- package/dist/admin/components/AdminNav.js.map +1 -0
- package/dist/admin/components/InventoryEditor.d.ts +15 -0
- package/dist/admin/components/InventoryEditor.d.ts.map +1 -0
- package/dist/admin/components/InventoryEditor.js +83 -0
- package/dist/admin/components/InventoryEditor.js.map +1 -0
- package/dist/admin/components/LowStockAlert.d.ts +11 -0
- package/dist/admin/components/LowStockAlert.d.ts.map +1 -0
- package/dist/admin/components/LowStockAlert.js +35 -0
- package/dist/admin/components/LowStockAlert.js.map +1 -0
- package/dist/admin/components/OrderDetails.d.ts +14 -0
- package/dist/admin/components/OrderDetails.d.ts.map +1 -0
- package/dist/admin/components/OrderDetails.js +94 -0
- package/dist/admin/components/OrderDetails.js.map +1 -0
- package/dist/admin/components/OrderTable.d.ts +13 -0
- package/dist/admin/components/OrderTable.d.ts.map +1 -0
- package/dist/admin/components/OrderTable.js +89 -0
- package/dist/admin/components/OrderTable.js.map +1 -0
- package/dist/admin/components/ProductForm.d.ts +18 -0
- package/dist/admin/components/ProductForm.d.ts.map +1 -0
- package/dist/admin/components/ProductForm.js +127 -0
- package/dist/admin/components/ProductForm.js.map +1 -0
- package/dist/admin/components/ProductTable.d.ts +13 -0
- package/dist/admin/components/ProductTable.d.ts.map +1 -0
- package/dist/admin/components/ProductTable.js +81 -0
- package/dist/admin/components/ProductTable.js.map +1 -0
- package/dist/admin/components/RecentOrders.d.ts +11 -0
- package/dist/admin/components/RecentOrders.d.ts.map +1 -0
- package/dist/admin/components/RecentOrders.js +58 -0
- package/dist/admin/components/RecentOrders.js.map +1 -0
- package/dist/admin/components/RefundDialog.d.ts +17 -0
- package/dist/admin/components/RefundDialog.d.ts.map +1 -0
- package/dist/admin/components/RefundDialog.js +86 -0
- package/dist/admin/components/RefundDialog.js.map +1 -0
- package/dist/admin/components/StatsCards.d.ts +23 -0
- package/dist/admin/components/StatsCards.d.ts.map +1 -0
- package/dist/admin/components/StatsCards.js +82 -0
- package/dist/admin/components/StatsCards.js.map +1 -0
- package/dist/admin/components/StoreSettings.d.ts +14 -0
- package/dist/admin/components/StoreSettings.d.ts.map +1 -0
- package/dist/admin/components/StoreSettings.js +88 -0
- package/dist/admin/components/StoreSettings.js.map +1 -0
- package/dist/admin/components/index.d.ts +21 -0
- package/dist/admin/components/index.d.ts.map +1 -0
- package/dist/admin/components/index.js +57 -0
- package/dist/admin/components/index.js.map +1 -0
- package/dist/admin/config.d.ts +74 -0
- package/dist/admin/config.d.ts.map +1 -0
- package/dist/admin/config.js +229 -0
- package/dist/admin/config.js.map +1 -0
- package/dist/admin/hooks/index.d.ts +10 -0
- package/dist/admin/hooks/index.d.ts.map +1 -0
- package/dist/admin/hooks/index.js +17 -0
- package/dist/admin/hooks/index.js.map +1 -0
- package/dist/admin/hooks/useAdminOrders.d.ts +41 -0
- package/dist/admin/hooks/useAdminOrders.d.ts.map +1 -0
- package/dist/admin/hooks/useAdminOrders.js +191 -0
- package/dist/admin/hooks/useAdminOrders.js.map +1 -0
- package/dist/admin/hooks/useAdminProducts.d.ts +39 -0
- package/dist/admin/hooks/useAdminProducts.d.ts.map +1 -0
- package/dist/admin/hooks/useAdminProducts.js +235 -0
- package/dist/admin/hooks/useAdminProducts.js.map +1 -0
- package/dist/admin/hooks/useAdminStats.d.ts +50 -0
- package/dist/admin/hooks/useAdminStats.d.ts.map +1 -0
- package/dist/admin/hooks/useAdminStats.js +111 -0
- package/dist/admin/hooks/useAdminStats.js.map +1 -0
- package/dist/admin/index.d.ts +63 -0
- package/dist/admin/index.d.ts.map +1 -0
- package/dist/admin/index.js +148 -0
- package/dist/admin/index.js.map +1 -0
- package/dist/admin/server/admin-service.d.ts +130 -0
- package/dist/admin/server/admin-service.d.ts.map +1 -0
- package/dist/admin/server/admin-service.js +298 -0
- package/dist/admin/server/admin-service.js.map +1 -0
- package/dist/admin/server/index.d.ts +8 -0
- package/dist/admin/server/index.d.ts.map +1 -0
- package/dist/admin/server/index.js +25 -0
- package/dist/admin/server/index.js.map +1 -0
- package/dist/admin/types.d.ts +549 -0
- package/dist/admin/types.d.ts.map +1 -0
- package/dist/admin/types.js +11 -0
- package/dist/admin/types.js.map +1 -0
- package/dist/auth/api/auth.d.ts +54 -0
- package/dist/auth/api/auth.d.ts.map +1 -0
- package/dist/auth/api/auth.js +67 -0
- package/dist/auth/api/auth.js.map +1 -0
- package/dist/auth/api/forgot-password.d.ts +41 -0
- package/dist/auth/api/forgot-password.d.ts.map +1 -0
- package/dist/auth/api/forgot-password.js +68 -0
- package/dist/auth/api/forgot-password.js.map +1 -0
- package/dist/auth/api/index.d.ts +34 -0
- package/dist/auth/api/index.d.ts.map +1 -0
- package/dist/auth/api/index.js +52 -0
- package/dist/auth/api/index.js.map +1 -0
- package/dist/auth/api/register.d.ts +41 -0
- package/dist/auth/api/register.d.ts.map +1 -0
- package/dist/auth/api/register.js +93 -0
- package/dist/auth/api/register.js.map +1 -0
- package/dist/auth/api/resend-verification.d.ts +41 -0
- package/dist/auth/api/resend-verification.d.ts.map +1 -0
- package/dist/auth/api/resend-verification.js +71 -0
- package/dist/auth/api/resend-verification.js.map +1 -0
- package/dist/auth/api/reset-password.d.ts +67 -0
- package/dist/auth/api/reset-password.d.ts.map +1 -0
- package/dist/auth/api/reset-password.js +110 -0
- package/dist/auth/api/reset-password.js.map +1 -0
- package/dist/auth/api/verify-email.d.ts +47 -0
- package/dist/auth/api/verify-email.d.ts.map +1 -0
- package/dist/auth/api/verify-email.js +94 -0
- package/dist/auth/api/verify-email.js.map +1 -0
- package/dist/auth/components/AuthGuard.d.ts +52 -0
- package/dist/auth/components/AuthGuard.d.ts.map +1 -0
- package/dist/auth/components/AuthGuard.js +113 -0
- package/dist/auth/components/AuthGuard.js.map +1 -0
- package/dist/auth/components/ForgotPasswordForm.d.ts +15 -0
- package/dist/auth/components/ForgotPasswordForm.d.ts.map +1 -0
- package/dist/auth/components/ForgotPasswordForm.js +44 -0
- package/dist/auth/components/ForgotPasswordForm.js.map +1 -0
- package/dist/auth/components/ResetPasswordForm.d.ts +18 -0
- package/dist/auth/components/ResetPasswordForm.d.ts.map +1 -0
- package/dist/auth/components/ResetPasswordForm.js +88 -0
- package/dist/auth/components/ResetPasswordForm.js.map +1 -0
- package/dist/auth/components/SignInForm.d.ts +21 -0
- package/dist/auth/components/SignInForm.d.ts.map +1 -0
- package/dist/auth/components/SignInForm.js +63 -0
- package/dist/auth/components/SignInForm.js.map +1 -0
- package/dist/auth/components/SignUpForm.d.ts +18 -0
- package/dist/auth/components/SignUpForm.d.ts.map +1 -0
- package/dist/auth/components/SignUpForm.js +79 -0
- package/dist/auth/components/SignUpForm.js.map +1 -0
- package/dist/auth/components/UserMenu.d.ts +18 -0
- package/dist/auth/components/UserMenu.d.ts.map +1 -0
- package/dist/auth/components/UserMenu.js +75 -0
- package/dist/auth/components/UserMenu.js.map +1 -0
- package/dist/auth/components/VerifyEmailNotice.d.ts +20 -0
- package/dist/auth/components/VerifyEmailNotice.d.ts.map +1 -0
- package/dist/auth/components/VerifyEmailNotice.js +59 -0
- package/dist/auth/components/VerifyEmailNotice.js.map +1 -0
- package/dist/auth/components/index.d.ts +13 -0
- package/dist/auth/components/index.d.ts.map +1 -0
- package/dist/auth/components/index.js +24 -0
- package/dist/auth/components/index.js.map +1 -0
- package/dist/auth/config.d.ts +42 -0
- package/dist/auth/config.d.ts.map +1 -0
- package/dist/auth/config.js +174 -0
- package/dist/auth/config.js.map +1 -0
- package/dist/auth/hooks/index.d.ts +7 -0
- package/dist/auth/hooks/index.d.ts.map +1 -0
- package/dist/auth/hooks/index.js +11 -0
- package/dist/auth/hooks/index.js.map +1 -0
- package/dist/auth/index.d.ts +54 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +88 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/server/customer-service.d.ts +138 -0
- package/dist/auth/server/customer-service.d.ts.map +1 -0
- package/dist/auth/server/customer-service.js +309 -0
- package/dist/auth/server/customer-service.js.map +1 -0
- package/dist/auth/server/email-sender.d.ts +64 -0
- package/dist/auth/server/email-sender.d.ts.map +1 -0
- package/dist/auth/server/email-sender.js +112 -0
- package/dist/auth/server/email-sender.js.map +1 -0
- package/dist/auth/server/index.d.ts +13 -0
- package/dist/auth/server/index.d.ts.map +1 -0
- package/dist/auth/server/index.js +48 -0
- package/dist/auth/server/index.js.map +1 -0
- package/dist/auth/server/password-reset-service.d.ts +86 -0
- package/dist/auth/server/password-reset-service.d.ts.map +1 -0
- package/dist/auth/server/password-reset-service.js +236 -0
- package/dist/auth/server/password-reset-service.js.map +1 -0
- package/dist/auth/server/password.d.ts +58 -0
- package/dist/auth/server/password.d.ts.map +1 -0
- package/dist/auth/server/password.js +94 -0
- package/dist/auth/server/password.js.map +1 -0
- package/dist/auth/server/verification-service.d.ts +87 -0
- package/dist/auth/server/verification-service.d.ts.map +1 -0
- package/dist/auth/server/verification-service.js +268 -0
- package/dist/auth/server/verification-service.js.map +1 -0
- package/dist/auth/types.d.ts +305 -0
- package/dist/auth/types.d.ts.map +1 -0
- package/dist/auth/types.js +8 -0
- package/dist/auth/types.js.map +1 -0
- package/dist/cart/CartProvider.d.ts +65 -0
- package/dist/cart/CartProvider.d.ts.map +1 -0
- package/dist/cart/CartProvider.js +101 -0
- package/dist/cart/CartProvider.js.map +1 -0
- package/dist/cart/components/AddToCartButton.d.ts +77 -0
- package/dist/cart/components/AddToCartButton.d.ts.map +1 -0
- package/dist/cart/components/AddToCartButton.js +124 -0
- package/dist/cart/components/AddToCartButton.js.map +1 -0
- package/dist/cart/components/CartDrawer.d.ts +71 -0
- package/dist/cart/components/CartDrawer.d.ts.map +1 -0
- package/dist/cart/components/CartDrawer.js +108 -0
- package/dist/cart/components/CartDrawer.js.map +1 -0
- package/dist/cart/components/CartIcon.d.ts +36 -0
- package/dist/cart/components/CartIcon.d.ts.map +1 -0
- package/dist/cart/components/CartIcon.js +70 -0
- package/dist/cart/components/CartIcon.js.map +1 -0
- package/dist/cart/components/CartItem.d.ts +52 -0
- package/dist/cart/components/CartItem.d.ts.map +1 -0
- package/dist/cart/components/CartItem.js +55 -0
- package/dist/cart/components/CartItem.js.map +1 -0
- package/dist/cart/components/CartSummary.d.ts +43 -0
- package/dist/cart/components/CartSummary.d.ts.map +1 -0
- package/dist/cart/components/CartSummary.js +58 -0
- package/dist/cart/components/CartSummary.js.map +1 -0
- package/dist/cart/components/QuantitySelector.d.ts +39 -0
- package/dist/cart/components/QuantitySelector.d.ts.map +1 -0
- package/dist/cart/components/QuantitySelector.js +87 -0
- package/dist/cart/components/QuantitySelector.js.map +1 -0
- package/dist/cart/components/index.d.ts +18 -0
- package/dist/cart/components/index.d.ts.map +1 -0
- package/dist/cart/components/index.js +21 -0
- package/dist/cart/components/index.js.map +1 -0
- package/dist/cart/index.d.ts +109 -0
- package/dist/cart/index.d.ts.map +1 -0
- package/dist/cart/index.js +129 -0
- package/dist/cart/index.js.map +1 -0
- package/dist/cart/store.d.ts +101 -0
- package/dist/cart/store.d.ts.map +1 -0
- package/dist/cart/store.js +207 -0
- package/dist/cart/store.js.map +1 -0
- package/dist/checkout/api/checkout.d.ts +31 -0
- package/dist/checkout/api/checkout.d.ts.map +1 -0
- package/dist/checkout/api/checkout.js +103 -0
- package/dist/checkout/api/checkout.js.map +1 -0
- package/dist/checkout/api/index.d.ts +8 -0
- package/dist/checkout/api/index.d.ts.map +1 -0
- package/dist/checkout/api/index.js +13 -0
- package/dist/checkout/api/index.js.map +1 -0
- package/dist/checkout/api/webhook.d.ts +30 -0
- package/dist/checkout/api/webhook.d.ts.map +1 -0
- package/dist/checkout/api/webhook.js +58 -0
- package/dist/checkout/api/webhook.js.map +1 -0
- package/dist/checkout/components/CheckoutButton.d.ts +44 -0
- package/dist/checkout/components/CheckoutButton.d.ts.map +1 -0
- package/dist/checkout/components/CheckoutButton.js +97 -0
- package/dist/checkout/components/CheckoutButton.js.map +1 -0
- package/dist/checkout/components/CheckoutSuccess.d.ts +29 -0
- package/dist/checkout/components/CheckoutSuccess.d.ts.map +1 -0
- package/dist/checkout/components/CheckoutSuccess.js +60 -0
- package/dist/checkout/components/CheckoutSuccess.js.map +1 -0
- package/dist/checkout/components/OrderSummary.d.ts +37 -0
- package/dist/checkout/components/OrderSummary.d.ts.map +1 -0
- package/dist/checkout/components/OrderSummary.js +70 -0
- package/dist/checkout/components/OrderSummary.js.map +1 -0
- package/dist/checkout/components/ShippingForm.d.ts +30 -0
- package/dist/checkout/components/ShippingForm.d.ts.map +1 -0
- package/dist/checkout/components/ShippingForm.js +125 -0
- package/dist/checkout/components/ShippingForm.js.map +1 -0
- package/dist/checkout/components/index.d.ts +10 -0
- package/dist/checkout/components/index.d.ts.map +1 -0
- package/dist/checkout/components/index.js +17 -0
- package/dist/checkout/components/index.js.map +1 -0
- package/dist/checkout/hooks/index.d.ts +7 -0
- package/dist/checkout/hooks/index.d.ts.map +1 -0
- package/dist/checkout/hooks/index.js +12 -0
- package/dist/checkout/hooks/index.js.map +1 -0
- package/dist/checkout/hooks/useCheckout.d.ts +61 -0
- package/dist/checkout/hooks/useCheckout.d.ts.map +1 -0
- package/dist/checkout/hooks/useCheckout.js +174 -0
- package/dist/checkout/hooks/useCheckout.js.map +1 -0
- package/dist/checkout/index.d.ts +111 -0
- package/dist/checkout/index.d.ts.map +1 -0
- package/dist/checkout/index.js +148 -0
- package/dist/checkout/index.js.map +1 -0
- package/dist/checkout/server/create-checkout-session.d.ts +69 -0
- package/dist/checkout/server/create-checkout-session.d.ts.map +1 -0
- package/dist/checkout/server/create-checkout-session.js +190 -0
- package/dist/checkout/server/create-checkout-session.js.map +1 -0
- package/dist/checkout/server/handle-webhook.d.ts +35 -0
- package/dist/checkout/server/handle-webhook.d.ts.map +1 -0
- package/dist/checkout/server/handle-webhook.js +279 -0
- package/dist/checkout/server/handle-webhook.js.map +1 -0
- package/dist/checkout/server/index.d.ts +10 -0
- package/dist/checkout/server/index.d.ts.map +1 -0
- package/dist/checkout/server/index.js +19 -0
- package/dist/checkout/server/index.js.map +1 -0
- package/dist/checkout/server/order-service.d.ts +43 -0
- package/dist/checkout/server/order-service.d.ts.map +1 -0
- package/dist/checkout/server/order-service.js +196 -0
- package/dist/checkout/server/order-service.js.map +1 -0
- package/dist/checkout/stripe/client.d.ts +72 -0
- package/dist/checkout/stripe/client.d.ts.map +1 -0
- package/dist/checkout/stripe/client.js +189 -0
- package/dist/checkout/stripe/client.js.map +1 -0
- package/dist/checkout/stripe/index.d.ts +7 -0
- package/dist/checkout/stripe/index.d.ts.map +1 -0
- package/dist/checkout/stripe/index.js +21 -0
- package/dist/checkout/stripe/index.js.map +1 -0
- package/dist/checkout/types.d.ts +263 -0
- package/dist/checkout/types.d.ts.map +1 -0
- package/dist/checkout/types.js +9 -0
- package/dist/checkout/types.js.map +1 -0
- package/dist/core/config.d.ts +296 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +162 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/db/client.d.ts +69 -0
- package/dist/core/db/client.d.ts.map +1 -0
- package/dist/core/db/client.js +202 -0
- package/dist/core/db/client.js.map +1 -0
- package/dist/core/db/index.d.ts +11 -0
- package/dist/core/db/index.d.ts.map +1 -0
- package/dist/core/db/index.js +109 -0
- package/dist/core/db/index.js.map +1 -0
- package/dist/core/db/queries.d.ts +627 -0
- package/dist/core/db/queries.d.ts.map +1 -0
- package/dist/core/db/queries.js +730 -0
- package/dist/core/db/queries.js.map +1 -0
- package/dist/core/db/schema.d.ts +1628 -0
- package/dist/core/db/schema.d.ts.map +1 -0
- package/dist/core/db/schema.js +262 -0
- package/dist/core/db/schema.js.map +1 -0
- package/dist/core/index.d.ts +20 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +71 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/server/index.d.ts +17 -0
- package/dist/core/server/index.d.ts.map +1 -0
- package/dist/core/server/index.js +96 -0
- package/dist/core/server/index.js.map +1 -0
- package/dist/core/types.d.ts +230 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +9 -0
- package/dist/core/types.js.map +1 -0
- package/dist/core/utils.d.ts +153 -0
- package/dist/core/utils.d.ts.map +1 -0
- package/dist/core/utils.js +356 -0
- package/dist/core/utils.js.map +1 -0
- package/dist/emails/config.d.ts +42 -0
- package/dist/emails/config.d.ts.map +1 -0
- package/dist/emails/config.js +89 -0
- package/dist/emails/config.js.map +1 -0
- package/dist/emails/index.d.ts +85 -0
- package/dist/emails/index.d.ts.map +1 -0
- package/dist/emails/index.js +170 -0
- package/dist/emails/index.js.map +1 -0
- package/dist/emails/send/auth.d.ts +91 -0
- package/dist/emails/send/auth.d.ts.map +1 -0
- package/dist/emails/send/auth.js +132 -0
- package/dist/emails/send/auth.js.map +1 -0
- package/dist/emails/send/index.d.ts +10 -0
- package/dist/emails/send/index.d.ts.map +1 -0
- package/dist/emails/send/index.js +33 -0
- package/dist/emails/send/index.js.map +1 -0
- package/dist/emails/send/orders.d.ts +180 -0
- package/dist/emails/send/orders.d.ts.map +1 -0
- package/dist/emails/send/orders.js +259 -0
- package/dist/emails/send/orders.js.map +1 -0
- package/dist/emails/sender.d.ts +72 -0
- package/dist/emails/sender.d.ts.map +1 -0
- package/dist/emails/sender.js +118 -0
- package/dist/emails/sender.js.map +1 -0
- package/dist/emails/templates/base.d.ts +105 -0
- package/dist/emails/templates/base.d.ts.map +1 -0
- package/dist/emails/templates/base.js +291 -0
- package/dist/emails/templates/base.js.map +1 -0
- package/dist/emails/templates/email-verification.d.ts +28 -0
- package/dist/emails/templates/email-verification.d.ts.map +1 -0
- package/dist/emails/templates/email-verification.js +56 -0
- package/dist/emails/templates/email-verification.js.map +1 -0
- package/dist/emails/templates/index.d.ts +15 -0
- package/dist/emails/templates/index.d.ts.map +1 -0
- package/dist/emails/templates/index.js +58 -0
- package/dist/emails/templates/index.js.map +1 -0
- package/dist/emails/templates/order-cancelled.d.ts +30 -0
- package/dist/emails/templates/order-cancelled.d.ts.map +1 -0
- package/dist/emails/templates/order-cancelled.js +87 -0
- package/dist/emails/templates/order-cancelled.js.map +1 -0
- package/dist/emails/templates/order-confirmation.d.ts +36 -0
- package/dist/emails/templates/order-confirmation.d.ts.map +1 -0
- package/dist/emails/templates/order-confirmation.js +161 -0
- package/dist/emails/templates/order-confirmation.js.map +1 -0
- package/dist/emails/templates/order-delivered.d.ts +31 -0
- package/dist/emails/templates/order-delivered.d.ts.map +1 -0
- package/dist/emails/templates/order-delivered.js +95 -0
- package/dist/emails/templates/order-delivered.js.map +1 -0
- package/dist/emails/templates/order-shipped.d.ts +32 -0
- package/dist/emails/templates/order-shipped.d.ts.map +1 -0
- package/dist/emails/templates/order-shipped.js +87 -0
- package/dist/emails/templates/order-shipped.js.map +1 -0
- package/dist/emails/templates/password-reset.d.ts +27 -0
- package/dist/emails/templates/password-reset.d.ts.map +1 -0
- package/dist/emails/templates/password-reset.js +55 -0
- package/dist/emails/templates/password-reset.js.map +1 -0
- package/dist/emails/templates/refund-processed.d.ts +32 -0
- package/dist/emails/templates/refund-processed.d.ts.map +1 -0
- package/dist/emails/templates/refund-processed.js +96 -0
- package/dist/emails/templates/refund-processed.js.map +1 -0
- package/dist/emails/templates/welcome.d.ts +27 -0
- package/dist/emails/templates/welcome.d.ts.map +1 -0
- package/dist/emails/templates/welcome.js +56 -0
- package/dist/emails/templates/welcome.js.map +1 -0
- package/dist/emails/types.d.ts +202 -0
- package/dist/emails/types.d.ts.map +1 -0
- package/dist/emails/types.js +8 -0
- package/dist/emails/types.js.map +1 -0
- package/dist/emails/utils.d.ts +94 -0
- package/dist/emails/utils.d.ts.map +1 -0
- package/dist/emails/utils.js +229 -0
- package/dist/emails/utils.js.map +1 -0
- package/dist/index.d.ts +40 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +225 -0
- package/dist/index.js.map +1 -0
- package/dist/products/api/categories.d.ts +29 -0
- package/dist/products/api/categories.d.ts.map +1 -0
- package/dist/products/api/categories.js +49 -0
- package/dist/products/api/categories.js.map +1 -0
- package/dist/products/api/index.d.ts +24 -0
- package/dist/products/api/index.d.ts.map +1 -0
- package/dist/products/api/index.js +30 -0
- package/dist/products/api/index.js.map +1 -0
- package/dist/products/api/product.d.ts +36 -0
- package/dist/products/api/product.d.ts.map +1 -0
- package/dist/products/api/product.js +70 -0
- package/dist/products/api/product.js.map +1 -0
- package/dist/products/api/products.d.ts +41 -0
- package/dist/products/api/products.d.ts.map +1 -0
- package/dist/products/api/products.js +102 -0
- package/dist/products/api/products.js.map +1 -0
- package/dist/products/components/CategoryNav.d.ts +51 -0
- package/dist/products/components/CategoryNav.d.ts.map +1 -0
- package/dist/products/components/CategoryNav.js +115 -0
- package/dist/products/components/CategoryNav.js.map +1 -0
- package/dist/products/components/ProductBreadcrumb.d.ts +52 -0
- package/dist/products/components/ProductBreadcrumb.d.ts.map +1 -0
- package/dist/products/components/ProductBreadcrumb.js +78 -0
- package/dist/products/components/ProductBreadcrumb.js.map +1 -0
- package/dist/products/components/ProductCard.d.ts +54 -0
- package/dist/products/components/ProductCard.d.ts.map +1 -0
- package/dist/products/components/ProductCard.js +65 -0
- package/dist/products/components/ProductCard.js.map +1 -0
- package/dist/products/components/ProductDetails.d.ts +63 -0
- package/dist/products/components/ProductDetails.d.ts.map +1 -0
- package/dist/products/components/ProductDetails.js +105 -0
- package/dist/products/components/ProductDetails.js.map +1 -0
- package/dist/products/components/ProductFilters.d.ts +70 -0
- package/dist/products/components/ProductFilters.d.ts.map +1 -0
- package/dist/products/components/ProductFilters.js +127 -0
- package/dist/products/components/ProductFilters.js.map +1 -0
- package/dist/products/components/ProductGallery.d.ts +37 -0
- package/dist/products/components/ProductGallery.d.ts.map +1 -0
- package/dist/products/components/ProductGallery.js +80 -0
- package/dist/products/components/ProductGallery.js.map +1 -0
- package/dist/products/components/ProductGrid.d.ts +50 -0
- package/dist/products/components/ProductGrid.d.ts.map +1 -0
- package/dist/products/components/ProductGrid.js +83 -0
- package/dist/products/components/ProductGrid.js.map +1 -0
- package/dist/products/components/ProductSearch.d.ts +43 -0
- package/dist/products/components/ProductSearch.d.ts.map +1 -0
- package/dist/products/components/ProductSearch.js +99 -0
- package/dist/products/components/ProductSearch.js.map +1 -0
- package/dist/products/components/ProductSort.d.ts +43 -0
- package/dist/products/components/ProductSort.d.ts.map +1 -0
- package/dist/products/components/ProductSort.js +61 -0
- package/dist/products/components/ProductSort.js.map +1 -0
- package/dist/products/components/VariantSelector.d.ts +43 -0
- package/dist/products/components/VariantSelector.d.ts.map +1 -0
- package/dist/products/components/VariantSelector.js +147 -0
- package/dist/products/components/VariantSelector.js.map +1 -0
- package/dist/products/components/index.d.ts +26 -0
- package/dist/products/components/index.d.ts.map +1 -0
- package/dist/products/components/index.js +32 -0
- package/dist/products/components/index.js.map +1 -0
- package/dist/products/hooks/index.d.ts +14 -0
- package/dist/products/hooks/index.d.ts.map +1 -0
- package/dist/products/hooks/index.js +17 -0
- package/dist/products/hooks/index.js.map +1 -0
- package/dist/products/hooks/useCategories.d.ts +56 -0
- package/dist/products/hooks/useCategories.d.ts.map +1 -0
- package/dist/products/hooks/useCategories.js +126 -0
- package/dist/products/hooks/useCategories.js.map +1 -0
- package/dist/products/hooks/useProduct.d.ts +44 -0
- package/dist/products/hooks/useProduct.d.ts.map +1 -0
- package/dist/products/hooks/useProduct.js +86 -0
- package/dist/products/hooks/useProduct.js.map +1 -0
- package/dist/products/hooks/useProductAttributes.d.ts +59 -0
- package/dist/products/hooks/useProductAttributes.d.ts.map +1 -0
- package/dist/products/hooks/useProductAttributes.js +148 -0
- package/dist/products/hooks/useProductAttributes.js.map +1 -0
- package/dist/products/hooks/useProducts.d.ts +67 -0
- package/dist/products/hooks/useProducts.d.ts.map +1 -0
- package/dist/products/hooks/useProducts.js +132 -0
- package/dist/products/hooks/useProducts.js.map +1 -0
- package/dist/products/index.d.ts +94 -0
- package/dist/products/index.d.ts.map +1 -0
- package/dist/products/index.js +123 -0
- package/dist/products/index.js.map +1 -0
- package/dist/theme/ThemeProvider.d.ts +70 -0
- package/dist/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/theme/ThemeProvider.js +77 -0
- package/dist/theme/ThemeProvider.js.map +1 -0
- package/dist/theme/colors.d.ts +148 -0
- package/dist/theme/colors.d.ts.map +1 -0
- package/dist/theme/colors.js +219 -0
- package/dist/theme/colors.js.map +1 -0
- package/dist/theme/defaults.d.ts +212 -0
- package/dist/theme/defaults.d.ts.map +1 -0
- package/dist/theme/defaults.js +278 -0
- package/dist/theme/defaults.js.map +1 -0
- package/dist/theme/fonts.d.ts +59 -0
- package/dist/theme/fonts.d.ts.map +1 -0
- package/dist/theme/fonts.js +202 -0
- package/dist/theme/fonts.js.map +1 -0
- package/dist/theme/generator.d.ts +50 -0
- package/dist/theme/generator.d.ts.map +1 -0
- package/dist/theme/generator.js +322 -0
- package/dist/theme/generator.js.map +1 -0
- package/dist/theme/hooks.d.ts +110 -0
- package/dist/theme/hooks.d.ts.map +1 -0
- package/dist/theme/hooks.js +106 -0
- package/dist/theme/hooks.js.map +1 -0
- package/dist/theme/index.d.ts +37 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +85 -0
- package/dist/theme/index.js.map +1 -0
- package/package.json +7 -2
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use client';
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.CartProvider = CartProvider;
|
|
5
|
+
exports.useCartHydrated = useCartHydrated;
|
|
6
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
7
|
+
/**
|
|
8
|
+
* @rovela/sdk/cart/CartProvider
|
|
9
|
+
*
|
|
10
|
+
* Optional provider for SSR-safe cart hydration.
|
|
11
|
+
* Ensures cart state is properly hydrated from localStorage after mount.
|
|
12
|
+
*/
|
|
13
|
+
const react_1 = require("react");
|
|
14
|
+
const store_1 = require("./store");
|
|
15
|
+
// =============================================================================
|
|
16
|
+
// Component
|
|
17
|
+
// =============================================================================
|
|
18
|
+
/**
|
|
19
|
+
* CartProvider component for SSR-safe cart hydration.
|
|
20
|
+
*
|
|
21
|
+
* This provider is optional but recommended for Next.js apps.
|
|
22
|
+
* It ensures the cart is properly hydrated from localStorage
|
|
23
|
+
* after the component mounts, preventing hydration mismatches.
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```tsx
|
|
27
|
+
* // In app/layout.tsx:
|
|
28
|
+
* import { CartProvider } from '@rovela/sdk/cart'
|
|
29
|
+
*
|
|
30
|
+
* export default function RootLayout({ children }) {
|
|
31
|
+
* return (
|
|
32
|
+
* <html>
|
|
33
|
+
* <body>
|
|
34
|
+
* <CartProvider>
|
|
35
|
+
* {children}
|
|
36
|
+
* </CartProvider>
|
|
37
|
+
* </body>
|
|
38
|
+
* </html>
|
|
39
|
+
* )
|
|
40
|
+
* }
|
|
41
|
+
* ```
|
|
42
|
+
*/
|
|
43
|
+
function CartProvider({ children, onHydrated }) {
|
|
44
|
+
const [hydrated, setHydrated] = (0, react_1.useState)(false);
|
|
45
|
+
(0, react_1.useEffect)(() => {
|
|
46
|
+
// Check if already hydrated (e.g., from a previous mount)
|
|
47
|
+
if ((0, store_1.isCartHydrated)()) {
|
|
48
|
+
setHydrated(true);
|
|
49
|
+
onHydrated?.();
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
// Hydrate from localStorage
|
|
53
|
+
(0, store_1.hydrateCart)();
|
|
54
|
+
setHydrated(true);
|
|
55
|
+
onHydrated?.();
|
|
56
|
+
}, [onHydrated]);
|
|
57
|
+
// Render children immediately - cart hooks will return empty state
|
|
58
|
+
// until hydration completes, preventing SSR mismatch
|
|
59
|
+
return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children });
|
|
60
|
+
}
|
|
61
|
+
// =============================================================================
|
|
62
|
+
// Hook
|
|
63
|
+
// =============================================================================
|
|
64
|
+
/**
|
|
65
|
+
* Hook to check if the cart has been hydrated.
|
|
66
|
+
* Useful for showing loading states or skeleton UI.
|
|
67
|
+
*
|
|
68
|
+
* @example
|
|
69
|
+
* ```tsx
|
|
70
|
+
* import { useCartHydrated } from '@rovela/sdk/cart'
|
|
71
|
+
*
|
|
72
|
+
* function CartIcon() {
|
|
73
|
+
* const hydrated = useCartHydrated()
|
|
74
|
+
* const { itemCount } = useCart()
|
|
75
|
+
*
|
|
76
|
+
* if (!hydrated) {
|
|
77
|
+
* return <span className="animate-pulse">...</span>
|
|
78
|
+
* }
|
|
79
|
+
*
|
|
80
|
+
* return <span>{itemCount}</span>
|
|
81
|
+
* }
|
|
82
|
+
* ```
|
|
83
|
+
*/
|
|
84
|
+
function useCartHydrated() {
|
|
85
|
+
const [hydrated, setHydrated] = (0, react_1.useState)(false);
|
|
86
|
+
(0, react_1.useEffect)(() => {
|
|
87
|
+
// Check hydration status on mount
|
|
88
|
+
const checkHydration = () => {
|
|
89
|
+
if ((0, store_1.isCartHydrated)()) {
|
|
90
|
+
setHydrated(true);
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
// Initial check
|
|
94
|
+
checkHydration();
|
|
95
|
+
// Set up a small delay to catch late hydration
|
|
96
|
+
const timeout = setTimeout(checkHydration, 100);
|
|
97
|
+
return () => clearTimeout(timeout);
|
|
98
|
+
}, []);
|
|
99
|
+
return hydrated;
|
|
100
|
+
}
|
|
101
|
+
//# sourceMappingURL=CartProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CartProvider.js","sourceRoot":"","sources":["../../src/cart/CartProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAA;;AAwDZ,oCAoBC;AA0BD,0CAqBC;;AAzHD;;;;;GAKG;AAEH,iCAA2D;AAC3D,mCAAqD;AAiBrD,gFAAgF;AAChF,YAAY;AACZ,gFAAgF;AAEhF;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,SAAgB,YAAY,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAqB;IACtE,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IAE/C,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,0DAA0D;QAC1D,IAAI,IAAA,sBAAc,GAAE,EAAE,CAAC;YACrB,WAAW,CAAC,IAAI,CAAC,CAAA;YACjB,UAAU,EAAE,EAAE,CAAA;YACd,OAAM;QACR,CAAC;QAED,4BAA4B;QAC5B,IAAA,mBAAW,GAAE,CAAA;QACb,WAAW,CAAC,IAAI,CAAC,CAAA;QACjB,UAAU,EAAE,EAAE,CAAA;IAChB,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;IAEhB,mEAAmE;IACnE,qDAAqD;IACrD,OAAO,2DAAG,QAAQ,GAAI,CAAA;AACxB,CAAC;AAED,gFAAgF;AAChF,OAAO;AACP,gFAAgF;AAEhF;;;;;;;;;;;;;;;;;;;GAmBG;AACH,SAAgB,eAAe;IAC7B,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IAE/C,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,kCAAkC;QAClC,MAAM,cAAc,GAAG,GAAG,EAAE;YAC1B,IAAI,IAAA,sBAAc,GAAE,EAAE,CAAC;gBACrB,WAAW,CAAC,IAAI,CAAC,CAAA;YACnB,CAAC;QACH,CAAC,CAAA;QAED,gBAAgB;QAChB,cAAc,EAAE,CAAA;QAEhB,+CAA+C;QAC/C,MAAM,OAAO,GAAG,UAAU,CAAC,cAAc,EAAE,GAAG,CAAC,CAAA;QAE/C,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;IACpC,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,QAAQ,CAAA;AACjB,CAAC"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @rovela/sdk/cart/components/AddToCartButton
|
|
3
|
+
*
|
|
4
|
+
* Button component for adding products to the cart with feedback.
|
|
5
|
+
*/
|
|
6
|
+
import { type ReactNode } from 'react';
|
|
7
|
+
import type { Product, ProductVariant } from '../../core/types';
|
|
8
|
+
export interface AddToCartButtonProps {
|
|
9
|
+
/** Product to add */
|
|
10
|
+
product: Product;
|
|
11
|
+
/** Selected product variant (optional) */
|
|
12
|
+
selectedVariant?: ProductVariant | null;
|
|
13
|
+
/** Quantity to add */
|
|
14
|
+
quantity?: number;
|
|
15
|
+
/** Disable the button */
|
|
16
|
+
disabled?: boolean;
|
|
17
|
+
/** Custom className */
|
|
18
|
+
className?: string;
|
|
19
|
+
/** Button content (default: "Add to Cart") */
|
|
20
|
+
children?: ReactNode;
|
|
21
|
+
/** Callback after successful add */
|
|
22
|
+
onSuccess?: () => void;
|
|
23
|
+
/** Callback on error */
|
|
24
|
+
onError?: (error: Error) => void;
|
|
25
|
+
/** Show "Added!" feedback after click */
|
|
26
|
+
showFeedback?: boolean;
|
|
27
|
+
/** Duration of feedback in milliseconds */
|
|
28
|
+
feedbackDuration?: number;
|
|
29
|
+
/** Open cart drawer after adding */
|
|
30
|
+
openCartAfterAdd?: boolean;
|
|
31
|
+
/** Size variant */
|
|
32
|
+
size?: 'sm' | 'md' | 'lg';
|
|
33
|
+
/** Button style variant */
|
|
34
|
+
variant?: 'primary' | 'secondary' | 'outline';
|
|
35
|
+
/** Full width button */
|
|
36
|
+
fullWidth?: boolean;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* AddToCartButton component for adding products to the cart.
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```tsx
|
|
43
|
+
* import { AddToCartButton } from '@rovela/sdk/cart'
|
|
44
|
+
*
|
|
45
|
+
* function ProductCard({ product }) {
|
|
46
|
+
* return (
|
|
47
|
+
* <div>
|
|
48
|
+
* <h3>{product.name}</h3>
|
|
49
|
+
* <AddToCartButton
|
|
50
|
+
* product={product}
|
|
51
|
+
* showFeedback
|
|
52
|
+
* />
|
|
53
|
+
* </div>
|
|
54
|
+
* )
|
|
55
|
+
* }
|
|
56
|
+
* ```
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* ```tsx
|
|
60
|
+
* // With variant selection
|
|
61
|
+
* function ProductPage({ product, selectedVariant }) {
|
|
62
|
+
* return (
|
|
63
|
+
* <AddToCartButton
|
|
64
|
+
* product={product}
|
|
65
|
+
* selectedVariant={selectedVariant}
|
|
66
|
+
* quantity={2}
|
|
67
|
+
* onSuccess={() => console.log('Added!')}
|
|
68
|
+
* openCartAfterAdd
|
|
69
|
+
* >
|
|
70
|
+
* Add 2 to Cart
|
|
71
|
+
* </AddToCartButton>
|
|
72
|
+
* )
|
|
73
|
+
* }
|
|
74
|
+
* ```
|
|
75
|
+
*/
|
|
76
|
+
export declare function AddToCartButton({ product, selectedVariant, quantity, disabled, className, children, onSuccess, onError, showFeedback, feedbackDuration, openCartAfterAdd, size, variant: buttonVariant, fullWidth, }: AddToCartButtonProps): import("react/jsx-runtime").JSX.Element;
|
|
77
|
+
//# sourceMappingURL=AddToCartButton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AddToCartButton.d.ts","sourceRoot":"","sources":["../../../src/cart/components/AddToCartButton.tsx"],"names":[],"mappings":"AAEA;;;;GAIG;AAEH,OAAO,EAAyB,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AAE7D,OAAO,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAO/D,MAAM,WAAW,oBAAoB;IACnC,qBAAqB;IACrB,OAAO,EAAE,OAAO,CAAA;IAChB,0CAA0C;IAC1C,eAAe,CAAC,EAAE,cAAc,GAAG,IAAI,CAAA;IACvC,sBAAsB;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,yBAAyB;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,uBAAuB;IACvB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,SAAS,CAAA;IACpB,oCAAoC;IACpC,SAAS,CAAC,EAAE,MAAM,IAAI,CAAA;IACtB,wBAAwB;IACxB,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAA;IAChC,yCAAyC;IACzC,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,2CAA2C;IAC3C,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,oCAAoC;IACpC,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B,mBAAmB;IACnB,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAA;IACzB,2BAA2B;IAC3B,OAAO,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,SAAS,CAAA;IAC7C,wBAAwB;IACxB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB;AAMD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AACH,wBAAgB,eAAe,CAAC,EAC9B,OAAO,EACP,eAAe,EACf,QAAY,EACZ,QAAgB,EAChB,SAAS,EACT,QAAQ,EACR,SAAS,EACT,OAAO,EACP,YAAmB,EACnB,gBAAuB,EACvB,gBAAwB,EACxB,IAAW,EACX,OAAO,EAAE,aAAyB,EAClC,SAAiB,GAClB,EAAE,oBAAoB,2CAgJtB"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use client';
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.AddToCartButton = AddToCartButton;
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
/**
|
|
7
|
+
* @rovela/sdk/cart/components/AddToCartButton
|
|
8
|
+
*
|
|
9
|
+
* Button component for adding products to the cart with feedback.
|
|
10
|
+
*/
|
|
11
|
+
const react_1 = require("react");
|
|
12
|
+
const utils_1 = require("../../core/utils");
|
|
13
|
+
const store_1 = require("../store");
|
|
14
|
+
// =============================================================================
|
|
15
|
+
// Component
|
|
16
|
+
// =============================================================================
|
|
17
|
+
/**
|
|
18
|
+
* AddToCartButton component for adding products to the cart.
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```tsx
|
|
22
|
+
* import { AddToCartButton } from '@rovela/sdk/cart'
|
|
23
|
+
*
|
|
24
|
+
* function ProductCard({ product }) {
|
|
25
|
+
* return (
|
|
26
|
+
* <div>
|
|
27
|
+
* <h3>{product.name}</h3>
|
|
28
|
+
* <AddToCartButton
|
|
29
|
+
* product={product}
|
|
30
|
+
* showFeedback
|
|
31
|
+
* />
|
|
32
|
+
* </div>
|
|
33
|
+
* )
|
|
34
|
+
* }
|
|
35
|
+
* ```
|
|
36
|
+
*
|
|
37
|
+
* @example
|
|
38
|
+
* ```tsx
|
|
39
|
+
* // With variant selection
|
|
40
|
+
* function ProductPage({ product, selectedVariant }) {
|
|
41
|
+
* return (
|
|
42
|
+
* <AddToCartButton
|
|
43
|
+
* product={product}
|
|
44
|
+
* selectedVariant={selectedVariant}
|
|
45
|
+
* quantity={2}
|
|
46
|
+
* onSuccess={() => console.log('Added!')}
|
|
47
|
+
* openCartAfterAdd
|
|
48
|
+
* >
|
|
49
|
+
* Add 2 to Cart
|
|
50
|
+
* </AddToCartButton>
|
|
51
|
+
* )
|
|
52
|
+
* }
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
function AddToCartButton({ product, selectedVariant, quantity = 1, disabled = false, className, children, onSuccess, onError, showFeedback = true, feedbackDuration = 1500, openCartAfterAdd = false, size = 'md', variant: buttonVariant = 'primary', fullWidth = false, }) {
|
|
56
|
+
const [isAdding, setIsAdding] = (0, react_1.useState)(false);
|
|
57
|
+
const [showSuccess, setShowSuccess] = (0, react_1.useState)(false);
|
|
58
|
+
const addItem = (0, store_1.useCart)((state) => state.addItem);
|
|
59
|
+
const openCart = (0, store_1.useCart)((state) => state.openCart);
|
|
60
|
+
const handleClick = (0, react_1.useCallback)(async () => {
|
|
61
|
+
if (disabled || isAdding)
|
|
62
|
+
return;
|
|
63
|
+
setIsAdding(true);
|
|
64
|
+
try {
|
|
65
|
+
// Add item to cart
|
|
66
|
+
addItem(product, selectedVariant, quantity);
|
|
67
|
+
// Show success feedback
|
|
68
|
+
if (showFeedback) {
|
|
69
|
+
setShowSuccess(true);
|
|
70
|
+
setTimeout(() => {
|
|
71
|
+
setShowSuccess(false);
|
|
72
|
+
}, feedbackDuration);
|
|
73
|
+
}
|
|
74
|
+
// Open cart if requested
|
|
75
|
+
if (openCartAfterAdd) {
|
|
76
|
+
openCart();
|
|
77
|
+
}
|
|
78
|
+
// Call success callback
|
|
79
|
+
onSuccess?.();
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
onError?.(error instanceof Error ? error : new Error('Failed to add to cart'));
|
|
83
|
+
}
|
|
84
|
+
finally {
|
|
85
|
+
setIsAdding(false);
|
|
86
|
+
}
|
|
87
|
+
}, [
|
|
88
|
+
disabled,
|
|
89
|
+
isAdding,
|
|
90
|
+
product,
|
|
91
|
+
selectedVariant,
|
|
92
|
+
quantity,
|
|
93
|
+
addItem,
|
|
94
|
+
showFeedback,
|
|
95
|
+
feedbackDuration,
|
|
96
|
+
openCartAfterAdd,
|
|
97
|
+
openCart,
|
|
98
|
+
onSuccess,
|
|
99
|
+
onError,
|
|
100
|
+
]);
|
|
101
|
+
const sizeClasses = {
|
|
102
|
+
sm: 'px-3 py-1.5 text-sm',
|
|
103
|
+
md: 'px-4 py-2 text-sm',
|
|
104
|
+
lg: 'px-6 py-3 text-base',
|
|
105
|
+
};
|
|
106
|
+
const variantClasses = {
|
|
107
|
+
primary: (0, utils_1.cn)('bg-primary text-primary-foreground', 'hover:bg-primary/90', 'disabled:bg-muted disabled:text-muted-foreground'),
|
|
108
|
+
secondary: (0, utils_1.cn)('bg-secondary text-secondary-foreground', 'hover:bg-secondary/80', 'disabled:bg-muted disabled:text-muted-foreground'),
|
|
109
|
+
outline: (0, utils_1.cn)('border border-primary text-primary bg-transparent', 'hover:bg-primary hover:text-primary-foreground', 'disabled:border-muted disabled:text-muted-foreground'),
|
|
110
|
+
};
|
|
111
|
+
// Determine button content
|
|
112
|
+
let buttonContent;
|
|
113
|
+
if (showSuccess) {
|
|
114
|
+
buttonContent = ((0, jsx_runtime_1.jsxs)("span", { className: "flex items-center gap-2", children: [(0, jsx_runtime_1.jsx)("svg", { className: "h-4 w-4", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" }) }), "Added!"] }));
|
|
115
|
+
}
|
|
116
|
+
else if (isAdding) {
|
|
117
|
+
buttonContent = ((0, jsx_runtime_1.jsxs)("span", { className: "flex items-center gap-2", children: [(0, jsx_runtime_1.jsxs)("svg", { className: "h-4 w-4 animate-spin", fill: "none", viewBox: "0 0 24 24", children: [(0, jsx_runtime_1.jsx)("circle", { className: "opacity-25", cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "4" }), (0, jsx_runtime_1.jsx)("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" })] }), "Adding..."] }));
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
buttonContent = children || 'Add to Cart';
|
|
121
|
+
}
|
|
122
|
+
return ((0, jsx_runtime_1.jsx)("button", { type: "button", onClick: handleClick, disabled: disabled || isAdding, className: (0, utils_1.cn)('inline-flex items-center justify-center rounded-md font-medium', 'transition-colors focus:outline-none focus-visible:ring-2 focus-visible:ring-primary', 'disabled:cursor-not-allowed', sizeClasses[size], variantClasses[buttonVariant], fullWidth && 'w-full', className), "aria-label": `Add ${product.name} to cart`, children: buttonContent }));
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=AddToCartButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AddToCartButton.js","sourceRoot":"","sources":["../../../src/cart/components/AddToCartButton.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @rovela/sdk/cart/components/CartDrawer
|
|
3
|
+
*
|
|
4
|
+
* Slide-out cart drawer component.
|
|
5
|
+
*/
|
|
6
|
+
import { type ReactNode } from 'react';
|
|
7
|
+
export interface CartDrawerProps {
|
|
8
|
+
/** Controlled open state (optional) */
|
|
9
|
+
open?: boolean;
|
|
10
|
+
/** Callback when open state changes */
|
|
11
|
+
onOpenChange?: (open: boolean) => void;
|
|
12
|
+
/** Drawer position */
|
|
13
|
+
position?: 'left' | 'right';
|
|
14
|
+
/** Custom className for the drawer */
|
|
15
|
+
className?: string;
|
|
16
|
+
/** Overlay className */
|
|
17
|
+
overlayClassName?: string;
|
|
18
|
+
/** Show "Continue Shopping" link */
|
|
19
|
+
showContinueShopping?: boolean;
|
|
20
|
+
/** Checkout button href */
|
|
21
|
+
checkoutHref?: string;
|
|
22
|
+
/** Custom empty state content */
|
|
23
|
+
emptyState?: ReactNode;
|
|
24
|
+
/** Custom header content */
|
|
25
|
+
header?: ReactNode;
|
|
26
|
+
/** Custom footer content (replaces default summary + buttons) */
|
|
27
|
+
footer?: ReactNode;
|
|
28
|
+
/** Currency for price formatting */
|
|
29
|
+
currency?: string;
|
|
30
|
+
/** Locale for price formatting */
|
|
31
|
+
locale?: string;
|
|
32
|
+
/** Title text */
|
|
33
|
+
title?: string;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* CartDrawer component for displaying the shopping cart.
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* ```tsx
|
|
40
|
+
* import { CartDrawer, CartIcon, CartProvider } from '@rovela/sdk/cart'
|
|
41
|
+
*
|
|
42
|
+
* function Layout({ children }) {
|
|
43
|
+
* return (
|
|
44
|
+
* <CartProvider>
|
|
45
|
+
* <header>
|
|
46
|
+
* <CartIcon />
|
|
47
|
+
* </header>
|
|
48
|
+
* <main>{children}</main>
|
|
49
|
+
* <CartDrawer />
|
|
50
|
+
* </CartProvider>
|
|
51
|
+
* )
|
|
52
|
+
* }
|
|
53
|
+
* ```
|
|
54
|
+
*
|
|
55
|
+
* @example
|
|
56
|
+
* ```tsx
|
|
57
|
+
* // Controlled mode
|
|
58
|
+
* function App() {
|
|
59
|
+
* const [cartOpen, setCartOpen] = useState(false)
|
|
60
|
+
*
|
|
61
|
+
* return (
|
|
62
|
+
* <CartDrawer
|
|
63
|
+
* open={cartOpen}
|
|
64
|
+
* onOpenChange={setCartOpen}
|
|
65
|
+
* />
|
|
66
|
+
* )
|
|
67
|
+
* }
|
|
68
|
+
* ```
|
|
69
|
+
*/
|
|
70
|
+
export declare function CartDrawer({ open: controlledOpen, onOpenChange, position, className, overlayClassName, showContinueShopping, checkoutHref, emptyState, header, footer, currency, locale, title, }: CartDrawerProps): import("react/jsx-runtime").JSX.Element;
|
|
71
|
+
//# sourceMappingURL=CartDrawer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CartDrawer.d.ts","sourceRoot":"","sources":["../../../src/cart/components/CartDrawer.tsx"],"names":[],"mappings":"AAEA;;;;GAIG;AAEH,OAAO,EAA0B,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AAW9D,MAAM,WAAW,eAAe;IAC9B,uCAAuC;IACvC,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,uCAAuC;IACvC,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAA;IACtC,sBAAsB;IACtB,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;IAC3B,sCAAsC;IACtC,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,wBAAwB;IACxB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,oCAAoC;IACpC,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,2BAA2B;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,iCAAiC;IACjC,UAAU,CAAC,EAAE,SAAS,CAAA;IACtB,4BAA4B;IAC5B,MAAM,CAAC,EAAE,SAAS,CAAA;IAClB,iEAAiE;IACjE,MAAM,CAAC,EAAE,SAAS,CAAA;IAClB,oCAAoC;IACpC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,kCAAkC;IAClC,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,iBAAiB;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;CACf;AAMD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AACH,wBAAgB,UAAU,CAAC,EACzB,IAAI,EAAE,cAAc,EACpB,YAAY,EACZ,QAAkB,EAClB,SAAS,EACT,gBAAgB,EAChB,oBAA2B,EAC3B,YAA0B,EAC1B,UAAU,EACV,MAAM,EACN,MAAM,EACN,QAAgB,EAChB,MAAgB,EAChB,KAAuB,GACxB,EAAE,eAAe,2CAuNjB"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use client';
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.CartDrawer = CartDrawer;
|
|
8
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
9
|
+
/**
|
|
10
|
+
* @rovela/sdk/cart/components/CartDrawer
|
|
11
|
+
*
|
|
12
|
+
* Slide-out cart drawer component.
|
|
13
|
+
*/
|
|
14
|
+
const react_1 = require("react");
|
|
15
|
+
const link_1 = __importDefault(require("next/link"));
|
|
16
|
+
const utils_1 = require("../../core/utils");
|
|
17
|
+
const store_1 = require("../store");
|
|
18
|
+
const CartItem_1 = require("./CartItem");
|
|
19
|
+
const CartSummary_1 = require("./CartSummary");
|
|
20
|
+
// =============================================================================
|
|
21
|
+
// Component
|
|
22
|
+
// =============================================================================
|
|
23
|
+
/**
|
|
24
|
+
* CartDrawer component for displaying the shopping cart.
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```tsx
|
|
28
|
+
* import { CartDrawer, CartIcon, CartProvider } from '@rovela/sdk/cart'
|
|
29
|
+
*
|
|
30
|
+
* function Layout({ children }) {
|
|
31
|
+
* return (
|
|
32
|
+
* <CartProvider>
|
|
33
|
+
* <header>
|
|
34
|
+
* <CartIcon />
|
|
35
|
+
* </header>
|
|
36
|
+
* <main>{children}</main>
|
|
37
|
+
* <CartDrawer />
|
|
38
|
+
* </CartProvider>
|
|
39
|
+
* )
|
|
40
|
+
* }
|
|
41
|
+
* ```
|
|
42
|
+
*
|
|
43
|
+
* @example
|
|
44
|
+
* ```tsx
|
|
45
|
+
* // Controlled mode
|
|
46
|
+
* function App() {
|
|
47
|
+
* const [cartOpen, setCartOpen] = useState(false)
|
|
48
|
+
*
|
|
49
|
+
* return (
|
|
50
|
+
* <CartDrawer
|
|
51
|
+
* open={cartOpen}
|
|
52
|
+
* onOpenChange={setCartOpen}
|
|
53
|
+
* />
|
|
54
|
+
* )
|
|
55
|
+
* }
|
|
56
|
+
* ```
|
|
57
|
+
*/
|
|
58
|
+
function CartDrawer({ open: controlledOpen, onOpenChange, position = 'right', className, overlayClassName, showContinueShopping = true, checkoutHref = '/checkout', emptyState, header, footer, currency = 'USD', locale = 'en-US', title = 'Shopping Cart', }) {
|
|
59
|
+
// Use controlled state if provided, otherwise use store state
|
|
60
|
+
const storeIsOpen = (0, store_1.useCart)((state) => state.isOpen);
|
|
61
|
+
const closeCart = (0, store_1.useCart)((state) => state.closeCart);
|
|
62
|
+
const items = (0, store_1.useCart)((state) => state.items);
|
|
63
|
+
const updateQuantity = (0, store_1.useCart)((state) => state.updateQuantity);
|
|
64
|
+
const removeItem = (0, store_1.useCart)((state) => state.removeItem);
|
|
65
|
+
const isOpen = controlledOpen !== undefined ? controlledOpen : storeIsOpen;
|
|
66
|
+
const handleClose = (0, react_1.useCallback)(() => {
|
|
67
|
+
if (onOpenChange) {
|
|
68
|
+
onOpenChange(false);
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
closeCart();
|
|
72
|
+
}
|
|
73
|
+
}, [onOpenChange, closeCart]);
|
|
74
|
+
// Handle escape key
|
|
75
|
+
(0, react_1.useEffect)(() => {
|
|
76
|
+
const handleKeyDown = (e) => {
|
|
77
|
+
if (e.key === 'Escape' && isOpen) {
|
|
78
|
+
handleClose();
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
document.addEventListener('keydown', handleKeyDown);
|
|
82
|
+
return () => document.removeEventListener('keydown', handleKeyDown);
|
|
83
|
+
}, [isOpen, handleClose]);
|
|
84
|
+
// Prevent body scroll when drawer is open
|
|
85
|
+
(0, react_1.useEffect)(() => {
|
|
86
|
+
if (isOpen) {
|
|
87
|
+
const originalOverflow = document.body.style.overflow;
|
|
88
|
+
document.body.style.overflow = 'hidden';
|
|
89
|
+
return () => {
|
|
90
|
+
document.body.style.overflow = originalOverflow;
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
}, [isOpen]);
|
|
94
|
+
const itemCount = items.reduce((sum, item) => sum + item.quantity, 0);
|
|
95
|
+
const isEmpty = items.length === 0;
|
|
96
|
+
const positionClasses = {
|
|
97
|
+
left: {
|
|
98
|
+
drawer: 'left-0',
|
|
99
|
+
translate: isOpen ? 'translate-x-0' : '-translate-x-full',
|
|
100
|
+
},
|
|
101
|
+
right: {
|
|
102
|
+
drawer: 'right-0',
|
|
103
|
+
translate: isOpen ? 'translate-x-0' : 'translate-x-full',
|
|
104
|
+
},
|
|
105
|
+
};
|
|
106
|
+
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("div", { className: (0, utils_1.cn)('fixed inset-0 z-40 bg-black/50 transition-opacity duration-300', isOpen ? 'opacity-100' : 'opacity-0 pointer-events-none', overlayClassName), onClick: handleClose, "aria-hidden": "true" }), (0, jsx_runtime_1.jsx)("div", { className: (0, utils_1.cn)('fixed top-0 z-50 h-full w-full max-w-md', 'bg-background shadow-xl', 'transition-transform duration-300 ease-in-out', positionClasses[position].drawer, positionClasses[position].translate, className), role: "dialog", "aria-modal": "true", "aria-label": title, children: (0, jsx_runtime_1.jsxs)("div", { className: "flex h-full flex-col", children: [header || ((0, jsx_runtime_1.jsxs)("div", { className: "flex items-center justify-between border-b border-border px-4 py-4", children: [(0, jsx_runtime_1.jsxs)("h2", { className: "text-lg font-semibold text-foreground", children: [title, itemCount > 0 && ((0, jsx_runtime_1.jsxs)("span", { className: "ml-2 text-sm font-normal text-muted-foreground", children: ["(", itemCount, " ", itemCount === 1 ? 'item' : 'items', ")"] }))] }), (0, jsx_runtime_1.jsx)("button", { type: "button", onClick: handleClose, className: "rounded-md p-2 text-muted-foreground hover:text-foreground hover:bg-muted transition-colors", "aria-label": "Close cart", children: (0, jsx_runtime_1.jsx)("svg", { className: "h-5 w-5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M6 18L18 6M6 6l12 12" }) }) })] })), (0, jsx_runtime_1.jsx)("div", { className: "flex-1 overflow-y-auto px-4", children: isEmpty ? (emptyState || ((0, jsx_runtime_1.jsxs)("div", { className: "flex h-full flex-col items-center justify-center text-center py-12", children: [(0, jsx_runtime_1.jsx)("svg", { className: "h-16 w-16 text-muted-foreground mb-4", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 1, d: "M3 3h2l.4 2M7 13h10l4-8H5.4M7 13L5.4 5M7 13l-2.293 2.293c-.63.63-.184 1.707.707 1.707H17m0 0a2 2 0 100 4 2 2 0 000-4zm-8 2a2 2 0 11-4 0 2 2 0 014 0z" }) }), (0, jsx_runtime_1.jsx)("h3", { className: "text-lg font-medium text-foreground", children: "Your cart is empty" }), (0, jsx_runtime_1.jsx)("p", { className: "mt-1 text-sm text-muted-foreground", children: "Add some items to get started!" }), showContinueShopping && ((0, jsx_runtime_1.jsx)("button", { type: "button", onClick: handleClose, className: "mt-6 text-sm font-medium text-primary hover:text-primary/80 transition-colors", children: "Continue Shopping" }))] }))) : ((0, jsx_runtime_1.jsx)("div", { className: "divide-y divide-border", children: items.map((item) => ((0, jsx_runtime_1.jsx)(CartItem_1.CartItem, { item: item, onUpdateQuantity: (qty) => updateQuantity(item.id, qty), onRemove: () => removeItem(item.id), currency: currency, locale: locale }, item.id))) })) }), !isEmpty && (footer || ((0, jsx_runtime_1.jsxs)("div", { className: "border-t border-border px-4 py-4 space-y-4", children: [(0, jsx_runtime_1.jsx)(CartSummary_1.CartSummary, { showShipping: true, showTotal: true, currency: currency, locale: locale }), (0, jsx_runtime_1.jsxs)("div", { className: "space-y-2", children: [(0, jsx_runtime_1.jsx)(link_1.default, { href: checkoutHref, onClick: handleClose, className: (0, utils_1.cn)('flex w-full items-center justify-center rounded-md', 'bg-primary px-4 py-3 text-sm font-medium text-primary-foreground', 'hover:bg-primary/90 transition-colors', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-primary'), children: "Checkout" }), showContinueShopping && ((0, jsx_runtime_1.jsx)("button", { type: "button", onClick: handleClose, className: (0, utils_1.cn)('flex w-full items-center justify-center rounded-md', 'border border-border px-4 py-3 text-sm font-medium text-foreground', 'hover:bg-muted transition-colors', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-primary'), children: "Continue Shopping" }))] })] })))] }) })] }));
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=CartDrawer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CartDrawer.js","sourceRoot":"","sources":["../../../src/cart/components/CartDrawer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export interface CartIconProps {
|
|
2
|
+
/** Click handler (default: opens cart drawer) */
|
|
3
|
+
onClick?: () => void;
|
|
4
|
+
/** Show item count badge */
|
|
5
|
+
showCount?: boolean;
|
|
6
|
+
/** Badge position */
|
|
7
|
+
countPosition?: 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left';
|
|
8
|
+
/** Hide badge when count is 0 */
|
|
9
|
+
hideZero?: boolean;
|
|
10
|
+
/** Custom className */
|
|
11
|
+
className?: string;
|
|
12
|
+
/** Icon size */
|
|
13
|
+
size?: 'sm' | 'md' | 'lg';
|
|
14
|
+
/** Aria label */
|
|
15
|
+
ariaLabel?: string;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* CartIcon component for header navigation.
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```tsx
|
|
22
|
+
* import { CartIcon } from '@rovela/sdk/cart'
|
|
23
|
+
*
|
|
24
|
+
* function Header() {
|
|
25
|
+
* return (
|
|
26
|
+
* <header>
|
|
27
|
+
* <nav>
|
|
28
|
+
* <CartIcon showCount />
|
|
29
|
+
* </nav>
|
|
30
|
+
* </header>
|
|
31
|
+
* )
|
|
32
|
+
* }
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
export declare function CartIcon({ onClick, showCount, countPosition, hideZero, className, size, ariaLabel, }: CartIconProps): import("react/jsx-runtime").JSX.Element;
|
|
36
|
+
//# sourceMappingURL=CartIcon.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CartIcon.d.ts","sourceRoot":"","sources":["../../../src/cart/components/CartIcon.tsx"],"names":[],"mappings":"AAgBA,MAAM,WAAW,aAAa;IAC5B,iDAAiD;IACjD,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;IACpB,4BAA4B;IAC5B,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,qBAAqB;IACrB,aAAa,CAAC,EAAE,WAAW,GAAG,UAAU,GAAG,cAAc,GAAG,aAAa,CAAA;IACzE,iCAAiC;IACjC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,uBAAuB;IACvB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gBAAgB;IAChB,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAA;IACzB,iBAAiB;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAMD;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,QAAQ,CAAC,EACvB,OAAO,EACP,SAAgB,EAChB,aAA2B,EAC3B,QAAe,EACf,SAAS,EACT,IAAW,EACX,SAA2B,GAC5B,EAAE,aAAa,2CAmGf"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
'use client';
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.CartIcon = CartIcon;
|
|
5
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
+
/**
|
|
7
|
+
* @rovela/sdk/cart/components/CartIcon
|
|
8
|
+
*
|
|
9
|
+
* Cart icon button with item count badge.
|
|
10
|
+
*/
|
|
11
|
+
const utils_1 = require("../../core/utils");
|
|
12
|
+
const store_1 = require("../store");
|
|
13
|
+
const CartProvider_1 = require("../CartProvider");
|
|
14
|
+
// =============================================================================
|
|
15
|
+
// Component
|
|
16
|
+
// =============================================================================
|
|
17
|
+
/**
|
|
18
|
+
* CartIcon component for header navigation.
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```tsx
|
|
22
|
+
* import { CartIcon } from '@rovela/sdk/cart'
|
|
23
|
+
*
|
|
24
|
+
* function Header() {
|
|
25
|
+
* return (
|
|
26
|
+
* <header>
|
|
27
|
+
* <nav>
|
|
28
|
+
* <CartIcon showCount />
|
|
29
|
+
* </nav>
|
|
30
|
+
* </header>
|
|
31
|
+
* )
|
|
32
|
+
* }
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
function CartIcon({ onClick, showCount = true, countPosition = 'top-right', hideZero = true, className, size = 'md', ariaLabel = 'Shopping cart', }) {
|
|
36
|
+
const openCart = (0, store_1.useCart)((state) => state.openCart);
|
|
37
|
+
const itemCount = (0, store_1.useCart)((state) => state.items.reduce((sum, item) => sum + item.quantity, 0));
|
|
38
|
+
const hydrated = (0, CartProvider_1.useCartHydrated)();
|
|
39
|
+
const handleClick = onClick || openCart;
|
|
40
|
+
const sizeClasses = {
|
|
41
|
+
sm: {
|
|
42
|
+
button: 'h-8 w-8',
|
|
43
|
+
icon: 'h-4 w-4',
|
|
44
|
+
badge: 'h-4 min-w-4 text-[10px]',
|
|
45
|
+
badgeOffset: '-top-1 -right-1',
|
|
46
|
+
},
|
|
47
|
+
md: {
|
|
48
|
+
button: 'h-10 w-10',
|
|
49
|
+
icon: 'h-5 w-5',
|
|
50
|
+
badge: 'h-5 min-w-5 text-xs',
|
|
51
|
+
badgeOffset: '-top-1.5 -right-1.5',
|
|
52
|
+
},
|
|
53
|
+
lg: {
|
|
54
|
+
button: 'h-12 w-12',
|
|
55
|
+
icon: 'h-6 w-6',
|
|
56
|
+
badge: 'h-6 min-w-6 text-sm',
|
|
57
|
+
badgeOffset: '-top-2 -right-2',
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
const classes = sizeClasses[size];
|
|
61
|
+
const positionClasses = {
|
|
62
|
+
'top-right': classes.badgeOffset,
|
|
63
|
+
'top-left': classes.badgeOffset.replace('right', 'left'),
|
|
64
|
+
'bottom-right': classes.badgeOffset.replace('top', 'bottom'),
|
|
65
|
+
'bottom-left': classes.badgeOffset.replace('top', 'bottom').replace('right', 'left'),
|
|
66
|
+
};
|
|
67
|
+
const showBadge = showCount && hydrated && (!hideZero || itemCount > 0);
|
|
68
|
+
return ((0, jsx_runtime_1.jsxs)("button", { type: "button", onClick: handleClick, className: (0, utils_1.cn)('relative flex items-center justify-center rounded-md', 'text-foreground hover:bg-muted transition-colors', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-primary', classes.button, className), "aria-label": `${ariaLabel}${itemCount > 0 ? `, ${itemCount} items` : ''}`, children: [(0, jsx_runtime_1.jsx)("svg", { className: classes.icon, fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: (0, jsx_runtime_1.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M3 3h2l.4 2M7 13h10l4-8H5.4M7 13L5.4 5M7 13l-2.293 2.293c-.63.63-.184 1.707.707 1.707H17m0 0a2 2 0 100 4 2 2 0 000-4zm-8 2a2 2 0 11-4 0 2 2 0 014 0z" }) }), showBadge && ((0, jsx_runtime_1.jsx)("span", { className: (0, utils_1.cn)('absolute flex items-center justify-center rounded-full', 'bg-primary text-primary-foreground font-medium', 'px-1', classes.badge, positionClasses[countPosition]), "aria-hidden": "true", children: itemCount > 99 ? '99+' : itemCount })), showCount && !hydrated && ((0, jsx_runtime_1.jsx)("span", { className: (0, utils_1.cn)('absolute flex items-center justify-center rounded-full', 'bg-muted animate-pulse', classes.badge, positionClasses[countPosition]), "aria-hidden": "true" }))] }));
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=CartIcon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CartIcon.js","sourceRoot":"","sources":["../../../src/cart/components/CartIcon.tsx"],"names":[],"mappings":"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"}
|