@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
|
@@ -16,13 +16,13 @@ export declare const createBlogPostSchema: z.ZodObject<{
|
|
|
16
16
|
alt: z.ZodOptional<z.ZodString>;
|
|
17
17
|
thumbnailUrl: z.ZodOptional<z.ZodString>;
|
|
18
18
|
}, "strip", z.ZodTypeAny, {
|
|
19
|
-
type: "video" | "image" | "file";
|
|
20
19
|
url: string;
|
|
20
|
+
type: "video" | "image" | "file";
|
|
21
21
|
alt?: string | undefined;
|
|
22
22
|
thumbnailUrl?: string | undefined;
|
|
23
23
|
}, {
|
|
24
|
-
type: "video" | "image" | "file";
|
|
25
24
|
url: string;
|
|
25
|
+
type: "video" | "image" | "file";
|
|
26
26
|
alt?: string | undefined;
|
|
27
27
|
thumbnailUrl?: string | undefined;
|
|
28
28
|
}>, z.ZodEffects<z.ZodString, {
|
|
@@ -35,13 +35,13 @@ export declare const createBlogPostSchema: z.ZodObject<{
|
|
|
35
35
|
alt: z.ZodOptional<z.ZodString>;
|
|
36
36
|
thumbnailUrl: z.ZodOptional<z.ZodString>;
|
|
37
37
|
}, "strip", z.ZodTypeAny, {
|
|
38
|
-
type: "video" | "image" | "file";
|
|
39
38
|
url: string;
|
|
39
|
+
type: "video" | "image" | "file";
|
|
40
40
|
alt?: string | undefined;
|
|
41
41
|
thumbnailUrl?: string | undefined;
|
|
42
42
|
}, {
|
|
43
|
-
type: "video" | "image" | "file";
|
|
44
43
|
url: string;
|
|
44
|
+
type: "video" | "image" | "file";
|
|
45
45
|
alt?: string | undefined;
|
|
46
46
|
thumbnailUrl?: string | undefined;
|
|
47
47
|
}>, "many">>>;
|
|
@@ -51,13 +51,13 @@ export declare const createBlogPostSchema: z.ZodObject<{
|
|
|
51
51
|
alt: z.ZodOptional<z.ZodString>;
|
|
52
52
|
thumbnailUrl: z.ZodOptional<z.ZodString>;
|
|
53
53
|
}, "strip", z.ZodTypeAny, {
|
|
54
|
-
type: "video" | "image" | "file";
|
|
55
54
|
url: string;
|
|
55
|
+
type: "video" | "image" | "file";
|
|
56
56
|
alt?: string | undefined;
|
|
57
57
|
thumbnailUrl?: string | undefined;
|
|
58
58
|
}, {
|
|
59
|
-
type: "video" | "image" | "file";
|
|
60
59
|
url: string;
|
|
60
|
+
type: "video" | "image" | "file";
|
|
61
61
|
alt?: string | undefined;
|
|
62
62
|
thumbnailUrl?: string | undefined;
|
|
63
63
|
}>, "many">>>;
|
|
@@ -69,39 +69,39 @@ export declare const createBlogPostSchema: z.ZodObject<{
|
|
|
69
69
|
metaTitle: z.ZodOptional<z.ZodString>;
|
|
70
70
|
metaDescription: z.ZodOptional<z.ZodString>;
|
|
71
71
|
}, "strip", z.ZodTypeAny, {
|
|
72
|
-
status: "draft" | "published" | "archived";
|
|
73
72
|
title: string;
|
|
74
73
|
content: string;
|
|
74
|
+
status: "draft" | "published" | "archived";
|
|
75
75
|
category: "news" | "tips" | "guides" | "updates" | "community";
|
|
76
|
+
additionalImages: {
|
|
77
|
+
url: string;
|
|
78
|
+
type: "video" | "image" | "file";
|
|
79
|
+
alt?: string | undefined;
|
|
80
|
+
thumbnailUrl?: string | undefined;
|
|
81
|
+
}[];
|
|
82
|
+
tags: string[];
|
|
76
83
|
slug: string;
|
|
77
84
|
isFeatured: boolean;
|
|
78
|
-
tags: string[];
|
|
79
85
|
excerpt: string;
|
|
80
86
|
contentImages: {
|
|
81
|
-
type: "video" | "image" | "file";
|
|
82
87
|
url: string;
|
|
83
|
-
alt?: string | undefined;
|
|
84
|
-
thumbnailUrl?: string | undefined;
|
|
85
|
-
}[];
|
|
86
|
-
additionalImages: {
|
|
87
88
|
type: "video" | "image" | "file";
|
|
88
|
-
url: string;
|
|
89
89
|
alt?: string | undefined;
|
|
90
90
|
thumbnailUrl?: string | undefined;
|
|
91
91
|
}[];
|
|
92
92
|
readTimeMinutes: number;
|
|
93
93
|
coverImage?: {
|
|
94
|
-
type: "video" | "image" | "file";
|
|
95
94
|
url: string;
|
|
95
|
+
type: "video" | "image" | "file";
|
|
96
96
|
alt?: string | undefined;
|
|
97
97
|
thumbnailUrl?: string | undefined;
|
|
98
98
|
} | {
|
|
99
99
|
url: string;
|
|
100
100
|
type: "image";
|
|
101
101
|
} | null | undefined;
|
|
102
|
+
authorName?: string | undefined;
|
|
102
103
|
publishedAt?: string | undefined;
|
|
103
104
|
authorId?: string | undefined;
|
|
104
|
-
authorName?: string | undefined;
|
|
105
105
|
authorAvatar?: string | undefined;
|
|
106
106
|
metaTitle?: string | undefined;
|
|
107
107
|
metaDescription?: string | undefined;
|
|
@@ -112,29 +112,29 @@ export declare const createBlogPostSchema: z.ZodObject<{
|
|
|
112
112
|
slug: string;
|
|
113
113
|
excerpt: string;
|
|
114
114
|
status?: "draft" | "published" | "archived" | undefined;
|
|
115
|
-
isFeatured?: boolean | undefined;
|
|
116
115
|
coverImage?: string | {
|
|
117
|
-
type: "video" | "image" | "file";
|
|
118
116
|
url: string;
|
|
117
|
+
type: "video" | "image" | "file";
|
|
119
118
|
alt?: string | undefined;
|
|
120
119
|
thumbnailUrl?: string | undefined;
|
|
121
120
|
} | null | undefined;
|
|
122
|
-
|
|
123
|
-
publishedAt?: string | undefined;
|
|
124
|
-
contentImages?: {
|
|
125
|
-
type: "video" | "image" | "file";
|
|
121
|
+
additionalImages?: {
|
|
126
122
|
url: string;
|
|
123
|
+
type: "video" | "image" | "file";
|
|
127
124
|
alt?: string | undefined;
|
|
128
125
|
thumbnailUrl?: string | undefined;
|
|
129
126
|
}[] | undefined;
|
|
130
|
-
|
|
131
|
-
|
|
127
|
+
tags?: string[] | undefined;
|
|
128
|
+
authorName?: string | undefined;
|
|
129
|
+
isFeatured?: boolean | undefined;
|
|
130
|
+
publishedAt?: string | undefined;
|
|
131
|
+
contentImages?: {
|
|
132
132
|
url: string;
|
|
133
|
+
type: "video" | "image" | "file";
|
|
133
134
|
alt?: string | undefined;
|
|
134
135
|
thumbnailUrl?: string | undefined;
|
|
135
136
|
}[] | undefined;
|
|
136
137
|
authorId?: string | undefined;
|
|
137
|
-
authorName?: string | undefined;
|
|
138
138
|
authorAvatar?: string | undefined;
|
|
139
139
|
readTimeMinutes?: number | undefined;
|
|
140
140
|
metaTitle?: string | undefined;
|
|
@@ -155,13 +155,13 @@ export declare const updateBlogPostSchema: z.ZodObject<{
|
|
|
155
155
|
alt: z.ZodOptional<z.ZodString>;
|
|
156
156
|
thumbnailUrl: z.ZodOptional<z.ZodString>;
|
|
157
157
|
}, "strip", z.ZodTypeAny, {
|
|
158
|
-
type: "video" | "image" | "file";
|
|
159
158
|
url: string;
|
|
159
|
+
type: "video" | "image" | "file";
|
|
160
160
|
alt?: string | undefined;
|
|
161
161
|
thumbnailUrl?: string | undefined;
|
|
162
162
|
}, {
|
|
163
|
-
type: "video" | "image" | "file";
|
|
164
163
|
url: string;
|
|
164
|
+
type: "video" | "image" | "file";
|
|
165
165
|
alt?: string | undefined;
|
|
166
166
|
thumbnailUrl?: string | undefined;
|
|
167
167
|
}>, z.ZodEffects<z.ZodString, {
|
|
@@ -174,13 +174,13 @@ export declare const updateBlogPostSchema: z.ZodObject<{
|
|
|
174
174
|
alt: z.ZodOptional<z.ZodString>;
|
|
175
175
|
thumbnailUrl: z.ZodOptional<z.ZodString>;
|
|
176
176
|
}, "strip", z.ZodTypeAny, {
|
|
177
|
-
type: "video" | "image" | "file";
|
|
178
177
|
url: string;
|
|
178
|
+
type: "video" | "image" | "file";
|
|
179
179
|
alt?: string | undefined;
|
|
180
180
|
thumbnailUrl?: string | undefined;
|
|
181
181
|
}, {
|
|
182
|
-
type: "video" | "image" | "file";
|
|
183
182
|
url: string;
|
|
183
|
+
type: "video" | "image" | "file";
|
|
184
184
|
alt?: string | undefined;
|
|
185
185
|
thumbnailUrl?: string | undefined;
|
|
186
186
|
}>, "many">>>>;
|
|
@@ -190,13 +190,13 @@ export declare const updateBlogPostSchema: z.ZodObject<{
|
|
|
190
190
|
alt: z.ZodOptional<z.ZodString>;
|
|
191
191
|
thumbnailUrl: z.ZodOptional<z.ZodString>;
|
|
192
192
|
}, "strip", z.ZodTypeAny, {
|
|
193
|
-
type: "video" | "image" | "file";
|
|
194
193
|
url: string;
|
|
194
|
+
type: "video" | "image" | "file";
|
|
195
195
|
alt?: string | undefined;
|
|
196
196
|
thumbnailUrl?: string | undefined;
|
|
197
197
|
}, {
|
|
198
|
-
type: "video" | "image" | "file";
|
|
199
198
|
url: string;
|
|
199
|
+
type: "video" | "image" | "file";
|
|
200
200
|
alt?: string | undefined;
|
|
201
201
|
thumbnailUrl?: string | undefined;
|
|
202
202
|
}>, "many">>>>;
|
|
@@ -208,72 +208,72 @@ export declare const updateBlogPostSchema: z.ZodObject<{
|
|
|
208
208
|
metaTitle: z.ZodOptional<z.ZodOptional<z.ZodString>>;
|
|
209
209
|
metaDescription: z.ZodOptional<z.ZodOptional<z.ZodString>>;
|
|
210
210
|
}, "strip", z.ZodTypeAny, {
|
|
211
|
-
status?: "draft" | "published" | "archived" | undefined;
|
|
212
211
|
title?: string | undefined;
|
|
213
212
|
content?: string | undefined;
|
|
213
|
+
status?: "draft" | "published" | "archived" | undefined;
|
|
214
214
|
category?: "news" | "tips" | "guides" | "updates" | "community" | undefined;
|
|
215
|
-
slug?: string | undefined;
|
|
216
|
-
isFeatured?: boolean | undefined;
|
|
217
215
|
coverImage?: {
|
|
218
|
-
type: "video" | "image" | "file";
|
|
219
216
|
url: string;
|
|
217
|
+
type: "video" | "image" | "file";
|
|
220
218
|
alt?: string | undefined;
|
|
221
219
|
thumbnailUrl?: string | undefined;
|
|
222
220
|
} | {
|
|
223
221
|
url: string;
|
|
224
222
|
type: "image";
|
|
225
223
|
} | null | undefined;
|
|
224
|
+
additionalImages?: {
|
|
225
|
+
url: string;
|
|
226
|
+
type: "video" | "image" | "file";
|
|
227
|
+
alt?: string | undefined;
|
|
228
|
+
thumbnailUrl?: string | undefined;
|
|
229
|
+
}[] | undefined;
|
|
226
230
|
tags?: string[] | undefined;
|
|
231
|
+
slug?: string | undefined;
|
|
232
|
+
authorName?: string | undefined;
|
|
233
|
+
isFeatured?: boolean | undefined;
|
|
227
234
|
publishedAt?: string | undefined;
|
|
228
235
|
excerpt?: string | undefined;
|
|
229
236
|
contentImages?: {
|
|
230
|
-
type: "video" | "image" | "file";
|
|
231
237
|
url: string;
|
|
232
|
-
alt?: string | undefined;
|
|
233
|
-
thumbnailUrl?: string | undefined;
|
|
234
|
-
}[] | undefined;
|
|
235
|
-
additionalImages?: {
|
|
236
238
|
type: "video" | "image" | "file";
|
|
237
|
-
url: string;
|
|
238
239
|
alt?: string | undefined;
|
|
239
240
|
thumbnailUrl?: string | undefined;
|
|
240
241
|
}[] | undefined;
|
|
241
242
|
authorId?: string | undefined;
|
|
242
|
-
authorName?: string | undefined;
|
|
243
243
|
authorAvatar?: string | undefined;
|
|
244
244
|
readTimeMinutes?: number | undefined;
|
|
245
245
|
metaTitle?: string | undefined;
|
|
246
246
|
metaDescription?: string | undefined;
|
|
247
247
|
}, {
|
|
248
|
-
status?: "draft" | "published" | "archived" | undefined;
|
|
249
248
|
title?: string | undefined;
|
|
250
249
|
content?: string | undefined;
|
|
250
|
+
status?: "draft" | "published" | "archived" | undefined;
|
|
251
251
|
category?: "news" | "tips" | "guides" | "updates" | "community" | undefined;
|
|
252
|
-
slug?: string | undefined;
|
|
253
|
-
isFeatured?: boolean | undefined;
|
|
254
252
|
coverImage?: string | {
|
|
255
|
-
type: "video" | "image" | "file";
|
|
256
253
|
url: string;
|
|
254
|
+
type: "video" | "image" | "file";
|
|
257
255
|
alt?: string | undefined;
|
|
258
256
|
thumbnailUrl?: string | undefined;
|
|
259
257
|
} | null | undefined;
|
|
258
|
+
additionalImages?: {
|
|
259
|
+
url: string;
|
|
260
|
+
type: "video" | "image" | "file";
|
|
261
|
+
alt?: string | undefined;
|
|
262
|
+
thumbnailUrl?: string | undefined;
|
|
263
|
+
}[] | undefined;
|
|
260
264
|
tags?: string[] | undefined;
|
|
265
|
+
slug?: string | undefined;
|
|
266
|
+
authorName?: string | undefined;
|
|
267
|
+
isFeatured?: boolean | undefined;
|
|
261
268
|
publishedAt?: string | undefined;
|
|
262
269
|
excerpt?: string | undefined;
|
|
263
270
|
contentImages?: {
|
|
264
|
-
type: "video" | "image" | "file";
|
|
265
271
|
url: string;
|
|
266
|
-
alt?: string | undefined;
|
|
267
|
-
thumbnailUrl?: string | undefined;
|
|
268
|
-
}[] | undefined;
|
|
269
|
-
additionalImages?: {
|
|
270
272
|
type: "video" | "image" | "file";
|
|
271
|
-
url: string;
|
|
272
273
|
alt?: string | undefined;
|
|
273
274
|
thumbnailUrl?: string | undefined;
|
|
274
275
|
}[] | undefined;
|
|
275
276
|
authorId?: string | undefined;
|
|
276
|
-
authorName?: string | undefined;
|
|
277
277
|
authorAvatar?: string | undefined;
|
|
278
278
|
readTimeMinutes?: number | undefined;
|
|
279
279
|
metaTitle?: string | undefined;
|
|
@@ -3,7 +3,7 @@ import { serverLogger } from "../../../monitoring";
|
|
|
3
3
|
import { blogRepository } from "../repository/blog.repository";
|
|
4
4
|
import { coerceMediaField, getMediaUrl } from "../../../utils";
|
|
5
5
|
import { finalizeStagedMediaField, finalizeStagedMediaObject, finalizeStagedMediaObjectArray, } from "../../media/finalize";
|
|
6
|
-
//
|
|
6
|
+
// --- Schemas --------------------------------------------------------------
|
|
7
7
|
const singleImageMediaSchema = z
|
|
8
8
|
.union([
|
|
9
9
|
z.object({
|
|
@@ -46,7 +46,7 @@ export const createBlogPostSchema = z.object({
|
|
|
46
46
|
metaDescription: z.string().optional(),
|
|
47
47
|
});
|
|
48
48
|
export const updateBlogPostSchema = createBlogPostSchema.partial();
|
|
49
|
-
//
|
|
49
|
+
// --- Actions --------------------------------------------------------------
|
|
50
50
|
export async function createBlogPost(input, author) {
|
|
51
51
|
const finalizedCoverUrl = await finalizeStagedMediaField(getMediaUrl(input.coverImage));
|
|
52
52
|
const finalizedCoverImage = await finalizeStagedMediaObject(coerceMediaField(input.coverImage ?? finalizedCoverUrl ?? null));
|
|
@@ -18,7 +18,7 @@ function toBlogPost(doc) {
|
|
|
18
18
|
updatedAt: doc.updatedAt.toISOString(),
|
|
19
19
|
};
|
|
20
20
|
}
|
|
21
|
-
//
|
|
21
|
+
// --- GET /api/blog/[slug] -----------------------------------------------------
|
|
22
22
|
export async function GET(_request, context) {
|
|
23
23
|
try {
|
|
24
24
|
const { slug } = await context.params;
|
|
@@ -18,7 +18,7 @@ function numParam(url, key, fallback) {
|
|
|
18
18
|
const n = v !== null ? Number(v) : NaN;
|
|
19
19
|
return Number.isFinite(n) ? n : fallback;
|
|
20
20
|
}
|
|
21
|
-
//
|
|
21
|
+
// --- GET /api/blog ------------------------------------------------------------
|
|
22
22
|
export async function GET(request) {
|
|
23
23
|
try {
|
|
24
24
|
const url = new URL(request.url);
|
|
@@ -1,16 +1,18 @@
|
|
|
1
|
-
"use client";
|
|
2
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
2
|
import { Article, Div, Heading, Row, Span, Text } from "../../../ui";
|
|
3
|
+
import { THEME_CONSTANTS, LAYOUT } from "../../../tokens";
|
|
4
4
|
import { getMediaUrl } from "../../media/types/index";
|
|
5
5
|
import { getDefaultLocale } from "../../../core/baseline-resolver";
|
|
6
|
+
import { safeDisplayName } from "../../../security";
|
|
6
7
|
const CATEGORY_BADGE = {
|
|
7
|
-
news: "bg-blue-100 text-blue-800",
|
|
8
|
-
tips: "bg-emerald-100 text-emerald-800",
|
|
9
|
-
guides: "bg-indigo-100 text-indigo-800",
|
|
10
|
-
updates: "bg-purple-100 text-purple-800",
|
|
11
|
-
community: "bg-orange-100 text-orange-800",
|
|
8
|
+
news: "bg-blue-100 text-blue-800 dark:bg-blue-900/40 dark:text-blue-300",
|
|
9
|
+
tips: "bg-emerald-100 text-emerald-800 dark:bg-emerald-900/40 dark:text-emerald-300",
|
|
10
|
+
guides: "bg-indigo-100 text-indigo-800 dark:bg-indigo-900/40 dark:text-indigo-300",
|
|
11
|
+
updates: "bg-purple-100 text-purple-800 dark:bg-purple-900/40 dark:text-purple-300",
|
|
12
|
+
community: "bg-orange-100 text-orange-800 dark:bg-orange-900/40 dark:text-orange-300",
|
|
12
13
|
};
|
|
13
14
|
export function BlogFeaturedCard({ post, href, labels = {}, renderLink, renderImage, className = "", }) {
|
|
15
|
+
const safeTitle = post.title?.trim() || "Untitled post";
|
|
14
16
|
const coverImageUrl = getMediaUrl(post.coverImage);
|
|
15
17
|
const date = post.publishedAt
|
|
16
18
|
? new Date(post.publishedAt).toLocaleDateString(getDefaultLocale(), {
|
|
@@ -19,6 +21,6 @@ export function BlogFeaturedCard({ post, href, labels = {}, renderLink, renderIm
|
|
|
19
21
|
day: "numeric",
|
|
20
22
|
})
|
|
21
23
|
: "";
|
|
22
|
-
const inner = (_jsxs(Article, { className: `overflow-hidden rounded-xl border border-neutral-200 bg-white shadow-sm hover:shadow-lg transition-shadow duration-200 md:flex ${className}`, children: [
|
|
24
|
+
const inner = (_jsxs(Article, { className: `overflow-hidden rounded-xl border border-neutral-200 dark:border-slate-700 bg-white dark:bg-slate-900 shadow-sm hover:shadow-lg transition-shadow duration-200 md:flex ${className}`, children: [_jsx(Div, { className: `md:w-1/2 relative ${LAYOUT.cardHeight.blog} overflow-hidden`, children: renderImage ? (renderImage(post)) : (coverImageUrl ? (_jsx(Div, { role: "img", "aria-label": safeTitle, className: "h-full w-full bg-cover bg-center", style: { backgroundImage: `url(${coverImageUrl})` } })) : (_jsx(Div, { role: "img", "aria-label": safeTitle, className: "h-full w-full bg-gradient-to-br from-zinc-200 via-zinc-100 to-zinc-300 dark:from-slate-800 dark:via-slate-700 dark:to-slate-900" }))) }), _jsxs(Div, { className: "p-8 md:w-1/2 flex flex-col justify-center", children: [_jsxs(Row, { className: "gap-2 mb-3", children: [_jsx(Span, { className: `inline-block px-2 py-0.5 rounded-full text-xs font-medium capitalize ${CATEGORY_BADGE[post.category] ?? ""}`, children: post.category }), post.isFeatured && (_jsx(Span, { className: "bg-yellow-100 text-yellow-800 dark:bg-yellow-900/40 dark:text-yellow-300 px-2 py-0.5 rounded-full text-xs font-medium", children: labels.featuredBadge ?? "Featured" }))] }), _jsx(Heading, { level: 2, className: "text-xl font-semibold text-neutral-900 dark:text-zinc-100 mb-3 leading-snug", children: safeTitle }), post.excerpt && (_jsx(Text, { className: `text-neutral-500 dark:text-zinc-400 mb-4 ${THEME_CONSTANTS.utilities.textClamp3} text-sm`, children: post.excerpt })), _jsxs(Row, { className: "gap-4 text-xs text-neutral-400 dark:text-zinc-500", children: [post.authorName && _jsx(Span, { children: safeDisplayName(post.authorName, "Author") }), post.readTimeMinutes != null && (_jsxs(Span, { children: [post.readTimeMinutes, " ", labels.readTime ?? "min read"] })), date && _jsx(Span, { children: date })] })] })] }));
|
|
23
25
|
return (_jsx(Div, { className: "mb-10", children: renderLink ? renderLink(href, inner) : inner }));
|
|
24
26
|
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { useUrlTable } from "../../../react/hooks/useUrlTable";
|
|
4
|
+
import { useBlogPosts } from "../hooks/useBlog";
|
|
5
|
+
import { Div, Grid, Input, Pagination, SlottedListingView, SortDropdown, Stack, Text, } from "../../../ui";
|
|
6
|
+
import { ROUTES } from "../../../next";
|
|
7
|
+
import { BlogCard } from "./BlogListView";
|
|
8
|
+
import { BlogFilters, BLOG_PUBLIC_SORT_OPTIONS, } from "./BlogFilters";
|
|
9
|
+
const PAGE_SIZE = 24;
|
|
10
|
+
export function BlogIndexListing({ initialData }) {
|
|
11
|
+
const table = useUrlTable({ defaults: { pageSize: String(PAGE_SIZE), sort: "-publishedAt" } });
|
|
12
|
+
const params = {
|
|
13
|
+
q: table.get("q") || undefined,
|
|
14
|
+
category: (table.get("category") || undefined),
|
|
15
|
+
sort: table.get("sort") || "-publishedAt",
|
|
16
|
+
page: table.getNumber("page", 1),
|
|
17
|
+
perPage: table.getNumber("pageSize", PAGE_SIZE),
|
|
18
|
+
};
|
|
19
|
+
const { posts, total, totalPages, isLoading } = useBlogPosts(params, {
|
|
20
|
+
initialData,
|
|
21
|
+
});
|
|
22
|
+
const currentPage = table.getNumber("page", 1);
|
|
23
|
+
return (_jsx(Div, { className: "min-h-screen", children: _jsx(SlottedListingView, { portal: "public", manageSearch: true, manageSort: true, inlineToolbar: true, renderSearch: (search, setSearch) => (_jsx(Input, { value: search, onChange: (e) => setSearch(e.target.value), placeholder: "Search posts...", className: "max-w-sm" })), renderSort: (value, onChange) => (_jsx(SortDropdown, { value: value, onChange: onChange, options: BLOG_PUBLIC_SORT_OPTIONS })), renderFilters: () => (_jsx(BlogFilters, { table: table, variant: "public" })), renderTable: () => posts.length === 0 && !isLoading ? (_jsx(Stack, { align: "center", gap: "3", className: "justify-center py-24 text-center", children: _jsx(Text, { className: "text-xl font-medium text-zinc-900 dark:text-zinc-50", children: "No posts found" }) })) : (_jsx(Grid, { cols: 3, gap: "md", children: posts.map((post) => (_jsx(BlogCard, { post: post, onClick: () => {
|
|
24
|
+
window.location.href = String(ROUTES.BLOG.ARTICLE(post.slug));
|
|
25
|
+
} }, post.id))) })), renderPagination: () => totalPages > 1 ? (_jsx(Pagination, { currentPage: currentPage, totalPages: totalPages, onPageChange: (p) => table.setPage(p) })) : null, total: total, isLoading: isLoading }) }));
|
|
26
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function BlogIndexPageView(): Promise<import("react/jsx-runtime").JSX.Element>;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { blogRepository } from "../../../repositories";
|
|
3
|
+
import { Container, Heading, Main, Section } from "../../../ui";
|
|
4
|
+
import { AdSlot } from "../../homepage/components/AdSlot";
|
|
5
|
+
import { BlogIndexListing } from "./BlogIndexListing";
|
|
6
|
+
export async function BlogIndexPageView() {
|
|
7
|
+
const result = await blogRepository
|
|
8
|
+
.listPublished({}, { sorts: "-publishedAt", page: 1, pageSize: 24 })
|
|
9
|
+
.catch(() => null);
|
|
10
|
+
return (_jsx(Main, { children: _jsx(Section, { className: "py-10", children: _jsxs(Container, { size: "xl", children: [_jsx(Heading, { level: 1, className: "mb-8 text-3xl font-semibold text-zinc-900 dark:text-zinc-50", children: "Blog" }), _jsx(AdSlot, { id: "listing-sidebar-top", className: "mb-6" }), _jsx(BlogIndexListing, { initialData: result }), _jsx(AdSlot, { id: "listing-sidebar-bottom", className: "mt-8" })] }) }) }));
|
|
11
|
+
}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
2
|
import React from "react";
|
|
3
3
|
import { Article, Button, Div, Heading, Pagination, Row, Span, Text, } from "../../../ui";
|
|
4
|
+
import { THEME_CONSTANTS } from "../../../tokens";
|
|
4
5
|
import { getDefaultLocale } from "../../../core/baseline-resolver";
|
|
5
6
|
import { getMediaUrl } from "../../media/types/index";
|
|
6
7
|
export function BlogCard({ post, onClick, className = "" }) {
|
|
@@ -14,14 +15,14 @@ export function BlogCard({ post, onClick, className = "" }) {
|
|
|
14
15
|
: "";
|
|
15
16
|
return (_jsxs(Article, { role: onClick ? "button" : undefined, tabIndex: onClick ? 0 : undefined, onKeyDown: onClick
|
|
16
17
|
? (e) => (e.key === "Enter" || e.key === " ") && onClick(post)
|
|
17
|
-
: undefined, onClick: onClick ? () => onClick(post) : undefined, className: `group flex flex-col h-full overflow-hidden rounded-xl border border-neutral-200 bg-white shadow-sm transition hover:shadow-md ${onClick ? "cursor-pointer" : ""} ${className}`, children: [coverImageUrl && (_jsx(Div, { className: "aspect-video w-full overflow-hidden bg-neutral-100", children: _jsx(Div, { role: "img", "aria-label": post.title, className: "h-full w-full bg-center bg-cover transition-transform duration-300 group-hover:scale-105", style: { backgroundImage: `url(${coverImageUrl})` } }) })), _jsxs(Div, { className: "flex flex-1 flex-col p-5", children: [_jsxs(Row, { className: "mb-2 gap-2", children: [_jsx(Span, { className: "rounded-full bg-primary/10 px-2 py-0.5 text-xs font-medium capitalize text-primary", children: post.category }), post.readTimeMinutes && (_jsxs(Span, { className: "text-xs text-neutral-400", children: [post.readTimeMinutes, " min read"] }))] }), _jsx(Heading, { level: 3, className:
|
|
18
|
+
: undefined, onClick: onClick ? () => onClick(post) : undefined, className: `group flex flex-col h-full overflow-hidden rounded-xl border border-neutral-200 dark:border-slate-700 bg-white dark:bg-slate-900 shadow-sm transition hover:shadow-md ${onClick ? "cursor-pointer" : ""} ${className}`, children: [coverImageUrl && (_jsx(Div, { className: "aspect-video w-full overflow-hidden bg-neutral-100 dark:bg-slate-800", children: _jsx(Div, { role: "img", "aria-label": post.title, className: "h-full w-full bg-center bg-cover transition-transform duration-300 group-hover:scale-105", style: { backgroundImage: `url(${coverImageUrl})` } }) })), _jsxs(Div, { className: "flex flex-1 flex-col p-5", children: [_jsxs(Row, { className: "mb-2 gap-2", children: [_jsx(Span, { className: "rounded-full bg-primary/10 px-2 py-0.5 text-xs font-medium capitalize text-primary", children: post.category }), post.readTimeMinutes && (_jsxs(Span, { className: "text-xs text-neutral-400 dark:text-zinc-500", children: [post.readTimeMinutes, " min read"] }))] }), _jsx(Heading, { level: 3, className: `${THEME_CONSTANTS.utilities.textClamp2} text-base font-semibold text-neutral-900 dark:text-zinc-100 group-hover:text-primary`, children: post.title }), post.excerpt && (_jsx(Text, { className: `mt-2 ${THEME_CONSTANTS.utilities.textClamp3} flex-1 text-sm text-neutral-500 dark:text-zinc-400`, children: post.excerpt })), _jsxs(Row, { className: "mt-4 gap-3", children: [post.authorAvatar && (_jsx(Div, { role: "img", "aria-label": post.authorName ?? "author", className: "h-7 w-7 rounded-full bg-center bg-cover", style: { backgroundImage: `url(${post.authorAvatar})` } })), _jsxs(Text, { className: "text-xs text-neutral-500 dark:text-zinc-400", children: [post.authorName && (_jsx(Span, { className: "font-medium text-neutral-700 dark:text-zinc-300", children: post.authorName })), date && _jsxs(Span, { className: "ml-1", children: ["\u00B7 ", date] })] })] })] })] }));
|
|
18
19
|
}
|
|
19
20
|
export function BlogCategoryTabs({ categories, active, onSelect, labels = {}, }) {
|
|
20
|
-
return (_jsxs(Div, { className: "scrollbar-none flex gap-2 overflow-x-auto pb-1", children: [_jsx(Button, { onClick: () => onSelect(null), variant: !active ? "primary" : "ghost", size: "sm", className: `whitespace-nowrap rounded-full px-4 py-1.5 text-sm font-medium transition ${!active ? "bg-neutral-900 text-white" : "bg-neutral-100 text-neutral-600 hover:bg-neutral-200"}`, children: labels.all ?? "All" }), categories.map((cat) => (_jsx(Button, { onClick: () => onSelect(cat), variant: active === cat ? "primary" : "ghost", size: "sm", className: `whitespace-nowrap rounded-full px-4 py-1.5 text-sm font-medium capitalize transition ${active === cat ? "bg-neutral-900 text-white" : "bg-neutral-100 text-neutral-600 hover:bg-neutral-200"}`, children: labels[cat] ?? cat }, cat)))] }));
|
|
21
|
+
return (_jsxs(Div, { className: "scrollbar-none flex gap-2 overflow-x-auto pb-1", children: [_jsx(Button, { onClick: () => onSelect(null), variant: !active ? "primary" : "ghost", size: "sm", className: `whitespace-nowrap rounded-full px-4 py-1.5 text-sm font-medium transition ${!active ? "bg-neutral-900 text-white" : "bg-neutral-100 dark:bg-slate-800 text-neutral-600 dark:text-zinc-300 hover:bg-neutral-200 dark:hover:bg-slate-700"}`, children: labels.all ?? "All" }), categories.map((cat) => (_jsx(Button, { onClick: () => onSelect(cat), variant: active === cat ? "primary" : "ghost", size: "sm", className: `whitespace-nowrap rounded-full px-4 py-1.5 text-sm font-medium capitalize transition ${active === cat ? "bg-neutral-900 text-white" : "bg-neutral-100 dark:bg-slate-800 text-neutral-600 dark:text-zinc-300 hover:bg-neutral-200 dark:hover:bg-slate-700"}`, children: labels[cat] ?? cat }, cat)))] }));
|
|
21
22
|
}
|
|
22
23
|
export function BlogListView({ posts, isLoading, totalPages = 1, currentPage = 1, total = 0, onPageChange, onPostClick, emptyLabel = "No posts found", slots, }) {
|
|
23
24
|
if (isLoading) {
|
|
24
|
-
return (_jsx(Div, { className: "grid gap-6 sm:grid-cols-2 lg:grid-cols-3", children: Array.from({ length: 6 }).map((_, i) => (_jsxs(Div, { className: "animate-pulse overflow-hidden rounded-xl border border-neutral-200 bg-neutral-100", children: [_jsx(Div, { className: "aspect-video bg-neutral-200" }), _jsxs(Div, { className: "space-y-2 p-5", children: [_jsx(Div, { className: "h-4 w-16 rounded bg-neutral-200" }), _jsx(Div, { className: "h-5 w-full rounded bg-neutral-200" }), _jsx(Div, { className: "h-4 w-3/4 rounded bg-neutral-200" })] })] }, i))) }));
|
|
25
|
+
return (_jsx(Div, { className: "grid gap-6 sm:grid-cols-2 lg:grid-cols-3", children: Array.from({ length: 6 }).map((_, i) => (_jsxs(Div, { className: "animate-pulse overflow-hidden rounded-xl border border-neutral-200 dark:border-slate-700 bg-neutral-100 dark:bg-slate-800", children: [_jsx(Div, { className: "aspect-video bg-neutral-200 dark:bg-slate-700" }), _jsxs(Div, { className: "space-y-2 p-5", children: [_jsx(Div, { className: "h-4 w-16 rounded bg-neutral-200 dark:bg-slate-700" }), _jsx(Div, { className: "h-5 w-full rounded bg-neutral-200 dark:bg-slate-700" }), _jsx(Div, { className: "h-4 w-3/4 rounded bg-neutral-200 dark:bg-slate-700" })] })] }, i))) }));
|
|
25
26
|
}
|
|
26
27
|
if (posts.length === 0) {
|
|
27
28
|
if (slots?.renderEmptyState) {
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
"use client";
|
|
2
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import { Div, Input, Label, Select, Stack, TagInput, Text, Textarea, } from "../../../ui";
|
|
2
|
+
import { Div, Input, Label, RichTextEditor, Select, Stack, TagInput, Text, Textarea, } from "../../../ui";
|
|
4
3
|
import { Checkbox } from "../../forms/index";
|
|
5
4
|
import { MediaUploadField, MediaUploadList } from "../../media/index";
|
|
6
5
|
import { coerceMediaFieldArray, getMediaUrl, } from "../../media/types/index";
|
|
6
|
+
import { normalizeRichTextHtml } from "../../../utils/string.formatter";
|
|
7
7
|
export function BlogPostForm({ value, onChange, categoryOptions, statusOptions, labels, onUploadCover, onUploadContentImage, onUploadAdditionalImage, onAbort, isReadonly = false, renderContentField, renderContentReadonly, }) {
|
|
8
8
|
const coverImageUrl = getMediaUrl(value.coverImage);
|
|
9
9
|
const contentImages = coerceMediaFieldArray(value.contentImages);
|
|
@@ -18,7 +18,7 @@ export function BlogPostForm({ value, onChange, categoryOptions, statusOptions,
|
|
|
18
18
|
value: value.content || "",
|
|
19
19
|
onChange: (content) => update({ content }),
|
|
20
20
|
isReadonly,
|
|
21
|
-
})) : isReadonly && renderContentReadonly ? (renderContentReadonly(value.content || "")) : (_jsx(
|
|
21
|
+
})) : isReadonly && renderContentReadonly ? (renderContentReadonly(value.content || "")) : (_jsxs(Stack, { gap: "xs", children: [_jsx(RichTextEditor, { value: normalizeRichTextHtml(value.content || ""), onChange: (content) => update({ content }), disabled: isReadonly, minHeightClassName: "min-h-[240px]", placeholder: "Write blog content" }), _jsx(Text, { className: "text-xs text-zinc-500 dark:text-zinc-400", children: "Rich text is supported for blog content." })] }))] }), _jsx(MediaUploadField, { label: labels.coverImage, value: coverImageUrl || "", onChange: (url) => update({ coverImage: url ? { url, type: "image" } : null }), onChangeField: (media) => update({ coverImage: media }), onUpload: onUploadCover, onAbort: onAbort, accept: "image/*", maxSizeMB: 10, disabled: isReadonly, helperText: labels.coverImageHelper }), _jsx(MediaUploadList, { label: labels.contentImages, value: contentImages, onChange: (media) => update({ contentImages: media }), onUpload: onUploadContentImage, onAbort: onAbort, accept: "image/*", maxItems: 10, maxSizeMB: 10, disabled: isReadonly, helperText: labels.contentImagesHelper }), _jsx(MediaUploadList, { label: labels.additionalImages, value: additionalImages, onChange: (media) => update({ additionalImages: media }), onUpload: onUploadAdditionalImage, onAbort: onAbort, accept: "image/*", maxItems: 5, maxSizeMB: 10, disabled: isReadonly, helperText: labels.additionalImagesHelper }), _jsxs(Div, { className: "grid gap-4 md:grid-cols-2", children: [_jsx(Select, { label: labels.category, value: value.category, onValueChange: (category) => update({ category }), options: categoryOptions, disabled: isReadonly }), _jsx(Select, { label: labels.status, value: value.status, onValueChange: (status) => update({ status }), options: statusOptions, disabled: isReadonly })] }), _jsxs(Div, { className: "grid gap-4 md:grid-cols-2", children: [_jsx(TagInput, { label: labels.tags, value: value.tags ?? [], onChange: (tags) => update({ tags }), disabled: isReadonly }), _jsxs(Stack, { gap: "xs", children: [_jsx(Label, { htmlFor: "blog-post-read-time", children: labels.readTime }), _jsx(Input, { id: "blog-post-read-time", type: "number", value: String(value.readTimeMinutes ?? 5), onChange: (event) => update({
|
|
22
22
|
readTimeMinutes: parseInt(event.target.value, 10) || 5,
|
|
23
23
|
}), disabled: isReadonly })] })] }), _jsx(Checkbox, { label: labels.featured, checked: value.isFeatured || false, onChange: (event) => update({ isFeatured: event.target.checked }), disabled: isReadonly }), isReadonly && coverImageUrl && (_jsx(Text, { size: "xs", variant: "secondary", children: coverImageUrl }))] }));
|
|
24
24
|
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
"use client";
|
|
2
1
|
import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
2
|
import React from "react";
|
|
4
|
-
import { Div, Heading, Row, Span, Text } from "../../../ui";
|
|
3
|
+
import { Div, Heading, RichText, Row, Span, Text } from "../../../ui";
|
|
5
4
|
import { useBlogPost } from "../hooks/useBlog";
|
|
6
5
|
import { BlogCard } from "./BlogListView";
|
|
7
6
|
import { getMediaUrl } from "../../media/types/index";
|
|
8
7
|
import { getDefaultLocale } from "../../../core/baseline-resolver";
|
|
8
|
+
import { normalizeRichTextHtml } from "../../../utils/string.formatter";
|
|
9
9
|
const CATEGORY_BADGE = {
|
|
10
10
|
news: "bg-blue-100 text-blue-800",
|
|
11
11
|
tips: "bg-emerald-100 text-emerald-800",
|
|
@@ -35,5 +35,5 @@ export function BlogPostView({ slug, initialData, labels = {}, renderImage, rend
|
|
|
35
35
|
})
|
|
36
36
|
: "";
|
|
37
37
|
const coverImageUrl = getMediaUrl(post.coverImage);
|
|
38
|
-
return (_jsxs(Div, { className: `min-h-screen ${className}`, children: [coverImageUrl && (_jsxs(Div, { className: "relative h-72 md:h-96 overflow-hidden", children: [renderImage ? (renderImage(post)) : (_jsx(Div, { role: "img", "aria-label": post.title, className: "h-full w-full bg-cover bg-center", style: { backgroundImage: `url(${coverImageUrl})` } })), _jsx(Div, { className: "absolute inset-0 bg-gradient-to-t from-black/50 to-transparent" })] })), _jsxs(Div, { className: "max-w-3xl mx-auto px-4 py-12", children: [_jsxs(Div, { className: "mb-8", children: [_jsxs(Row, { className: "gap-2 mb-4", children: [_jsx(Span, { className: `inline-block px-2 py-0.5 rounded-full text-xs font-medium capitalize ${CATEGORY_BADGE[post.category] ?? ""}`, children: post.category }), post.isFeatured && (_jsx(Span, { className: "bg-yellow-100 text-yellow-800 px-2 py-0.5 rounded-full text-xs font-medium", children: labels.featured ?? "Featured" }))] }), _jsx(Heading, { level: 1, className: "text-3xl font-bold mb-4", children: post.title }), post.excerpt && (_jsx(Text, { className: "text-lg text-neutral-500 mb-6", children: post.excerpt })), _jsxs(Row, { wrap: true, gap: "md", className: "text-sm text-neutral-400", children: [post.authorName && (_jsxs(Span, { children: [labels.author ?? "By", " ", _jsx(Span, { className: "font-medium text-neutral-700", children: post.authorName })] })), post.readTimeMinutes != null && (_jsxs(Span, { children: [post.readTimeMinutes, " ", labels.readTime ?? "min read"] })), date && (_jsxs(Span, { children: [labels.publishedOn ?? "Published", " ", date] })), post.views != null && (_jsxs(Span, { children: [post.views, " ", labels.viewsLabel ?? "views"] }))] })] }), post.tags && post.tags.length > 0 && (_jsx(Row, { wrap: true, gap: "sm", className: "mb-8", children: post.tags.map((tag) => (_jsxs(Span, { className: "inline-block px-3 py-1 rounded-full bg-neutral-100 text-neutral-600 text-xs font-medium", children: ["#", tag] }, tag))) })), _jsx(Div, { className: "bg-white rounded-xl border border-neutral-200 p-8 mb-12", children: renderContent ? (renderContent(post)) : (_jsx(
|
|
38
|
+
return (_jsxs(Div, { className: `min-h-screen ${className}`, children: [coverImageUrl && (_jsxs(Div, { className: "relative h-72 md:h-96 overflow-hidden", children: [renderImage ? (renderImage(post)) : (_jsx(Div, { role: "img", "aria-label": post.title, className: "h-full w-full bg-cover bg-center", style: { backgroundImage: `url(${coverImageUrl})` } })), _jsx(Div, { className: "absolute inset-0 bg-gradient-to-t from-black/50 to-transparent" })] })), _jsxs(Div, { className: "max-w-3xl mx-auto px-4 py-12", children: [_jsxs(Div, { className: "mb-8", children: [_jsxs(Row, { className: "gap-2 mb-4", children: [_jsx(Span, { className: `inline-block px-2 py-0.5 rounded-full text-xs font-medium capitalize ${CATEGORY_BADGE[post.category] ?? ""}`, children: post.category }), post.isFeatured && (_jsx(Span, { className: "bg-yellow-100 text-yellow-800 px-2 py-0.5 rounded-full text-xs font-medium", children: labels.featured ?? "Featured" }))] }), _jsx(Heading, { level: 1, className: "text-3xl font-bold mb-4", children: post.title }), post.excerpt && (_jsx(Text, { className: "text-lg text-neutral-500 mb-6", children: post.excerpt })), _jsxs(Row, { wrap: true, gap: "md", className: "text-sm text-neutral-400", children: [post.authorName && (_jsxs(Span, { children: [labels.author ?? "By", " ", _jsx(Span, { className: "font-medium text-neutral-700", children: post.authorName })] })), post.readTimeMinutes != null && (_jsxs(Span, { children: [post.readTimeMinutes, " ", labels.readTime ?? "min read"] })), date && (_jsxs(Span, { children: [labels.publishedOn ?? "Published", " ", date] })), post.views != null && (_jsxs(Span, { children: [post.views, " ", labels.viewsLabel ?? "views"] }))] })] }), post.tags && post.tags.length > 0 && (_jsx(Row, { wrap: true, gap: "sm", className: "mb-8", children: post.tags.map((tag) => (_jsxs(Span, { className: "inline-block px-3 py-1 rounded-full bg-neutral-100 text-neutral-600 text-xs font-medium", children: ["#", tag] }, tag))) })), _jsx(Div, { className: "bg-white rounded-xl border border-neutral-200 p-8 mb-12", children: renderContent ? (renderContent(post)) : (_jsx(RichText, { html: normalizeRichTextHtml(post.content ?? ""), proseClass: "prose max-w-none dark:prose-invert", className: "text-neutral-800 dark:text-neutral-100" })) }), related.length > 0 && (_jsxs(Div, { children: [_jsx(Heading, { level: 2, className: "text-xl font-semibold mb-6", children: labels.relatedTitle ?? "Related Posts" }), _jsx(Div, { className: "grid sm:grid-cols-3 gap-6", children: related.map((rel, i) => renderRelatedCard ? (_jsx(React.Fragment, { children: renderRelatedCard(rel, i) }, rel.id)) : (_jsx(BlogCard, { post: rel }, rel.id))) })] })), renderBackButton && (_jsx(Div, { className: "mt-10 pt-8 border-t border-neutral-200", children: renderBackButton() }))] })] }));
|
|
39
39
|
}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
export { BlogCard, BlogCategoryTabs, BlogListView } from "./BlogListView";
|
|
2
|
+
export { BlogIndexListing } from "./BlogIndexListing";
|
|
3
|
+
export type { BlogIndexListingProps } from "./BlogIndexListing";
|
|
2
4
|
export { BlogFilters, BLOG_SORT_OPTIONS, BLOG_FILTER_KEYS, BLOG_ADMIN_SORT_OPTIONS, BLOG_SELLER_SORT_OPTIONS, BLOG_PUBLIC_SORT_OPTIONS, getBlogFilterKeys, getBlogSortOptions, } from "./BlogFilters";
|
|
3
5
|
export type { BlogFiltersProps, BlogFilterVariant } from "./BlogFilters";
|
|
4
6
|
export { BlogFeaturedCard } from "./BlogFeaturedCard";
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export { BlogCard, BlogCategoryTabs, BlogListView } from "./BlogListView";
|
|
2
|
+
export { BlogIndexListing } from "./BlogIndexListing";
|
|
2
3
|
export { BlogFilters, BLOG_SORT_OPTIONS, BLOG_FILTER_KEYS, BLOG_ADMIN_SORT_OPTIONS, BLOG_SELLER_SORT_OPTIONS, BLOG_PUBLIC_SORT_OPTIONS, getBlogFilterKeys, getBlogSortOptions, } from "./BlogFilters";
|
|
3
4
|
export { BlogFeaturedCard } from "./BlogFeaturedCard";
|
|
4
5
|
export { BlogPostForm } from "./BlogPostForm";
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import "server-only";
|
|
2
1
|
import type { FirebaseSieveResult, SieveModel } from "../../../providers/db-firebase";
|
|
3
2
|
import { BaseRepository } from "../../../providers/db-firebase";
|
|
4
3
|
import { type BlogPostCreateInput, type BlogPostDocument, type BlogPostUpdateInput } from "../schemas";
|