@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
|
@@ -12,7 +12,7 @@ import { NextResponse } from "next/server.js";
|
|
|
12
12
|
import { z } from "zod";
|
|
13
13
|
import { getProviders } from "../../../../../contracts";
|
|
14
14
|
import { createRouteHandler } from "../../../../../next";
|
|
15
|
-
//
|
|
15
|
+
// ---- GET /api/carousel/[id] --------------------------------------------------
|
|
16
16
|
export async function GET(_request, context) {
|
|
17
17
|
try {
|
|
18
18
|
const { id } = await context.params;
|
|
@@ -33,7 +33,7 @@ export async function GET(_request, context) {
|
|
|
33
33
|
}
|
|
34
34
|
}
|
|
35
35
|
export { GET as carouselItemGET };
|
|
36
|
-
//
|
|
36
|
+
// ---- PATCH /api/carousel/[id] -------------------------------------------------
|
|
37
37
|
const carouselSlideUpdateSchema = z
|
|
38
38
|
.object({
|
|
39
39
|
title: z.string().min(1).max(200).optional(),
|
|
@@ -101,7 +101,7 @@ export const carouselItemPATCH = createRouteHandler({
|
|
|
101
101
|
return NextResponse.json({ success: true, data: updated });
|
|
102
102
|
},
|
|
103
103
|
});
|
|
104
|
-
//
|
|
104
|
+
// ---- DELETE /api/carousel/[id] -----------------------------------------------
|
|
105
105
|
export const carouselItemDELETE = createRouteHandler({
|
|
106
106
|
auth: true,
|
|
107
107
|
roles: ["admin"],
|
|
@@ -34,7 +34,7 @@ async function getRoleFromSession(request) {
|
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
36
|
const MAX_ACTIVE_SLIDES = 5;
|
|
37
|
-
//
|
|
37
|
+
// --- GET /api/carousel --------------------------------------------------------
|
|
38
38
|
export async function GET(request) {
|
|
39
39
|
try {
|
|
40
40
|
const url = new URL(request.url);
|
|
@@ -33,7 +33,7 @@ async function getRoleFromSession(request) {
|
|
|
33
33
|
return null;
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
-
//
|
|
36
|
+
// --- GET /api/homepage-sections -----------------------------------------------
|
|
37
37
|
export async function GET(request) {
|
|
38
38
|
try {
|
|
39
39
|
const url = new URL(request.url);
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type { AdSlotId } from "../ad-registry";
|
|
3
|
+
export interface AdSlotProps {
|
|
4
|
+
/** The registered slot id to render. */
|
|
5
|
+
id: AdSlotId;
|
|
6
|
+
/**
|
|
7
|
+
* Manual ad content — rendered only when the slot's provider is `"manual"`.
|
|
8
|
+
* Pass any ReactNode: an image, a promotional banner, etc.
|
|
9
|
+
*/
|
|
10
|
+
manualContent?: React.ReactNode;
|
|
11
|
+
className?: string;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* `<AdSlot>` renders an ad based on the registered configuration for `id`.
|
|
15
|
+
*
|
|
16
|
+
* Renders nothing (zero height) when:
|
|
17
|
+
* - The slot id is not registered
|
|
18
|
+
* - `enabled: false` in config
|
|
19
|
+
* - `requiresConsent: true` and consent has not been granted
|
|
20
|
+
*
|
|
21
|
+
* When `reservedHeight` is set in the config, the container always reserves
|
|
22
|
+
* that height to prevent CLS — even before the ad loads.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* <AdSlot id="homepage-hero-banner" />
|
|
26
|
+
* <AdSlot id="listing-between-rows" manualContent={<PromoBanner />} />
|
|
27
|
+
*/
|
|
28
|
+
export declare function AdSlot({ id, manualContent, className }: AdSlotProps): import("react/jsx-runtime").JSX.Element | null;
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { useEffect, useRef, useState } from "react";
|
|
4
|
+
import { getAdSlot, isAdSlotRenderable } from "../ad-registry";
|
|
5
|
+
// ---------------------------------------------------------------------------
|
|
6
|
+
// Sub-renderers
|
|
7
|
+
// ---------------------------------------------------------------------------
|
|
8
|
+
function AdsenseAd({ config }) {
|
|
9
|
+
const ref = useRef(null);
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
if (typeof window === "undefined")
|
|
12
|
+
return;
|
|
13
|
+
try {
|
|
14
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
15
|
+
(window.adsbygoogle = window.adsbygoogle || []).push({});
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
// AdSense not loaded yet — no-op
|
|
19
|
+
}
|
|
20
|
+
}, []);
|
|
21
|
+
return (_jsx("div", { ref: ref, "data-section": "adslot-div-296", children: _jsx("ins", { className: "adsbygoogle", style: { display: "block" }, "data-ad-client": config.adsenseClient ?? "", "data-ad-slot": config.adsenseSlot ?? "", "data-ad-format": config.adsenseFormat ?? "auto", "data-full-width-responsive": "true" }) }));
|
|
22
|
+
}
|
|
23
|
+
function ThirdPartyAd({ config }) {
|
|
24
|
+
if (config.thirdPartyUrl) {
|
|
25
|
+
return (_jsx("iframe", { src: config.thirdPartyUrl, width: config.thirdPartyWidth ?? "100%", height: config.thirdPartyHeight ?? "90", scrolling: "no", frameBorder: "0", title: "Advertisement", style: { border: 0, overflow: "hidden" }, loading: "lazy" }));
|
|
26
|
+
}
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
// ---------------------------------------------------------------------------
|
|
30
|
+
// Primary component
|
|
31
|
+
// ---------------------------------------------------------------------------
|
|
32
|
+
/**
|
|
33
|
+
* `<AdSlot>` renders an ad based on the registered configuration for `id`.
|
|
34
|
+
*
|
|
35
|
+
* Renders nothing (zero height) when:
|
|
36
|
+
* - The slot id is not registered
|
|
37
|
+
* - `enabled: false` in config
|
|
38
|
+
* - `requiresConsent: true` and consent has not been granted
|
|
39
|
+
*
|
|
40
|
+
* When `reservedHeight` is set in the config, the container always reserves
|
|
41
|
+
* that height to prevent CLS — even before the ad loads.
|
|
42
|
+
*
|
|
43
|
+
* @example
|
|
44
|
+
* <AdSlot id="homepage-hero-banner" />
|
|
45
|
+
* <AdSlot id="listing-between-rows" manualContent={<PromoBanner />} />
|
|
46
|
+
*/
|
|
47
|
+
export function AdSlot({ id, manualContent, className = "" }) {
|
|
48
|
+
const [hydrated, setHydrated] = useState(false);
|
|
49
|
+
useEffect(() => {
|
|
50
|
+
setHydrated(true);
|
|
51
|
+
}, []);
|
|
52
|
+
if (!hydrated) {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
const config = getAdSlot(id);
|
|
56
|
+
const renderable = isAdSlotRenderable(id);
|
|
57
|
+
const reservedStyle = config?.reservedHeight
|
|
58
|
+
? { minHeight: config.reservedHeight }
|
|
59
|
+
: undefined;
|
|
60
|
+
if (!config || !renderable) {
|
|
61
|
+
// Preserve reserved space even when ad is not shown (avoids layout jumps
|
|
62
|
+
// when ads are re-enabled after consent grant in the same session).
|
|
63
|
+
if (config?.reservedHeight && config?.enabled !== false) {
|
|
64
|
+
return (_jsx("div", { className: className, style: reservedStyle, "aria-hidden": "true", "data-ad-slot-id": id, "data-ad-slot-state": "awaiting-consent" }));
|
|
65
|
+
}
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
const content = renderProvider(config.provider, config, manualContent);
|
|
69
|
+
return (_jsx("div", { className: className, style: reservedStyle, "data-ad-slot-id": id, "aria-label": "Advertisement", children: content }));
|
|
70
|
+
}
|
|
71
|
+
// ---------------------------------------------------------------------------
|
|
72
|
+
// Provider dispatch
|
|
73
|
+
// ---------------------------------------------------------------------------
|
|
74
|
+
function renderProvider(provider, config, manualContent) {
|
|
75
|
+
switch (provider) {
|
|
76
|
+
case "manual":
|
|
77
|
+
return manualContent ?? null;
|
|
78
|
+
case "adsense":
|
|
79
|
+
return _jsx(AdsenseAd, { config: config });
|
|
80
|
+
case "thirdParty":
|
|
81
|
+
return _jsx(ThirdPartyAd, { config: config });
|
|
82
|
+
default:
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
"use client";
|
|
2
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
3
3
|
import { Button, Heading, Row, Section, Span, Text } from "../../../ui";
|
|
4
4
|
import { MediaImage } from "../../media/MediaImage";
|
|
5
5
|
import { ArrowRight, Sparkles } from "lucide-react";
|
|
6
|
-
//
|
|
6
|
+
// --- Component ---------------------------------------------------------------
|
|
7
7
|
export function AdvertisementBanner({ title, subtitle, ctaLabel = "Shop now", onCtaClick, backgroundImage, backgroundColor, tagLabel, isLoading = false, compact = false, className = "", }) {
|
|
8
8
|
const wrapClass = "bg-gradient-to-br from-amber-50/40 to-orange-50/20 dark:from-amber-950/10 dark:to-orange-950/5";
|
|
9
9
|
if (isLoading) {
|
|
10
|
-
return (_jsx(Section, { className: `p-8 ${wrapClass} ${className}`, children: _jsx("div", { className: "w-full max-w-7xl mx-auto", children: _jsx("div", { className: "h-72 bg-zinc-200 dark:bg-slate-700 rounded-2xl animate-pulse" }) }) }));
|
|
10
|
+
return (_jsx(Section, { className: `p-8 ${wrapClass} ${className}`, children: _jsx("div", { className: "w-full max-w-7xl mx-auto", "data-section": "advertisementbanner-div-297", children: _jsx("div", { className: "h-72 bg-zinc-200 dark:bg-slate-700 rounded-2xl animate-pulse" }) }) }));
|
|
11
11
|
}
|
|
12
|
-
//
|
|
12
|
+
// -- Split layout: when a backgroundImage is provided --
|
|
13
13
|
if (backgroundImage) {
|
|
14
|
-
return (_jsx(Section, { className: `p-8 ${wrapClass} ${className}`, children: _jsx("div", { className: "w-full max-w-7xl mx-auto", children: _jsx("div", { className: "relative overflow-hidden rounded-2xl bg-zinc-900 shadow-xl", children: _jsxs("div", { className:
|
|
14
|
+
return (_jsx(Section, { className: `p-8 ${wrapClass} ${className}`, children: _jsx("div", { className: "w-full max-w-7xl mx-auto", "data-section": "advertisementbanner-div-298", children: _jsx("div", { className: "relative overflow-hidden rounded-2xl bg-zinc-900 shadow-xl", "data-section": "advertisementbanner-div-299", children: _jsxs("div", { className: `${THEME_CONSTANTS.grid.cols2Md} min-h-[clamp(300px,40vh,420px)]`, "data-section": "advertisementbanner-div-300", children: [_jsxs("div", { className: `relative ${THEME_CONSTANTS.card.aspectBanner} order-last md:order-first min-h-0 min-h-[clamp(300px,40vh,420px)]`, "data-section": "advertisementbanner-div-301", children: [_jsx(MediaImage, { src: backgroundImage, alt: title, size: "banner", priority: true }), _jsx("div", { className: "hidden md:block absolute inset-y-0 right-0 w-24 bg-gradient-to-r from-transparent to-zinc-900/60 pointer-events-none" })] }), _jsxs("div", { className: "relative flex flex-col justify-center px-8 py-10 md:px-12 md:py-14", "data-section": "advertisementbanner-div-302", children: [_jsx("div", { className: "absolute top-0 right-0 w-32 h-32 opacity-10 pointer-events-none bg-[radial-gradient(circle,_white_1px,_transparent_1px)] bg-[length:12px_12px]", "aria-hidden": true }), tagLabel && (_jsxs("div", { className: "inline-flex items-center gap-1.5 self-start bg-white/10 text-white/80 text-xs font-semibold uppercase tracking-widest px-3 py-1 rounded-full mb-5 backdrop-blur-sm", "data-section": "advertisementbanner-div-303", children: [_jsx(Sparkles, { className: "w-3.5 h-3.5" }), tagLabel] })), _jsx(Heading, { level: 2, variant: "none", className: "text-3xl md:text-4xl lg:text-5xl font-extrabold text-white mb-4 leading-tight", children: title }), subtitle && (_jsx(Text, { variant: "none", className: "text-white/75 text-base md:text-lg mb-8 leading-relaxed", children: subtitle })), ctaLabel && onCtaClick && (_jsxs(Button, { variant: "secondary", size: "lg", onClick: onCtaClick, className: "self-start bg-white text-zinc-900 hover:bg-zinc-100 font-semibold shadow-lg gap-2", children: [ctaLabel, _jsx(ArrowRight, { className: "w-4 h-4" })] }))] })] }) }) }) }));
|
|
15
15
|
}
|
|
16
|
-
//
|
|
17
|
-
return (_jsx(Section, { className: `p-8 ${wrapClass} ${className}`, children: _jsx("div", { className: "w-full max-w-7xl mx-auto", children: _jsxs("div", { className: [
|
|
16
|
+
// -- Full-width gradient layout --
|
|
17
|
+
return (_jsx(Section, { className: `p-8 ${wrapClass} ${className}`, children: _jsx("div", { className: "w-full max-w-7xl mx-auto", "data-section": "advertisementbanner-div-304", children: _jsxs("div", { className: [
|
|
18
18
|
"relative overflow-hidden rounded-2xl flex items-center",
|
|
19
19
|
compact
|
|
20
20
|
? "h-[clamp(112px,16vh,160px)]"
|
|
21
21
|
: "min-h-[clamp(240px,34vh,360px)]",
|
|
22
|
-
].join(" "), style: backgroundColor ? { backgroundColor } : undefined, children: [!backgroundColor && (_jsx("div", { className: "absolute inset-0 bg-gradient-to-br from-indigo-600 via-purple-600 to-fuchsia-600", "aria-hidden": true })), _jsxs("div", { className: "absolute inset-0 overflow-hidden", "aria-hidden": true, children: [_jsx("div", { className: "absolute -top-16 -left-16 w-64 h-64 rounded-full bg-primary/20 blur-3xl animate-pulse" }), _jsx("div", { className: "absolute -bottom-16 right-0 w-80 h-80 rounded-full bg-cobalt/20 blur-3xl animate-pulse" })] }), compact ? (_jsxs(Row, { justify: "between", className: "relative z-10 w-full px-6 py-4 gap-4 flex-wrap", children: [_jsxs("div", { className: "inline-flex items-center gap-2", children: [_jsx(Sparkles, { className: "w-4 h-4 text-white/80" }), _jsx(Span, { className: "text-white font-semibold text-sm", children: title })] }), ctaLabel && onCtaClick && (_jsxs(Button, { variant: "secondary", size: "sm", onClick: onCtaClick, className: "bg-white text-indigo-700 hover:bg-zinc-50 font-semibold gap-1.5 flex-shrink-0", children: [ctaLabel, _jsx(ArrowRight, { className: "w-3.5 h-3.5" })] }))] })) : (_jsxs("div", { className: "relative z-10 w-full max-w-4xl mx-auto px-6 py-12 md:py-16 text-center", children: [tagLabel && (_jsxs("div", { className: "inline-flex items-center gap-1.5 bg-white/15 text-white/90 text-xs font-semibold uppercase tracking-widest px-4 py-1.5 rounded-full mb-5 backdrop-blur-sm shadow-sm", children: [_jsx(Sparkles, { className: "w-3.5 h-3.5" }), tagLabel] })), _jsx(Heading, { level: 2, variant: "none", className: "text-3xl md:text-5xl lg:text-6xl font-extrabold text-white mb-4 drop-shadow-lg leading-tight", children: title }), subtitle && (_jsx(Text, { variant: "none", className: "text-white text-base md:text-xl mb-10 max-w-2xl mx-auto", children: subtitle })), ctaLabel && onCtaClick && (_jsxs(Button, { variant: "secondary", size: "lg", onClick: onCtaClick, className: "bg-white text-indigo-700 hover:bg-zinc-50 font-semibold shadow-lg gap-2", children: [ctaLabel, _jsx(ArrowRight, { className: "w-4 h-4" })] }))] }))] }) }) }));
|
|
22
|
+
].join(" "), style: backgroundColor ? { backgroundColor } : undefined, "data-section": "advertisementbanner-div-305", children: [!backgroundColor && (_jsx("div", { className: "absolute inset-0 bg-gradient-to-br from-indigo-600 via-purple-600 to-fuchsia-600", "aria-hidden": true })), _jsxs("div", { className: "absolute inset-0 overflow-hidden", "aria-hidden": true, "data-section": "advertisementbanner-div-306", children: [_jsx("div", { className: "absolute -top-16 -left-16 w-64 h-64 rounded-full bg-primary/20 blur-3xl animate-pulse" }), _jsx("div", { className: "absolute -bottom-16 right-0 w-80 h-80 rounded-full bg-cobalt/20 blur-3xl animate-pulse" })] }), compact ? (_jsxs(Row, { justify: "between", className: "relative z-10 w-full px-6 py-4 gap-4 flex-wrap", children: [_jsxs("div", { className: "inline-flex items-center gap-2", "data-section": "advertisementbanner-div-307", children: [_jsx(Sparkles, { className: "w-4 h-4 text-white/80" }), _jsx(Span, { className: "text-white font-semibold text-sm", children: title })] }), ctaLabel && onCtaClick && (_jsxs(Button, { variant: "secondary", size: "sm", onClick: onCtaClick, className: "bg-white text-indigo-700 hover:bg-zinc-50 font-semibold gap-1.5 flex-shrink-0", children: [ctaLabel, _jsx(ArrowRight, { className: "w-3.5 h-3.5" })] }))] })) : (_jsxs("div", { className: "relative z-10 w-full max-w-4xl mx-auto px-6 py-12 md:py-16 text-center", "data-section": "advertisementbanner-div-308", children: [tagLabel && (_jsxs("div", { className: "inline-flex items-center gap-1.5 bg-white/15 text-white/90 text-xs font-semibold uppercase tracking-widest px-4 py-1.5 rounded-full mb-5 backdrop-blur-sm shadow-sm", "data-section": "advertisementbanner-div-309", children: [_jsx(Sparkles, { className: "w-3.5 h-3.5" }), tagLabel] })), _jsx(Heading, { level: 2, variant: "none", className: "text-3xl md:text-5xl lg:text-6xl font-extrabold text-white mb-4 drop-shadow-lg leading-tight", children: title }), subtitle && (_jsx(Text, { variant: "none", className: "text-white text-base md:text-xl mb-10 max-w-2xl mx-auto", children: subtitle })), ctaLabel && onCtaClick && (_jsxs(Button, { variant: "secondary", size: "lg", onClick: onCtaClick, className: "bg-white text-indigo-700 hover:bg-zinc-50 font-semibold shadow-lg gap-2", children: [ctaLabel, _jsx(ArrowRight, { className: "w-4 h-4" })] }))] }))] }) }) }));
|
|
23
23
|
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useState } from "react";
|
|
4
|
+
import { X } from "lucide-react";
|
|
5
|
+
export function AnnouncementBar({ message, className = "" }) {
|
|
6
|
+
const [dismissed, setDismissed] = useState(false);
|
|
7
|
+
if (dismissed)
|
|
8
|
+
return null;
|
|
9
|
+
return (_jsx("div", { className: `relative left-1/2 right-1/2 w-screen -translate-x-1/2 bg-primary-700 ${className}`, role: "banner", "data-section": "announcementbar-div-310", children: _jsx("div", { className: "container mx-auto max-w-[1920px] px-4 sm:px-6 lg:px-8", "data-section": "announcementbar-div-311", children: _jsxs("div", { className: "relative flex items-center justify-center py-2 text-center text-sm font-medium text-white", "data-section": "announcementbar-div-312", children: [_jsx("span", { children: message }), _jsx("button", { type: "button", onClick: () => setDismissed(true), className: "absolute right-0 top-1/2 -translate-y-1/2 rounded p-0.5 hover:bg-white/20 focus:outline-none focus:ring-2 focus:ring-white", "aria-label": "Dismiss announcement", children: _jsx(X, { className: "h-4 w-4" }) })] }) }) }));
|
|
10
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface BlogArticlesSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
description?: string;
|
|
4
|
+
viewMoreHref?: string;
|
|
5
|
+
viewMoreLabel?: string;
|
|
6
|
+
className?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function BlogArticlesSection({ title, description, viewMoreHref, viewMoreLabel, className, }: BlogArticlesSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { SectionCarousel } from "./SectionCarousel";
|
|
5
|
+
import { useBlogArticles } from "../hooks/useBlogArticles";
|
|
6
|
+
import { BlogFeaturedCard } from "../../blog/components/BlogFeaturedCard";
|
|
7
|
+
import { ROUTES } from "../../../next";
|
|
8
|
+
export function BlogArticlesSection({ title = "From Our Blog", description, viewMoreHref, viewMoreLabel = "View all posts →", className = "", }) {
|
|
9
|
+
const { data, isLoading } = useBlogArticles();
|
|
10
|
+
const items = data?.posts ?? [];
|
|
11
|
+
return (_jsx(SectionCarousel, { title: title, description: description, viewMoreHref: viewMoreHref, viewMoreLabel: viewMoreLabel, items: items, isLoading: isLoading, skeletonCount: 4, perView: THEME_CONSTANTS.carousel.perView.cards, gap: 16, keyExtractor: (post) => post.id, renderItem: (post) => (_jsx(BlogFeaturedCard, { post: post, href: ROUTES.BLOG.ARTICLE(post.slug) })), className: className }));
|
|
12
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export interface BrandsSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
subtitle?: string;
|
|
4
|
+
limit?: number;
|
|
5
|
+
viewMoreHref?: string;
|
|
6
|
+
viewMoreLabel?: string;
|
|
7
|
+
className?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function BrandsSection({ title, subtitle, limit, viewMoreHref, viewMoreLabel, className, }: BrandsSectionProps): import("react/jsx-runtime").JSX.Element | null;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import Link from "next/link";
|
|
4
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
5
|
+
import { Heading, HorizontalScroller, Section, Text } from "../../../ui";
|
|
6
|
+
import { ROUTES } from "../../../next";
|
|
7
|
+
import { useTopBrands } from "../hooks/useTopBrands";
|
|
8
|
+
function BrandLogo({ brand }) {
|
|
9
|
+
const iconSrc = brand.display?.icon;
|
|
10
|
+
const coverImage = brand.display?.coverImage;
|
|
11
|
+
const initial = brand.name[0]?.toUpperCase() ?? "?";
|
|
12
|
+
return (_jsxs(Link, { href: ROUTES.PUBLIC.CATEGORY_DETAIL(brand.slug), className: "flex h-24 w-28 flex-col items-center justify-center gap-2 rounded-xl border border-zinc-200 bg-white p-3 shadow-sm transition-all hover:border-primary-300 hover:shadow-md dark:border-slate-700 dark:bg-slate-900", children: [iconSrc || coverImage ? (_jsx("img", { src: iconSrc ?? coverImage, alt: brand.name, className: "h-10 w-10 rounded object-contain" })) : (_jsx("div", { className: "flex h-10 w-10 items-center justify-center rounded-lg bg-primary-100 text-sm font-bold text-primary-700 dark:bg-primary-900 dark:text-primary-300", children: initial })), _jsx(Text, { className: "w-full truncate text-center text-xs font-medium text-zinc-700 dark:text-zinc-300", children: brand.name })] }));
|
|
13
|
+
}
|
|
14
|
+
export function BrandsSection({ title = "Top Brands", subtitle, limit = 12, viewMoreHref, viewMoreLabel = "All brands →", className = "", }) {
|
|
15
|
+
const { themed } = THEME_CONSTANTS;
|
|
16
|
+
const { data: brands = [], isLoading } = useTopBrands(limit);
|
|
17
|
+
if (!isLoading && brands.length === 0)
|
|
18
|
+
return null;
|
|
19
|
+
return (_jsx(Section, { className: `py-12 px-4 ${themed.bgSecondary} ${className}`, children: _jsxs("div", { className: "mx-auto max-w-7xl", children: [_jsxs("div", { className: "mb-6 flex items-center justify-between", children: [_jsxs("div", { children: [_jsx(Heading, { level: 2, className: `text-2xl font-bold md:text-3xl ${themed.textPrimary}`, children: title }), subtitle && (_jsx(Text, { variant: "secondary", className: "mt-1 text-sm", children: subtitle }))] }), viewMoreHref && (_jsx(Link, { href: viewMoreHref, className: "text-sm font-medium text-primary hover:underline", children: viewMoreLabel }))] }), isLoading ? (_jsx("div", { className: "flex gap-3 overflow-hidden", children: Array.from({ length: 8 }).map((_, i) => (_jsx("div", { className: "h-24 w-28 flex-none animate-pulse rounded-xl bg-zinc-200 dark:bg-slate-700" }, i))) })) : (_jsx(HorizontalScroller, { items: brands, renderItem: (brand) => _jsx(BrandLogo, { brand: brand }), keyExtractor: (brand) => brand.id, gap: 12, showArrows: true, showScrollbar: false }))] }) }));
|
|
20
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export interface CTABannerSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
subtitle?: string;
|
|
4
|
+
primaryLabel?: string;
|
|
5
|
+
primaryHref?: string;
|
|
6
|
+
secondaryLabel?: string;
|
|
7
|
+
secondaryHref?: string;
|
|
8
|
+
className?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare function CTABannerSection({ title, subtitle, primaryLabel, primaryHref, secondaryLabel, secondaryHref, className, }: CTABannerSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import Link from "next/link";
|
|
3
|
+
import { Section } from "../../../ui";
|
|
4
|
+
export function CTABannerSection({ title = "Thousands of collectibles. One marketplace.", subtitle, primaryLabel = "Shop All Products →", primaryHref = "/products", secondaryLabel = "Browse Auctions →", secondaryHref = "/auctions", className = "", }) {
|
|
5
|
+
return (_jsx(Section, { className: `bg-gradient-to-r from-primary-600 to-primary-700 py-16 px-4 ${className}`, children: _jsxs("div", { className: "mx-auto max-w-3xl text-center", "data-section": "ctabannersection-div-313", children: [_jsx("span", { className: "mb-4 inline-block text-2xl", "aria-hidden": "true", children: "\u2728" }), _jsx("h2", { className: "text-2xl font-bold text-white md:text-3xl lg:text-4xl", children: title }), subtitle && (_jsx("p", { className: "mt-3 text-base text-white/80", children: subtitle })), _jsxs("div", { className: "mt-8 flex flex-wrap items-center justify-center gap-4", "data-section": "ctabannersection-div-314", children: [_jsx(Link, { href: primaryHref, className: "inline-flex items-center rounded-full bg-white px-8 py-3 text-sm font-semibold text-primary-700 shadow-sm transition-all hover:bg-zinc-50 hover:shadow-md focus:outline-none focus:ring-2 focus:ring-white focus:ring-offset-2 focus:ring-offset-primary-600", children: primaryLabel }), secondaryHref && (_jsx(Link, { href: secondaryHref, className: "inline-flex items-center rounded-full border-2 border-white/80 px-8 py-3 text-sm font-semibold text-white transition-all hover:bg-white/10 focus:outline-none focus:ring-2 focus:ring-white focus:ring-offset-2 focus:ring-offset-primary-600", children: secondaryLabel }))] })] }) }));
|
|
6
|
+
}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import "client-only";
|
|
4
3
|
import { useState, useCallback, useEffect, useRef } from "react";
|
|
5
4
|
import Image from "next/image";
|
|
6
5
|
import Link from "next/link";
|
|
6
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
7
7
|
import { useMediaQuery } from "../../../react";
|
|
8
8
|
import { Button, Div, Heading, Row, Section, Span, Text } from "../../../ui";
|
|
9
|
-
/*
|
|
9
|
+
/* -- Fallback when no Firestore config is saved yet --------------------------
|
|
10
10
|
Consumers can override the full config via the `config` prop.
|
|
11
|
-
|
|
11
|
+
----------------------------------------------------------------- */
|
|
12
12
|
const FALLBACK_IMAGE = "/animevssuperhero.jpg";
|
|
13
13
|
const FALLBACK_IMAGE_ALT = "DC, Marvel and Anime characters";
|
|
14
14
|
const DEFAULT_HOTSPOTS = [
|
|
@@ -352,7 +352,7 @@ function CharacterHotspotInner({ panoramicImage, panoramicAlt, hotspots, univers
|
|
|
352
352
|
background: active.accent,
|
|
353
353
|
color: active.accent === "#FFE500" ? "#0D0D0D" : "#FFFFFF",
|
|
354
354
|
borderRadius: 4,
|
|
355
|
-
}, children: [active.buyText, _jsx(Span, { "aria-hidden": "true", children: "\u2192" })] }), _jsx(Button, { type: "button", variant: "outline", onClick: () => setActiveId(null), className: "px-5 py-3 text-sm font-bold rounded", style: { background: "#F1F5F9", color: "#475569" }, children: "Close" })] })] })] }) })), _jsx(Div, { className:
|
|
355
|
+
}, children: [active.buyText, _jsx(Span, { "aria-hidden": "true", children: "\u2192" })] }), _jsx(Button, { type: "button", variant: "outline", onClick: () => setActiveId(null), className: "px-5 py-3 text-sm font-bold rounded", style: { background: "#F1F5F9", color: "#475569" }, children: "Close" })] })] })] }) })), _jsx(Div, { className: `mx-auto max-w-7xl px-4 py-6 ${THEME_CONSTANTS.grid.cols6Lg} gap-3`, style: { borderTop: "1px solid rgba(255,255,255,0.08)" }, children: universeLinks.map(({ label, href, color, icon }) => (_jsxs(Link, { href: href, className: "group flex items-center gap-2.5 px-3 py-2.5 rounded-sm transition-all hover:-translate-y-0.5", style: {
|
|
356
356
|
background: "rgba(255,255,255,0.04)",
|
|
357
357
|
border: "1px solid rgba(255,255,255,0.08)",
|
|
358
358
|
transition: "all 0.15s ease",
|
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
"use client";
|
|
2
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
2
|
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
3
|
import { Heading, HorizontalScroller, Section, Text, TextLink, } from "../../../ui";
|
|
5
|
-
//
|
|
4
|
+
// --- Section -----------------------------------------------------------------
|
|
6
5
|
export function CustomerReviewsSection({ title, subtitle, items, renderItem, viewMoreHref, viewMoreLabel = "See all reviews", isLoading = false, keyExtractor, className = "", }) {
|
|
7
6
|
const { themed, skeleton } = THEME_CONSTANTS;
|
|
8
7
|
if (isLoading) {
|
|
9
|
-
return (_jsx(Section, { className: `p-8 ${themed.bgPrimary} ${className}`, children: _jsxs("div", { className: "w-full max-w-7xl mx-auto", children: [_jsx("div", { className: `h-8 ${skeleton.base} mb-8 max-w-xs mx-auto` }), _jsx("div", { className: "flex gap-6 overflow-hidden", children: [...Array(3)].map((_, i) => (_jsx("div", { className: `${skeleton.card} h-[clamp(180px,26vh,260px)] min-w-[clamp(150px,18vw,260px)] max-w-[clamp(240px,36vw,380px)] flex-none` }, i))) })] }) }));
|
|
8
|
+
return (_jsx(Section, { className: `p-8 ${themed.bgPrimary} ${className}`, children: _jsxs("div", { className: "w-full max-w-7xl mx-auto", "data-section": "customerreviewssection-div-315", children: [_jsx("div", { className: `h-8 ${skeleton.base} mb-8 max-w-xs mx-auto` }), _jsx("div", { className: "flex gap-6 overflow-hidden", "data-section": "customerreviewssection-div-316", children: [...Array(3)].map((_, i) => (_jsx("div", { className: `${skeleton.card} h-[clamp(180px,26vh,260px)] min-w-[clamp(150px,18vw,260px)] max-w-[clamp(240px,36vw,380px)] flex-none` }, i))) })] }) }));
|
|
10
9
|
}
|
|
11
10
|
if (items.length === 0)
|
|
12
11
|
return null;
|
|
13
|
-
return (_jsx(Section, { className: `py-12 ${themed.bgPrimary} ${className}`, children: _jsxs("div", { className: "w-full max-w-7xl mx-auto px-4 md:px-8", children: [_jsxs("div", { className: "text-center mb-10", children: [_jsx(Heading, { level: 2, className: `text-3xl md:text-4xl font-bold ${themed.textPrimary} mb-3`, children: title }), subtitle && (_jsx(Text, { className: `text-base ${themed.textSecondary}`, children: subtitle }))] }), _jsx(HorizontalScroller, { items: items, renderItem: (item) => renderItem(item), perView:
|
|
12
|
+
return (_jsx(Section, { className: `py-12 ${themed.bgPrimary} ${className}`, children: _jsxs("div", { className: "w-full max-w-7xl mx-auto px-4 md:px-8", "data-section": "customerreviewssection-div-317", children: [_jsxs("div", { className: "text-center mb-10", "data-section": "customerreviewssection-div-318", children: [_jsx(Heading, { level: 2, className: `text-3xl md:text-4xl font-bold ${themed.textPrimary} mb-3`, children: title }), subtitle && (_jsx(Text, { className: `text-base ${themed.textSecondary}`, children: subtitle }))] }), _jsx(HorizontalScroller, { items: items, renderItem: (item) => renderItem(item), perView: THEME_CONSTANTS.carousel.perView.reviews, gap: 24, autoScroll: true, autoScrollInterval: 4500, pauseOnHover: true, snapToItems: true, showArrows: true, keyExtractor: keyExtractor }), viewMoreHref && (_jsx("div", { className: "text-center mt-8", "data-section": "customerreviewssection-div-319", children: _jsx(TextLink, { href: viewMoreHref, className: "text-sm font-medium text-primary hover:text-primary/80", children: viewMoreLabel }) }))] }) }));
|
|
14
13
|
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export interface EventsSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
description?: string;
|
|
4
|
+
viewMoreHref?: string;
|
|
5
|
+
viewMoreLabel?: string;
|
|
6
|
+
limit?: number;
|
|
7
|
+
className?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function EventsSection({ title, description, viewMoreHref, viewMoreLabel, limit, className, }: EventsSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { SectionCarousel } from "./SectionCarousel";
|
|
5
|
+
import { useHomepageEvents } from "../hooks/useHomepageEvents";
|
|
6
|
+
import { EventCard } from "../../events/components/EventCard";
|
|
7
|
+
export function EventsSection({ title = "Events & Offers", description, viewMoreHref, viewMoreLabel = "View all events →", limit = 6, className = "", }) {
|
|
8
|
+
const { data: items = [], isLoading } = useHomepageEvents(limit);
|
|
9
|
+
return (_jsx(SectionCarousel, { title: title, description: description, viewMoreHref: viewMoreHref, viewMoreLabel: viewMoreLabel, items: items, isLoading: isLoading, skeletonCount: 3, perView: THEME_CONSTANTS.carousel.perView.events, gap: 16, keyExtractor: (event) => event.id, renderItem: (event) => (_jsx(EventCard, { event: event })), className: className }));
|
|
10
|
+
}
|
|
@@ -4,17 +4,17 @@ import { useState } from "react";
|
|
|
4
4
|
import { THEME_CONSTANTS } from "../../../tokens";
|
|
5
5
|
import { Button, Heading, Section, Span, Text, TextLink } from "../../../ui";
|
|
6
6
|
import { ChevronDown } from "lucide-react";
|
|
7
|
-
//
|
|
7
|
+
// --- Section -----------------------------------------------------------------
|
|
8
8
|
export function FAQSection({ title, subtitle, items, viewMoreHref, viewMoreLabel = "View all →", hasMore = false, moreCount = 0, renderTabs, className = "", }) {
|
|
9
9
|
const { themed, spacing, flex } = THEME_CONSTANTS;
|
|
10
10
|
const [openFaqId, setOpenFaqId] = useState(null);
|
|
11
11
|
const toggleFaq = (faqId) => {
|
|
12
12
|
setOpenFaqId(openFaqId === faqId ? null : faqId);
|
|
13
13
|
};
|
|
14
|
-
return (_jsx(Section, { className: `p-8 ${themed.bgSecondary} ${className}`, children: _jsxs("div", { className: "w-full max-w-7xl mx-auto", children: [_jsxs("div", { className: "text-center mb-8", children: [_jsx(Heading, { level: 2, variant: "none", className: "bg-gradient-to-r from-primary to-cobalt bg-clip-text text-transparent text-3xl md:text-4xl font-bold mb-3", children: title }), subtitle && (_jsx(Text, { className: `text-base ${themed.textSecondary}`, children: subtitle }))] }), renderTabs && _jsx("div", { className: "mb-8 -mx-8", children: renderTabs() }), _jsxs("div", { className: `${spacing.stack} max-w-5xl mx-auto`, children: [items.length === 0 && (_jsx(Text, { className: `text-center py-8 ${themed.textSecondary}`, children: "No FAQs found." })), items.map((faq) => {
|
|
14
|
+
return (_jsx(Section, { className: `p-8 ${themed.bgSecondary} ${className}`, children: _jsxs("div", { className: "w-full max-w-7xl mx-auto", "data-section": "faqsection-div-320", children: [_jsxs("div", { className: "text-center mb-8", "data-section": "faqsection-div-321", children: [_jsx(Heading, { level: 2, variant: "none", className: "bg-gradient-to-r from-primary to-cobalt bg-clip-text text-transparent text-3xl md:text-4xl font-bold mb-3", children: title }), subtitle && (_jsx(Text, { className: `text-base ${themed.textSecondary}`, children: subtitle }))] }), renderTabs && _jsx("div", { className: "mb-8 -mx-8", "data-section": "faqsection-div-322", children: renderTabs() }), _jsxs("div", { className: `${spacing.stack} max-w-5xl mx-auto`, "data-section": "faqsection-div-323", children: [items.length === 0 && (_jsx(Text, { className: `text-center py-8 ${themed.textSecondary}`, children: "No FAQs found." })), items.map((faq) => {
|
|
15
15
|
const isOpen = openFaqId === faq.id;
|
|
16
16
|
return (_jsxs("div", { className: `${themed.bgPrimary} rounded-2xl overflow-hidden transition-all border-l-4 ${isOpen
|
|
17
17
|
? "border-primary bg-primary/5 dark:bg-primary/10"
|
|
18
|
-
: "border-transparent"}`, children: [_jsxs(Button, { variant: "ghost", className: `w-full text-left p-6 ${flex.between} gap-4 hover:bg-zinc-50 dark:hover:bg-slate-800 transition-colors`, onClick: () => toggleFaq(faq.id), "aria-expanded": isOpen, children: [_jsx(Span, { className: `text-base ${themed.textPrimary} font-medium flex-1`, children: faq.question }), _jsx(ChevronDown, { className: `w-5 h-5 flex-shrink-0 ${themed.textSecondary} transition-transform duration-300 ${isOpen ? "rotate-180" : ""}` })] }), _jsx("div", { className: `overflow-hidden transition-all duration-300 ease-out ${isOpen ? "max-h-96 opacity-100" : "max-h-0 opacity-0"}`, children: _jsx("div", { className: "p-6 pt-0", children: _jsx(Text, { className: `text-base ${themed.textSecondary} rounded-md ${themed.bgTertiary} p-4`, children: faq.answer }) }) })] }, faq.id));
|
|
19
|
-
})] }), viewMoreHref && (_jsx("div", { className: "text-center mt-8", children: _jsxs(TextLink, { href: viewMoreHref, className: "inline-flex items-center gap-2 px-6 py-2.5 rounded-full text-sm font-medium bg-primary/10 text-primary hover:bg-primary/20 dark:bg-primary/15 dark:text-primary-400 transition-colors", children: [viewMoreLabel, hasMore && moreCount > 0 && (_jsxs(Span, { className: "bg-primary dark:bg-primary/80 text-white text-xs px-2 py-0.5 rounded-full", children: ["+", moreCount] }))] }) }))] }) }));
|
|
18
|
+
: "border-transparent"}`, "data-section": "faqsection-div-324", children: [_jsxs(Button, { variant: "ghost", className: `w-full text-left p-6 ${flex.between} gap-4 hover:bg-zinc-50 dark:hover:bg-slate-800 transition-colors`, onClick: () => toggleFaq(faq.id), "aria-expanded": isOpen, children: [_jsx(Span, { className: `text-base ${themed.textPrimary} font-medium flex-1`, children: faq.question }), _jsx(ChevronDown, { className: `w-5 h-5 flex-shrink-0 ${themed.textSecondary} transition-transform duration-300 ${isOpen ? "rotate-180" : ""}` })] }), _jsx("div", { className: `overflow-hidden transition-all duration-300 ease-out ${isOpen ? "max-h-96 opacity-100" : "max-h-0 opacity-0"}`, "data-section": "faqsection-div-325", children: _jsx("div", { className: "p-6 pt-0", "data-section": "faqsection-div-326", children: _jsx(Text, { className: `text-base ${themed.textSecondary} rounded-md ${themed.bgTertiary} p-4`, children: faq.answer }) }) })] }, faq.id));
|
|
19
|
+
})] }), viewMoreHref && (_jsx("div", { className: "text-center mt-8", "data-section": "faqsection-div-327", children: _jsxs(TextLink, { href: viewMoreHref, className: "inline-flex items-center gap-2 px-6 py-2.5 rounded-full text-sm font-medium bg-primary/10 text-primary hover:bg-primary/20 dark:bg-primary/15 dark:text-primary-400 transition-colors", children: [viewMoreLabel, hasMore && moreCount > 0 && (_jsxs(Span, { className: "bg-primary dark:bg-primary/80 text-white text-xs px-2 py-0.5 rounded-full", children: ["+", moreCount] }))] }) }))] }) }));
|
|
20
20
|
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface FeaturedAuctionsSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
description?: string;
|
|
4
|
+
viewMoreHref?: string;
|
|
5
|
+
viewMoreLabel?: string;
|
|
6
|
+
className?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function FeaturedAuctionsSection({ title, description, viewMoreHref, viewMoreLabel, className, }: FeaturedAuctionsSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { SectionCarousel } from "./SectionCarousel";
|
|
5
|
+
import { useFeaturedAuctions } from "../hooks/useFeaturedAuctions";
|
|
6
|
+
import { MarketplaceAuctionCard } from "../../auctions/components/MarketplaceAuctionCard";
|
|
7
|
+
export function FeaturedAuctionsSection({ title = "Live Auctions", description, viewMoreHref, viewMoreLabel = "View all auctions →", className = "", }) {
|
|
8
|
+
const { data: items = [], isLoading } = useFeaturedAuctions();
|
|
9
|
+
return (_jsx(SectionCarousel, { title: title, description: description, viewMoreHref: viewMoreHref, viewMoreLabel: viewMoreLabel, items: items, isLoading: isLoading, skeletonCount: 4, perView: THEME_CONSTANTS.carousel.perView.compact, gap: 16, keyExtractor: (product) => product.id, renderItem: (product) => (_jsx(MarketplaceAuctionCard, { product: product })), className: className }));
|
|
10
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface FeaturedPreOrdersSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
description?: string;
|
|
4
|
+
viewMoreHref?: string;
|
|
5
|
+
viewMoreLabel?: string;
|
|
6
|
+
className?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function FeaturedPreOrdersSection({ title, description, viewMoreHref, viewMoreLabel, className, }: FeaturedPreOrdersSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { SectionCarousel } from "./SectionCarousel";
|
|
5
|
+
import { useFeaturedPreOrders } from "../hooks/useFeaturedPreOrders";
|
|
6
|
+
import { MarketplacePreorderCard } from "../../pre-orders/components/MarketplacePreorderCard";
|
|
7
|
+
export function FeaturedPreOrdersSection({ title = "Reserve Before It Ships", description, viewMoreHref, viewMoreLabel = "View all pre-orders →", className = "", }) {
|
|
8
|
+
const { data: items = [], isLoading } = useFeaturedPreOrders();
|
|
9
|
+
return (_jsx(SectionCarousel, { title: title, description: description, viewMoreHref: viewMoreHref, viewMoreLabel: viewMoreLabel, items: items, isLoading: isLoading, skeletonCount: 4, perView: THEME_CONSTANTS.carousel.perView.compact, gap: 16, keyExtractor: (product) => product.id, renderItem: (product) => (_jsx(MarketplacePreorderCard, { product: product })), className: className }));
|
|
10
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface FeaturedProductsSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
description?: string;
|
|
4
|
+
viewMoreHref?: string;
|
|
5
|
+
viewMoreLabel?: string;
|
|
6
|
+
className?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function FeaturedProductsSection({ title, description, viewMoreHref, viewMoreLabel, className, }: FeaturedProductsSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { SectionCarousel } from "./SectionCarousel";
|
|
4
|
+
import { useFeaturedProducts } from "../hooks/useFeaturedProducts";
|
|
5
|
+
import { InteractiveProductCard } from "../../products/components/InteractiveProductCard";
|
|
6
|
+
import { ROUTES } from "../../../next";
|
|
7
|
+
export function FeaturedProductsSection({ title = "Featured Products", description, viewMoreHref, viewMoreLabel = "View all products →", className = "", }) {
|
|
8
|
+
const { data, isLoading } = useFeaturedProducts();
|
|
9
|
+
const items = data?.items ?? [];
|
|
10
|
+
return (_jsx(SectionCarousel, { title: title, description: description, viewMoreHref: viewMoreHref, viewMoreLabel: viewMoreLabel, items: items, isLoading: isLoading, skeletonCount: 4, perView: { base: 1 }, gap: 16, rows: 2, keyExtractor: (product) => product.id, renderItem: (product) => (_jsx(InteractiveProductCard, { product: product, href: ROUTES.PUBLIC.PRODUCT_DETAIL(product.slug ?? product.id) })), className: className }));
|
|
11
|
+
}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { THEME_CONSTANTS } from "../../../tokens";
|
|
3
|
-
import { Div,
|
|
3
|
+
import { Div, Heading, Section, Span, Text, HorizontalScroller } from "../../../ui";
|
|
4
4
|
import { BeforeAfterCard } from "./BeforeAfterCard";
|
|
5
|
-
//
|
|
5
|
+
// --- Sectmon -----------------------------------------------------------------
|
|
6
6
|
export function FeaturedResultsSection({ title, subtitle, pillLabel, ornamentLabel = "✶", items, className = "", }) {
|
|
7
7
|
const { flex } = THEME_CONSTANTS;
|
|
8
8
|
const pillCls = "inline-flex items-center gap-2 rounded-full border border-primary-500/30 bg-primary-500/10 px-5 py-1.5 text-xs font-medium uppercase tracking-[0.2em] text-primary-700 backdrop-blur-sm dark:text-primary-400";
|
|
9
9
|
if (!items.length)
|
|
10
10
|
return null;
|
|
11
|
-
return (_jsxs(Section, { className: `px-4 py-16 md:py-20 ${className}`, children: [_jsxs(Div, { className: "mb-12 text-center", children: [pillLabel && (_jsxs(Span, { className: pillCls, children: [_jsx(Span, { className: "inline-block h-1.5 w-1.5 rounded-full bg-primary-500", "aria-hidden": "true" }), pillLabel] })), _jsx(Heading, { level: 2, className: "mt-3 font-display text-4xl text-zinc-900 dark:text-white", children: title }), _jsxs(Div, { className: `mt-3 ${flex.center} gap-2 text-zinc-400 dark:text-zinc-500`, "aria-hidden": "true", children: [_jsx(Span, { className: "h-px w-6 bg-current" }), _jsx(Span, { className: "text-xs", children: ornamentLabel }), _jsx(Span, { className: "h-px w-6 bg-current" })] }), subtitle && (_jsx(Text, { className: "mx-auto mt-4 max-w-md text-sm text-zinc-500 dark:text-zinc-400", children: subtitle }))] }), _jsx(
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
11
|
+
return (_jsxs(Section, { className: `px-4 py-16 md:py-20 ${className}`, children: [_jsxs(Div, { className: "mb-12 text-center", children: [pillLabel && (_jsxs(Span, { className: pillCls, children: [_jsx(Span, { className: "inline-block h-1.5 w-1.5 rounded-full bg-primary-500", "aria-hidden": "true" }), pillLabel] })), _jsx(Heading, { level: 2, className: "mt-3 font-display text-4xl text-zinc-900 dark:text-white", children: title }), _jsxs(Div, { className: `mt-3 ${flex.center} gap-2 text-zinc-400 dark:text-zinc-500`, "aria-hidden": "true", children: [_jsx(Span, { className: "h-px w-6 bg-current" }), _jsx(Span, { className: "text-xs", children: ornamentLabel }), _jsx(Span, { className: "h-px w-6 bg-current" })] }), subtitle && (_jsx(Text, { className: "mx-auto mt-4 max-w-md text-sm text-zinc-500 dark:text-zinc-400", children: subtitle }))] }), _jsx("div", { className: "mx-auto max-w-7xl", children: _jsx(HorizontalScroller, { items: items, renderItem: (item, i) => (_jsx("div", { className: "w-full sm:w-auto", children: _jsx(BeforeAfterCard, { item: {
|
|
12
|
+
id: item.id ?? `result-${i}`,
|
|
13
|
+
beforeImage: item.beforeImage,
|
|
14
|
+
afterImage: item.afterImage,
|
|
15
|
+
caption: item.caption ?? "",
|
|
16
|
+
sortOrder: item.sortOrder ?? i,
|
|
17
|
+
} }, item.id ?? `result-${i}`) })), keyExtractor: (item, i) => item.id ?? `result-${i}`, perView: THEME_CONSTANTS.carousel.perView.cards, gap: 24, minItemWidth: 260, snapToItems: true, showArrows: true, showFadeEdges: true }) })] }));
|
|
18
18
|
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export interface FeaturedStoresSectionProps {
|
|
2
|
+
title?: string;
|
|
3
|
+
description?: string;
|
|
4
|
+
viewMoreHref?: string;
|
|
5
|
+
viewMoreLabel?: string;
|
|
6
|
+
limit?: number;
|
|
7
|
+
className?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function FeaturedStoresSection({ title, description, viewMoreHref, viewMoreLabel, limit, className, }: FeaturedStoresSectionProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
|
+
import { SectionCarousel } from "./SectionCarousel";
|
|
5
|
+
import { useFeaturedStores } from "../hooks/useFeaturedStores";
|
|
6
|
+
import { InteractiveStoreCard } from "../../stores/components/InteractiveStoreCard";
|
|
7
|
+
import { ROUTES } from "../../../next";
|
|
8
|
+
export function FeaturedStoresSection({ title = "Featured Stores", description, viewMoreHref, viewMoreLabel = "View all stores →", limit = 8, className = "", }) {
|
|
9
|
+
const { data: items = [], isLoading } = useFeaturedStores(limit);
|
|
10
|
+
return (_jsx(SectionCarousel, { title: title, description: description, viewMoreHref: viewMoreHref, viewMoreLabel: viewMoreLabel, items: items, isLoading: isLoading, skeletonCount: 4, perView: THEME_CONSTANTS.carousel.perView.cards, gap: 16, keyExtractor: (store) => store.id, renderItem: (store) => (_jsx(InteractiveStoreCard, { store: store, href: ROUTES.PUBLIC.STORE_DETAIL(store.storeSlug) })), className: className }));
|
|
11
|
+
}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import "client-only";
|
|
2
1
|
import type { CarouselSlide } from "../types/index";
|
|
3
2
|
export interface HeroCarouselProps {
|
|
4
3
|
initialSlides?: CarouselSlide[];
|
|
@@ -9,4 +8,4 @@ export interface HeroCarouselProps {
|
|
|
9
8
|
*/
|
|
10
9
|
push?: (href: string) => void;
|
|
11
10
|
}
|
|
12
|
-
export declare function HeroCarousel({ initialSlides, push }?: HeroCarouselProps): import("react/jsx-runtime").JSX.Element
|
|
11
|
+
export declare function HeroCarousel({ initialSlides, push }?: HeroCarouselProps): import("react/jsx-runtime").JSX.Element;
|