@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.
Files changed (1022) hide show
  1. package/README.md +94 -31
  2. package/dist/client.d.ts +95 -15
  3. package/dist/client.js +143 -15
  4. package/dist/constants/api-endpoints.d.ts +46 -0
  5. package/dist/constants/api-endpoints.js +23 -0
  6. package/dist/constants/index.d.ts +1 -0
  7. package/dist/constants/index.js +1 -0
  8. package/dist/contracts/auth.js +1 -1
  9. package/dist/contracts/client-auth.js +1 -1
  10. package/dist/contracts/client-payment-gateway.js +1 -1
  11. package/dist/contracts/client-realtime.js +1 -1
  12. package/dist/contracts/client-session.js +17 -5
  13. package/dist/contracts/config.js +1 -1
  14. package/dist/contracts/email.js +1 -1
  15. package/dist/contracts/feature.js +1 -1
  16. package/dist/contracts/field-ops.js +2 -2
  17. package/dist/contracts/form.js +1 -1
  18. package/dist/contracts/infra.js +1 -1
  19. package/dist/contracts/payment.js +1 -1
  20. package/dist/contracts/repository.js +2 -2
  21. package/dist/contracts/search.js +1 -1
  22. package/dist/contracts/shipping.js +1 -1
  23. package/dist/contracts/storage.js +1 -1
  24. package/dist/contracts/style.js +1 -1
  25. package/dist/core/hooks/useSiteSettings.js +0 -1
  26. package/dist/core/index.d.ts +1 -0
  27. package/dist/core/index.js +1 -0
  28. package/dist/core/integration-keys.d.ts +0 -16
  29. package/dist/core/integration-keys.js +0 -1
  30. package/dist/core/mutation-events.js +2 -2
  31. package/dist/core/server-action.js +5 -5
  32. package/dist/core/unit-of-work.d.ts +13 -14
  33. package/dist/core/unit-of-work.js +0 -1
  34. package/dist/errors/messages.d.ts +1 -0
  35. package/dist/errors/messages.js +1 -0
  36. package/dist/features/about/components/AboutView.d.ts +14 -14
  37. package/dist/features/about/components/AboutView.js +2 -2
  38. package/dist/features/about/components/FAQPageView.d.ts +6 -0
  39. package/dist/features/about/components/FAQPageView.js +29 -0
  40. package/dist/features/about/components/FeesView.d.ts +4 -0
  41. package/dist/features/about/components/FeesView.js +63 -0
  42. package/dist/features/about/components/HelpPageView.d.ts +4 -0
  43. package/dist/features/about/components/HelpPageView.js +63 -0
  44. package/dist/features/about/components/HowAuctionsWorkView.d.ts +4 -0
  45. package/dist/features/about/components/HowAuctionsWorkView.js +87 -0
  46. package/dist/features/about/components/HowCheckoutWorksView.d.ts +4 -0
  47. package/dist/features/about/components/HowCheckoutWorksView.js +73 -0
  48. package/dist/features/about/components/HowOffersWorkView.d.ts +4 -0
  49. package/dist/features/about/components/HowOffersWorkView.js +58 -0
  50. package/dist/features/about/components/HowOrdersWorkView.d.ts +4 -0
  51. package/dist/features/about/components/HowOrdersWorkView.js +131 -0
  52. package/dist/features/about/components/HowPayoutsWorkView.d.ts +4 -0
  53. package/dist/features/about/components/HowPayoutsWorkView.js +87 -0
  54. package/dist/features/about/components/HowPreOrdersWorkView.d.ts +4 -0
  55. package/dist/features/about/components/HowPreOrdersWorkView.js +87 -0
  56. package/dist/features/about/components/HowReviewsWorkView.d.ts +4 -0
  57. package/dist/features/about/components/HowReviewsWorkView.js +72 -0
  58. package/dist/features/about/components/PolicyPageView.d.ts +6 -0
  59. package/dist/features/about/components/PolicyPageView.js +28 -0
  60. package/dist/features/about/components/PublicProfileView.d.ts +5 -0
  61. package/dist/features/about/components/PublicProfileView.js +21 -0
  62. package/dist/features/about/components/SecurityPrivacyView.d.ts +4 -0
  63. package/dist/features/about/components/SecurityPrivacyView.js +122 -0
  64. package/dist/features/about/components/ShippingPolicyView.d.ts +4 -0
  65. package/dist/features/about/components/ShippingPolicyView.js +59 -0
  66. package/dist/features/about/components/TrackOrderView.d.ts +4 -0
  67. package/dist/features/about/components/TrackOrderView.js +43 -0
  68. package/dist/features/about/components/UnauthorizedView.d.ts +4 -0
  69. package/dist/features/about/components/UnauthorizedView.js +29 -0
  70. package/dist/features/about/index.d.ts +32 -0
  71. package/dist/features/about/index.js +16 -0
  72. package/dist/features/account/components/AddressBook.js +3 -2
  73. package/dist/features/account/components/AddressForm.js +2 -1
  74. package/dist/features/account/components/AddressSelectorCreate.js +2 -1
  75. package/dist/features/account/components/ChatList.js +0 -1
  76. package/dist/features/account/components/ChatWindow.js +2 -2
  77. package/dist/features/account/components/MessagesView.js +2 -1
  78. package/dist/features/account/components/NotificationBell.js +3 -2
  79. package/dist/features/account/components/UserSidebar.d.ts +15 -0
  80. package/dist/features/account/components/UserSidebar.js +18 -0
  81. package/dist/features/account/components/index.d.ts +2 -0
  82. package/dist/features/account/components/index.js +1 -0
  83. package/dist/features/account/hooks/useAccount.js +0 -1
  84. package/dist/features/account/hooks/useAddressSelector.js +0 -1
  85. package/dist/features/account/hooks/useAddresses.js +0 -1
  86. package/dist/features/account/hooks/useNotifications.js +0 -1
  87. package/dist/features/account/hooks/useProfile.js +0 -1
  88. package/dist/features/account/hooks/useProfileStats.js +0 -1
  89. package/dist/features/account/hooks/usePublicProfile.js +0 -1
  90. package/dist/features/account/repository/address.repository.js +2 -3
  91. package/dist/features/account/schemas/index.d.ts +20 -20
  92. package/dist/features/account/schemas/index.js +2 -2
  93. package/dist/features/account/server.d.ts +0 -1
  94. package/dist/features/account/server.js +0 -1
  95. package/dist/features/account/types/index.js +1 -1
  96. package/dist/features/admin/components/AdminAdEditorView.d.ts +10 -0
  97. package/dist/features/admin/components/AdminAdEditorView.js +225 -0
  98. package/dist/features/admin/components/AdminAdsView.d.ts +25 -0
  99. package/dist/features/admin/components/AdminAdsView.js +165 -0
  100. package/dist/features/admin/components/AdminAnalyticsView.d.ts +2 -1
  101. package/dist/features/admin/components/AdminAnalyticsView.js +19 -5
  102. package/dist/features/admin/components/AdminBidsView.d.ts +1 -1
  103. package/dist/features/admin/components/AdminBidsView.js +26 -2
  104. package/dist/features/admin/components/AdminBlogView.d.ts +1 -1
  105. package/dist/features/admin/components/AdminBlogView.js +34 -2
  106. package/dist/features/admin/components/AdminCarouselView.d.ts +3 -8
  107. package/dist/features/admin/components/AdminCarouselView.js +39 -4
  108. package/dist/features/admin/components/AdminCategoriesView.d.ts +3 -8
  109. package/dist/features/admin/components/AdminCategoriesView.js +40 -4
  110. package/dist/features/admin/components/AdminCouponsView.d.ts +1 -1
  111. package/dist/features/admin/components/AdminCouponsView.js +28 -2
  112. package/dist/features/admin/components/AdminDashboardView.d.ts +2 -1
  113. package/dist/features/admin/components/AdminDashboardView.js +28 -3
  114. package/dist/features/admin/components/AdminFaqsView.d.ts +1 -1
  115. package/dist/features/admin/components/AdminFaqsView.js +23 -2
  116. package/dist/features/admin/components/AdminFeatureFlagsView.js +48 -3
  117. package/dist/features/admin/components/AdminFilterBar.js +3 -4
  118. package/dist/features/admin/components/AdminListingScaffold.d.ts +26 -0
  119. package/dist/features/admin/components/AdminListingScaffold.js +57 -0
  120. package/dist/features/admin/components/AdminMediaView.d.ts +7 -7
  121. package/dist/features/admin/components/AdminMediaView.js +50 -4
  122. package/dist/features/admin/components/AdminNavigationView.d.ts +7 -3
  123. package/dist/features/admin/components/AdminNavigationView.js +81 -4
  124. package/dist/features/admin/components/AdminOrdersView.d.ts +1 -1
  125. package/dist/features/admin/components/AdminOrdersView.js +28 -2
  126. package/dist/features/admin/components/AdminPageHeader.js +1 -2
  127. package/dist/features/admin/components/AdminPayoutsView.d.ts +1 -1
  128. package/dist/features/admin/components/AdminPayoutsView.js +28 -2
  129. package/dist/features/admin/components/AdminProductsView.d.ts +1 -1
  130. package/dist/features/admin/components/AdminProductsView.js +26 -2
  131. package/dist/features/admin/components/AdminReviewsView.d.ts +1 -1
  132. package/dist/features/admin/components/AdminReviewsView.js +24 -2
  133. package/dist/features/admin/components/AdminSectionsView.d.ts +3 -7
  134. package/dist/features/admin/components/AdminSectionsView.js +947 -4
  135. package/dist/features/admin/components/AdminSessionsManager.js +1 -2
  136. package/dist/features/admin/components/AdminSidebar.d.ts +5 -1
  137. package/dist/features/admin/components/AdminSidebar.js +5 -4
  138. package/dist/features/admin/components/AdminSiteView.js +43 -3
  139. package/dist/features/admin/components/AdminStoresView.d.ts +1 -1
  140. package/dist/features/admin/components/AdminStoresView.js +26 -2
  141. package/dist/features/admin/components/AdminUsersView.d.ts +1 -1
  142. package/dist/features/admin/components/AdminUsersView.js +38 -2
  143. package/dist/features/admin/components/DashboardStats.js +7 -7
  144. package/dist/features/admin/components/DataTable.js +2 -2
  145. package/dist/features/admin/components/DrawerFormFooter.js +1 -2
  146. package/dist/features/admin/components/QuickActionsPanel.js +1 -2
  147. package/dist/features/admin/components/analytics/AdminStatCard.js +0 -1
  148. package/dist/features/admin/components/analytics/AdminTopProductsTable.js +1 -2
  149. package/dist/features/admin/components/index.d.ts +4 -0
  150. package/dist/features/admin/components/index.js +2 -0
  151. package/dist/features/admin/hooks/useAdmin.js +0 -1
  152. package/dist/features/admin/hooks/useAdminListingData.d.ts +28 -0
  153. package/dist/features/admin/hooks/useAdminListingData.js +100 -0
  154. package/dist/features/admin/hooks/useAdminSectionsListing.d.ts +28 -0
  155. package/dist/features/admin/hooks/useAdminSectionsListing.js +34 -0
  156. package/dist/features/admin/index.d.ts +2 -0
  157. package/dist/features/admin/index.js +2 -0
  158. package/dist/features/admin/repository/chat.repository.d.ts +1 -1
  159. package/dist/features/admin/repository/chat.repository.js +1 -1
  160. package/dist/features/admin/repository/notification.repository.d.ts +0 -1
  161. package/dist/features/admin/repository/notification.repository.js +9 -7
  162. package/dist/features/admin/repository/site-settings.repository.d.ts +2 -0
  163. package/dist/features/admin/repository/site-settings.repository.js +25 -2
  164. package/dist/features/admin/schemas/firestore.d.ts +5 -1
  165. package/dist/features/admin/schemas/firestore.js +5 -0
  166. package/dist/features/admin/server.d.ts +0 -1
  167. package/dist/features/admin/server.js +0 -1
  168. package/dist/features/auctions/actions/bid-actions.js +1 -1
  169. package/dist/features/auctions/api/route.js +1 -1
  170. package/dist/features/auctions/columns/index.js +2 -2
  171. package/dist/features/auctions/components/AuctionCard.js +3 -2
  172. package/dist/features/auctions/components/AuctionDetailPageView.d.ts +4 -0
  173. package/dist/features/auctions/components/AuctionDetailPageView.js +71 -0
  174. package/dist/features/auctions/components/AuctionsListView.d.ts +1 -0
  175. package/dist/features/auctions/components/AuctionsListView.js +17 -0
  176. package/dist/features/auctions/components/MarketplaceAuctionCard.js +5 -2
  177. package/dist/features/auctions/components/MarketplaceAuctionGrid.js +0 -1
  178. package/dist/features/auctions/components/index.d.ts +3 -0
  179. package/dist/features/auctions/components/index.js +2 -0
  180. package/dist/features/auctions/hooks/useAuctions.js +0 -1
  181. package/dist/features/auctions/hooks/usePlaceBid.js +0 -1
  182. package/dist/features/auctions/repository/bid.repository.js +3 -13
  183. package/dist/features/auctions/schemas/index.d.ts +22 -22
  184. package/dist/features/auctions/schemas/index.js +2 -2
  185. package/dist/features/auctions/server.d.ts +0 -1
  186. package/dist/features/auctions/server.js +0 -1
  187. package/dist/features/auth/api/route.js +2 -2
  188. package/dist/features/auth/components/AuthStatusPanel.js +3 -3
  189. package/dist/features/auth/components/ForgotPasswordView.js +2 -2
  190. package/dist/features/auth/components/Guards.d.ts +2 -2
  191. package/dist/features/auth/components/Guards.js +2 -2
  192. package/dist/features/auth/components/LoginForm.js +1 -1
  193. package/dist/features/auth/components/OAuthLoadingView.d.ts +1 -0
  194. package/dist/features/auth/components/OAuthLoadingView.js +5 -0
  195. package/dist/features/auth/components/RegisterForm.js +1 -1
  196. package/dist/features/auth/components/ResetPasswordView.js +1 -1
  197. package/dist/features/auth/components/SocialAuthButtons.js +1 -2
  198. package/dist/features/auth/components/VerifyEmailView.js +4 -3
  199. package/dist/features/auth/components/index.d.ts +1 -0
  200. package/dist/features/auth/components/index.js +1 -0
  201. package/dist/features/auth/consent-otp.d.ts +5 -3
  202. package/dist/features/auth/consent-otp.js +0 -1
  203. package/dist/features/auth/hooks/useAuth.d.ts +0 -1
  204. package/dist/features/auth/hooks/useAuth.js +0 -1
  205. package/dist/features/auth/hooks/useAuthEvent.js +0 -1
  206. package/dist/features/auth/hooks/useLogout.js +0 -1
  207. package/dist/features/auth/repository/session.repository.d.ts +0 -1
  208. package/dist/features/auth/repository/session.repository.js +0 -1
  209. package/dist/features/auth/repository/token.repository.d.ts +0 -1
  210. package/dist/features/auth/repository/token.repository.js +0 -1
  211. package/dist/features/auth/repository/user.repository.d.ts +0 -1
  212. package/dist/features/auth/repository/user.repository.js +18 -29
  213. package/dist/features/auth/schemas/firestore.js +1 -1
  214. package/dist/features/auth/schemas/index.d.ts +4 -4
  215. package/dist/features/auth/schemas/index.js +2 -2
  216. package/dist/features/auth/server.d.ts +0 -1
  217. package/dist/features/auth/server.js +0 -1
  218. package/dist/features/auth/token-store.d.ts +0 -1
  219. package/dist/features/auth/token-store.js +0 -1
  220. package/dist/features/before-after/hooks/useBeforeAfter.js +0 -1
  221. package/dist/features/before-after/schemas/index.d.ts +2 -2
  222. package/dist/features/before-after/server.d.ts +0 -1
  223. package/dist/features/before-after/server.js +0 -1
  224. package/dist/features/blog/actions/blog-actions.d.ts +53 -53
  225. package/dist/features/blog/actions/blog-actions.js +2 -2
  226. package/dist/features/blog/api/[slug]/route.js +1 -1
  227. package/dist/features/blog/api/route.js +1 -1
  228. package/dist/features/blog/components/BlogFeaturedCard.js +9 -7
  229. package/dist/features/blog/components/BlogFilters.js +0 -1
  230. package/dist/features/blog/components/BlogIndexListing.d.ts +4 -0
  231. package/dist/features/blog/components/BlogIndexListing.js +26 -0
  232. package/dist/features/blog/components/BlogIndexPageView.d.ts +1 -0
  233. package/dist/features/blog/components/BlogIndexPageView.js +11 -0
  234. package/dist/features/blog/components/BlogListView.js +4 -3
  235. package/dist/features/blog/components/BlogPostForm.js +3 -3
  236. package/dist/features/blog/components/BlogPostView.js +3 -3
  237. package/dist/features/blog/components/index.d.ts +2 -0
  238. package/dist/features/blog/components/index.js +1 -0
  239. package/dist/features/blog/hooks/useBlog.js +0 -1
  240. package/dist/features/blog/repository/blog.repository.d.ts +0 -1
  241. package/dist/features/blog/repository/blog.repository.js +0 -1
  242. package/dist/features/blog/schemas/index.d.ts +35 -35
  243. package/dist/features/blog/schemas/index.js +2 -2
  244. package/dist/features/blog/server.d.ts +0 -1
  245. package/dist/features/blog/server.js +0 -1
  246. package/dist/features/cart/components/CartDrawer.js +5 -4
  247. package/dist/features/cart/components/CartSummary.js +1 -1
  248. package/dist/features/cart/components/CartView.js +1 -1
  249. package/dist/features/cart/components/CheckoutAddressStep.js +0 -1
  250. package/dist/features/cart/components/CheckoutOtpModal.js +1 -2
  251. package/dist/features/cart/components/CheckoutView.js +1 -1
  252. package/dist/features/cart/hooks/useCart.js +0 -1
  253. package/dist/features/cart/hooks/useCartCount.js +0 -1
  254. package/dist/features/cart/hooks/useCartQuery.js +0 -1
  255. package/dist/features/cart/hooks/useCheckoutReadQueries.js +0 -1
  256. package/dist/features/cart/hooks/useOrder.js +0 -1
  257. package/dist/features/cart/repository/cart.repository.d.ts +0 -1
  258. package/dist/features/cart/repository/cart.repository.js +0 -1
  259. package/dist/features/cart/schemas/index.d.ts +19 -19
  260. package/dist/features/cart/server.d.ts +0 -1
  261. package/dist/features/cart/server.js +0 -1
  262. package/dist/features/cart/utils/guest-cart.d.ts +0 -1
  263. package/dist/features/cart/utils/guest-cart.js +0 -1
  264. package/dist/features/categories/api/[id]/route.js +3 -3
  265. package/dist/features/categories/api/route.js +5 -5
  266. package/dist/features/categories/components/BreadcrumbTrail.js +0 -1
  267. package/dist/features/categories/components/CategoriesIndexListing.d.ts +5 -0
  268. package/dist/features/categories/components/CategoriesIndexListing.js +44 -0
  269. package/dist/features/categories/components/CategoriesIndexPageView.d.ts +1 -0
  270. package/dist/features/categories/components/CategoriesIndexPageView.js +12 -0
  271. package/dist/features/categories/components/CategoriesListView.js +3 -3
  272. package/dist/features/categories/components/CategoryDetailPageView.d.ts +4 -0
  273. package/dist/features/categories/components/CategoryDetailPageView.js +25 -0
  274. package/dist/features/categories/components/CategoryFilters.js +0 -1
  275. package/dist/features/categories/components/CategoryForm.js +4 -4
  276. package/dist/features/categories/components/CategoryGrid.d.ts +2 -1
  277. package/dist/features/categories/components/CategoryGrid.js +11 -5
  278. package/dist/features/categories/components/CategoryProductsListing.d.ts +5 -0
  279. package/dist/features/categories/components/CategoryProductsListing.js +29 -0
  280. package/dist/features/categories/components/CategoryProductsView.js +3 -3
  281. package/dist/features/categories/components/CategorySelectorCreate.js +2 -2
  282. package/dist/features/categories/components/CategorySortSelect.js +0 -1
  283. package/dist/features/categories/components/CategoryTableColumns.js +3 -3
  284. package/dist/features/categories/components/CategoryTree.js +1 -1
  285. package/dist/features/categories/components/ConcernCard.js +2 -1
  286. package/dist/features/categories/components/index.d.ts +4 -0
  287. package/dist/features/categories/components/index.js +2 -0
  288. package/dist/features/categories/hooks/useCategories.js +0 -1
  289. package/dist/features/categories/hooks/useCategorySelector.js +0 -1
  290. package/dist/features/categories/repository/categories.repository.d.ts +0 -1
  291. package/dist/features/categories/repository/categories.repository.js +0 -1
  292. package/dist/features/categories/schemas/index.d.ts +40 -40
  293. package/dist/features/categories/schemas/index.js +2 -2
  294. package/dist/features/categories/server.d.ts +0 -1
  295. package/dist/features/categories/server.js +0 -1
  296. package/dist/features/checkout/actions/checkout-actions.d.ts +7 -1
  297. package/dist/features/checkout/actions/checkout-actions.js +0 -1
  298. package/dist/features/checkout/components/CheckoutStepper.js +4 -3
  299. package/dist/features/checkout/hooks/useCheckoutApi.js +0 -1
  300. package/dist/features/checkout/hooks/usePaymentCheckout.d.ts +0 -1
  301. package/dist/features/checkout/hooks/usePaymentCheckout.js +1 -2
  302. package/dist/features/checkout/server.d.ts +0 -1
  303. package/dist/features/checkout/server.js +0 -1
  304. package/dist/features/collections/components/CollectionCard.js +2 -2
  305. package/dist/features/collections/hooks/useCollections.js +0 -1
  306. package/dist/features/collections/schemas/index.d.ts +5 -5
  307. package/dist/features/collections/server.d.ts +0 -1
  308. package/dist/features/collections/server.js +0 -1
  309. package/dist/features/consultation/hooks/useBookConsultation.js +0 -1
  310. package/dist/features/consultation/schemas/index.d.ts +7 -7
  311. package/dist/features/consultation/server.d.ts +0 -1
  312. package/dist/features/consultation/server.js +0 -1
  313. package/dist/features/contact/components/ContactInfoSidebar.js +1 -2
  314. package/dist/features/contact/components/ContactPageView.d.ts +1 -0
  315. package/dist/features/contact/components/ContactPageView.js +45 -0
  316. package/dist/features/contact/components/index.d.ts +1 -0
  317. package/dist/features/contact/components/index.js +1 -0
  318. package/dist/features/contact/email.d.ts +0 -1
  319. package/dist/features/contact/email.js +0 -1
  320. package/dist/features/contact/hooks/useContactSubmit.js +0 -1
  321. package/dist/features/contact/server.d.ts +0 -1
  322. package/dist/features/contact/server.js +0 -1
  323. package/dist/features/copilot/components/AdminCopilotView.d.ts +5 -5
  324. package/dist/features/copilot/components/AdminCopilotView.js +26 -11
  325. package/dist/features/copilot/hooks/useCopilotChat.d.ts +3 -0
  326. package/dist/features/copilot/hooks/useCopilotChat.js +9 -1
  327. package/dist/features/copilot/hooks/useCopilotFeedback.js +0 -1
  328. package/dist/features/corporate/hooks/useSubmitCorporateInquiry.js +0 -1
  329. package/dist/features/corporate/schemas/index.d.ts +1 -1
  330. package/dist/features/corporate/server.d.ts +0 -1
  331. package/dist/features/corporate/server.js +0 -1
  332. package/dist/features/cron/firebase-adapters.js +2 -2
  333. package/dist/features/cron/index.js +3 -3
  334. package/dist/features/cron/registry.js +4 -4
  335. package/dist/features/events/actions/event-actions.js +7 -7
  336. package/dist/features/events/api/[id]/route.js +1 -1
  337. package/dist/features/events/components/AdminEventEntriesView.d.ts +7 -2
  338. package/dist/features/events/components/AdminEventEntriesView.js +114 -7
  339. package/dist/features/events/components/AdminEventsView.d.ts +3 -10
  340. package/dist/features/events/components/AdminEventsView.js +34 -4
  341. package/dist/features/events/components/EventBanner.js +1 -1
  342. package/dist/features/events/components/EventCard.d.ts +1 -0
  343. package/dist/features/events/components/EventCard.js +7 -5
  344. package/dist/features/events/components/EventFilters.js +0 -1
  345. package/dist/features/events/components/EventFormDrawer.js +1 -1
  346. package/dist/features/events/components/EventLeaderboard.js +3 -3
  347. package/dist/features/events/components/EventParticipateView.js +2 -2
  348. package/dist/features/events/components/EventsIndexListing.d.ts +4 -0
  349. package/dist/features/events/components/EventsIndexListing.js +24 -0
  350. package/dist/features/events/components/EventsListPageView.d.ts +1 -0
  351. package/dist/features/events/components/EventsListPageView.js +16 -0
  352. package/dist/features/events/components/index.d.ts +2 -0
  353. package/dist/features/events/components/index.js +1 -0
  354. package/dist/features/events/hooks/useBulkEvent.js +0 -1
  355. package/dist/features/events/hooks/useEvent.js +0 -1
  356. package/dist/features/events/hooks/useEvents.js +0 -1
  357. package/dist/features/events/schemas/index.d.ts +45 -45
  358. package/dist/features/events/schemas/index.js +2 -2
  359. package/dist/features/events/server.d.ts +0 -1
  360. package/dist/features/events/server.js +0 -1
  361. package/dist/features/faq/actions/faq-actions.d.ts +20 -20
  362. package/dist/features/faq/actions/faq-actions.js +2 -2
  363. package/dist/features/faq/components/ContactCTA.js +0 -1
  364. package/dist/features/faq/components/FAQAccordion.js +5 -5
  365. package/dist/features/faq/components/FAQCategorySidebar.js +0 -1
  366. package/dist/features/faq/components/FAQHelpfulButtons.js +2 -2
  367. package/dist/features/faq/components/FAQPageContent.d.ts +4 -1
  368. package/dist/features/faq/components/FAQPageContent.js +14 -15
  369. package/dist/features/faq/components/FAQSortDropdown.js +1 -2
  370. package/dist/features/faq/components/RelatedFAQs.js +0 -1
  371. package/dist/features/faq/hooks/useFAQs.js +0 -1
  372. package/dist/features/faq/hooks/useFaqList.js +0 -1
  373. package/dist/features/faq/hooks/useFaqVote.js +0 -1
  374. package/dist/features/faq/repository/faqs.repository.d.ts +0 -1
  375. package/dist/features/faq/repository/faqs.repository.js +0 -1
  376. package/dist/features/faq/schemas/index.d.ts +18 -18
  377. package/dist/features/faq/schemas/index.js +2 -2
  378. package/dist/features/faq/server.d.ts +0 -1
  379. package/dist/features/faq/server.js +0 -1
  380. package/dist/features/filters/FilterFacetSection.js +1 -1
  381. package/dist/features/filters/index.d.ts +4 -0
  382. package/dist/features/filters/index.js +2 -0
  383. package/dist/features/filters/routeFilterState.d.ts +58 -0
  384. package/dist/features/filters/routeFilterState.js +97 -0
  385. package/dist/features/filters/usePendingFilters.d.ts +37 -0
  386. package/dist/features/filters/usePendingFilters.js +22 -0
  387. package/dist/features/forms/Checkbox.js +1 -0
  388. package/dist/features/forms/Form.js +1 -2
  389. package/dist/features/forms/Radio.js +0 -1
  390. package/dist/features/forms/utils.js +1 -1
  391. package/dist/features/homepage/actions/homepage-section-actions.js +2 -2
  392. package/dist/features/homepage/ad-registry.d.ts +96 -0
  393. package/dist/features/homepage/ad-registry.js +84 -0
  394. package/dist/features/homepage/api/[id]/route.js +3 -3
  395. package/dist/features/homepage/api/carousel/[id]/route.js +3 -3
  396. package/dist/features/homepage/api/carousel/route.js +1 -1
  397. package/dist/features/homepage/api/route.js +1 -1
  398. package/dist/features/homepage/components/AdSlot.d.ts +28 -0
  399. package/dist/features/homepage/components/AdSlot.js +85 -0
  400. package/dist/features/homepage/components/AdvertisementBanner.js +8 -8
  401. package/dist/features/homepage/components/AnnouncementBar.d.ts +5 -0
  402. package/dist/features/homepage/components/AnnouncementBar.js +10 -0
  403. package/dist/features/homepage/components/BeforeAfterCard.d.ts +0 -1
  404. package/dist/features/homepage/components/BeforeAfterCard.js +0 -1
  405. package/dist/features/homepage/components/BlogArticlesSection.d.ts +8 -0
  406. package/dist/features/homepage/components/BlogArticlesSection.js +12 -0
  407. package/dist/features/homepage/components/BrandsSection.d.ts +9 -0
  408. package/dist/features/homepage/components/BrandsSection.js +20 -0
  409. package/dist/features/homepage/components/CTABannerSection.d.ts +10 -0
  410. package/dist/features/homepage/components/CTABannerSection.js +6 -0
  411. package/dist/features/homepage/components/CharacterHotspot.d.ts +0 -1
  412. package/dist/features/homepage/components/CharacterHotspot.js +4 -4
  413. package/dist/features/homepage/components/CustomerReviewsSection.js +3 -4
  414. package/dist/features/homepage/components/EventsSection.d.ts +9 -0
  415. package/dist/features/homepage/components/EventsSection.js +10 -0
  416. package/dist/features/homepage/components/FAQSection.d.ts +0 -1
  417. package/dist/features/homepage/components/FAQSection.js +4 -4
  418. package/dist/features/homepage/components/FeaturedAuctionsSection.d.ts +8 -0
  419. package/dist/features/homepage/components/FeaturedAuctionsSection.js +10 -0
  420. package/dist/features/homepage/components/FeaturedPreOrdersSection.d.ts +8 -0
  421. package/dist/features/homepage/components/FeaturedPreOrdersSection.js +10 -0
  422. package/dist/features/homepage/components/FeaturedProductsSection.d.ts +8 -0
  423. package/dist/features/homepage/components/FeaturedProductsSection.js +11 -0
  424. package/dist/features/homepage/components/FeaturedResultsSection.js +9 -9
  425. package/dist/features/homepage/components/FeaturedStoresSection.d.ts +9 -0
  426. package/dist/features/homepage/components/FeaturedStoresSection.js +11 -0
  427. package/dist/features/homepage/components/HeroCarousel.d.ts +1 -2
  428. package/dist/features/homepage/components/HeroCarousel.js +5 -12
  429. package/dist/features/homepage/components/HomepageCustomerReviewsSection.d.ts +8 -0
  430. package/dist/features/homepage/components/HomepageCustomerReviewsSection.js +9 -0
  431. package/dist/features/homepage/components/HomepageSkeleton.js +1 -2
  432. package/dist/features/homepage/components/HowItWorksInfoView.js +2 -2
  433. package/dist/features/homepage/components/HowItWorksSection.js +4 -4
  434. package/dist/features/homepage/components/MarketplaceHomepageView.d.ts +25 -0
  435. package/dist/features/homepage/components/MarketplaceHomepageView.js +252 -0
  436. package/dist/features/homepage/components/NewsletterSection.js +2 -3
  437. package/dist/features/homepage/components/SectionCarousel.js +13 -7
  438. package/dist/features/homepage/components/SecurityHighlightsSection.js +4 -4
  439. package/dist/features/homepage/components/ShopByCategorySection.d.ts +9 -0
  440. package/dist/features/homepage/components/ShopByCategorySection.js +21 -0
  441. package/dist/features/homepage/components/SiteFeaturesSection.js +2 -3
  442. package/dist/features/homepage/components/StatsCounterSection.js +5 -5
  443. package/dist/features/homepage/components/TrustFeaturesSection.js +7 -7
  444. package/dist/features/homepage/components/TrustIndicatorsSection.js +2 -3
  445. package/dist/features/homepage/components/WelcomeSection.d.ts +3 -1
  446. package/dist/features/homepage/components/WelcomeSection.js +5 -5
  447. package/dist/features/homepage/components/WhatsAppCommunitySection.d.ts +0 -1
  448. package/dist/features/homepage/components/WhatsAppCommunitySection.js +4 -5
  449. package/dist/features/homepage/components/index.d.ts +24 -0
  450. package/dist/features/homepage/components/index.js +12 -0
  451. package/dist/features/homepage/hooks/useBlogArticles.js +0 -1
  452. package/dist/features/homepage/hooks/useFeaturedAuctions.js +0 -1
  453. package/dist/features/homepage/hooks/useFeaturedPreOrders.js +0 -1
  454. package/dist/features/homepage/hooks/useFeaturedProducts.js +0 -1
  455. package/dist/features/homepage/hooks/useFeaturedStores.d.ts +2 -0
  456. package/dist/features/homepage/hooks/useFeaturedStores.js +14 -0
  457. package/dist/features/homepage/hooks/useHeroCarousel.js +0 -1
  458. package/dist/features/homepage/hooks/useHomepage.js +0 -1
  459. package/dist/features/homepage/hooks/useHomepageEvents.d.ts +6 -0
  460. package/dist/features/homepage/hooks/useHomepageEvents.js +14 -0
  461. package/dist/features/homepage/hooks/useHomepageReviews.js +0 -1
  462. package/dist/features/homepage/hooks/useHomepageSections.js +0 -1
  463. package/dist/features/homepage/hooks/useNewsletter.js +0 -1
  464. package/dist/features/homepage/hooks/useTopBrands.js +0 -1
  465. package/dist/features/homepage/hooks/useTopCategories.js +0 -1
  466. package/dist/features/homepage/index.d.ts +4 -0
  467. package/dist/features/homepage/index.js +3 -0
  468. package/dist/features/homepage/repository/carousel.repository.d.ts +0 -1
  469. package/dist/features/homepage/repository/carousel.repository.js +2 -8
  470. package/dist/features/homepage/schemas/firestore.d.ts +20 -2
  471. package/dist/features/homepage/schemas/firestore.js +10 -8
  472. package/dist/features/homepage/server.d.ts +0 -1
  473. package/dist/features/homepage/server.js +0 -1
  474. package/dist/features/layout/AppLayoutShell.d.ts +98 -0
  475. package/dist/features/layout/AppLayoutShell.js +147 -0
  476. package/dist/features/layout/AutoBreadcrumbs.js +5 -5
  477. package/dist/features/layout/BackToTop.d.ts +0 -1
  478. package/dist/features/layout/BackToTop.js +0 -1
  479. package/dist/features/layout/BottomActions.js +8 -11
  480. package/dist/features/layout/BottomActionsContext.js +2 -2
  481. package/dist/features/layout/BottomNavItem.js +0 -1
  482. package/dist/features/layout/BottomNavLayout.js +1 -2
  483. package/dist/features/layout/BottomNavbar.d.ts +7 -0
  484. package/dist/features/layout/BottomNavbar.js +13 -6
  485. package/dist/features/layout/BottomSheet.d.ts +0 -1
  486. package/dist/features/layout/BottomSheet.js +0 -1
  487. package/dist/features/layout/Breadcrumbs.js +3 -3
  488. package/dist/features/layout/DashboardNavContext.d.ts +10 -2
  489. package/dist/features/layout/DashboardNavContext.js +35 -3
  490. package/dist/features/layout/FooterLayout.js +4 -2
  491. package/dist/features/layout/LayoutClient.js +0 -1
  492. package/dist/features/layout/ListingLayout.d.ts +0 -1
  493. package/dist/features/layout/ListingLayout.js +0 -1
  494. package/dist/features/layout/LocaleSwitcher.js +0 -1
  495. package/dist/features/layout/NavItem.js +2 -3
  496. package/dist/features/layout/NavbarLayout.js +4 -4
  497. package/dist/features/layout/SidebarLayout.js +0 -1
  498. package/dist/features/layout/TitleBar.d.ts +4 -2
  499. package/dist/features/layout/TitleBar.js +8 -4
  500. package/dist/features/layout/TitleBarLayout.d.ts +5 -3
  501. package/dist/features/layout/TitleBarLayout.js +3 -4
  502. package/dist/features/layout/index.d.ts +2 -0
  503. package/dist/features/layout/index.js +1 -0
  504. package/dist/features/loyalty/components/CoinsDisplay.js +0 -1
  505. package/dist/features/loyalty/hooks/useLoyaltyBalance.js +0 -1
  506. package/dist/features/loyalty/schemas/index.d.ts +6 -6
  507. package/dist/features/loyalty/server.d.ts +0 -1
  508. package/dist/features/loyalty/server.js +0 -1
  509. package/dist/features/media/AvatarUpload.js +1 -1
  510. package/dist/features/media/MediaImage.d.ts +3 -1
  511. package/dist/features/media/MediaImage.js +9 -5
  512. package/dist/features/media/MediaLightbox.d.ts +0 -1
  513. package/dist/features/media/MediaLightbox.js +1 -2
  514. package/dist/features/media/components/MediaSlider.d.ts +4 -0
  515. package/dist/features/media/components/MediaSlider.js +0 -1
  516. package/dist/features/media/hooks/useMedia.d.ts +6 -0
  517. package/dist/features/media/hooks/useMedia.js +1 -2
  518. package/dist/features/media/server.d.ts +0 -1
  519. package/dist/features/media/server.js +0 -1
  520. package/dist/features/media/types/index.d.ts +2 -2
  521. package/dist/features/orders/api/track/[trackingId]/route.d.ts +0 -1
  522. package/dist/features/orders/api/track/[trackingId]/route.js +0 -1
  523. package/dist/features/orders/components/MarketplaceOrderCard.d.ts +0 -1
  524. package/dist/features/orders/components/MarketplaceOrderCard.js +1 -2
  525. package/dist/features/orders/components/OrderFilters.js +0 -1
  526. package/dist/features/orders/components/OrdersList.js +3 -2
  527. package/dist/features/orders/hooks/useOrders.js +0 -1
  528. package/dist/features/orders/repository/orders.repository.d.ts +0 -1
  529. package/dist/features/orders/repository/orders.repository.js +0 -1
  530. package/dist/features/orders/schemas/index.d.ts +28 -28
  531. package/dist/features/orders/schemas/index.js +2 -2
  532. package/dist/features/orders/server.d.ts +0 -1
  533. package/dist/features/orders/server.js +0 -1
  534. package/dist/features/payments/hooks/usePaymentEvent.js +0 -1
  535. package/dist/features/payments/hooks/usePayments.js +0 -1
  536. package/dist/features/payments/schemas/index.d.ts +4 -4
  537. package/dist/features/payments/server.d.ts +0 -1
  538. package/dist/features/payments/server.js +0 -1
  539. package/dist/features/pre-orders/api/route.js +1 -1
  540. package/dist/features/pre-orders/components/MarketplacePreorderCard.d.ts +1 -0
  541. package/dist/features/pre-orders/components/MarketplacePreorderCard.js +7 -3
  542. package/dist/features/pre-orders/components/PreOrderDetailPageView.d.ts +4 -0
  543. package/dist/features/pre-orders/components/PreOrderDetailPageView.js +27 -0
  544. package/dist/features/pre-orders/components/PreOrdersIndexListing.d.ts +4 -0
  545. package/dist/features/pre-orders/components/PreOrdersIndexListing.js +25 -0
  546. package/dist/features/pre-orders/components/PreOrdersListView.d.ts +1 -0
  547. package/dist/features/pre-orders/components/PreOrdersListView.js +16 -0
  548. package/dist/features/pre-orders/components/PreorderCard.js +0 -1
  549. package/dist/features/pre-orders/components/index.d.ts +5 -0
  550. package/dist/features/pre-orders/components/index.js +3 -0
  551. package/dist/features/pre-orders/hooks/usePreOrders.js +0 -1
  552. package/dist/features/pre-orders/schemas/index.d.ts +8 -8
  553. package/dist/features/pre-orders/server.d.ts +0 -1
  554. package/dist/features/pre-orders/server.js +0 -1
  555. package/dist/features/products/api/[id]/route.js +3 -3
  556. package/dist/features/products/api/route.js +4 -4
  557. package/dist/features/products/columns/productTableColumns.js +0 -1
  558. package/dist/features/products/components/AuctionsIndexListing.d.ts +4 -0
  559. package/dist/features/products/components/AuctionsIndexListing.js +23 -0
  560. package/dist/features/products/components/BidHistory.js +3 -3
  561. package/dist/features/products/components/BuyBar.js +0 -1
  562. package/dist/features/products/components/InteractiveProductCard.js +0 -1
  563. package/dist/features/products/components/MakeOfferForm.js +1 -1
  564. package/dist/features/products/components/PlaceBidForm.js +1 -1
  565. package/dist/features/products/components/ProductDetailPageView.d.ts +4 -0
  566. package/dist/features/products/components/ProductDetailPageView.js +100 -0
  567. package/dist/features/products/components/ProductDetailView.d.ts +15 -2
  568. package/dist/features/products/components/ProductDetailView.js +2 -2
  569. package/dist/features/products/components/ProductFeatureBadges.js +0 -1
  570. package/dist/features/products/components/ProductFilters.js +0 -1
  571. package/dist/features/products/components/ProductForm.js +3 -2
  572. package/dist/features/products/components/ProductGalleryClient.d.ts +5 -0
  573. package/dist/features/products/components/ProductGalleryClient.js +23 -0
  574. package/dist/features/products/components/ProductGrid.d.ts +6 -2
  575. package/dist/features/products/components/ProductGrid.js +19 -11
  576. package/dist/features/products/components/ProductInfo.js +1 -1
  577. package/dist/features/products/components/ProductTabs.js +2 -1
  578. package/dist/features/products/components/ProductTabsShell.d.ts +18 -0
  579. package/dist/features/products/components/ProductTabsShell.js +26 -0
  580. package/dist/features/products/components/ProductsIndexListing.d.ts +4 -0
  581. package/dist/features/products/components/ProductsIndexListing.js +27 -0
  582. package/dist/features/products/components/ProductsIndexPageView.d.ts +1 -0
  583. package/dist/features/products/components/ProductsIndexPageView.js +17 -0
  584. package/dist/features/products/components/RelatedProducts.js +2 -2
  585. package/dist/features/products/components/index.d.ts +4 -0
  586. package/dist/features/products/components/index.js +2 -0
  587. package/dist/features/products/hooks/useProductDetail.js +0 -1
  588. package/dist/features/products/hooks/useProducts.js +2 -1
  589. package/dist/features/products/hooks/useRelatedProducts.js +0 -1
  590. package/dist/features/products/repository/products.repository.d.ts +7 -1
  591. package/dist/features/products/repository/products.repository.js +53 -4
  592. package/dist/features/products/schemas/index.d.ts +110 -110
  593. package/dist/features/products/schemas/index.js +2 -2
  594. package/dist/features/products/server.d.ts +0 -1
  595. package/dist/features/products/server.js +0 -1
  596. package/dist/features/products/types/index.d.ts +1 -0
  597. package/dist/features/promotions/actions/seller-coupon-actions.js +3 -3
  598. package/dist/features/promotions/api/route.js +1 -1
  599. package/dist/features/promotions/hooks/useCouponValidate.js +0 -1
  600. package/dist/features/promotions/hooks/usePromotions.js +0 -1
  601. package/dist/features/promotions/repository/coupons.repository.d.ts +0 -1
  602. package/dist/features/promotions/repository/coupons.repository.js +0 -1
  603. package/dist/features/promotions/schemas/index.d.ts +18 -18
  604. package/dist/features/promotions/schemas/index.js +2 -2
  605. package/dist/features/promotions/server.d.ts +0 -1
  606. package/dist/features/promotions/server.js +0 -1
  607. package/dist/features/promotions/types/index.js +1 -1
  608. package/dist/features/reviews/api/[id]/route.js +3 -3
  609. package/dist/features/reviews/api/route.js +3 -3
  610. package/dist/features/reviews/components/ReviewFilters.js +0 -1
  611. package/dist/features/reviews/components/ReviewModal.js +6 -2
  612. package/dist/features/reviews/components/ReviewSummary.js +0 -1
  613. package/dist/features/reviews/components/ReviewsIndexListing.d.ts +5 -0
  614. package/dist/features/reviews/components/ReviewsIndexListing.js +55 -0
  615. package/dist/features/reviews/components/ReviewsIndexPageView.d.ts +1 -0
  616. package/dist/features/reviews/components/ReviewsIndexPageView.js +9 -0
  617. package/dist/features/reviews/components/ReviewsList.js +6 -4
  618. package/dist/features/reviews/components/index.d.ts +2 -0
  619. package/dist/features/reviews/components/index.js +1 -0
  620. package/dist/features/reviews/hooks/useCreateReview.js +2 -1
  621. package/dist/features/reviews/hooks/useReviews.js +0 -1
  622. package/dist/features/reviews/schemas/index.d.ts +24 -24
  623. package/dist/features/reviews/schemas/index.js +2 -2
  624. package/dist/features/reviews/server.d.ts +0 -1
  625. package/dist/features/reviews/server.js +0 -1
  626. package/dist/features/search/api/route.js +1 -1
  627. package/dist/features/search/components/Search.d.ts +0 -1
  628. package/dist/features/search/components/Search.js +9 -10
  629. package/dist/features/search/components/SearchResultsSection.js +0 -1
  630. package/dist/features/search/hooks/useSearch.js +0 -1
  631. package/dist/features/search/schemas/index.d.ts +5 -5
  632. package/dist/features/search/server.d.ts +0 -1
  633. package/dist/features/search/server.js +0 -1
  634. package/dist/features/seller/actions/offer-actions.js +7 -7
  635. package/dist/features/seller/actions/seller-actions.js +9 -9
  636. package/dist/features/seller/columns/index.js +2 -2
  637. package/dist/features/seller/components/SellerAddressesView.d.ts +1 -1
  638. package/dist/features/seller/components/SellerAddressesView.js +1 -1
  639. package/dist/features/seller/components/SellerAuctionsView.d.ts +3 -3
  640. package/dist/features/seller/components/SellerAuctionsView.js +27 -3
  641. package/dist/features/seller/components/SellerCouponsView.d.ts +3 -3
  642. package/dist/features/seller/components/SellerCouponsView.js +27 -3
  643. package/dist/features/seller/components/SellerCreateProductView.d.ts +1 -1
  644. package/dist/features/seller/components/SellerCreateProductView.js +1 -1
  645. package/dist/features/seller/components/SellerEditProductView.d.ts +1 -1
  646. package/dist/features/seller/components/SellerEditProductView.js +1 -1
  647. package/dist/features/seller/components/SellerOffersView.d.ts +3 -3
  648. package/dist/features/seller/components/SellerOffersView.js +27 -3
  649. package/dist/features/seller/components/SellerOrdersView.d.ts +3 -3
  650. package/dist/features/seller/components/SellerOrdersView.js +27 -3
  651. package/dist/features/seller/components/SellerPayoutHistoryTable.js +0 -1
  652. package/dist/features/seller/components/SellerPayoutStats.js +0 -1
  653. package/dist/features/seller/components/SellerPayoutsView.d.ts +3 -17
  654. package/dist/features/seller/components/SellerPayoutsView.js +27 -9
  655. package/dist/features/seller/components/SellerProductsView.d.ts +3 -3
  656. package/dist/features/seller/components/SellerProductsView.js +27 -3
  657. package/dist/features/seller/components/SellerSidebar.d.ts +5 -1
  658. package/dist/features/seller/components/SellerSidebar.js +11 -6
  659. package/dist/features/seller/components/SellerStatCard.js +2 -1
  660. package/dist/features/seller/components/SellerStoreView.d.ts +1 -1
  661. package/dist/features/seller/components/SellerStoreView.js +1 -1
  662. package/dist/features/seller/components/analytics/SellerAnalyticsStats.js +0 -1
  663. package/dist/features/seller/components/analytics/SellerTopProducts.js +0 -1
  664. package/dist/features/seller/hooks/useBecomeSeller.js +0 -1
  665. package/dist/features/seller/hooks/useSellerListingData.d.ts +29 -0
  666. package/dist/features/seller/hooks/useSellerListingData.js +87 -0
  667. package/dist/features/seller/hooks/useSellerPayouts.js +0 -1
  668. package/dist/features/seller/hooks/useSellerStore.js +0 -1
  669. package/dist/features/seller/hooks/useSellerStorefront.js +0 -1
  670. package/dist/features/seller/index.d.ts +1 -0
  671. package/dist/features/seller/index.js +1 -0
  672. package/dist/features/seller/repository/offer.repository.js +3 -3
  673. package/dist/features/seller/schemas/index.d.ts +26 -26
  674. package/dist/features/seller/schemas/index.js +3 -3
  675. package/dist/features/seller/server.d.ts +0 -1
  676. package/dist/features/seller/server.js +0 -1
  677. package/dist/features/seller/types/index.js +1 -1
  678. package/dist/features/stores/api/[storeSlug]/auctions/route.js +1 -1
  679. package/dist/features/stores/api/[storeSlug]/products/route.js +1 -1
  680. package/dist/features/stores/api/[storeSlug]/reviews/route.js +1 -1
  681. package/dist/features/stores/api/[storeSlug]/route.js +1 -1
  682. package/dist/features/stores/api/route.js +1 -1
  683. package/dist/features/stores/components/InteractiveStoreCard.d.ts +1 -0
  684. package/dist/features/stores/components/InteractiveStoreCard.js +5 -5
  685. package/dist/features/stores/components/StoreAboutView.js +3 -2
  686. package/dist/features/stores/components/StoreAddressSelectorCreate.js +1 -1
  687. package/dist/features/stores/components/StoreAuctionsListing.d.ts +5 -0
  688. package/dist/features/stores/components/StoreAuctionsListing.js +41 -0
  689. package/dist/features/stores/components/StoreAuctionsPageView.d.ts +4 -0
  690. package/dist/features/stores/components/StoreAuctionsPageView.js +21 -0
  691. package/dist/features/stores/components/StoreAuctionsView.d.ts +2 -2
  692. package/dist/features/stores/components/StoreAuctionsView.js +2 -2
  693. package/dist/features/stores/components/StoreDetailLayoutView.d.ts +8 -0
  694. package/dist/features/stores/components/StoreDetailLayoutView.js +19 -0
  695. package/dist/features/stores/components/StoreHeader.js +3 -3
  696. package/dist/features/stores/components/StoreNavTabs.js +3 -4
  697. package/dist/features/stores/components/StoreProductsListing.d.ts +5 -0
  698. package/dist/features/stores/components/StoreProductsListing.js +29 -0
  699. package/dist/features/stores/components/StoreProductsPageView.d.ts +4 -0
  700. package/dist/features/stores/components/StoreProductsPageView.js +21 -0
  701. package/dist/features/stores/components/StoreProductsView.js +8 -3
  702. package/dist/features/stores/components/StoreReviewsListing.d.ts +4 -0
  703. package/dist/features/stores/components/StoreReviewsListing.js +34 -0
  704. package/dist/features/stores/components/StoreReviewsPageView.d.ts +4 -0
  705. package/dist/features/stores/components/StoreReviewsPageView.js +5 -0
  706. package/dist/features/stores/components/StoreReviewsView.d.ts +2 -2
  707. package/dist/features/stores/components/StoreReviewsView.js +2 -6
  708. package/dist/features/stores/components/StoresIndexListing.d.ts +4 -0
  709. package/dist/features/stores/components/StoresIndexListing.js +22 -0
  710. package/dist/features/stores/components/StoresIndexPageView.d.ts +1 -0
  711. package/dist/features/stores/components/StoresIndexPageView.js +11 -0
  712. package/dist/features/stores/components/StoresListView.js +5 -4
  713. package/dist/features/stores/components/index.d.ts +8 -0
  714. package/dist/features/stores/components/index.js +4 -0
  715. package/dist/features/stores/hooks/useStoreAddressSelector.js +0 -1
  716. package/dist/features/stores/hooks/useStores.d.ts +2 -1
  717. package/dist/features/stores/hooks/useStores.js +1 -1
  718. package/dist/features/stores/repository/store-address.repository.js +2 -3
  719. package/dist/features/stores/repository/store.repository.d.ts +0 -1
  720. package/dist/features/stores/repository/store.repository.js +0 -1
  721. package/dist/features/stores/schemas/firestore.js +1 -1
  722. package/dist/features/stores/schemas/index.d.ts +14 -14
  723. package/dist/features/stores/schemas/index.js +1 -1
  724. package/dist/features/stores/server.d.ts +0 -1
  725. package/dist/features/stores/server.js +0 -1
  726. package/dist/features/stores/types/index.js +1 -1
  727. package/dist/features/whatsapp-bot/components/WhatsAppChatButton.js +0 -1
  728. package/dist/features/whatsapp-bot/helpers/whatsapp.d.ts +0 -1
  729. package/dist/features/whatsapp-bot/helpers/whatsapp.js +0 -1
  730. package/dist/features/whatsapp-bot/server.d.ts +0 -1
  731. package/dist/features/whatsapp-bot/server.js +0 -1
  732. package/dist/features/wishlist/components/WishlistPage.js +4 -3
  733. package/dist/features/wishlist/components/WishlistToggleButton.js +0 -1
  734. package/dist/features/wishlist/components/WishlistView.d.ts +2 -2
  735. package/dist/features/wishlist/components/WishlistView.js +2 -2
  736. package/dist/features/wishlist/hooks/useUserWishlist.js +0 -1
  737. package/dist/features/wishlist/hooks/useWishlist.js +0 -1
  738. package/dist/features/wishlist/schemas/index.d.ts +2 -2
  739. package/dist/features/wishlist/server.d.ts +0 -1
  740. package/dist/features/wishlist/server.js +0 -1
  741. package/dist/index.d.ts +2766 -1
  742. package/dist/index.js +5177 -1
  743. package/dist/monitoring/server-logger.d.ts +10 -1
  744. package/dist/monitoring/server-logger.js +35 -14
  745. package/dist/next/ErrorBoundary.d.ts +1 -1
  746. package/dist/next/ErrorBoundary.js +2 -1
  747. package/dist/next/api/apiHandler.d.ts +9 -0
  748. package/dist/next/api/apiHandler.js +20 -0
  749. package/dist/next/api/routeHandler.d.ts +9 -0
  750. package/dist/next/api/routeHandler.js +30 -5
  751. package/dist/next/routing/route-map.d.ts +6 -2
  752. package/dist/next/routing/route-map.js +3 -1
  753. package/dist/providers/auth-firebase/helpers.js +3 -3
  754. package/dist/providers/db-firebase/admin-app-lite.d.ts +0 -1
  755. package/dist/providers/db-firebase/admin-app-lite.js +11 -6
  756. package/dist/providers/db-firebase/admin-storage-lite.d.ts +0 -1
  757. package/dist/providers/db-firebase/admin-storage-lite.js +0 -1
  758. package/dist/providers/db-firebase/admin.d.ts +0 -1
  759. package/dist/providers/db-firebase/admin.js +16 -21
  760. package/dist/providers/db-firebase/base.d.ts +0 -1
  761. package/dist/providers/db-firebase/base.js +42 -16
  762. package/dist/providers/db-firebase/base.repository.d.ts +1 -2
  763. package/dist/providers/db-firebase/base.repository.js +0 -1
  764. package/dist/providers/db-firebase/field-ops.d.ts +0 -1
  765. package/dist/providers/db-firebase/field-ops.js +0 -1
  766. package/dist/providers/db-firebase/helpers.d.ts +2 -0
  767. package/dist/providers/db-firebase/helpers.js +11 -2
  768. package/dist/providers/db-firebase/index.d.ts +1 -2
  769. package/dist/providers/db-firebase/index.js +1 -2
  770. package/dist/providers/db-firebase/realtime.d.ts +1 -2
  771. package/dist/providers/db-firebase/realtime.js +20 -4
  772. package/dist/providers/db-firebase/sieve.d.ts +0 -1
  773. package/dist/providers/db-firebase/sieve.js +23 -5
  774. package/dist/providers/firebase-client/auth.js +0 -1
  775. package/dist/providers/firebase-client/index.js +0 -1
  776. package/dist/providers/firebase-client/realtime.js +0 -1
  777. package/dist/providers/payment-razorpay/index.d.ts +20 -1
  778. package/dist/providers/payment-razorpay/index.js +3 -4
  779. package/dist/providers/shipping-shiprocket/index.d.ts +37 -0
  780. package/dist/providers/shipping-shiprocket/index.js +36 -3
  781. package/dist/providers/shipping-shiprocket/shiprocket-provider.d.ts +2 -3
  782. package/dist/providers/shipping-shiprocket/shiprocket-provider.js +28 -12
  783. package/dist/providers/storage-firebase/client.js +1 -2
  784. package/dist/providers.d.ts +25 -0
  785. package/dist/providers.js +31 -0
  786. package/dist/react/ErrorBoundary.d.ts +1 -1
  787. package/dist/react/ErrorBoundary.js +1 -1
  788. package/dist/react/contexts/SessionContext.d.ts +0 -1
  789. package/dist/react/contexts/SessionContext.js +0 -1
  790. package/dist/react/contexts/ThemeContext.d.ts +0 -1
  791. package/dist/react/contexts/ThemeContext.js +0 -1
  792. package/dist/react/hooks/useBreakpoint.js +0 -1
  793. package/dist/react/hooks/useCamera.d.ts +0 -1
  794. package/dist/react/hooks/useCamera.js +0 -1
  795. package/dist/react/hooks/useClickOutside.d.ts +0 -1
  796. package/dist/react/hooks/useClickOutside.js +0 -1
  797. package/dist/react/hooks/useContainerGrid.js +1 -1
  798. package/dist/react/hooks/useCountdown.js +1 -0
  799. package/dist/react/hooks/useMediaQuery.d.ts +0 -1
  800. package/dist/react/hooks/useMediaQuery.js +0 -1
  801. package/dist/react/hooks/useSwipe.d.ts +0 -1
  802. package/dist/react/hooks/useSwipe.js +0 -1
  803. package/dist/react/hooks/useUnsavedChanges.d.ts +0 -1
  804. package/dist/react/hooks/useUnsavedChanges.js +3 -3
  805. package/dist/react/hooks/useVisibleItems.js +1 -1
  806. package/dist/react/useModalStack.js +1 -1
  807. package/dist/repositories/index.d.ts +0 -1
  808. package/dist/repositories/index.js +0 -1
  809. package/dist/security/authorization.js +10 -15
  810. package/dist/security/index.d.ts +1 -1
  811. package/dist/security/index.js +1 -1
  812. package/dist/security/pii-encrypt.d.ts +11 -1
  813. package/dist/security/pii-encrypt.js +11 -5
  814. package/dist/security/pii-redact.d.ts +16 -0
  815. package/dist/security/pii-redact.js +32 -0
  816. package/dist/security/rate-limit.d.ts +0 -1
  817. package/dist/security/rate-limit.js +17 -5
  818. package/dist/security/rbac/Can.js +0 -2
  819. package/dist/security/rbac/hook.js +1 -1
  820. package/dist/security/settings-encryption.d.ts +0 -1
  821. package/dist/security/settings-encryption.js +7 -2
  822. package/dist/seed/actions/demo-seed-actions.d.ts +12 -1
  823. package/dist/seed/addresses-seed-data.d.ts +0 -1
  824. package/dist/seed/addresses-seed-data.js +1 -2
  825. package/dist/seed/bids-seed-data.d.ts +0 -1
  826. package/dist/seed/bids-seed-data.js +21 -22
  827. package/dist/seed/blog-posts-seed-data.d.ts +0 -1
  828. package/dist/seed/blog-posts-seed-data.js +8 -5
  829. package/dist/seed/carousel-slides-seed-data.d.ts +0 -1
  830. package/dist/seed/carousel-slides-seed-data.js +4 -1
  831. package/dist/seed/cart-seed-data.d.ts +0 -1
  832. package/dist/seed/cart-seed-data.js +5 -6
  833. package/dist/seed/categories-seed-data.d.ts +0 -1
  834. package/dist/seed/categories-seed-data.js +4 -1
  835. package/dist/seed/coupons-seed-data.d.ts +0 -1
  836. package/dist/seed/coupons-seed-data.js +4 -1
  837. package/dist/seed/events-seed-data.d.ts +0 -1
  838. package/dist/seed/events-seed-data.js +7 -4
  839. package/dist/seed/factories/product.factory.js +1 -1
  840. package/dist/seed/faq-seed-data.d.ts +0 -1
  841. package/dist/seed/faq-seed-data.js +15 -1
  842. package/dist/seed/firestore-indexes.d.ts +0 -1
  843. package/dist/seed/firestore-indexes.js +0 -1
  844. package/dist/seed/homepage-sections-seed-data.d.ts +4 -5
  845. package/dist/seed/homepage-sections-seed-data.js +84 -31
  846. package/dist/seed/index.d.ts +7 -1
  847. package/dist/seed/index.js +8 -1
  848. package/dist/seed/notifications-seed-data.d.ts +0 -1
  849. package/dist/seed/notifications-seed-data.js +15 -12
  850. package/dist/seed/orders-seed-data.d.ts +0 -1
  851. package/dist/seed/orders-seed-data.js +6 -7
  852. package/dist/seed/payouts-seed-data.d.ts +0 -1
  853. package/dist/seed/payouts-seed-data.js +4 -5
  854. package/dist/seed/pokemon-carousel-slides-seed-data.d.ts +6 -0
  855. package/dist/seed/pokemon-carousel-slides-seed-data.js +433 -0
  856. package/dist/seed/pokemon-categories-seed-data.d.ts +27 -0
  857. package/dist/seed/pokemon-categories-seed-data.js +1127 -0
  858. package/dist/seed/pokemon-homepage-sections-seed-data.d.ts +6 -0
  859. package/dist/seed/pokemon-homepage-sections-seed-data.js +370 -0
  860. package/dist/seed/pokemon-products-seed-data.d.ts +9 -0
  861. package/dist/seed/pokemon-products-seed-data.js +1119 -0
  862. package/dist/seed/pokemon-seed-bundle.d.ts +22 -0
  863. package/dist/seed/pokemon-seed-bundle.js +22 -0
  864. package/dist/seed/pokemon-stores-seed-data.d.ts +7 -0
  865. package/dist/seed/pokemon-stores-seed-data.js +78 -0
  866. package/dist/seed/pokemon-users-seed-data.d.ts +6 -0
  867. package/dist/seed/pokemon-users-seed-data.js +438 -0
  868. package/dist/seed/products-seed-data.d.ts +0 -1
  869. package/dist/seed/products-seed-data.js +34 -2
  870. package/dist/seed/reviews-seed-data.d.ts +0 -1
  871. package/dist/seed/reviews-seed-data.js +4 -1
  872. package/dist/seed/runner.d.ts +0 -1
  873. package/dist/seed/runner.js +10 -2
  874. package/dist/seed/seed-market-config.d.ts +0 -1
  875. package/dist/seed/seed-market-config.js +1 -2
  876. package/dist/seed/sessions-seed-data.d.ts +0 -1
  877. package/dist/seed/sessions-seed-data.js +19 -20
  878. package/dist/seed/site-settings-seed-data.d.ts +38 -2
  879. package/dist/seed/site-settings-seed-data.js +124 -1
  880. package/dist/seed/store-addresses-seed-data.d.ts +0 -1
  881. package/dist/seed/store-addresses-seed-data.js +1 -2
  882. package/dist/seed/stores-seed-data.d.ts +0 -1
  883. package/dist/seed/stores-seed-data.js +14 -4
  884. package/dist/seed/test-utils.d.ts +0 -1
  885. package/dist/seed/test-utils.js +0 -1
  886. package/dist/seed/types.d.ts +0 -1
  887. package/dist/seed/types.js +2 -1
  888. package/dist/seed/users-seed-data.d.ts +0 -1
  889. package/dist/seed/users-seed-data.js +7 -8
  890. package/dist/seed/wishlists-seed-data.d.ts +10 -0
  891. package/dist/seed/wishlists-seed-data.js +38 -0
  892. package/dist/seo/json-ld.js +1 -1
  893. package/dist/server.d.ts +437 -109
  894. package/dist/server.js +1296 -110
  895. package/dist/styles.css +20 -0
  896. package/dist/tokens/index.d.ts +131 -0
  897. package/dist/tokens/index.js +55 -11
  898. package/dist/tokens/tokens.css +9 -9
  899. package/dist/ui/DataTable.js +15 -15
  900. package/dist/ui/columns/column-renderers.js +3 -3
  901. package/dist/ui/components/Accordion.js +1 -1
  902. package/dist/ui/components/ActiveFilterChips.js +0 -1
  903. package/dist/ui/components/Alert.js +1 -1
  904. package/dist/ui/components/Avatar.js +1 -2
  905. package/dist/ui/components/AvatarDisplay.js +2 -3
  906. package/dist/ui/components/BackgroundRenderer.js +1 -1
  907. package/dist/ui/components/BaseListingCard.js +7 -5
  908. package/dist/ui/components/BulkActionBar.d.ts +0 -1
  909. package/dist/ui/components/BulkActionBar.js +2 -3
  910. package/dist/ui/components/Button.style.css +2 -2
  911. package/dist/ui/components/Card.js +4 -4
  912. package/dist/ui/components/Checkbox.js +1 -1
  913. package/dist/ui/components/ConfirmDeleteModal.d.ts +0 -1
  914. package/dist/ui/components/ConfirmDeleteModal.js +2 -3
  915. package/dist/ui/components/CountdownDisplay.d.ts +0 -1
  916. package/dist/ui/components/CountdownDisplay.js +0 -1
  917. package/dist/ui/components/DashboardStatsCard.js +1 -2
  918. package/dist/ui/components/DescriptionField.js +1 -1
  919. package/dist/ui/components/DetailViewShell.d.ts +16 -2
  920. package/dist/ui/components/DetailViewShell.js +9 -5
  921. package/dist/ui/components/Div.d.ts +1 -1
  922. package/dist/ui/components/Div.js +2 -2
  923. package/dist/ui/components/Divider.js +1 -1
  924. package/dist/ui/components/Drawer.d.ts +0 -1
  925. package/dist/ui/components/Drawer.js +2 -3
  926. package/dist/ui/components/Dropdown.d.ts +0 -1
  927. package/dist/ui/components/Dropdown.js +1 -2
  928. package/dist/ui/components/DynamicSelect.d.ts +0 -1
  929. package/dist/ui/components/DynamicSelect.js +2 -3
  930. package/dist/ui/components/EmptyState.js +1 -2
  931. package/dist/ui/components/FilterDrawer.d.ts +3 -1
  932. package/dist/ui/components/FilterDrawer.js +3 -3
  933. package/dist/ui/components/FlowDiagram.js +3 -3
  934. package/dist/ui/components/Form.js +2 -2
  935. package/dist/ui/components/FormField.js +3 -4
  936. package/dist/ui/components/FormGrid.js +2 -2
  937. package/dist/ui/components/FormGrid.style.css +1 -1
  938. package/dist/ui/components/HorizontalScroller.d.ts +1 -1
  939. package/dist/ui/components/HorizontalScroller.js +86 -15
  940. package/dist/ui/components/HorizontalScroller.style.css +105 -109
  941. package/dist/ui/components/ImageGallery.d.ts +0 -1
  942. package/dist/ui/components/ImageGallery.js +4 -5
  943. package/dist/ui/components/ImageLightbox.d.ts +0 -1
  944. package/dist/ui/components/ImageLightbox.js +1 -2
  945. package/dist/ui/components/ImageLightbox.style.css +3 -3
  946. package/dist/ui/components/Input.js +1 -1
  947. package/dist/ui/components/Layout.d.ts +7 -7
  948. package/dist/ui/components/Layout.js +5 -5
  949. package/dist/ui/components/ListingLayout.d.ts +11 -8
  950. package/dist/ui/components/ListingLayout.js +22 -44
  951. package/dist/ui/components/ListingLayout.style.css +15 -15
  952. package/dist/ui/components/ListingViewShell.d.ts +1 -2
  953. package/dist/ui/components/ListingViewShell.js +1 -3
  954. package/dist/ui/components/Menu.js +0 -1
  955. package/dist/ui/components/Modal.d.ts +0 -1
  956. package/dist/ui/components/Modal.js +3 -4
  957. package/dist/ui/components/NavigationLoader.d.ts +29 -0
  958. package/dist/ui/components/NavigationLoader.js +146 -0
  959. package/dist/ui/components/NavigationLoader.style.css +19 -0
  960. package/dist/ui/components/Pagination.js +0 -1
  961. package/dist/ui/components/PasswordStrengthIndicator.js +1 -2
  962. package/dist/ui/components/PriceDisplay.js +0 -1
  963. package/dist/ui/components/Progress.js +2 -3
  964. package/dist/ui/components/Radio.js +1 -2
  965. package/dist/ui/components/RatingDisplay.js +1 -2
  966. package/dist/ui/components/ResponsiveView.js +1 -2
  967. package/dist/ui/components/RichTextEditor.d.ts +9 -0
  968. package/dist/ui/components/RichTextEditor.js +59 -0
  969. package/dist/ui/components/RoleBadge.js +0 -1
  970. package/dist/ui/components/RowActionMenu.js +1 -1
  971. package/dist/ui/components/SectionTabs.js +4 -4
  972. package/dist/ui/components/Select.js +2 -2
  973. package/dist/ui/components/Semantic.d.ts +2 -2
  974. package/dist/ui/components/Semantic.js +1 -1
  975. package/dist/ui/components/SideDrawer.d.ts +0 -1
  976. package/dist/ui/components/SideDrawer.js +2 -3
  977. package/dist/ui/components/SideDrawer.style.css +2 -2
  978. package/dist/ui/components/SideModal.d.ts +0 -1
  979. package/dist/ui/components/SideModal.js +0 -1
  980. package/dist/ui/components/SideModal.style.css +4 -4
  981. package/dist/ui/components/Skeleton.js +1 -2
  982. package/dist/ui/components/SkipToMain.js +0 -1
  983. package/dist/ui/components/Slider.js +2 -2
  984. package/dist/ui/components/SlottedListingView.d.ts +1 -2
  985. package/dist/ui/components/SlottedListingView.js +2 -3
  986. package/dist/ui/components/SortDropdown.js +1 -2
  987. package/dist/ui/components/Spinner.d.ts +1 -1
  988. package/dist/ui/components/Spinner.js +2 -1
  989. package/dist/ui/components/Spinner.style.css +8 -0
  990. package/dist/ui/components/StackedViewShell.d.ts +0 -1
  991. package/dist/ui/components/StackedViewShell.js +0 -2
  992. package/dist/ui/components/StatsGrid.js +0 -1
  993. package/dist/ui/components/StatusBadge.d.ts +5 -5
  994. package/dist/ui/components/StepperNav.js +2 -3
  995. package/dist/ui/components/SummaryCard.js +0 -1
  996. package/dist/ui/components/TabStrip.d.ts +0 -1
  997. package/dist/ui/components/TabStrip.js +1 -2
  998. package/dist/ui/components/TablePagination.js +0 -1
  999. package/dist/ui/components/Tabs.js +3 -3
  1000. package/dist/ui/components/TagInput.js +1 -1
  1001. package/dist/ui/components/TextLink.js +0 -1
  1002. package/dist/ui/components/Textarea.js +2 -2
  1003. package/dist/ui/components/Toast.d.ts +0 -1
  1004. package/dist/ui/components/Toast.js +2 -3
  1005. package/dist/ui/components/Toggle.js +1 -1
  1006. package/dist/ui/components/Tooltip.d.ts +0 -1
  1007. package/dist/ui/components/Tooltip.js +1 -2
  1008. package/dist/ui/components/UnsavedChangesModal.d.ts +0 -1
  1009. package/dist/ui/components/UnsavedChangesModal.js +2 -3
  1010. package/dist/ui/components/ViewToggle.js +0 -1
  1011. package/dist/ui/components/index.style.css +1 -0
  1012. package/dist/ui/index.d.ts +5 -1
  1013. package/dist/ui/index.js +5 -3
  1014. package/dist/ui/rich-text/RichText.d.ts +0 -1
  1015. package/dist/ui/rich-text/RichText.js +3 -4
  1016. package/dist/utils/event-manager.d.ts +6 -1
  1017. package/dist/utils/event-manager.js +6 -1
  1018. package/dist/utils/id-generators.js +3 -3
  1019. package/dist/utils/string.formatter.d.ts +5 -0
  1020. package/dist/utils/string.formatter.js +15 -0
  1021. package/dist/validation/schemas.d.ts +20 -20
  1022. package/package.json +86 -25
@@ -1,8 +1,6 @@
1
1
  "use client";
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import "client-only";
4
3
  import { useState, useEffect, useRef, useCallback } from "react";
5
- import { useTranslations } from "next-intl";
6
4
  import { useMediaQuery } from "../../../react";
7
5
  import { THEME_CONSTANTS } from "../../../tokens";
8
6
  import { Button, Div, Heading, Row, Section, Span, Text } from "../../../ui";
@@ -19,8 +17,6 @@ function navigate(href, push) {
19
17
  }
20
18
  }
21
19
  export function HeroCarousel({ initialSlides, push } = {}) {
22
- const tLoading = useTranslations("loading");
23
- const tA11y = useTranslations("accessibility");
24
20
  const [currentSlide, setCurrentSlide] = useState(0);
25
21
  const [isPaused, setIsPaused] = useState(false);
26
22
  const sectionRef = useRef(null);
@@ -63,10 +59,10 @@ export function HeroCarousel({ initialSlides, push } = {}) {
63
59
  return () => clearInterval(interval);
64
60
  }, [slides.length, isPaused, prefersReducedMotion, goNext]);
65
61
  if (isLoading) {
66
- return (_jsx(Div, { className: `relative w-full ${homepage.heroMinH} ${THEME_CONSTANTS.themed.bgTertiary} animate-pulse`, children: _jsx(Div, { className: `${position.fill} ${flex.center}`, children: _jsx(Text, { variant: "secondary", children: tLoading("default") }) }) }));
62
+ return (_jsx(Div, { className: `relative w-full ${homepage.heroMinH} ${THEME_CONSTANTS.themed.bgTertiary} animate-pulse`, children: _jsx(Div, { className: `${position.fill} ${flex.center}`, children: _jsx(Text, { variant: "secondary", children: "Loading..." }) }) }));
67
63
  }
68
64
  if (!slides || slides.length === 0) {
69
- return null;
65
+ return (_jsxs(Div, { className: `relative w-full ${homepage.heroMinH} bg-gradient-to-br from-primary/10 to-secondary/10 ${flex.center} flex-col gap-4`, children: [_jsx(Heading, { level: 2, className: "text-2xl font-bold text-primary", children: "Coming Soon" }), _jsx(Text, { variant: "secondary", className: "text-center max-w-md px-4", children: "Amazing deals are on their way. Stay tuned!" })] }));
70
66
  }
71
67
  const getBackgroundStyle = (card) => {
72
68
  const { type, value } = card.background;
@@ -92,10 +88,7 @@ export function HeroCarousel({ initialSlides, push } = {}) {
92
88
  setIsPaused((p) => !p);
93
89
  }
94
90
  };
95
- return (_jsxs(Section, { ref: sectionRef, className: `relative w-full ${homepage.heroMinH} overflow-hidden`, "aria-roledescription": "carousel", "aria-label": tA11y("heroCarouselAriaLabel"), onKeyDown: handleKeyDown, onMouseEnter: () => setIsPaused(true), onMouseLeave: () => setIsPaused(false), onFocus: () => setIsPaused(true), onBlur: () => setIsPaused(false), tabIndex: 0, children: [_jsx(Div, { "aria-live": "polite", "aria-atomic": "true", className: "sr-only", children: tA11y("heroCarouselSlideOf", {
96
- current: currentSlide + 1,
97
- total: slides.length,
98
- }) }), _jsx(Div, { className: position.fill, children: _jsx(Div, { ref: slidesRef, onScroll: handleSlidesScroll, className: "flex h-full overflow-x-auto scroll-smooth snap-x snap-mandatory [scrollbar-width:none] [&::-webkit-scrollbar]:hidden", style: { gap: 0 }, children: slides.map((slide, slideIndex) => (_jsxs(Div, { className: "snap-start flex-none w-full relative self-stretch bg-zinc-900", children: [_jsxs(Div, { className: position.fill, children: [slide.media.type === "image" ? (_jsx(MediaImage, { src: isMobile && slide.mobileMedia
91
+ return (_jsxs(Section, { ref: sectionRef, className: `relative w-full ${homepage.heroMinH} overflow-hidden`, "aria-roledescription": "carousel", "aria-label": "Hero carousel", onKeyDown: handleKeyDown, onMouseEnter: () => setIsPaused(true), onMouseLeave: () => setIsPaused(false), onFocus: () => setIsPaused(true), onBlur: () => setIsPaused(false), tabIndex: 0, children: [_jsx(Div, { "aria-live": "polite", "aria-atomic": "true", className: "sr-only", children: `Slide ${currentSlide + 1} of ${slides.length}` }), _jsx(Div, { className: position.fill, children: _jsx(Div, { ref: slidesRef, onScroll: handleSlidesScroll, className: "flex h-full overflow-x-auto scroll-smooth snap-x snap-mandatory [scrollbar-width:none] [&::-webkit-scrollbar]:hidden", style: { gap: 0 }, children: slides.map((slide, slideIndex) => (_jsxs(Div, { className: "snap-start flex-none w-full relative self-stretch bg-zinc-900", children: [_jsxs(Div, { className: position.fill, children: [slide.media.type === "image" ? (_jsx(MediaImage, { src: isMobile && slide.mobileMedia
99
92
  ? slide.mobileMedia.url
100
93
  : slide.media.url, alt: slide.media.alt, size: "hero", priority: slideIndex === 0 })) : (_jsx(MediaVideo, { src: isMobile && slide.mobileMedia
101
94
  ? slide.mobileMedia.url
@@ -136,7 +129,7 @@ export function HeroCarousel({ initialSlides, push } = {}) {
136
129
  ? "p-1.5 md:p-3"
137
130
  : card.sizing?.padding === "lg"
138
131
  ? "p-3 md:p-8"
139
- : "p-2 md:p-6"}`, children: [card.content?.subtitle && (_jsx(Text, { className: "hidden md:block text-xs md:text-sm !text-white/90 mb-0.5 md:mb-2 drop-shadow-sm", children: card.content.subtitle })), card.content?.title && (_jsx(Heading, { level: 2, className: "text-[11px] md:text-2xl lg:text-3xl font-bold !text-white mb-0.5 md:mb-3 line-clamp-1 md:line-clamp-2 drop-shadow-md", children: card.content.title })), card.content?.description && (_jsx(Text, { className: "text-[10px] md:text-sm lg:text-base !text-white/80 mb-1 md:mb-4 line-clamp-1 drop-shadow-sm", children: card.content.description })), (card.buttons?.length ?? 0) > 0 && (_jsx(Row, { wrap: true, gap: "xs", className: "md:gap-2", children: (card.buttons ?? []).map((btn) => (_jsx(Button, { variant: btn.variant, size: "sm", onClick: () => {
132
+ : "p-2 md:p-6"}`, children: [card.content?.subtitle && (_jsx(Text, { className: "hidden md:block text-xs md:text-sm !text-white/90 mb-0.5 md:mb-2 drop-shadow-sm", children: card.content.subtitle })), card.content?.title && (_jsx(Heading, { level: 2, className: `text-[11px] md:text-2xl lg:text-3xl font-bold !text-white mb-0.5 md:mb-3 ${THEME_CONSTANTS.utilities.textClamp1} md:${THEME_CONSTANTS.utilities.textClamp2} drop-shadow-md`, children: card.content.title })), card.content?.description && (_jsx(Text, { className: `text-[10px] md:text-sm lg:text-base !text-white/80 mb-1 md:mb-4 ${THEME_CONSTANTS.utilities.textClamp1} drop-shadow-sm`, children: card.content.description })), (card.buttons?.length ?? 0) > 0 && (_jsx(Row, { wrap: true, gap: "xs", className: "md:gap-2", children: (card.buttons ?? []).map((btn) => (_jsx(Button, { variant: btn.variant, size: "sm", onClick: () => {
140
133
  if (btn.openInNewTab) {
141
134
  window.open(btn.link, "_blank", "noopener,noreferrer");
142
135
  }
@@ -153,5 +146,5 @@ export function HeroCarousel({ initialSlides, push } = {}) {
153
146
  }
154
147
  }, children: _jsx(Span, { className: "text-lg md:text-2xl", children: card.buttons[0].text }) }))] }, card.id))) }))] }, slide.id))) }) }), slides.length > 1 && (_jsx(Div, { className: "absolute bottom-4 left-1/2 -translate-x-1/2 flex gap-2 z-10", children: slides.map((_, index) => (_jsx(Button, { variant: "ghost", className: `relative overflow-hidden rounded-full transition-all duration-500 p-0 !min-h-0 ${index === currentSlide
155
148
  ? THEME_CONSTANTS.carousel.dotActive
156
- : `${THEME_CONSTANTS.carousel.dotInactive} hover:bg-white/75`}`, onClick: () => goToSlide(index), "aria-label": tA11y("heroCarouselGoToSlide", { number: index + 1 }), children: index === currentSlide && (_jsx(Span, { className: "absolute inset-y-0 left-0 bg-black/20 rounded-full animate-[progress-fill_4s_linear_forwards]", "aria-hidden": "true" })) }, index))) })), _jsx(Div, { className: "absolute bottom-0 left-0 right-0 h-32 bg-gradient-to-t from-white dark:from-slate-950 to-transparent pointer-events-none z-[5]", "aria-hidden": "true" }), slides.length > 1 && (_jsxs(Div, { className: "absolute bottom-4 right-4 z-20 flex gap-2", children: [_jsx(Button, { variant: "ghost", className: `p-0 ${THEME_CONSTANTS.carousel.arrow}`, onClick: goPrev, "aria-label": tA11y("heroCarouselPrevSlide"), children: _jsx("svg", { className: "w-7 h-7", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2.5, d: "M15 19l-7-7 7-7" }) }) }), _jsx(Button, { variant: "ghost", className: `p-0 ${THEME_CONSTANTS.carousel.arrow}`, onClick: goNext, "aria-label": tA11y("heroCarouselNextSlide"), children: _jsx("svg", { className: "w-7 h-7", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2.5, d: "M9 5l7 7-7 7" }) }) })] }))] }));
149
+ : `${THEME_CONSTANTS.carousel.dotInactive} hover:bg-white/75`}`, onClick: () => goToSlide(index), "aria-label": `Go to slide ${index + 1}`, children: index === currentSlide && (_jsx(Span, { className: "absolute inset-y-0 left-0 bg-black/20 rounded-full animate-[progress-fill_4s_linear_forwards]", "aria-hidden": "true" })) }, index))) })), _jsx(Div, { className: "absolute bottom-0 left-0 right-0 h-32 bg-gradient-to-t from-white dark:from-slate-950 to-transparent pointer-events-none z-[5]", "aria-hidden": "true" }), slides.length > 1 && (_jsxs(Div, { className: "absolute bottom-4 right-4 z-20 flex gap-2", children: [_jsx(Button, { variant: "ghost", className: `p-0 ${THEME_CONSTANTS.carousel.arrow}`, onClick: goPrev, "aria-label": "Previous slide", children: _jsx("svg", { className: "w-7 h-7", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2.5, d: "M15 19l-7-7 7-7" }) }) }), _jsx(Button, { variant: "ghost", className: `p-0 ${THEME_CONSTANTS.carousel.arrow}`, onClick: goNext, "aria-label": "Next slide", children: _jsx("svg", { className: "w-7 h-7", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2.5, d: "M9 5l7 7-7 7" }) }) })] }))] }));
157
150
  }
@@ -0,0 +1,8 @@
1
+ export interface HomepageCustomerReviewsSectionProps {
2
+ title?: string;
3
+ subtitle?: string;
4
+ viewMoreHref?: string;
5
+ viewMoreLabel?: string;
6
+ className?: string;
7
+ }
8
+ export declare function HomepageCustomerReviewsSection({ title, subtitle, viewMoreHref, viewMoreLabel, className, }: HomepageCustomerReviewsSectionProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,9 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { CustomerReviewsSection } from "./CustomerReviewsSection";
4
+ import { useHomepageReviews } from "../hooks/useHomepageReviews";
5
+ import { ReviewCard } from "../../reviews/components";
6
+ export function HomepageCustomerReviewsSection({ title = "What Our Customers Say", subtitle, viewMoreHref, viewMoreLabel = "See all reviews →", className = "", }) {
7
+ const { data: reviews = [], isLoading } = useHomepageReviews();
8
+ return (_jsx(CustomerReviewsSection, { title: title, subtitle: subtitle, items: reviews, renderItem: (review) => (_jsx(ReviewCard, { review: review, className: "h-full border-zinc-200 shadow-sm dark:border-slate-700" })), viewMoreHref: viewMoreHref, viewMoreLabel: viewMoreLabel, isLoading: isLoading, keyExtractor: (review) => review.id, className: className }));
9
+ }
@@ -1,4 +1,3 @@
1
- "use client";
2
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
2
  import { THEME_CONSTANTS } from "../../../tokens";
4
3
  import { Grid, Section } from "../../../ui";
@@ -10,5 +9,5 @@ export function HomepageSkeleton() {
10
9
  const trustCardH = "h-[clamp(120px,18vh,170px)]";
11
10
  const categoryTileH = "h-[clamp(112px,16vh,160px)]";
12
11
  const newsletterH = "h-[clamp(220px,28vh,320px)]";
13
- return (_jsxs("div", { className: "w-full overflow-hidden", children: [_jsx("div", { className: `${skeleton.card} w-full ${heroSkeletonH}`, "aria-hidden": "true" }), _jsx(Section, { className: `p-8 ${themed.bgPrimary}`, children: _jsx(Grid, { className: "grid-cols-2 md:grid-cols-4 xl:grid-cols-4 2xl:grid-cols-4", children: Array.from({ length: 4 }).map((_, i) => (_jsx("div", { className: `${skeleton.card} flex flex-col items-center gap-3 p-6 ${trustCardH}` }, i))) }) }), _jsxs(Section, { className: `p-8 ${themed.bgSecondary}`, children: [_jsx("div", { className: `${skeleton.heading} w-48 mx-auto mb-6` }), _jsx(Grid, { className: "grid-cols-2 sm:grid-cols-4", children: Array.from({ length: 6 }).map((_, i) => (_jsx("div", { className: `${skeleton.card} ${categoryTileH}` }, i))) })] }), _jsxs(Section, { className: `p-8 ${themed.bgPrimary}`, children: [_jsxs("div", { className: `${flex.between} mb-6`, children: [_jsx("div", { className: `${skeleton.heading} w-52` }), _jsx("div", { className: `${skeleton.text} w-24` })] }), _jsx(Grid, { className: "grid-cols-2 sm:grid-cols-3 md:grid-cols-4 xl:grid-cols-4 2xl:grid-cols-5", children: Array.from({ length: 5 }).map((_, i) => (_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx("div", { className: `${skeleton.image} w-full pb-[100%]` }), _jsx("div", { className: `${skeleton.text} w-3/4` }), _jsx("div", { className: `${skeleton.text} w-1/2` })] }, i))) })] }), _jsxs(Section, { className: `p-8 ${themed.bgSecondary}`, children: [_jsxs("div", { className: `${flex.between} mb-6`, children: [_jsx("div", { className: `${skeleton.heading} w-56` }), _jsx("div", { className: `${skeleton.text} w-24` })] }), _jsx(Grid, { className: "grid-cols-2 sm:grid-cols-3 md:grid-cols-4 xl:grid-cols-4 2xl:grid-cols-5", children: Array.from({ length: 5 }).map((_, i) => (_jsxs("div", { className: "flex flex-col gap-2", children: [_jsx("div", { className: `${skeleton.image} w-full pb-[100%]` }), _jsx("div", { className: `${skeleton.text} w-3/4` }), _jsx("div", { className: `${skeleton.text} w-1/2` })] }, i))) })] }), _jsx(Section, { className: `p-8 ${themed.bgPrimary}`, children: _jsx("div", { className: `${skeleton.card} rounded-2xl max-w-2xl mx-auto ${newsletterH}` }) })] }));
12
+ return (_jsxs("div", { className: "w-full overflow-hidden", "data-section": "homepageskeleton-div-328", children: [_jsx("div", { className: `${skeleton.card} w-full ${heroSkeletonH}`, "aria-hidden": "true" }), _jsx(Section, { className: `p-8 ${themed.bgPrimary}`, children: _jsx(Grid, { className: "grid-cols-2 md:grid-cols-4 xl:grid-cols-4 2xl:grid-cols-4", children: Array.from({ length: 4 }).map((_, i) => (_jsx("div", { className: `${skeleton.card} flex flex-col items-center gap-3 p-6 ${trustCardH}` }, i))) }) }), _jsxs(Section, { className: `p-8 ${themed.bgSecondary}`, children: [_jsx("div", { className: `${skeleton.heading} w-48 mx-auto mb-6` }), _jsx(Grid, { className: "grid-cols-2 sm:grid-cols-4", children: Array.from({ length: 6 }).map((_, i) => (_jsx("div", { className: `${skeleton.card} ${categoryTileH}` }, i))) })] }), _jsxs(Section, { className: `p-8 ${themed.bgPrimary}`, children: [_jsxs("div", { className: `${flex.between} mb-6`, "data-section": "homepageskeleton-div-329", children: [_jsx("div", { className: `${skeleton.heading} w-52` }), _jsx("div", { className: `${skeleton.text} w-24` })] }), _jsx(Grid, { className: "grid-cols-2 sm:grid-cols-3 md:grid-cols-4 xl:grid-cols-4 2xl:grid-cols-5", children: Array.from({ length: 5 }).map((_, i) => (_jsxs("div", { className: "flex flex-col gap-2", "data-section": "homepageskeleton-div-330", children: [_jsx("div", { className: `${skeleton.image} w-full pb-[100%]` }), _jsx("div", { className: `${skeleton.text} w-3/4` }), _jsx("div", { className: `${skeleton.text} w-1/2` })] }, i))) })] }), _jsxs(Section, { className: `p-8 ${themed.bgSecondary}`, children: [_jsxs("div", { className: `${flex.between} mb-6`, "data-section": "homepageskeleton-div-331", children: [_jsx("div", { className: `${skeleton.heading} w-56` }), _jsx("div", { className: `${skeleton.text} w-24` })] }), _jsx(Grid, { className: "grid-cols-2 sm:grid-cols-3 md:grid-cols-4 xl:grid-cols-4 2xl:grid-cols-5", children: Array.from({ length: 5 }).map((_, i) => (_jsxs("div", { className: "flex flex-col gap-2", "data-section": "homepageskeleton-div-332", children: [_jsx("div", { className: `${skeleton.image} w-full pb-[100%]` }), _jsx("div", { className: `${skeleton.text} w-3/4` }), _jsx("div", { className: `${skeleton.text} w-1/2` })] }, i))) })] }), _jsx(Section, { className: `p-8 ${themed.bgPrimary}`, children: _jsx("div", { className: `${skeleton.card} rounded-2xl max-w-2xl mx-auto ${newsletterH}` }) })] }));
14
13
  }
@@ -1,8 +1,8 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  import { THEME_CONSTANTS } from "../../../tokens";
3
3
  import { Grid, Heading, Section, Span, Text } from "../../../ui";
4
- // ─── View ─────────────────────────────────────────────────────────────────────
4
+ // --- View ---------------------------------------------------------------------
5
5
  export function HowItWorksInfoView({ title, subtitle, heroClass = "bg-gradient-to-br from-cobalt-700 via-cobalt-600 to-violet-700", stepsTitle, steps, detailsSectionTitle, details = [], renderDiagram, renderFooter, accentClass = "bg-blue-100 dark:bg-blue-900/40 text-blue-700 dark:text-blue-400", className = "", }) {
6
6
  const { themed, flex, spacing } = THEME_CONSTANTS;
7
- return (_jsxs("div", { className: `-mx-4 md:-mx-6 lg:-mx-8 -mt-6 sm:-mt-8 lg:-mt-10 ${className}`, children: [_jsx(Section, { className: `${heroClass} text-white py-14 md:py-16 lg:py-20`, children: _jsxs("div", { className: "max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 text-center", children: [_jsx(Heading, { level: 1, variant: "none", className: "mb-4 text-white", children: title }), subtitle && (_jsx(Text, { variant: "none", className: "text-white/80 max-w-2xl mx-auto", children: subtitle }))] }) }), _jsxs("div", { className: "max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 py-10 md:py-12 lg:py-16", children: [renderDiagram?.(), stepsTitle && (_jsx(Heading, { level: 2, className: "mb-6", children: stepsTitle })), _jsx("div", { className: `${spacing.stack} mb-14`, children: steps.map(({ number, icon, title: stepTitle, text, accentClass: stepAccent, textClass, }) => (_jsxs(Section, { className: `flex gap-4 items-start ${themed.bgSecondary} rounded-xl p-6 border ${themed.border}`, children: [_jsx("div", { className: `shrink-0 w-10 h-10 rounded-xl ${stepAccent ?? accentClass} ${flex.center} text-sm font-bold`, children: _jsx(Span, { className: textClass, children: number }) }), _jsxs("div", { children: [_jsxs(Heading, { level: 3, className: "font-semibold mb-1", children: [icon, " ", stepTitle] }), _jsx(Text, { variant: "secondary", size: "sm", className: "leading-relaxed", children: text })] })] }, number))) }), details.length > 0 && (_jsxs(_Fragment, { children: [detailsSectionTitle && (_jsx(Heading, { level: 2, className: "mb-6", children: detailsSectionTitle })), _jsx(Grid, { className: "grid-cols-1 sm:grid-cols-2 xl:grid-cols-2 2xl:grid-cols-3 mb-12", children: details.map(({ title: dt, text: dx }) => (_jsxs("div", { className: `${themed.bgSecondary} border ${themed.border} rounded-xl p-5`, children: [_jsx(Heading, { level: 3, className: "font-semibold mb-2", children: dt }), _jsx(Text, { variant: "secondary", size: "sm", className: "leading-relaxed", children: dx })] }, dt))) })] })), renderFooter?.()] })] }));
7
+ return (_jsxs("div", { className: `-mx-4 md:-mx-6 lg:-mx-8 -mt-6 sm:-mt-8 lg:-mt-10 ${className}`, "data-section": "howitworksinfoview-div-333", children: [_jsx(Section, { className: `${heroClass} text-white py-14 md:py-16 lg:py-20`, children: _jsxs("div", { className: "max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 text-center", "data-section": "howitworksinfoview-div-334", children: [_jsx(Heading, { level: 1, variant: "none", className: "mb-4 text-white", children: title }), subtitle && (_jsx(Text, { variant: "none", className: "text-white/80 max-w-2xl mx-auto", children: subtitle }))] }) }), _jsxs("div", { className: "max-w-4xl mx-auto px-4 sm:px-6 lg:px-8 py-10 md:py-12 lg:py-16", "data-section": "howitworksinfoview-div-335", children: [renderDiagram?.(), stepsTitle && (_jsx(Heading, { level: 2, className: "mb-6", children: stepsTitle })), _jsx("div", { className: `${spacing.stack} mb-14`, "data-section": "howitworksinfoview-div-336", children: steps.map(({ number, icon, title: stepTitle, text, accentClass: stepAccent, textClass, }) => (_jsxs(Section, { className: `flex gap-4 items-start ${themed.bgSecondary} rounded-xl p-6 border ${themed.border}`, children: [_jsx("div", { className: `shrink-0 w-10 h-10 rounded-xl ${stepAccent ?? accentClass} ${flex.center} text-sm font-bold`, "data-section": "howitworksinfoview-div-337", children: _jsx(Span, { className: textClass, children: number }) }), _jsxs("div", { "data-section": "howitworksinfoview-div-338", children: [_jsxs(Heading, { level: 3, className: "font-semibold mb-1", children: [icon, " ", stepTitle] }), _jsx(Text, { variant: "secondary", size: "sm", className: "leading-relaxed", children: text })] })] }, number))) }), details.length > 0 && (_jsxs(_Fragment, { children: [detailsSectionTitle && (_jsx(Heading, { level: 2, className: "mb-6", children: detailsSectionTitle })), _jsx(Grid, { className: "grid-cols-1 sm:grid-cols-2 xl:grid-cols-2 2xl:grid-cols-3 mb-12", children: details.map(({ title: dt, text: dx }) => (_jsxs("div", { className: `${themed.bgSecondary} border ${themed.border} rounded-xl p-5`, "data-section": "howitworksinfoview-div-339", children: [_jsx(Heading, { level: 3, className: "font-semibold mb-2", children: dt }), _jsx(Text, { variant: "secondary", size: "sm", className: "leading-relaxed", children: dx })] }, dt))) })] })), renderFooter?.()] })] }));
8
8
  }
@@ -3,7 +3,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useEffect, useRef, useState } from "react";
4
4
  import { THEME_CONSTANTS } from "../../../tokens";
5
5
  import { Button, Div, Grid, Heading, Section, Text } from "../../../ui";
6
- // ─── Single step card ─────────────────────────────────────────────────────────
6
+ // --- Single step card ---------------------------------------------------------
7
7
  function StepCard({ step, visible, delay, }) {
8
8
  const { badgeBg = "bg-primary", iconColor = "text-primary", iconBg = "bg-primary/5 dark:bg-primary/10", } = step;
9
9
  return (_jsxs("div", { className: [
@@ -12,9 +12,9 @@ function StepCard({ step, visible, delay, }) {
12
12
  "shadow-md group hover:-translate-y-2 hover:shadow-xl",
13
13
  "transition-all duration-300",
14
14
  visible ? "opacity-100 translate-y-0" : "opacity-0 translate-y-8",
15
- ].join(" "), style: { transitionDelay: `${delay}ms` }, children: [_jsx("div", { className: "absolute top-4 right-5 font-display text-7xl bg-gradient-to-br from-primary to-cobalt opacity-10 bg-clip-text text-transparent select-none pointer-events-none leading-none", "aria-hidden": "true", children: step.number }), _jsx("div", { className: `relative z-10 w-10 h-10 rounded-full ${badgeBg} text-white font-bold text-sm flex items-center justify-center mb-5 shadow-md`, children: step.number }), step.renderIcon && (_jsx("div", { className: `relative z-10 w-14 h-14 rounded-2xl ${iconBg} flex items-center justify-center mb-4 border border-white/80 dark:border-slate-700/50`, children: _jsx("span", { className: `${iconColor}`, "aria-hidden": "true", children: step.renderIcon({ className: "w-6 h-6" }) }) })), _jsx(Heading, { level: 3, className: `relative z-10 text-base font-semibold ${THEME_CONSTANTS.themed.textPrimary} mb-2`, children: step.title }), _jsx(Text, { className: `relative z-10 text-sm ${THEME_CONSTANTS.themed.textSecondary} leading-relaxed`, children: step.desc })] }));
15
+ ].join(" "), style: { transitionDelay: `${delay}ms` }, "data-section": "howitworkssection-div-340", children: [_jsx("div", { className: "absolute top-4 right-5 font-display text-7xl bg-gradient-to-br from-primary to-cobalt opacity-10 bg-clip-text text-transparent select-none pointer-events-none leading-none", "aria-hidden": "true", "data-section": "howitworkssection-div-341", children: step.number }), _jsx("div", { className: `relative z-10 w-10 h-10 rounded-full ${badgeBg} text-white font-bold text-sm flex items-center justify-center mb-5 shadow-md`, "data-section": "howitworkssection-div-342", children: step.number }), step.renderIcon && (_jsx("div", { className: `relative z-10 w-14 h-14 rounded-2xl ${iconBg} flex items-center justify-center mb-4 border border-white/80 dark:border-slate-700/50`, "data-section": "howitworkssection-div-343", children: _jsx("span", { className: `${iconColor}`, "aria-hidden": "true", children: step.renderIcon({ className: "w-6 h-6" }) }) })), _jsx(Heading, { level: 3, className: `relative z-10 text-base font-semibold ${THEME_CONSTANTS.themed.textPrimary} mb-2`, children: step.title }), _jsx(Text, { className: `relative z-10 text-sm ${THEME_CONSTANTS.themed.textSecondary} leading-relaxed`, children: step.desc })] }));
16
16
  }
17
- // ─── Section ─────────────────────────────────────────────────────────────────
17
+ // --- Section -----------------------------------------------------------------
18
18
  export function HowItWorksSection({ title, subtitle, pillLabel, ctaLabel, onCtaClick, steps, className = "", }) {
19
19
  const { themed } = THEME_CONSTANTS;
20
20
  const sectionRef = useRef(null);
@@ -32,5 +32,5 @@ export function HowItWorksSection({ title, subtitle, pillLabel, ctaLabel, onCtaC
32
32
  observer.observe(el);
33
33
  return () => observer.disconnect();
34
34
  }, []);
35
- return (_jsx(Section, { ref: sectionRef, className: `p-8 ${themed.bgPrimary} ${className}`, children: _jsxs(Div, { className: "max-w-6xl mx-auto", children: [_jsxs("div", { className: `text-center mb-12 transition-all duration-700 ${visible ? "opacity-100 translate-y-0" : "opacity-0 translate-y-4"}`, children: [pillLabel && (_jsx("div", { className: "inline-block mb-4 inline-flex items-center gap-2 rounded-full border border-primary-500/30 bg-primary-500/10 px-5 py-1.5 text-xs font-medium tracking-[0.2em] uppercase text-primary-700 dark:text-primary-400 backdrop-blur-sm", children: pillLabel })), _jsx(Heading, { level: 2, className: `text-3xl md:text-4xl font-bold ${themed.textPrimary} mb-3`, children: title }), subtitle && (_jsx(Text, { className: `text-base ${themed.textSecondary} max-w-xl mx-auto`, children: subtitle }))] }), _jsx(Grid, { gap: "lg", className: "grid-cols-1 md:grid-cols-3 xl:grid-cols-3 2xl:grid-cols-3 mb-10", children: steps.map((step, i) => (_jsx(StepCard, { step: step, visible: visible, delay: i * 150 }, step.number))) }), ctaLabel && onCtaClick && (_jsx("div", { className: `text-center transition-all duration-700 delay-500 ${visible ? "opacity-100 translate-y-0" : "opacity-0 translate-y-4"}`, children: _jsx(Button, { variant: "primary", size: "lg", onClick: onCtaClick, children: ctaLabel }) }))] }) }));
35
+ return (_jsx(Section, { ref: sectionRef, className: `p-8 ${themed.bgPrimary} ${className}`, children: _jsxs(Div, { className: "max-w-6xl mx-auto", children: [_jsxs("div", { className: `text-center mb-12 transition-all duration-700 ${visible ? "opacity-100 translate-y-0" : "opacity-0 translate-y-4"}`, "data-section": "howitworkssection-div-344", children: [pillLabel && (_jsx("div", { className: "inline-block mb-4 inline-flex items-center gap-2 rounded-full border border-primary-500/30 bg-primary-500/10 px-5 py-1.5 text-xs font-medium tracking-[0.2em] uppercase text-primary-700 dark:text-primary-400 backdrop-blur-sm", "data-section": "howitworkssection-div-345", children: pillLabel })), _jsx(Heading, { level: 2, className: `text-3xl md:text-4xl font-bold ${themed.textPrimary} mb-3`, children: title }), subtitle && (_jsx(Text, { className: `text-base ${themed.textSecondary} max-w-xl mx-auto`, children: subtitle }))] }), _jsx(Grid, { gap: "lg", className: "grid-cols-1 md:grid-cols-3 xl:grid-cols-3 2xl:grid-cols-3 mb-10", children: steps.map((step, i) => (_jsx(StepCard, { step: step, visible: visible, delay: i * 150 }, step.number))) }), ctaLabel && onCtaClick && (_jsx("div", { className: `text-center transition-all duration-700 delay-500 ${visible ? "opacity-100 translate-y-0" : "opacity-0 translate-y-4"}`, "data-section": "howitworkssection-div-346", children: _jsx(Button, { variant: "primary", size: "lg", onClick: onCtaClick, children: ctaLabel }) }))] }) }));
36
36
  }
@@ -0,0 +1,25 @@
1
+ import React from "react";
2
+ export interface MarketplaceHomepageViewAdSlots {
3
+ /** Rendered immediately after the hero carousel. Good for a full-width banner. */
4
+ afterHero?: React.ReactNode;
5
+ /** Rendered between featured products and featured auctions. */
6
+ afterFeaturedProducts?: React.ReactNode;
7
+ /** Rendered after the customer reviews section. */
8
+ afterReviews?: React.ReactNode;
9
+ /** Rendered after the FAQ section. */
10
+ afterFAQ?: React.ReactNode;
11
+ }
12
+ export interface MarketplaceHomepageViewProps {
13
+ /**
14
+ * Optional ad slot content injected at key positions in the homepage.
15
+ * Pass `<AdSlot id="..." />` as values; they render nothing when the slot
16
+ * is not configured or consent hasn't been granted.
17
+ */
18
+ adSlots?: MarketplaceHomepageViewAdSlots;
19
+ /**
20
+ * Optional newsletter form content for homepage section #16.
21
+ * Provide a client component wired to live subscribe actions/API.
22
+ */
23
+ newsletterFormSlot?: React.ReactNode;
24
+ }
25
+ export declare function MarketplaceHomepageView({ adSlots, newsletterFormSlot, }?: MarketplaceHomepageViewProps): Promise<import("react/jsx-runtime").JSX.Element>;
@@ -0,0 +1,252 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from "react";
3
+ import { Main } from "../../../ui";
4
+ import { carouselRepository, faqsRepository, siteSettingsRepository } from "../../../repositories";
5
+ import { ROUTES } from "../../../next";
6
+ import { AnnouncementBar } from "./AnnouncementBar";
7
+ import { HeroCarousel } from "./HeroCarousel";
8
+ import { StatsCounterSection } from "./StatsCounterSection";
9
+ import { TrustFeaturesSection } from "./TrustFeaturesSection";
10
+ import { ShopByCategorySection } from "./ShopByCategorySection";
11
+ import { FeaturedProductsSection } from "./FeaturedProductsSection";
12
+ import { FeaturedAuctionsSection } from "./FeaturedAuctionsSection";
13
+ import { FeaturedPreOrdersSection } from "./FeaturedPreOrdersSection";
14
+ import { FeaturedStoresSection } from "./FeaturedStoresSection";
15
+ import { EventsSection } from "./EventsSection";
16
+ import { CTABannerSection } from "./CTABannerSection";
17
+ import { HomepageCustomerReviewsSection } from "./HomepageCustomerReviewsSection";
18
+ import { SecurityHighlightsSection } from "./SecurityHighlightsSection";
19
+ import { WhatsAppCommunitySection } from "./WhatsAppCommunitySection";
20
+ import { FAQSection } from "./FAQSection";
21
+ import { NewsletterSection } from "./NewsletterSection";
22
+ import { BlogArticlesSection } from "./BlogArticlesSection";
23
+ import { WelcomeSection } from "./WelcomeSection";
24
+ import { BrandsSection } from "./BrandsSection";
25
+ import { homepageSectionsRepository } from "../repository/homepage-sections.repository";
26
+ const DEFAULT_TRUST_FEATURES = [
27
+ {
28
+ iconName: "secure-payments",
29
+ title: "Secure Payments",
30
+ description: "Protected payments with transparent order tracking.",
31
+ },
32
+ {
33
+ iconName: "fast-delivery",
34
+ title: "Fast Delivery",
35
+ description: "Fast shipping with reliable nationwide logistics partners.",
36
+ },
37
+ {
38
+ iconName: "easy-returns",
39
+ title: "Easy Returns",
40
+ description: "Hassle-free returns within the policy window.",
41
+ },
42
+ {
43
+ iconName: "support",
44
+ title: "24/7 Support",
45
+ description: "Real help from our team across pre and post purchase.",
46
+ },
47
+ ];
48
+ const DEFAULT_HOW_IT_WORKS = [
49
+ {
50
+ number: 1,
51
+ title: "Browse & Discover",
52
+ desc: "Search 10,000+ listings across products, auctions, and pre-orders.",
53
+ },
54
+ {
55
+ number: 2,
56
+ title: "Bid or Buy Now",
57
+ desc: "Place a bid on live auctions or buy instantly at the listed price.",
58
+ },
59
+ {
60
+ number: 3,
61
+ title: "Get Delivered",
62
+ desc: "Track your order end-to-end until it arrives at your door.",
63
+ },
64
+ ];
65
+ const DEFAULT_SECURITY_ITEMS = [
66
+ {
67
+ key: "encryption",
68
+ title: "End-to-End Encryption",
69
+ description: "All sensitive data is encrypted in transit and at rest.",
70
+ },
71
+ {
72
+ key: "tls",
73
+ title: "TLS 1.3 in Transit",
74
+ description: "Every API call and page load is secured with modern TLS.",
75
+ },
76
+ {
77
+ key: "rbac",
78
+ title: "Role-Based Access",
79
+ description: "Strict role boundaries keep buyer, seller, and admin data separate.",
80
+ },
81
+ {
82
+ key: "min-priv",
83
+ title: "Minimum-Privilege Tokens",
84
+ description: "Short-lived, scoped tokens minimise exposure on every request.",
85
+ },
86
+ ];
87
+ // --- Helpers -----------------------------------------------------------------
88
+ function parseWelcomeDescription(description) {
89
+ if (!description)
90
+ return "";
91
+ try {
92
+ const parsed = JSON.parse(description);
93
+ const extracted = parsed.content
94
+ ?.flatMap((node) => node.content ?? [])
95
+ .map((leaf) => leaf.text ?? "")
96
+ .join(" ")
97
+ .trim();
98
+ return extracted || description;
99
+ }
100
+ catch {
101
+ return description;
102
+ }
103
+ }
104
+ /**
105
+ * Render a single homepage section based on its type and config
106
+ */
107
+ const AD_SLOT_MAP = {
108
+ products: "afterFeaturedProducts",
109
+ reviews: "afterReviews",
110
+ faq: "afterFAQ",
111
+ };
112
+ function renderSection(section, adSlots, newsletterFormSlot, faqItems) {
113
+ const { type, config } = section;
114
+ const adSlotKey = AD_SLOT_MAP[type];
115
+ const sectionElement = (() => {
116
+ switch (type) {
117
+ case "welcome": {
118
+ const cfg = config;
119
+ const title = cfg?.h1 || "Discover Amazing Products";
120
+ const subtitle = parseWelcomeDescription(cfg?.description);
121
+ const ctaText = cfg?.ctaText || "Shop Now";
122
+ const ctaLink = cfg?.ctaLink || ROUTES.PUBLIC.PRODUCTS;
123
+ return (_jsx(WelcomeSection, { title: title, subtitle: subtitle, pillLabel: "India's #1 Marketplace", showCTA: cfg?.showCTA ?? true, ctaLabel: ctaText, ctaHref: ctaLink, secondaryCtaLabel: "Browse All", secondaryCtaHref: ROUTES.PUBLIC.PRODUCTS, trustChips: [
124
+ { key: "delivery", emoji: "🚀", label: "Fast Delivery" },
125
+ { key: "secure", emoji: "🔒", label: "Secure Payments" },
126
+ { key: "rating", emoji: "⭐", label: "4.8+ Rated" },
127
+ { key: "returns", emoji: "↩️", label: "Easy Returns" },
128
+ ], brandLogoText: "LIR" }));
129
+ }
130
+ case "categories": {
131
+ const cfg = config;
132
+ return (_jsx(ShopByCategorySection, { title: cfg?.title || "Shop by Category", viewMoreHref: ROUTES.PUBLIC.CATEGORIES, viewMoreLabel: "All categories \u2192" }));
133
+ }
134
+ case "stats": {
135
+ const cfg = config;
136
+ const stats = Array.isArray(cfg?.stats)
137
+ ? cfg.stats
138
+ .filter((item) => typeof item?.label === "string" &&
139
+ item.label.trim().length > 0 &&
140
+ typeof item?.value === "string" &&
141
+ item.value.trim().length > 0)
142
+ .map((item, index) => ({
143
+ key: typeof item?.key === "string" && item.key.trim().length > 0
144
+ ? item.key
145
+ : `stat-${index}`,
146
+ label: item.label,
147
+ value: item.value,
148
+ }))
149
+ : [];
150
+ if (stats.length === 0) {
151
+ return null;
152
+ }
153
+ return _jsx(StatsCounterSection, { stats: stats });
154
+ }
155
+ case "products": {
156
+ const cfg = config;
157
+ return (_jsx(FeaturedProductsSection, { title: cfg?.title || "Featured Products", viewMoreHref: ROUTES.PUBLIC.PRODUCTS, viewMoreLabel: "View all products \u2192" }));
158
+ }
159
+ case "auctions": {
160
+ const cfg = config;
161
+ return (_jsx(FeaturedAuctionsSection, { title: cfg?.title || "Live Auctions", viewMoreHref: ROUTES.PUBLIC.AUCTIONS, viewMoreLabel: "View all auctions \u2192" }));
162
+ }
163
+ case "pre-orders": {
164
+ const cfg = config;
165
+ return (_jsx(FeaturedPreOrdersSection, { title: cfg?.title || "Reserve Before It Ships", viewMoreHref: ROUTES.PUBLIC.PRE_ORDERS, viewMoreLabel: "View all pre-orders \u2192" }));
166
+ }
167
+ case "stores": {
168
+ const cfg = config;
169
+ return (_jsx(FeaturedStoresSection, { title: cfg?.title || "Featured Stores", viewMoreHref: ROUTES.PUBLIC.STORES, viewMoreLabel: "View all stores \u2192" }));
170
+ }
171
+ case "events": {
172
+ const cfg = config;
173
+ return (_jsx(EventsSection, { title: cfg?.title || "Events & Offers", viewMoreHref: ROUTES.PUBLIC.EVENTS, viewMoreLabel: "View all events \u2192" }));
174
+ }
175
+ case "reviews": {
176
+ const cfg = config;
177
+ return (_jsx(HomepageCustomerReviewsSection, { title: cfg?.title || "What Our Customers Say", viewMoreHref: ROUTES.PUBLIC.REVIEWS, viewMoreLabel: "See all reviews \u2192" }));
178
+ }
179
+ case "banner": {
180
+ const cfg = config;
181
+ return (_jsx(CTABannerSection, { title: cfg?.content?.title || "Thousands of collectibles. One marketplace.", primaryLabel: "Shop All Products \u2192", primaryHref: ROUTES.PUBLIC.PRODUCTS, secondaryLabel: "Browse Auctions \u2192", secondaryHref: ROUTES.PUBLIC.AUCTIONS }));
182
+ }
183
+ case "trust-indicators": {
184
+ const cfg = config;
185
+ return (_jsx(TrustFeaturesSection, { title: cfg?.title || "Why Buyers Trust LetiTrip", items: DEFAULT_TRUST_FEATURES }));
186
+ }
187
+ case "features": {
188
+ const cfg = config;
189
+ return (_jsx(SecurityHighlightsSection, { title: cfg?.title || "Security You Can Trust", pillLabel: "Built for trust", items: DEFAULT_SECURITY_ITEMS, learnMoreHref: ROUTES.PUBLIC.SECURITY, learnMoreLabel: "Learn about our security \u2192" }));
190
+ }
191
+ case "whatsapp-community": {
192
+ const cfg = config;
193
+ return (_jsx(WhatsAppCommunitySection, { title: cfg?.title || "Join Our WhatsApp Community", descriptionHtml: cfg?.description || "5,000+ members. Get deal alerts, auction updates, and exclusive drops before anyone else.", memberCount: cfg?.memberCount || 5000, groupLink: cfg?.groupLink || "https://chat.whatsapp.com/" }));
194
+ }
195
+ case "faq": {
196
+ const cfg = config;
197
+ if (!cfg?.showOnHomepage) {
198
+ return null;
199
+ }
200
+ return (_jsx(FAQSection, { title: cfg?.title || "Frequently Asked Questions", tabs: [], activeTab: "", items: faqItems, viewMoreHref: ROUTES.PUBLIC.FAQS, viewMoreLabel: "View all FAQs \u2192" }));
201
+ }
202
+ case "blog-articles": {
203
+ const cfg = config;
204
+ return (_jsx(BlogArticlesSection, { title: cfg?.title || "From Our Blog", viewMoreHref: ROUTES.BLOG.LIST, viewMoreLabel: "View all posts \u2192" }));
205
+ }
206
+ case "newsletter": {
207
+ const cfg = config;
208
+ return (_jsx(NewsletterSection, { title: cfg?.title || "Stay Updated", subtitle: cfg?.description || "Get the latest drops, auctions, and deals in your inbox.", renderForm: () => newsletterFormSlot ?? null }));
209
+ }
210
+ case "brands": {
211
+ const cfg = config;
212
+ return (_jsx(BrandsSection, { title: cfg?.title || "Top Brands", subtitle: cfg?.subtitle, limit: cfg?.maxBrands || 12, viewMoreHref: ROUTES.PUBLIC.CATEGORIES, viewMoreLabel: "All brands \u2192" }));
213
+ }
214
+ default:
215
+ return null;
216
+ }
217
+ })();
218
+ // Return section with optional ad slot before it
219
+ if (!sectionElement) {
220
+ return null;
221
+ }
222
+ return (_jsxs(React.Fragment, { children: [sectionElement, adSlots && adSlotKey !== undefined && adSlotKey in adSlots && adSlots[adSlotKey]] }, section.id));
223
+ }
224
+ // --- Main View ---------------------------------------------------------------
225
+ export async function MarketplaceHomepageView({ adSlots, newsletterFormSlot, } = {}) {
226
+ // Load carousel slides and sections from DB
227
+ const slides = await carouselRepository.getActiveSlides().catch(() => []);
228
+ const siteSettings = await siteSettingsRepository.getSingleton().catch(() => null);
229
+ const announcementMessage = siteSettings?.announcementBar?.message?.trim() ||
230
+ "🎉 Up to 15% Off on Pokémon TCG this week — Use code SAVE15";
231
+ const showAnnouncement = siteSettings?.announcementBar?.enabled ?? true;
232
+ const [enabledSections, rawFaqItems] = await Promise.all([
233
+ homepageSectionsRepository.getEnabledSections().catch(() => []),
234
+ faqsRepository.getHomepageFAQs().catch(() => []),
235
+ ]);
236
+ const orderedSections = [...enabledSections].sort((a, b) => {
237
+ if (a.order !== b.order)
238
+ return a.order - b.order;
239
+ const aUpdated = new Date(a.updatedAt).getTime();
240
+ const bUpdated = new Date(b.updatedAt).getTime();
241
+ if (aUpdated !== bUpdated)
242
+ return aUpdated - bUpdated;
243
+ return a.id.localeCompare(b.id);
244
+ });
245
+ const faqItems = rawFaqItems.map((faq) => ({
246
+ id: faq.id,
247
+ question: faq.question,
248
+ answer: typeof faq.answer === "string" ? faq.answer : faq.answer.text,
249
+ }));
250
+ // Render with dynamic sections from DB
251
+ return (_jsxs(Main, { children: [showAnnouncement ? _jsx(AnnouncementBar, { message: announcementMessage }) : null, _jsx(HeroCarousel, { initialSlides: slides }), adSlots?.afterHero, orderedSections.map((section) => renderSection(section, adSlots, newsletterFormSlot ?? null, faqItems))] }));
252
+ }
@@ -1,8 +1,7 @@
1
- "use client";
2
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
2
  import { Heading, Section, Text, TextLink } from "../../../ui";
4
3
  import { Mail } from "lucide-react";
5
- // ─── Section ─────────────────────────────────────────────────────────────────
4
+ // --- Section -----------------------------------------------------------------
6
5
  export function NewsletterSection({ title, subtitle, privacyLabel, privacyHref, renderForm, className = "", }) {
7
- return (_jsxs(Section, { className: `py-16 px-4 relative overflow-hidden ${className}`, children: [_jsx("div", { className: "absolute inset-0 bg-gradient-to-br from-primary/10 via-cobalt/5 to-secondary/10 dark:from-primary/15 dark:via-cobalt/10 dark:to-secondary/15 pointer-events-none", "aria-hidden": true }), _jsx("div", { className: "absolute -top-20 -right-20 w-80 h-80 rounded-full bg-primary/5 dark:bg-primary/10 pointer-events-none", "aria-hidden": true }), _jsx("div", { className: "absolute -bottom-16 -left-16 w-64 h-64 rounded-full bg-cobalt/5 dark:bg-cobalt/10 pointer-events-none", "aria-hidden": true }), _jsxs("div", { className: "relative z-10 max-w-2xl mx-auto text-center", children: [_jsx("div", { className: "inline-flex items-center justify-center w-14 h-14 rounded-2xl bg-primary/10 dark:bg-primary/20 border border-primary/20 mb-5 mx-auto", children: _jsx(Mail, { className: "w-7 h-7 text-primary" }) }), _jsx(Heading, { level: 2, className: "text-2xl sm:text-3xl font-bold text-zinc-900 dark:text-white mb-3", children: title }), subtitle && (_jsx(Text, { size: "base", className: "text-zinc-500 dark:text-zinc-400 mb-8 max-w-md mx-auto", children: subtitle })), renderForm(), privacyLabel && privacyHref && (_jsxs(Text, { size: "xs", className: "text-zinc-400 dark:text-zinc-500 mt-4", children: [privacyLabel, " ", _jsx(TextLink, { href: privacyHref, className: "underline underline-offset-2 hover:text-primary", children: "Privacy Policy" }), "."] }))] })] }));
6
+ return (_jsxs(Section, { className: `py-16 px-4 relative overflow-hidden ${className}`, children: [_jsx("div", { className: "absolute inset-0 bg-gradient-to-br from-primary/10 via-cobalt/5 to-secondary/10 dark:from-primary/15 dark:via-cobalt/10 dark:to-secondary/15 pointer-events-none", "aria-hidden": true }), _jsx("div", { className: "absolute -top-20 -right-20 w-80 h-80 rounded-full bg-primary/5 dark:bg-primary/10 pointer-events-none", "aria-hidden": true }), _jsx("div", { className: "absolute -bottom-16 -left-16 w-64 h-64 rounded-full bg-cobalt/5 dark:bg-cobalt/10 pointer-events-none", "aria-hidden": true }), _jsxs("div", { className: "relative z-10 max-w-2xl mx-auto text-center", "data-section": "newslettersection-div-347", children: [_jsx("div", { className: "inline-flex items-center justify-center w-14 h-14 rounded-2xl bg-primary/10 dark:bg-primary/20 border border-primary/20 mb-5 mx-auto", "data-section": "newslettersection-div-348", children: _jsx(Mail, { className: "w-7 h-7 text-primary" }) }), _jsx(Heading, { level: 2, className: "text-2xl sm:text-3xl font-bold text-zinc-900 dark:text-white mb-3", children: title }), subtitle && (_jsx(Text, { size: "base", className: "text-zinc-500 dark:text-zinc-400 mb-8 max-w-md mx-auto", children: subtitle })), renderForm(), privacyLabel && privacyHref && (_jsxs(Text, { size: "xs", className: "text-zinc-400 dark:text-zinc-500 mt-4", children: [privacyLabel, " ", _jsx(TextLink, { href: privacyHref, className: "underline underline-offset-2 hover:text-primary", children: "Privacy Policy" }), "."] }))] })] }));
8
7
  }
@@ -1,15 +1,14 @@
1
- "use client";
2
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
2
  import { THEME_CONSTANTS } from "../../../tokens";
4
3
  import { Heading, HorizontalScroller, Section, Span, Text, TextLink, } from "../../../ui";
5
4
  import { MediaImage } from "../../media/MediaImage";
6
- // ─── Skeleton ────────────────────────────────────────────────────────────────
5
+ // --- Skeleton ----------------------------------------------------------------
7
6
  function CarouselSkeleton({ count }) {
8
7
  const { skeleton } = THEME_CONSTANTS;
9
- return (_jsx("div", { className: "flex gap-4 overflow-hidden px-4", children: Array.from({ length: count }).map((_, i) => (_jsxs("div", { className: "flex-none min-w-[clamp(150px,18vw,260px)] max-w-[clamp(240px,36vw,380px)] h-[clamp(180px,26vh,260px)] space-y-2", children: [_jsx("div", { className: `aspect-square rounded-xl ${skeleton.image}` }), _jsx("div", { className: `${skeleton.text} w-3/4` }), _jsx("div", { className: `${skeleton.text} w-1/2` })] }, i))) }));
8
+ return (_jsx("div", { className: "flex gap-4 overflow-hidden px-4", "data-section": "sectioncarousel-div-349", children: Array.from({ length: count }).map((_, i) => (_jsxs("div", { className: "flex-none min-w-[clamp(150px,18vw,260px)] max-w-[clamp(240px,36vw,380px)] h-[clamp(180px,26vh,260px)] space-y-2", "data-section": "sectioncarousel-div-350", children: [_jsx("div", { className: `aspect-square rounded-xl ${skeleton.image}` }), _jsx("div", { className: `${skeleton.text} w-3/4` }), _jsx("div", { className: `${skeleton.text} w-1/2` })] }, i))) }));
10
9
  }
11
- // ─── Component ───────────────────────────────────────────────────────────────
12
- export function SectionCarousel({ title, description, headingVariant = "default", pillLabel, backgroundImage, viewMoreHref, viewMoreLabel = "View all →", items, renderItem, perView = { base: 1, sm: 2, md: 3 }, gap = 16, autoScroll = false, autoScrollInterval = 3500, keyExtractor, rows = 1, className = "", isLoading = false, skeletonCount = 4, lightText, showPeek = false, minItemWidth = 220, }) {
10
+ // --- Component ---------------------------------------------------------------
11
+ export function SectionCarousel({ title, description, headingVariant = "default", pillLabel, backgroundImage, viewMoreHref, viewMoreLabel = "View all →", items, renderItem, perView = THEME_CONSTANTS.carousel.perView.default, gap = 16, autoScroll = false, autoScrollInterval = 3500, keyExtractor, rows = 1, className = "", isLoading = false, skeletonCount = 4, lightText, showPeek = false, minItemWidth = 220, }) {
13
12
  const hasBg = Boolean(backgroundImage);
14
13
  const useLightText = lightText ?? hasBg;
15
14
  const { themed, flex } = THEME_CONSTANTS;
@@ -27,13 +26,20 @@ export function SectionCarousel({ title, description, headingVariant = "default"
27
26
  className,
28
27
  ]
29
28
  .filter(Boolean)
30
- .join(" "), children: [hasBg && backgroundImage && (_jsxs(_Fragment, { children: [_jsx("div", { className: "absolute inset-0 overflow-hidden", children: _jsx(MediaImage, { src: backgroundImage, alt: "", size: "hero" }) }), _jsx("div", { className: "absolute inset-0 bg-black/55" })] })), _jsxs("div", { className: "relative z-10 w-full max-w-7xl mx-auto", children: [_jsxs("div", { className: "text-center mb-6", children: [headingVariant === "editorial" && pillLabel && (_jsx("div", { className: "mb-4", children: _jsxs(Span, { className: pillClass, children: [_jsx(Span, { className: "w-1.5 h-1.5 rounded-full bg-primary-500 inline-block", "aria-hidden": "true" }), pillLabel, _jsx(Span, { className: "w-1.5 h-1.5 rounded-full bg-primary-500 inline-block", "aria-hidden": "true" })] }) })), _jsx(Heading, { level: 2, variant: "none", className: [
29
+ .join(" "), children: [hasBg && backgroundImage && (_jsxs(_Fragment, { children: [_jsx("div", { className: "absolute inset-0 overflow-hidden", "data-section": "sectioncarousel-div-351", children: _jsx(MediaImage, { src: backgroundImage, alt: "", size: "hero" }) }), _jsx("div", { className: "absolute inset-0 bg-black/55" })] })), _jsxs("div", { className: "relative z-10 w-full max-w-7xl mx-auto", "data-section": "sectioncarousel-div-352", children: [_jsxs("div", { className: "text-center mb-6", "data-section": "sectioncarousel-div-353", children: [headingVariant === "editorial" && pillLabel && (_jsx("div", { className: "mb-4", "data-section": "sectioncarousel-div-354", children: _jsxs(Span, { className: pillClass, children: [_jsx(Span, { className: "w-1.5 h-1.5 rounded-full bg-primary-500 inline-block", "aria-hidden": "true" }), pillLabel, _jsx(Span, { className: "w-1.5 h-1.5 rounded-full bg-primary-500 inline-block", "aria-hidden": "true" })] }) })), _jsx(Heading, { level: 2, variant: "none", className: [
31
30
  "text-3xl md:text-4xl font-bold mb-2",
32
31
  headingVariant === "editorial" ? "font-display text-4xl" : "",
33
32
  headingClass,
34
33
  ]
35
34
  .filter(Boolean)
36
- .join(" "), children: title }), headingVariant === "editorial" && (_jsxs("div", { className: `${flex.center} gap-2 mt-1 text-zinc-400 dark:text-zinc-500 text-xs select-none`, "aria-hidden": "true", children: [_jsx(Span, { className: "h-px w-6 bg-current" }), _jsx(Span, { className: "text-xs", children: "\u2736" }), _jsx(Span, { className: "h-px w-6 bg-current" })] })), description && (_jsx(Text, { className: `text-base ${descVariant} mt-2`, children: description }))] }), isLoading ? (_jsx(CarouselSkeleton, { count: skeletonCount })) : (_jsx(HorizontalScroller, { items: items, renderItem: renderItem, perView: perView, gap: gap, autoScroll: autoScroll, autoScrollInterval: autoScrollInterval, keyExtractor: keyExtractor, rows: rows, minItemWidth: minItemWidth })), viewMoreHref && !isLoading && (_jsx("div", { className: "mt-6 text-center", children: _jsx(TextLink, { href: viewMoreHref, className: `inline-flex items-center gap-2 px-6 py-2.5 rounded-full text-sm font-medium transition-colors ${useLightText
35
+ .join(" "), children: title }), headingVariant === "editorial" && (_jsxs("div", { className: `${flex.center} gap-2 mt-1 text-zinc-400 dark:text-zinc-500 text-xs select-none`, "aria-hidden": "true", "data-section": "sectioncarousel-div-355", children: [_jsx(Span, { className: "h-px w-6 bg-current" }), _jsx(Span, { className: "text-xs", children: "\u2736" }), _jsx(Span, { className: "h-px w-6 bg-current" })] })), description && (_jsx(Text, { className: `text-base ${descVariant} mt-2`, children: description }))] }), isLoading ? (_jsx(CarouselSkeleton, { count: skeletonCount })) : (_jsx(HorizontalScroller, { items: items, renderItem: renderItem, perView: perView, gap: gap, autoScroll: autoScroll, autoScrollInterval: autoScrollInterval, keyExtractor: keyExtractor, rows: rows, minItemWidth: minItemWidth,
36
+ /* Default behaviour for homepage sections using cards:
37
+ - show arrows for easier navigation
38
+ - snap to items for a tidy carousel feel
39
+ - show fade edges for visual affordance
40
+ - hide native scrollbar for cleaner appearance
41
+ */
42
+ showArrows: true, snapToItems: true, showFadeEdges: true, showScrollbar: false, pauseOnHover: true })), viewMoreHref && !isLoading && (_jsx("div", { className: "mt-6 text-center", "data-section": "sectioncarousel-div-356", children: _jsx(TextLink, { href: viewMoreHref, className: `inline-flex items-center gap-2 px-6 py-2.5 rounded-full text-sm font-medium transition-colors ${useLightText
37
43
  ? "bg-white/20 text-white hover:bg-white/30 backdrop-blur-sm"
38
44
  : "bg-primary/10 text-primary hover:bg-primary/20 dark:bg-primary/15 dark:text-primary-400"}`, children: viewMoreLabel }) }))] })] }));
39
45
  }
@@ -3,7 +3,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { useEffect, useRef, useState } from "react";
4
4
  import { THEME_CONSTANTS } from "../../../tokens";
5
5
  import { Grid, Heading, Section, Span, Text, TextLink } from "../../../ui";
6
- // ─── Single card ─────────────────────────────────────────────────────────────
6
+ // --- Single card -------------------------------------------------------------
7
7
  function SecurityCard({ item, visible, delay, }) {
8
8
  const colorClass = item.colorClass ??
9
9
  "bg-primary/5 border-primary/20 dark:bg-primary/10 dark:border-primary/30";
@@ -12,9 +12,9 @@ function SecurityCard({ item, visible, delay, }) {
12
12
  "rounded-xl border p-5 transition-all duration-500",
13
13
  colorClass,
14
14
  visible ? "opacity-100 translate-y-0" : "opacity-0 translate-y-4",
15
- ].join(" "), style: { transitionDelay: `${delay}ms` }, children: [item.renderIcon && (_jsx("div", { className: "w-10 h-10 rounded-lg bg-white/60 dark:bg-white/10 flex items-center justify-center mb-3", children: _jsx("span", { className: iconColorClass, "aria-hidden": "true", children: item.renderIcon({ className: "w-6 h-6" }) }) })), _jsx(Text, { className: "font-semibold mb-1", children: item.title }), _jsx(Text, { variant: "secondary", className: "text-sm leading-relaxed", children: item.description })] }));
15
+ ].join(" "), style: { transitionDelay: `${delay}ms` }, "data-section": "securityhighlightssection-div-357", children: [item.renderIcon && (_jsx("div", { className: "w-10 h-10 rounded-lg bg-white/60 dark:bg-white/10 flex items-center justify-center mb-3", "data-section": "securityhighlightssection-div-358", children: _jsx("span", { className: iconColorClass, "aria-hidden": "true", children: item.renderIcon({ className: "w-6 h-6" }) }) })), _jsx(Text, { className: "font-semibold mb-1", children: item.title }), _jsx(Text, { variant: "secondary", className: "text-sm leading-relaxed", children: item.description })] }));
16
16
  }
17
- // ─── Section ─────────────────────────────────────────────────────────────────
17
+ // --- Section -----------------------------------------------------------------
18
18
  export function SecurityHighlightsSection({ title, subtitle, pillLabel, items, learnMoreHref, learnMoreLabel = "Learn more →", className = "", }) {
19
19
  const { themed } = THEME_CONSTANTS;
20
20
  const sectionRef = useRef(null);
@@ -32,5 +32,5 @@ export function SecurityHighlightsSection({ title, subtitle, pillLabel, items, l
32
32
  observer.observe(el);
33
33
  return () => observer.disconnect();
34
34
  }, []);
35
- return (_jsx(Section, { ref: sectionRef, className: `py-14 px-4 ${themed.bgPrimary} ${className}`, children: _jsxs("div", { className: "max-w-6xl mx-auto", children: [_jsxs("div", { className: "text-center mb-10", children: [pillLabel && (_jsx(Span, { className: "inline-flex items-center gap-2 rounded-full border border-primary-500/30 bg-primary-500/10 px-5 py-1.5 text-xs font-medium tracking-[0.2em] uppercase text-primary-700 dark:text-primary-400 backdrop-blur-sm", children: pillLabel })), _jsx(Heading, { level: 2, className: `mt-4 text-3xl md:text-4xl font-bold ${themed.textPrimary}`, children: title }), subtitle && (_jsx(Text, { variant: "secondary", className: "mt-2 max-w-xl mx-auto", children: subtitle }))] }), _jsx(Grid, { gap: "none", className: "grid-cols-1 sm:grid-cols-2 xl:grid-cols-4 gap-5", children: items.map((item, index) => (_jsx(SecurityCard, { item: item, visible: visible, delay: index * 100 }, item.key))) }), learnMoreHref && (_jsx("div", { className: "text-center mt-8", children: _jsx(TextLink, { href: learnMoreHref, children: learnMoreLabel }) }))] }) }));
35
+ return (_jsx(Section, { ref: sectionRef, className: `py-14 px-4 ${themed.bgPrimary} ${className}`, children: _jsxs("div", { className: "max-w-6xl mx-auto", "data-section": "securityhighlightssection-div-359", children: [_jsxs("div", { className: "text-center mb-10", "data-section": "securityhighlightssection-div-360", children: [pillLabel && (_jsx(Span, { className: "inline-flex items-center gap-2 rounded-full border border-primary-500/30 bg-primary-500/10 px-5 py-1.5 text-xs font-medium tracking-[0.2em] uppercase text-primary-700 dark:text-primary-400 backdrop-blur-sm", children: pillLabel })), _jsx(Heading, { level: 2, className: `mt-4 text-3xl md:text-4xl font-bold ${themed.textPrimary}`, children: title }), subtitle && (_jsx(Text, { variant: "secondary", className: "mt-2 max-w-xl mx-auto", children: subtitle }))] }), _jsx(Grid, { gap: "none", className: "grid-cols-1 sm:grid-cols-2 xl:grid-cols-4 gap-5", children: items.map((item, index) => (_jsx(SecurityCard, { item: item, visible: visible, delay: index * 100 }, item.key))) }), learnMoreHref && (_jsx("div", { className: "text-center mt-8", "data-section": "securityhighlightssection-div-361", children: _jsx(TextLink, { href: learnMoreHref, children: learnMoreLabel }) }))] }) }));
36
36
  }
@@ -0,0 +1,9 @@
1
+ export interface ShopByCategorySectionProps {
2
+ title?: string;
3
+ subtitle?: string;
4
+ limit?: number;
5
+ viewMoreHref?: string;
6
+ viewMoreLabel?: string;
7
+ className?: string;
8
+ }
9
+ export declare function ShopByCategorySection({ title, subtitle, limit, viewMoreHref, viewMoreLabel, className, }: ShopByCategorySectionProps): import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1,21 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import Link from "next/link";
4
+ import { THEME_CONSTANTS } from "../../../tokens";
5
+ import { Heading, HorizontalScroller, Section, Text } from "../../../ui";
6
+ import { ROUTES } from "../../../next";
7
+ import { useTopCategories } from "../hooks/useTopCategories";
8
+ function CategoryChip({ category }) {
9
+ const iconSrc = category.display?.icon;
10
+ const coverImage = category.display?.coverImage;
11
+ const initial = category.name[0]?.toUpperCase() ?? "?";
12
+ const productCount = category.metrics?.productCount ?? 0;
13
+ return (_jsxs(Link, { href: ROUTES.PUBLIC.CATEGORY_DETAIL(category.slug), className: "group flex min-h-[220px] min-w-[180px] max-w-[220px] flex-col overflow-hidden rounded-xl border border-zinc-200 bg-white shadow-sm transition-all hover:border-primary-300 hover:shadow-md dark:border-slate-700 dark:bg-slate-900 dark:hover:border-primary-600", children: [coverImage ? (_jsx("div", { className: "aspect-video w-full overflow-hidden bg-zinc-100 dark:bg-slate-800", "data-section": "shopbycategorysection-div-362", children: _jsx("img", { src: coverImage, alt: category.name, className: "h-full w-full object-cover transition-transform duration-300 group-hover:scale-105" }) })) : (_jsx("div", { className: "aspect-video w-full bg-gradient-to-br from-zinc-100 to-zinc-200 dark:from-slate-800 dark:to-slate-700" })), _jsxs("div", { className: "flex flex-1 flex-col p-3 text-left", "data-section": "shopbycategorysection-div-363", children: [_jsx("div", { className: "mb-2 flex h-9 w-9 items-center justify-center rounded-lg bg-primary-100 text-sm font-bold text-primary-700 dark:bg-primary-900 dark:text-primary-300", "data-section": "shopbycategorysection-div-364", children: iconSrc ? (_jsx("img", { src: iconSrc, alt: "", className: "h-6 w-6 rounded object-cover", "aria-hidden": "true" })) : (initial) }), _jsx(Text, { className: `${THEME_CONSTANTS.utilities.textClamp2} text-sm font-semibold text-zinc-800 dark:text-zinc-200`, children: category.name }), _jsxs(Text, { className: "mt-1 text-xs text-zinc-500 dark:text-zinc-400", children: [productCount.toLocaleString(), " items"] }), _jsx(Text, { className: "mt-auto pt-3 text-xs font-medium text-primary dark:text-primary-400", children: "Browse category \u2192" })] })] }));
14
+ }
15
+ export function ShopByCategorySection({ title = "Shop by Category", subtitle, limit = 12, viewMoreHref, viewMoreLabel = "View all categories →", className = "", }) {
16
+ const { themed } = THEME_CONSTANTS;
17
+ const { data: categories = [], isLoading } = useTopCategories(limit);
18
+ if (!isLoading && categories.length === 0)
19
+ return null;
20
+ return (_jsx(Section, { className: `py-12 px-4 ${themed.bgSecondary} ${className}`, children: _jsxs("div", { className: "mx-auto max-w-7xl", "data-section": "shopbycategorysection-div-365", children: [_jsxs("div", { className: "mb-6 text-center", "data-section": "shopbycategorysection-div-366", children: [_jsx(Heading, { level: 2, className: `text-2xl font-bold md:text-3xl ${themed.textPrimary}`, children: title }), subtitle && (_jsx(Text, { variant: "secondary", className: "mt-1 text-sm", children: subtitle }))] }), isLoading ? (_jsx("div", { className: "flex gap-3 overflow-hidden px-1", "data-section": "shopbycategorysection-div-367", children: Array.from({ length: 6 }).map((_, i) => (_jsx("div", { className: "flex-none h-[104px] w-[108px] animate-pulse rounded-xl bg-zinc-200 dark:bg-slate-700" }, i))) })) : (_jsx(HorizontalScroller, { items: categories, renderItem: (cat) => _jsx(CategoryChip, { category: cat }), perView: THEME_CONSTANTS.carousel.perView.compact, gap: 16, keyExtractor: (cat) => cat.id, minItemWidth: 180 })), viewMoreHref && !isLoading && (_jsx("div", { className: "mt-6 text-center", "data-section": "shopbycategorysection-div-368", children: _jsx(Link, { href: viewMoreHref, className: "inline-flex items-center gap-1 text-sm font-medium text-primary hover:text-primary/80", children: viewMoreLabel }) }))] }) }));
21
+ }