@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
|
@@ -10,13 +10,25 @@
|
|
|
10
10
|
// Runtime registry (same pattern as IClientAuthProvider / IClientRealtimeProvider)
|
|
11
11
|
// ---------------------------------------------------------------------------
|
|
12
12
|
let _adapter = null;
|
|
13
|
+
/**
|
|
14
|
+
* No-op guest adapter used when no real adapter has been registered.
|
|
15
|
+
* Allows SessionProvider to render in "not signed in" mode without crashing.
|
|
16
|
+
*/
|
|
17
|
+
const GUEST_ADAPTER = {
|
|
18
|
+
onAuthStateChanged(callback) {
|
|
19
|
+
callback(null);
|
|
20
|
+
return () => { };
|
|
21
|
+
},
|
|
22
|
+
getCurrentUser() {
|
|
23
|
+
return null;
|
|
24
|
+
},
|
|
25
|
+
signOut() {
|
|
26
|
+
return Promise.resolve();
|
|
27
|
+
},
|
|
28
|
+
};
|
|
13
29
|
export function registerClientSessionAdapter(adapter) {
|
|
14
30
|
_adapter = adapter;
|
|
15
31
|
}
|
|
16
32
|
export function getClientSessionAdapter() {
|
|
17
|
-
|
|
18
|
-
throw new Error("Client session adapter not registered. " +
|
|
19
|
-
"Call registerClientSessionAdapter() before using SessionProvider.");
|
|
20
|
-
}
|
|
21
|
-
return _adapter;
|
|
33
|
+
return _adapter ?? GUEST_ADAPTER;
|
|
22
34
|
}
|
package/dist/contracts/config.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Site Config -------------------------------------------------------------
|
|
2
2
|
export {};
|
package/dist/contracts/email.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Email Shared Types -------------------------------------------------------
|
|
2
2
|
export {};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Feature Manifest ---------------------------------------------------------
|
|
2
2
|
export {};
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
* The active DB provider registers its concrete implementations
|
|
7
7
|
* at startup via `registerFieldOps()`.
|
|
8
8
|
*/
|
|
9
|
-
//
|
|
9
|
+
// --- Runtime registry ------------------------------------------------------
|
|
10
10
|
let _ops = null;
|
|
11
11
|
export function registerFieldOps(ops) {
|
|
12
12
|
_ops = ops;
|
|
@@ -17,7 +17,7 @@ function getOps() {
|
|
|
17
17
|
}
|
|
18
18
|
return _ops;
|
|
19
19
|
}
|
|
20
|
-
//
|
|
20
|
+
// --- Public helpers (used by feature repositories) -------------------------
|
|
21
21
|
export function serverTimestamp() {
|
|
22
22
|
return getOps().serverTimestamp();
|
|
23
23
|
}
|
package/dist/contracts/form.js
CHANGED
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
* />
|
|
39
39
|
* ```
|
|
40
40
|
*/
|
|
41
|
-
//
|
|
41
|
+
// --- Global registry ----------------------------------------------------------
|
|
42
42
|
const _fieldRegistry = new Map();
|
|
43
43
|
/**
|
|
44
44
|
* Register extra fields for a specific form by its form key (e.g. `"product"`,
|
package/dist/contracts/infra.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Infra Interfaces ---------------------------------------------------------
|
|
2
2
|
export {};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Payment Shared Types -----------------------------------------------------
|
|
2
2
|
export {};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Repository Interfaces ----------------------------------------------------
|
|
2
2
|
// Segregated per ISP: features that only read never depend on IWriteRepository.
|
|
3
|
-
//
|
|
3
|
+
// --- Global hooks registry ----------------------------------------------------
|
|
4
4
|
const _hooksRegistry = new Map();
|
|
5
5
|
/**
|
|
6
6
|
* Register lifecycle hooks for a specific Firestore collection (or any
|
package/dist/contracts/search.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Search Shared Types ------------------------------------------------------
|
|
2
2
|
export {};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Shipping Shared Types ----------------------------------------------------
|
|
2
2
|
export {};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Storage Shared Types -----------------------------------------------------
|
|
2
2
|
export {};
|
package/dist/contracts/style.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
//
|
|
1
|
+
// --- Style Adapter Interface --------------------------------------------------
|
|
2
2
|
export {};
|
package/dist/core/index.d.ts
CHANGED
|
@@ -30,5 +30,6 @@ export type { ActionResult, ActionMiddleware, ActionMiddlewareContext, ServerAct
|
|
|
30
30
|
export { MUTATION_EVENTS, emitMutation, onMutation, inferMutationEvent, } from "./mutation-events";
|
|
31
31
|
export type { MutationEventPayload } from "./mutation-events";
|
|
32
32
|
export type { ResolvedKeys } from "./integration-keys";
|
|
33
|
+
export { invalidateIntegrationKeysCache } from "./integration-keys";
|
|
33
34
|
export { configureMarketDefaults, resetMarketDefaults, getMarketProfile, getDefaultCurrency, getDefaultLocale, getDefaultCountry, getDefaultPhonePrefix, getDefaultTimezone, getDefaultCurrencySymbol, } from "./baseline-resolver";
|
|
34
35
|
export type { MarketProfile } from "./baseline-resolver";
|
package/dist/core/index.js
CHANGED
|
@@ -18,4 +18,5 @@ export { subscribeNewsletter, } from "./newsletter-actions";
|
|
|
18
18
|
export { unitOfWork } from "./unit-of-work";
|
|
19
19
|
export { createServerAction, setActionMiddleware, _resetActionMiddleware, } from "./server-action";
|
|
20
20
|
export { MUTATION_EVENTS, emitMutation, onMutation, inferMutationEvent, } from "./mutation-events";
|
|
21
|
+
export { invalidateIntegrationKeysCache } from "./integration-keys";
|
|
21
22
|
export { configureMarketDefaults, resetMarketDefaults, getMarketProfile, getDefaultCurrency, getDefaultLocale, getDefaultCountry, getDefaultPhonePrefix, getDefaultTimezone, getDefaultCurrencySymbol, } from "./baseline-resolver";
|
|
@@ -1,19 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Integration Keys — Centralised Credential Resolver
|
|
3
|
-
*
|
|
4
|
-
* Server-only. Resolves all provider credentials with a two-tier priority:
|
|
5
|
-
* 1. Firestore siteSettings.credentials (encrypted with AES-256-GCM)
|
|
6
|
-
* 2. Environment variables (fallback for local dev / initial setup)
|
|
7
|
-
*
|
|
8
|
-
* Results are cached in process memory for 60 seconds so Firestore is not
|
|
9
|
-
* hit on every API request. Call invalidateIntegrationKeysCache() after an
|
|
10
|
-
* admin saves new credentials so the next request picks up the fresh values.
|
|
11
|
-
*
|
|
12
|
-
* Usage:
|
|
13
|
-
* const keys = await resolveKeys();
|
|
14
|
-
* const razorpay = new Razorpay({ key_id: keys.razorpayKeyId, key_secret: keys.razorpayKeySecret });
|
|
15
|
-
*/
|
|
16
|
-
import "server-only";
|
|
17
1
|
export interface ResolvedKeys {
|
|
18
2
|
razorpayKeyId: string;
|
|
19
3
|
razorpayKeySecret: string;
|
|
@@ -13,7 +13,6 @@
|
|
|
13
13
|
* const keys = await resolveKeys();
|
|
14
14
|
* const razorpay = new Razorpay({ key_id: keys.razorpayKeyId, key_secret: keys.razorpayKeySecret });
|
|
15
15
|
*/
|
|
16
|
-
import "server-only";
|
|
17
16
|
import { siteSettingsRepository } from "../repositories";
|
|
18
17
|
const EMPTY_KEYS = {
|
|
19
18
|
razorpayKeyId: "",
|
|
@@ -24,7 +24,7 @@
|
|
|
24
24
|
* ```
|
|
25
25
|
*/
|
|
26
26
|
import { eventBus } from "./EventBus";
|
|
27
|
-
//
|
|
27
|
+
// --- Typed event name registry ------------------------------------------------
|
|
28
28
|
/**
|
|
29
29
|
* Canonical event name constants for all appkit feature mutations.
|
|
30
30
|
* Use these when subscribing or emitting to ensure consistent naming.
|
|
@@ -109,7 +109,7 @@ export const MUTATION_EVENTS = {
|
|
|
109
109
|
SETTLED: "appkit/auction/settled",
|
|
110
110
|
},
|
|
111
111
|
};
|
|
112
|
-
//
|
|
112
|
+
// --- Helpers ------------------------------------------------------------------
|
|
113
113
|
/**
|
|
114
114
|
* Emit a typed mutation event on the shared `eventBus`.
|
|
115
115
|
*
|
|
@@ -59,7 +59,7 @@ export function _resetActionMiddleware() {
|
|
|
59
59
|
export function createServerAction(options) {
|
|
60
60
|
const actionName = options.name ?? options.handler.name ?? "anonymous";
|
|
61
61
|
return async function serverAction(rawInput) {
|
|
62
|
-
//
|
|
62
|
+
// -- 1. Validate input --------------------------------------------------
|
|
63
63
|
let input = rawInput;
|
|
64
64
|
if (options.schema) {
|
|
65
65
|
const parsed = options.schema.safeParse(rawInput);
|
|
@@ -70,7 +70,7 @@ export function createServerAction(options) {
|
|
|
70
70
|
input = parsed.data;
|
|
71
71
|
}
|
|
72
72
|
const ctx = { actionName, input };
|
|
73
|
-
//
|
|
73
|
+
// -- 2. Before hooks (global → per-action) -----------------------------
|
|
74
74
|
try {
|
|
75
75
|
await _globalMiddleware.beforeAction?.(ctx);
|
|
76
76
|
await options.beforeAction?.(ctx);
|
|
@@ -78,7 +78,7 @@ export function createServerAction(options) {
|
|
|
78
78
|
catch (err) {
|
|
79
79
|
logger.error(`[createServerAction] beforeAction error in "${actionName}"`, { err });
|
|
80
80
|
}
|
|
81
|
-
//
|
|
81
|
+
// -- 3. Run handler -----------------------------------------------------
|
|
82
82
|
let result;
|
|
83
83
|
try {
|
|
84
84
|
const data = await options.handler({ input });
|
|
@@ -91,7 +91,7 @@ export function createServerAction(options) {
|
|
|
91
91
|
});
|
|
92
92
|
result = { ok: false, error: message };
|
|
93
93
|
}
|
|
94
|
-
//
|
|
94
|
+
// -- 4. After hooks (per-action → global) ------------------------------
|
|
95
95
|
try {
|
|
96
96
|
await options.afterAction?.({ ...ctx, result });
|
|
97
97
|
await _globalMiddleware.afterAction?.({
|
|
@@ -102,7 +102,7 @@ export function createServerAction(options) {
|
|
|
102
102
|
catch (err) {
|
|
103
103
|
logger.error(`[createServerAction] afterAction error in "${actionName}"`, { err });
|
|
104
104
|
}
|
|
105
|
-
//
|
|
105
|
+
// -- 5. Auto-emit mutation event ---------------------------------------
|
|
106
106
|
if (result.ok) {
|
|
107
107
|
const eventName = inferMutationEvent(actionName);
|
|
108
108
|
if (eventName) {
|
|
@@ -1,29 +1,28 @@
|
|
|
1
|
-
import "server-only";
|
|
2
1
|
import type { Transaction, WriteBatch } from "firebase-admin/firestore";
|
|
3
2
|
export declare class UnitOfWork {
|
|
4
3
|
private get db();
|
|
5
|
-
get users(): import("
|
|
6
|
-
get addresses(): import("
|
|
4
|
+
get users(): import("..").UserRepository;
|
|
5
|
+
get addresses(): import("..").AddressRepository;
|
|
7
6
|
get tokens(): {
|
|
8
|
-
email: import("
|
|
9
|
-
password: import("
|
|
7
|
+
email: import("..").EmailVerificationTokenRepository;
|
|
8
|
+
password: import("..").PasswordResetTokenRepository;
|
|
10
9
|
getExpiredEmailVerificationRefs(now: Date): Promise<FirebaseFirestore.DocumentReference[]>;
|
|
11
10
|
getExpiredPasswordResetRefs(now: Date): Promise<FirebaseFirestore.DocumentReference[]>;
|
|
12
11
|
};
|
|
13
|
-
get products(): import("
|
|
14
|
-
get orders(): import("
|
|
15
|
-
get reviews(): import("
|
|
16
|
-
get sessions(): import("
|
|
12
|
+
get products(): import("..").ProductRepository;
|
|
13
|
+
get orders(): import("..").OrderRepository;
|
|
14
|
+
get reviews(): import("..").ReviewRepository;
|
|
15
|
+
get sessions(): import("..").SessionRepository;
|
|
17
16
|
get bids(): import("../features/auctions/repository/bid.repository").BidRepository;
|
|
18
|
-
get carts(): import("
|
|
17
|
+
get carts(): import("..").CartRepository;
|
|
19
18
|
get siteSettings(): import("../features/admin/repository/site-settings.repository").SiteSettingsRepository;
|
|
20
19
|
get carousel(): import("../features/homepage/repository/carousel.repository").CarouselRepository;
|
|
21
20
|
get homepageSections(): import("../features/homepage/repository/homepage-sections.repository").HomepageSectionsRepository;
|
|
22
|
-
get categories(): import("
|
|
21
|
+
get categories(): import("..").CategoriesRepository;
|
|
23
22
|
get coupons(): import("../features/promotions/repository/coupons.repository").CouponsRepository;
|
|
24
|
-
get faqs(): import("
|
|
25
|
-
get wishlists(): import("
|
|
26
|
-
get blogs(): import("
|
|
23
|
+
get faqs(): import("..").FirebaseFAQsRepository;
|
|
24
|
+
get wishlists(): import("..").UserWishlistRepository;
|
|
25
|
+
get blogs(): import("..").BlogRepository;
|
|
27
26
|
get payouts(): import("../features/payments/repository/payout.repository").PayoutRepository;
|
|
28
27
|
get notifications(): import("../features/admin/repository/notification.repository").NotificationRepository;
|
|
29
28
|
runTransaction<TResult>(fn: (tx: Transaction) => Promise<TResult>): Promise<TResult>;
|
|
@@ -123,6 +123,7 @@ export declare const ERROR_MESSAGES: {
|
|
|
123
123
|
readonly NOT_IMPLEMENTED: "This feature is not yet implemented";
|
|
124
124
|
readonly TRY_AGAIN: "Something went wrong. Please try again in a moment.";
|
|
125
125
|
readonly RATE_LIMIT_EXCEEDED: "Too many requests. Please try again later.";
|
|
126
|
+
readonly UNSAVED_CHANGES: "You have unsaved changes. Leave without saving?";
|
|
126
127
|
};
|
|
127
128
|
readonly NETWORK: {
|
|
128
129
|
readonly OFFLINE: "You appear to be offline. Check your connection and try again.";
|
package/dist/errors/messages.js
CHANGED
|
@@ -130,6 +130,7 @@ export const ERROR_MESSAGES = {
|
|
|
130
130
|
NOT_IMPLEMENTED: "This feature is not yet implemented",
|
|
131
131
|
TRY_AGAIN: "Something went wrong. Please try again in a moment.",
|
|
132
132
|
RATE_LIMIT_EXCEEDED: "Too many requests. Please try again later.",
|
|
133
|
+
UNSAVED_CHANGES: "You have unsaved changes. Leave without saving?",
|
|
133
134
|
},
|
|
134
135
|
// Network Errors
|
|
135
136
|
NETWORK: {
|
|
@@ -15,21 +15,21 @@ export interface AboutMilestone {
|
|
|
15
15
|
text: string;
|
|
16
16
|
}
|
|
17
17
|
export interface AboutViewProps {
|
|
18
|
-
labels
|
|
19
|
-
title
|
|
20
|
-
subtitle
|
|
21
|
-
missionTitle
|
|
22
|
-
missionText
|
|
23
|
-
howItWorksTitle
|
|
24
|
-
valuesTitle
|
|
25
|
-
milestonesTitle
|
|
26
|
-
ctaTitle
|
|
27
|
-
ctaSell
|
|
28
|
-
ctaShop
|
|
18
|
+
labels?: {
|
|
19
|
+
title?: string;
|
|
20
|
+
subtitle?: string;
|
|
21
|
+
missionTitle?: string;
|
|
22
|
+
missionText?: string;
|
|
23
|
+
howItWorksTitle?: string;
|
|
24
|
+
valuesTitle?: string;
|
|
25
|
+
milestonesTitle?: string;
|
|
26
|
+
ctaTitle?: string;
|
|
27
|
+
ctaSell?: string;
|
|
28
|
+
ctaShop?: string;
|
|
29
29
|
};
|
|
30
|
-
howItems
|
|
31
|
-
valueItems
|
|
32
|
-
milestones
|
|
30
|
+
howItems?: AboutHowItem[];
|
|
31
|
+
valueItems?: AboutValueItem[];
|
|
32
|
+
milestones?: AboutMilestone[];
|
|
33
33
|
heroBannerClass?: string;
|
|
34
34
|
ctaBannerClass?: string;
|
|
35
35
|
/** Render the CTA action buttons */
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { Heading, Section, Span, Text } from "../../../ui";
|
|
3
|
-
export function AboutView({ labels, howItems, valueItems, milestones, heroBannerClass = "bg-gradient-to-br from-violet-600 to-indigo-600", ctaBannerClass = "bg-gradient-to-br from-violet-600 to-indigo-600", renderCtaButtons, }) {
|
|
4
|
-
return (_jsxs("div", { className: "-mx-4 md:-mx-6 lg:-mx-8 -mt-6 sm:-mt-8 lg:-mt-10", children: [_jsx(Section, { className: `${heroBannerClass} text-white py-16 md:py-20 lg:py-24`, children: _jsxs("div", { className: "max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 text-center", children: [_jsx(Heading, { level: 1, variant: "none", className: "text-4xl md:text-5xl font-bold mb-6 text-white", children: labels.title }), _jsx(Text, { variant: "none", className: "text-xl text-white/80 max-w-2xl mx-auto", children: labels.subtitle })] }) }), _jsxs("div", { className: "max-w-5xl mx-auto px-4 sm:px-6 lg:px-8 py-16 md:py-20 space-y-16 md:space-y-20", children: [_jsxs(Section, { className: "text-center max-w-3xl mx-auto", children: [_jsx(Heading, { level: 2, className: "mb-4", children: labels.missionTitle }), _jsx(Text, { size: "lg", variant: "secondary", className: "leading-relaxed", children: labels.missionText })] }), _jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "text-center mb-12", children: labels.howItWorksTitle }), _jsx("div", { className: "grid md:grid-cols-3 gap-6 md:gap-8", children: howItems.map(({ title, text, icon, color }) => (_jsxs("div", { className: `bg-gradient-to-br ${color ?? "from-primary/5 to-primary/5"} rounded-2xl p-6 space-y-3`, children: [_jsx("div", { className: "text-4xl", children: icon }), _jsx(Heading, { level: 3, children: title }), _jsx(Text, { size: "sm", variant: "secondary", className: "leading-relaxed", children: text })] }, title))) })] }), _jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "text-center mb-12", children: labels.valuesTitle }), _jsx("div", { className: "grid md:grid-cols-3 gap-5 md:gap-6", children: valueItems.map(({ title, text, icon }) => (_jsxs("div", { className: "bg-white dark:bg-slate-800 rounded-xl p-6 space-y-3 border border-neutral-200 dark:border-slate-700", children: [_jsx("div", { className: "text-3xl", children: icon }), _jsx(Heading, { level: 3, children: title }), _jsx(Text, { size: "sm", variant: "secondary", className: "leading-relaxed", children: text })] }, title))) })] }), _jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "text-center mb-10", children: labels.milestonesTitle }), _jsx("div", { className: "relative border-l-2 border-primary/30 pl-8 space-y-8 max-w-2xl mx-auto", children: milestones.map(({ year, text }) => (_jsxs("div", { className: "relative", children: [_jsx("div", { className: "absolute -left-10 top-1 w-4 h-4 rounded-full bg-primary border-2 border-white dark:border-slate-900" }), _jsx(Span, { size: "xs", weight: "bold", className: "text-primary uppercase tracking-wide", children: year }), _jsx(Text, { className: "mt-1", children: text })] }, year))) })] }), _jsxs(Section, { className: `text-center ${ctaBannerClass} rounded-2xl p-8 md:p-12 text-white`, children: [_jsx(Heading, { level: 2, variant: "none", className: "text-3xl font-bold mb-8 text-white", children: labels.ctaTitle }), renderCtaButtons ? (renderCtaButtons()) : (_jsx("div", { className: "flex justify-center gap-3 flex-wrap", children: _jsxs(Span, { className: "text-white/70 text-sm", children: [labels.ctaSell, " \u00B7 ", labels.ctaShop] }) }))] })] })] }));
|
|
3
|
+
export function AboutView({ labels = {}, howItems = [], valueItems = [], milestones = [], heroBannerClass = "bg-gradient-to-br from-violet-600 to-indigo-600", ctaBannerClass = "bg-gradient-to-br from-violet-600 to-indigo-600", renderCtaButtons, }) {
|
|
4
|
+
return (_jsxs("div", { className: "-mx-4 md:-mx-6 lg:-mx-8 -mt-6 sm:-mt-8 lg:-mt-10", "data-section": "aboutview-div-81", children: [_jsx(Section, { className: `${heroBannerClass} text-white py-16 md:py-20 lg:py-24`, children: _jsxs("div", { className: "max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 text-center", "data-section": "aboutview-div-82", children: [_jsx(Heading, { level: 1, variant: "none", className: "text-4xl md:text-5xl font-bold mb-6 text-white", children: labels.title }), _jsx(Text, { variant: "none", className: "text-xl text-white/80 max-w-2xl mx-auto", children: labels.subtitle })] }) }), _jsxs("div", { className: "max-w-5xl mx-auto px-4 sm:px-6 lg:px-8 py-16 md:py-20 space-y-16 md:space-y-20", "data-section": "aboutview-div-83", children: [_jsxs(Section, { className: "text-center max-w-3xl mx-auto", children: [_jsx(Heading, { level: 2, className: "mb-4", children: labels.missionTitle }), _jsx(Text, { size: "lg", variant: "secondary", className: "leading-relaxed", children: labels.missionText })] }), _jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "text-center mb-12", children: labels.howItWorksTitle }), _jsx("div", { className: "grid md:grid-cols-3 gap-6 md:gap-8", "data-section": "aboutview-div-84", children: howItems.map(({ title, text, icon, color }) => (_jsxs("div", { className: `bg-gradient-to-br ${color ?? "from-primary/5 to-primary/5"} rounded-2xl p-6 space-y-3`, "data-section": "aboutview-div-85", children: [_jsx("div", { className: "text-4xl", "data-section": "aboutview-div-86", children: icon }), _jsx(Heading, { level: 3, children: title }), _jsx(Text, { size: "sm", variant: "secondary", className: "leading-relaxed", children: text })] }, title))) })] }), _jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "text-center mb-12", children: labels.valuesTitle }), _jsx("div", { className: "grid md:grid-cols-3 gap-5 md:gap-6", "data-section": "aboutview-div-87", children: valueItems.map(({ title, text, icon }) => (_jsxs("div", { className: "bg-white dark:bg-slate-800 rounded-xl p-6 space-y-3 border border-neutral-200 dark:border-slate-700", "data-section": "aboutview-div-88", children: [_jsx("div", { className: "text-3xl", "data-section": "aboutview-div-89", children: icon }), _jsx(Heading, { level: 3, children: title }), _jsx(Text, { size: "sm", variant: "secondary", className: "leading-relaxed", children: text })] }, title))) })] }), _jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "text-center mb-10", children: labels.milestonesTitle }), _jsx("div", { className: "relative border-l-2 border-primary/30 pl-8 space-y-8 max-w-2xl mx-auto", "data-section": "aboutview-div-90", children: milestones.map(({ year, text }) => (_jsxs("div", { className: "relative", "data-section": "aboutview-div-91", children: [_jsx("div", { className: "absolute -left-10 top-1 w-4 h-4 rounded-full bg-primary border-2 border-white dark:border-slate-900" }), _jsx(Span, { size: "xs", weight: "bold", className: "text-primary uppercase tracking-wide", children: year }), _jsx(Text, { className: "mt-1", children: text })] }, year))) })] }), _jsxs(Section, { className: `text-center ${ctaBannerClass} rounded-2xl p-8 md:p-12 text-white`, children: [_jsx(Heading, { level: 2, variant: "none", className: "text-3xl font-bold mb-8 text-white", children: labels.ctaTitle }), renderCtaButtons ? (renderCtaButtons()) : (_jsx("div", { className: "flex justify-center gap-3 flex-wrap", "data-section": "aboutview-div-92", children: _jsxs(Span, { className: "text-white/70 text-sm", children: [labels.ctaSell, " \u00B7 ", labels.ctaShop] }) }))] })] })] }));
|
|
5
5
|
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export interface FAQPageViewProps {
|
|
2
|
+
/** If provided, filter to this category slug */
|
|
3
|
+
category?: string;
|
|
4
|
+
heroBannerClass?: string;
|
|
5
|
+
}
|
|
6
|
+
export declare function FAQPageView({ category, heroBannerClass, }?: FAQPageViewProps): Promise<import("react/jsx-runtime").JSX.Element>;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { ROUTES } from "../../../constants";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { Heading, Text, Section, Stack } from "../../../ui";
|
|
5
|
+
import { TextLink } from "../../../ui";
|
|
6
|
+
import { HelpCircle, ChevronRight } from "lucide-react";
|
|
7
|
+
const DEFAULT_HERO_CLASS = "bg-gradient-to-br from-violet-700 to-indigo-700 dark:from-violet-800 dark:to-indigo-800";
|
|
8
|
+
export async function FAQPageView({ category, heroBannerClass = DEFAULT_HERO_CLASS, } = {}) {
|
|
9
|
+
const { themed, flex, page } = THEME_CONSTANTS;
|
|
10
|
+
const { getTranslations } = await import("next-intl/server");
|
|
11
|
+
const t = await getTranslations("faqs");
|
|
12
|
+
// Each FAQ namespace must export:
|
|
13
|
+
// title, subtitle, searchPlaceholder
|
|
14
|
+
// categories: [{ slug, label, icon }]
|
|
15
|
+
// items (or per-category items keyed by category slug): [{ question, answer }]
|
|
16
|
+
const rawCategories = t.raw("categories");
|
|
17
|
+
const categories = Array.isArray(rawCategories) ? rawCategories : [];
|
|
18
|
+
const rawItems = t.raw("items");
|
|
19
|
+
const allItems = Array.isArray(rawItems) ? rawItems : [];
|
|
20
|
+
const visibleItems = category
|
|
21
|
+
? allItems.filter((item) => item.category === category)
|
|
22
|
+
: allItems;
|
|
23
|
+
const activeCategory = categories.find((c) => c.slug === category);
|
|
24
|
+
return (_jsxs("div", { className: "-mx-4 md:-mx-6 lg:-mx-8 -mt-6 sm:-mt-8 lg:-mt-10", "data-section": "faqpageview-div-93", children: [_jsx(Section, { className: `${heroBannerClass} text-white py-14 md:py-16 lg:py-20`, children: _jsxs("div", { className: `${page.container.md} text-center`, "data-section": "faqpageview-div-94", children: [_jsx(Heading, { level: 1, variant: "none", className: "mb-3 text-white", children: activeCategory ? activeCategory.label : t("title") }), _jsx(Text, { variant: "none", className: "text-white/80 max-w-2xl mx-auto", children: t("subtitle") })] }) }), _jsx("div", { className: `${page.container.md} py-10 md:py-12 lg:py-16`, "data-section": "faqpageview-div-95", children: _jsxs("div", { className: "flex flex-col md:flex-row gap-8", "data-section": "faqpageview-div-96", children: [categories.length > 0 && (_jsxs("aside", { className: "md:w-56 flex-shrink-0", children: [_jsx(Heading, { level: 3, className: "text-sm font-semibold uppercase tracking-wide text-neutral-500 mb-3", children: t("categoriesLabel") }), _jsxs("nav", { className: "space-y-1", children: [_jsxs(TextLink, { href: String(ROUTES.PUBLIC.FAQS), className: `flex items-center justify-between px-3 py-2 rounded-lg text-sm transition-colors ${!category
|
|
25
|
+
? "bg-primary/10 text-primary font-semibold"
|
|
26
|
+
: "hover:bg-neutral-100 dark:hover:bg-neutral-800"}`, children: [_jsxs("span", { className: `${flex.row} gap-2`, children: [_jsx(HelpCircle, { className: "w-4 h-4" }), t("allCategories")] }), _jsx(ChevronRight, { className: "w-3.5 h-3.5 opacity-50" })] }), categories.map((cat) => (_jsxs(TextLink, { href: String(ROUTES.PUBLIC.FAQ_CATEGORY(cat.slug)), className: `flex items-center justify-between px-3 py-2 rounded-lg text-sm transition-colors ${category === cat.slug
|
|
27
|
+
? "bg-primary/10 text-primary font-semibold"
|
|
28
|
+
: "hover:bg-neutral-100 dark:hover:bg-neutral-800"}`, children: [_jsxs("span", { className: `${flex.row} gap-2`, children: [_jsx("span", { children: cat.icon }), cat.label] }), _jsx(ChevronRight, { className: "w-3.5 h-3.5 opacity-50" })] }, cat.slug)))] })] })), _jsxs("div", { className: "flex-1 min-w-0", "data-section": "faqpageview-div-97", children: [visibleItems.length === 0 ? (_jsxs(Section, { className: `text-center py-16 rounded-2xl border ${themed.border} ${themed.bgSecondary}`, children: [_jsx(HelpCircle, { className: "w-10 h-10 mx-auto mb-3 text-neutral-300 dark:text-neutral-600" }), _jsx(Heading, { level: 3, className: "mb-2 text-base", children: t("emptyTitle") }), _jsx(Text, { variant: "secondary", className: "text-sm", children: t("emptyText") })] })) : (_jsx(Stack, { gap: "sm", className: "space-y-3", children: visibleItems.map((item, i) => (_jsxs("details", { className: `group rounded-xl border ${themed.border} ${themed.bgPrimary} overflow-hidden`, children: [_jsxs("summary", { className: `flex items-center justify-between px-5 py-4 cursor-pointer list-none select-none font-medium text-sm hover:bg-neutral-50 dark:hover:bg-neutral-800/50 transition-colors`, children: [_jsx("span", { children: item.question }), _jsx(ChevronRight, { className: "w-4 h-4 flex-shrink-0 ml-3 transition-transform group-open:rotate-90" })] }), _jsx("div", { className: "px-5 pb-5 pt-1", "data-section": "faqpageview-div-98", children: _jsx(Text, { variant: "secondary", className: "text-sm leading-relaxed whitespace-pre-line", children: item.answer }) })] }, i))) })), _jsxs(Section, { className: `mt-10 rounded-2xl p-6 text-center border ${themed.border} ${themed.bgSecondary}`, children: [_jsx(Heading, { level: 3, className: "mb-2 text-base", children: t("stillNeedHelpTitle") }), _jsx(Text, { variant: "secondary", className: "text-sm mb-4", children: t("stillNeedHelpText") }), _jsxs("div", { className: `${flex.center} gap-4 flex-wrap`, "data-section": "faqpageview-div-99", children: [_jsx(TextLink, { href: String(ROUTES.PUBLIC.HELP), children: t("helpCenter") }), _jsx(TextLink, { href: String(ROUTES.PUBLIC.CONTACT), variant: "muted", children: t("contactUs") })] })] })] })] }) })] }));
|
|
29
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { ROUTES } from "../../../constants";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { Heading, Text, Section, Caption } from "../../../ui";
|
|
5
|
+
const DEFAULT_HERO_CLASS = "bg-gradient-to-br from-violet-700 to-indigo-700 dark:from-violet-800 dark:to-indigo-800";
|
|
6
|
+
export async function FeesView({ heroBannerClass = DEFAULT_HERO_CLASS, } = {}) {
|
|
7
|
+
const { themed, page } = THEME_CONSTANTS;
|
|
8
|
+
const { getTranslations } = await import("next-intl/server");
|
|
9
|
+
const t = await getTranslations("fees");
|
|
10
|
+
const FEE_ROWS = [
|
|
11
|
+
{
|
|
12
|
+
category: t("platformFeeTitle"),
|
|
13
|
+
rate: t("platformFeeRate"),
|
|
14
|
+
who: t("paidBySeller"),
|
|
15
|
+
note: t("platformFeeNote"),
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
category: t("gatewayFeeTitle"),
|
|
19
|
+
rate: t("gatewayFeeRate"),
|
|
20
|
+
who: t("paidBySeller"),
|
|
21
|
+
note: t("gatewayFeeNote"),
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
category: t("gstTitle"),
|
|
25
|
+
rate: t("gstRate"),
|
|
26
|
+
who: t("paidBySeller"),
|
|
27
|
+
note: t("gstNote"),
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
category: t("buyerFeeTitle"),
|
|
31
|
+
rate: t("buyerFeeRate"),
|
|
32
|
+
who: t("paidByBuyer"),
|
|
33
|
+
note: t("buyerFeeNote"),
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
category: t("offerFeeTitle"),
|
|
37
|
+
rate: t("offerFeeRate"),
|
|
38
|
+
who: t("paidByBuyer"),
|
|
39
|
+
note: t("offerFeeNote"),
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
category: t("shippingFeeTitle"),
|
|
43
|
+
rate: t("shippingFeeRate"),
|
|
44
|
+
who: t("paidByBuyer"),
|
|
45
|
+
note: t("shippingFeeNote"),
|
|
46
|
+
},
|
|
47
|
+
];
|
|
48
|
+
const OFFER_PAYOUT_ROWS = [
|
|
49
|
+
{ label: t("grossSale"), example: "₹1,000" },
|
|
50
|
+
{ label: `${t("platformFeeTitle")} (5%)`, example: "− ₹50" },
|
|
51
|
+
{ label: `${t("gatewayFeeTitle")} (2.36%)`, example: "− ₹23.60" },
|
|
52
|
+
{ label: `${t("gstTitle")} on platform fee (18%)`, example: "− ₹9" },
|
|
53
|
+
{ label: t("netPayoutLabel"), example: "= ₹917.40", highlight: true },
|
|
54
|
+
];
|
|
55
|
+
void ROUTES; // ROUTES imported for future CTA links if needed
|
|
56
|
+
return (_jsxs("div", { className: "-mx-4 md:-mx-6 lg:-mx-8 -mt-6 sm:-mt-8 lg:-mt-10", "data-section": "feesview-div-100", children: [_jsx(Section, { className: `${heroBannerClass} text-white py-14 md:py-16 lg:py-20`, children: _jsxs("div", { className: `${page.container.sm} text-center`, "data-section": "feesview-div-101", children: [_jsx(Heading, { level: 1, variant: "none", className: "mb-4 text-white", children: t("title") }), _jsx(Text, { variant: "none", className: "text-white/80 max-w-2xl mx-auto", children: t("subtitle") })] }) }), _jsxs("div", { className: `${page.container.sm} py-10 md:py-12 lg:py-16 space-y-12`, "data-section": "feesview-div-102", children: [_jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "mb-6", children: t("tableTitle") }), _jsx("div", { className: `overflow-x-auto rounded-xl border ${themed.border}`, "data-section": "feesview-div-103", children: _jsxs("table", { className: "w-full text-sm", children: [_jsx("thead", { className: themed.bgSecondary, children: _jsxs("tr", { children: [_jsx("th", { className: "py-3 px-4 text-left font-semibold", children: t("colFeeType") }), _jsx("th", { className: "py-3 px-4 text-left font-semibold", children: t("colRate") }), _jsx("th", { className: "py-3 px-4 text-left font-semibold", children: t("colPaidBy") }), _jsx("th", { className: "py-3 px-4 text-left font-semibold hidden md:table-cell", children: t("colNote") })] }) }), _jsx("tbody", { className: "divide-y divide-neutral-100 dark:divide-neutral-800", children: FEE_ROWS.map((row) => (_jsxs("tr", { className: `${themed.bgPrimary} hover:bg-neutral-50 dark:hover:bg-neutral-800/50`, children: [_jsx("td", { className: "py-3 px-4 font-medium", children: row.category }), _jsx("td", { className: "py-3 px-4 font-semibold text-violet-700 dark:text-violet-400", children: row.rate }), _jsx("td", { className: "py-3 px-4", children: _jsx(Caption, { children: row.who }) }), _jsx("td", { className: "py-3 px-4 text-neutral-500 dark:text-neutral-400 hidden md:table-cell text-xs", children: row.note })] }, row.category))) })] }) }), _jsx(Caption, { className: "mt-3 block text-neutral-500", children: t("tableNote") })] }), _jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "mb-3", children: t("payoutExampleTitle") }), _jsx(Text, { variant: "secondary", className: "mb-6", children: t("payoutExampleSubtitle") }), _jsxs("div", { className: `rounded-xl border ${themed.border} ${themed.bgPrimary} p-5 max-w-sm`, "data-section": "feesview-div-104", children: [_jsx(Heading, { level: 3, className: "text-base mb-4", children: t("payoutExampleProduct") }), _jsx("div", { className: "space-y-2", "data-section": "feesview-div-105", children: OFFER_PAYOUT_ROWS.map((row, i) => (_jsxs("div", { className: `flex justify-between text-sm ${row.highlight
|
|
57
|
+
? "border-t border-neutral-200 dark:border-neutral-700 pt-2 mt-2 font-bold"
|
|
58
|
+
: ""}`, "data-section": "feesview-div-106", children: [_jsx(Text, { className: row.highlight
|
|
59
|
+
? "font-bold"
|
|
60
|
+
: "text-neutral-600 dark:text-neutral-400", children: row.label }), _jsx(Text, { className: row.highlight
|
|
61
|
+
? "font-bold text-green-700 dark:text-green-400"
|
|
62
|
+
: "", children: row.example })] }, i))) })] })] }), _jsxs(Section, { className: `rounded-xl border ${themed.border} p-5 ${themed.bgSecondary}`, children: [_jsx(Heading, { level: 3, className: "text-base mb-2", children: t("disclaimerTitle") }), _jsx(Caption, { className: "leading-relaxed", children: t("disclaimerText") })] })] })] }));
|
|
63
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { ROUTES } from "../../../constants";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { Heading, Text, Section, Stack } from "../../../ui";
|
|
5
|
+
import { TextLink } from "../../../ui";
|
|
6
|
+
import { BookOpen, MessageCircle, ShoppingBag, Truck, CreditCard, Store, ShieldCheck, ChevronRight, } from "lucide-react";
|
|
7
|
+
const DEFAULT_HERO_CLASS = "bg-gradient-to-br from-violet-700 to-indigo-700 dark:from-violet-800 dark:to-indigo-800";
|
|
8
|
+
export async function HelpPageView({ heroBannerClass = DEFAULT_HERO_CLASS, } = {}) {
|
|
9
|
+
const { themed, flex, page } = THEME_CONSTANTS;
|
|
10
|
+
const { getTranslations } = await import("next-intl/server");
|
|
11
|
+
const t = await getTranslations("helpPage");
|
|
12
|
+
const TOPICS = [
|
|
13
|
+
{
|
|
14
|
+
icon: ShoppingBag,
|
|
15
|
+
title: t("topicBuying"),
|
|
16
|
+
desc: t("topicBuyingDesc"),
|
|
17
|
+
href: String(ROUTES.PUBLIC.HOW_ORDERS_WORK),
|
|
18
|
+
color: "bg-primary/5 border-primary/20 dark:bg-primary/10 dark:border-primary/30",
|
|
19
|
+
iconColor: "text-primary",
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
icon: Truck,
|
|
23
|
+
title: t("topicShipping"),
|
|
24
|
+
desc: t("topicShippingDesc"),
|
|
25
|
+
href: String(ROUTES.PUBLIC.SHIPPING_POLICY),
|
|
26
|
+
color: "bg-sky-50 border-sky-200 dark:bg-sky-900/20 dark:border-sky-700",
|
|
27
|
+
iconColor: "text-sky-600 dark:text-sky-400",
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
icon: CreditCard,
|
|
31
|
+
title: t("topicPayment"),
|
|
32
|
+
desc: t("topicPaymentDesc"),
|
|
33
|
+
href: String(ROUTES.PUBLIC.HOW_CHECKOUT_WORKS),
|
|
34
|
+
color: "bg-emerald-50 border-emerald-200 dark:bg-emerald-900/20 dark:border-emerald-700",
|
|
35
|
+
iconColor: "text-emerald-600 dark:text-emerald-400",
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
icon: Store,
|
|
39
|
+
title: t("topicSelling"),
|
|
40
|
+
desc: t("topicSellingDesc"),
|
|
41
|
+
href: String(ROUTES.PUBLIC.SELLER_GUIDE),
|
|
42
|
+
color: "bg-amber-50 border-amber-200 dark:bg-amber-900/20 dark:border-amber-700",
|
|
43
|
+
iconColor: "text-amber-600 dark:text-amber-400",
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
icon: BookOpen,
|
|
47
|
+
title: t("topicFAQs"),
|
|
48
|
+
desc: t("topicFAQsDesc"),
|
|
49
|
+
href: String(ROUTES.PUBLIC.FAQS),
|
|
50
|
+
color: "bg-violet-50 border-violet-200 dark:bg-violet-900/20 dark:border-violet-700",
|
|
51
|
+
iconColor: "text-violet-600 dark:text-violet-400",
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
icon: ShieldCheck,
|
|
55
|
+
title: t("topicSecurity"),
|
|
56
|
+
desc: t("topicSecurityDesc"),
|
|
57
|
+
href: String(ROUTES.PUBLIC.SECURITY),
|
|
58
|
+
color: "bg-rose-50 border-rose-200 dark:bg-rose-900/20 dark:border-rose-700",
|
|
59
|
+
iconColor: "text-rose-600 dark:text-rose-400",
|
|
60
|
+
},
|
|
61
|
+
];
|
|
62
|
+
return (_jsxs("div", { className: "-mx-4 md:-mx-6 lg:-mx-8 -mt-6 sm:-mt-8 lg:-mt-10", "data-section": "helppageview-div-107", children: [_jsx(Section, { className: `${heroBannerClass} text-white py-14 md:py-16 lg:py-20`, children: _jsxs("div", { className: `${page.container.md} text-center`, "data-section": "helppageview-div-108", children: [_jsx(Heading, { level: 1, variant: "none", className: "mb-4 text-white", children: t("title") }), _jsx(Text, { variant: "none", className: "text-white/80 max-w-2xl mx-auto", children: t("subtitle") })] }) }), _jsxs("div", { className: `${page.container.md} py-10 md:py-12 lg:py-16 space-y-14`, "data-section": "helppageview-div-109", children: [_jsxs(Section, { children: [_jsx(Heading, { level: 2, className: "mb-6 text-center", children: t("browseTopics") }), _jsx("div", { className: "grid gap-4 sm:grid-cols-2 lg:grid-cols-3", "data-section": "helppageview-div-110", children: TOPICS.map(({ icon: Icon, title, desc, href, color, iconColor }) => (_jsxs(TextLink, { href: href, className: `group rounded-xl border p-5 transition-shadow hover:shadow-md ${color} no-underline`, children: [_jsx("div", { className: `w-10 h-10 rounded-lg bg-white/60 dark:bg-white/10 ${flex.center} mb-3`, "data-section": "helppageview-div-111", children: _jsx(Icon, { className: `w-5 h-5 ${iconColor}` }) }), _jsxs("div", { className: `${flex.row} justify-between items-start`, "data-section": "helppageview-div-112", children: [_jsxs("div", { "data-section": "helppageview-div-113", children: [_jsx(Text, { className: "font-semibold mb-1", children: title }), _jsx(Text, { variant: "secondary", className: "text-sm leading-relaxed", children: desc })] }), _jsx(ChevronRight, { className: "w-4 h-4 mt-1 flex-shrink-0 opacity-40 group-hover:opacity-80 transition-opacity" })] })] }, href))) })] }), _jsxs(Section, { className: `rounded-2xl p-6 border ${themed.border} ${themed.bgSecondary} flex flex-col sm:flex-row items-center gap-4`, children: [_jsxs("div", { className: "flex-1", "data-section": "helppageview-div-114", children: [_jsx(Heading, { level: 3, className: "mb-1 text-base", children: t("trackOrderTitle") }), _jsx(Text, { variant: "secondary", className: "text-sm", children: t("trackOrderText") })] }), _jsx(TextLink, { href: String(ROUTES.PUBLIC.TRACK_ORDER), className: "flex-shrink-0", children: t("trackOrderCta") })] }), _jsxs(Section, { className: `rounded-2xl p-8 text-center border ${themed.border} ${themed.bgSecondary}`, children: [_jsx(MessageCircle, { className: "w-10 h-10 mx-auto mb-3 text-primary/70" }), _jsx(Heading, { level: 2, className: "mb-3", children: t("contactTitle") }), _jsx(Text, { variant: "secondary", className: "mb-6 max-w-lg mx-auto", children: t("contactText") }), _jsxs(Stack, { gap: "sm", className: "flex-row flex-wrap justify-center gap-4", children: [_jsx(TextLink, { href: String(ROUTES.PUBLIC.CONTACT), children: t("contactCta") }), _jsx(TextLink, { href: String(ROUTES.PUBLIC.FAQS), variant: "muted", children: t("faqCta") })] })] })] })] }));
|
|
63
|
+
}
|