@mohasinac/appkit 2.2.0 → 2.3.1
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/README.md +94 -31
- package/dist/client.d.ts +95 -15
- package/dist/client.js +143 -15
- package/dist/constants/api-endpoints.d.ts +46 -0
- package/dist/constants/api-endpoints.js +23 -0
- package/dist/constants/index.d.ts +1 -0
- package/dist/constants/index.js +1 -0
- package/dist/contracts/auth.js +1 -1
- package/dist/contracts/client-auth.js +1 -1
- package/dist/contracts/client-payment-gateway.js +1 -1
- package/dist/contracts/client-realtime.js +1 -1
- package/dist/contracts/client-session.js +17 -5
- package/dist/contracts/config.js +1 -1
- package/dist/contracts/email.js +1 -1
- package/dist/contracts/feature.js +1 -1
- package/dist/contracts/field-ops.js +2 -2
- package/dist/contracts/form.js +1 -1
- package/dist/contracts/infra.js +1 -1
- package/dist/contracts/payment.js +1 -1
- package/dist/contracts/repository.js +2 -2
- package/dist/contracts/search.js +1 -1
- package/dist/contracts/shipping.js +1 -1
- package/dist/contracts/storage.js +1 -1
- package/dist/contracts/style.js +1 -1
- package/dist/core/hooks/useSiteSettings.js +0 -1
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.js +1 -0
- package/dist/core/integration-keys.d.ts +0 -16
- package/dist/core/integration-keys.js +0 -1
- package/dist/core/mutation-events.js +2 -2
- package/dist/core/server-action.js +5 -5
- package/dist/core/unit-of-work.d.ts +13 -14
- package/dist/core/unit-of-work.js +0 -1
- package/dist/errors/messages.d.ts +1 -0
- package/dist/errors/messages.js +1 -0
- package/dist/features/about/components/AboutView.d.ts +14 -14
- package/dist/features/about/components/AboutView.js +2 -2
- package/dist/features/about/components/FAQPageView.d.ts +6 -0
- package/dist/features/about/components/FAQPageView.js +29 -0
- package/dist/features/about/components/FeesView.d.ts +4 -0
- package/dist/features/about/components/FeesView.js +63 -0
- package/dist/features/about/components/HelpPageView.d.ts +4 -0
- package/dist/features/about/components/HelpPageView.js +63 -0
- package/dist/features/about/components/HowAuctionsWorkView.d.ts +4 -0
- package/dist/features/about/components/HowAuctionsWorkView.js +87 -0
- package/dist/features/about/components/HowCheckoutWorksView.d.ts +4 -0
- package/dist/features/about/components/HowCheckoutWorksView.js +73 -0
- package/dist/features/about/components/HowOffersWorkView.d.ts +4 -0
- package/dist/features/about/components/HowOffersWorkView.js +58 -0
- package/dist/features/about/components/HowOrdersWorkView.d.ts +4 -0
- package/dist/features/about/components/HowOrdersWorkView.js +131 -0
- package/dist/features/about/components/HowPayoutsWorkView.d.ts +4 -0
- package/dist/features/about/components/HowPayoutsWorkView.js +87 -0
- package/dist/features/about/components/HowPreOrdersWorkView.d.ts +4 -0
- package/dist/features/about/components/HowPreOrdersWorkView.js +87 -0
- package/dist/features/about/components/HowReviewsWorkView.d.ts +4 -0
- package/dist/features/about/components/HowReviewsWorkView.js +72 -0
- package/dist/features/about/components/PolicyPageView.d.ts +6 -0
- package/dist/features/about/components/PolicyPageView.js +28 -0
- package/dist/features/about/components/PublicProfileView.d.ts +5 -0
- package/dist/features/about/components/PublicProfileView.js +21 -0
- package/dist/features/about/components/SecurityPrivacyView.d.ts +4 -0
- package/dist/features/about/components/SecurityPrivacyView.js +122 -0
- package/dist/features/about/components/ShippingPolicyView.d.ts +4 -0
- package/dist/features/about/components/ShippingPolicyView.js +59 -0
- package/dist/features/about/components/TrackOrderView.d.ts +4 -0
- package/dist/features/about/components/TrackOrderView.js +43 -0
- package/dist/features/about/components/UnauthorizedView.d.ts +4 -0
- package/dist/features/about/components/UnauthorizedView.js +29 -0
- package/dist/features/about/index.d.ts +32 -0
- package/dist/features/about/index.js +16 -0
- package/dist/features/account/components/AddressBook.js +3 -2
- package/dist/features/account/components/AddressForm.js +2 -1
- package/dist/features/account/components/AddressSelectorCreate.js +2 -1
- package/dist/features/account/components/ChatList.js +0 -1
- package/dist/features/account/components/ChatWindow.js +2 -2
- package/dist/features/account/components/MessagesView.js +2 -1
- package/dist/features/account/components/NotificationBell.js +3 -2
- package/dist/features/account/components/UserSidebar.d.ts +15 -0
- package/dist/features/account/components/UserSidebar.js +18 -0
- package/dist/features/account/components/index.d.ts +2 -0
- package/dist/features/account/components/index.js +1 -0
- package/dist/features/account/hooks/useAccount.js +0 -1
- package/dist/features/account/hooks/useAddressSelector.js +0 -1
- package/dist/features/account/hooks/useAddresses.js +0 -1
- package/dist/features/account/hooks/useNotifications.js +0 -1
- package/dist/features/account/hooks/useProfile.js +0 -1
- package/dist/features/account/hooks/useProfileStats.js +0 -1
- package/dist/features/account/hooks/usePublicProfile.js +0 -1
- package/dist/features/account/repository/address.repository.js +2 -3
- package/dist/features/account/schemas/index.d.ts +20 -20
- package/dist/features/account/schemas/index.js +2 -2
- package/dist/features/account/server.d.ts +0 -1
- package/dist/features/account/server.js +0 -1
- package/dist/features/account/types/index.js +1 -1
- package/dist/features/admin/components/AdminAdEditorView.d.ts +10 -0
- package/dist/features/admin/components/AdminAdEditorView.js +225 -0
- package/dist/features/admin/components/AdminAdsView.d.ts +25 -0
- package/dist/features/admin/components/AdminAdsView.js +165 -0
- package/dist/features/admin/components/AdminAnalyticsView.d.ts +2 -1
- package/dist/features/admin/components/AdminAnalyticsView.js +19 -5
- package/dist/features/admin/components/AdminBidsView.d.ts +1 -1
- package/dist/features/admin/components/AdminBidsView.js +26 -2
- package/dist/features/admin/components/AdminBlogView.d.ts +1 -1
- package/dist/features/admin/components/AdminBlogView.js +34 -2
- package/dist/features/admin/components/AdminCarouselView.d.ts +3 -8
- package/dist/features/admin/components/AdminCarouselView.js +39 -4
- package/dist/features/admin/components/AdminCategoriesView.d.ts +3 -8
- package/dist/features/admin/components/AdminCategoriesView.js +40 -4
- package/dist/features/admin/components/AdminCouponsView.d.ts +1 -1
- package/dist/features/admin/components/AdminCouponsView.js +28 -2
- package/dist/features/admin/components/AdminDashboardView.d.ts +2 -1
- package/dist/features/admin/components/AdminDashboardView.js +28 -3
- package/dist/features/admin/components/AdminFaqsView.d.ts +1 -1
- package/dist/features/admin/components/AdminFaqsView.js +23 -2
- package/dist/features/admin/components/AdminFeatureFlagsView.js +48 -3
- package/dist/features/admin/components/AdminFilterBar.js +3 -4
- package/dist/features/admin/components/AdminListingScaffold.d.ts +26 -0
- package/dist/features/admin/components/AdminListingScaffold.js +57 -0
- package/dist/features/admin/components/AdminMediaView.d.ts +7 -7
- package/dist/features/admin/components/AdminMediaView.js +50 -4
- package/dist/features/admin/components/AdminNavigationView.d.ts +7 -3
- package/dist/features/admin/components/AdminNavigationView.js +81 -4
- package/dist/features/admin/components/AdminOrdersView.d.ts +1 -1
- package/dist/features/admin/components/AdminOrdersView.js +28 -2
- package/dist/features/admin/components/AdminPageHeader.js +1 -2
- package/dist/features/admin/components/AdminPayoutsView.d.ts +1 -1
- package/dist/features/admin/components/AdminPayoutsView.js +28 -2
- package/dist/features/admin/components/AdminProductsView.d.ts +1 -1
- package/dist/features/admin/components/AdminProductsView.js +26 -2
- package/dist/features/admin/components/AdminReviewsView.d.ts +1 -1
- package/dist/features/admin/components/AdminReviewsView.js +24 -2
- package/dist/features/admin/components/AdminSectionsView.d.ts +3 -7
- package/dist/features/admin/components/AdminSectionsView.js +947 -4
- package/dist/features/admin/components/AdminSessionsManager.js +1 -2
- package/dist/features/admin/components/AdminSidebar.d.ts +5 -1
- package/dist/features/admin/components/AdminSidebar.js +5 -4
- package/dist/features/admin/components/AdminSiteView.js +43 -3
- package/dist/features/admin/components/AdminStoresView.d.ts +1 -1
- package/dist/features/admin/components/AdminStoresView.js +26 -2
- package/dist/features/admin/components/AdminUsersView.d.ts +1 -1
- package/dist/features/admin/components/AdminUsersView.js +38 -2
- package/dist/features/admin/components/DashboardStats.js +7 -7
- package/dist/features/admin/components/DataTable.js +2 -2
- package/dist/features/admin/components/DrawerFormFooter.js +1 -2
- package/dist/features/admin/components/QuickActionsPanel.js +1 -2
- package/dist/features/admin/components/analytics/AdminStatCard.js +0 -1
- package/dist/features/admin/components/analytics/AdminTopProductsTable.js +1 -2
- package/dist/features/admin/components/index.d.ts +4 -0
- package/dist/features/admin/components/index.js +2 -0
- package/dist/features/admin/hooks/useAdmin.js +0 -1
- package/dist/features/admin/hooks/useAdminListingData.d.ts +28 -0
- package/dist/features/admin/hooks/useAdminListingData.js +100 -0
- package/dist/features/admin/hooks/useAdminSectionsListing.d.ts +28 -0
- package/dist/features/admin/hooks/useAdminSectionsListing.js +34 -0
- package/dist/features/admin/index.d.ts +2 -0
- package/dist/features/admin/index.js +2 -0
- package/dist/features/admin/repository/chat.repository.d.ts +1 -1
- package/dist/features/admin/repository/chat.repository.js +1 -1
- package/dist/features/admin/repository/notification.repository.d.ts +0 -1
- package/dist/features/admin/repository/notification.repository.js +9 -7
- package/dist/features/admin/repository/site-settings.repository.d.ts +2 -0
- package/dist/features/admin/repository/site-settings.repository.js +25 -2
- package/dist/features/admin/schemas/firestore.d.ts +5 -1
- package/dist/features/admin/schemas/firestore.js +5 -0
- package/dist/features/admin/server.d.ts +0 -1
- package/dist/features/admin/server.js +0 -1
- package/dist/features/auctions/actions/bid-actions.js +1 -1
- package/dist/features/auctions/api/route.js +1 -1
- package/dist/features/auctions/columns/index.js +2 -2
- package/dist/features/auctions/components/AuctionCard.js +3 -2
- package/dist/features/auctions/components/AuctionDetailPageView.d.ts +4 -0
- package/dist/features/auctions/components/AuctionDetailPageView.js +71 -0
- package/dist/features/auctions/components/AuctionsListView.d.ts +1 -0
- package/dist/features/auctions/components/AuctionsListView.js +17 -0
- package/dist/features/auctions/components/MarketplaceAuctionCard.js +5 -2
- package/dist/features/auctions/components/MarketplaceAuctionGrid.js +0 -1
- package/dist/features/auctions/components/index.d.ts +3 -0
- package/dist/features/auctions/components/index.js +2 -0
- package/dist/features/auctions/hooks/useAuctions.js +0 -1
- package/dist/features/auctions/hooks/usePlaceBid.js +0 -1
- package/dist/features/auctions/repository/bid.repository.js +3 -13
- package/dist/features/auctions/schemas/index.d.ts +22 -22
- package/dist/features/auctions/schemas/index.js +2 -2
- package/dist/features/auctions/server.d.ts +0 -1
- package/dist/features/auctions/server.js +0 -1
- package/dist/features/auth/api/route.js +2 -2
- package/dist/features/auth/components/AuthStatusPanel.js +3 -3
- package/dist/features/auth/components/ForgotPasswordView.js +2 -2
- package/dist/features/auth/components/Guards.d.ts +2 -2
- package/dist/features/auth/components/Guards.js +2 -2
- package/dist/features/auth/components/LoginForm.js +1 -1
- package/dist/features/auth/components/OAuthLoadingView.d.ts +1 -0
- package/dist/features/auth/components/OAuthLoadingView.js +5 -0
- package/dist/features/auth/components/RegisterForm.js +1 -1
- package/dist/features/auth/components/ResetPasswordView.js +1 -1
- package/dist/features/auth/components/SocialAuthButtons.js +1 -2
- package/dist/features/auth/components/VerifyEmailView.js +4 -3
- package/dist/features/auth/components/index.d.ts +1 -0
- package/dist/features/auth/components/index.js +1 -0
- package/dist/features/auth/consent-otp.d.ts +5 -3
- package/dist/features/auth/consent-otp.js +0 -1
- package/dist/features/auth/hooks/useAuth.d.ts +0 -1
- package/dist/features/auth/hooks/useAuth.js +0 -1
- package/dist/features/auth/hooks/useAuthEvent.js +0 -1
- package/dist/features/auth/hooks/useLogout.js +0 -1
- package/dist/features/auth/repository/session.repository.d.ts +0 -1
- package/dist/features/auth/repository/session.repository.js +0 -1
- package/dist/features/auth/repository/token.repository.d.ts +0 -1
- package/dist/features/auth/repository/token.repository.js +0 -1
- package/dist/features/auth/repository/user.repository.d.ts +0 -1
- package/dist/features/auth/repository/user.repository.js +18 -29
- package/dist/features/auth/schemas/firestore.js +1 -1
- package/dist/features/auth/schemas/index.d.ts +4 -4
- package/dist/features/auth/schemas/index.js +2 -2
- package/dist/features/auth/server.d.ts +0 -1
- package/dist/features/auth/server.js +0 -1
- package/dist/features/auth/token-store.d.ts +0 -1
- package/dist/features/auth/token-store.js +0 -1
- package/dist/features/before-after/hooks/useBeforeAfter.js +0 -1
- package/dist/features/before-after/schemas/index.d.ts +2 -2
- package/dist/features/before-after/server.d.ts +0 -1
- package/dist/features/before-after/server.js +0 -1
- package/dist/features/blog/actions/blog-actions.d.ts +53 -53
- package/dist/features/blog/actions/blog-actions.js +2 -2
- package/dist/features/blog/api/[slug]/route.js +1 -1
- package/dist/features/blog/api/route.js +1 -1
- package/dist/features/blog/components/BlogFeaturedCard.js +9 -7
- package/dist/features/blog/components/BlogFilters.js +0 -1
- package/dist/features/blog/components/BlogIndexListing.d.ts +4 -0
- package/dist/features/blog/components/BlogIndexListing.js +26 -0
- package/dist/features/blog/components/BlogIndexPageView.d.ts +1 -0
- package/dist/features/blog/components/BlogIndexPageView.js +11 -0
- package/dist/features/blog/components/BlogListView.js +4 -3
- package/dist/features/blog/components/BlogPostForm.js +3 -3
- package/dist/features/blog/components/BlogPostView.js +3 -3
- package/dist/features/blog/components/index.d.ts +2 -0
- package/dist/features/blog/components/index.js +1 -0
- package/dist/features/blog/hooks/useBlog.js +0 -1
- package/dist/features/blog/repository/blog.repository.d.ts +0 -1
- package/dist/features/blog/repository/blog.repository.js +0 -1
- package/dist/features/blog/schemas/index.d.ts +35 -35
- package/dist/features/blog/schemas/index.js +2 -2
- package/dist/features/blog/server.d.ts +0 -1
- package/dist/features/blog/server.js +0 -1
- package/dist/features/cart/components/CartDrawer.js +5 -4
- package/dist/features/cart/components/CartSummary.js +1 -1
- package/dist/features/cart/components/CartView.js +1 -1
- package/dist/features/cart/components/CheckoutAddressStep.js +0 -1
- package/dist/features/cart/components/CheckoutOtpModal.js +1 -2
- package/dist/features/cart/components/CheckoutView.js +1 -1
- package/dist/features/cart/hooks/useCart.js +0 -1
- package/dist/features/cart/hooks/useCartCount.js +0 -1
- package/dist/features/cart/hooks/useCartQuery.js +0 -1
- package/dist/features/cart/hooks/useCheckoutReadQueries.js +0 -1
- package/dist/features/cart/hooks/useOrder.js +0 -1
- package/dist/features/cart/repository/cart.repository.d.ts +0 -1
- package/dist/features/cart/repository/cart.repository.js +0 -1
- package/dist/features/cart/schemas/index.d.ts +19 -19
- package/dist/features/cart/server.d.ts +0 -1
- package/dist/features/cart/server.js +0 -1
- package/dist/features/cart/utils/guest-cart.d.ts +0 -1
- package/dist/features/cart/utils/guest-cart.js +0 -1
- package/dist/features/categories/api/[id]/route.js +3 -3
- package/dist/features/categories/api/route.js +5 -5
- package/dist/features/categories/components/BreadcrumbTrail.js +0 -1
- package/dist/features/categories/components/CategoriesIndexListing.d.ts +5 -0
- package/dist/features/categories/components/CategoriesIndexListing.js +44 -0
- package/dist/features/categories/components/CategoriesIndexPageView.d.ts +1 -0
- package/dist/features/categories/components/CategoriesIndexPageView.js +12 -0
- package/dist/features/categories/components/CategoriesListView.js +3 -3
- package/dist/features/categories/components/CategoryDetailPageView.d.ts +4 -0
- package/dist/features/categories/components/CategoryDetailPageView.js +25 -0
- package/dist/features/categories/components/CategoryFilters.js +0 -1
- package/dist/features/categories/components/CategoryForm.js +4 -4
- package/dist/features/categories/components/CategoryGrid.d.ts +2 -1
- package/dist/features/categories/components/CategoryGrid.js +11 -5
- package/dist/features/categories/components/CategoryProductsListing.d.ts +5 -0
- package/dist/features/categories/components/CategoryProductsListing.js +29 -0
- package/dist/features/categories/components/CategoryProductsView.js +3 -3
- package/dist/features/categories/components/CategorySelectorCreate.js +2 -2
- package/dist/features/categories/components/CategorySortSelect.js +0 -1
- package/dist/features/categories/components/CategoryTableColumns.js +3 -3
- package/dist/features/categories/components/CategoryTree.js +1 -1
- package/dist/features/categories/components/ConcernCard.js +2 -1
- package/dist/features/categories/components/index.d.ts +4 -0
- package/dist/features/categories/components/index.js +2 -0
- package/dist/features/categories/hooks/useCategories.js +0 -1
- package/dist/features/categories/hooks/useCategorySelector.js +0 -1
- package/dist/features/categories/repository/categories.repository.d.ts +0 -1
- package/dist/features/categories/repository/categories.repository.js +0 -1
- package/dist/features/categories/schemas/index.d.ts +40 -40
- package/dist/features/categories/schemas/index.js +2 -2
- package/dist/features/categories/server.d.ts +0 -1
- package/dist/features/categories/server.js +0 -1
- package/dist/features/checkout/actions/checkout-actions.d.ts +7 -1
- package/dist/features/checkout/actions/checkout-actions.js +0 -1
- package/dist/features/checkout/components/CheckoutStepper.js +4 -3
- package/dist/features/checkout/hooks/useCheckoutApi.js +0 -1
- package/dist/features/checkout/hooks/usePaymentCheckout.d.ts +0 -1
- package/dist/features/checkout/hooks/usePaymentCheckout.js +1 -2
- package/dist/features/checkout/server.d.ts +0 -1
- package/dist/features/checkout/server.js +0 -1
- package/dist/features/collections/components/CollectionCard.js +2 -2
- package/dist/features/collections/hooks/useCollections.js +0 -1
- package/dist/features/collections/schemas/index.d.ts +5 -5
- package/dist/features/collections/server.d.ts +0 -1
- package/dist/features/collections/server.js +0 -1
- package/dist/features/consultation/hooks/useBookConsultation.js +0 -1
- package/dist/features/consultation/schemas/index.d.ts +7 -7
- package/dist/features/consultation/server.d.ts +0 -1
- package/dist/features/consultation/server.js +0 -1
- package/dist/features/contact/components/ContactInfoSidebar.js +1 -2
- package/dist/features/contact/components/ContactPageView.d.ts +1 -0
- package/dist/features/contact/components/ContactPageView.js +45 -0
- package/dist/features/contact/components/index.d.ts +1 -0
- package/dist/features/contact/components/index.js +1 -0
- package/dist/features/contact/email.d.ts +0 -1
- package/dist/features/contact/email.js +0 -1
- package/dist/features/contact/hooks/useContactSubmit.js +0 -1
- package/dist/features/contact/server.d.ts +0 -1
- package/dist/features/contact/server.js +0 -1
- package/dist/features/copilot/components/AdminCopilotView.d.ts +5 -5
- package/dist/features/copilot/components/AdminCopilotView.js +26 -11
- package/dist/features/copilot/hooks/useCopilotChat.d.ts +3 -0
- package/dist/features/copilot/hooks/useCopilotChat.js +9 -1
- package/dist/features/copilot/hooks/useCopilotFeedback.js +0 -1
- package/dist/features/corporate/hooks/useSubmitCorporateInquiry.js +0 -1
- package/dist/features/corporate/schemas/index.d.ts +1 -1
- package/dist/features/corporate/server.d.ts +0 -1
- package/dist/features/corporate/server.js +0 -1
- package/dist/features/cron/firebase-adapters.js +2 -2
- package/dist/features/cron/index.js +3 -3
- package/dist/features/cron/registry.js +4 -4
- package/dist/features/events/actions/event-actions.js +7 -7
- package/dist/features/events/api/[id]/route.js +1 -1
- package/dist/features/events/components/AdminEventEntriesView.d.ts +7 -2
- package/dist/features/events/components/AdminEventEntriesView.js +114 -7
- package/dist/features/events/components/AdminEventsView.d.ts +3 -10
- package/dist/features/events/components/AdminEventsView.js +34 -4
- package/dist/features/events/components/EventBanner.js +1 -1
- package/dist/features/events/components/EventCard.d.ts +1 -0
- package/dist/features/events/components/EventCard.js +7 -5
- package/dist/features/events/components/EventFilters.js +0 -1
- package/dist/features/events/components/EventFormDrawer.js +1 -1
- package/dist/features/events/components/EventLeaderboard.js +3 -3
- package/dist/features/events/components/EventParticipateView.js +2 -2
- package/dist/features/events/components/EventsIndexListing.d.ts +4 -0
- package/dist/features/events/components/EventsIndexListing.js +24 -0
- package/dist/features/events/components/EventsListPageView.d.ts +1 -0
- package/dist/features/events/components/EventsListPageView.js +16 -0
- package/dist/features/events/components/index.d.ts +2 -0
- package/dist/features/events/components/index.js +1 -0
- package/dist/features/events/hooks/useBulkEvent.js +0 -1
- package/dist/features/events/hooks/useEvent.js +0 -1
- package/dist/features/events/hooks/useEvents.js +0 -1
- package/dist/features/events/schemas/index.d.ts +45 -45
- package/dist/features/events/schemas/index.js +2 -2
- package/dist/features/events/server.d.ts +0 -1
- package/dist/features/events/server.js +0 -1
- package/dist/features/faq/actions/faq-actions.d.ts +20 -20
- package/dist/features/faq/actions/faq-actions.js +2 -2
- package/dist/features/faq/components/ContactCTA.js +0 -1
- package/dist/features/faq/components/FAQAccordion.js +5 -5
- package/dist/features/faq/components/FAQCategorySidebar.js +0 -1
- package/dist/features/faq/components/FAQHelpfulButtons.js +2 -2
- package/dist/features/faq/components/FAQPageContent.d.ts +4 -1
- package/dist/features/faq/components/FAQPageContent.js +14 -15
- package/dist/features/faq/components/FAQSortDropdown.js +1 -2
- package/dist/features/faq/components/RelatedFAQs.js +0 -1
- package/dist/features/faq/hooks/useFAQs.js +0 -1
- package/dist/features/faq/hooks/useFaqList.js +0 -1
- package/dist/features/faq/hooks/useFaqVote.js +0 -1
- package/dist/features/faq/repository/faqs.repository.d.ts +0 -1
- package/dist/features/faq/repository/faqs.repository.js +0 -1
- package/dist/features/faq/schemas/index.d.ts +18 -18
- package/dist/features/faq/schemas/index.js +2 -2
- package/dist/features/faq/server.d.ts +0 -1
- package/dist/features/faq/server.js +0 -1
- package/dist/features/filters/FilterFacetSection.js +1 -1
- package/dist/features/filters/index.d.ts +4 -0
- package/dist/features/filters/index.js +2 -0
- package/dist/features/filters/routeFilterState.d.ts +58 -0
- package/dist/features/filters/routeFilterState.js +97 -0
- package/dist/features/filters/usePendingFilters.d.ts +37 -0
- package/dist/features/filters/usePendingFilters.js +22 -0
- package/dist/features/forms/Checkbox.js +1 -0
- package/dist/features/forms/Form.js +1 -2
- package/dist/features/forms/Radio.js +0 -1
- package/dist/features/forms/utils.js +1 -1
- package/dist/features/homepage/actions/homepage-section-actions.js +2 -2
- package/dist/features/homepage/ad-registry.d.ts +96 -0
- package/dist/features/homepage/ad-registry.js +84 -0
- package/dist/features/homepage/api/[id]/route.js +3 -3
- package/dist/features/homepage/api/carousel/[id]/route.js +3 -3
- package/dist/features/homepage/api/carousel/route.js +1 -1
- package/dist/features/homepage/api/route.js +1 -1
- package/dist/features/homepage/components/AdSlot.d.ts +28 -0
- package/dist/features/homepage/components/AdSlot.js +85 -0
- package/dist/features/homepage/components/AdvertisementBanner.js +8 -8
- package/dist/features/homepage/components/AnnouncementBar.d.ts +5 -0
- package/dist/features/homepage/components/AnnouncementBar.js +10 -0
- package/dist/features/homepage/components/BeforeAfterCard.d.ts +0 -1
- package/dist/features/homepage/components/BeforeAfterCard.js +0 -1
- package/dist/features/homepage/components/BlogArticlesSection.d.ts +8 -0
- package/dist/features/homepage/components/BlogArticlesSection.js +12 -0
- package/dist/features/homepage/components/BrandsSection.d.ts +9 -0
- package/dist/features/homepage/components/BrandsSection.js +20 -0
- package/dist/features/homepage/components/CTABannerSection.d.ts +10 -0
- package/dist/features/homepage/components/CTABannerSection.js +6 -0
- package/dist/features/homepage/components/CharacterHotspot.d.ts +0 -1
- package/dist/features/homepage/components/CharacterHotspot.js +4 -4
- package/dist/features/homepage/components/CustomerReviewsSection.js +3 -4
- package/dist/features/homepage/components/EventsSection.d.ts +9 -0
- package/dist/features/homepage/components/EventsSection.js +10 -0
- package/dist/features/homepage/components/FAQSection.d.ts +0 -1
- package/dist/features/homepage/components/FAQSection.js +4 -4
- package/dist/features/homepage/components/FeaturedAuctionsSection.d.ts +8 -0
- package/dist/features/homepage/components/FeaturedAuctionsSection.js +10 -0
- package/dist/features/homepage/components/FeaturedPreOrdersSection.d.ts +8 -0
- package/dist/features/homepage/components/FeaturedPreOrdersSection.js +10 -0
- package/dist/features/homepage/components/FeaturedProductsSection.d.ts +8 -0
- package/dist/features/homepage/components/FeaturedProductsSection.js +11 -0
- package/dist/features/homepage/components/FeaturedResultsSection.js +9 -9
- package/dist/features/homepage/components/FeaturedStoresSection.d.ts +9 -0
- package/dist/features/homepage/components/FeaturedStoresSection.js +11 -0
- package/dist/features/homepage/components/HeroCarousel.d.ts +1 -2
- package/dist/features/homepage/components/HeroCarousel.js +5 -12
- package/dist/features/homepage/components/HomepageCustomerReviewsSection.d.ts +8 -0
- package/dist/features/homepage/components/HomepageCustomerReviewsSection.js +9 -0
- package/dist/features/homepage/components/HomepageSkeleton.js +1 -2
- package/dist/features/homepage/components/HowItWorksInfoView.js +2 -2
- package/dist/features/homepage/components/HowItWorksSection.js +4 -4
- package/dist/features/homepage/components/MarketplaceHomepageView.d.ts +25 -0
- package/dist/features/homepage/components/MarketplaceHomepageView.js +252 -0
- package/dist/features/homepage/components/NewsletterSection.js +2 -3
- package/dist/features/homepage/components/SectionCarousel.js +13 -7
- package/dist/features/homepage/components/SecurityHighlightsSection.js +4 -4
- package/dist/features/homepage/components/ShopByCategorySection.d.ts +9 -0
- package/dist/features/homepage/components/ShopByCategorySection.js +21 -0
- package/dist/features/homepage/components/SiteFeaturesSection.js +2 -3
- package/dist/features/homepage/components/StatsCounterSection.js +5 -5
- package/dist/features/homepage/components/TrustFeaturesSection.js +7 -7
- package/dist/features/homepage/components/TrustIndicatorsSection.js +2 -3
- package/dist/features/homepage/components/WelcomeSection.d.ts +3 -1
- package/dist/features/homepage/components/WelcomeSection.js +5 -5
- package/dist/features/homepage/components/WhatsAppCommunitySection.d.ts +0 -1
- package/dist/features/homepage/components/WhatsAppCommunitySection.js +4 -5
- package/dist/features/homepage/components/index.d.ts +24 -0
- package/dist/features/homepage/components/index.js +12 -0
- package/dist/features/homepage/hooks/useBlogArticles.js +0 -1
- package/dist/features/homepage/hooks/useFeaturedAuctions.js +0 -1
- package/dist/features/homepage/hooks/useFeaturedPreOrders.js +0 -1
- package/dist/features/homepage/hooks/useFeaturedProducts.js +0 -1
- package/dist/features/homepage/hooks/useFeaturedStores.d.ts +2 -0
- package/dist/features/homepage/hooks/useFeaturedStores.js +14 -0
- package/dist/features/homepage/hooks/useHeroCarousel.js +0 -1
- package/dist/features/homepage/hooks/useHomepage.js +0 -1
- package/dist/features/homepage/hooks/useHomepageEvents.d.ts +6 -0
- package/dist/features/homepage/hooks/useHomepageEvents.js +14 -0
- package/dist/features/homepage/hooks/useHomepageReviews.js +0 -1
- package/dist/features/homepage/hooks/useHomepageSections.js +0 -1
- package/dist/features/homepage/hooks/useNewsletter.js +0 -1
- package/dist/features/homepage/hooks/useTopBrands.js +0 -1
- package/dist/features/homepage/hooks/useTopCategories.js +0 -1
- package/dist/features/homepage/index.d.ts +4 -0
- package/dist/features/homepage/index.js +3 -0
- package/dist/features/homepage/repository/carousel.repository.d.ts +0 -1
- package/dist/features/homepage/repository/carousel.repository.js +2 -8
- package/dist/features/homepage/schemas/firestore.d.ts +20 -2
- package/dist/features/homepage/schemas/firestore.js +10 -8
- package/dist/features/homepage/server.d.ts +0 -1
- package/dist/features/homepage/server.js +0 -1
- package/dist/features/layout/AppLayoutShell.d.ts +98 -0
- package/dist/features/layout/AppLayoutShell.js +147 -0
- package/dist/features/layout/AutoBreadcrumbs.js +5 -5
- package/dist/features/layout/BackToTop.d.ts +0 -1
- package/dist/features/layout/BackToTop.js +0 -1
- package/dist/features/layout/BottomActions.js +8 -11
- package/dist/features/layout/BottomActionsContext.js +2 -2
- package/dist/features/layout/BottomNavItem.js +0 -1
- package/dist/features/layout/BottomNavLayout.js +1 -2
- package/dist/features/layout/BottomNavbar.d.ts +7 -0
- package/dist/features/layout/BottomNavbar.js +13 -6
- package/dist/features/layout/BottomSheet.d.ts +0 -1
- package/dist/features/layout/BottomSheet.js +0 -1
- package/dist/features/layout/Breadcrumbs.js +3 -3
- package/dist/features/layout/DashboardNavContext.d.ts +10 -2
- package/dist/features/layout/DashboardNavContext.js +35 -3
- package/dist/features/layout/FooterLayout.js +4 -2
- package/dist/features/layout/LayoutClient.js +0 -1
- package/dist/features/layout/ListingLayout.d.ts +0 -1
- package/dist/features/layout/ListingLayout.js +0 -1
- package/dist/features/layout/LocaleSwitcher.js +0 -1
- package/dist/features/layout/NavItem.js +2 -3
- package/dist/features/layout/NavbarLayout.js +4 -4
- package/dist/features/layout/SidebarLayout.js +0 -1
- package/dist/features/layout/TitleBar.d.ts +4 -2
- package/dist/features/layout/TitleBar.js +8 -4
- package/dist/features/layout/TitleBarLayout.d.ts +5 -3
- package/dist/features/layout/TitleBarLayout.js +3 -4
- package/dist/features/layout/index.d.ts +2 -0
- package/dist/features/layout/index.js +1 -0
- package/dist/features/loyalty/components/CoinsDisplay.js +0 -1
- package/dist/features/loyalty/hooks/useLoyaltyBalance.js +0 -1
- package/dist/features/loyalty/schemas/index.d.ts +6 -6
- package/dist/features/loyalty/server.d.ts +0 -1
- package/dist/features/loyalty/server.js +0 -1
- package/dist/features/media/AvatarUpload.js +1 -1
- package/dist/features/media/MediaImage.d.ts +3 -1
- package/dist/features/media/MediaImage.js +9 -5
- package/dist/features/media/MediaLightbox.d.ts +0 -1
- package/dist/features/media/MediaLightbox.js +1 -2
- package/dist/features/media/components/MediaSlider.d.ts +4 -0
- package/dist/features/media/components/MediaSlider.js +0 -1
- package/dist/features/media/hooks/useMedia.d.ts +6 -0
- package/dist/features/media/hooks/useMedia.js +1 -2
- package/dist/features/media/server.d.ts +0 -1
- package/dist/features/media/server.js +0 -1
- package/dist/features/media/types/index.d.ts +2 -2
- package/dist/features/orders/api/track/[trackingId]/route.d.ts +0 -1
- package/dist/features/orders/api/track/[trackingId]/route.js +0 -1
- package/dist/features/orders/components/MarketplaceOrderCard.d.ts +0 -1
- package/dist/features/orders/components/MarketplaceOrderCard.js +1 -2
- package/dist/features/orders/components/OrderFilters.js +0 -1
- package/dist/features/orders/components/OrdersList.js +3 -2
- package/dist/features/orders/hooks/useOrders.js +0 -1
- package/dist/features/orders/repository/orders.repository.d.ts +0 -1
- package/dist/features/orders/repository/orders.repository.js +0 -1
- package/dist/features/orders/schemas/index.d.ts +28 -28
- package/dist/features/orders/schemas/index.js +2 -2
- package/dist/features/orders/server.d.ts +0 -1
- package/dist/features/orders/server.js +0 -1
- package/dist/features/payments/hooks/usePaymentEvent.js +0 -1
- package/dist/features/payments/hooks/usePayments.js +0 -1
- package/dist/features/payments/schemas/index.d.ts +4 -4
- package/dist/features/payments/server.d.ts +0 -1
- package/dist/features/payments/server.js +0 -1
- package/dist/features/pre-orders/api/route.js +1 -1
- package/dist/features/pre-orders/components/MarketplacePreorderCard.d.ts +1 -0
- package/dist/features/pre-orders/components/MarketplacePreorderCard.js +7 -3
- package/dist/features/pre-orders/components/PreOrderDetailPageView.d.ts +4 -0
- package/dist/features/pre-orders/components/PreOrderDetailPageView.js +27 -0
- package/dist/features/pre-orders/components/PreOrdersIndexListing.d.ts +4 -0
- package/dist/features/pre-orders/components/PreOrdersIndexListing.js +25 -0
- package/dist/features/pre-orders/components/PreOrdersListView.d.ts +1 -0
- package/dist/features/pre-orders/components/PreOrdersListView.js +16 -0
- package/dist/features/pre-orders/components/PreorderCard.js +0 -1
- package/dist/features/pre-orders/components/index.d.ts +5 -0
- package/dist/features/pre-orders/components/index.js +3 -0
- package/dist/features/pre-orders/hooks/usePreOrders.js +0 -1
- package/dist/features/pre-orders/schemas/index.d.ts +8 -8
- package/dist/features/pre-orders/server.d.ts +0 -1
- package/dist/features/pre-orders/server.js +0 -1
- package/dist/features/products/api/[id]/route.js +3 -3
- package/dist/features/products/api/route.js +4 -4
- package/dist/features/products/columns/productTableColumns.js +0 -1
- package/dist/features/products/components/AuctionsIndexListing.d.ts +4 -0
- package/dist/features/products/components/AuctionsIndexListing.js +23 -0
- package/dist/features/products/components/BidHistory.js +3 -3
- package/dist/features/products/components/BuyBar.js +0 -1
- package/dist/features/products/components/InteractiveProductCard.js +0 -1
- package/dist/features/products/components/MakeOfferForm.js +1 -1
- package/dist/features/products/components/PlaceBidForm.js +1 -1
- package/dist/features/products/components/ProductDetailPageView.d.ts +4 -0
- package/dist/features/products/components/ProductDetailPageView.js +100 -0
- package/dist/features/products/components/ProductDetailView.d.ts +15 -2
- package/dist/features/products/components/ProductDetailView.js +2 -2
- package/dist/features/products/components/ProductFeatureBadges.js +0 -1
- package/dist/features/products/components/ProductFilters.js +0 -1
- package/dist/features/products/components/ProductForm.js +3 -2
- package/dist/features/products/components/ProductGalleryClient.d.ts +5 -0
- package/dist/features/products/components/ProductGalleryClient.js +23 -0
- package/dist/features/products/components/ProductGrid.d.ts +6 -2
- package/dist/features/products/components/ProductGrid.js +19 -11
- package/dist/features/products/components/ProductInfo.js +1 -1
- package/dist/features/products/components/ProductTabs.js +2 -1
- package/dist/features/products/components/ProductTabsShell.d.ts +18 -0
- package/dist/features/products/components/ProductTabsShell.js +26 -0
- package/dist/features/products/components/ProductsIndexListing.d.ts +4 -0
- package/dist/features/products/components/ProductsIndexListing.js +27 -0
- package/dist/features/products/components/ProductsIndexPageView.d.ts +1 -0
- package/dist/features/products/components/ProductsIndexPageView.js +17 -0
- package/dist/features/products/components/RelatedProducts.js +2 -2
- package/dist/features/products/components/index.d.ts +4 -0
- package/dist/features/products/components/index.js +2 -0
- package/dist/features/products/hooks/useProductDetail.js +0 -1
- package/dist/features/products/hooks/useProducts.js +2 -1
- package/dist/features/products/hooks/useRelatedProducts.js +0 -1
- package/dist/features/products/repository/products.repository.d.ts +7 -1
- package/dist/features/products/repository/products.repository.js +53 -4
- package/dist/features/products/schemas/index.d.ts +110 -110
- package/dist/features/products/schemas/index.js +2 -2
- package/dist/features/products/server.d.ts +0 -1
- package/dist/features/products/server.js +0 -1
- package/dist/features/products/types/index.d.ts +1 -0
- package/dist/features/promotions/actions/seller-coupon-actions.js +3 -3
- package/dist/features/promotions/api/route.js +1 -1
- package/dist/features/promotions/hooks/useCouponValidate.js +0 -1
- package/dist/features/promotions/hooks/usePromotions.js +0 -1
- package/dist/features/promotions/repository/coupons.repository.d.ts +0 -1
- package/dist/features/promotions/repository/coupons.repository.js +0 -1
- package/dist/features/promotions/schemas/index.d.ts +18 -18
- package/dist/features/promotions/schemas/index.js +2 -2
- package/dist/features/promotions/server.d.ts +0 -1
- package/dist/features/promotions/server.js +0 -1
- package/dist/features/promotions/types/index.js +1 -1
- package/dist/features/reviews/api/[id]/route.js +3 -3
- package/dist/features/reviews/api/route.js +3 -3
- package/dist/features/reviews/components/ReviewFilters.js +0 -1
- package/dist/features/reviews/components/ReviewModal.js +6 -2
- package/dist/features/reviews/components/ReviewSummary.js +0 -1
- package/dist/features/reviews/components/ReviewsIndexListing.d.ts +5 -0
- package/dist/features/reviews/components/ReviewsIndexListing.js +55 -0
- package/dist/features/reviews/components/ReviewsIndexPageView.d.ts +1 -0
- package/dist/features/reviews/components/ReviewsIndexPageView.js +9 -0
- package/dist/features/reviews/components/ReviewsList.js +6 -4
- package/dist/features/reviews/components/index.d.ts +2 -0
- package/dist/features/reviews/components/index.js +1 -0
- package/dist/features/reviews/hooks/useCreateReview.js +2 -1
- package/dist/features/reviews/hooks/useReviews.js +0 -1
- package/dist/features/reviews/schemas/index.d.ts +24 -24
- package/dist/features/reviews/schemas/index.js +2 -2
- package/dist/features/reviews/server.d.ts +0 -1
- package/dist/features/reviews/server.js +0 -1
- package/dist/features/search/api/route.js +1 -1
- package/dist/features/search/components/Search.d.ts +0 -1
- package/dist/features/search/components/Search.js +9 -10
- package/dist/features/search/components/SearchResultsSection.js +0 -1
- package/dist/features/search/hooks/useSearch.js +0 -1
- package/dist/features/search/schemas/index.d.ts +5 -5
- package/dist/features/search/server.d.ts +0 -1
- package/dist/features/search/server.js +0 -1
- package/dist/features/seller/actions/offer-actions.js +7 -7
- package/dist/features/seller/actions/seller-actions.js +9 -9
- package/dist/features/seller/columns/index.js +2 -2
- package/dist/features/seller/components/SellerAddressesView.d.ts +1 -1
- package/dist/features/seller/components/SellerAddressesView.js +1 -1
- package/dist/features/seller/components/SellerAuctionsView.d.ts +3 -3
- package/dist/features/seller/components/SellerAuctionsView.js +27 -3
- package/dist/features/seller/components/SellerCouponsView.d.ts +3 -3
- package/dist/features/seller/components/SellerCouponsView.js +27 -3
- package/dist/features/seller/components/SellerCreateProductView.d.ts +1 -1
- package/dist/features/seller/components/SellerCreateProductView.js +1 -1
- package/dist/features/seller/components/SellerEditProductView.d.ts +1 -1
- package/dist/features/seller/components/SellerEditProductView.js +1 -1
- package/dist/features/seller/components/SellerOffersView.d.ts +3 -3
- package/dist/features/seller/components/SellerOffersView.js +27 -3
- package/dist/features/seller/components/SellerOrdersView.d.ts +3 -3
- package/dist/features/seller/components/SellerOrdersView.js +27 -3
- package/dist/features/seller/components/SellerPayoutHistoryTable.js +0 -1
- package/dist/features/seller/components/SellerPayoutStats.js +0 -1
- package/dist/features/seller/components/SellerPayoutsView.d.ts +3 -17
- package/dist/features/seller/components/SellerPayoutsView.js +27 -9
- package/dist/features/seller/components/SellerProductsView.d.ts +3 -3
- package/dist/features/seller/components/SellerProductsView.js +27 -3
- package/dist/features/seller/components/SellerSidebar.d.ts +5 -1
- package/dist/features/seller/components/SellerSidebar.js +11 -6
- package/dist/features/seller/components/SellerStatCard.js +2 -1
- package/dist/features/seller/components/SellerStoreView.d.ts +1 -1
- package/dist/features/seller/components/SellerStoreView.js +1 -1
- package/dist/features/seller/components/analytics/SellerAnalyticsStats.js +0 -1
- package/dist/features/seller/components/analytics/SellerTopProducts.js +0 -1
- package/dist/features/seller/hooks/useBecomeSeller.js +0 -1
- package/dist/features/seller/hooks/useSellerListingData.d.ts +29 -0
- package/dist/features/seller/hooks/useSellerListingData.js +87 -0
- package/dist/features/seller/hooks/useSellerPayouts.js +0 -1
- package/dist/features/seller/hooks/useSellerStore.js +0 -1
- package/dist/features/seller/hooks/useSellerStorefront.js +0 -1
- package/dist/features/seller/index.d.ts +1 -0
- package/dist/features/seller/index.js +1 -0
- package/dist/features/seller/repository/offer.repository.js +3 -3
- package/dist/features/seller/schemas/index.d.ts +26 -26
- package/dist/features/seller/schemas/index.js +3 -3
- package/dist/features/seller/server.d.ts +0 -1
- package/dist/features/seller/server.js +0 -1
- package/dist/features/seller/types/index.js +1 -1
- package/dist/features/stores/api/[storeSlug]/auctions/route.js +1 -1
- package/dist/features/stores/api/[storeSlug]/products/route.js +1 -1
- package/dist/features/stores/api/[storeSlug]/reviews/route.js +1 -1
- package/dist/features/stores/api/[storeSlug]/route.js +1 -1
- package/dist/features/stores/api/route.js +1 -1
- package/dist/features/stores/components/InteractiveStoreCard.d.ts +1 -0
- package/dist/features/stores/components/InteractiveStoreCard.js +5 -5
- package/dist/features/stores/components/StoreAboutView.js +3 -2
- package/dist/features/stores/components/StoreAddressSelectorCreate.js +1 -1
- package/dist/features/stores/components/StoreAuctionsListing.d.ts +5 -0
- package/dist/features/stores/components/StoreAuctionsListing.js +41 -0
- package/dist/features/stores/components/StoreAuctionsPageView.d.ts +4 -0
- package/dist/features/stores/components/StoreAuctionsPageView.js +21 -0
- package/dist/features/stores/components/StoreAuctionsView.d.ts +2 -2
- package/dist/features/stores/components/StoreAuctionsView.js +2 -2
- package/dist/features/stores/components/StoreDetailLayoutView.d.ts +8 -0
- package/dist/features/stores/components/StoreDetailLayoutView.js +19 -0
- package/dist/features/stores/components/StoreHeader.js +3 -3
- package/dist/features/stores/components/StoreNavTabs.js +3 -4
- package/dist/features/stores/components/StoreProductsListing.d.ts +5 -0
- package/dist/features/stores/components/StoreProductsListing.js +29 -0
- package/dist/features/stores/components/StoreProductsPageView.d.ts +4 -0
- package/dist/features/stores/components/StoreProductsPageView.js +21 -0
- package/dist/features/stores/components/StoreProductsView.js +8 -3
- package/dist/features/stores/components/StoreReviewsListing.d.ts +4 -0
- package/dist/features/stores/components/StoreReviewsListing.js +34 -0
- package/dist/features/stores/components/StoreReviewsPageView.d.ts +4 -0
- package/dist/features/stores/components/StoreReviewsPageView.js +5 -0
- package/dist/features/stores/components/StoreReviewsView.d.ts +2 -2
- package/dist/features/stores/components/StoreReviewsView.js +2 -6
- package/dist/features/stores/components/StoresIndexListing.d.ts +4 -0
- package/dist/features/stores/components/StoresIndexListing.js +22 -0
- package/dist/features/stores/components/StoresIndexPageView.d.ts +1 -0
- package/dist/features/stores/components/StoresIndexPageView.js +11 -0
- package/dist/features/stores/components/StoresListView.js +5 -4
- package/dist/features/stores/components/index.d.ts +8 -0
- package/dist/features/stores/components/index.js +4 -0
- package/dist/features/stores/hooks/useStoreAddressSelector.js +0 -1
- package/dist/features/stores/hooks/useStores.d.ts +2 -1
- package/dist/features/stores/hooks/useStores.js +1 -1
- package/dist/features/stores/repository/store-address.repository.js +2 -3
- package/dist/features/stores/repository/store.repository.d.ts +0 -1
- package/dist/features/stores/repository/store.repository.js +0 -1
- package/dist/features/stores/schemas/firestore.js +1 -1
- package/dist/features/stores/schemas/index.d.ts +14 -14
- package/dist/features/stores/schemas/index.js +1 -1
- package/dist/features/stores/server.d.ts +0 -1
- package/dist/features/stores/server.js +0 -1
- package/dist/features/stores/types/index.js +1 -1
- package/dist/features/whatsapp-bot/components/WhatsAppChatButton.js +0 -1
- package/dist/features/whatsapp-bot/helpers/whatsapp.d.ts +0 -1
- package/dist/features/whatsapp-bot/helpers/whatsapp.js +0 -1
- package/dist/features/whatsapp-bot/server.d.ts +0 -1
- package/dist/features/whatsapp-bot/server.js +0 -1
- package/dist/features/wishlist/components/WishlistPage.js +4 -3
- package/dist/features/wishlist/components/WishlistToggleButton.js +0 -1
- package/dist/features/wishlist/components/WishlistView.d.ts +2 -2
- package/dist/features/wishlist/components/WishlistView.js +2 -2
- package/dist/features/wishlist/hooks/useUserWishlist.js +0 -1
- package/dist/features/wishlist/hooks/useWishlist.js +0 -1
- package/dist/features/wishlist/schemas/index.d.ts +2 -2
- package/dist/features/wishlist/server.d.ts +0 -1
- package/dist/features/wishlist/server.js +0 -1
- package/dist/index.d.ts +2766 -1
- package/dist/index.js +5177 -1
- package/dist/monitoring/server-logger.d.ts +10 -1
- package/dist/monitoring/server-logger.js +35 -14
- package/dist/next/ErrorBoundary.d.ts +1 -1
- package/dist/next/ErrorBoundary.js +2 -1
- package/dist/next/api/apiHandler.d.ts +9 -0
- package/dist/next/api/apiHandler.js +20 -0
- package/dist/next/api/routeHandler.d.ts +9 -0
- package/dist/next/api/routeHandler.js +30 -5
- package/dist/next/routing/route-map.d.ts +6 -2
- package/dist/next/routing/route-map.js +3 -1
- package/dist/providers/auth-firebase/helpers.js +3 -3
- package/dist/providers/db-firebase/admin-app-lite.d.ts +0 -1
- package/dist/providers/db-firebase/admin-app-lite.js +11 -6
- package/dist/providers/db-firebase/admin-storage-lite.d.ts +0 -1
- package/dist/providers/db-firebase/admin-storage-lite.js +0 -1
- package/dist/providers/db-firebase/admin.d.ts +0 -1
- package/dist/providers/db-firebase/admin.js +16 -21
- package/dist/providers/db-firebase/base.d.ts +0 -1
- package/dist/providers/db-firebase/base.js +42 -16
- package/dist/providers/db-firebase/base.repository.d.ts +1 -2
- package/dist/providers/db-firebase/base.repository.js +0 -1
- package/dist/providers/db-firebase/field-ops.d.ts +0 -1
- package/dist/providers/db-firebase/field-ops.js +0 -1
- package/dist/providers/db-firebase/helpers.d.ts +2 -0
- package/dist/providers/db-firebase/helpers.js +11 -2
- package/dist/providers/db-firebase/index.d.ts +1 -2
- package/dist/providers/db-firebase/index.js +1 -2
- package/dist/providers/db-firebase/realtime.d.ts +1 -2
- package/dist/providers/db-firebase/realtime.js +20 -4
- package/dist/providers/db-firebase/sieve.d.ts +0 -1
- package/dist/providers/db-firebase/sieve.js +23 -5
- package/dist/providers/firebase-client/auth.js +0 -1
- package/dist/providers/firebase-client/index.js +0 -1
- package/dist/providers/firebase-client/realtime.js +0 -1
- package/dist/providers/payment-razorpay/index.d.ts +20 -1
- package/dist/providers/payment-razorpay/index.js +3 -4
- package/dist/providers/shipping-shiprocket/index.d.ts +37 -0
- package/dist/providers/shipping-shiprocket/index.js +36 -3
- package/dist/providers/shipping-shiprocket/shiprocket-provider.d.ts +2 -3
- package/dist/providers/shipping-shiprocket/shiprocket-provider.js +28 -12
- package/dist/providers/storage-firebase/client.js +1 -2
- package/dist/providers.d.ts +25 -0
- package/dist/providers.js +31 -0
- package/dist/react/ErrorBoundary.d.ts +1 -1
- package/dist/react/ErrorBoundary.js +1 -1
- package/dist/react/contexts/SessionContext.d.ts +0 -1
- package/dist/react/contexts/SessionContext.js +0 -1
- package/dist/react/contexts/ThemeContext.d.ts +0 -1
- package/dist/react/contexts/ThemeContext.js +0 -1
- package/dist/react/hooks/useBreakpoint.js +0 -1
- package/dist/react/hooks/useCamera.d.ts +0 -1
- package/dist/react/hooks/useCamera.js +0 -1
- package/dist/react/hooks/useClickOutside.d.ts +0 -1
- package/dist/react/hooks/useClickOutside.js +0 -1
- package/dist/react/hooks/useContainerGrid.js +1 -1
- package/dist/react/hooks/useCountdown.js +1 -0
- package/dist/react/hooks/useMediaQuery.d.ts +0 -1
- package/dist/react/hooks/useMediaQuery.js +0 -1
- package/dist/react/hooks/useSwipe.d.ts +0 -1
- package/dist/react/hooks/useSwipe.js +0 -1
- package/dist/react/hooks/useUnsavedChanges.d.ts +0 -1
- package/dist/react/hooks/useUnsavedChanges.js +3 -3
- package/dist/react/hooks/useVisibleItems.js +1 -1
- package/dist/react/useModalStack.js +1 -1
- package/dist/repositories/index.d.ts +0 -1
- package/dist/repositories/index.js +0 -1
- package/dist/security/authorization.js +10 -15
- package/dist/security/index.d.ts +1 -1
- package/dist/security/index.js +1 -1
- package/dist/security/pii-encrypt.d.ts +11 -1
- package/dist/security/pii-encrypt.js +11 -5
- package/dist/security/pii-redact.d.ts +16 -0
- package/dist/security/pii-redact.js +32 -0
- package/dist/security/rate-limit.d.ts +0 -1
- package/dist/security/rate-limit.js +17 -5
- package/dist/security/rbac/Can.js +0 -2
- package/dist/security/rbac/hook.js +1 -1
- package/dist/security/settings-encryption.d.ts +0 -1
- package/dist/security/settings-encryption.js +7 -2
- package/dist/seed/actions/demo-seed-actions.d.ts +12 -1
- package/dist/seed/addresses-seed-data.d.ts +0 -1
- package/dist/seed/addresses-seed-data.js +1 -2
- package/dist/seed/bids-seed-data.d.ts +0 -1
- package/dist/seed/bids-seed-data.js +21 -22
- package/dist/seed/blog-posts-seed-data.d.ts +0 -1
- package/dist/seed/blog-posts-seed-data.js +8 -5
- package/dist/seed/carousel-slides-seed-data.d.ts +0 -1
- package/dist/seed/carousel-slides-seed-data.js +4 -1
- package/dist/seed/cart-seed-data.d.ts +0 -1
- package/dist/seed/cart-seed-data.js +5 -6
- package/dist/seed/categories-seed-data.d.ts +0 -1
- package/dist/seed/categories-seed-data.js +4 -1
- package/dist/seed/coupons-seed-data.d.ts +0 -1
- package/dist/seed/coupons-seed-data.js +4 -1
- package/dist/seed/events-seed-data.d.ts +0 -1
- package/dist/seed/events-seed-data.js +7 -4
- package/dist/seed/factories/product.factory.js +1 -1
- package/dist/seed/faq-seed-data.d.ts +0 -1
- package/dist/seed/faq-seed-data.js +15 -1
- package/dist/seed/firestore-indexes.d.ts +0 -1
- package/dist/seed/firestore-indexes.js +0 -1
- package/dist/seed/homepage-sections-seed-data.d.ts +4 -5
- package/dist/seed/homepage-sections-seed-data.js +84 -31
- package/dist/seed/index.d.ts +7 -1
- package/dist/seed/index.js +8 -1
- package/dist/seed/notifications-seed-data.d.ts +0 -1
- package/dist/seed/notifications-seed-data.js +15 -12
- package/dist/seed/orders-seed-data.d.ts +0 -1
- package/dist/seed/orders-seed-data.js +6 -7
- package/dist/seed/payouts-seed-data.d.ts +0 -1
- package/dist/seed/payouts-seed-data.js +4 -5
- package/dist/seed/pokemon-carousel-slides-seed-data.d.ts +6 -0
- package/dist/seed/pokemon-carousel-slides-seed-data.js +433 -0
- package/dist/seed/pokemon-categories-seed-data.d.ts +27 -0
- package/dist/seed/pokemon-categories-seed-data.js +1127 -0
- package/dist/seed/pokemon-homepage-sections-seed-data.d.ts +6 -0
- package/dist/seed/pokemon-homepage-sections-seed-data.js +370 -0
- package/dist/seed/pokemon-products-seed-data.d.ts +9 -0
- package/dist/seed/pokemon-products-seed-data.js +1119 -0
- package/dist/seed/pokemon-seed-bundle.d.ts +22 -0
- package/dist/seed/pokemon-seed-bundle.js +22 -0
- package/dist/seed/pokemon-stores-seed-data.d.ts +7 -0
- package/dist/seed/pokemon-stores-seed-data.js +78 -0
- package/dist/seed/pokemon-users-seed-data.d.ts +6 -0
- package/dist/seed/pokemon-users-seed-data.js +438 -0
- package/dist/seed/products-seed-data.d.ts +0 -1
- package/dist/seed/products-seed-data.js +34 -2
- package/dist/seed/reviews-seed-data.d.ts +0 -1
- package/dist/seed/reviews-seed-data.js +4 -1
- package/dist/seed/runner.d.ts +0 -1
- package/dist/seed/runner.js +10 -2
- package/dist/seed/seed-market-config.d.ts +0 -1
- package/dist/seed/seed-market-config.js +1 -2
- package/dist/seed/sessions-seed-data.d.ts +0 -1
- package/dist/seed/sessions-seed-data.js +19 -20
- package/dist/seed/site-settings-seed-data.d.ts +38 -2
- package/dist/seed/site-settings-seed-data.js +124 -1
- package/dist/seed/store-addresses-seed-data.d.ts +0 -1
- package/dist/seed/store-addresses-seed-data.js +1 -2
- package/dist/seed/stores-seed-data.d.ts +0 -1
- package/dist/seed/stores-seed-data.js +14 -4
- package/dist/seed/test-utils.d.ts +0 -1
- package/dist/seed/test-utils.js +0 -1
- package/dist/seed/types.d.ts +0 -1
- package/dist/seed/types.js +2 -1
- package/dist/seed/users-seed-data.d.ts +0 -1
- package/dist/seed/users-seed-data.js +7 -8
- package/dist/seed/wishlists-seed-data.d.ts +10 -0
- package/dist/seed/wishlists-seed-data.js +38 -0
- package/dist/seo/json-ld.js +1 -1
- package/dist/server.d.ts +437 -109
- package/dist/server.js +1296 -110
- package/dist/styles.css +20 -0
- package/dist/tokens/index.d.ts +131 -0
- package/dist/tokens/index.js +55 -11
- package/dist/tokens/tokens.css +9 -9
- package/dist/ui/DataTable.js +15 -15
- package/dist/ui/columns/column-renderers.js +3 -3
- package/dist/ui/components/Accordion.js +1 -1
- package/dist/ui/components/ActiveFilterChips.js +0 -1
- package/dist/ui/components/Alert.js +1 -1
- package/dist/ui/components/Avatar.js +1 -2
- package/dist/ui/components/AvatarDisplay.js +2 -3
- package/dist/ui/components/BackgroundRenderer.js +1 -1
- package/dist/ui/components/BaseListingCard.js +7 -5
- package/dist/ui/components/BulkActionBar.d.ts +0 -1
- package/dist/ui/components/BulkActionBar.js +2 -3
- package/dist/ui/components/Button.style.css +2 -2
- package/dist/ui/components/Card.js +4 -4
- package/dist/ui/components/Checkbox.js +1 -1
- package/dist/ui/components/ConfirmDeleteModal.d.ts +0 -1
- package/dist/ui/components/ConfirmDeleteModal.js +2 -3
- package/dist/ui/components/CountdownDisplay.d.ts +0 -1
- package/dist/ui/components/CountdownDisplay.js +0 -1
- package/dist/ui/components/DashboardStatsCard.js +1 -2
- package/dist/ui/components/DescriptionField.js +1 -1
- package/dist/ui/components/DetailViewShell.d.ts +16 -2
- package/dist/ui/components/DetailViewShell.js +9 -5
- package/dist/ui/components/Div.d.ts +1 -1
- package/dist/ui/components/Div.js +2 -2
- package/dist/ui/components/Divider.js +1 -1
- package/dist/ui/components/Drawer.d.ts +0 -1
- package/dist/ui/components/Drawer.js +2 -3
- package/dist/ui/components/Dropdown.d.ts +0 -1
- package/dist/ui/components/Dropdown.js +1 -2
- package/dist/ui/components/DynamicSelect.d.ts +0 -1
- package/dist/ui/components/DynamicSelect.js +2 -3
- package/dist/ui/components/EmptyState.js +1 -2
- package/dist/ui/components/FilterDrawer.d.ts +3 -1
- package/dist/ui/components/FilterDrawer.js +3 -3
- package/dist/ui/components/FlowDiagram.js +3 -3
- package/dist/ui/components/Form.js +2 -2
- package/dist/ui/components/FormField.js +3 -4
- package/dist/ui/components/FormGrid.js +2 -2
- package/dist/ui/components/FormGrid.style.css +1 -1
- package/dist/ui/components/HorizontalScroller.d.ts +1 -1
- package/dist/ui/components/HorizontalScroller.js +86 -15
- package/dist/ui/components/HorizontalScroller.style.css +105 -109
- package/dist/ui/components/ImageGallery.d.ts +0 -1
- package/dist/ui/components/ImageGallery.js +4 -5
- package/dist/ui/components/ImageLightbox.d.ts +0 -1
- package/dist/ui/components/ImageLightbox.js +1 -2
- package/dist/ui/components/ImageLightbox.style.css +3 -3
- package/dist/ui/components/Input.js +1 -1
- package/dist/ui/components/Layout.d.ts +7 -7
- package/dist/ui/components/Layout.js +5 -5
- package/dist/ui/components/ListingLayout.d.ts +11 -8
- package/dist/ui/components/ListingLayout.js +22 -44
- package/dist/ui/components/ListingLayout.style.css +15 -15
- package/dist/ui/components/ListingViewShell.d.ts +1 -2
- package/dist/ui/components/ListingViewShell.js +1 -3
- package/dist/ui/components/Menu.js +0 -1
- package/dist/ui/components/Modal.d.ts +0 -1
- package/dist/ui/components/Modal.js +3 -4
- package/dist/ui/components/NavigationLoader.d.ts +29 -0
- package/dist/ui/components/NavigationLoader.js +146 -0
- package/dist/ui/components/NavigationLoader.style.css +19 -0
- package/dist/ui/components/Pagination.js +0 -1
- package/dist/ui/components/PasswordStrengthIndicator.js +1 -2
- package/dist/ui/components/PriceDisplay.js +0 -1
- package/dist/ui/components/Progress.js +2 -3
- package/dist/ui/components/Radio.js +1 -2
- package/dist/ui/components/RatingDisplay.js +1 -2
- package/dist/ui/components/ResponsiveView.js +1 -2
- package/dist/ui/components/RichTextEditor.d.ts +9 -0
- package/dist/ui/components/RichTextEditor.js +59 -0
- package/dist/ui/components/RoleBadge.js +0 -1
- package/dist/ui/components/RowActionMenu.js +1 -1
- package/dist/ui/components/SectionTabs.js +4 -4
- package/dist/ui/components/Select.js +2 -2
- package/dist/ui/components/Semantic.d.ts +2 -2
- package/dist/ui/components/Semantic.js +1 -1
- package/dist/ui/components/SideDrawer.d.ts +0 -1
- package/dist/ui/components/SideDrawer.js +2 -3
- package/dist/ui/components/SideDrawer.style.css +2 -2
- package/dist/ui/components/SideModal.d.ts +0 -1
- package/dist/ui/components/SideModal.js +0 -1
- package/dist/ui/components/SideModal.style.css +4 -4
- package/dist/ui/components/Skeleton.js +1 -2
- package/dist/ui/components/SkipToMain.js +0 -1
- package/dist/ui/components/Slider.js +2 -2
- package/dist/ui/components/SlottedListingView.d.ts +1 -2
- package/dist/ui/components/SlottedListingView.js +2 -3
- package/dist/ui/components/SortDropdown.js +1 -2
- package/dist/ui/components/Spinner.d.ts +1 -1
- package/dist/ui/components/Spinner.js +2 -1
- package/dist/ui/components/Spinner.style.css +8 -0
- package/dist/ui/components/StackedViewShell.d.ts +0 -1
- package/dist/ui/components/StackedViewShell.js +0 -2
- package/dist/ui/components/StatsGrid.js +0 -1
- package/dist/ui/components/StatusBadge.d.ts +5 -5
- package/dist/ui/components/StepperNav.js +2 -3
- package/dist/ui/components/SummaryCard.js +0 -1
- package/dist/ui/components/TabStrip.d.ts +0 -1
- package/dist/ui/components/TabStrip.js +1 -2
- package/dist/ui/components/TablePagination.js +0 -1
- package/dist/ui/components/Tabs.js +3 -3
- package/dist/ui/components/TagInput.js +1 -1
- package/dist/ui/components/TextLink.js +0 -1
- package/dist/ui/components/Textarea.js +2 -2
- package/dist/ui/components/Toast.d.ts +0 -1
- package/dist/ui/components/Toast.js +2 -3
- package/dist/ui/components/Toggle.js +1 -1
- package/dist/ui/components/Tooltip.d.ts +0 -1
- package/dist/ui/components/Tooltip.js +1 -2
- package/dist/ui/components/UnsavedChangesModal.d.ts +0 -1
- package/dist/ui/components/UnsavedChangesModal.js +2 -3
- package/dist/ui/components/ViewToggle.js +0 -1
- package/dist/ui/components/index.style.css +1 -0
- package/dist/ui/index.d.ts +5 -1
- package/dist/ui/index.js +5 -3
- package/dist/ui/rich-text/RichText.d.ts +0 -1
- package/dist/ui/rich-text/RichText.js +3 -4
- package/dist/utils/event-manager.d.ts +6 -1
- package/dist/utils/event-manager.js +6 -1
- package/dist/utils/id-generators.js +3 -3
- package/dist/utils/string.formatter.d.ts +5 -0
- package/dist/utils/string.formatter.js +15 -0
- package/dist/validation/schemas.d.ts +20 -20
- package/package.json +86 -25
|
@@ -8,8 +8,8 @@ export function ForgotPasswordView({ onSubmit, isLoading = false, error, success
|
|
|
8
8
|
e.preventDefault();
|
|
9
9
|
await onSubmit(email);
|
|
10
10
|
}, [onSubmit, email]);
|
|
11
|
-
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Forgot Password" }), _jsx(Text, { className: "mt-2 text-sm text-neutral-600", children: labels.description ??
|
|
12
|
-
"Enter your email and we'll send you a reset link." })] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), !success && (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "fp-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "fp-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: email, onChange: (e) => setEmail(e.target.value), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
|
|
11
|
+
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Forgot Password" }), _jsx(Text, { className: "mt-2 text-sm text-neutral-600 dark:text-zinc-400", children: labels.description ??
|
|
12
|
+
"Enter your email and we'll send you a reset link." })] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), !success && (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "fp-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "fp-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: email, onChange: (e) => setEmail(e.target.value), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
|
|
13
13
|
? (labels.submittingLabel ?? "Sending…")
|
|
14
14
|
: (labels.submitLabel ?? "Send reset link") })] })), renderBackLink && (_jsx(Div, { className: "text-center text-sm", children: renderBackLink() }))] }) }));
|
|
15
15
|
}
|
|
@@ -6,7 +6,7 @@ import type { UserRole } from "../types";
|
|
|
6
6
|
*/
|
|
7
7
|
export interface AuthGuardUser {
|
|
8
8
|
id?: string;
|
|
9
|
-
role?: UserRole;
|
|
9
|
+
role?: UserRole | string;
|
|
10
10
|
disabled?: boolean;
|
|
11
11
|
emailVerified?: boolean;
|
|
12
12
|
}
|
|
@@ -27,7 +27,7 @@ export interface AuthRouteConfig {
|
|
|
27
27
|
* <RoleGate
|
|
28
28
|
* user={currentUser}
|
|
29
29
|
* allowedRoles="admin"
|
|
30
|
-
* fallback={<div>Not authorized</div>}
|
|
30
|
+
* fallback={<div data-section="guards-div-259">Not authorized</div>}
|
|
31
31
|
* >
|
|
32
32
|
* <AdminPanel />
|
|
33
33
|
* </RoleGate>
|
|
@@ -7,7 +7,7 @@ export function RoleGate({ children, user, allowedRoles, fallback = null, }) {
|
|
|
7
7
|
return _jsx(_Fragment, { children: fallback });
|
|
8
8
|
}
|
|
9
9
|
const allowed = Array.isArray(allowedRoles) ? allowedRoles : [allowedRoles];
|
|
10
|
-
if (!allowed.
|
|
10
|
+
if (!allowed.some((role) => role === user.role)) {
|
|
11
11
|
return _jsx(_Fragment, { children: fallback });
|
|
12
12
|
}
|
|
13
13
|
return _jsx(_Fragment, { children: children });
|
|
@@ -42,7 +42,7 @@ export function ProtectedRoute({ children, user, loading = false, requireAuth =
|
|
|
42
42
|
if (requireRole) {
|
|
43
43
|
const roles = Array.isArray(requireRole) ? requireRole : [requireRole];
|
|
44
44
|
const userRole = user.role;
|
|
45
|
-
if (!userRole || !roles.
|
|
45
|
+
if (!userRole || !roles.some((role) => role === userRole)) {
|
|
46
46
|
return { isAuthorized: false, redirectPath: unauthorizedPath };
|
|
47
47
|
}
|
|
48
48
|
}
|
|
@@ -12,7 +12,7 @@ export function LoginForm({ onSubmit, onGoogleLogin, isLoading = false, error, l
|
|
|
12
12
|
e.preventDefault();
|
|
13
13
|
await onSubmit(values);
|
|
14
14
|
}, [onSubmit, values]);
|
|
15
|
-
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Sign In" }), (labels.subtitle || renderCreateAccountLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600", children: [labels.subtitle ?? "Or", " ", renderCreateAccountLink?.()] }))] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "login-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "login-password", name: "password", type: "password", autoComplete: "current-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Row, { justify: "between", children: [_jsxs(Row, { className: "gap-2", children: [_jsx("input", { id: "login-remember", type: "checkbox", checked: values.rememberMe ?? false, onChange: (e) => setValues({ ...values, rememberMe: e.target.checked }), className: "h-4 w-4 rounded border-neutral-300 accent-primary" }), _jsx(Label, { htmlFor: "login-remember", className: "text-sm", children: labels.rememberMe ?? "Remember me" })] }), renderForgotPasswordLink?.()] }), renderSubmitButton ? (renderSubmitButton(isLoading, labels)) : (_jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
|
|
15
|
+
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Sign In" }), (labels.subtitle || renderCreateAccountLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600", children: [labels.subtitle ?? "Or", " ", renderCreateAccountLink?.()] }))] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "login-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-700 bg-white dark:bg-slate-900 text-zinc-900 dark:text-zinc-50 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "login-password", name: "password", type: "password", autoComplete: "current-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-700 bg-white dark:bg-slate-900 text-zinc-900 dark:text-zinc-50 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Row, { justify: "between", children: [_jsxs(Row, { className: "gap-2", children: [_jsx("input", { id: "login-remember", type: "checkbox", checked: values.rememberMe ?? false, onChange: (e) => setValues({ ...values, rememberMe: e.target.checked }), className: "h-4 w-4 rounded border-neutral-300 dark:border-slate-600 accent-primary" }), _jsx(Label, { htmlFor: "login-remember", className: "text-sm", children: labels.rememberMe ?? "Remember me" })] }), renderForgotPasswordLink?.()] }), renderSubmitButton ? (renderSubmitButton(isLoading, labels)) : (_jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
|
|
16
16
|
? (labels.submittingLabel ?? "Signing in…")
|
|
17
17
|
: (labels.submitLabel ?? "Sign in") }))] }), renderSocialButtons?.()] }) }));
|
|
18
18
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function OAuthLoadingView(): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Div, Heading, Text } from "../../../ui";
|
|
3
|
+
export function OAuthLoadingView() {
|
|
4
|
+
return (_jsx(Div, { className: "flex items-center justify-center min-h-[60vh] px-4", children: _jsxs(Div, { className: "max-w-sm w-full text-center", children: [_jsx(Div, { className: "w-12 h-12 rounded-full border-4 border-primary border-t-transparent animate-spin mx-auto mb-6" }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: "Signing you in\u2026" }), _jsx(Text, { variant: "secondary", className: "text-sm", children: "Please wait while we complete your sign-in." })] }) }));
|
|
5
|
+
}
|
|
@@ -21,7 +21,7 @@ export function RegisterForm({ onSubmit, isLoading = false, error, success, labe
|
|
|
21
21
|
await onSubmit(values);
|
|
22
22
|
}, [onSubmit, values, labels.passwordMismatch]);
|
|
23
23
|
const displayError = error ?? validationError;
|
|
24
|
-
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Create Account" }), (labels.subtitle || renderLoginLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600", children: [labels.subtitle ?? "Already have an account?", " ", renderLoginLink?.()] }))] }), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-name", className: "block text-sm font-medium mb-1", children: labels.displayNameLabel ?? "Full name" }), _jsx("input", { id: "reg-name", name: "displayName", type: "text", autoComplete: "name", required: true, placeholder: labels.displayNamePlaceholder ?? "Your name", value: values.displayName, onChange: (e) => setValues({ ...values, displayName: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "reg-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "reg-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" }), renderPasswordStrength?.(values.password)] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm password" }), _jsx("input", { id: "reg-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: values.confirmPassword, onChange: (e) => setValues({ ...values, confirmPassword: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { className: "flex items-start gap-2", children: [_jsx("input", { id: "reg-terms", type: "checkbox", required: true, checked: values.acceptTerms, onChange: (e) => setValues({ ...values, acceptTerms: e.target.checked }), className: "mt-0.5 h-4 w-4 rounded border-neutral-300 accent-primary" }), _jsxs(Label, { htmlFor: "reg-terms", className: "text-sm leading-snug", children: [labels.acceptTermsLabel ?? "I accept the", " ", renderTermsLink?.()] })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-
|
|
24
|
+
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Create Account" }), (labels.subtitle || renderLoginLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600 dark:text-zinc-400", children: [labels.subtitle ?? "Already have an account?", " ", renderLoginLink?.()] }))] }), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-name", className: "block text-sm font-medium mb-1", children: labels.displayNameLabel ?? "Full name" }), _jsx("input", { id: "reg-name", name: "displayName", type: "text", autoComplete: "name", required: true, placeholder: labels.displayNamePlaceholder ?? "Your name", value: values.displayName, onChange: (e) => setValues({ ...values, displayName: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "reg-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "reg-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" }), renderPasswordStrength?.(values.password)] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm password" }), _jsx("input", { id: "reg-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: values.confirmPassword, onChange: (e) => setValues({ ...values, confirmPassword: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { className: "flex items-start gap-2", children: [_jsx("input", { id: "reg-terms", type: "checkbox", required: true, checked: values.acceptTerms, onChange: (e) => setValues({ ...values, acceptTerms: e.target.checked }), className: "mt-0.5 h-4 w-4 rounded border-neutral-300 dark:border-slate-600 accent-primary" }), _jsxs(Label, { htmlFor: "reg-terms", className: "text-sm leading-snug", children: [labels.acceptTermsLabel ?? "I accept the", " ", renderTermsLink?.()] })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-zinc-900 px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-zinc-800 dark:bg-zinc-100 dark:text-zinc-900 dark:hover:bg-zinc-200 transition-colors", children: isLoading
|
|
25
25
|
? (labels.submittingLabel ?? "Creating account…")
|
|
26
26
|
: (labels.submitLabel ?? "Create account") })] }), renderSocialButtons?.()] }) }));
|
|
27
27
|
}
|
|
@@ -16,7 +16,7 @@ export function ResetPasswordView({ oobCode, onSubmit, isLoading = false, error,
|
|
|
16
16
|
await onSubmit(oobCode, password);
|
|
17
17
|
}, [oobCode, onSubmit, password, confirm, labels.passwordMismatch]);
|
|
18
18
|
const displayError = error ?? validationError;
|
|
19
|
-
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Reset Password" }), labels.description && (_jsx(Text, { className: "mt-2 text-sm text-neutral-600", children: labels.description }))] }), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), success ? (_jsxs(Alert, { variant: "success", compact: true, children: [success, renderLoginLink && _jsx(Div, { className: "mt-2", children: renderLoginLink() })] })) : (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "New password" }), _jsx("input", { id: "rp-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: password, onChange: (e) => setPassword(e.target.value), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm new password" }), _jsx("input", { id: "rp-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: confirm, onChange: (e) => setConfirm(e.target.value), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-
|
|
19
|
+
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Reset Password" }), labels.description && (_jsx(Text, { className: "mt-2 text-sm text-neutral-600 dark:text-zinc-400", children: labels.description }))] }), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), success ? (_jsxs(Alert, { variant: "success", compact: true, children: [success, renderLoginLink && _jsx(Div, { className: "mt-2", children: renderLoginLink() })] })) : (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "New password" }), _jsx("input", { id: "rp-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: password, onChange: (e) => setPassword(e.target.value), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm new password" }), _jsx("input", { id: "rp-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: confirm, onChange: (e) => setConfirm(e.target.value), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-zinc-900 px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-zinc-800 dark:bg-zinc-100 dark:text-zinc-900 dark:hover:bg-zinc-200 transition-colors", children: isLoading
|
|
20
20
|
? (labels.submittingLabel ?? "Resetting…")
|
|
21
21
|
: (labels.submitLabel ?? "Reset password") })] }))] }) }));
|
|
22
22
|
}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
"use client";
|
|
2
1
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
2
|
import { Button, Div, Span } from "../../../ui";
|
|
4
3
|
export function SocialAuthButtons({ onGoogle, disabled, dividerLabel, googleLabel, }) {
|
|
5
|
-
return (_jsxs(_Fragment, { children: [_jsxs(Div, { className: "relative", children: [_jsx(Div, { className: "absolute inset-0 flex items-center", children: _jsx(Div, { className: "w-full border-t border-neutral-200" }) }), _jsx(Div, { className: "relative flex justify-center text-sm", children: _jsx(Span, { className: "px-2 bg-white text-neutral-500", children: dividerLabel }) })] }), _jsx(Div, { className: "grid grid-cols-1 gap-3", children: _jsxs(Button, { type: "button", onClick: onGoogle, disabled: disabled, variant: "outline", className: "inline-flex items-center justify-center rounded-md border border-neutral-300 bg-white px-4 py-2 text-sm font-medium text-neutral-900 hover:bg-neutral-50 disabled:cursor-not-allowed disabled:opacity-50", children: [_jsxs("svg", { className: "mr-2 h-5 w-5", viewBox: "0 0 24 24", "aria-hidden": "true", children: [_jsx("path", { fill: "currentColor", d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z" }), _jsx("path", { fill: "currentColor", d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z" }), _jsx("path", { fill: "currentColor", d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z" }), _jsx("path", { fill: "currentColor", d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z" })] }), googleLabel] }) })] }));
|
|
4
|
+
return (_jsxs(_Fragment, { children: [_jsxs(Div, { className: "relative", children: [_jsx(Div, { className: "absolute inset-0 flex items-center", children: _jsx(Div, { className: "w-full border-t border-neutral-200 dark:border-slate-700" }) }), _jsx(Div, { className: "relative flex justify-center text-sm", children: _jsx(Span, { className: "px-2 bg-white dark:bg-slate-950 text-neutral-500 dark:text-slate-400", children: dividerLabel }) })] }), _jsx(Div, { className: "grid grid-cols-1 gap-3", children: _jsxs(Button, { type: "button", onClick: onGoogle, disabled: disabled, variant: "outline", className: "inline-flex items-center justify-center rounded-md border border-neutral-300 dark:border-slate-700 bg-white dark:bg-slate-900 px-4 py-2 text-sm font-medium text-neutral-900 dark:text-zinc-100 hover:bg-neutral-50 dark:hover:bg-slate-800 disabled:cursor-not-allowed disabled:opacity-50", children: [_jsxs("svg", { className: "mr-2 h-5 w-5", viewBox: "0 0 24 24", "aria-hidden": "true", children: [_jsx("path", { fill: "currentColor", d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z" }), _jsx("path", { fill: "currentColor", d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z" }), _jsx("path", { fill: "currentColor", d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z" }), _jsx("path", { fill: "currentColor", d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z" })] }), googleLabel] }) })] }));
|
|
6
5
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { Div, Heading, Text } from "../../../ui";
|
|
2
|
+
import { Div, Heading, Text, Button } from "../../../ui";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
3
4
|
export function VerifyEmailView({ status, error, labels = {}, onRetry, renderContinueButton, className = "", }) {
|
|
4
|
-
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full bg-white rounded-2xl border border-neutral-200 shadow-sm p-8 text-center", children: [status === "loading" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full border-4 border-primary border-t-transparent animate-spin mx-auto mb-6" }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.loadingTitle ?? "Verifying your email…" }), _jsx(Text, { className: "text-neutral-500", children: labels.loadingDescription ?? "Please wait a moment." })] })), status === "success" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full bg-green-100 flex items-center justify-center mx-auto mb-6", children: _jsx("svg", { className:
|
|
5
|
+
return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full bg-white dark:bg-slate-900 rounded-2xl border border-neutral-200 dark:border-slate-700 shadow-sm p-8 text-center", children: [status === "loading" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full border-4 border-primary border-t-transparent animate-spin mx-auto mb-6" }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.loadingTitle ?? "Verifying your email…" }), _jsx(Text, { className: "text-neutral-500", children: labels.loadingDescription ?? "Please wait a moment." })] })), status === "success" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full bg-green-100 flex items-center justify-center mx-auto mb-6", children: _jsx("svg", { className: `w-6 h-6 ${THEME_CONSTANTS.themed.textSuccess}`, fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", "aria-hidden": "true", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" }) }) }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.successTitle ?? "Email verified!" }), _jsx(Text, { className: "text-neutral-500 mb-6", children: labels.successDescription ??
|
|
5
6
|
"Your email has been verified successfully." }), renderContinueButton?.()] })), status === "error" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full bg-red-100 flex items-center justify-center mx-auto mb-6", children: _jsx("svg", { className: "w-6 h-6 text-red-600", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", "aria-hidden": "true", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M6 18L18 6M6 6l12 12" }) }) }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.errorTitle ?? "Verification failed" }), _jsx(Text, { className: "text-neutral-500 mb-2", children: error ??
|
|
6
7
|
labels.errorDescription ??
|
|
7
|
-
"The verification link may have expired." }), onRetry && (_jsx(
|
|
8
|
+
"The verification link may have expired." }), onRetry && (_jsx(Button, { onClick: onRetry, className: "mt-4 rounded-lg bg-primary px-4 py-2 text-sm font-semibold text-white hover:bg-primary/90 transition-colors", children: labels.retryLabel ?? "Try again" }))] }))] }) }));
|
|
8
9
|
}
|
|
@@ -12,3 +12,4 @@ export { ResetPasswordView } from "./ResetPasswordView";
|
|
|
12
12
|
export type { ResetPasswordViewProps } from "./ResetPasswordView";
|
|
13
13
|
export { VerifyEmailView } from "./VerifyEmailView";
|
|
14
14
|
export type { VerifyEmailViewProps } from "./VerifyEmailView";
|
|
15
|
+
export { OAuthLoadingView } from "./OAuthLoadingView";
|
|
@@ -6,3 +6,4 @@ export { RegisterForm } from "./RegisterForm";
|
|
|
6
6
|
export { ForgotPasswordView } from "./ForgotPasswordView";
|
|
7
7
|
export { ResetPasswordView } from "./ResetPasswordView";
|
|
8
8
|
export { VerifyEmailView } from "./VerifyEmailView";
|
|
9
|
+
export { OAuthLoadingView } from "./OAuthLoadingView";
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Consent OTP - Shared constants, path helpers, and utilities
|
|
3
|
+
*/
|
|
2
4
|
import { getAdminDb } from "../../providers/db-firebase";
|
|
3
5
|
/** OTP validity window (10 minutes). */
|
|
4
6
|
export declare const CONSENT_OTP_EXPIRY_MS: number;
|
|
@@ -17,9 +19,9 @@ export declare const CONSENT_OTP_VERIFY_RATE_LIMIT: {
|
|
|
17
19
|
};
|
|
18
20
|
type Db = ReturnType<typeof getAdminDb>;
|
|
19
21
|
/** Reference to a user's consent OTP document for a given address. */
|
|
20
|
-
export declare function consentOtpRef(db: Db, uid: string, addressId: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData
|
|
22
|
+
export declare function consentOtpRef(db: Db, uid: string, addressId: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData>;
|
|
21
23
|
/** Reference to a user's consent OTP rate-limit metadata document. */
|
|
22
|
-
export declare function consentOtpRateLimitRef(db: Db, uid: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData
|
|
24
|
+
export declare function consentOtpRateLimitRef(db: Db, uid: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData>;
|
|
23
25
|
/** HMAC-SHA256 hash of an OTP code. */
|
|
24
26
|
export declare function hashOtp(code: string): string;
|
|
25
27
|
/** Generate a cryptographically-secure random 6-digit OTP string. */
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import "server-only";
|
|
2
1
|
import type { DocumentReference } from "firebase-admin/firestore";
|
|
3
2
|
import { BaseRepository, type FirebaseSieveFields, type FirebaseSieveResult, type SieveModel } from "../../../providers/db-firebase";
|
|
4
3
|
import { type SessionCreateInput, type SessionDocument, type SessionUpdateInput } from "../schemas";
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import "server-only";
|
|
2
1
|
import { DatabaseError } from "../../../errors";
|
|
3
2
|
import { BaseRepository } from "../../../providers/db-firebase";
|
|
4
3
|
import { TOKEN_PII_FIELDS, TOKEN_PII_INDEX_MAP, addPiiIndices, decryptPiiFields, encryptPiiFields, piiBlindIndex, } from "../../../security";
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import "server-only";
|
|
2
1
|
import type { DocumentSnapshot } from "../../../providers/db-firebase";
|
|
3
2
|
import { BaseRepository, type FirebaseSieveFields, type FirebaseSieveResult, type SieveModel } from "../../../providers/db-firebase";
|
|
4
3
|
import type { UserRole } from "../types";
|
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
import "server-only";
|
|
2
|
-
import { increment, serverTimestamp } from "../../../contracts/field-ops";
|
|
3
1
|
import { DatabaseError } from "../../../errors";
|
|
4
|
-
import { BaseRepository, prepareForFirestore, } from "../../../providers/db-firebase";
|
|
2
|
+
import { BaseRepository, getFirestoreCount, prepareForFirestore, } from "../../../providers/db-firebase";
|
|
5
3
|
import { USER_PII_FIELDS, USER_PII_INDEX_MAP, addPiiIndices, decryptPayoutDetails, decryptPiiFields, decryptShippingConfig, encryptPayoutDetails, encryptPiiFields, encryptShippingConfig, piiBlindIndex, } from "../../../security";
|
|
6
4
|
import { USER_COLLECTION, USER_FIELDS, createUserId, } from "../schemas";
|
|
7
5
|
export class UserRepository extends BaseRepository {
|
|
@@ -130,11 +128,7 @@ export class UserRepository extends BaseRepository {
|
|
|
130
128
|
}
|
|
131
129
|
async countByRole(role) {
|
|
132
130
|
try {
|
|
133
|
-
|
|
134
|
-
.where(USER_FIELDS.ROLE, "==", role)
|
|
135
|
-
.count()
|
|
136
|
-
.get();
|
|
137
|
-
return snapshot.data().count;
|
|
131
|
+
return await getFirestoreCount(this.getCollection().where(USER_FIELDS.ROLE, "==", role));
|
|
138
132
|
}
|
|
139
133
|
catch (error) {
|
|
140
134
|
throw new DatabaseError(`Failed to count users by role: ${role}`, error);
|
|
@@ -142,11 +136,7 @@ export class UserRepository extends BaseRepository {
|
|
|
142
136
|
}
|
|
143
137
|
async countActive() {
|
|
144
138
|
try {
|
|
145
|
-
|
|
146
|
-
.where(USER_FIELDS.DISABLED, "==", false)
|
|
147
|
-
.count()
|
|
148
|
-
.get();
|
|
149
|
-
return snapshot.data().count;
|
|
139
|
+
return await getFirestoreCount(this.getCollection().where(USER_FIELDS.DISABLED, "==", false));
|
|
150
140
|
}
|
|
151
141
|
catch (error) {
|
|
152
142
|
throw new DatabaseError("Failed to count active users", error);
|
|
@@ -154,11 +144,7 @@ export class UserRepository extends BaseRepository {
|
|
|
154
144
|
}
|
|
155
145
|
async countDisabled() {
|
|
156
146
|
try {
|
|
157
|
-
|
|
158
|
-
.where(USER_FIELDS.DISABLED, "==", true)
|
|
159
|
-
.count()
|
|
160
|
-
.get();
|
|
161
|
-
return snapshot.data().count;
|
|
147
|
+
return await getFirestoreCount(this.getCollection().where(USER_FIELDS.DISABLED, "==", true));
|
|
162
148
|
}
|
|
163
149
|
catch (error) {
|
|
164
150
|
throw new DatabaseError("Failed to count disabled users", error);
|
|
@@ -166,11 +152,7 @@ export class UserRepository extends BaseRepository {
|
|
|
166
152
|
}
|
|
167
153
|
async countNewSince(since) {
|
|
168
154
|
try {
|
|
169
|
-
|
|
170
|
-
.where(USER_FIELDS.CREATED_AT, ">=", since)
|
|
171
|
-
.count()
|
|
172
|
-
.get();
|
|
173
|
-
return snapshot.data().count;
|
|
155
|
+
return await getFirestoreCount(this.getCollection().where(USER_FIELDS.CREATED_AT, ">=", since));
|
|
174
156
|
}
|
|
175
157
|
catch (error) {
|
|
176
158
|
throw new DatabaseError("Failed to count new users", error);
|
|
@@ -178,12 +160,19 @@ export class UserRepository extends BaseRepository {
|
|
|
178
160
|
}
|
|
179
161
|
async updateLoginMetadata(uid) {
|
|
180
162
|
try {
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
.
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
163
|
+
const docRef = this.getCollection().doc(uid);
|
|
164
|
+
await this.db.runTransaction(async (tx) => {
|
|
165
|
+
const snapAny = (await tx.get(docRef));
|
|
166
|
+
// support both DocumentSnapshot and other shapes defensively
|
|
167
|
+
const docData = (typeof snapAny?.data === "function"
|
|
168
|
+
? snapAny.data()
|
|
169
|
+
: snapAny?.data) ?? {};
|
|
170
|
+
const currentLoginCount = docData?.metadata?.loginCount || 0;
|
|
171
|
+
tx.update(docRef, {
|
|
172
|
+
[USER_FIELDS.META.LAST_SIGN_IN_TIME]: new Date(),
|
|
173
|
+
[USER_FIELDS.META.LOGIN_COUNT]: Number(currentLoginCount) + 1,
|
|
174
|
+
[USER_FIELDS.UPDATED_AT]: new Date(),
|
|
175
|
+
});
|
|
187
176
|
});
|
|
188
177
|
}
|
|
189
178
|
catch (error) {
|
|
@@ -85,7 +85,7 @@ export const userQueryHelpers = {
|
|
|
85
85
|
export function createUserId(input) {
|
|
86
86
|
return generateUserId(input);
|
|
87
87
|
}
|
|
88
|
-
//
|
|
88
|
+
// -- User field name constants ------------------------------------------------
|
|
89
89
|
export const USER_FIELDS = {
|
|
90
90
|
ID: "id",
|
|
91
91
|
UID: "uid",
|
|
@@ -57,16 +57,16 @@ export declare const authUserSchema: z.ZodObject<{
|
|
|
57
57
|
isEmailVerified: z.ZodOptional<z.ZodBoolean>;
|
|
58
58
|
}, "strip", z.ZodTypeAny, {
|
|
59
59
|
id: string;
|
|
60
|
-
displayName?: string | undefined;
|
|
61
|
-
email?: string | undefined;
|
|
62
60
|
role?: "admin" | "seller" | "customer" | "superadmin" | undefined;
|
|
61
|
+
email?: string | undefined;
|
|
62
|
+
displayName?: string | undefined;
|
|
63
63
|
photoURL?: string | undefined;
|
|
64
64
|
isEmailVerified?: boolean | undefined;
|
|
65
65
|
}, {
|
|
66
66
|
id: string;
|
|
67
|
-
displayName?: string | undefined;
|
|
68
|
-
email?: string | undefined;
|
|
69
67
|
role?: "admin" | "seller" | "customer" | "superadmin" | undefined;
|
|
68
|
+
email?: string | undefined;
|
|
69
|
+
displayName?: string | undefined;
|
|
70
70
|
photoURL?: string | undefined;
|
|
71
71
|
isEmailVerified?: boolean | undefined;
|
|
72
72
|
}>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export * from "./firestore";
|
|
2
2
|
import { z } from "zod";
|
|
3
|
-
//
|
|
3
|
+
// --- Form schemas -------------------------------------------------------------
|
|
4
4
|
/**
|
|
5
5
|
* Login form schema — use with react-hook-form + zodResolver.
|
|
6
6
|
*
|
|
@@ -24,7 +24,7 @@ export const resetPasswordSchema = z.object({
|
|
|
24
24
|
token: z.string().min(1),
|
|
25
25
|
password: z.string().min(6),
|
|
26
26
|
});
|
|
27
|
-
//
|
|
27
|
+
// --- Auth user schema ---------------------------------------------------------
|
|
28
28
|
export const userRoleSchema = z.enum([
|
|
29
29
|
"customer",
|
|
30
30
|
"seller",
|
|
@@ -23,9 +23,9 @@ export declare const beforeAfterItemSchema: z.ZodObject<{
|
|
|
23
23
|
createdAt: z.ZodOptional<z.ZodString>;
|
|
24
24
|
}, "strip", z.ZodTypeAny, {
|
|
25
25
|
id: string;
|
|
26
|
-
sortOrder: number;
|
|
27
26
|
title: string;
|
|
28
27
|
isActive: boolean;
|
|
28
|
+
sortOrder: number;
|
|
29
29
|
createdAt?: string | undefined;
|
|
30
30
|
description?: string | undefined;
|
|
31
31
|
productId?: string | undefined;
|
|
@@ -37,9 +37,9 @@ export declare const beforeAfterItemSchema: z.ZodObject<{
|
|
|
37
37
|
id: string;
|
|
38
38
|
title: string;
|
|
39
39
|
createdAt?: string | undefined;
|
|
40
|
+
isActive?: boolean | undefined;
|
|
40
41
|
sortOrder?: number | undefined;
|
|
41
42
|
description?: string | undefined;
|
|
42
|
-
isActive?: boolean | undefined;
|
|
43
43
|
productId?: string | undefined;
|
|
44
44
|
concern?: string | undefined;
|
|
45
45
|
beforeImageUrl?: string | undefined;
|