@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
@@ -8,8 +8,8 @@ export function ForgotPasswordView({ onSubmit, isLoading = false, error, success
8
8
  e.preventDefault();
9
9
  await onSubmit(email);
10
10
  }, [onSubmit, email]);
11
- return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Forgot Password" }), _jsx(Text, { className: "mt-2 text-sm text-neutral-600", children: labels.description ??
12
- "Enter your email and we'll send you a reset link." })] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), !success && (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "fp-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "fp-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: email, onChange: (e) => setEmail(e.target.value), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
11
+ return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Forgot Password" }), _jsx(Text, { className: "mt-2 text-sm text-neutral-600 dark:text-zinc-400", children: labels.description ??
12
+ "Enter your email and we'll send you a reset link." })] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), !success && (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "fp-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "fp-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: email, onChange: (e) => setEmail(e.target.value), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
13
13
  ? (labels.submittingLabel ?? "Sending…")
14
14
  : (labels.submitLabel ?? "Send reset link") })] })), renderBackLink && (_jsx(Div, { className: "text-center text-sm", children: renderBackLink() }))] }) }));
15
15
  }
@@ -6,7 +6,7 @@ import type { UserRole } from "../types";
6
6
  */
7
7
  export interface AuthGuardUser {
8
8
  id?: string;
9
- role?: UserRole;
9
+ role?: UserRole | string;
10
10
  disabled?: boolean;
11
11
  emailVerified?: boolean;
12
12
  }
@@ -27,7 +27,7 @@ export interface AuthRouteConfig {
27
27
  * <RoleGate
28
28
  * user={currentUser}
29
29
  * allowedRoles="admin"
30
- * fallback={<div>Not authorized</div>}
30
+ * fallback={<div data-section="guards-div-259">Not authorized</div>}
31
31
  * >
32
32
  * <AdminPanel />
33
33
  * </RoleGate>
@@ -7,7 +7,7 @@ export function RoleGate({ children, user, allowedRoles, fallback = null, }) {
7
7
  return _jsx(_Fragment, { children: fallback });
8
8
  }
9
9
  const allowed = Array.isArray(allowedRoles) ? allowedRoles : [allowedRoles];
10
- if (!allowed.includes(user.role)) {
10
+ if (!allowed.some((role) => role === user.role)) {
11
11
  return _jsx(_Fragment, { children: fallback });
12
12
  }
13
13
  return _jsx(_Fragment, { children: children });
@@ -42,7 +42,7 @@ export function ProtectedRoute({ children, user, loading = false, requireAuth =
42
42
  if (requireRole) {
43
43
  const roles = Array.isArray(requireRole) ? requireRole : [requireRole];
44
44
  const userRole = user.role;
45
- if (!userRole || !roles.includes(userRole)) {
45
+ if (!userRole || !roles.some((role) => role === userRole)) {
46
46
  return { isAuthorized: false, redirectPath: unauthorizedPath };
47
47
  }
48
48
  }
@@ -12,7 +12,7 @@ export function LoginForm({ onSubmit, onGoogleLogin, isLoading = false, error, l
12
12
  e.preventDefault();
13
13
  await onSubmit(values);
14
14
  }, [onSubmit, values]);
15
- return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Sign In" }), (labels.subtitle || renderCreateAccountLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600", children: [labels.subtitle ?? "Or", " ", renderCreateAccountLink?.()] }))] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "login-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "login-password", name: "password", type: "password", autoComplete: "current-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Row, { justify: "between", children: [_jsxs(Row, { className: "gap-2", children: [_jsx("input", { id: "login-remember", type: "checkbox", checked: values.rememberMe ?? false, onChange: (e) => setValues({ ...values, rememberMe: e.target.checked }), className: "h-4 w-4 rounded border-neutral-300 accent-primary" }), _jsx(Label, { htmlFor: "login-remember", className: "text-sm", children: labels.rememberMe ?? "Remember me" })] }), renderForgotPasswordLink?.()] }), renderSubmitButton ? (renderSubmitButton(isLoading, labels)) : (_jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
15
+ return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Sign In" }), (labels.subtitle || renderCreateAccountLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600", children: [labels.subtitle ?? "Or", " ", renderCreateAccountLink?.()] }))] }), error && (_jsx(Alert, { variant: "error", compact: true, children: error })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "login-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-700 bg-white dark:bg-slate-900 text-zinc-900 dark:text-zinc-50 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "login-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "login-password", name: "password", type: "password", autoComplete: "current-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-700 bg-white dark:bg-slate-900 text-zinc-900 dark:text-zinc-50 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Row, { justify: "between", children: [_jsxs(Row, { className: "gap-2", children: [_jsx("input", { id: "login-remember", type: "checkbox", checked: values.rememberMe ?? false, onChange: (e) => setValues({ ...values, rememberMe: e.target.checked }), className: "h-4 w-4 rounded border-neutral-300 dark:border-slate-600 accent-primary" }), _jsx(Label, { htmlFor: "login-remember", className: "text-sm", children: labels.rememberMe ?? "Remember me" })] }), renderForgotPasswordLink?.()] }), renderSubmitButton ? (renderSubmitButton(isLoading, labels)) : (_jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
16
16
  ? (labels.submittingLabel ?? "Signing in…")
17
17
  : (labels.submitLabel ?? "Sign in") }))] }), renderSocialButtons?.()] }) }));
18
18
  }
@@ -0,0 +1 @@
1
+ export declare function OAuthLoadingView(): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,5 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Div, Heading, Text } from "../../../ui";
3
+ export function OAuthLoadingView() {
4
+ return (_jsx(Div, { className: "flex items-center justify-center min-h-[60vh] px-4", children: _jsxs(Div, { className: "max-w-sm w-full text-center", children: [_jsx(Div, { className: "w-12 h-12 rounded-full border-4 border-primary border-t-transparent animate-spin mx-auto mb-6" }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: "Signing you in\u2026" }), _jsx(Text, { variant: "secondary", className: "text-sm", children: "Please wait while we complete your sign-in." })] }) }));
5
+ }
@@ -21,7 +21,7 @@ export function RegisterForm({ onSubmit, isLoading = false, error, success, labe
21
21
  await onSubmit(values);
22
22
  }, [onSubmit, values, labels.passwordMismatch]);
23
23
  const displayError = error ?? validationError;
24
- return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Create Account" }), (labels.subtitle || renderLoginLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600", children: [labels.subtitle ?? "Already have an account?", " ", renderLoginLink?.()] }))] }), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-name", className: "block text-sm font-medium mb-1", children: labels.displayNameLabel ?? "Full name" }), _jsx("input", { id: "reg-name", name: "displayName", type: "text", autoComplete: "name", required: true, placeholder: labels.displayNamePlaceholder ?? "Your name", value: values.displayName, onChange: (e) => setValues({ ...values, displayName: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "reg-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "reg-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" }), renderPasswordStrength?.(values.password)] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm password" }), _jsx("input", { id: "reg-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: values.confirmPassword, onChange: (e) => setValues({ ...values, confirmPassword: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { className: "flex items-start gap-2", children: [_jsx("input", { id: "reg-terms", type: "checkbox", required: true, checked: values.acceptTerms, onChange: (e) => setValues({ ...values, acceptTerms: e.target.checked }), className: "mt-0.5 h-4 w-4 rounded border-neutral-300 accent-primary" }), _jsxs(Label, { htmlFor: "reg-terms", className: "text-sm leading-snug", children: [labels.acceptTermsLabel ?? "I accept the", " ", renderTermsLink?.()] })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
24
+ return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Create Account" }), (labels.subtitle || renderLoginLink) && (_jsxs(Text, { className: "mt-2 text-sm text-neutral-600 dark:text-zinc-400", children: [labels.subtitle ?? "Already have an account?", " ", renderLoginLink?.()] }))] }), success && (_jsx(Alert, { variant: "success", compact: true, children: success })), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), _jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-name", className: "block text-sm font-medium mb-1", children: labels.displayNameLabel ?? "Full name" }), _jsx("input", { id: "reg-name", name: "displayName", type: "text", autoComplete: "name", required: true, placeholder: labels.displayNamePlaceholder ?? "Your name", value: values.displayName, onChange: (e) => setValues({ ...values, displayName: e.target.value }), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-email", className: "block text-sm font-medium mb-1", children: labels.emailLabel ?? "Email address" }), _jsx("input", { id: "reg-email", name: "email", type: "email", autoComplete: "username", required: true, placeholder: labels.emailPlaceholder ?? "you@example.com", value: values.email, onChange: (e) => setValues({ ...values, email: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "Password" }), _jsx("input", { id: "reg-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: values.password, onChange: (e) => setValues({ ...values, password: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" }), renderPasswordStrength?.(values.password)] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "reg-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm password" }), _jsx("input", { id: "reg-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: values.confirmPassword, onChange: (e) => setValues({ ...values, confirmPassword: e.target.value }), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { className: "flex items-start gap-2", children: [_jsx("input", { id: "reg-terms", type: "checkbox", required: true, checked: values.acceptTerms, onChange: (e) => setValues({ ...values, acceptTerms: e.target.checked }), className: "mt-0.5 h-4 w-4 rounded border-neutral-300 dark:border-slate-600 accent-primary" }), _jsxs(Label, { htmlFor: "reg-terms", className: "text-sm leading-snug", children: [labels.acceptTermsLabel ?? "I accept the", " ", renderTermsLink?.()] })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-zinc-900 px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-zinc-800 dark:bg-zinc-100 dark:text-zinc-900 dark:hover:bg-zinc-200 transition-colors", children: isLoading
25
25
  ? (labels.submittingLabel ?? "Creating account…")
26
26
  : (labels.submitLabel ?? "Create account") })] }), renderSocialButtons?.()] }) }));
27
27
  }
@@ -16,7 +16,7 @@ export function ResetPasswordView({ oobCode, onSubmit, isLoading = false, error,
16
16
  await onSubmit(oobCode, password);
17
17
  }, [oobCode, onSubmit, password, confirm, labels.passwordMismatch]);
18
18
  const displayError = error ?? validationError;
19
- return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Reset Password" }), labels.description && (_jsx(Text, { className: "mt-2 text-sm text-neutral-600", children: labels.description }))] }), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), success ? (_jsxs(Alert, { variant: "success", compact: true, children: [success, renderLoginLink && _jsx(Div, { className: "mt-2", children: renderLoginLink() })] })) : (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "New password" }), _jsx("input", { id: "rp-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: password, onChange: (e) => setPassword(e.target.value), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm new password" }), _jsx("input", { id: "rp-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: confirm, onChange: (e) => setConfirm(e.target.value), className: "w-full rounded-lg border border-neutral-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-primary px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-primary/90 transition-colors", children: isLoading
19
+ return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full space-y-6", children: [_jsxs(Div, { className: "text-center", children: [_jsx(Heading, { level: 1, className: "text-3xl font-extrabold", children: labels.title ?? "Reset Password" }), labels.description && (_jsx(Text, { className: "mt-2 text-sm text-neutral-600 dark:text-zinc-400", children: labels.description }))] }), displayError && (_jsx(Alert, { variant: "error", compact: true, children: displayError })), success ? (_jsxs(Alert, { variant: "success", compact: true, children: [success, renderLoginLink && _jsx(Div, { className: "mt-2", children: renderLoginLink() })] })) : (_jsxs("form", { className: "space-y-4", onSubmit: handleSubmit, noValidate: true, children: [_jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-password", className: "block text-sm font-medium mb-1", children: labels.passwordLabel ?? "New password" }), _jsx("input", { id: "rp-password", name: "password", type: "password", autoComplete: "new-password", required: true, placeholder: labels.passwordPlaceholder ?? "••••••••", value: password, onChange: (e) => setPassword(e.target.value), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsxs(Div, { children: [_jsx(Label, { htmlFor: "rp-confirm", className: "block text-sm font-medium mb-1", children: labels.confirmPasswordLabel ?? "Confirm new password" }), _jsx("input", { id: "rp-confirm", name: "confirmPassword", type: "password", autoComplete: "new-password", required: true, placeholder: labels.confirmPasswordPlaceholder ?? "••••••••", value: confirm, onChange: (e) => setConfirm(e.target.value), className: "w-full rounded-lg border border-neutral-300 dark:border-slate-600 bg-white dark:bg-slate-800 text-zinc-900 dark:text-zinc-100 placeholder:text-neutral-400 dark:placeholder:text-slate-500 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary" })] }), _jsx("button", { type: "submit", disabled: isLoading, className: "w-full rounded-lg bg-zinc-900 px-4 py-2.5 text-sm font-semibold text-white disabled:opacity-60 hover:bg-zinc-800 dark:bg-zinc-100 dark:text-zinc-900 dark:hover:bg-zinc-200 transition-colors", children: isLoading
20
20
  ? (labels.submittingLabel ?? "Resetting…")
21
21
  : (labels.submitLabel ?? "Reset password") })] }))] }) }));
22
22
  }
@@ -1,6 +1,5 @@
1
- "use client";
2
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
2
  import { Button, Div, Span } from "../../../ui";
4
3
  export function SocialAuthButtons({ onGoogle, disabled, dividerLabel, googleLabel, }) {
5
- return (_jsxs(_Fragment, { children: [_jsxs(Div, { className: "relative", children: [_jsx(Div, { className: "absolute inset-0 flex items-center", children: _jsx(Div, { className: "w-full border-t border-neutral-200" }) }), _jsx(Div, { className: "relative flex justify-center text-sm", children: _jsx(Span, { className: "px-2 bg-white text-neutral-500", children: dividerLabel }) })] }), _jsx(Div, { className: "grid grid-cols-1 gap-3", children: _jsxs(Button, { type: "button", onClick: onGoogle, disabled: disabled, variant: "outline", className: "inline-flex items-center justify-center rounded-md border border-neutral-300 bg-white px-4 py-2 text-sm font-medium text-neutral-900 hover:bg-neutral-50 disabled:cursor-not-allowed disabled:opacity-50", children: [_jsxs("svg", { className: "mr-2 h-5 w-5", viewBox: "0 0 24 24", "aria-hidden": "true", children: [_jsx("path", { fill: "currentColor", d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z" }), _jsx("path", { fill: "currentColor", d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z" }), _jsx("path", { fill: "currentColor", d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z" }), _jsx("path", { fill: "currentColor", d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z" })] }), googleLabel] }) })] }));
4
+ return (_jsxs(_Fragment, { children: [_jsxs(Div, { className: "relative", children: [_jsx(Div, { className: "absolute inset-0 flex items-center", children: _jsx(Div, { className: "w-full border-t border-neutral-200 dark:border-slate-700" }) }), _jsx(Div, { className: "relative flex justify-center text-sm", children: _jsx(Span, { className: "px-2 bg-white dark:bg-slate-950 text-neutral-500 dark:text-slate-400", children: dividerLabel }) })] }), _jsx(Div, { className: "grid grid-cols-1 gap-3", children: _jsxs(Button, { type: "button", onClick: onGoogle, disabled: disabled, variant: "outline", className: "inline-flex items-center justify-center rounded-md border border-neutral-300 dark:border-slate-700 bg-white dark:bg-slate-900 px-4 py-2 text-sm font-medium text-neutral-900 dark:text-zinc-100 hover:bg-neutral-50 dark:hover:bg-slate-800 disabled:cursor-not-allowed disabled:opacity-50", children: [_jsxs("svg", { className: "mr-2 h-5 w-5", viewBox: "0 0 24 24", "aria-hidden": "true", children: [_jsx("path", { fill: "currentColor", d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z" }), _jsx("path", { fill: "currentColor", d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z" }), _jsx("path", { fill: "currentColor", d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z" }), _jsx("path", { fill: "currentColor", d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z" })] }), googleLabel] }) })] }));
6
5
  }
@@ -1,8 +1,9 @@
1
1
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Div, Heading, Text } from "../../../ui";
2
+ import { Div, Heading, Text, Button } from "../../../ui";
3
+ import { THEME_CONSTANTS } from "../../../tokens";
3
4
  export function VerifyEmailView({ status, error, labels = {}, onRetry, renderContinueButton, className = "", }) {
4
- return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full bg-white rounded-2xl border border-neutral-200 shadow-sm p-8 text-center", children: [status === "loading" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full border-4 border-primary border-t-transparent animate-spin mx-auto mb-6" }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.loadingTitle ?? "Verifying your email…" }), _jsx(Text, { className: "text-neutral-500", children: labels.loadingDescription ?? "Please wait a moment." })] })), status === "success" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full bg-green-100 flex items-center justify-center mx-auto mb-6", children: _jsx("svg", { className: "w-6 h-6 text-green-600", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", "aria-hidden": "true", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" }) }) }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.successTitle ?? "Email verified!" }), _jsx(Text, { className: "text-neutral-500 mb-6", children: labels.successDescription ??
5
+ return (_jsx(Div, { className: `flex items-center justify-center min-h-[60vh] px-4 ${className}`, children: _jsxs(Div, { className: "max-w-md w-full bg-white dark:bg-slate-900 rounded-2xl border border-neutral-200 dark:border-slate-700 shadow-sm p-8 text-center", children: [status === "loading" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full border-4 border-primary border-t-transparent animate-spin mx-auto mb-6" }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.loadingTitle ?? "Verifying your email…" }), _jsx(Text, { className: "text-neutral-500", children: labels.loadingDescription ?? "Please wait a moment." })] })), status === "success" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full bg-green-100 flex items-center justify-center mx-auto mb-6", children: _jsx("svg", { className: `w-6 h-6 ${THEME_CONSTANTS.themed.textSuccess}`, fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", "aria-hidden": "true", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" }) }) }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.successTitle ?? "Email verified!" }), _jsx(Text, { className: "text-neutral-500 mb-6", children: labels.successDescription ??
5
6
  "Your email has been verified successfully." }), renderContinueButton?.()] })), status === "error" && (_jsxs(_Fragment, { children: [_jsx(Div, { className: "w-12 h-12 rounded-full bg-red-100 flex items-center justify-center mx-auto mb-6", children: _jsx("svg", { className: "w-6 h-6 text-red-600", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", "aria-hidden": "true", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M6 18L18 6M6 6l12 12" }) }) }), _jsx(Heading, { level: 2, className: "text-xl font-semibold mb-2", children: labels.errorTitle ?? "Verification failed" }), _jsx(Text, { className: "text-neutral-500 mb-2", children: error ??
6
7
  labels.errorDescription ??
7
- "The verification link may have expired." }), onRetry && (_jsx("button", { onClick: onRetry, className: "mt-4 rounded-lg bg-primary px-4 py-2 text-sm font-semibold text-white hover:bg-primary/90 transition-colors", children: labels.retryLabel ?? "Try again" }))] }))] }) }));
8
+ "The verification link may have expired." }), onRetry && (_jsx(Button, { onClick: onRetry, className: "mt-4 rounded-lg bg-primary px-4 py-2 text-sm font-semibold text-white hover:bg-primary/90 transition-colors", children: labels.retryLabel ?? "Try again" }))] }))] }) }));
8
9
  }
@@ -12,3 +12,4 @@ export { ResetPasswordView } from "./ResetPasswordView";
12
12
  export type { ResetPasswordViewProps } from "./ResetPasswordView";
13
13
  export { VerifyEmailView } from "./VerifyEmailView";
14
14
  export type { VerifyEmailViewProps } from "./VerifyEmailView";
15
+ export { OAuthLoadingView } from "./OAuthLoadingView";
@@ -6,3 +6,4 @@ export { RegisterForm } from "./RegisterForm";
6
6
  export { ForgotPasswordView } from "./ForgotPasswordView";
7
7
  export { ResetPasswordView } from "./ResetPasswordView";
8
8
  export { VerifyEmailView } from "./VerifyEmailView";
9
+ export { OAuthLoadingView } from "./OAuthLoadingView";
@@ -1,4 +1,6 @@
1
- import "server-only";
1
+ /**
2
+ * Consent OTP - Shared constants, path helpers, and utilities
3
+ */
2
4
  import { getAdminDb } from "../../providers/db-firebase";
3
5
  /** OTP validity window (10 minutes). */
4
6
  export declare const CONSENT_OTP_EXPIRY_MS: number;
@@ -17,9 +19,9 @@ export declare const CONSENT_OTP_VERIFY_RATE_LIMIT: {
17
19
  };
18
20
  type Db = ReturnType<typeof getAdminDb>;
19
21
  /** Reference to a user's consent OTP document for a given address. */
20
- export declare function consentOtpRef(db: Db, uid: string, addressId: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData, FirebaseFirestore.DocumentData>;
22
+ export declare function consentOtpRef(db: Db, uid: string, addressId: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData>;
21
23
  /** Reference to a user's consent OTP rate-limit metadata document. */
22
- export declare function consentOtpRateLimitRef(db: Db, uid: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData, FirebaseFirestore.DocumentData>;
24
+ export declare function consentOtpRateLimitRef(db: Db, uid: string): FirebaseFirestore.DocumentReference<FirebaseFirestore.DocumentData>;
23
25
  /** HMAC-SHA256 hash of an OTP code. */
24
26
  export declare function hashOtp(code: string): string;
25
27
  /** Generate a cryptographically-secure random 6-digit OTP string. */
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  /**
3
2
  * Consent OTP - Shared constants, path helpers, and utilities
4
3
  */
@@ -1,4 +1,3 @@
1
- import "client-only";
2
1
  import type { AuthUser } from "../types";
3
2
  interface UseCurrentUserOptions {
4
3
  initialData?: AuthUser | null;
@@ -1,5 +1,4 @@
1
1
  "use client";
2
- import "client-only";
3
2
  import { useCallback, useEffect, useRef, useState } from "react";
4
3
  import { useMutation, useQuery } from "@tanstack/react-query";
5
4
  import { getClientAuthProvider } from "../../../contracts/client-auth";
@@ -1,4 +1,3 @@
1
- "use client";
2
1
  import { logger } from "../../../core/Logger";
3
2
  import { RealtimeEventType, useRealtimeEvent, } from "../../../react";
4
3
  const AUTH_EVENT_TIMEOUT_MS = 5 * 60 * 1000;
@@ -1,4 +1,3 @@
1
- "use client";
2
1
  import { useMutation } from "@tanstack/react-query";
3
2
  import { apiClient } from "../../../http";
4
3
  import { AUTH_ENDPOINTS } from "../../../constants/api-endpoints";
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  import type { DocumentReference } from "firebase-admin/firestore";
3
2
  import { BaseRepository, type FirebaseSieveFields, type FirebaseSieveResult, type SieveModel } from "../../../providers/db-firebase";
4
3
  import { type SessionCreateInput, type SessionDocument, type SessionUpdateInput } from "../schemas";
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  import { DatabaseError } from "../../../errors";
3
2
  import { serverLogger } from "../../../monitoring";
4
3
  import { BaseRepository, } from "../../../providers/db-firebase";
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  import type { DocumentSnapshot } from "../../../providers/db-firebase";
3
2
  import { BaseRepository } from "../../../providers/db-firebase";
4
3
  import { type EmailVerificationTokenDocument, type PasswordResetTokenDocument } from "../schemas";
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  import { DatabaseError } from "../../../errors";
3
2
  import { BaseRepository } from "../../../providers/db-firebase";
4
3
  import { TOKEN_PII_FIELDS, TOKEN_PII_INDEX_MAP, addPiiIndices, decryptPiiFields, encryptPiiFields, piiBlindIndex, } from "../../../security";
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  import type { DocumentSnapshot } from "../../../providers/db-firebase";
3
2
  import { BaseRepository, type FirebaseSieveFields, type FirebaseSieveResult, type SieveModel } from "../../../providers/db-firebase";
4
3
  import type { UserRole } from "../types";
@@ -1,7 +1,5 @@
1
- import "server-only";
2
- import { increment, serverTimestamp } from "../../../contracts/field-ops";
3
1
  import { DatabaseError } from "../../../errors";
4
- import { BaseRepository, prepareForFirestore, } from "../../../providers/db-firebase";
2
+ import { BaseRepository, getFirestoreCount, prepareForFirestore, } from "../../../providers/db-firebase";
5
3
  import { USER_PII_FIELDS, USER_PII_INDEX_MAP, addPiiIndices, decryptPayoutDetails, decryptPiiFields, decryptShippingConfig, encryptPayoutDetails, encryptPiiFields, encryptShippingConfig, piiBlindIndex, } from "../../../security";
6
4
  import { USER_COLLECTION, USER_FIELDS, createUserId, } from "../schemas";
7
5
  export class UserRepository extends BaseRepository {
@@ -130,11 +128,7 @@ export class UserRepository extends BaseRepository {
130
128
  }
131
129
  async countByRole(role) {
132
130
  try {
133
- const snapshot = await this.getCollection()
134
- .where(USER_FIELDS.ROLE, "==", role)
135
- .count()
136
- .get();
137
- return snapshot.data().count;
131
+ return await getFirestoreCount(this.getCollection().where(USER_FIELDS.ROLE, "==", role));
138
132
  }
139
133
  catch (error) {
140
134
  throw new DatabaseError(`Failed to count users by role: ${role}`, error);
@@ -142,11 +136,7 @@ export class UserRepository extends BaseRepository {
142
136
  }
143
137
  async countActive() {
144
138
  try {
145
- const snapshot = await this.getCollection()
146
- .where(USER_FIELDS.DISABLED, "==", false)
147
- .count()
148
- .get();
149
- return snapshot.data().count;
139
+ return await getFirestoreCount(this.getCollection().where(USER_FIELDS.DISABLED, "==", false));
150
140
  }
151
141
  catch (error) {
152
142
  throw new DatabaseError("Failed to count active users", error);
@@ -154,11 +144,7 @@ export class UserRepository extends BaseRepository {
154
144
  }
155
145
  async countDisabled() {
156
146
  try {
157
- const snapshot = await this.getCollection()
158
- .where(USER_FIELDS.DISABLED, "==", true)
159
- .count()
160
- .get();
161
- return snapshot.data().count;
147
+ return await getFirestoreCount(this.getCollection().where(USER_FIELDS.DISABLED, "==", true));
162
148
  }
163
149
  catch (error) {
164
150
  throw new DatabaseError("Failed to count disabled users", error);
@@ -166,11 +152,7 @@ export class UserRepository extends BaseRepository {
166
152
  }
167
153
  async countNewSince(since) {
168
154
  try {
169
- const snapshot = await this.getCollection()
170
- .where(USER_FIELDS.CREATED_AT, ">=", since)
171
- .count()
172
- .get();
173
- return snapshot.data().count;
155
+ return await getFirestoreCount(this.getCollection().where(USER_FIELDS.CREATED_AT, ">=", since));
174
156
  }
175
157
  catch (error) {
176
158
  throw new DatabaseError("Failed to count new users", error);
@@ -178,12 +160,19 @@ export class UserRepository extends BaseRepository {
178
160
  }
179
161
  async updateLoginMetadata(uid) {
180
162
  try {
181
- await this.getCollection()
182
- .doc(uid)
183
- .update({
184
- [USER_FIELDS.META.LAST_SIGN_IN_TIME]: serverTimestamp(),
185
- [USER_FIELDS.META.LOGIN_COUNT]: increment(1),
186
- [USER_FIELDS.UPDATED_AT]: serverTimestamp(),
163
+ const docRef = this.getCollection().doc(uid);
164
+ await this.db.runTransaction(async (tx) => {
165
+ const snapAny = (await tx.get(docRef));
166
+ // support both DocumentSnapshot and other shapes defensively
167
+ const docData = (typeof snapAny?.data === "function"
168
+ ? snapAny.data()
169
+ : snapAny?.data) ?? {};
170
+ const currentLoginCount = docData?.metadata?.loginCount || 0;
171
+ tx.update(docRef, {
172
+ [USER_FIELDS.META.LAST_SIGN_IN_TIME]: new Date(),
173
+ [USER_FIELDS.META.LOGIN_COUNT]: Number(currentLoginCount) + 1,
174
+ [USER_FIELDS.UPDATED_AT]: new Date(),
175
+ });
187
176
  });
188
177
  }
189
178
  catch (error) {
@@ -85,7 +85,7 @@ export const userQueryHelpers = {
85
85
  export function createUserId(input) {
86
86
  return generateUserId(input);
87
87
  }
88
- // ── User field name constants ────────────────────────────────────────────────
88
+ // -- User field name constants ------------------------------------------------
89
89
  export const USER_FIELDS = {
90
90
  ID: "id",
91
91
  UID: "uid",
@@ -57,16 +57,16 @@ export declare const authUserSchema: z.ZodObject<{
57
57
  isEmailVerified: z.ZodOptional<z.ZodBoolean>;
58
58
  }, "strip", z.ZodTypeAny, {
59
59
  id: string;
60
- displayName?: string | undefined;
61
- email?: string | undefined;
62
60
  role?: "admin" | "seller" | "customer" | "superadmin" | undefined;
61
+ email?: string | undefined;
62
+ displayName?: string | undefined;
63
63
  photoURL?: string | undefined;
64
64
  isEmailVerified?: boolean | undefined;
65
65
  }, {
66
66
  id: string;
67
- displayName?: string | undefined;
68
- email?: string | undefined;
69
67
  role?: "admin" | "seller" | "customer" | "superadmin" | undefined;
68
+ email?: string | undefined;
69
+ displayName?: string | undefined;
70
70
  photoURL?: string | undefined;
71
71
  isEmailVerified?: boolean | undefined;
72
72
  }>;
@@ -1,6 +1,6 @@
1
1
  export * from "./firestore";
2
2
  import { z } from "zod";
3
- // ─── Form schemas ─────────────────────────────────────────────────────────────
3
+ // --- Form schemas -------------------------------------------------------------
4
4
  /**
5
5
  * Login form schema — use with react-hook-form + zodResolver.
6
6
  *
@@ -24,7 +24,7 @@ export const resetPasswordSchema = z.object({
24
24
  token: z.string().min(1),
25
25
  password: z.string().min(6),
26
26
  });
27
- // ─── Auth user schema ─────────────────────────────────────────────────────────
27
+ // --- Auth user schema ---------------------------------------------------------
28
28
  export const userRoleSchema = z.enum([
29
29
  "customer",
30
30
  "seller",
@@ -13,7 +13,6 @@
13
13
  * export const GET = withProviders(authMeGET);
14
14
  * ```
15
15
  */
16
- import "server-only";
17
16
  export * from "./token-store";
18
17
  export * from "./consent-otp";
19
18
  export * from "./repository";
@@ -13,7 +13,6 @@
13
13
  * export const GET = withProviders(authMeGET);
14
14
  * ```
15
15
  */
16
- import "server-only";
17
16
  export * from "./token-store";
18
17
  export * from "./consent-otp";
19
18
  export * from "./repository";
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  import { EMAIL_VERIFICATION_COLLECTION, PASSWORD_RESET_COLLECTION } from "./schemas";
3
2
  export interface TokenData {
4
3
  userId: string;
@@ -1,4 +1,3 @@
1
- import "server-only";
2
1
  import crypto from "crypto";
3
2
  import { getAdminDb, prepareForFirestore } from "../../providers/db-firebase";
4
3
  import { resolveDate } from "../../utils";
@@ -1,4 +1,3 @@
1
- "use client";
2
1
  import { useQuery } from "@tanstack/react-query";
3
2
  import { apiClient } from "../../../http";
4
3
  import { BEFORE_AFTER_ENDPOINTS } from "../../../constants/api-endpoints";
@@ -23,9 +23,9 @@ export declare const beforeAfterItemSchema: z.ZodObject<{
23
23
  createdAt: z.ZodOptional<z.ZodString>;
24
24
  }, "strip", z.ZodTypeAny, {
25
25
  id: string;
26
- sortOrder: number;
27
26
  title: string;
28
27
  isActive: boolean;
28
+ sortOrder: number;
29
29
  createdAt?: string | undefined;
30
30
  description?: string | undefined;
31
31
  productId?: string | undefined;
@@ -37,9 +37,9 @@ export declare const beforeAfterItemSchema: z.ZodObject<{
37
37
  id: string;
38
38
  title: string;
39
39
  createdAt?: string | undefined;
40
+ isActive?: boolean | undefined;
40
41
  sortOrder?: number | undefined;
41
42
  description?: string | undefined;
42
- isActive?: boolean | undefined;
43
43
  productId?: string | undefined;
44
44
  concern?: string | undefined;
45
45
  beforeImageUrl?: string | undefined;
@@ -3,5 +3,4 @@
3
3
  *
4
4
  * Server-only entry point for before-after repositories.
5
5
  */
6
- import "server-only";
7
6
  export { BeforeAfterRepository } from "./repository/before-after.repository";
@@ -3,5 +3,4 @@
3
3
  *
4
4
  * Server-only entry point for before-after repositories.
5
5
  */
6
- import "server-only";
7
6
  export { BeforeAfterRepository } from "./repository/before-after.repository";