@mohasinac/appkit 2.3.2 → 2.4.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 (677) hide show
  1. package/dist/client.d.ts +48 -12
  2. package/dist/client.js +25 -6
  3. package/dist/constants/api-endpoints.d.ts +380 -22
  4. package/dist/constants/api-endpoints.js +66 -13
  5. package/dist/constants/index.d.ts +1 -1
  6. package/dist/constants/index.js +1 -1
  7. package/dist/core/hooks/useSyncManager.d.ts +1 -0
  8. package/dist/core/hooks/useSyncManager.js +83 -0
  9. package/dist/core/integration-keys.d.ts +4 -0
  10. package/dist/core/integration-keys.js +8 -0
  11. package/dist/features/about/components/FAQPageView.js +9 -11
  12. package/dist/features/about/components/PolicyPageView.js +32 -11
  13. package/dist/features/about/components/PublicProfileView.js +77 -11
  14. package/dist/features/account/components/AddressesIndexListing.js +63 -38
  15. package/dist/features/account/components/UserOffersPanel.d.ts +8 -0
  16. package/dist/features/account/components/UserOffersPanel.js +81 -0
  17. package/dist/features/account/components/UserSettingsView.d.ts +2 -1
  18. package/dist/features/account/components/UserSettingsView.js +2 -1
  19. package/dist/features/account/components/UserSidebar.d.ts +6 -1
  20. package/dist/features/account/components/UserSidebar.js +48 -42
  21. package/dist/features/account/components/index.d.ts +2 -0
  22. package/dist/features/account/components/index.js +1 -0
  23. package/dist/features/admin/actions/admin-actions.d.ts +1 -1
  24. package/dist/features/admin/actions/admin-actions.js +13 -3
  25. package/dist/features/admin/components/AdminAdEditorView.js +6 -7
  26. package/dist/features/admin/components/AdminAllEventEntriesView.d.ts +4 -0
  27. package/dist/features/admin/components/AdminAllEventEntriesView.js +102 -0
  28. package/dist/features/admin/components/AdminBidsView.js +94 -8
  29. package/dist/features/admin/components/AdminBlogEditorView.d.ts +7 -0
  30. package/dist/features/admin/components/AdminBlogEditorView.js +162 -0
  31. package/dist/features/admin/components/AdminBlogView.d.ts +4 -1
  32. package/dist/features/admin/components/AdminBlogView.js +61 -31
  33. package/dist/features/admin/components/AdminBrandEditorView.d.ts +7 -0
  34. package/dist/features/admin/components/AdminBrandEditorView.js +104 -0
  35. package/dist/features/admin/components/AdminBrandsView.d.ts +4 -0
  36. package/dist/features/admin/components/AdminBrandsView.js +76 -0
  37. package/dist/features/admin/components/AdminCarouselEditorView.d.ts +8 -0
  38. package/dist/features/admin/components/AdminCarouselEditorView.js +204 -0
  39. package/dist/features/admin/components/AdminCarouselView.js +153 -34
  40. package/dist/features/admin/components/AdminCartsView.d.ts +4 -0
  41. package/dist/features/admin/components/AdminCartsView.js +82 -0
  42. package/dist/features/admin/components/AdminCategoriesView.d.ts +4 -1
  43. package/dist/features/admin/components/AdminCategoriesView.js +66 -48
  44. package/dist/features/admin/components/AdminCategoryEditorView.d.ts +7 -0
  45. package/dist/features/admin/components/AdminCategoryEditorView.js +115 -0
  46. package/dist/features/admin/components/AdminContactEditorView.d.ts +11 -0
  47. package/dist/features/admin/components/AdminContactEditorView.js +32 -0
  48. package/dist/features/admin/components/AdminContactView.js +111 -20
  49. package/dist/features/admin/components/AdminCouponEditorView.d.ts +7 -0
  50. package/dist/features/admin/components/AdminCouponEditorView.js +179 -0
  51. package/dist/features/admin/components/AdminCouponsView.d.ts +4 -1
  52. package/dist/features/admin/components/AdminCouponsView.js +57 -9
  53. package/dist/features/admin/components/AdminDashboardView.js +3 -0
  54. package/dist/features/admin/components/AdminFaqEditorView.d.ts +7 -0
  55. package/dist/features/admin/components/AdminFaqEditorView.js +128 -0
  56. package/dist/features/admin/components/AdminFaqsView.d.ts +4 -1
  57. package/dist/features/admin/components/AdminFaqsView.js +55 -23
  58. package/dist/features/admin/components/AdminFeatureFlagsView.js +33 -24
  59. package/dist/features/admin/components/AdminListingScaffold.d.ts +7 -1
  60. package/dist/features/admin/components/AdminListingScaffold.js +2 -2
  61. package/dist/features/admin/components/AdminMediaView.js +18 -8
  62. package/dist/features/admin/components/AdminNavEditorView.d.ts +20 -0
  63. package/dist/features/admin/components/AdminNavEditorView.js +84 -0
  64. package/dist/features/admin/components/AdminNavigationView.d.ts +1 -7
  65. package/dist/features/admin/components/AdminNavigationView.js +84 -72
  66. package/dist/features/admin/components/AdminNewsletterView.js +102 -20
  67. package/dist/features/admin/components/AdminNotificationsView.d.ts +4 -0
  68. package/dist/features/admin/components/AdminNotificationsView.js +119 -0
  69. package/dist/features/admin/components/AdminOrderEditorView.d.ts +8 -0
  70. package/dist/features/admin/components/AdminOrderEditorView.js +74 -0
  71. package/dist/features/admin/components/AdminOrdersView.js +64 -8
  72. package/dist/features/admin/components/AdminPayoutsView.js +122 -13
  73. package/dist/features/admin/components/AdminProductEditorView.d.ts +7 -0
  74. package/dist/features/admin/components/AdminProductEditorView.js +143 -0
  75. package/dist/features/admin/components/AdminProductsView.d.ts +4 -1
  76. package/dist/features/admin/components/AdminProductsView.js +119 -30
  77. package/dist/features/admin/components/AdminReturnRequestsView.d.ts +5 -0
  78. package/dist/features/admin/components/AdminReturnRequestsView.js +101 -0
  79. package/dist/features/admin/components/AdminReviewsView.js +138 -28
  80. package/dist/features/admin/components/AdminSectionsView.js +361 -472
  81. package/dist/features/admin/components/AdminSessionsView.d.ts +4 -0
  82. package/dist/features/admin/components/AdminSessionsView.js +119 -0
  83. package/dist/features/admin/components/AdminSidebar.d.ts +18 -3
  84. package/dist/features/admin/components/AdminSidebar.js +51 -4
  85. package/dist/features/admin/components/AdminSiteSettingsView.d.ts +7 -0
  86. package/dist/features/admin/components/AdminSiteSettingsView.js +319 -0
  87. package/dist/features/admin/components/AdminStoreAddressesView.d.ts +5 -0
  88. package/dist/features/admin/components/AdminStoreAddressesView.js +52 -0
  89. package/dist/features/admin/components/AdminStoreEditorView.d.ts +9 -0
  90. package/dist/features/admin/components/AdminStoreEditorView.js +55 -0
  91. package/dist/features/admin/components/AdminStoresView.js +62 -20
  92. package/dist/features/admin/components/AdminUserEditorView.d.ts +10 -0
  93. package/dist/features/admin/components/AdminUserEditorView.js +72 -0
  94. package/dist/features/admin/components/AdminUsersView.js +70 -36
  95. package/dist/features/admin/components/AdminWishlistsView.d.ts +4 -0
  96. package/dist/features/admin/components/AdminWishlistsView.js +53 -0
  97. package/dist/features/admin/components/BrandQuickCreateForm.d.ts +5 -0
  98. package/dist/features/admin/components/BrandQuickCreateForm.js +36 -0
  99. package/dist/features/admin/components/CategoryQuickCreateForm.d.ts +5 -0
  100. package/dist/features/admin/components/CategoryQuickCreateForm.js +35 -0
  101. package/dist/features/admin/components/DataTable.d.ts +4 -2
  102. package/dist/features/admin/components/DataTable.js +26 -6
  103. package/dist/features/admin/components/index.d.ts +47 -1
  104. package/dist/features/admin/components/index.js +23 -0
  105. package/dist/features/admin/components/sections/adminSectionsBuildParse.d.ts +48 -0
  106. package/dist/features/admin/components/sections/adminSectionsBuildParse.js +653 -0
  107. package/dist/features/admin/components/sections/adminSectionsTypes.d.ts +298 -0
  108. package/dist/features/admin/components/sections/adminSectionsTypes.js +278 -0
  109. package/dist/features/admin/schemas/firestore.d.ts +26 -0
  110. package/dist/features/admin/schemas/firestore.js +1 -0
  111. package/dist/features/admin/types/product.types.d.ts +2 -3
  112. package/dist/features/auctions/actions/bid-actions.js +6 -2
  113. package/dist/features/auctions/components/AuctionDetailPageView.d.ts +3 -1
  114. package/dist/features/auctions/components/AuctionDetailPageView.js +38 -12
  115. package/dist/features/auctions/components/AuctionFilters.d.ts +3 -1
  116. package/dist/features/auctions/components/AuctionFilters.js +6 -2
  117. package/dist/features/auctions/components/CollapsibleBidHistory.d.ts +7 -0
  118. package/dist/features/auctions/components/CollapsibleBidHistory.js +8 -0
  119. package/dist/features/auctions/components/MarketplaceAuctionCard.d.ts +4 -0
  120. package/dist/features/auctions/components/MarketplaceAuctionCard.js +43 -9
  121. package/dist/features/auctions/components/MarketplaceAuctionGrid.js +1 -0
  122. package/dist/features/auctions/components/PlaceBidFormClient.d.ts +18 -0
  123. package/dist/features/auctions/components/PlaceBidFormClient.js +33 -0
  124. package/dist/features/auctions/hooks/useAuctions.d.ts +1 -0
  125. package/dist/features/auctions/hooks/useAuctions.js +1 -0
  126. package/dist/features/auctions/schemas/index.d.ts +22 -12
  127. package/dist/features/auth/actions/profile-actions.d.ts +5 -3
  128. package/dist/features/auth/actions/profile-actions.js +30 -11
  129. package/dist/features/auth/auth-helpers.js +1 -0
  130. package/dist/features/auth/components/LoginForm.js +2 -1
  131. package/dist/features/auth/hooks/useAuth.js +16 -4
  132. package/dist/features/auth/permissions/constants.d.ts +63 -0
  133. package/dist/features/auth/permissions/constants.js +323 -0
  134. package/dist/features/auth/schemas/firestore.d.ts +20 -0
  135. package/dist/features/auth/schemas/index.d.ts +4 -4
  136. package/dist/features/auth/schemas/index.js +3 -2
  137. package/dist/features/auth/types/index.d.ts +1 -1
  138. package/dist/features/before-after/schemas/index.d.ts +2 -2
  139. package/dist/features/blog/actions/blog-actions.d.ts +15 -15
  140. package/dist/features/blog/components/BlogFilters.js +1 -1
  141. package/dist/features/blog/components/BlogIndexListing.js +57 -5
  142. package/dist/features/blog/components/BlogIndexPageView.js +14 -2
  143. package/dist/features/blog/components/BlogPostForm.js +6 -2
  144. package/dist/features/blog/components/BlogPostView.js +2 -1
  145. package/dist/features/blog/hooks/useBlog.d.ts +2 -0
  146. package/dist/features/blog/hooks/useBlog.js +2 -0
  147. package/dist/features/blog/schemas/index.d.ts +46 -12
  148. package/dist/features/brands/actions/brand-actions.d.ts +2 -0
  149. package/dist/features/brands/actions/brand-actions.js +5 -0
  150. package/dist/features/brands/index.d.ts +3 -0
  151. package/dist/features/brands/index.js +3 -0
  152. package/dist/features/brands/repository/brands.repository.d.ts +13 -0
  153. package/dist/features/brands/repository/brands.repository.js +60 -0
  154. package/dist/features/brands/schemas/index.d.ts +33 -0
  155. package/dist/features/brands/schemas/index.js +15 -0
  156. package/dist/features/brands/server.d.ts +7 -0
  157. package/dist/features/brands/server.js +7 -0
  158. package/dist/features/cart/actions/cart-actions.js +2 -2
  159. package/dist/features/cart/components/CartDrawer.d.ts +5 -1
  160. package/dist/features/cart/components/CartDrawer.js +3 -3
  161. package/dist/features/cart/hooks/useCartCount.d.ts +3 -2
  162. package/dist/features/cart/hooks/useCartCount.js +4 -2
  163. package/dist/features/cart/hooks/useGuestCartMerge.js +1 -1
  164. package/dist/features/cart/index.d.ts +1 -0
  165. package/dist/features/cart/index.js +1 -0
  166. package/dist/features/cart/repository/cart.repository.d.ts +5 -1
  167. package/dist/features/cart/repository/cart.repository.js +36 -5
  168. package/dist/features/cart/schemas/firestore.d.ts +25 -6
  169. package/dist/features/cart/schemas/firestore.js +2 -2
  170. package/dist/features/cart/schemas/index.d.ts +9 -9
  171. package/dist/features/cart/schemas/index.js +1 -1
  172. package/dist/features/cart/types/index.d.ts +1 -1
  173. package/dist/features/cart/utils/pending-ops.d.ts +33 -0
  174. package/dist/features/cart/utils/pending-ops.js +102 -0
  175. package/dist/features/categories/components/BrandDetailPageView.d.ts +4 -0
  176. package/dist/features/categories/components/BrandDetailPageView.js +54 -0
  177. package/dist/features/categories/components/BrandDetailTabs.d.ts +10 -0
  178. package/dist/features/categories/components/BrandDetailTabs.js +22 -0
  179. package/dist/features/categories/components/CategoriesIndexListing.d.ts +3 -1
  180. package/dist/features/categories/components/CategoriesIndexListing.js +83 -7
  181. package/dist/features/categories/components/CategoryDetailPageView.js +42 -21
  182. package/dist/features/categories/components/CategoryDetailTabs.d.ts +7 -1
  183. package/dist/features/categories/components/CategoryDetailTabs.js +12 -7
  184. package/dist/features/categories/components/CategoryFilters.js +1 -1
  185. package/dist/features/categories/components/CategoryForm.js +10 -4
  186. package/dist/features/categories/components/CategoryProductsListing.d.ts +4 -1
  187. package/dist/features/categories/components/CategoryProductsListing.js +34 -5
  188. package/dist/features/categories/components/ConcernCard.js +1 -1
  189. package/dist/features/categories/hooks/useCategories.js +2 -0
  190. package/dist/features/categories/repository/categories.repository.js +2 -3
  191. package/dist/features/categories/schemas/firestore.d.ts +23 -2
  192. package/dist/features/categories/schemas/firestore.js +8 -0
  193. package/dist/features/categories/schemas/index.d.ts +8 -8
  194. package/dist/features/categories/types/index.d.ts +1 -0
  195. package/dist/features/collections/schemas/index.d.ts +2 -2
  196. package/dist/features/events/components/AdminEventEditorView.js +2 -2
  197. package/dist/features/events/components/AdminEventsView.d.ts +4 -1
  198. package/dist/features/events/components/AdminEventsView.js +64 -38
  199. package/dist/features/events/components/EventCard.js +1 -1
  200. package/dist/features/events/components/EventFilters.js +1 -1
  201. package/dist/features/events/components/EventPollWidget.d.ts +12 -0
  202. package/dist/features/events/components/EventPollWidget.js +62 -0
  203. package/dist/features/events/components/EventsIndexListing.js +57 -5
  204. package/dist/features/events/components/EventsListPageView.js +1 -1
  205. package/dist/features/events/components/index.d.ts +2 -0
  206. package/dist/features/events/components/index.js +1 -0
  207. package/dist/features/events/hooks/useEvents.d.ts +1 -0
  208. package/dist/features/events/hooks/useEvents.js +1 -0
  209. package/dist/features/events/repository/events.repository.js +3 -0
  210. package/dist/features/events/schemas/firestore.d.ts +1 -0
  211. package/dist/features/events/schemas/index.d.ts +44 -0
  212. package/dist/features/events/types/index.d.ts +2 -0
  213. package/dist/features/faq/actions/faq-actions.d.ts +16 -16
  214. package/dist/features/faq/hooks/useFaqList.js +1 -1
  215. package/dist/features/faq/schemas/firestore.d.ts +2 -2
  216. package/dist/features/faq/schemas/firestore.js +2 -1
  217. package/dist/features/faq/schemas/index.d.ts +4 -4
  218. package/dist/features/filters/FilterFacetSection.d.ts +1 -0
  219. package/dist/features/filters/FilterFacetSection.js +13 -1
  220. package/dist/features/filters/SwitchFilter.js +1 -1
  221. package/dist/features/grouped/schemas/firestore.d.ts +32 -0
  222. package/dist/features/grouped/schemas/firestore.js +19 -0
  223. package/dist/features/homepage/components/AdSlot.d.ts +1 -3
  224. package/dist/features/homepage/components/AdSlot.js +15 -14
  225. package/dist/features/homepage/components/BlogArticlesSection.d.ts +3 -1
  226. package/dist/features/homepage/components/BlogArticlesSection.js +2 -2
  227. package/dist/features/homepage/components/BrandsSection.d.ts +3 -1
  228. package/dist/features/homepage/components/BrandsSection.js +4 -3
  229. package/dist/features/homepage/components/CustomCardsSection.d.ts +3 -0
  230. package/dist/features/homepage/components/CustomCardsSection.js +76 -0
  231. package/dist/features/homepage/components/EventsSection.d.ts +3 -1
  232. package/dist/features/homepage/components/EventsSection.js +2 -2
  233. package/dist/features/homepage/components/FeaturedAuctionsSection.d.ts +4 -1
  234. package/dist/features/homepage/components/FeaturedAuctionsSection.js +2 -2
  235. package/dist/features/homepage/components/FeaturedPreOrdersSection.d.ts +4 -1
  236. package/dist/features/homepage/components/FeaturedPreOrdersSection.js +2 -2
  237. package/dist/features/homepage/components/FeaturedProductsSection.d.ts +4 -1
  238. package/dist/features/homepage/components/FeaturedProductsSection.js +8 -3
  239. package/dist/features/homepage/components/FeaturedStoresSection.d.ts +3 -1
  240. package/dist/features/homepage/components/FeaturedStoresSection.js +2 -2
  241. package/dist/features/homepage/components/GoogleReviewsSection.d.ts +3 -0
  242. package/dist/features/homepage/components/GoogleReviewsSection.js +65 -0
  243. package/dist/features/homepage/components/HeroCarousel.js +128 -84
  244. package/dist/features/homepage/components/MarketplaceHomepageView.d.ts +2 -20
  245. package/dist/features/homepage/components/MarketplaceHomepageView.js +73 -230
  246. package/dist/features/homepage/components/SectionCarousel.d.ts +1 -1
  247. package/dist/features/homepage/components/SectionCarousel.js +2 -0
  248. package/dist/features/homepage/components/ShopByCategorySection.d.ts +3 -1
  249. package/dist/features/homepage/components/ShopByCategorySection.js +8 -4
  250. package/dist/features/homepage/components/SocialFeedSection.d.ts +3 -0
  251. package/dist/features/homepage/components/SocialFeedSection.js +86 -0
  252. package/dist/features/homepage/components/SocialPostCard.d.ts +7 -0
  253. package/dist/features/homepage/components/SocialPostCard.js +39 -0
  254. package/dist/features/homepage/components/StatsCounterSection.js +1 -1
  255. package/dist/features/homepage/components/WelcomeSection.js +1 -1
  256. package/dist/features/homepage/components/WhatsAppCommunitySection.js +1 -1
  257. package/dist/features/homepage/hooks/useActiveAd.d.ts +23 -0
  258. package/dist/features/homepage/hooks/useActiveAd.js +20 -0
  259. package/dist/features/homepage/hooks/useBlogArticles.d.ts +1 -0
  260. package/dist/features/homepage/hooks/useBlogArticles.js +10 -0
  261. package/dist/features/homepage/hooks/useFeaturedAuctions.d.ts +4 -1
  262. package/dist/features/homepage/hooks/useFeaturedAuctions.js +8 -4
  263. package/dist/features/homepage/hooks/useFeaturedPreOrders.d.ts +4 -1
  264. package/dist/features/homepage/hooks/useFeaturedPreOrders.js +8 -4
  265. package/dist/features/homepage/hooks/useFeaturedProducts.d.ts +1 -0
  266. package/dist/features/homepage/hooks/useFeaturedProducts.js +6 -3
  267. package/dist/features/homepage/hooks/useFeaturedStores.d.ts +3 -1
  268. package/dist/features/homepage/hooks/useFeaturedStores.js +2 -1
  269. package/dist/features/homepage/hooks/useHomepageEvents.d.ts +3 -1
  270. package/dist/features/homepage/hooks/useHomepageEvents.js +2 -1
  271. package/dist/features/homepage/hooks/useTopBrands.d.ts +3 -1
  272. package/dist/features/homepage/hooks/useTopBrands.js +2 -1
  273. package/dist/features/homepage/index.d.ts +2 -0
  274. package/dist/features/homepage/index.js +1 -0
  275. package/dist/features/homepage/lib/google-reviews-fetcher.d.ts +14 -0
  276. package/dist/features/homepage/lib/google-reviews-fetcher.js +27 -0
  277. package/dist/features/homepage/lib/live-stats.d.ts +14 -0
  278. package/dist/features/homepage/lib/live-stats.js +62 -0
  279. package/dist/features/homepage/lib/section-defaults.d.ts +11 -0
  280. package/dist/features/homepage/lib/section-defaults.js +45 -0
  281. package/dist/features/homepage/lib/section-helpers.d.ts +5 -0
  282. package/dist/features/homepage/lib/section-helpers.js +25 -0
  283. package/dist/features/homepage/lib/section-renderer.d.ts +33 -0
  284. package/dist/features/homepage/lib/section-renderer.js +164 -0
  285. package/dist/features/homepage/lib/social-feed-fetcher.d.ts +5 -0
  286. package/dist/features/homepage/lib/social-feed-fetcher.js +193 -0
  287. package/dist/features/homepage/schemas/firestore.d.ts +180 -29
  288. package/dist/features/homepage/schemas/firestore.js +5 -0
  289. package/dist/features/homepage/types/index.d.ts +48 -19
  290. package/dist/features/layout/AppLayoutShell.d.ts +6 -1
  291. package/dist/features/layout/AppLayoutShell.js +25 -9
  292. package/dist/features/layout/BottomActions.js +1 -1
  293. package/dist/features/layout/BottomNavbar.d.ts +15 -1
  294. package/dist/features/layout/BottomNavbar.js +8 -2
  295. package/dist/features/layout/FooterLayout.d.ts +7 -1
  296. package/dist/features/layout/FooterLayout.js +3 -3
  297. package/dist/features/layout/ListingLayout.js +2 -2
  298. package/dist/features/layout/MainNavbar.d.ts +6 -14
  299. package/dist/features/layout/MainNavbar.js +4 -16
  300. package/dist/features/layout/NavItem.js +1 -1
  301. package/dist/features/layout/NavbarLayout.d.ts +3 -1
  302. package/dist/features/layout/NavbarLayout.js +5 -5
  303. package/dist/features/layout/TitleBar.d.ts +4 -2
  304. package/dist/features/layout/TitleBar.js +5 -3
  305. package/dist/features/layout/TitleBarLayout.d.ts +3 -1
  306. package/dist/features/layout/TitleBarLayout.js +2 -2
  307. package/dist/features/layout/index.d.ts +1 -1
  308. package/dist/features/media/MediaPickerModal.d.ts +30 -0
  309. package/dist/features/media/MediaPickerModal.js +72 -0
  310. package/dist/features/media/index.d.ts +3 -1
  311. package/dist/features/media/index.js +1 -0
  312. package/dist/features/media/types/index.d.ts +12 -0
  313. package/dist/features/media/types/index.js +4 -2
  314. package/dist/features/media/upload/MediaUploadField.d.ts +5 -1
  315. package/dist/features/media/upload/MediaUploadField.js +56 -3
  316. package/dist/features/messages/schemas/firestore.d.ts +36 -0
  317. package/dist/features/messages/schemas/firestore.js +16 -0
  318. package/dist/features/orders/repository/orders.repository.d.ts +2 -2
  319. package/dist/features/orders/repository/orders.repository.js +2 -2
  320. package/dist/features/orders/schemas/firestore.d.ts +17 -4
  321. package/dist/features/orders/schemas/firestore.js +2 -2
  322. package/dist/features/orders/schemas/index.d.ts +18 -18
  323. package/dist/features/orders/schemas/index.js +3 -3
  324. package/dist/features/orders/types/index.d.ts +1 -1
  325. package/dist/features/orders/utils/order-splitter.d.ts +1 -1
  326. package/dist/features/orders/utils/order-splitter.js +2 -2
  327. package/dist/features/payments/repository/payout.repository.d.ts +4 -4
  328. package/dist/features/payments/repository/payout.repository.js +7 -7
  329. package/dist/features/payments/schemas/firestore.d.ts +6 -6
  330. package/dist/features/payments/schemas/firestore.js +6 -6
  331. package/dist/features/pre-orders/components/MarketplacePreorderCard.js +11 -10
  332. package/dist/features/pre-orders/components/PreOrderActionsClient.d.ts +11 -0
  333. package/dist/features/pre-orders/components/PreOrderActionsClient.js +28 -0
  334. package/dist/features/pre-orders/components/PreOrderDetailPageView.d.ts +2 -1
  335. package/dist/features/pre-orders/components/PreOrderDetailPageView.js +27 -9
  336. package/dist/features/pre-orders/components/PreOrderFilters.d.ts +3 -1
  337. package/dist/features/pre-orders/components/PreOrderFilters.js +9 -6
  338. package/dist/features/pre-orders/components/PreOrdersIndexListing.d.ts +3 -1
  339. package/dist/features/pre-orders/components/PreOrdersIndexListing.js +132 -36
  340. package/dist/features/pre-orders/components/PreOrdersListView.js +3 -3
  341. package/dist/features/pre-orders/components/PreorderCard.js +1 -1
  342. package/dist/features/pre-orders/schemas/index.d.ts +10 -0
  343. package/dist/features/products/actions/product-actions.d.ts +2 -2
  344. package/dist/features/products/actions/product-actions.js +5 -5
  345. package/dist/features/products/api/[id]/route.js +5 -2
  346. package/dist/features/products/api/route.js +10 -14
  347. package/dist/features/products/columns/productTableColumns.js +2 -2
  348. package/dist/features/products/components/AuctionDetailView.d.ts +2 -1
  349. package/dist/features/products/components/AuctionDetailView.js +2 -2
  350. package/dist/features/products/components/AuctionsIndexListing.d.ts +3 -1
  351. package/dist/features/products/components/AuctionsIndexListing.js +93 -31
  352. package/dist/features/products/components/BidHistory.d.ts +2 -1
  353. package/dist/features/products/components/BidHistory.js +18 -2
  354. package/dist/features/products/components/MakeOfferButton.d.ts +10 -0
  355. package/dist/features/products/components/MakeOfferButton.js +68 -0
  356. package/dist/features/products/components/ProductDetailPageView.d.ts +11 -1
  357. package/dist/features/products/components/ProductDetailPageView.js +27 -8
  358. package/dist/features/products/components/ProductFilters.d.ts +7 -1
  359. package/dist/features/products/components/ProductFilters.js +4 -2
  360. package/dist/features/products/components/ProductForm.d.ts +19 -1
  361. package/dist/features/products/components/ProductForm.js +24 -6
  362. package/dist/features/products/components/ProductGrid.d.ts +10 -2
  363. package/dist/features/products/components/ProductGrid.js +76 -29
  364. package/dist/features/products/components/ProductsIndexListing.js +131 -45
  365. package/dist/features/products/components/RelatedProductsCarousel.js +1 -1
  366. package/dist/features/products/components/ShareButton.d.ts +7 -0
  367. package/dist/features/products/components/ShareButton.js +22 -0
  368. package/dist/features/products/components/index.d.ts +2 -0
  369. package/dist/features/products/components/index.js +1 -0
  370. package/dist/features/products/hooks/useProducts.d.ts +7 -0
  371. package/dist/features/products/hooks/useProducts.js +6 -4
  372. package/dist/features/products/repository/products.repository.d.ts +4 -8
  373. package/dist/features/products/repository/products.repository.js +17 -50
  374. package/dist/features/products/schemas/firestore.d.ts +11 -9
  375. package/dist/features/products/schemas/firestore.js +11 -3
  376. package/dist/features/products/schemas/index.d.ts +51 -50
  377. package/dist/features/products/schemas/index.js +2 -5
  378. package/dist/features/products/types/index.d.ts +13 -5
  379. package/dist/features/promotions/actions/coupon-actions.d.ts +2 -2
  380. package/dist/features/promotions/actions/coupon-actions.js +1 -1
  381. package/dist/features/promotions/actions/seller-coupon-actions.js +11 -6
  382. package/dist/features/promotions/api/route.js +3 -3
  383. package/dist/features/promotions/components/CouponCard.js +16 -7
  384. package/dist/features/promotions/components/CouponsIndexListing.js +3 -9
  385. package/dist/features/promotions/hooks/useCouponValidate.d.ts +1 -1
  386. package/dist/features/promotions/hooks/usePromotions.js +2 -2
  387. package/dist/features/promotions/repository/coupons.repository.d.ts +21 -15
  388. package/dist/features/promotions/repository/coupons.repository.js +97 -125
  389. package/dist/features/promotions/schemas/firestore.d.ts +31 -2
  390. package/dist/features/promotions/schemas/firestore.js +29 -0
  391. package/dist/features/promotions/schemas/index.d.ts +9 -12
  392. package/dist/features/promotions/schemas/index.js +1 -2
  393. package/dist/features/promotions/types/index.d.ts +1 -2
  394. package/dist/features/reviews/actions/review-actions.js +3 -2
  395. package/dist/features/reviews/components/ReviewDetailPageView.js +5 -9
  396. package/dist/features/reviews/components/ReviewFilters.js +1 -1
  397. package/dist/features/reviews/components/ReviewsIndexListing.js +58 -7
  398. package/dist/features/reviews/components/ReviewsList.js +2 -2
  399. package/dist/features/reviews/hooks/useReviews.d.ts +1 -0
  400. package/dist/features/reviews/hooks/useReviews.js +2 -1
  401. package/dist/features/reviews/repository/reviews.repository.d.ts +9 -4
  402. package/dist/features/reviews/repository/reviews.repository.js +18 -7
  403. package/dist/features/reviews/schemas/firestore.d.ts +5 -2
  404. package/dist/features/reviews/schemas/firestore.js +1 -0
  405. package/dist/features/reviews/schemas/index.d.ts +19 -16
  406. package/dist/features/reviews/schemas/index.js +3 -2
  407. package/dist/features/reviews/types/index.d.ts +3 -2
  408. package/dist/features/scams/actions/scam-actions.d.ts +29 -0
  409. package/dist/features/scams/actions/scam-actions.js +62 -0
  410. package/dist/features/scams/components/ScamProfileView.d.ts +10 -0
  411. package/dist/features/scams/components/ScamProfileView.js +51 -0
  412. package/dist/features/scams/components/ScamRegistryView.d.ts +6 -0
  413. package/dist/features/scams/components/ScamRegistryView.js +41 -0
  414. package/dist/features/scams/components/index.d.ts +4 -0
  415. package/dist/features/scams/components/index.js +2 -0
  416. package/dist/features/scams/constants/scam-types.d.ts +38 -0
  417. package/dist/features/scams/constants/scam-types.js +443 -0
  418. package/dist/features/scams/repository/scammer.repository.d.ts +67 -0
  419. package/dist/features/scams/repository/scammer.repository.js +160 -0
  420. package/dist/features/scams/schemas/firestore.d.ts +362 -0
  421. package/dist/features/scams/schemas/firestore.js +233 -0
  422. package/dist/features/search/components/Search.d.ts +12 -2
  423. package/dist/features/search/components/Search.js +26 -7
  424. package/dist/features/search/components/index.d.ts +1 -1
  425. package/dist/features/search/hooks/useNavSuggestions.d.ts +1 -1
  426. package/dist/features/search/hooks/useNavSuggestions.js +2 -2
  427. package/dist/features/search/schemas/index.d.ts +7 -7
  428. package/dist/features/seller/actions/offer-actions.js +52 -36
  429. package/dist/features/seller/actions/seller-actions.js +19 -13
  430. package/dist/features/seller/api/products/route.js +9 -4
  431. package/dist/features/seller/components/SellerAddressesView.d.ts +3 -12
  432. package/dist/features/seller/components/SellerAddressesView.js +144 -4
  433. package/dist/features/seller/components/SellerAuctionsView.js +58 -5
  434. package/dist/features/seller/components/SellerBidsView.d.ts +4 -0
  435. package/dist/features/seller/components/SellerBidsView.js +131 -0
  436. package/dist/features/seller/components/SellerCouponEditorView.d.ts +19 -0
  437. package/dist/features/seller/components/SellerCouponEditorView.js +67 -0
  438. package/dist/features/seller/components/SellerCouponsView.d.ts +5 -3
  439. package/dist/features/seller/components/SellerCouponsView.js +135 -13
  440. package/dist/features/seller/components/SellerCreateProductView.d.ts +4 -10
  441. package/dist/features/seller/components/SellerCreateProductView.js +4 -3
  442. package/dist/features/seller/components/SellerEditProductView.d.ts +4 -10
  443. package/dist/features/seller/components/SellerEditProductView.js +4 -3
  444. package/dist/features/seller/components/SellerOffersPanel.d.ts +20 -0
  445. package/dist/features/seller/components/SellerOffersPanel.js +138 -0
  446. package/dist/features/seller/components/SellerOffersView.js +56 -5
  447. package/dist/features/seller/components/SellerOrdersView.d.ts +2 -1
  448. package/dist/features/seller/components/SellerOrdersView.js +185 -16
  449. package/dist/features/seller/components/SellerPayoutRequestView.d.ts +7 -0
  450. package/dist/features/seller/components/SellerPayoutRequestView.js +63 -0
  451. package/dist/features/seller/components/SellerPayoutSettingsView.d.ts +3 -10
  452. package/dist/features/seller/components/SellerPayoutSettingsView.js +89 -3
  453. package/dist/features/seller/components/SellerPayoutsView.js +56 -5
  454. package/dist/features/seller/components/SellerProductShell.d.ts +68 -0
  455. package/dist/features/seller/components/SellerProductShell.js +179 -0
  456. package/dist/features/seller/components/SellerProductsView.d.ts +2 -3
  457. package/dist/features/seller/components/SellerProductsView.js +194 -18
  458. package/dist/features/seller/components/SellerReviewsView.d.ts +5 -0
  459. package/dist/features/seller/components/SellerReviewsView.js +100 -0
  460. package/dist/features/seller/components/SellerShippingView.d.ts +3 -11
  461. package/dist/features/seller/components/SellerShippingView.js +87 -3
  462. package/dist/features/seller/components/SellerSidebar.d.ts +11 -3
  463. package/dist/features/seller/components/SellerSidebar.js +52 -8
  464. package/dist/features/seller/components/SellerStorefrontView.d.ts +26 -11
  465. package/dist/features/seller/components/SellerStorefrontView.js +45 -7
  466. package/dist/features/seller/components/index.d.ts +16 -2
  467. package/dist/features/seller/components/index.js +7 -0
  468. package/dist/features/seller/hooks/useSellerListingData.d.ts +3 -1
  469. package/dist/features/seller/hooks/useSellerListingData.js +6 -4
  470. package/dist/features/seller/repository/offer.repository.d.ts +3 -3
  471. package/dist/features/seller/repository/offer.repository.js +6 -6
  472. package/dist/features/seller/schemas/firestore.d.ts +7 -7
  473. package/dist/features/seller/schemas/firestore.js +4 -4
  474. package/dist/features/seller/schemas/index.d.ts +16 -16
  475. package/dist/features/shell/FormShell.d.ts +29 -0
  476. package/dist/features/shell/FormShell.js +103 -0
  477. package/dist/features/shell/QuickFormDrawer.d.ts +29 -0
  478. package/dist/features/shell/QuickFormDrawer.js +117 -0
  479. package/dist/features/shell/StepForm.d.ts +44 -0
  480. package/dist/features/shell/StepForm.js +81 -0
  481. package/dist/features/shell/index.d.ts +6 -0
  482. package/dist/features/shell/index.js +3 -0
  483. package/dist/features/stores/actions/store-query-actions.js +3 -3
  484. package/dist/features/stores/api/[storeSlug]/auctions/route.js +1 -1
  485. package/dist/features/stores/api/[storeSlug]/products/route.js +1 -1
  486. package/dist/features/stores/api/[storeSlug]/reviews/route.js +1 -1
  487. package/dist/features/stores/components/InteractiveStoreCard.d.ts +2 -2
  488. package/dist/features/stores/components/InteractiveStoreCard.js +21 -7
  489. package/dist/features/stores/components/StoreAboutView.js +1 -1
  490. package/dist/features/stores/components/StoreAuctionsListing.d.ts +5 -2
  491. package/dist/features/stores/components/StoreAuctionsListing.js +81 -8
  492. package/dist/features/stores/components/StoreAuctionsPageView.js +8 -7
  493. package/dist/features/stores/components/StoreDetailLayoutView.d.ts +1 -0
  494. package/dist/features/stores/components/StoreDetailLayoutView.js +29 -5
  495. package/dist/features/stores/components/StoreHeader.js +2 -1
  496. package/dist/features/stores/components/StorePreOrdersListing.d.ts +4 -2
  497. package/dist/features/stores/components/StorePreOrdersListing.js +59 -7
  498. package/dist/features/stores/components/StorePreOrdersPageView.js +8 -7
  499. package/dist/features/stores/components/StoreProductsListing.d.ts +5 -2
  500. package/dist/features/stores/components/StoreProductsListing.js +97 -8
  501. package/dist/features/stores/components/StoreProductsPageView.js +8 -7
  502. package/dist/features/stores/components/StoreReviewsListing.js +2 -2
  503. package/dist/features/stores/components/StoresIndexListing.js +74 -11
  504. package/dist/features/stores/components/StoresListView.js +1 -1
  505. package/dist/features/stores/hooks/useStores.d.ts +1 -0
  506. package/dist/features/stores/hooks/useStores.js +1 -0
  507. package/dist/features/stores/schemas/firestore.d.ts +34 -0
  508. package/dist/features/stores/schemas/index.d.ts +8 -8
  509. package/dist/features/sublisting/schemas/firestore.d.ts +30 -0
  510. package/dist/features/sublisting/schemas/firestore.js +19 -0
  511. package/dist/features/support/schemas/firestore.d.ts +113 -0
  512. package/dist/features/support/schemas/firestore.js +95 -0
  513. package/dist/features/whatsapp-bot/components/SellerWhatsAppSettingsView.d.ts +5 -0
  514. package/dist/features/whatsapp-bot/components/SellerWhatsAppSettingsView.js +143 -0
  515. package/dist/features/whatsapp-bot/components/index.d.ts +2 -0
  516. package/dist/features/whatsapp-bot/components/index.js +1 -0
  517. package/dist/features/whatsapp-bot/helpers/whatsapp.d.ts +23 -1
  518. package/dist/features/whatsapp-bot/helpers/whatsapp.js +104 -0
  519. package/dist/features/whatsapp-bot/server.d.ts +1 -0
  520. package/dist/features/whatsapp-bot/server.js +1 -0
  521. package/dist/features/whatsapp-bot/types/index.d.ts +49 -0
  522. package/dist/features/wishlist/components/WishlistView.d.ts +0 -10
  523. package/dist/features/wishlist/components/WishlistView.js +13 -6
  524. package/dist/features/wishlist/hooks/useWishlist.js +2 -0
  525. package/dist/features/wishlist/hooks/useWishlistCount.d.ts +11 -3
  526. package/dist/features/wishlist/hooks/useWishlistCount.js +89 -25
  527. package/dist/features/wishlist/hooks/useWishlistWithGuest.d.ts +1 -1
  528. package/dist/features/wishlist/schemas/index.d.ts +2 -2
  529. package/dist/features/wishlist/types/index.d.ts +16 -0
  530. package/dist/http/api-handler.js +8 -1
  531. package/dist/index.d.ts +114 -16
  532. package/dist/index.js +136 -28
  533. package/dist/monitoring/server-logger.js +9 -3
  534. package/dist/next/routing/route-map.d.ts +120 -6
  535. package/dist/next/routing/route-map.js +53 -2
  536. package/dist/providers/db-firebase/realtime.d.ts +1 -1
  537. package/dist/react/contexts/SessionContext.js +17 -26
  538. package/dist/react/hooks/useBulkSelection.d.ts +7 -24
  539. package/dist/react/hooks/useBulkSelection.js +27 -34
  540. package/dist/react/hooks/useLongPress.d.ts +3 -16
  541. package/dist/react/hooks/useLongPress.js +6 -25
  542. package/dist/react/index.d.ts +1 -0
  543. package/dist/react/index.js +2 -0
  544. package/dist/repositories/index.d.ts +3 -0
  545. package/dist/repositories/index.js +2 -0
  546. package/dist/seed/actions/demo-seed-actions.d.ts +2 -2
  547. package/dist/seed/actions/demo-seed-actions.js +1 -1
  548. package/dist/seed/anime-figures-seed-data.d.ts +8 -0
  549. package/dist/seed/anime-figures-seed-data.js +1033 -0
  550. package/dist/seed/beyblade-seed-data.js +206 -24
  551. package/dist/seed/bids-seed-data.d.ts +4 -10
  552. package/dist/seed/bids-seed-data.js +365 -238
  553. package/dist/seed/blog-posts-seed-data.d.ts +3 -2
  554. package/dist/seed/blog-posts-seed-data.js +250 -511
  555. package/dist/seed/brands-seed-data.d.ts +7 -0
  556. package/dist/seed/brands-seed-data.js +410 -0
  557. package/dist/seed/carousel-slides-seed-data.d.ts +3 -2
  558. package/dist/seed/carousel-slides-seed-data.js +177 -216
  559. package/dist/seed/cart-seed-data.d.ts +9 -9
  560. package/dist/seed/cart-seed-data.js +73 -73
  561. package/dist/seed/categories-seed-data.d.ts +4 -2
  562. package/dist/seed/categories-seed-data.js +720 -879
  563. package/dist/seed/conversations-seed-data.d.ts +8 -0
  564. package/dist/seed/conversations-seed-data.js +388 -0
  565. package/dist/seed/cosplay-accessories-seed-data.d.ts +8 -0
  566. package/dist/seed/cosplay-accessories-seed-data.js +647 -0
  567. package/dist/seed/coupon-usage-seed-data.d.ts +25 -0
  568. package/dist/seed/coupon-usage-seed-data.js +69 -0
  569. package/dist/seed/coupons-seed-data.d.ts +6 -3
  570. package/dist/seed/coupons-seed-data.js +375 -3
  571. package/dist/seed/events-seed-data.d.ts +4 -2
  572. package/dist/seed/events-seed-data.js +128 -430
  573. package/dist/seed/factories/cart.factory.d.ts +0 -1
  574. package/dist/seed/factories/cart.factory.js +2 -2
  575. package/dist/seed/faq-seed-data.d.ts +11 -18
  576. package/dist/seed/faq-seed-data.js +786 -1817
  577. package/dist/seed/grouped-listings-seed-data.d.ts +8 -0
  578. package/dist/seed/grouped-listings-seed-data.js +201 -0
  579. package/dist/seed/homepage-sections-seed-data.d.ts +3 -13
  580. package/dist/seed/homepage-sections-seed-data.js +228 -252
  581. package/dist/seed/hot-wheels-seed-data.js +285 -38
  582. package/dist/seed/index.d.ts +12 -11
  583. package/dist/seed/index.js +10 -12
  584. package/dist/seed/letitrip-official-seed-data.d.ts +8 -0
  585. package/dist/seed/letitrip-official-seed-data.js +399 -0
  586. package/dist/seed/manifest.d.ts +15 -0
  587. package/dist/seed/manifest.js +140 -0
  588. package/dist/seed/notifications-seed-data.d.ts +4 -2
  589. package/dist/seed/notifications-seed-data.js +117 -440
  590. package/dist/seed/orders-seed-data.d.ts +4 -2
  591. package/dist/seed/orders-seed-data.js +1090 -521
  592. package/dist/seed/payouts-seed-data.d.ts +4 -2
  593. package/dist/seed/payouts-seed-data.js +522 -145
  594. package/dist/seed/pokemon-carousel-slides-seed-data.js +6 -1
  595. package/dist/seed/pokemon-categories-seed-data.js +81 -81
  596. package/dist/seed/pokemon-homepage-sections-seed-data.d.ts +1 -1
  597. package/dist/seed/pokemon-homepage-sections-seed-data.js +116 -23
  598. package/dist/seed/pokemon-products-seed-data.d.ts +1 -1
  599. package/dist/seed/pokemon-products-seed-data.js +83 -73
  600. package/dist/seed/pokemon-seed-bundle.d.ts +5 -1
  601. package/dist/seed/pokemon-seed-bundle.js +21 -2
  602. package/dist/seed/pokemon-stores-seed-data.js +85 -9
  603. package/dist/seed/pokemon-users-seed-data.js +107 -8
  604. package/dist/seed/products-auctions-seed-data.d.ts +10 -0
  605. package/dist/seed/products-auctions-seed-data.js +689 -0
  606. package/dist/seed/products-preorders-seed-data.d.ts +9 -0
  607. package/dist/seed/products-preorders-seed-data.js +483 -0
  608. package/dist/seed/products-seed-data.js +34 -13
  609. package/dist/seed/products-standard-seed-data.d.ts +8 -0
  610. package/dist/seed/products-standard-seed-data.js +4179 -0
  611. package/dist/seed/retro-gaming-seed-data.d.ts +8 -0
  612. package/dist/seed/retro-gaming-seed-data.js +801 -0
  613. package/dist/seed/reviews-seed-data.d.ts +4 -17
  614. package/dist/seed/reviews-seed-data.js +1043 -515
  615. package/dist/seed/scammers-seed-data.d.ts +17 -0
  616. package/dist/seed/scammers-seed-data.js +118 -0
  617. package/dist/seed/site-settings-seed-data.js +25 -2
  618. package/dist/seed/store-addresses-seed-data.js +188 -84
  619. package/dist/seed/stores-seed-data.d.ts +3 -9
  620. package/dist/seed/stores-seed-data.js +212 -102
  621. package/dist/seed/sublisting-categories-seed-data.d.ts +7 -0
  622. package/dist/seed/sublisting-categories-seed-data.js +315 -0
  623. package/dist/seed/transformers-seed-data.js +34 -14
  624. package/dist/seed/users-seed-data.d.ts +3 -2
  625. package/dist/seed/users-seed-data.js +531 -440
  626. package/dist/seed/wishlists-seed-data.js +13 -13
  627. package/dist/server.d.ts +9 -2
  628. package/dist/server.js +12 -4
  629. package/dist/tokens/tokens.css +76 -31
  630. package/dist/ui/components/Avatar.style.css +10 -12
  631. package/dist/ui/components/BaseListingCard.d.ts +8 -3
  632. package/dist/ui/components/BaseListingCard.js +17 -6
  633. package/dist/ui/components/BaseListingCard.style.css +3 -1
  634. package/dist/ui/components/BulkActionsBar.d.ts +16 -0
  635. package/dist/ui/components/BulkActionsBar.js +22 -0
  636. package/dist/ui/components/Button.style.css +23 -23
  637. package/dist/ui/components/Card.style.css +60 -62
  638. package/dist/ui/components/Checkbox.style.css +19 -21
  639. package/dist/ui/components/DashboardStatsCard.style.css +12 -14
  640. package/dist/ui/components/Drawer.style.css +18 -14
  641. package/dist/ui/components/Dropdown.style.css +25 -27
  642. package/dist/ui/components/EmptyState.style.css +2 -4
  643. package/dist/ui/components/HorizontalScroller.d.ts +3 -1
  644. package/dist/ui/components/HorizontalScroller.js +116 -21
  645. package/dist/ui/components/HorizontalScroller.style.css +2 -2
  646. package/dist/ui/components/ImageLightbox.d.ts +0 -9
  647. package/dist/ui/components/ImageLightbox.js +43 -9
  648. package/dist/ui/components/InlineCreateSelect.d.ts +38 -0
  649. package/dist/ui/components/InlineCreateSelect.js +70 -0
  650. package/dist/ui/components/ListingLayout.style.css +41 -77
  651. package/dist/ui/components/ListingToolbar.d.ts +54 -0
  652. package/dist/ui/components/ListingToolbar.js +34 -0
  653. package/dist/ui/components/Modal.style.css +14 -10
  654. package/dist/ui/components/PageLoader.d.ts +11 -0
  655. package/dist/ui/components/PageLoader.js +21 -0
  656. package/dist/ui/components/Radio.style.css +34 -36
  657. package/dist/ui/components/RichTextEditor.js +1 -1
  658. package/dist/ui/components/RowActionMenu.d.ts +1 -0
  659. package/dist/ui/components/RowActionMenu.js +4 -2
  660. package/dist/ui/components/SectionTabs.js +1 -1
  661. package/dist/ui/components/SectionTabs.style.css +1 -0
  662. package/dist/ui/components/SideModal.style.css +4 -8
  663. package/dist/ui/components/Slider.style.css +2 -4
  664. package/dist/ui/components/Tabs.style.css +8 -10
  665. package/dist/ui/components/Toast.style.css +22 -24
  666. package/dist/ui/components/Toggle.style.css +11 -13
  667. package/dist/ui/index.d.ts +9 -0
  668. package/dist/ui/index.js +5 -0
  669. package/dist/ui/rich-text/RichText.js +2 -1
  670. package/dist/ui/rich-text/RichText.style.css +292 -5
  671. package/dist/ui/rich-text/RichTextRenderer.d.ts +15 -0
  672. package/dist/ui/rich-text/RichTextRenderer.js +15 -0
  673. package/dist/utils/id-generators.d.ts +10 -0
  674. package/dist/utils/id-generators.js +12 -0
  675. package/dist/validation/schemas.d.ts +9 -9
  676. package/package.json +5 -1
  677. package/README.md +0 -116
@@ -7,29 +7,29 @@
7
7
 
8
8
  /* Variants */
9
9
  .appkit-card--flat {
10
- background: white;
10
+ background: var(--appkit-color-surface, #ffffff);
11
11
  }
12
12
  .appkit-card--default {
13
- background: white;
13
+ background: var(--appkit-color-surface, #ffffff);
14
14
  }
15
15
  .appkit-card--primary {
16
16
  background: var(--color-primary);
17
17
  color: var(--color-primary-foreground, white);
18
18
  }
19
19
  .appkit-card--outlined {
20
- background: white;
20
+ background: var(--appkit-color-surface, #ffffff);
21
21
  border: 1px solid #e4e4e7;
22
22
  }
23
23
  .appkit-card--bordered {
24
- background: white;
24
+ background: var(--appkit-color-surface, #ffffff);
25
25
  border: 2px solid #e4e4e7;
26
26
  }
27
27
  .appkit-card--elevated {
28
- background: white;
28
+ background: var(--appkit-color-surface, #ffffff);
29
29
  box-shadow: 0 4px 6px -1px rgba(228, 228, 231, 0.5);
30
30
  }
31
31
  .appkit-card--interactive {
32
- background: white;
32
+ background: var(--appkit-color-surface, #ffffff);
33
33
  border: 1px solid #e4e4e7;
34
34
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
35
35
  }
@@ -133,60 +133,58 @@
133
133
  }
134
134
 
135
135
  /* Dark mode */
136
- @media (prefers-color-scheme: dark) {
137
- .appkit-card--flat,
138
- .appkit-card--default {
139
- background: #0f172a;
140
- }
141
- .appkit-card--outlined {
142
- background: #0f172a;
143
- border-color: #334155;
144
- }
145
- .appkit-card--bordered {
146
- background: #0f172a;
147
- border-color: #334155;
148
- }
149
- .appkit-card--elevated {
150
- background: #0f172a;
151
- box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2);
152
- }
153
- .appkit-card--interactive {
154
- background: #0f172a;
155
- border-color: #334155;
156
- }
157
- .appkit-card--glass {
158
- border-color: rgba(51, 65, 85, 0.4);
159
- background: rgba(15, 23, 42, 0.75);
160
- }
161
- .appkit-card--stat-indigo {
162
- background: rgba(49, 46, 129, 0.4);
163
- color: #c7d2fe;
164
- border-color: rgba(99, 102, 241, 0.6);
165
- }
166
- .appkit-card--stat-teal {
167
- background: rgba(19, 78, 74, 0.4);
168
- color: #99f6e4;
169
- border-color: rgba(20, 184, 166, 0.6);
170
- }
171
- .appkit-card--stat-amber {
172
- background: rgba(120, 53, 15, 0.4);
173
- color: #fde68a;
174
- border-color: rgba(245, 158, 11, 0.6);
175
- }
176
- .appkit-card--stat-rose {
177
- background: rgba(136, 19, 55, 0.4);
178
- color: #fecdd3;
179
- border-color: rgba(244, 63, 94, 0.6);
180
- }
181
- .appkit-card--stat-emerald {
182
- background: rgba(6, 78, 59, 0.4);
183
- color: #a7f3d0;
184
- border-color: rgba(16, 185, 129, 0.6);
185
- }
186
- .appkit-card__header {
187
- border-bottom-color: #334155;
188
- }
189
- .appkit-card__footer {
190
- border-top-color: #334155;
191
- }
136
+ .dark .appkit-card--flat,
137
+ .dark .appkit-card--default {
138
+ background: #0f172a;
139
+ }
140
+ .dark .appkit-card--outlined {
141
+ background: #0f172a;
142
+ border-color: #334155;
143
+ }
144
+ .dark .appkit-card--bordered {
145
+ background: #0f172a;
146
+ border-color: #334155;
147
+ }
148
+ .dark .appkit-card--elevated {
149
+ background: #0f172a;
150
+ box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2);
151
+ }
152
+ .dark .appkit-card--interactive {
153
+ background: #0f172a;
154
+ border-color: #334155;
155
+ }
156
+ .dark .appkit-card--glass {
157
+ border-color: rgba(51, 65, 85, 0.4);
158
+ background: rgba(15, 23, 42, 0.75);
159
+ }
160
+ .dark .appkit-card--stat-indigo {
161
+ background: rgba(49, 46, 129, 0.4);
162
+ color: #c7d2fe;
163
+ border-color: rgba(99, 102, 241, 0.6);
164
+ }
165
+ .dark .appkit-card--stat-teal {
166
+ background: rgba(19, 78, 74, 0.4);
167
+ color: #99f6e4;
168
+ border-color: rgba(20, 184, 166, 0.6);
169
+ }
170
+ .dark .appkit-card--stat-amber {
171
+ background: rgba(120, 53, 15, 0.4);
172
+ color: #fde68a;
173
+ border-color: rgba(245, 158, 11, 0.6);
174
+ }
175
+ .dark .appkit-card--stat-rose {
176
+ background: rgba(136, 19, 55, 0.4);
177
+ color: #fecdd3;
178
+ border-color: rgba(244, 63, 94, 0.6);
179
+ }
180
+ .dark .appkit-card--stat-emerald {
181
+ background: rgba(6, 78, 59, 0.4);
182
+ color: #a7f3d0;
183
+ border-color: rgba(16, 185, 129, 0.6);
184
+ }
185
+ .dark .appkit-card__header {
186
+ border-bottom-color: #334155;
187
+ }
188
+ .dark .appkit-card__footer {
189
+ border-top-color: #334155;
192
190
  }
@@ -89,25 +89,23 @@
89
89
  }
90
90
 
91
91
  /* Dark mode */
92
- @media (prefers-color-scheme: dark) {
93
- .appkit-checkbox__input {
94
- border-color: #475569;
95
- background: #0f172a;
96
- }
97
- .appkit-checkbox__input:focus-visible {
98
- box-shadow: 0 0 0 2px rgba(236, 72, 153, 0.3), 0 0 0 4px #020617;
99
- }
100
- .appkit-checkbox__input:not(:disabled):hover {
101
- border-color: #ec4899;
102
- }
103
- .appkit-checkbox__input:checked {
104
- border-color: #ec4899;
105
- background-color: #ec4899;
106
- }
107
- .appkit-checkbox__input--error {
108
- border-color: #ef4444;
109
- }
110
- .appkit-checkbox__text {
111
- color: #e4e4e7;
112
- }
92
+ .dark .appkit-checkbox__input {
93
+ border-color: #475569;
94
+ background: #0f172a;
95
+ }
96
+ .dark .appkit-checkbox__input:focus-visible {
97
+ box-shadow: 0 0 0 2px rgba(236, 72, 153, 0.3), 0 0 0 4px #020617;
98
+ }
99
+ .dark .appkit-checkbox__input:not(:disabled):hover {
100
+ border-color: #ec4899;
101
+ }
102
+ .dark .appkit-checkbox__input:checked {
103
+ border-color: #ec4899;
104
+ background-color: #ec4899;
105
+ }
106
+ .dark .appkit-checkbox__input--error {
107
+ border-color: #ef4444;
108
+ }
109
+ .dark .appkit-checkbox__text {
110
+ color: #e4e4e7;
113
111
  }
@@ -53,18 +53,16 @@
53
53
  }
54
54
 
55
55
  /* Dark mode */
56
- @media (prefers-color-scheme: dark) {
57
- .appkit-stats-card {
58
- border-color: #334155;
59
- background: #0f172a;
60
- }
61
- .appkit-stats-card__label {
62
- color: #a1a1aa;
63
- }
64
- .appkit-stats-card__trend--up {
65
- color: #34d399;
66
- }
67
- .appkit-stats-card__trend--down {
68
- color: #f87171;
69
- }
56
+ .dark .appkit-stats-card {
57
+ border-color: #334155;
58
+ background: #0f172a;
59
+ }
60
+ .dark .appkit-stats-card__label {
61
+ color: #a1a1aa;
62
+ }
63
+ .dark .appkit-stats-card__trend--up {
64
+ color: #34d399;
65
+ }
66
+ .dark .appkit-stats-card__trend--down {
67
+ color: #f87171;
70
68
  }
@@ -32,15 +32,15 @@
32
32
  position: absolute;
33
33
  display: flex;
34
34
  flex-direction: column;
35
- background: #ffffff;
36
- border: 1px solid #e4e4e7;
35
+ background: var(--appkit-color-surface, #ffffff);
36
+ border: 1px solid var(--appkit-color-border, #e4e4e7);
37
37
  box-shadow: 0 20px 45px -20px rgba(0, 0, 0, 0.45);
38
38
  transition: transform 0.3s ease;
39
39
  }
40
40
 
41
41
  .dark .appkit-drawer__panel {
42
- background: #0f172a;
43
- border-color: #334155;
42
+ background: var(--appkit-color-surface, #0f172a);
43
+ border-color: var(--appkit-color-border, #334155);
44
44
  }
45
45
 
46
46
  .appkit-drawer__panel--left { left: 0; top: 0; bottom: 0; }
@@ -79,11 +79,11 @@
79
79
  width: 2.5rem;
80
80
  height: 0.25rem;
81
81
  border-radius: 9999px;
82
- background: #d4d4d8;
82
+ background: var(--appkit-color-border, #d4d4d8);
83
83
  }
84
84
 
85
85
  .dark .appkit-drawer__drag {
86
- background: #475569;
86
+ background: var(--appkit-color-border, #475569);
87
87
  }
88
88
 
89
89
  .appkit-drawer__header {
@@ -91,17 +91,18 @@
91
91
  align-items: center;
92
92
  justify-content: space-between;
93
93
  padding: 1rem 1.25rem;
94
- border-bottom: 1px solid #f4f4f5;
94
+ border-bottom: 1px solid var(--appkit-color-border-subtle, #f4f4f5);
95
95
  flex-shrink: 0;
96
96
  }
97
97
 
98
98
  .dark .appkit-drawer__header {
99
- border-bottom-color: #1e293b;
99
+ border-bottom-color: var(--appkit-color-border-subtle, #1e293b);
100
100
  }
101
101
 
102
102
  .appkit-drawer__title {
103
103
  font-size: 1rem;
104
104
  font-weight: 600;
105
+ color: var(--appkit-color-text, #18181b);
105
106
  }
106
107
 
107
108
  .appkit-drawer__close {
@@ -109,19 +110,22 @@
109
110
  min-height: 0;
110
111
  padding: 0.375rem;
111
112
  border-radius: 0.5rem;
112
- color: #a1a1aa;
113
+ color: var(--appkit-color-text-faint, #a1a1aa);
114
+ transition: color 0.15s ease, background-color 0.15s ease;
113
115
  }
114
116
 
115
117
  .appkit-drawer__close:hover {
116
- color: #3f3f46;
118
+ color: var(--appkit-color-text, #3f3f46);
119
+ background-color: var(--appkit-color-border-subtle, #f4f4f5);
117
120
  }
118
121
 
119
122
  .dark .appkit-drawer__close {
120
- color: #71717a;
123
+ color: var(--appkit-color-text-faint, #71717a);
121
124
  }
122
125
 
123
126
  .dark .appkit-drawer__close:hover {
124
- color: #cbd5e1;
127
+ color: var(--appkit-color-text-muted, #cbd5e1);
128
+ background-color: rgba(30, 41, 59, 0.5);
125
129
  }
126
130
 
127
131
  .appkit-drawer__close-icon {
@@ -137,10 +141,10 @@
137
141
 
138
142
  .appkit-drawer__footer {
139
143
  flex-shrink: 0;
140
- border-top: 1px solid #f4f4f5;
144
+ border-top: 1px solid var(--appkit-color-border-subtle, #f4f4f5);
141
145
  padding: 1rem 1.25rem;
142
146
  }
143
147
 
144
148
  .dark .appkit-drawer__footer {
145
- border-top-color: #1e293b;
149
+ border-top-color: var(--appkit-color-border-subtle, #1e293b);
146
150
  }
@@ -82,31 +82,29 @@
82
82
  }
83
83
 
84
84
  /* Dark mode */
85
- @media (prefers-color-scheme: dark) {
86
- .appkit-dropdown__menu {
87
- border-color: #334155;
88
- background: #0f172a;
89
- }
90
- .appkit-dropdown__item {
91
- color: #e2e8f0;
92
- }
93
- .appkit-dropdown__item--active {
94
- background: #1e293b;
95
- }
96
- .appkit-dropdown__item--destructive {
97
- color: #f87171;
98
- }
99
- .appkit-dropdown__composed-menu {
100
- border-color: #334155;
101
- background: #0f172a;
102
- }
103
- .appkit-dropdown__composed-item {
104
- color: #e2e8f0;
105
- }
106
- .appkit-dropdown__composed-item:hover {
107
- background: #1e293b;
108
- }
109
- .appkit-dropdown__separator {
110
- border-color: #334155;
111
- }
85
+ .dark .appkit-dropdown__menu {
86
+ border-color: #334155;
87
+ background: #0f172a;
88
+ }
89
+ .dark .appkit-dropdown__item {
90
+ color: #e2e8f0;
91
+ }
92
+ .dark .appkit-dropdown__item--active {
93
+ background: #1e293b;
94
+ }
95
+ .dark .appkit-dropdown__item--destructive {
96
+ color: #f87171;
97
+ }
98
+ .dark .appkit-dropdown__composed-menu {
99
+ border-color: #334155;
100
+ background: #0f172a;
101
+ }
102
+ .dark .appkit-dropdown__composed-item {
103
+ color: #e2e8f0;
104
+ }
105
+ .dark .appkit-dropdown__composed-item:hover {
106
+ background: #1e293b;
107
+ }
108
+ .dark .appkit-dropdown__separator {
109
+ border-color: #334155;
112
110
  }
@@ -23,8 +23,6 @@
23
23
  }
24
24
 
25
25
  /* Dark mode */
26
- @media (prefers-color-scheme: dark) {
27
- .appkit-empty-state__icon {
28
- color: #64748b;
29
- }
26
+ .dark .appkit-empty-state__icon {
27
+ color: #64748b;
30
28
  }
@@ -29,5 +29,7 @@ export interface HorizontalScrollerProps<T = unknown> {
29
29
  minItemWidth?: number;
30
30
  pauseOnHover?: boolean;
31
31
  itemClassName?: string;
32
+ /** Infinite-loop mode: circular slot rendering with scroll teleport — no array cloning */
33
+ loop?: boolean;
32
34
  }
33
- export declare function HorizontalScroller<T = unknown>({ children, className, gap, snapToItems, showArrows, arrowSize, showScrollbar, showFadeEdges, scrollContainerRef: externalRef, onScroll, items, renderItem, keyExtractor, perView, rows, autoScroll, autoScrollInterval, minItemWidth, pauseOnHover, itemClassName, }: HorizontalScrollerProps<T>): import("react/jsx-runtime").JSX.Element;
35
+ export declare function HorizontalScroller<T = unknown>({ children, className, gap, snapToItems, showArrows, arrowSize, showScrollbar, showFadeEdges, scrollContainerRef: externalRef, onScroll, items, renderItem, keyExtractor, perView, rows, autoScroll, autoScrollInterval, minItemWidth, pauseOnHover, itemClassName, loop, }: HorizontalScrollerProps<T>): import("react/jsx-runtime").JSX.Element;
@@ -21,13 +21,74 @@ function resolvePerView(perView, containerWidth) {
21
21
  }
22
22
  return 1;
23
23
  }
24
- export function HorizontalScroller({ children, className = "", gap = 16, snapToItems, showArrows, arrowSize = "md", showScrollbar, showFadeEdges, scrollContainerRef: externalRef, onScroll, items, renderItem, keyExtractor, perView, rows = 1, autoScroll, autoScrollInterval = 3500, minItemWidth, pauseOnHover = false, itemClassName = "", }) {
24
+ export function HorizontalScroller({ children, className = "", gap = 16, snapToItems, showArrows, arrowSize = "md", showScrollbar, showFadeEdges, scrollContainerRef: externalRef, onScroll, items, renderItem, keyExtractor, perView, rows = 1, autoScroll, autoScrollInterval = 3500, minItemWidth, pauseOnHover = false, itemClassName = "", loop = false, }) {
25
25
  const [itemWidth, setItemWidth] = useState(undefined);
26
26
  const [isPaused, setIsPaused] = useState(false);
27
27
  const internalRef = useRef(null);
28
28
  const containerRef = (externalRef ??
29
29
  internalRef);
30
30
  const autoScrollTimer = useRef(undefined);
31
+ // Prevents re-entrant teleports during the instantaneous scrollLeft reset
32
+ const isJumping = useRef(false);
33
+ // Prevents re-running the initial scroll-to-real-start on every itemWidth update
34
+ const loopInitialized = useRef(false);
35
+ const normalizedItems = Array.isArray(items) ? items : [];
36
+ const itemsMode = Array.isArray(items) && renderItem != null;
37
+ const itemCount = normalizedItems.length;
38
+ // Number of clone slots on each side — fixed size, computed once from perView hint.
39
+ // Using Math.min so tiny lists don't double-render more slots than they have items.
40
+ const loopCloneCount = loop && itemsMode && itemCount > 0
41
+ ? Math.min(itemCount, typeof perView === "number" ? perView : 3)
42
+ : 0;
43
+ // On first paint after itemWidth resolves, scroll to the first *real* item
44
+ // (skipping the left clone slots that provide backward-wrap buffer).
45
+ useEffect(() => {
46
+ if (!loop || loopCloneCount === 0 || itemWidth === undefined)
47
+ return;
48
+ const el = containerRef.current;
49
+ if (!el || loopInitialized.current)
50
+ return;
51
+ loopInitialized.current = true;
52
+ el.style.scrollBehavior = "auto";
53
+ el.scrollLeft = loopCloneCount * (itemWidth + gap);
54
+ requestAnimationFrame(() => {
55
+ el.style.scrollBehavior = "";
56
+ });
57
+ }, [loop, loopCloneCount, itemWidth, gap, containerRef]);
58
+ // Circular teleporter: when scroll enters a clone zone, jump by exactly one
59
+ // full cycle so the viewport content is unchanged but we're back in real territory.
60
+ const handleScrollLoop = useCallback(() => {
61
+ if (!loop || loopCloneCount === 0 || itemWidth === undefined)
62
+ return;
63
+ const el = containerRef.current;
64
+ if (!el || isJumping.current)
65
+ return;
66
+ const stride = itemWidth + gap;
67
+ const cycleWidth = itemCount * stride;
68
+ // scrollLeft where real items start and end
69
+ const realStart = loopCloneCount * stride;
70
+ const realEnd = realStart + cycleWidth;
71
+ if (el.scrollLeft < realStart - stride * 0.5) {
72
+ // Entered left clone zone — jump forward one cycle
73
+ isJumping.current = true;
74
+ el.style.scrollBehavior = "auto";
75
+ el.scrollLeft += cycleWidth;
76
+ requestAnimationFrame(() => {
77
+ isJumping.current = false;
78
+ el.style.scrollBehavior = "";
79
+ });
80
+ }
81
+ else if (el.scrollLeft > realEnd - el.clientWidth + stride * 0.5) {
82
+ // Entered right clone zone — jump backward one cycle
83
+ isJumping.current = true;
84
+ el.style.scrollBehavior = "auto";
85
+ el.scrollLeft -= cycleWidth;
86
+ requestAnimationFrame(() => {
87
+ isJumping.current = false;
88
+ el.style.scrollBehavior = "";
89
+ });
90
+ }
91
+ }, [loop, loopCloneCount, itemWidth, gap, itemCount, containerRef]);
31
92
  const scrollBy = useCallback((direction) => {
32
93
  const el = containerRef.current;
33
94
  if (!el)
@@ -48,9 +109,15 @@ export function HorizontalScroller({ children, className = "", gap = 16, snapToI
48
109
  useEffect(() => {
49
110
  if (!autoScroll || isPaused)
50
111
  return;
51
- autoScrollTimer.current = setInterval(() => scrollBy(1), autoScrollInterval);
112
+ autoScrollTimer.current = setInterval(() => {
113
+ const el = containerRef.current;
114
+ if (!el)
115
+ return;
116
+ // Always advance; handleScrollLoop teleports when clone zone is reached
117
+ el.scrollBy({ left: el.clientWidth * 0.8, behavior: "smooth" });
118
+ }, autoScrollInterval);
52
119
  return () => clearInterval(autoScrollTimer.current);
53
- }, [autoScroll, isPaused, autoScrollInterval, scrollBy]);
120
+ }, [autoScroll, isPaused, autoScrollInterval, containerRef]);
54
121
  useEffect(() => {
55
122
  if (!perView)
56
123
  return;
@@ -67,20 +134,10 @@ export function HorizontalScroller({ children, className = "", gap = 16, snapToI
67
134
  observer.observe(el);
68
135
  return () => observer.disconnect();
69
136
  }, [perView, gap, containerRef]);
70
- const normalizedItems = Array.isArray(items) ? items : [];
71
- const itemsMode = Array.isArray(items) && renderItem != null;
72
- const scrollerCls = [
73
- "appkit-hscroller__track",
74
- snapToItems ? "appkit-hscroller__track--snap" : "",
75
- !showScrollbar ? "appkit-hscroller__track--no-scrollbar" : "",
76
- ]
77
- .filter(Boolean)
78
- .join(" ");
79
137
  const content = itemsMode ? (rows > 1 ? (
80
138
  // Grid mode: group items into slides with rows x cols
81
- // On mobile: 1 card centered, on larger screens: 2x3 grid
82
139
  normalizedItems.reduce((slides, item, i) => {
83
- const cardsPerSlide = 6; // Always 6 cards per slide (2x3 grid)
140
+ const cardsPerSlide = 6;
84
141
  const slideIndex = Math.floor(i / cardsPerSlide);
85
142
  const itemInSlide = i % cardsPerSlide;
86
143
  const rowIndex = Math.floor(itemInSlide / 3);
@@ -88,7 +145,6 @@ export function HorizontalScroller({ children, className = "", gap = 16, snapToI
88
145
  if (!slides[slideIndex]) {
89
146
  slides[slideIndex] = (_jsx("div", { className: "appkit-hscroller__slide grid grid-cols-1 sm:grid-cols-3 gap-4 place-items-center sm:place-items-start", style: { gap: `${gap}px`, width: "100%", flexShrink: 0 }, children: Array.from({ length: 6 }, (_, idx) => (_jsx("div", { className: "appkit-hscroller__item-placeholder w-full sm:w-auto" }, `placeholder-${idx}`))) }, `slide-${slideIndex}`));
90
147
  }
91
- // Replace placeholder with actual item
92
148
  const slideElement = slides[slideIndex];
93
149
  const gridIndex = rowIndex * 3 + colIndex;
94
150
  const childrenArr = slideElement.props.children ?? [];
@@ -107,8 +163,29 @@ export function HorizontalScroller({ children, className = "", gap = 16, snapToI
107
163
  });
108
164
  }
109
165
  return slides;
110
- }, [])) : (
111
- // Single row mode
166
+ }, [])) : loop && itemCount > 0 ? (
167
+ // Circular loop: fixed (itemCount + 2×loopCloneCount) DOM slots.
168
+ // Each slot maps to a real item via modulo — no array cloning, no list growth.
169
+ // Left slots [0 .. loopCloneCount-1] → tail of real list (left buffer)
170
+ // Real slots [loopCloneCount .. loopCloneCount+n-1] → items[0..n-1]
171
+ // Right slots [loopCloneCount+n .. end] → head of real list (right buffer)
172
+ Array.from({ length: itemCount + 2 * loopCloneCount }, (_, i) => {
173
+ const realIndex = ((i - loopCloneCount) % itemCount + itemCount) % itemCount;
174
+ const item = normalizedItems[realIndex];
175
+ const isClone = i < loopCloneCount || i >= loopCloneCount + itemCount;
176
+ return (_jsx("div", { className: [
177
+ "appkit-hscroller__item",
178
+ snapToItems ? "appkit-hscroller__item--snap" : "",
179
+ itemClassName,
180
+ ]
181
+ .filter(Boolean)
182
+ .join(" "), style: itemWidth !== undefined
183
+ ? { width: itemWidth, flexShrink: 0 }
184
+ : minItemWidth
185
+ ? { minWidth: minItemWidth }
186
+ : undefined, "aria-hidden": isClone ? true : undefined, children: renderItem(item, realIndex) }, `loop-slot-${i}`));
187
+ })) : (
188
+ // Normal single row (no loop)
112
189
  normalizedItems.map((item, i) => (_jsx("div", { className: [
113
190
  "appkit-hscroller__item",
114
191
  snapToItems ? "appkit-hscroller__item--snap" : "",
@@ -119,14 +196,32 @@ export function HorizontalScroller({ children, className = "", gap = 16, snapToI
119
196
  ? { width: itemWidth, flexShrink: 0 }
120
197
  : minItemWidth
121
198
  ? { minWidth: minItemWidth }
122
- : undefined, children: renderItem(item, i) }, keyExtractor ? keyExtractor(item, i) : i))))) : children;
199
+ : undefined, children: renderItem(item, i) }, keyExtractor ? keyExtractor(item, i) : i))))) : (children);
123
200
  const hoverHandlers = pauseOnHover
124
- ? { onMouseEnter: () => setIsPaused(true), onMouseLeave: () => setIsPaused(false) }
201
+ ? {
202
+ onMouseEnter: () => setIsPaused(true),
203
+ onMouseLeave: () => setIsPaused(false),
204
+ }
125
205
  : {};
206
+ const combinedOnScroll = loop
207
+ ? () => {
208
+ handleScrollLoop();
209
+ onScroll?.();
210
+ }
211
+ : onScroll;
126
212
  if (showArrows) {
127
213
  return (_jsxs("div", { className: ["appkit-hscroller appkit-hscroller--with-arrows", className]
128
214
  .filter(Boolean)
129
- .join(" "), tabIndex: 0, onKeyDown: handleKeyDown, ...hoverHandlers, "data-section": "horizontalscroller-div-511", children: [showFadeEdges && (_jsxs(_Fragment, { children: [_jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--left" }), _jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--right" })] })), _jsx("button", { type: "button", onClick: () => scrollBy(-1), "aria-label": "Previous", className: `appkit-hscroller__arrow appkit-hscroller__arrow--prev appkit-hscroller__arrow--${arrowSize}`, children: _jsx(ChevronLeft, { className: "w-4 h-4" }) }), _jsx("div", { ref: containerRef, onScroll: onScroll, className: scrollerCls, style: { gap: `${gap}px`, paddingLeft: 36, paddingRight: 36 }, "data-section": "horizontalscroller-div-512", children: content }), _jsx("button", { type: "button", onClick: () => scrollBy(1), "aria-label": "Next", className: `appkit-hscroller__arrow appkit-hscroller__arrow--next appkit-hscroller__arrow--${arrowSize}`, children: _jsx(ChevronRight, { className: "w-4 h-4" }) })] }));
215
+ .join(" "), tabIndex: 0, onKeyDown: handleKeyDown, ...hoverHandlers, "data-section": "horizontalscroller-div-511", children: [showFadeEdges && (_jsxs(_Fragment, { children: [_jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--left" }), _jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--right" })] })), _jsx("button", { type: "button", onClick: () => scrollBy(-1), "aria-label": "Previous", className: `appkit-hscroller__arrow appkit-hscroller__arrow--prev appkit-hscroller__arrow--${arrowSize}`, children: _jsx(ChevronLeft, { className: "w-4 h-4" }) }), _jsx("div", { ref: containerRef, onScroll: combinedOnScroll, className: scrollerCls(snapToItems, showScrollbar), style: { gap: `${gap}px`, paddingLeft: 36, paddingRight: 36 }, "data-section": "horizontalscroller-div-512", children: content }), _jsx("button", { type: "button", onClick: () => scrollBy(1), "aria-label": "Next", className: `appkit-hscroller__arrow appkit-hscroller__arrow--next appkit-hscroller__arrow--${arrowSize}`, children: _jsx(ChevronRight, { className: "w-4 h-4" }) })] }));
130
216
  }
131
- return (_jsxs("div", { className: ["appkit-hscroller", className].filter(Boolean).join(" "), tabIndex: 0, onKeyDown: handleKeyDown, ...hoverHandlers, "data-section": "horizontalscroller-div-513", children: [showFadeEdges && (_jsxs(_Fragment, { children: [_jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--left" }), _jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--right" })] })), _jsx("div", { ref: containerRef, onScroll: onScroll, className: scrollerCls, style: { gap: `${gap}px` }, "data-section": "horizontalscroller-div-514", children: content })] }));
217
+ return (_jsxs("div", { className: ["appkit-hscroller", className].filter(Boolean).join(" "), tabIndex: 0, onKeyDown: handleKeyDown, ...hoverHandlers, "data-section": "horizontalscroller-div-513", children: [showFadeEdges && (_jsxs(_Fragment, { children: [_jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--left" }), _jsx("div", { className: "appkit-hscroller__fade appkit-hscroller__fade--right" })] })), _jsx("div", { ref: containerRef, onScroll: combinedOnScroll, className: scrollerCls(snapToItems, showScrollbar), style: { gap: `${gap}px` }, "data-section": "horizontalscroller-div-514", children: content })] }));
218
+ }
219
+ function scrollerCls(snapToItems, showScrollbar) {
220
+ return [
221
+ "appkit-hscroller__track",
222
+ snapToItems ? "appkit-hscroller__track--snap" : "",
223
+ !showScrollbar ? "appkit-hscroller__track--no-scrollbar" : "",
224
+ ]
225
+ .filter(Boolean)
226
+ .join(" ");
132
227
  }
@@ -98,8 +98,8 @@
98
98
  }
99
99
 
100
100
  .dark .appkit-hscroller__fade--left {
101
- background: linear-gradient(to right, #111827, transparent); /* gray-900 */
101
+ background: linear-gradient(to right, #0f172a, transparent); /* slate-900 — matches surface dark */
102
102
  }
103
103
  .dark .appkit-hscroller__fade--right {
104
- background: linear-gradient(to left, #111827, transparent);
104
+ background: linear-gradient(to left, #0f172a, transparent);
105
105
  }
@@ -1,13 +1,4 @@
1
1
  import React from "react";
2
- /**
3
- * ImageLightbox — full-screen image overlay with keyboard navigation.
4
- *
5
- * Standalone @mohasinac/ui primitive. No app-specific imports.
6
- * Navigation: ← / → arrow keys, Esc to close. Displays item counter.
7
- *
8
- * Uses a standard <img> tag for framework portability.
9
- * In a Next.js app, callers may swap src with a blurDataURL if desired.
10
- */
11
2
  export interface LightboxImage {
12
3
  src: string;
13
4
  alt?: string;