@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.
- package/dist/client.d.ts +48 -12
- package/dist/client.js +25 -6
- package/dist/constants/api-endpoints.d.ts +380 -22
- package/dist/constants/api-endpoints.js +66 -13
- package/dist/constants/index.d.ts +1 -1
- package/dist/constants/index.js +1 -1
- package/dist/core/hooks/useSyncManager.d.ts +1 -0
- package/dist/core/hooks/useSyncManager.js +83 -0
- package/dist/core/integration-keys.d.ts +4 -0
- package/dist/core/integration-keys.js +8 -0
- package/dist/features/about/components/FAQPageView.js +9 -11
- package/dist/features/about/components/PolicyPageView.js +32 -11
- package/dist/features/about/components/PublicProfileView.js +77 -11
- package/dist/features/account/components/AddressesIndexListing.js +63 -38
- package/dist/features/account/components/UserOffersPanel.d.ts +8 -0
- package/dist/features/account/components/UserOffersPanel.js +81 -0
- package/dist/features/account/components/UserSettingsView.d.ts +2 -1
- package/dist/features/account/components/UserSettingsView.js +2 -1
- package/dist/features/account/components/UserSidebar.d.ts +6 -1
- package/dist/features/account/components/UserSidebar.js +48 -42
- package/dist/features/account/components/index.d.ts +2 -0
- package/dist/features/account/components/index.js +1 -0
- package/dist/features/admin/actions/admin-actions.d.ts +1 -1
- package/dist/features/admin/actions/admin-actions.js +13 -3
- package/dist/features/admin/components/AdminAdEditorView.js +6 -7
- package/dist/features/admin/components/AdminAllEventEntriesView.d.ts +4 -0
- package/dist/features/admin/components/AdminAllEventEntriesView.js +102 -0
- package/dist/features/admin/components/AdminBidsView.js +94 -8
- package/dist/features/admin/components/AdminBlogEditorView.d.ts +7 -0
- package/dist/features/admin/components/AdminBlogEditorView.js +162 -0
- package/dist/features/admin/components/AdminBlogView.d.ts +4 -1
- package/dist/features/admin/components/AdminBlogView.js +61 -31
- package/dist/features/admin/components/AdminBrandEditorView.d.ts +7 -0
- package/dist/features/admin/components/AdminBrandEditorView.js +104 -0
- package/dist/features/admin/components/AdminBrandsView.d.ts +4 -0
- package/dist/features/admin/components/AdminBrandsView.js +76 -0
- package/dist/features/admin/components/AdminCarouselEditorView.d.ts +8 -0
- package/dist/features/admin/components/AdminCarouselEditorView.js +204 -0
- package/dist/features/admin/components/AdminCarouselView.js +153 -34
- package/dist/features/admin/components/AdminCartsView.d.ts +4 -0
- package/dist/features/admin/components/AdminCartsView.js +82 -0
- package/dist/features/admin/components/AdminCategoriesView.d.ts +4 -1
- package/dist/features/admin/components/AdminCategoriesView.js +66 -48
- package/dist/features/admin/components/AdminCategoryEditorView.d.ts +7 -0
- package/dist/features/admin/components/AdminCategoryEditorView.js +115 -0
- package/dist/features/admin/components/AdminContactEditorView.d.ts +11 -0
- package/dist/features/admin/components/AdminContactEditorView.js +32 -0
- package/dist/features/admin/components/AdminContactView.js +111 -20
- package/dist/features/admin/components/AdminCouponEditorView.d.ts +7 -0
- package/dist/features/admin/components/AdminCouponEditorView.js +179 -0
- package/dist/features/admin/components/AdminCouponsView.d.ts +4 -1
- package/dist/features/admin/components/AdminCouponsView.js +57 -9
- package/dist/features/admin/components/AdminDashboardView.js +3 -0
- package/dist/features/admin/components/AdminFaqEditorView.d.ts +7 -0
- package/dist/features/admin/components/AdminFaqEditorView.js +128 -0
- package/dist/features/admin/components/AdminFaqsView.d.ts +4 -1
- package/dist/features/admin/components/AdminFaqsView.js +55 -23
- package/dist/features/admin/components/AdminFeatureFlagsView.js +33 -24
- package/dist/features/admin/components/AdminListingScaffold.d.ts +7 -1
- package/dist/features/admin/components/AdminListingScaffold.js +2 -2
- package/dist/features/admin/components/AdminMediaView.js +18 -8
- package/dist/features/admin/components/AdminNavEditorView.d.ts +20 -0
- package/dist/features/admin/components/AdminNavEditorView.js +84 -0
- package/dist/features/admin/components/AdminNavigationView.d.ts +1 -7
- package/dist/features/admin/components/AdminNavigationView.js +84 -72
- package/dist/features/admin/components/AdminNewsletterView.js +102 -20
- package/dist/features/admin/components/AdminNotificationsView.d.ts +4 -0
- package/dist/features/admin/components/AdminNotificationsView.js +119 -0
- package/dist/features/admin/components/AdminOrderEditorView.d.ts +8 -0
- package/dist/features/admin/components/AdminOrderEditorView.js +74 -0
- package/dist/features/admin/components/AdminOrdersView.js +64 -8
- package/dist/features/admin/components/AdminPayoutsView.js +122 -13
- package/dist/features/admin/components/AdminProductEditorView.d.ts +7 -0
- package/dist/features/admin/components/AdminProductEditorView.js +143 -0
- package/dist/features/admin/components/AdminProductsView.d.ts +4 -1
- package/dist/features/admin/components/AdminProductsView.js +119 -30
- package/dist/features/admin/components/AdminReturnRequestsView.d.ts +5 -0
- package/dist/features/admin/components/AdminReturnRequestsView.js +101 -0
- package/dist/features/admin/components/AdminReviewsView.js +138 -28
- package/dist/features/admin/components/AdminSectionsView.js +361 -472
- package/dist/features/admin/components/AdminSessionsView.d.ts +4 -0
- package/dist/features/admin/components/AdminSessionsView.js +119 -0
- package/dist/features/admin/components/AdminSidebar.d.ts +18 -3
- package/dist/features/admin/components/AdminSidebar.js +51 -4
- package/dist/features/admin/components/AdminSiteSettingsView.d.ts +7 -0
- package/dist/features/admin/components/AdminSiteSettingsView.js +319 -0
- package/dist/features/admin/components/AdminStoreAddressesView.d.ts +5 -0
- package/dist/features/admin/components/AdminStoreAddressesView.js +52 -0
- package/dist/features/admin/components/AdminStoreEditorView.d.ts +9 -0
- package/dist/features/admin/components/AdminStoreEditorView.js +55 -0
- package/dist/features/admin/components/AdminStoresView.js +62 -20
- package/dist/features/admin/components/AdminUserEditorView.d.ts +10 -0
- package/dist/features/admin/components/AdminUserEditorView.js +72 -0
- package/dist/features/admin/components/AdminUsersView.js +70 -36
- package/dist/features/admin/components/AdminWishlistsView.d.ts +4 -0
- package/dist/features/admin/components/AdminWishlistsView.js +53 -0
- package/dist/features/admin/components/BrandQuickCreateForm.d.ts +5 -0
- package/dist/features/admin/components/BrandQuickCreateForm.js +36 -0
- package/dist/features/admin/components/CategoryQuickCreateForm.d.ts +5 -0
- package/dist/features/admin/components/CategoryQuickCreateForm.js +35 -0
- package/dist/features/admin/components/DataTable.d.ts +4 -2
- package/dist/features/admin/components/DataTable.js +26 -6
- package/dist/features/admin/components/index.d.ts +47 -1
- package/dist/features/admin/components/index.js +23 -0
- package/dist/features/admin/components/sections/adminSectionsBuildParse.d.ts +48 -0
- package/dist/features/admin/components/sections/adminSectionsBuildParse.js +653 -0
- package/dist/features/admin/components/sections/adminSectionsTypes.d.ts +298 -0
- package/dist/features/admin/components/sections/adminSectionsTypes.js +278 -0
- package/dist/features/admin/schemas/firestore.d.ts +26 -0
- package/dist/features/admin/schemas/firestore.js +1 -0
- package/dist/features/admin/types/product.types.d.ts +2 -3
- package/dist/features/auctions/actions/bid-actions.js +6 -2
- package/dist/features/auctions/components/AuctionDetailPageView.d.ts +3 -1
- package/dist/features/auctions/components/AuctionDetailPageView.js +38 -12
- package/dist/features/auctions/components/AuctionFilters.d.ts +3 -1
- package/dist/features/auctions/components/AuctionFilters.js +6 -2
- package/dist/features/auctions/components/CollapsibleBidHistory.d.ts +7 -0
- package/dist/features/auctions/components/CollapsibleBidHistory.js +8 -0
- package/dist/features/auctions/components/MarketplaceAuctionCard.d.ts +4 -0
- package/dist/features/auctions/components/MarketplaceAuctionCard.js +43 -9
- package/dist/features/auctions/components/MarketplaceAuctionGrid.js +1 -0
- package/dist/features/auctions/components/PlaceBidFormClient.d.ts +18 -0
- package/dist/features/auctions/components/PlaceBidFormClient.js +33 -0
- package/dist/features/auctions/hooks/useAuctions.d.ts +1 -0
- package/dist/features/auctions/hooks/useAuctions.js +1 -0
- package/dist/features/auctions/schemas/index.d.ts +22 -12
- package/dist/features/auth/actions/profile-actions.d.ts +5 -3
- package/dist/features/auth/actions/profile-actions.js +30 -11
- package/dist/features/auth/auth-helpers.js +1 -0
- package/dist/features/auth/components/LoginForm.js +2 -1
- package/dist/features/auth/hooks/useAuth.js +16 -4
- package/dist/features/auth/permissions/constants.d.ts +63 -0
- package/dist/features/auth/permissions/constants.js +323 -0
- package/dist/features/auth/schemas/firestore.d.ts +20 -0
- package/dist/features/auth/schemas/index.d.ts +4 -4
- package/dist/features/auth/schemas/index.js +3 -2
- package/dist/features/auth/types/index.d.ts +1 -1
- package/dist/features/before-after/schemas/index.d.ts +2 -2
- package/dist/features/blog/actions/blog-actions.d.ts +15 -15
- package/dist/features/blog/components/BlogFilters.js +1 -1
- package/dist/features/blog/components/BlogIndexListing.js +57 -5
- package/dist/features/blog/components/BlogIndexPageView.js +14 -2
- package/dist/features/blog/components/BlogPostForm.js +6 -2
- package/dist/features/blog/components/BlogPostView.js +2 -1
- package/dist/features/blog/hooks/useBlog.d.ts +2 -0
- package/dist/features/blog/hooks/useBlog.js +2 -0
- package/dist/features/blog/schemas/index.d.ts +46 -12
- package/dist/features/brands/actions/brand-actions.d.ts +2 -0
- package/dist/features/brands/actions/brand-actions.js +5 -0
- package/dist/features/brands/index.d.ts +3 -0
- package/dist/features/brands/index.js +3 -0
- package/dist/features/brands/repository/brands.repository.d.ts +13 -0
- package/dist/features/brands/repository/brands.repository.js +60 -0
- package/dist/features/brands/schemas/index.d.ts +33 -0
- package/dist/features/brands/schemas/index.js +15 -0
- package/dist/features/brands/server.d.ts +7 -0
- package/dist/features/brands/server.js +7 -0
- package/dist/features/cart/actions/cart-actions.js +2 -2
- package/dist/features/cart/components/CartDrawer.d.ts +5 -1
- package/dist/features/cart/components/CartDrawer.js +3 -3
- package/dist/features/cart/hooks/useCartCount.d.ts +3 -2
- package/dist/features/cart/hooks/useCartCount.js +4 -2
- package/dist/features/cart/hooks/useGuestCartMerge.js +1 -1
- package/dist/features/cart/index.d.ts +1 -0
- package/dist/features/cart/index.js +1 -0
- package/dist/features/cart/repository/cart.repository.d.ts +5 -1
- package/dist/features/cart/repository/cart.repository.js +36 -5
- package/dist/features/cart/schemas/firestore.d.ts +25 -6
- package/dist/features/cart/schemas/firestore.js +2 -2
- package/dist/features/cart/schemas/index.d.ts +9 -9
- package/dist/features/cart/schemas/index.js +1 -1
- package/dist/features/cart/types/index.d.ts +1 -1
- package/dist/features/cart/utils/pending-ops.d.ts +33 -0
- package/dist/features/cart/utils/pending-ops.js +102 -0
- package/dist/features/categories/components/BrandDetailPageView.d.ts +4 -0
- package/dist/features/categories/components/BrandDetailPageView.js +54 -0
- package/dist/features/categories/components/BrandDetailTabs.d.ts +10 -0
- package/dist/features/categories/components/BrandDetailTabs.js +22 -0
- package/dist/features/categories/components/CategoriesIndexListing.d.ts +3 -1
- package/dist/features/categories/components/CategoriesIndexListing.js +83 -7
- package/dist/features/categories/components/CategoryDetailPageView.js +42 -21
- package/dist/features/categories/components/CategoryDetailTabs.d.ts +7 -1
- package/dist/features/categories/components/CategoryDetailTabs.js +12 -7
- package/dist/features/categories/components/CategoryFilters.js +1 -1
- package/dist/features/categories/components/CategoryForm.js +10 -4
- package/dist/features/categories/components/CategoryProductsListing.d.ts +4 -1
- package/dist/features/categories/components/CategoryProductsListing.js +34 -5
- package/dist/features/categories/components/ConcernCard.js +1 -1
- package/dist/features/categories/hooks/useCategories.js +2 -0
- package/dist/features/categories/repository/categories.repository.js +2 -3
- package/dist/features/categories/schemas/firestore.d.ts +23 -2
- package/dist/features/categories/schemas/firestore.js +8 -0
- package/dist/features/categories/schemas/index.d.ts +8 -8
- package/dist/features/categories/types/index.d.ts +1 -0
- package/dist/features/collections/schemas/index.d.ts +2 -2
- package/dist/features/events/components/AdminEventEditorView.js +2 -2
- package/dist/features/events/components/AdminEventsView.d.ts +4 -1
- package/dist/features/events/components/AdminEventsView.js +64 -38
- package/dist/features/events/components/EventCard.js +1 -1
- package/dist/features/events/components/EventFilters.js +1 -1
- package/dist/features/events/components/EventPollWidget.d.ts +12 -0
- package/dist/features/events/components/EventPollWidget.js +62 -0
- package/dist/features/events/components/EventsIndexListing.js +57 -5
- package/dist/features/events/components/EventsListPageView.js +1 -1
- package/dist/features/events/components/index.d.ts +2 -0
- package/dist/features/events/components/index.js +1 -0
- package/dist/features/events/hooks/useEvents.d.ts +1 -0
- package/dist/features/events/hooks/useEvents.js +1 -0
- package/dist/features/events/repository/events.repository.js +3 -0
- package/dist/features/events/schemas/firestore.d.ts +1 -0
- package/dist/features/events/schemas/index.d.ts +44 -0
- package/dist/features/events/types/index.d.ts +2 -0
- package/dist/features/faq/actions/faq-actions.d.ts +16 -16
- package/dist/features/faq/hooks/useFaqList.js +1 -1
- package/dist/features/faq/schemas/firestore.d.ts +2 -2
- package/dist/features/faq/schemas/firestore.js +2 -1
- package/dist/features/faq/schemas/index.d.ts +4 -4
- package/dist/features/filters/FilterFacetSection.d.ts +1 -0
- package/dist/features/filters/FilterFacetSection.js +13 -1
- package/dist/features/filters/SwitchFilter.js +1 -1
- package/dist/features/grouped/schemas/firestore.d.ts +32 -0
- package/dist/features/grouped/schemas/firestore.js +19 -0
- package/dist/features/homepage/components/AdSlot.d.ts +1 -3
- package/dist/features/homepage/components/AdSlot.js +15 -14
- package/dist/features/homepage/components/BlogArticlesSection.d.ts +3 -1
- package/dist/features/homepage/components/BlogArticlesSection.js +2 -2
- package/dist/features/homepage/components/BrandsSection.d.ts +3 -1
- package/dist/features/homepage/components/BrandsSection.js +4 -3
- package/dist/features/homepage/components/CustomCardsSection.d.ts +3 -0
- package/dist/features/homepage/components/CustomCardsSection.js +76 -0
- package/dist/features/homepage/components/EventsSection.d.ts +3 -1
- package/dist/features/homepage/components/EventsSection.js +2 -2
- package/dist/features/homepage/components/FeaturedAuctionsSection.d.ts +4 -1
- package/dist/features/homepage/components/FeaturedAuctionsSection.js +2 -2
- package/dist/features/homepage/components/FeaturedPreOrdersSection.d.ts +4 -1
- package/dist/features/homepage/components/FeaturedPreOrdersSection.js +2 -2
- package/dist/features/homepage/components/FeaturedProductsSection.d.ts +4 -1
- package/dist/features/homepage/components/FeaturedProductsSection.js +8 -3
- package/dist/features/homepage/components/FeaturedStoresSection.d.ts +3 -1
- package/dist/features/homepage/components/FeaturedStoresSection.js +2 -2
- package/dist/features/homepage/components/GoogleReviewsSection.d.ts +3 -0
- package/dist/features/homepage/components/GoogleReviewsSection.js +65 -0
- package/dist/features/homepage/components/HeroCarousel.js +128 -84
- package/dist/features/homepage/components/MarketplaceHomepageView.d.ts +2 -20
- package/dist/features/homepage/components/MarketplaceHomepageView.js +73 -230
- package/dist/features/homepage/components/SectionCarousel.d.ts +1 -1
- package/dist/features/homepage/components/SectionCarousel.js +2 -0
- package/dist/features/homepage/components/ShopByCategorySection.d.ts +3 -1
- package/dist/features/homepage/components/ShopByCategorySection.js +8 -4
- package/dist/features/homepage/components/SocialFeedSection.d.ts +3 -0
- package/dist/features/homepage/components/SocialFeedSection.js +86 -0
- package/dist/features/homepage/components/SocialPostCard.d.ts +7 -0
- package/dist/features/homepage/components/SocialPostCard.js +39 -0
- package/dist/features/homepage/components/StatsCounterSection.js +1 -1
- package/dist/features/homepage/components/WelcomeSection.js +1 -1
- package/dist/features/homepage/components/WhatsAppCommunitySection.js +1 -1
- package/dist/features/homepage/hooks/useActiveAd.d.ts +23 -0
- package/dist/features/homepage/hooks/useActiveAd.js +20 -0
- package/dist/features/homepage/hooks/useBlogArticles.d.ts +1 -0
- package/dist/features/homepage/hooks/useBlogArticles.js +10 -0
- package/dist/features/homepage/hooks/useFeaturedAuctions.d.ts +4 -1
- package/dist/features/homepage/hooks/useFeaturedAuctions.js +8 -4
- package/dist/features/homepage/hooks/useFeaturedPreOrders.d.ts +4 -1
- package/dist/features/homepage/hooks/useFeaturedPreOrders.js +8 -4
- package/dist/features/homepage/hooks/useFeaturedProducts.d.ts +1 -0
- package/dist/features/homepage/hooks/useFeaturedProducts.js +6 -3
- package/dist/features/homepage/hooks/useFeaturedStores.d.ts +3 -1
- package/dist/features/homepage/hooks/useFeaturedStores.js +2 -1
- package/dist/features/homepage/hooks/useHomepageEvents.d.ts +3 -1
- package/dist/features/homepage/hooks/useHomepageEvents.js +2 -1
- package/dist/features/homepage/hooks/useTopBrands.d.ts +3 -1
- package/dist/features/homepage/hooks/useTopBrands.js +2 -1
- package/dist/features/homepage/index.d.ts +2 -0
- package/dist/features/homepage/index.js +1 -0
- package/dist/features/homepage/lib/google-reviews-fetcher.d.ts +14 -0
- package/dist/features/homepage/lib/google-reviews-fetcher.js +27 -0
- package/dist/features/homepage/lib/live-stats.d.ts +14 -0
- package/dist/features/homepage/lib/live-stats.js +62 -0
- package/dist/features/homepage/lib/section-defaults.d.ts +11 -0
- package/dist/features/homepage/lib/section-defaults.js +45 -0
- package/dist/features/homepage/lib/section-helpers.d.ts +5 -0
- package/dist/features/homepage/lib/section-helpers.js +25 -0
- package/dist/features/homepage/lib/section-renderer.d.ts +33 -0
- package/dist/features/homepage/lib/section-renderer.js +164 -0
- package/dist/features/homepage/lib/social-feed-fetcher.d.ts +5 -0
- package/dist/features/homepage/lib/social-feed-fetcher.js +193 -0
- package/dist/features/homepage/schemas/firestore.d.ts +180 -29
- package/dist/features/homepage/schemas/firestore.js +5 -0
- package/dist/features/homepage/types/index.d.ts +48 -19
- package/dist/features/layout/AppLayoutShell.d.ts +6 -1
- package/dist/features/layout/AppLayoutShell.js +25 -9
- package/dist/features/layout/BottomActions.js +1 -1
- package/dist/features/layout/BottomNavbar.d.ts +15 -1
- package/dist/features/layout/BottomNavbar.js +8 -2
- package/dist/features/layout/FooterLayout.d.ts +7 -1
- package/dist/features/layout/FooterLayout.js +3 -3
- package/dist/features/layout/ListingLayout.js +2 -2
- package/dist/features/layout/MainNavbar.d.ts +6 -14
- package/dist/features/layout/MainNavbar.js +4 -16
- package/dist/features/layout/NavItem.js +1 -1
- package/dist/features/layout/NavbarLayout.d.ts +3 -1
- package/dist/features/layout/NavbarLayout.js +5 -5
- package/dist/features/layout/TitleBar.d.ts +4 -2
- package/dist/features/layout/TitleBar.js +5 -3
- package/dist/features/layout/TitleBarLayout.d.ts +3 -1
- package/dist/features/layout/TitleBarLayout.js +2 -2
- package/dist/features/layout/index.d.ts +1 -1
- package/dist/features/media/MediaPickerModal.d.ts +30 -0
- package/dist/features/media/MediaPickerModal.js +72 -0
- package/dist/features/media/index.d.ts +3 -1
- package/dist/features/media/index.js +1 -0
- package/dist/features/media/types/index.d.ts +12 -0
- package/dist/features/media/types/index.js +4 -2
- package/dist/features/media/upload/MediaUploadField.d.ts +5 -1
- package/dist/features/media/upload/MediaUploadField.js +56 -3
- package/dist/features/messages/schemas/firestore.d.ts +36 -0
- package/dist/features/messages/schemas/firestore.js +16 -0
- package/dist/features/orders/repository/orders.repository.d.ts +2 -2
- package/dist/features/orders/repository/orders.repository.js +2 -2
- package/dist/features/orders/schemas/firestore.d.ts +17 -4
- package/dist/features/orders/schemas/firestore.js +2 -2
- package/dist/features/orders/schemas/index.d.ts +18 -18
- package/dist/features/orders/schemas/index.js +3 -3
- package/dist/features/orders/types/index.d.ts +1 -1
- package/dist/features/orders/utils/order-splitter.d.ts +1 -1
- package/dist/features/orders/utils/order-splitter.js +2 -2
- package/dist/features/payments/repository/payout.repository.d.ts +4 -4
- package/dist/features/payments/repository/payout.repository.js +7 -7
- package/dist/features/payments/schemas/firestore.d.ts +6 -6
- package/dist/features/payments/schemas/firestore.js +6 -6
- package/dist/features/pre-orders/components/MarketplacePreorderCard.js +11 -10
- package/dist/features/pre-orders/components/PreOrderActionsClient.d.ts +11 -0
- package/dist/features/pre-orders/components/PreOrderActionsClient.js +28 -0
- package/dist/features/pre-orders/components/PreOrderDetailPageView.d.ts +2 -1
- package/dist/features/pre-orders/components/PreOrderDetailPageView.js +27 -9
- package/dist/features/pre-orders/components/PreOrderFilters.d.ts +3 -1
- package/dist/features/pre-orders/components/PreOrderFilters.js +9 -6
- package/dist/features/pre-orders/components/PreOrdersIndexListing.d.ts +3 -1
- package/dist/features/pre-orders/components/PreOrdersIndexListing.js +132 -36
- package/dist/features/pre-orders/components/PreOrdersListView.js +3 -3
- package/dist/features/pre-orders/components/PreorderCard.js +1 -1
- package/dist/features/pre-orders/schemas/index.d.ts +10 -0
- package/dist/features/products/actions/product-actions.d.ts +2 -2
- package/dist/features/products/actions/product-actions.js +5 -5
- package/dist/features/products/api/[id]/route.js +5 -2
- package/dist/features/products/api/route.js +10 -14
- package/dist/features/products/columns/productTableColumns.js +2 -2
- package/dist/features/products/components/AuctionDetailView.d.ts +2 -1
- package/dist/features/products/components/AuctionDetailView.js +2 -2
- package/dist/features/products/components/AuctionsIndexListing.d.ts +3 -1
- package/dist/features/products/components/AuctionsIndexListing.js +93 -31
- package/dist/features/products/components/BidHistory.d.ts +2 -1
- package/dist/features/products/components/BidHistory.js +18 -2
- package/dist/features/products/components/MakeOfferButton.d.ts +10 -0
- package/dist/features/products/components/MakeOfferButton.js +68 -0
- package/dist/features/products/components/ProductDetailPageView.d.ts +11 -1
- package/dist/features/products/components/ProductDetailPageView.js +27 -8
- package/dist/features/products/components/ProductFilters.d.ts +7 -1
- package/dist/features/products/components/ProductFilters.js +4 -2
- package/dist/features/products/components/ProductForm.d.ts +19 -1
- package/dist/features/products/components/ProductForm.js +24 -6
- package/dist/features/products/components/ProductGrid.d.ts +10 -2
- package/dist/features/products/components/ProductGrid.js +76 -29
- package/dist/features/products/components/ProductsIndexListing.js +131 -45
- package/dist/features/products/components/RelatedProductsCarousel.js +1 -1
- package/dist/features/products/components/ShareButton.d.ts +7 -0
- package/dist/features/products/components/ShareButton.js +22 -0
- package/dist/features/products/components/index.d.ts +2 -0
- package/dist/features/products/components/index.js +1 -0
- package/dist/features/products/hooks/useProducts.d.ts +7 -0
- package/dist/features/products/hooks/useProducts.js +6 -4
- package/dist/features/products/repository/products.repository.d.ts +4 -8
- package/dist/features/products/repository/products.repository.js +17 -50
- package/dist/features/products/schemas/firestore.d.ts +11 -9
- package/dist/features/products/schemas/firestore.js +11 -3
- package/dist/features/products/schemas/index.d.ts +51 -50
- package/dist/features/products/schemas/index.js +2 -5
- package/dist/features/products/types/index.d.ts +13 -5
- package/dist/features/promotions/actions/coupon-actions.d.ts +2 -2
- package/dist/features/promotions/actions/coupon-actions.js +1 -1
- package/dist/features/promotions/actions/seller-coupon-actions.js +11 -6
- package/dist/features/promotions/api/route.js +3 -3
- package/dist/features/promotions/components/CouponCard.js +16 -7
- package/dist/features/promotions/components/CouponsIndexListing.js +3 -9
- package/dist/features/promotions/hooks/useCouponValidate.d.ts +1 -1
- package/dist/features/promotions/hooks/usePromotions.js +2 -2
- package/dist/features/promotions/repository/coupons.repository.d.ts +21 -15
- package/dist/features/promotions/repository/coupons.repository.js +97 -125
- package/dist/features/promotions/schemas/firestore.d.ts +31 -2
- package/dist/features/promotions/schemas/firestore.js +29 -0
- package/dist/features/promotions/schemas/index.d.ts +9 -12
- package/dist/features/promotions/schemas/index.js +1 -2
- package/dist/features/promotions/types/index.d.ts +1 -2
- package/dist/features/reviews/actions/review-actions.js +3 -2
- package/dist/features/reviews/components/ReviewDetailPageView.js +5 -9
- package/dist/features/reviews/components/ReviewFilters.js +1 -1
- package/dist/features/reviews/components/ReviewsIndexListing.js +58 -7
- package/dist/features/reviews/components/ReviewsList.js +2 -2
- package/dist/features/reviews/hooks/useReviews.d.ts +1 -0
- package/dist/features/reviews/hooks/useReviews.js +2 -1
- package/dist/features/reviews/repository/reviews.repository.d.ts +9 -4
- package/dist/features/reviews/repository/reviews.repository.js +18 -7
- package/dist/features/reviews/schemas/firestore.d.ts +5 -2
- package/dist/features/reviews/schemas/firestore.js +1 -0
- package/dist/features/reviews/schemas/index.d.ts +19 -16
- package/dist/features/reviews/schemas/index.js +3 -2
- package/dist/features/reviews/types/index.d.ts +3 -2
- package/dist/features/scams/actions/scam-actions.d.ts +29 -0
- package/dist/features/scams/actions/scam-actions.js +62 -0
- package/dist/features/scams/components/ScamProfileView.d.ts +10 -0
- package/dist/features/scams/components/ScamProfileView.js +51 -0
- package/dist/features/scams/components/ScamRegistryView.d.ts +6 -0
- package/dist/features/scams/components/ScamRegistryView.js +41 -0
- package/dist/features/scams/components/index.d.ts +4 -0
- package/dist/features/scams/components/index.js +2 -0
- package/dist/features/scams/constants/scam-types.d.ts +38 -0
- package/dist/features/scams/constants/scam-types.js +443 -0
- package/dist/features/scams/repository/scammer.repository.d.ts +67 -0
- package/dist/features/scams/repository/scammer.repository.js +160 -0
- package/dist/features/scams/schemas/firestore.d.ts +362 -0
- package/dist/features/scams/schemas/firestore.js +233 -0
- package/dist/features/search/components/Search.d.ts +12 -2
- package/dist/features/search/components/Search.js +26 -7
- package/dist/features/search/components/index.d.ts +1 -1
- package/dist/features/search/hooks/useNavSuggestions.d.ts +1 -1
- package/dist/features/search/hooks/useNavSuggestions.js +2 -2
- package/dist/features/search/schemas/index.d.ts +7 -7
- package/dist/features/seller/actions/offer-actions.js +52 -36
- package/dist/features/seller/actions/seller-actions.js +19 -13
- package/dist/features/seller/api/products/route.js +9 -4
- package/dist/features/seller/components/SellerAddressesView.d.ts +3 -12
- package/dist/features/seller/components/SellerAddressesView.js +144 -4
- package/dist/features/seller/components/SellerAuctionsView.js +58 -5
- package/dist/features/seller/components/SellerBidsView.d.ts +4 -0
- package/dist/features/seller/components/SellerBidsView.js +131 -0
- package/dist/features/seller/components/SellerCouponEditorView.d.ts +19 -0
- package/dist/features/seller/components/SellerCouponEditorView.js +67 -0
- package/dist/features/seller/components/SellerCouponsView.d.ts +5 -3
- package/dist/features/seller/components/SellerCouponsView.js +135 -13
- package/dist/features/seller/components/SellerCreateProductView.d.ts +4 -10
- package/dist/features/seller/components/SellerCreateProductView.js +4 -3
- package/dist/features/seller/components/SellerEditProductView.d.ts +4 -10
- package/dist/features/seller/components/SellerEditProductView.js +4 -3
- package/dist/features/seller/components/SellerOffersPanel.d.ts +20 -0
- package/dist/features/seller/components/SellerOffersPanel.js +138 -0
- package/dist/features/seller/components/SellerOffersView.js +56 -5
- package/dist/features/seller/components/SellerOrdersView.d.ts +2 -1
- package/dist/features/seller/components/SellerOrdersView.js +185 -16
- package/dist/features/seller/components/SellerPayoutRequestView.d.ts +7 -0
- package/dist/features/seller/components/SellerPayoutRequestView.js +63 -0
- package/dist/features/seller/components/SellerPayoutSettingsView.d.ts +3 -10
- package/dist/features/seller/components/SellerPayoutSettingsView.js +89 -3
- package/dist/features/seller/components/SellerPayoutsView.js +56 -5
- package/dist/features/seller/components/SellerProductShell.d.ts +68 -0
- package/dist/features/seller/components/SellerProductShell.js +179 -0
- package/dist/features/seller/components/SellerProductsView.d.ts +2 -3
- package/dist/features/seller/components/SellerProductsView.js +194 -18
- package/dist/features/seller/components/SellerReviewsView.d.ts +5 -0
- package/dist/features/seller/components/SellerReviewsView.js +100 -0
- package/dist/features/seller/components/SellerShippingView.d.ts +3 -11
- package/dist/features/seller/components/SellerShippingView.js +87 -3
- package/dist/features/seller/components/SellerSidebar.d.ts +11 -3
- package/dist/features/seller/components/SellerSidebar.js +52 -8
- package/dist/features/seller/components/SellerStorefrontView.d.ts +26 -11
- package/dist/features/seller/components/SellerStorefrontView.js +45 -7
- package/dist/features/seller/components/index.d.ts +16 -2
- package/dist/features/seller/components/index.js +7 -0
- package/dist/features/seller/hooks/useSellerListingData.d.ts +3 -1
- package/dist/features/seller/hooks/useSellerListingData.js +6 -4
- package/dist/features/seller/repository/offer.repository.d.ts +3 -3
- package/dist/features/seller/repository/offer.repository.js +6 -6
- package/dist/features/seller/schemas/firestore.d.ts +7 -7
- package/dist/features/seller/schemas/firestore.js +4 -4
- package/dist/features/seller/schemas/index.d.ts +16 -16
- package/dist/features/shell/FormShell.d.ts +29 -0
- package/dist/features/shell/FormShell.js +103 -0
- package/dist/features/shell/QuickFormDrawer.d.ts +29 -0
- package/dist/features/shell/QuickFormDrawer.js +117 -0
- package/dist/features/shell/StepForm.d.ts +44 -0
- package/dist/features/shell/StepForm.js +81 -0
- package/dist/features/shell/index.d.ts +6 -0
- package/dist/features/shell/index.js +3 -0
- package/dist/features/stores/actions/store-query-actions.js +3 -3
- package/dist/features/stores/api/[storeSlug]/auctions/route.js +1 -1
- package/dist/features/stores/api/[storeSlug]/products/route.js +1 -1
- package/dist/features/stores/api/[storeSlug]/reviews/route.js +1 -1
- package/dist/features/stores/components/InteractiveStoreCard.d.ts +2 -2
- package/dist/features/stores/components/InteractiveStoreCard.js +21 -7
- package/dist/features/stores/components/StoreAboutView.js +1 -1
- package/dist/features/stores/components/StoreAuctionsListing.d.ts +5 -2
- package/dist/features/stores/components/StoreAuctionsListing.js +81 -8
- package/dist/features/stores/components/StoreAuctionsPageView.js +8 -7
- package/dist/features/stores/components/StoreDetailLayoutView.d.ts +1 -0
- package/dist/features/stores/components/StoreDetailLayoutView.js +29 -5
- package/dist/features/stores/components/StoreHeader.js +2 -1
- package/dist/features/stores/components/StorePreOrdersListing.d.ts +4 -2
- package/dist/features/stores/components/StorePreOrdersListing.js +59 -7
- package/dist/features/stores/components/StorePreOrdersPageView.js +8 -7
- package/dist/features/stores/components/StoreProductsListing.d.ts +5 -2
- package/dist/features/stores/components/StoreProductsListing.js +97 -8
- package/dist/features/stores/components/StoreProductsPageView.js +8 -7
- package/dist/features/stores/components/StoreReviewsListing.js +2 -2
- package/dist/features/stores/components/StoresIndexListing.js +74 -11
- package/dist/features/stores/components/StoresListView.js +1 -1
- package/dist/features/stores/hooks/useStores.d.ts +1 -0
- package/dist/features/stores/hooks/useStores.js +1 -0
- package/dist/features/stores/schemas/firestore.d.ts +34 -0
- package/dist/features/stores/schemas/index.d.ts +8 -8
- package/dist/features/sublisting/schemas/firestore.d.ts +30 -0
- package/dist/features/sublisting/schemas/firestore.js +19 -0
- package/dist/features/support/schemas/firestore.d.ts +113 -0
- package/dist/features/support/schemas/firestore.js +95 -0
- package/dist/features/whatsapp-bot/components/SellerWhatsAppSettingsView.d.ts +5 -0
- package/dist/features/whatsapp-bot/components/SellerWhatsAppSettingsView.js +143 -0
- package/dist/features/whatsapp-bot/components/index.d.ts +2 -0
- package/dist/features/whatsapp-bot/components/index.js +1 -0
- package/dist/features/whatsapp-bot/helpers/whatsapp.d.ts +23 -1
- package/dist/features/whatsapp-bot/helpers/whatsapp.js +104 -0
- package/dist/features/whatsapp-bot/server.d.ts +1 -0
- package/dist/features/whatsapp-bot/server.js +1 -0
- package/dist/features/whatsapp-bot/types/index.d.ts +49 -0
- package/dist/features/wishlist/components/WishlistView.d.ts +0 -10
- package/dist/features/wishlist/components/WishlistView.js +13 -6
- package/dist/features/wishlist/hooks/useWishlist.js +2 -0
- package/dist/features/wishlist/hooks/useWishlistCount.d.ts +11 -3
- package/dist/features/wishlist/hooks/useWishlistCount.js +89 -25
- package/dist/features/wishlist/hooks/useWishlistWithGuest.d.ts +1 -1
- package/dist/features/wishlist/schemas/index.d.ts +2 -2
- package/dist/features/wishlist/types/index.d.ts +16 -0
- package/dist/http/api-handler.js +8 -1
- package/dist/index.d.ts +114 -16
- package/dist/index.js +136 -28
- package/dist/monitoring/server-logger.js +9 -3
- package/dist/next/routing/route-map.d.ts +120 -6
- package/dist/next/routing/route-map.js +53 -2
- package/dist/providers/db-firebase/realtime.d.ts +1 -1
- package/dist/react/contexts/SessionContext.js +17 -26
- package/dist/react/hooks/useBulkSelection.d.ts +7 -24
- package/dist/react/hooks/useBulkSelection.js +27 -34
- package/dist/react/hooks/useLongPress.d.ts +3 -16
- package/dist/react/hooks/useLongPress.js +6 -25
- package/dist/react/index.d.ts +1 -0
- package/dist/react/index.js +2 -0
- package/dist/repositories/index.d.ts +3 -0
- package/dist/repositories/index.js +2 -0
- package/dist/seed/actions/demo-seed-actions.d.ts +2 -2
- package/dist/seed/actions/demo-seed-actions.js +1 -1
- package/dist/seed/anime-figures-seed-data.d.ts +8 -0
- package/dist/seed/anime-figures-seed-data.js +1033 -0
- package/dist/seed/beyblade-seed-data.js +206 -24
- package/dist/seed/bids-seed-data.d.ts +4 -10
- package/dist/seed/bids-seed-data.js +365 -238
- package/dist/seed/blog-posts-seed-data.d.ts +3 -2
- package/dist/seed/blog-posts-seed-data.js +250 -511
- package/dist/seed/brands-seed-data.d.ts +7 -0
- package/dist/seed/brands-seed-data.js +410 -0
- package/dist/seed/carousel-slides-seed-data.d.ts +3 -2
- package/dist/seed/carousel-slides-seed-data.js +177 -216
- package/dist/seed/cart-seed-data.d.ts +9 -9
- package/dist/seed/cart-seed-data.js +73 -73
- package/dist/seed/categories-seed-data.d.ts +4 -2
- package/dist/seed/categories-seed-data.js +720 -879
- package/dist/seed/conversations-seed-data.d.ts +8 -0
- package/dist/seed/conversations-seed-data.js +388 -0
- package/dist/seed/cosplay-accessories-seed-data.d.ts +8 -0
- package/dist/seed/cosplay-accessories-seed-data.js +647 -0
- package/dist/seed/coupon-usage-seed-data.d.ts +25 -0
- package/dist/seed/coupon-usage-seed-data.js +69 -0
- package/dist/seed/coupons-seed-data.d.ts +6 -3
- package/dist/seed/coupons-seed-data.js +375 -3
- package/dist/seed/events-seed-data.d.ts +4 -2
- package/dist/seed/events-seed-data.js +128 -430
- package/dist/seed/factories/cart.factory.d.ts +0 -1
- package/dist/seed/factories/cart.factory.js +2 -2
- package/dist/seed/faq-seed-data.d.ts +11 -18
- package/dist/seed/faq-seed-data.js +786 -1817
- package/dist/seed/grouped-listings-seed-data.d.ts +8 -0
- package/dist/seed/grouped-listings-seed-data.js +201 -0
- package/dist/seed/homepage-sections-seed-data.d.ts +3 -13
- package/dist/seed/homepage-sections-seed-data.js +228 -252
- package/dist/seed/hot-wheels-seed-data.js +285 -38
- package/dist/seed/index.d.ts +12 -11
- package/dist/seed/index.js +10 -12
- package/dist/seed/letitrip-official-seed-data.d.ts +8 -0
- package/dist/seed/letitrip-official-seed-data.js +399 -0
- package/dist/seed/manifest.d.ts +15 -0
- package/dist/seed/manifest.js +140 -0
- package/dist/seed/notifications-seed-data.d.ts +4 -2
- package/dist/seed/notifications-seed-data.js +117 -440
- package/dist/seed/orders-seed-data.d.ts +4 -2
- package/dist/seed/orders-seed-data.js +1090 -521
- package/dist/seed/payouts-seed-data.d.ts +4 -2
- package/dist/seed/payouts-seed-data.js +522 -145
- package/dist/seed/pokemon-carousel-slides-seed-data.js +6 -1
- package/dist/seed/pokemon-categories-seed-data.js +81 -81
- package/dist/seed/pokemon-homepage-sections-seed-data.d.ts +1 -1
- package/dist/seed/pokemon-homepage-sections-seed-data.js +116 -23
- package/dist/seed/pokemon-products-seed-data.d.ts +1 -1
- package/dist/seed/pokemon-products-seed-data.js +83 -73
- package/dist/seed/pokemon-seed-bundle.d.ts +5 -1
- package/dist/seed/pokemon-seed-bundle.js +21 -2
- package/dist/seed/pokemon-stores-seed-data.js +85 -9
- package/dist/seed/pokemon-users-seed-data.js +107 -8
- package/dist/seed/products-auctions-seed-data.d.ts +10 -0
- package/dist/seed/products-auctions-seed-data.js +689 -0
- package/dist/seed/products-preorders-seed-data.d.ts +9 -0
- package/dist/seed/products-preorders-seed-data.js +483 -0
- package/dist/seed/products-seed-data.js +34 -13
- package/dist/seed/products-standard-seed-data.d.ts +8 -0
- package/dist/seed/products-standard-seed-data.js +4179 -0
- package/dist/seed/retro-gaming-seed-data.d.ts +8 -0
- package/dist/seed/retro-gaming-seed-data.js +801 -0
- package/dist/seed/reviews-seed-data.d.ts +4 -17
- package/dist/seed/reviews-seed-data.js +1043 -515
- package/dist/seed/scammers-seed-data.d.ts +17 -0
- package/dist/seed/scammers-seed-data.js +118 -0
- package/dist/seed/site-settings-seed-data.js +25 -2
- package/dist/seed/store-addresses-seed-data.js +188 -84
- package/dist/seed/stores-seed-data.d.ts +3 -9
- package/dist/seed/stores-seed-data.js +212 -102
- package/dist/seed/sublisting-categories-seed-data.d.ts +7 -0
- package/dist/seed/sublisting-categories-seed-data.js +315 -0
- package/dist/seed/transformers-seed-data.js +34 -14
- package/dist/seed/users-seed-data.d.ts +3 -2
- package/dist/seed/users-seed-data.js +531 -440
- package/dist/seed/wishlists-seed-data.js +13 -13
- package/dist/server.d.ts +9 -2
- package/dist/server.js +12 -4
- package/dist/tokens/tokens.css +76 -31
- package/dist/ui/components/Avatar.style.css +10 -12
- package/dist/ui/components/BaseListingCard.d.ts +8 -3
- package/dist/ui/components/BaseListingCard.js +17 -6
- package/dist/ui/components/BaseListingCard.style.css +3 -1
- package/dist/ui/components/BulkActionsBar.d.ts +16 -0
- package/dist/ui/components/BulkActionsBar.js +22 -0
- package/dist/ui/components/Button.style.css +23 -23
- package/dist/ui/components/Card.style.css +60 -62
- package/dist/ui/components/Checkbox.style.css +19 -21
- package/dist/ui/components/DashboardStatsCard.style.css +12 -14
- package/dist/ui/components/Drawer.style.css +18 -14
- package/dist/ui/components/Dropdown.style.css +25 -27
- package/dist/ui/components/EmptyState.style.css +2 -4
- package/dist/ui/components/HorizontalScroller.d.ts +3 -1
- package/dist/ui/components/HorizontalScroller.js +116 -21
- package/dist/ui/components/HorizontalScroller.style.css +2 -2
- package/dist/ui/components/ImageLightbox.d.ts +0 -9
- package/dist/ui/components/ImageLightbox.js +43 -9
- package/dist/ui/components/InlineCreateSelect.d.ts +38 -0
- package/dist/ui/components/InlineCreateSelect.js +70 -0
- package/dist/ui/components/ListingLayout.style.css +41 -77
- package/dist/ui/components/ListingToolbar.d.ts +54 -0
- package/dist/ui/components/ListingToolbar.js +34 -0
- package/dist/ui/components/Modal.style.css +14 -10
- package/dist/ui/components/PageLoader.d.ts +11 -0
- package/dist/ui/components/PageLoader.js +21 -0
- package/dist/ui/components/Radio.style.css +34 -36
- package/dist/ui/components/RichTextEditor.js +1 -1
- package/dist/ui/components/RowActionMenu.d.ts +1 -0
- package/dist/ui/components/RowActionMenu.js +4 -2
- package/dist/ui/components/SectionTabs.js +1 -1
- package/dist/ui/components/SectionTabs.style.css +1 -0
- package/dist/ui/components/SideModal.style.css +4 -8
- package/dist/ui/components/Slider.style.css +2 -4
- package/dist/ui/components/Tabs.style.css +8 -10
- package/dist/ui/components/Toast.style.css +22 -24
- package/dist/ui/components/Toggle.style.css +11 -13
- package/dist/ui/index.d.ts +9 -0
- package/dist/ui/index.js +5 -0
- package/dist/ui/rich-text/RichText.js +2 -1
- package/dist/ui/rich-text/RichText.style.css +292 -5
- package/dist/ui/rich-text/RichTextRenderer.d.ts +15 -0
- package/dist/ui/rich-text/RichTextRenderer.js +15 -0
- package/dist/utils/id-generators.d.ts +10 -0
- package/dist/utils/id-generators.js +12 -0
- package/dist/validation/schemas.d.ts +9 -9
- package/package.json +5 -1
- package/README.md +0 -116
|
@@ -7,29 +7,29 @@
|
|
|
7
7
|
|
|
8
8
|
/* Variants */
|
|
9
9
|
.appkit-card--flat {
|
|
10
|
-
background:
|
|
10
|
+
background: var(--appkit-color-surface, #ffffff);
|
|
11
11
|
}
|
|
12
12
|
.appkit-card--default {
|
|
13
|
-
background:
|
|
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:
|
|
20
|
+
background: var(--appkit-color-surface, #ffffff);
|
|
21
21
|
border: 1px solid #e4e4e7;
|
|
22
22
|
}
|
|
23
23
|
.appkit-card--bordered {
|
|
24
|
-
background:
|
|
24
|
+
background: var(--appkit-color-surface, #ffffff);
|
|
25
25
|
border: 2px solid #e4e4e7;
|
|
26
26
|
}
|
|
27
27
|
.appkit-card--elevated {
|
|
28
|
-
background:
|
|
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:
|
|
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
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
.
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
.
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
.
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
.
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
.
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
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
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
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
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
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
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
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
|
}
|
|
@@ -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(() =>
|
|
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,
|
|
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;
|
|
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
|
-
//
|
|
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
|
-
? {
|
|
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:
|
|
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:
|
|
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, #
|
|
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, #
|
|
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;
|