@mohasinac/appkit 2.4.11 → 2.5.0
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/_internal/client/features/products/index.d.ts +1 -0
- package/dist/_internal/client/features/products/index.js +3 -0
- package/dist/_internal/client/i18n/LabelsProvider.d.ts +13 -0
- package/dist/_internal/client/i18n/LabelsProvider.js +38 -0
- package/dist/_internal/client/index.d.ts +0 -0
- package/dist/_internal/client/index.js +4 -0
- package/dist/_internal/client/scaffolds/AppShell.d.ts +39 -0
- package/dist/_internal/client/scaffolds/AppShell.js +9 -0
- package/dist/_internal/client/scaffolds/DashboardScaffold.d.ts +34 -0
- package/dist/_internal/client/scaffolds/DashboardScaffold.js +23 -0
- package/dist/_internal/client/scaffolds/index.d.ts +4 -0
- package/dist/_internal/client/scaffolds/index.js +2 -0
- package/dist/_internal/server/features/account/actions.d.ts +7 -0
- package/dist/_internal/server/features/account/actions.js +7 -0
- package/dist/_internal/server/features/account/data.d.ts +17 -0
- package/dist/_internal/server/features/account/data.js +25 -0
- package/dist/_internal/server/features/account/index.d.ts +2 -0
- package/dist/_internal/server/features/account/index.js +2 -0
- package/dist/_internal/server/features/auctions/actions.d.ts +1 -0
- package/dist/_internal/server/features/auctions/actions.js +44 -0
- package/dist/_internal/server/features/auctions/data.d.ts +4 -0
- package/dist/_internal/server/features/auctions/data.js +9 -0
- package/dist/_internal/server/features/auctions/index.d.ts +5 -0
- package/dist/_internal/server/features/auctions/index.js +5 -0
- package/dist/_internal/server/features/auctions/og.d.ts +19 -0
- package/dist/_internal/server/features/auctions/og.js +51 -0
- package/dist/_internal/server/features/auctions/service.d.ts +13 -0
- package/dist/_internal/server/features/auctions/service.js +57 -0
- package/dist/_internal/server/features/auth/actions.d.ts +8 -0
- package/dist/_internal/server/features/auth/actions.js +8 -0
- package/dist/_internal/server/features/auth/index.d.ts +1 -0
- package/dist/_internal/server/features/auth/index.js +1 -0
- package/dist/_internal/server/features/blog/actions.d.ts +5 -0
- package/dist/_internal/server/features/blog/actions.js +51 -0
- package/dist/_internal/server/features/blog/data.d.ts +2 -0
- package/dist/_internal/server/features/blog/data.js +8 -0
- package/dist/_internal/server/features/blog/index.d.ts +5 -0
- package/dist/_internal/server/features/blog/index.js +5 -0
- package/dist/_internal/server/features/blog/og.d.ts +23 -0
- package/dist/_internal/server/features/blog/og.js +64 -0
- package/dist/_internal/server/features/blog/service.d.ts +3 -0
- package/dist/_internal/server/features/blog/service.js +18 -0
- package/dist/_internal/server/features/brands/actions.d.ts +4 -0
- package/dist/_internal/server/features/brands/actions.js +32 -0
- package/dist/_internal/server/features/brands/data.d.ts +12 -0
- package/dist/_internal/server/features/brands/data.js +16 -0
- package/dist/_internal/server/features/brands/index.d.ts +5 -0
- package/dist/_internal/server/features/brands/index.js +5 -0
- package/dist/_internal/server/features/brands/og.d.ts +17 -0
- package/dist/_internal/server/features/brands/og.js +37 -0
- package/dist/_internal/server/features/brands/service.d.ts +3 -0
- package/dist/_internal/server/features/brands/service.js +14 -0
- package/dist/_internal/server/features/bundles/data.d.ts +9 -0
- package/dist/_internal/server/features/bundles/data.js +9 -0
- package/dist/_internal/server/features/bundles/index.d.ts +2 -0
- package/dist/_internal/server/features/bundles/index.js +2 -0
- package/dist/_internal/server/features/cart/actions.d.ts +12 -0
- package/dist/_internal/server/features/cart/actions.js +35 -0
- package/dist/_internal/server/features/cart/data.d.ts +1 -0
- package/dist/_internal/server/features/cart/data.js +5 -0
- package/dist/_internal/server/features/cart/index.d.ts +4 -0
- package/dist/_internal/server/features/cart/index.js +4 -0
- package/dist/_internal/server/features/cart/service.d.ts +8 -0
- package/dist/_internal/server/features/cart/service.js +25 -0
- package/dist/_internal/server/features/categories/data.d.ts +13 -0
- package/dist/_internal/server/features/categories/data.js +40 -0
- package/dist/_internal/server/features/categories/index.d.ts +2 -0
- package/dist/_internal/server/features/categories/index.js +2 -0
- package/dist/_internal/server/features/checkout/actions.d.ts +35 -0
- package/dist/_internal/server/features/checkout/actions.js +327 -0
- package/dist/_internal/server/features/checkout/data.d.ts +13 -0
- package/dist/_internal/server/features/checkout/data.js +13 -0
- package/dist/_internal/server/features/checkout/index.d.ts +3 -0
- package/dist/_internal/server/features/checkout/index.js +3 -0
- package/dist/_internal/server/features/events/actions.d.ts +4 -0
- package/dist/_internal/server/features/events/actions.js +60 -0
- package/dist/_internal/server/features/events/data.d.ts +1 -0
- package/dist/_internal/server/features/events/data.js +5 -0
- package/dist/_internal/server/features/events/index.d.ts +5 -0
- package/dist/_internal/server/features/events/index.js +5 -0
- package/dist/_internal/server/features/events/og.d.ts +26 -0
- package/dist/_internal/server/features/events/og.js +87 -0
- package/dist/_internal/server/features/events/service.d.ts +2 -0
- package/dist/_internal/server/features/events/service.js +27 -0
- package/dist/_internal/server/features/grouped/data.d.ts +25 -0
- package/dist/_internal/server/features/grouped/data.js +116 -0
- package/dist/_internal/server/features/grouped/index.d.ts +2 -0
- package/dist/_internal/server/features/grouped/index.js +2 -0
- package/dist/_internal/server/features/history/actions.d.ts +8 -0
- package/dist/_internal/server/features/history/actions.js +15 -0
- package/dist/_internal/server/features/history/data.d.ts +7 -0
- package/dist/_internal/server/features/history/data.js +6 -0
- package/dist/_internal/server/features/history/index.d.ts +3 -0
- package/dist/_internal/server/features/history/index.js +3 -0
- package/dist/_internal/server/features/homepage/data.d.ts +18 -0
- package/dist/_internal/server/features/homepage/data.js +39 -0
- package/dist/_internal/server/features/homepage/index.d.ts +2 -0
- package/dist/_internal/server/features/homepage/index.js +2 -0
- package/dist/_internal/server/features/messages/actions.d.ts +6 -0
- package/dist/_internal/server/features/messages/actions.js +6 -0
- package/dist/_internal/server/features/messages/data.d.ts +10 -0
- package/dist/_internal/server/features/messages/data.js +24 -0
- package/dist/_internal/server/features/messages/index.d.ts +2 -0
- package/dist/_internal/server/features/messages/index.js +2 -0
- package/dist/_internal/server/features/orders/actions.d.ts +4 -0
- package/dist/_internal/server/features/orders/actions.js +50 -0
- package/dist/_internal/server/features/orders/adapters.d.ts +3 -0
- package/dist/_internal/server/features/orders/adapters.js +56 -0
- package/dist/_internal/server/features/orders/data.d.ts +10 -0
- package/dist/_internal/server/features/orders/data.js +18 -0
- package/dist/_internal/server/features/orders/index.d.ts +5 -0
- package/dist/_internal/server/features/orders/index.js +5 -0
- package/dist/_internal/server/features/orders/service.d.ts +4 -0
- package/dist/_internal/server/features/orders/service.js +30 -0
- package/dist/_internal/server/features/payments/actions.d.ts +30 -0
- package/dist/_internal/server/features/payments/actions.js +45 -0
- package/dist/_internal/server/features/payments/data.d.ts +11 -0
- package/dist/_internal/server/features/payments/data.js +14 -0
- package/dist/_internal/server/features/payments/index.d.ts +3 -0
- package/dist/_internal/server/features/payments/index.js +3 -0
- package/dist/_internal/server/features/pre-orders/actions.d.ts +7 -0
- package/dist/_internal/server/features/pre-orders/actions.js +26 -0
- package/dist/_internal/server/features/pre-orders/data.d.ts +4 -0
- package/dist/_internal/server/features/pre-orders/data.js +9 -0
- package/dist/_internal/server/features/pre-orders/index.d.ts +5 -0
- package/dist/_internal/server/features/pre-orders/index.js +5 -0
- package/dist/_internal/server/features/pre-orders/og.d.ts +19 -0
- package/dist/_internal/server/features/pre-orders/og.js +49 -0
- package/dist/_internal/server/features/pre-orders/service.d.ts +7 -0
- package/dist/_internal/server/features/pre-orders/service.js +30 -0
- package/dist/_internal/server/features/products/actions.d.ts +7 -0
- package/dist/_internal/server/features/products/actions.js +74 -0
- package/dist/_internal/server/features/products/data.d.ts +14 -0
- package/dist/_internal/server/features/products/data.js +48 -0
- package/dist/_internal/server/features/products/index.d.ts +5 -0
- package/dist/_internal/server/features/products/index.js +5 -0
- package/dist/_internal/server/features/products/og.d.ts +19 -0
- package/dist/_internal/server/features/products/og.js +43 -0
- package/dist/_internal/server/features/products/service.d.ts +11 -0
- package/dist/_internal/server/features/products/service.js +55 -0
- package/dist/_internal/server/features/profile/index.d.ts +1 -0
- package/dist/_internal/server/features/profile/index.js +1 -0
- package/dist/_internal/server/features/profile/og.d.ts +26 -0
- package/dist/_internal/server/features/profile/og.js +91 -0
- package/dist/_internal/server/features/promotions/actions.d.ts +9 -0
- package/dist/_internal/server/features/promotions/actions.js +38 -0
- package/dist/_internal/server/features/promotions/data.d.ts +1 -0
- package/dist/_internal/server/features/promotions/data.js +5 -0
- package/dist/_internal/server/features/promotions/index.d.ts +4 -0
- package/dist/_internal/server/features/promotions/index.js +4 -0
- package/dist/_internal/server/features/promotions/service.d.ts +3 -0
- package/dist/_internal/server/features/promotions/service.js +47 -0
- package/dist/_internal/server/features/reviews/actions.d.ts +4 -0
- package/dist/_internal/server/features/reviews/actions.js +66 -0
- package/dist/_internal/server/features/reviews/data.d.ts +10 -0
- package/dist/_internal/server/features/reviews/data.js +18 -0
- package/dist/_internal/server/features/reviews/index.d.ts +3 -0
- package/dist/_internal/server/features/reviews/index.js +3 -0
- package/dist/_internal/server/features/reviews/service.d.ts +5 -0
- package/dist/_internal/server/features/reviews/service.js +27 -0
- package/dist/_internal/server/features/scams/data.d.ts +10 -0
- package/dist/_internal/server/features/scams/data.js +22 -0
- package/dist/_internal/server/features/scams/index.d.ts +1 -0
- package/dist/_internal/server/features/scams/index.js +1 -0
- package/dist/_internal/server/features/search/actions.d.ts +15 -0
- package/dist/_internal/server/features/search/actions.js +18 -0
- package/dist/_internal/server/features/search/data.d.ts +15 -0
- package/dist/_internal/server/features/search/data.js +18 -0
- package/dist/_internal/server/features/search/index.d.ts +3 -0
- package/dist/_internal/server/features/search/index.js +2 -0
- package/dist/_internal/server/features/stores/data.d.ts +31 -0
- package/dist/_internal/server/features/stores/data.js +58 -0
- package/dist/_internal/server/features/stores/index.d.ts +3 -0
- package/dist/_internal/server/features/stores/index.js +3 -0
- package/dist/_internal/server/features/stores/og.d.ts +19 -0
- package/dist/_internal/server/features/stores/og.js +52 -0
- package/dist/_internal/server/features/sublisting-categories/data.d.ts +1 -0
- package/dist/_internal/server/features/sublisting-categories/data.js +5 -0
- package/dist/_internal/server/features/sublisting-categories/index.d.ts +2 -0
- package/dist/_internal/server/features/sublisting-categories/index.js +2 -0
- package/dist/_internal/server/features/sublisting-categories/og.d.ts +20 -0
- package/dist/_internal/server/features/sublisting-categories/og.js +56 -0
- package/dist/_internal/server/features/wishlist/actions.d.ts +13 -0
- package/dist/_internal/server/features/wishlist/actions.js +40 -0
- package/dist/_internal/server/features/wishlist/data.d.ts +8 -0
- package/dist/_internal/server/features/wishlist/data.js +9 -0
- package/dist/_internal/server/features/wishlist/index.d.ts +4 -0
- package/dist/_internal/server/features/wishlist/index.js +4 -0
- package/dist/_internal/server/index.d.ts +0 -0
- package/dist/_internal/server/index.js +4 -0
- package/dist/_internal/server/jobs/handlers/_helpers.d.ts +8 -0
- package/dist/_internal/server/jobs/handlers/_helpers.js +19 -0
- package/dist/_internal/server/jobs/handlers/adminAnalytics.d.ts +28 -0
- package/dist/_internal/server/jobs/handlers/adminAnalytics.js +98 -0
- package/dist/_internal/server/jobs/handlers/auctionSettlement.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/auctionSettlement.js +70 -0
- package/dist/_internal/server/jobs/handlers/autoPayoutEligibility.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/autoPayoutEligibility.js +110 -0
- package/dist/_internal/server/jobs/handlers/cartPrune.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/cartPrune.js +13 -0
- package/dist/_internal/server/jobs/handlers/cleanupRtdbEvents.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/cleanupRtdbEvents.js +45 -0
- package/dist/_internal/server/jobs/handlers/countersReconcile.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/countersReconcile.js +109 -0
- package/dist/_internal/server/jobs/handlers/couponExpiry.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/couponExpiry.js +13 -0
- package/dist/_internal/server/jobs/handlers/dailyDataCleanup.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/dailyDataCleanup.js +20 -0
- package/dist/_internal/server/jobs/handlers/index.d.ts +35 -0
- package/dist/_internal/server/jobs/handlers/index.js +35 -0
- package/dist/_internal/server/jobs/handlers/listingProcessor.d.ts +30 -0
- package/dist/_internal/server/jobs/handlers/listingProcessor.js +128 -0
- package/dist/_internal/server/jobs/handlers/mediaTmpCleanup.d.ts +14 -0
- package/dist/_internal/server/jobs/handlers/mediaTmpCleanup.js +69 -0
- package/dist/_internal/server/jobs/handlers/messages.d.ts +45 -0
- package/dist/_internal/server/jobs/handlers/messages.js +45 -0
- package/dist/_internal/server/jobs/handlers/notificationPrune.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/notificationPrune.js +13 -0
- package/dist/_internal/server/jobs/handlers/offerExpiry.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/offerExpiry.js +50 -0
- package/dist/_internal/server/jobs/handlers/onBidPlaced.d.ts +12 -0
- package/dist/_internal/server/jobs/handlers/onBidPlaced.js +63 -0
- package/dist/_internal/server/jobs/handlers/onCategoryWrite.d.ts +10 -0
- package/dist/_internal/server/jobs/handlers/onCategoryWrite.js +136 -0
- package/dist/_internal/server/jobs/handlers/onOrderCreate.d.ts +14 -0
- package/dist/_internal/server/jobs/handlers/onOrderCreate.js +83 -0
- package/dist/_internal/server/jobs/handlers/onOrderStatusChange.d.ts +14 -0
- package/dist/_internal/server/jobs/handlers/onOrderStatusChange.js +141 -0
- package/dist/_internal/server/jobs/handlers/onProductWrite.d.ts +8 -0
- package/dist/_internal/server/jobs/handlers/onProductWrite.js +92 -0
- package/dist/_internal/server/jobs/handlers/onReviewWrite.d.ts +2 -0
- package/dist/_internal/server/jobs/handlers/onReviewWrite.js +51 -0
- package/dist/_internal/server/jobs/handlers/onStoreWrite.d.ts +10 -0
- package/dist/_internal/server/jobs/handlers/onStoreWrite.js +9 -0
- package/dist/_internal/server/jobs/handlers/payoutBatch.d.ts +11 -0
- package/dist/_internal/server/jobs/handlers/payoutBatch.js +104 -0
- package/dist/_internal/server/jobs/handlers/pendingOrderTimeout.d.ts +8 -0
- package/dist/_internal/server/jobs/handlers/pendingOrderTimeout.js +33 -0
- package/dist/_internal/server/jobs/handlers/positionsReconcile.d.ts +7 -0
- package/dist/_internal/server/jobs/handlers/positionsReconcile.js +87 -0
- package/dist/_internal/server/jobs/handlers/productStatsSync.d.ts +8 -0
- package/dist/_internal/server/jobs/handlers/productStatsSync.js +36 -0
- package/dist/_internal/server/jobs/handlers/promotions.d.ts +12 -0
- package/dist/_internal/server/jobs/handlers/promotions.js +43 -0
- package/dist/_internal/server/jobs/handlers/storeAnalytics.d.ts +30 -0
- package/dist/_internal/server/jobs/handlers/storeAnalytics.js +109 -0
- package/dist/_internal/server/jobs/handlers/weeklyPayoutEligibility.d.ts +8 -0
- package/dist/_internal/server/jobs/handlers/weeklyPayoutEligibility.js +87 -0
- package/dist/_internal/server/jobs/index.d.ts +4 -0
- package/dist/_internal/server/jobs/index.js +3 -0
- package/dist/_internal/server/jobs/runtime/adapters/firebase.d.ts +50 -0
- package/dist/_internal/server/jobs/runtime/adapters/firebase.js +156 -0
- package/dist/_internal/server/jobs/runtime/types.d.ts +52 -0
- package/dist/_internal/server/jobs/runtime/types.js +13 -0
- package/dist/_internal/shared/config/index.d.ts +1 -0
- package/dist/_internal/shared/config/index.js +1 -0
- package/dist/_internal/shared/config/schema.d.ts +82 -0
- package/dist/_internal/shared/config/schema.js +1 -0
- package/dist/_internal/shared/constants/index.d.ts +1 -0
- package/dist/_internal/shared/constants/index.js +1 -0
- package/dist/_internal/shared/errors/index.d.ts +24 -0
- package/dist/_internal/shared/errors/index.js +46 -0
- package/dist/_internal/shared/features/auctions/config.d.ts +6 -0
- package/dist/_internal/shared/features/auctions/config.js +6 -0
- package/dist/_internal/shared/features/auctions/errors.d.ts +16 -0
- package/dist/_internal/shared/features/auctions/errors.js +31 -0
- package/dist/_internal/shared/features/auctions/schema.d.ts +30 -0
- package/dist/_internal/shared/features/auctions/schema.js +12 -0
- package/dist/_internal/shared/features/blog/config.d.ts +6 -0
- package/dist/_internal/shared/features/blog/config.js +6 -0
- package/dist/_internal/shared/features/blog/errors.d.ts +10 -0
- package/dist/_internal/shared/features/blog/errors.js +19 -0
- package/dist/_internal/shared/features/blog/schema.d.ts +81 -0
- package/dist/_internal/shared/features/blog/schema.js +17 -0
- package/dist/_internal/shared/features/brands/config.d.ts +4 -0
- package/dist/_internal/shared/features/brands/config.js +4 -0
- package/dist/_internal/shared/features/brands/errors.d.ts +7 -0
- package/dist/_internal/shared/features/brands/errors.js +13 -0
- package/dist/_internal/shared/features/brands/schema.d.ts +69 -0
- package/dist/_internal/shared/features/brands/schema.js +15 -0
- package/dist/_internal/shared/features/bundles/config.d.ts +6 -0
- package/dist/_internal/shared/features/bundles/config.js +6 -0
- package/dist/_internal/shared/features/cart/config.d.ts +3 -0
- package/dist/_internal/shared/features/cart/config.js +3 -0
- package/dist/_internal/shared/features/cart/errors.d.ts +10 -0
- package/dist/_internal/shared/features/cart/errors.js +19 -0
- package/dist/_internal/shared/features/cart/schema.d.ts +132 -0
- package/dist/_internal/shared/features/cart/schema.js +33 -0
- package/dist/_internal/shared/features/categories/config.d.ts +6 -0
- package/dist/_internal/shared/features/categories/config.js +6 -0
- package/dist/_internal/shared/features/checkout/config.d.ts +8 -0
- package/dist/_internal/shared/features/checkout/config.js +7 -0
- package/dist/_internal/shared/features/events/config.d.ts +5 -0
- package/dist/_internal/shared/features/events/config.js +5 -0
- package/dist/_internal/shared/features/events/errors.d.ts +16 -0
- package/dist/_internal/shared/features/events/errors.js +31 -0
- package/dist/_internal/shared/features/events/schema.d.ts +91 -0
- package/dist/_internal/shared/features/events/schema.js +21 -0
- package/dist/_internal/shared/features/grouped/config.d.ts +3 -0
- package/dist/_internal/shared/features/grouped/config.js +3 -0
- package/dist/_internal/shared/features/history/config.d.ts +2 -0
- package/dist/_internal/shared/features/history/config.js +2 -0
- package/dist/_internal/shared/features/homepage/config.d.ts +3 -0
- package/dist/_internal/shared/features/homepage/config.js +3 -0
- package/dist/_internal/shared/features/orders/config.d.ts +8 -0
- package/dist/_internal/shared/features/orders/config.js +8 -0
- package/dist/_internal/shared/features/orders/errors.d.ts +13 -0
- package/dist/_internal/shared/features/orders/errors.js +25 -0
- package/dist/_internal/shared/features/orders/schema.d.ts +114 -0
- package/dist/_internal/shared/features/orders/schema.js +33 -0
- package/dist/_internal/shared/features/payments/config.d.ts +2 -0
- package/dist/_internal/shared/features/payments/config.js +2 -0
- package/dist/_internal/shared/features/pre-orders/config.d.ts +4 -0
- package/dist/_internal/shared/features/pre-orders/config.js +4 -0
- package/dist/_internal/shared/features/pre-orders/errors.d.ts +13 -0
- package/dist/_internal/shared/features/pre-orders/errors.js +25 -0
- package/dist/_internal/shared/features/pre-orders/schema.d.ts +25 -0
- package/dist/_internal/shared/features/pre-orders/schema.js +10 -0
- package/dist/_internal/shared/features/products/config.d.ts +5 -0
- package/dist/_internal/shared/features/products/config.js +5 -0
- package/dist/_internal/shared/features/products/errors.d.ts +16 -0
- package/dist/_internal/shared/features/products/errors.js +31 -0
- package/dist/_internal/shared/features/products/schema.d.ts +364 -0
- package/dist/_internal/shared/features/products/schema.js +58 -0
- package/dist/_internal/shared/features/products/types.d.ts +46 -0
- package/dist/_internal/shared/features/products/types.js +1 -0
- package/dist/_internal/shared/features/promotions/config.d.ts +3 -0
- package/dist/_internal/shared/features/promotions/config.js +3 -0
- package/dist/_internal/shared/features/promotions/errors.d.ts +19 -0
- package/dist/_internal/shared/features/promotions/errors.js +37 -0
- package/dist/_internal/shared/features/promotions/schema.d.ts +242 -0
- package/dist/_internal/shared/features/promotions/schema.js +37 -0
- package/dist/_internal/shared/features/reviews/config.d.ts +8 -0
- package/dist/_internal/shared/features/reviews/config.js +8 -0
- package/dist/_internal/shared/features/reviews/errors.d.ts +13 -0
- package/dist/_internal/shared/features/reviews/errors.js +25 -0
- package/dist/_internal/shared/features/reviews/schema.d.ts +44 -0
- package/dist/_internal/shared/features/reviews/schema.js +18 -0
- package/dist/_internal/shared/features/stores/config.d.ts +4 -0
- package/dist/_internal/shared/features/stores/config.js +4 -0
- package/dist/_internal/shared/features/wishlist/config.d.ts +2 -0
- package/dist/_internal/shared/features/wishlist/config.js +2 -0
- package/dist/_internal/shared/features/wishlist/errors.d.ts +4 -0
- package/dist/_internal/shared/features/wishlist/errors.js +7 -0
- package/dist/_internal/shared/index.d.ts +2 -0
- package/dist/_internal/shared/index.js +4 -0
- package/dist/_internal/shared/serialization/index.d.ts +17 -0
- package/dist/_internal/shared/serialization/index.js +42 -0
- package/dist/_internal/shared/tokens/index.d.ts +137 -0
- package/dist/_internal/shared/tokens/index.js +159 -0
- package/dist/client-entry.d.ts +23 -0
- package/dist/client-entry.js +27 -0
- package/dist/client.d.ts +47 -5
- package/dist/client.js +68 -33
- package/dist/configs/eslint.d.ts +29 -0
- package/dist/configs/eslint.js +38 -0
- package/dist/configs/index.d.ts +14 -0
- package/dist/configs/index.js +14 -0
- package/dist/configs/next.d.ts +38 -0
- package/dist/configs/next.js +116 -0
- package/dist/configs/postcss.d.ts +22 -0
- package/dist/configs/postcss.js +22 -0
- package/dist/configs/tailwind.d.ts +59 -0
- package/dist/configs/tailwind.js +62 -0
- package/dist/constants/api-endpoints.d.ts +24 -0
- package/dist/constants/api-endpoints.js +8 -0
- package/dist/constants/index.d.ts +1 -0
- package/dist/constants/index.js +1 -0
- package/dist/constants/limits.d.ts +15 -0
- package/dist/constants/limits.js +15 -0
- package/dist/contracts/client-auth.d.ts +2 -0
- package/dist/errors/messages.d.ts +23 -0
- package/dist/errors/messages.js +25 -0
- package/dist/features/about/components/PublicProfileView.js +16 -9
- package/dist/features/account/components/AddressBook.d.ts +2 -1
- package/dist/features/account/components/AddressBook.js +2 -2
- package/dist/features/account/components/UserReturnsView.d.ts +10 -0
- package/dist/features/account/components/UserReturnsView.js +5 -0
- package/dist/features/account/components/index.d.ts +2 -0
- package/dist/features/account/components/index.js +1 -0
- package/dist/features/account/hooks/useProfile.d.ts +2 -0
- package/dist/features/account/schemas/index.d.ts +18 -18
- package/dist/features/admin/actions/chat-actions.d.ts +1 -1
- package/dist/features/admin/actions/chat-actions.js +10 -10
- package/dist/features/admin/components/AdminBlogEditorView.d.ts +2 -1
- package/dist/features/admin/components/AdminBlogEditorView.js +16 -14
- package/dist/features/admin/components/AdminBlogView.js +6 -3
- package/dist/features/admin/components/AdminBrandEditorView.d.ts +3 -1
- package/dist/features/admin/components/AdminBrandEditorView.js +16 -14
- package/dist/features/admin/components/AdminBrandsView.js +6 -3
- package/dist/features/admin/components/AdminCategoriesView.js +6 -3
- package/dist/features/admin/components/AdminCategoryEditorView.d.ts +2 -1
- package/dist/features/admin/components/AdminCategoryEditorView.js +16 -14
- package/dist/features/admin/components/AdminCouponEditorView.d.ts +2 -1
- package/dist/features/admin/components/AdminCouponEditorView.js +16 -14
- package/dist/features/admin/components/AdminCouponsView.js +6 -3
- package/dist/features/admin/components/AdminFaqEditorView.d.ts +2 -1
- package/dist/features/admin/components/AdminFaqEditorView.js +16 -14
- package/dist/features/admin/components/AdminFaqsView.js +6 -3
- package/dist/features/admin/components/AdminFeatureEditorView.d.ts +19 -0
- package/dist/features/admin/components/AdminFeatureEditorView.js +150 -0
- package/dist/features/admin/components/AdminFeaturesView.d.ts +4 -0
- package/dist/features/admin/components/AdminFeaturesView.js +95 -0
- package/dist/features/admin/components/AdminHistoryView.d.ts +4 -0
- package/dist/features/admin/components/AdminHistoryView.js +57 -0
- package/dist/features/admin/components/AdminMediaView.js +64 -2
- package/dist/features/admin/components/AdminOrdersView.js +31 -4
- package/dist/features/admin/components/AdminProductEditorView.d.ts +2 -1
- package/dist/features/admin/components/AdminProductEditorView.js +30 -19
- package/dist/features/admin/components/AdminProductsView.js +40 -3
- package/dist/features/admin/components/AdminSectionsView.js +138 -2
- package/dist/features/admin/components/AdminSiteSettingsView.js +22 -2
- package/dist/features/admin/components/AdminStoresView.js +5 -4
- package/dist/features/admin/components/AdminUserEditorView.d.ts +4 -1
- package/dist/features/admin/components/AdminUserEditorView.js +2 -2
- package/dist/features/admin/components/AdminUsersView.js +1 -1
- package/dist/features/admin/components/AdminWishlistsView.js +17 -15
- package/dist/features/admin/components/DataTable.d.ts +2 -1
- package/dist/features/admin/components/DataTable.js +14 -12
- package/dist/features/admin/components/DrawerFormFooter.d.ts +9 -21
- package/dist/features/admin/components/DrawerFormFooter.js +10 -2
- package/dist/features/admin/components/QuickEditMenu.d.ts +20 -0
- package/dist/features/admin/components/QuickEditMenu.js +31 -0
- package/dist/features/admin/components/analytics/AdminAnalyticsCharts.js +11 -23
- package/dist/features/admin/components/index.d.ts +8 -0
- package/dist/features/admin/components/index.js +4 -0
- package/dist/features/admin/components/sections/adminSectionsBuildParse.d.ts +9 -1
- package/dist/features/admin/components/sections/adminSectionsBuildParse.js +169 -9
- package/dist/features/admin/components/sections/adminSectionsTypes.d.ts +62 -1
- package/dist/features/admin/components/sections/adminSectionsTypes.js +57 -4
- package/dist/features/admin/hooks/useChat.d.ts +1 -1
- package/dist/features/admin/repository/chat.repository.d.ts +2 -2
- package/dist/features/admin/repository/chat.repository.js +7 -7
- package/dist/features/admin/schemas/firestore.d.ts +42 -7
- package/dist/features/admin/schemas/firestore.js +7 -7
- package/dist/features/admin/types/product.types.d.ts +2 -2
- package/dist/features/auctions/actions/bid-actions.js +3 -2
- package/dist/features/auctions/components/AuctionDetailPageView.d.ts +11 -1
- package/dist/features/auctions/components/AuctionDetailPageView.js +80 -68
- package/dist/features/auctions/components/AuctionsListView.js +11 -6
- package/dist/features/auctions/components/MarketplaceAuctionCard.d.ts +2 -1
- package/dist/features/auctions/hooks/useAuctions.js +2 -1
- package/dist/features/auctions/repository/auctions.repository.js +4 -4
- package/dist/features/auctions/schemas/index.d.ts +24 -24
- package/dist/features/auctions/types/index.d.ts +2 -1
- package/dist/features/auth/hooks/useAuth.d.ts +8 -0
- package/dist/features/auth/hooks/useAuth.js +9 -0
- package/dist/features/auth/schemas/index.d.ts +2 -2
- package/dist/features/before-after/schemas/index.d.ts +2 -2
- package/dist/features/blog/actions/blog-actions.d.ts +63 -63
- package/dist/features/blog/components/BlogPostView.d.ts +3 -1
- package/dist/features/blog/components/BlogPostView.js +3 -2
- package/dist/features/blog/schemas/index.d.ts +41 -41
- package/dist/features/bundles/components/AdminBundleEditorView.d.ts +8 -0
- package/dist/features/bundles/components/AdminBundleEditorView.js +7 -0
- package/dist/features/bundles/components/BundleDetailPageView.d.ts +9 -0
- package/dist/features/bundles/components/BundleDetailPageView.js +45 -0
- package/dist/features/bundles/components/BundleForm.d.ts +12 -0
- package/dist/features/bundles/components/BundleForm.js +126 -0
- package/dist/features/bundles/components/BundleItemsPicker.d.ts +9 -0
- package/dist/features/bundles/components/BundleItemsPicker.js +77 -0
- package/dist/features/bundles/components/BundlesListingView.d.ts +17 -0
- package/dist/features/bundles/components/BundlesListingView.js +50 -0
- package/dist/features/bundles/components/FeaturedBundlesSection.d.ts +5 -0
- package/dist/features/bundles/components/FeaturedBundlesSection.js +55 -0
- package/dist/features/bundles/components/SellerBundleCreateView.d.ts +8 -0
- package/dist/features/bundles/components/SellerBundleCreateView.js +7 -0
- package/dist/features/bundles/components/SellerBundleEditView.d.ts +9 -0
- package/dist/features/bundles/components/SellerBundleEditView.js +7 -0
- package/dist/features/bundles/components/index.d.ts +16 -0
- package/dist/features/bundles/components/index.js +8 -0
- package/dist/features/bundles/constants/index.d.ts +32 -0
- package/dist/features/bundles/constants/index.js +35 -0
- package/dist/features/bundles/index.d.ts +2 -0
- package/dist/features/bundles/index.js +2 -0
- package/dist/features/bundles/repository/bundles.repository.d.ts +36 -0
- package/dist/features/bundles/repository/bundles.repository.js +148 -0
- package/dist/features/bundles/repository/index.d.ts +1 -0
- package/dist/features/bundles/repository/index.js +1 -0
- package/dist/features/bundles/schemas/firestore.d.ts +88 -0
- package/dist/features/bundles/schemas/firestore.js +29 -0
- package/dist/features/bundles/schemas/index.d.ts +1 -0
- package/dist/features/bundles/schemas/index.js +1 -0
- package/dist/features/cart/actions/cart-actions.js +2 -1
- package/dist/features/cart/repository/cart.repository.js +1 -2
- package/dist/features/cart/schemas/firestore.d.ts +9 -6
- package/dist/features/cart/schemas/firestore.js +1 -2
- package/dist/features/cart/schemas/index.d.ts +7 -7
- package/dist/features/cart/utils/guest-cart.d.ts +6 -0
- package/dist/features/cart/utils/guest-cart.js +14 -0
- package/dist/features/categories/components/BrandDetailPageView.d.ts +3 -1
- package/dist/features/categories/components/BrandDetailPageView.js +6 -6
- package/dist/features/categories/components/CategoryDetailPageView.js +3 -3
- package/dist/features/categories/components/CategoryProductsListing.js +1 -1
- package/dist/features/categories/schemas/index.d.ts +24 -24
- package/dist/features/collections/schemas/index.d.ts +3 -3
- package/dist/features/consultation/schemas/index.d.ts +7 -7
- package/dist/features/corporate/schemas/index.d.ts +1 -1
- package/dist/features/events/components/AdminEventEditorView.d.ts +2 -1
- package/dist/features/events/components/AdminEventEditorView.js +10 -8
- package/dist/features/events/components/AdminEventsView.js +6 -3
- package/dist/features/events/components/EventDetailView.d.ts +7 -1
- package/dist/features/events/components/EventDetailView.js +4 -1
- package/dist/features/events/components/EventRafflesSection.d.ts +12 -0
- package/dist/features/events/components/EventRafflesSection.js +17 -0
- package/dist/features/events/components/index.d.ts +2 -0
- package/dist/features/events/components/index.js +1 -0
- package/dist/features/events/schemas/index.d.ts +41 -41
- package/dist/features/faq/actions/faq-actions.d.ts +16 -16
- package/dist/features/faq/schemas/index.d.ts +12 -12
- package/dist/features/history/actions/history-actions.d.ts +24 -0
- package/dist/features/history/actions/history-actions.js +43 -0
- package/dist/features/history/actions/index.d.ts +1 -0
- package/dist/features/history/actions/index.js +1 -0
- package/dist/features/history/components/HistoryTracker.d.ts +8 -0
- package/dist/features/history/components/HistoryTracker.js +18 -0
- package/dist/features/history/hooks/useHistory.d.ts +16 -0
- package/dist/features/history/hooks/useHistory.js +148 -0
- package/dist/features/history/hooks/useHistoryMergeOnLogin.d.ts +1 -0
- package/dist/features/history/hooks/useHistoryMergeOnLogin.js +41 -0
- package/dist/features/history/index.d.ts +5 -0
- package/dist/features/history/index.js +4 -0
- package/dist/features/history/repository/user-history.repository.d.ts +59 -0
- package/dist/features/history/repository/user-history.repository.js +203 -0
- package/dist/features/history/server.d.ts +6 -0
- package/dist/features/history/server.js +6 -0
- package/dist/features/history/utils/guest-history.d.ts +24 -0
- package/dist/features/history/utils/guest-history.js +66 -0
- package/dist/features/homepage/actions/homepage-section-actions.d.ts +4 -4
- package/dist/features/homepage/components/BrandsSection.d.ts +7 -1
- package/dist/features/homepage/components/BrandsSection.js +26 -4
- package/dist/features/homepage/components/CollectionCardsSection.d.ts +13 -0
- package/dist/features/homepage/components/CollectionCardsSection.js +41 -0
- package/dist/features/homepage/components/FAQSection.d.ts +14 -4
- package/dist/features/homepage/components/FAQSection.js +63 -13
- package/dist/features/homepage/components/FeaturedProductsSection.d.ts +8 -1
- package/dist/features/homepage/components/FeaturedProductsSection.js +42 -2
- package/dist/features/homepage/components/MarketplaceHomepageView.js +17 -8
- package/dist/features/homepage/components/ShopByCategorySection.d.ts +8 -1
- package/dist/features/homepage/components/ShopByCategorySection.js +44 -4
- package/dist/features/homepage/components/SocialFeedSection.js +22 -2
- package/dist/features/homepage/components/SocialPostCard.js +20 -5
- package/dist/features/homepage/components/WelcomeSection.js +2 -2
- package/dist/features/homepage/components/WhatsAppCommunitySection.d.ts +0 -1
- package/dist/features/homepage/components/WhatsAppCommunitySection.js +4 -4
- package/dist/features/homepage/lib/live-stats.d.ts +18 -5
- package/dist/features/homepage/lib/live-stats.js +60 -29
- package/dist/features/homepage/lib/section-renderer.d.ts +2 -1
- package/dist/features/homepage/lib/section-renderer.js +50 -11
- package/dist/features/homepage/repository/carousels.repository.d.ts +38 -0
- package/dist/features/homepage/repository/carousels.repository.js +142 -0
- package/dist/features/homepage/schemas/firestore.d.ts +177 -21
- package/dist/features/homepage/schemas/firestore.js +24 -0
- package/dist/features/layout/AppLayoutShell.d.ts +3 -1
- package/dist/features/layout/AppLayoutShell.js +2 -2
- package/dist/features/layout/TitleBarLayout.d.ts +3 -1
- package/dist/features/layout/TitleBarLayout.js +5 -4
- package/dist/features/layout/index.d.ts +1 -1
- package/dist/features/media/MediaPickerModal.js +67 -3
- package/dist/features/media/types/index.d.ts +2 -2
- package/dist/features/media/upload/MediaUploadField.js +21 -5
- package/dist/features/messages/actions/index.d.ts +2 -0
- package/dist/features/messages/actions/index.js +2 -0
- package/dist/features/messages/actions/messages-actions.d.ts +15 -0
- package/dist/features/messages/actions/messages-actions.js +33 -0
- package/dist/features/messages/actions/ping-rtdb.d.ts +2 -0
- package/dist/features/messages/actions/ping-rtdb.js +24 -0
- package/dist/features/messages/hooks/useConversation.d.ts +22 -0
- package/dist/features/messages/hooks/useConversation.js +125 -0
- package/dist/features/messages/hooks/useConversations.d.ts +9 -0
- package/dist/features/messages/hooks/useConversations.js +62 -0
- package/dist/features/messages/index.d.ts +6 -0
- package/dist/features/messages/index.js +4 -0
- package/dist/features/messages/realtime.d.ts +32 -0
- package/dist/features/messages/realtime.js +39 -0
- package/dist/features/messages/repository/conversations.repository.d.ts +35 -0
- package/dist/features/messages/repository/conversations.repository.js +180 -0
- package/dist/features/messages/server.d.ts +6 -0
- package/dist/features/messages/server.js +6 -0
- package/dist/features/orders/schemas/firestore.d.ts +21 -0
- package/dist/features/orders/schemas/index.d.ts +28 -28
- package/dist/features/orders/utils/order-splitter.d.ts +12 -2
- package/dist/features/orders/utils/order-splitter.js +13 -2
- package/dist/features/payments/schemas/index.d.ts +6 -6
- package/dist/features/pre-orders/api/route.js +10 -11
- package/dist/features/pre-orders/components/PreOrderDetailPageView.d.ts +11 -1
- package/dist/features/pre-orders/components/PreOrderDetailPageView.js +45 -35
- package/dist/features/pre-orders/components/PreOrdersIndexListing.js +24 -7
- package/dist/features/pre-orders/components/PreOrdersListView.js +10 -5
- package/dist/features/pre-orders/schemas/index.d.ts +6 -6
- package/dist/features/products/actions/product-actions.d.ts +2 -2
- package/dist/features/products/actions/product-actions.js +21 -16
- package/dist/features/products/api/[id]/route.js +4 -4
- package/dist/features/products/api/route.js +21 -6
- package/dist/features/products/components/AuctionsIndexListing.js +1 -1
- package/dist/features/products/components/CompareOverlay.d.ts +51 -0
- package/dist/features/products/components/CompareOverlay.js +154 -0
- package/dist/features/products/components/FeatureBadge.d.ts +28 -0
- package/dist/features/products/components/FeatureBadge.js +63 -0
- package/dist/features/products/components/GroupSettingsPanel.js +1 -1
- package/dist/features/products/components/NonRefundableConsentModal.d.ts +23 -0
- package/dist/features/products/components/NonRefundableConsentModal.js +55 -0
- package/dist/features/products/components/PrizeDrawsSection.d.ts +12 -0
- package/dist/features/products/components/PrizeDrawsSection.js +17 -0
- package/dist/features/products/components/ProductDetailPageView.d.ts +16 -1
- package/dist/features/products/components/ProductDetailPageView.js +65 -60
- package/dist/features/products/components/ProductFeaturesContext.d.ts +9 -0
- package/dist/features/products/components/ProductFeaturesContext.js +11 -0
- package/dist/features/products/components/ProductFeaturesSelector.d.ts +12 -0
- package/dist/features/products/components/ProductFeaturesSelector.js +72 -0
- package/dist/features/products/components/ProductForm.js +9 -3
- package/dist/features/products/components/ProductGrid.js +9 -3
- package/dist/features/products/components/ProductsIndexListing.js +24 -8
- package/dist/features/products/components/ProductsIndexPageView.js +12 -7
- package/dist/features/products/components/ShowGroupSection.js +2 -1
- package/dist/features/products/components/SublistingCarouselSection.js +3 -2
- package/dist/features/products/components/index.d.ts +12 -0
- package/dist/features/products/components/index.js +6 -0
- package/dist/features/products/constants/action-defs.d.ts +209 -0
- package/dist/features/products/constants/action-defs.js +270 -0
- package/dist/features/products/constants/product-features.constants.d.ts +23 -0
- package/dist/features/products/constants/product-features.constants.js +50 -0
- package/dist/features/products/hooks/useProducts.d.ts +1 -0
- package/dist/features/products/hooks/useProducts.js +15 -6
- package/dist/features/products/hooks/useRelatedProducts.d.ts +5 -0
- package/dist/features/products/hooks/useRelatedProducts.js +9 -1
- package/dist/features/products/index.d.ts +3 -1
- package/dist/features/products/index.js +3 -1
- package/dist/features/products/repository/loadProductFeatures.d.ts +2 -0
- package/dist/features/products/repository/loadProductFeatures.js +23 -0
- package/dist/features/products/repository/product-features.repository.d.ts +27 -0
- package/dist/features/products/repository/product-features.repository.js +141 -0
- package/dist/features/products/repository/product-templates.repository.d.ts +12 -0
- package/dist/features/products/repository/product-templates.repository.js +61 -0
- package/dist/features/products/repository/products.repository.d.ts +16 -1
- package/dist/features/products/repository/products.repository.js +126 -6
- package/dist/features/products/schemas/firestore.d.ts +43 -5
- package/dist/features/products/schemas/firestore.js +6 -7
- package/dist/features/products/schemas/index.d.ts +147 -51
- package/dist/features/products/schemas/index.js +32 -3
- package/dist/features/products/schemas/product-features.d.ts +84 -0
- package/dist/features/products/schemas/product-features.js +33 -0
- package/dist/features/products/schemas/product-features.validators.d.ts +107 -0
- package/dist/features/products/schemas/product-features.validators.js +64 -0
- package/dist/features/products/schemas/product-templates.d.ts +28 -0
- package/dist/features/products/schemas/product-templates.js +6 -0
- package/dist/features/products/types/index.d.ts +13 -5
- package/dist/features/products/utils/listing-type.d.ts +23 -2
- package/dist/features/products/utils/listing-type.js +14 -7
- package/dist/features/products/utils/sanitize.d.ts +2 -0
- package/dist/features/products/utils/sanitize.js +25 -0
- package/dist/features/promotions/actions/coupon-actions.d.ts +2 -2
- package/dist/features/promotions/components/CouponsIndexListing.d.ts +4 -4
- package/dist/features/promotions/components/CouponsIndexListing.js +3 -3
- package/dist/features/promotions/hooks/useCouponValidate.d.ts +2 -2
- package/dist/features/promotions/repository/coupons.repository.d.ts +2 -2
- package/dist/features/promotions/repository/coupons.repository.js +5 -5
- package/dist/features/promotions/schemas/index.d.ts +18 -18
- package/dist/features/reviews/schemas/index.d.ts +16 -16
- package/dist/features/search/actions/search-actions.js +4 -5
- package/dist/features/search/api/route.js +13 -10
- package/dist/features/search/columns/index.d.ts +1 -1
- package/dist/features/search/columns/index.js +4 -4
- package/dist/features/search/repository/search.repository.js +4 -6
- package/dist/features/search/schemas/index.d.ts +5 -5
- package/dist/features/search/types/index.d.ts +4 -3
- package/dist/features/seller/actions/offer-actions.js +1 -2
- package/dist/features/seller/components/BrandInlineSelect.d.ts +9 -0
- package/dist/features/seller/components/BrandInlineSelect.js +26 -0
- package/dist/features/seller/components/CategoryInlineSelect.d.ts +9 -0
- package/dist/features/seller/components/CategoryInlineSelect.js +26 -0
- package/dist/features/seller/components/SellerFeaturesView.d.ts +1 -0
- package/dist/features/seller/components/SellerFeaturesView.js +61 -0
- package/dist/features/seller/components/SellerProductShell.d.ts +15 -1
- package/dist/features/seller/components/SellerProductShell.js +7 -7
- package/dist/features/seller/components/SellerProductsView.js +17 -17
- package/dist/features/seller/components/SellerStorefrontView.d.ts +7 -0
- package/dist/features/seller/components/SellerStorefrontView.js +12 -2
- package/dist/features/seller/components/analytics/SellerRevenueChart.js +9 -17
- package/dist/features/seller/components/index.d.ts +6 -0
- package/dist/features/seller/components/index.js +4 -0
- package/dist/features/seller/schemas/index.d.ts +26 -26
- package/dist/features/shell/FormShell.d.ts +9 -1
- package/dist/features/shell/FormShell.js +5 -3
- package/dist/features/stores/actions/store-query-actions.js +2 -2
- package/dist/features/stores/api/[storeSlug]/auctions/route.js +11 -15
- package/dist/features/stores/api/[storeSlug]/products/route.js +11 -15
- package/dist/features/stores/api/route.js +12 -14
- package/dist/features/stores/components/StoreAuctionsListing.d.ts +2 -4
- package/dist/features/stores/components/StoreAuctionsListing.js +3 -4
- package/dist/features/stores/components/StoreAuctionsPageView.js +1 -1
- package/dist/features/stores/components/StoreDetailLayoutView.js +3 -3
- package/dist/features/stores/components/StorePreOrdersListing.d.ts +1 -3
- package/dist/features/stores/components/StorePreOrdersListing.js +2 -3
- package/dist/features/stores/components/StorePreOrdersPageView.js +1 -1
- package/dist/features/stores/components/StoreProductsListing.d.ts +2 -4
- package/dist/features/stores/components/StoreProductsListing.js +2 -3
- package/dist/features/stores/components/StoreProductsPageView.d.ts +4 -1
- package/dist/features/stores/components/StoreProductsPageView.js +17 -11
- package/dist/features/stores/repository/store.repository.d.ts +10 -0
- package/dist/features/stores/repository/store.repository.js +39 -0
- package/dist/features/stores/schemas/firestore.d.ts +7 -0
- package/dist/features/stores/schemas/index.d.ts +8 -8
- package/dist/features/stores/types/index.d.ts +4 -3
- package/dist/features/wishlist/actions/wishlist-actions.d.ts +8 -6
- package/dist/features/wishlist/actions/wishlist-actions.js +9 -7
- package/dist/features/wishlist/components/WishlistCapWatcher.d.ts +1 -0
- package/dist/features/wishlist/components/WishlistCapWatcher.js +24 -0
- package/dist/features/wishlist/components/index.d.ts +1 -0
- package/dist/features/wishlist/components/index.js +1 -0
- package/dist/features/wishlist/hooks/useWishlistCount.d.ts +17 -0
- package/dist/features/wishlist/hooks/useWishlistCount.js +36 -1
- package/dist/features/wishlist/index.d.ts +2 -0
- package/dist/features/wishlist/index.js +1 -0
- package/dist/features/wishlist/repository/user-wishlist.repository.d.ts +52 -7
- package/dist/features/wishlist/repository/user-wishlist.repository.js +154 -44
- package/dist/features/wishlist/schemas/index.d.ts +2 -2
- package/dist/features/wishlist/server.d.ts +1 -1
- package/dist/features/wishlist/server.js +1 -1
- package/dist/features/wishlist/types/index.d.ts +2 -2
- package/dist/index.d.ts +87 -5
- package/dist/index.js +101 -12
- package/dist/next/api/routeHandler.d.ts +7 -0
- package/dist/next/api/routeHandler.js +8 -0
- package/dist/next/routing/route-map.d.ts +68 -0
- package/dist/next/routing/route-map.js +32 -0
- package/dist/providers/db-firebase/filter-aliases.d.ts +20 -0
- package/dist/providers/db-firebase/filter-aliases.js +29 -0
- package/dist/providers/db-firebase/index.d.ts +2 -2
- package/dist/providers/db-firebase/index.js +1 -1
- package/dist/providers/db-firebase/sieve.d.ts +9 -0
- package/dist/providers/db-firebase/sieve.js +24 -6
- package/dist/providers/firebase-client/auth.d.ts +1 -0
- package/dist/providers/firebase-client/auth.js +9 -1
- package/dist/providers/shipping-shiprocket/index.d.ts +9 -0
- package/dist/providers/shipping-shiprocket/index.js +11 -0
- package/dist/react/hooks/use-action-dispatch.d.ts +25 -0
- package/dist/react/hooks/use-action-dispatch.js +30 -0
- package/dist/react/hooks/use-panel-url-sync.d.ts +15 -0
- package/dist/react/hooks/use-panel-url-sync.js +46 -0
- package/dist/react/hooks/useInfiniteScroll.d.ts +52 -0
- package/dist/react/hooks/useInfiniteScroll.js +45 -0
- package/dist/repositories/index.d.ts +9 -1
- package/dist/repositories/index.js +8 -1
- package/dist/seed/_bundle-constants.d.ts +14 -0
- package/dist/seed/_bundle-constants.js +14 -0
- package/dist/seed/actions/demo-seed-actions.d.ts +1 -1
- package/dist/seed/bids-seed-data.js +165 -0
- package/dist/seed/blog-posts-seed-data.js +393 -0
- package/dist/seed/bundles-seed-data.d.ts +13 -0
- package/dist/seed/bundles-seed-data.js +229 -0
- package/dist/seed/carousels-seed-data.d.ts +2 -0
- package/dist/seed/carousels-seed-data.js +16 -0
- package/dist/seed/cart-seed-data.js +161 -16
- package/dist/seed/categories-seed-data.js +168 -0
- package/dist/seed/coupons-seed-data.js +174 -0
- package/dist/seed/events-seed-data.js +161 -0
- package/dist/seed/history-seed-data.d.ts +19 -0
- package/dist/seed/history-seed-data.js +61 -0
- package/dist/seed/homepage-sections-seed-data.js +97 -1
- package/dist/seed/index.d.ts +4 -3
- package/dist/seed/index.js +9 -3
- package/dist/seed/manifest.js +23 -1
- package/dist/seed/notifications-seed-data.js +60 -0
- package/dist/seed/orders-seed-data.js +2 -2
- package/dist/seed/product-features-seed-data.d.ts +10 -0
- package/dist/seed/product-features-seed-data.js +162 -0
- package/dist/seed/products-auctions-seed-data.d.ts +6 -1
- package/dist/seed/products-auctions-seed-data.js +495 -24
- package/dist/seed/products-preorders-seed-data.d.ts +6 -1
- package/dist/seed/products-preorders-seed-data.js +27 -18
- package/dist/seed/products-standard-seed-data.d.ts +5 -0
- package/dist/seed/products-standard-seed-data.js +208 -297
- package/dist/seed/runner.js +95 -16
- package/dist/seed/server.d.ts +2 -0
- package/dist/seed/server.js +7 -0
- package/dist/seed/site-settings-seed-data.js +11 -1
- package/dist/seed/types.d.ts +58 -1
- package/dist/seed/types.js +14 -1
- package/dist/seed/wishlists-seed-data.d.ts +14 -7
- package/dist/seed/wishlists-seed-data.js +52 -109
- package/dist/seo/json-ld.d.ts +2 -1
- package/dist/server-entry.d.ts +60 -0
- package/dist/server-entry.js +93 -0
- package/dist/server.d.ts +26 -3
- package/dist/server.js +39 -7
- package/dist/stores/panel-store.d.ts +9 -0
- package/dist/stores/panel-store.js +8 -0
- package/dist/tailwind-utilities.css +1 -1
- package/dist/tokens/tokens.css +182 -12
- package/dist/ui/DataTable.style.css +192 -190
- package/dist/ui/components/Accordion.style.css +82 -82
- package/dist/ui/components/ActiveFilterChips.style.css +12 -12
- package/dist/ui/components/Alert.style.css +187 -187
- package/dist/ui/components/Avatar.style.css +71 -71
- package/dist/ui/components/AvatarDisplay.style.css +3 -3
- package/dist/ui/components/Badge.style.css +114 -114
- package/dist/ui/components/BaseListingCard.style.css +86 -86
- package/dist/ui/components/Breadcrumb.style.css +10 -10
- package/dist/ui/components/BulkActionBar.style.css +196 -196
- package/dist/ui/components/BulkActionsBar.d.ts +2 -0
- package/dist/ui/components/BulkActionsBar.js +5 -2
- package/dist/ui/components/Button.d.ts +3 -1
- package/dist/ui/components/Button.js +12 -2
- package/dist/ui/components/Button.style.css +160 -160
- package/dist/ui/components/Card.style.css +190 -190
- package/dist/ui/components/Checkbox.style.css +111 -111
- package/dist/ui/components/ConfirmDeleteModal.style.css +89 -89
- package/dist/ui/components/DashboardStatsCard.style.css +68 -68
- package/dist/ui/components/DescriptionField.style.css +36 -36
- package/dist/ui/components/DetailViewShell.js +1 -2
- package/dist/ui/components/Divider.style.css +39 -39
- package/dist/ui/components/Drawer.style.css +150 -150
- package/dist/ui/components/Dropdown.style.css +110 -110
- package/dist/ui/components/DynamicSelect.style.css +101 -101
- package/dist/ui/components/EmptyState.style.css +2 -2
- package/dist/ui/components/FilterDrawer.style.css +61 -61
- package/dist/ui/components/FlowDiagram.style.css +3 -3
- package/dist/ui/components/Form.style.css +27 -27
- package/dist/ui/components/FormActionBar.d.ts +22 -0
- package/dist/ui/components/FormActionBar.js +8 -0
- package/dist/ui/components/FormActionBar.style.css +77 -0
- package/dist/ui/components/FormField.style.css +30 -30
- package/dist/ui/components/HorizontalScroller.style.css +10 -10
- package/dist/ui/components/IconButton.style.css +103 -103
- package/dist/ui/components/ImageGallery.style.css +4 -4
- package/dist/ui/components/InlineCreateSelect.d.ts +13 -3
- package/dist/ui/components/InlineCreateSelect.js +9 -4
- package/dist/ui/components/Input.style.css +28 -28
- package/dist/ui/components/Layout.d.ts +2 -0
- package/dist/ui/components/Layout.js +2 -0
- package/dist/ui/components/Layout.style.css +22 -5
- package/dist/ui/components/ListingLayout.style.css +491 -491
- package/dist/ui/components/Modal.style.css +106 -106
- package/dist/ui/components/Pagination.style.css +76 -76
- package/dist/ui/components/PasswordStrengthIndicator.style.css +56 -56
- package/dist/ui/components/PriceDisplay.style.css +47 -47
- package/dist/ui/components/Progress.style.css +81 -81
- package/dist/ui/components/Radio.style.css +153 -153
- package/dist/ui/components/RatingDisplay.style.css +50 -50
- package/dist/ui/components/RowActionMenu.style.css +91 -91
- package/dist/ui/components/SectionTabs.style.css +18 -18
- package/dist/ui/components/Select.style.css +177 -177
- package/dist/ui/components/SideDrawer.style.css +206 -206
- package/dist/ui/components/SideModal.style.css +73 -73
- package/dist/ui/components/SiteLogo.d.ts +26 -0
- package/dist/ui/components/SiteLogo.js +18 -0
- package/dist/ui/components/Skeleton.style.css +55 -55
- package/dist/ui/components/SkipToMain.style.css +3 -3
- package/dist/ui/components/Slider.style.css +15 -15
- package/dist/ui/components/Spinner.style.css +84 -84
- package/dist/ui/components/StarRating.style.css +44 -44
- package/dist/ui/components/StatsGrid.style.css +96 -96
- package/dist/ui/components/StepperNav.style.css +110 -110
- package/dist/ui/components/SummaryCard.style.css +80 -82
- package/dist/ui/components/TabStrip.style.css +97 -97
- package/dist/ui/components/TablePagination.style.css +89 -89
- package/dist/ui/components/Tabs.style.css +44 -44
- package/dist/ui/components/TagInput.style.css +121 -121
- package/dist/ui/components/TextLink.style.css +94 -94
- package/dist/ui/components/Textarea.style.css +30 -30
- package/dist/ui/components/Toast.style.css +112 -112
- package/dist/ui/components/Toggle.style.css +105 -105
- package/dist/ui/components/Tooltip.style.css +114 -114
- package/dist/ui/components/Typography.style.css +178 -178
- package/dist/ui/components/UnsavedChangesModal.style.css +1 -1
- package/dist/ui/components/ViewToggle.style.css +8 -8
- package/dist/ui/components/index.style.css +1 -0
- package/dist/ui/index.d.ts +4 -0
- package/dist/ui/index.js +2 -0
- package/dist/ui/rich-text/RichText.style.css +40 -40
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +1 -0
- package/dist/utils/listing-params.d.ts +86 -0
- package/dist/utils/listing-params.js +121 -0
- package/dist/validation/schemas.d.ts +22 -22
- package/package.json +61 -9
- package/scripts/audit-violations.mjs +77 -0
- package/scripts/init-config.mjs +76 -0
- package/scripts/labels-extract.mjs +64 -0
- package/scripts/seed-cli-loader.mjs +37 -0
- package/scripts/seed-cli.mjs +660 -0
- package/scripts/sieve-audit.mjs +475 -0
- package/scripts/smoke-bundle.mjs +60 -0
- package/scripts/smoke-ssr.mjs +81 -0
- package/scripts/smoke-theme.mjs +105 -0
- package/scripts/verify-css-build.mjs +49 -0
- package/scripts/verify-entries.mjs +55 -0
- package/tsconfig.base.json +16 -0
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { bidRepository, notificationRepository, productRepository, } from "../../../../repositories";
|
|
2
|
+
import { decryptPii } from "../../../../security/index";
|
|
3
|
+
import { getAdminRealtimeDb } from "../../../../providers/db-firebase";
|
|
4
|
+
import { BID_MESSAGES } from "./messages";
|
|
5
|
+
const BIDS_COLLECTION = "bids";
|
|
6
|
+
export const onBidPlacedHandler = async (event, ctx) => {
|
|
7
|
+
const newBid = event.after;
|
|
8
|
+
if (!newBid) {
|
|
9
|
+
ctx.logger.error("No snapshot data", null);
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
newBid.userName = decryptPii(newBid.userName);
|
|
13
|
+
try {
|
|
14
|
+
const prevWinning = await bidRepository.getWinningBid(newBid.productId);
|
|
15
|
+
const batch = ctx.db.batch();
|
|
16
|
+
const newBidRef = ctx.db.collection(BIDS_COLLECTION).doc(event.params.bidId);
|
|
17
|
+
bidRepository.markWinning(batch, newBidRef);
|
|
18
|
+
let outbidUserId = null;
|
|
19
|
+
if (prevWinning && prevWinning.data.userId !== newBid.userId) {
|
|
20
|
+
outbidUserId = prevWinning.data.userId;
|
|
21
|
+
bidRepository.markOutbid(batch, prevWinning.ref);
|
|
22
|
+
notificationRepository.createInBatch(batch, {
|
|
23
|
+
userId: outbidUserId,
|
|
24
|
+
type: "bid_outbid",
|
|
25
|
+
priority: "high",
|
|
26
|
+
title: BID_MESSAGES.OUTBID_TITLE,
|
|
27
|
+
message: BID_MESSAGES.OUTBID_MESSAGE(newBid.productTitle, newBid.currency, newBid.bidAmount),
|
|
28
|
+
relatedId: newBid.productId,
|
|
29
|
+
relatedType: "product",
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
productRepository.incrementBidCountInBatch(batch, newBid.productId, newBid.bidAmount);
|
|
33
|
+
await batch.commit();
|
|
34
|
+
try {
|
|
35
|
+
if (outbidUserId) {
|
|
36
|
+
await getAdminRealtimeDb()
|
|
37
|
+
.ref(`notifications/${outbidUserId}`)
|
|
38
|
+
.push({
|
|
39
|
+
type: "bid_outbid",
|
|
40
|
+
title: BID_MESSAGES.OUTBID_TITLE,
|
|
41
|
+
message: BID_MESSAGES.OUTBID_MESSAGE(newBid.productTitle, newBid.currency, newBid.bidAmount),
|
|
42
|
+
timestamp: Date.now(),
|
|
43
|
+
read: false,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
catch (rtdbError) {
|
|
48
|
+
ctx.logger.error("Realtime DB push failed (non-fatal)", rtdbError);
|
|
49
|
+
}
|
|
50
|
+
ctx.logger.info(`Bid placed on ${newBid.productId}`, {
|
|
51
|
+
bidId: event.params.bidId,
|
|
52
|
+
amount: newBid.bidAmount,
|
|
53
|
+
outbidUserId,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
ctx.logger.error("Error handling bid placement", error, {
|
|
58
|
+
bidId: event.params.bidId,
|
|
59
|
+
productId: newBid.productId,
|
|
60
|
+
});
|
|
61
|
+
throw error;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trigger handler: maintain DFS `position` + `subtreeSize` on every category
|
|
3
|
+
* write. CREATE → insert into parent's subtree + shift later siblings;
|
|
4
|
+
* DELETE → shift back; MOVE → mark `positionDirty` so the nightly reconcile
|
|
5
|
+
* job rebuilds (real-time move would require repositioning an entire subtree).
|
|
6
|
+
*/
|
|
7
|
+
import type { FirestoreTriggerHandler } from "../runtime/types";
|
|
8
|
+
type CategoryDoc = Record<string, unknown>;
|
|
9
|
+
export declare const onCategoryWriteHandler: FirestoreTriggerHandler<CategoryDoc, CategoryDoc>;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trigger handler: maintain DFS `position` + `subtreeSize` on every category
|
|
3
|
+
* write. CREATE → insert into parent's subtree + shift later siblings;
|
|
4
|
+
* DELETE → shift back; MOVE → mark `positionDirty` so the nightly reconcile
|
|
5
|
+
* job rebuilds (real-time move would require repositioning an entire subtree).
|
|
6
|
+
*/
|
|
7
|
+
import { FieldValue } from "firebase-admin/firestore";
|
|
8
|
+
import { BATCH_LIMIT } from "./messages";
|
|
9
|
+
const CATEGORIES = "categories";
|
|
10
|
+
async function shiftPositions(ctx, threshold, delta, excludeId) {
|
|
11
|
+
const snap = await ctx.db.collection(CATEGORIES).where("position", ">=", threshold).get();
|
|
12
|
+
const docs = snap.docs.filter((d) => d.id !== excludeId && d.data().position >= threshold);
|
|
13
|
+
if (docs.length === 0)
|
|
14
|
+
return 0;
|
|
15
|
+
for (let i = 0; i < docs.length; i += BATCH_LIMIT) {
|
|
16
|
+
const batch = ctx.db.batch();
|
|
17
|
+
for (const doc of docs.slice(i, i + BATCH_LIMIT)) {
|
|
18
|
+
batch.update(doc.ref, {
|
|
19
|
+
position: doc.data().position + delta,
|
|
20
|
+
updatedAt: new Date(),
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
await batch.commit();
|
|
24
|
+
}
|
|
25
|
+
return docs.length;
|
|
26
|
+
}
|
|
27
|
+
async function adjustAncestorSubtreeSize(ctx, ancestorIds, delta) {
|
|
28
|
+
if (ancestorIds.length === 0)
|
|
29
|
+
return;
|
|
30
|
+
for (let i = 0; i < ancestorIds.length; i += BATCH_LIMIT) {
|
|
31
|
+
const batch = ctx.db.batch();
|
|
32
|
+
for (const id of ancestorIds.slice(i, i + BATCH_LIMIT)) {
|
|
33
|
+
batch.update(ctx.db.collection(CATEGORIES).doc(id), {
|
|
34
|
+
subtreeSize: FieldValue.increment(delta),
|
|
35
|
+
updatedAt: new Date(),
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
await batch.commit();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
async function getMaxPosition(ctx, excludeId) {
|
|
42
|
+
const snap = await ctx.db
|
|
43
|
+
.collection(CATEGORIES)
|
|
44
|
+
.orderBy("position", "desc")
|
|
45
|
+
.limit(excludeId ? 2 : 1)
|
|
46
|
+
.get();
|
|
47
|
+
for (const doc of snap.docs) {
|
|
48
|
+
if (doc.id === excludeId)
|
|
49
|
+
continue;
|
|
50
|
+
return doc.data().position ?? 0;
|
|
51
|
+
}
|
|
52
|
+
return 0;
|
|
53
|
+
}
|
|
54
|
+
export const onCategoryWriteHandler = async (event, ctx) => {
|
|
55
|
+
const categoryId = event.params.categoryId;
|
|
56
|
+
const before = event.before;
|
|
57
|
+
const after = event.after;
|
|
58
|
+
const isCreate = !before && !!after;
|
|
59
|
+
const isDelete = !!before && !after;
|
|
60
|
+
const isUpdate = !!before && !!after;
|
|
61
|
+
try {
|
|
62
|
+
if (isCreate) {
|
|
63
|
+
const parentIds = after.parentIds ?? [];
|
|
64
|
+
const parentId = parentIds.length > 0 ? parentIds[parentIds.length - 1] : null;
|
|
65
|
+
let insertPosition;
|
|
66
|
+
if (parentId) {
|
|
67
|
+
const parentSnap = await ctx.db.collection(CATEGORIES).doc(parentId).get();
|
|
68
|
+
if (!parentSnap.exists) {
|
|
69
|
+
ctx.logger.warn("Parent not found, appending at end", { categoryId, parentId });
|
|
70
|
+
insertPosition = (await getMaxPosition(ctx, categoryId)) + 1;
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
const p = parentSnap.data();
|
|
74
|
+
const parentPos = p.position ?? 0;
|
|
75
|
+
const parentSize = p.subtreeSize ?? 1;
|
|
76
|
+
insertPosition = parentPos + parentSize;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
insertPosition = (await getMaxPosition(ctx, categoryId)) + 1;
|
|
81
|
+
}
|
|
82
|
+
const shifted = await shiftPositions(ctx, insertPosition, +1, categoryId);
|
|
83
|
+
await ctx.db.collection(CATEGORIES).doc(categoryId).update({
|
|
84
|
+
position: insertPosition,
|
|
85
|
+
subtreeSize: 1,
|
|
86
|
+
updatedAt: new Date(),
|
|
87
|
+
});
|
|
88
|
+
await adjustAncestorSubtreeSize(ctx, parentIds, +1);
|
|
89
|
+
ctx.logger.info("Category created — position assigned", {
|
|
90
|
+
categoryId,
|
|
91
|
+
position: insertPosition,
|
|
92
|
+
parentId,
|
|
93
|
+
shifted,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
else if (isDelete) {
|
|
97
|
+
const deletedPos = before.position ?? 0;
|
|
98
|
+
const deletedSize = before.subtreeSize ?? 1;
|
|
99
|
+
const parentIds = before.parentIds ?? [];
|
|
100
|
+
if (deletedPos === 0) {
|
|
101
|
+
ctx.logger.warn("Deleted category had no position — skipping shift", { categoryId });
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
const shifted = await shiftPositions(ctx, deletedPos + deletedSize, -deletedSize);
|
|
105
|
+
await adjustAncestorSubtreeSize(ctx, parentIds, -deletedSize);
|
|
106
|
+
ctx.logger.info("Category deleted — positions shifted", {
|
|
107
|
+
categoryId,
|
|
108
|
+
position: deletedPos,
|
|
109
|
+
subtreeSize: deletedSize,
|
|
110
|
+
shifted,
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
else if (isUpdate) {
|
|
114
|
+
const beforeParents = before.parentIds ?? [];
|
|
115
|
+
const afterParents = after.parentIds ?? [];
|
|
116
|
+
const beforeParent = beforeParents[beforeParents.length - 1] ?? null;
|
|
117
|
+
const afterParent = afterParents[afterParents.length - 1] ?? null;
|
|
118
|
+
if (beforeParent !== afterParent) {
|
|
119
|
+
await ctx.db
|
|
120
|
+
.collection(CATEGORIES)
|
|
121
|
+
.doc(categoryId)
|
|
122
|
+
.update({ positionDirty: true, updatedAt: new Date() });
|
|
123
|
+
ctx.logger.warn("Category moved — positionDirty flagged for nightly reconcile", {
|
|
124
|
+
categoryId,
|
|
125
|
+
fromParent: beforeParent,
|
|
126
|
+
toParent: afterParent,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
catch (err) {
|
|
132
|
+
ctx.logger.error("Position update failed (non-fatal — will heal on next reconcile)", err, {
|
|
133
|
+
categoryId,
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { FirestoreTriggerHandler } from "../runtime/types";
|
|
2
|
+
interface OrderItem {
|
|
3
|
+
title?: string;
|
|
4
|
+
name?: string;
|
|
5
|
+
}
|
|
6
|
+
interface NewOrder {
|
|
7
|
+
buyerDisplayName?: string;
|
|
8
|
+
buyerId?: string;
|
|
9
|
+
items?: OrderItem[];
|
|
10
|
+
totalAmount?: number;
|
|
11
|
+
storeId?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare const onOrderCreateHandler: FirestoreTriggerHandler<null, NewOrder>;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { storeRepository, userRepository } from "../../../../repositories";
|
|
2
|
+
import { decryptPii } from "../../../../security/index";
|
|
3
|
+
import { sendWhatsAppBusinessMessage, buildPurchaseAnnouncementMessage, } from "../../../../features/whatsapp-bot/server";
|
|
4
|
+
async function sendAnnouncement(ctx, toPhone, message, phoneNumberId, accessToken, label, orderId) {
|
|
5
|
+
try {
|
|
6
|
+
const sent = await sendWhatsAppBusinessMessage({
|
|
7
|
+
toPhone,
|
|
8
|
+
message,
|
|
9
|
+
phoneNumberId,
|
|
10
|
+
accessToken,
|
|
11
|
+
});
|
|
12
|
+
if (sent) {
|
|
13
|
+
ctx.logger.info(`Announcement sent to ${label}`, {
|
|
14
|
+
orderId,
|
|
15
|
+
toPhone: `...${toPhone.slice(-4)}`,
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
ctx.logger.error(`Announcement delivery failed for ${label} (non-fatal)`, null, { orderId });
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
catch (err) {
|
|
23
|
+
ctx.logger.error(`Announcement send threw for ${label} (non-fatal)`, err, { orderId });
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export const onOrderCreateHandler = async (event, ctx) => {
|
|
27
|
+
const order = event.after;
|
|
28
|
+
if (!order) {
|
|
29
|
+
ctx.logger.error("No snapshot data", null);
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const orderId = event.params.orderId;
|
|
33
|
+
const phoneNumberId = ctx.env("WHATSAPP_PHONE_NUMBER_ID") ?? "";
|
|
34
|
+
const accessToken = ctx.env("WHATSAPP_CLOUD_API_TOKEN") ?? "";
|
|
35
|
+
if (!phoneNumberId || !accessToken) {
|
|
36
|
+
ctx.logger.info("WhatsApp Cloud API not configured — skipping announcement", { orderId });
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
const items = order.items ?? [];
|
|
40
|
+
const firstItem = items[0];
|
|
41
|
+
const firstItemName = firstItem?.title ?? firstItem?.name ?? "an item";
|
|
42
|
+
const additionalItemCount = Math.max(0, items.length - 1);
|
|
43
|
+
const buyerName = order.buyerDisplayName ?? "A customer";
|
|
44
|
+
const message = buildPurchaseAnnouncementMessage({
|
|
45
|
+
buyerName,
|
|
46
|
+
firstItemName,
|
|
47
|
+
additionalItemCount,
|
|
48
|
+
totalAmount: order.totalAmount ?? 0,
|
|
49
|
+
orderId,
|
|
50
|
+
});
|
|
51
|
+
const adminNumbersRaw = ctx.env("WHATSAPP_ADMIN_NOTIFY_NUMBERS") ?? "";
|
|
52
|
+
const adminNumbers = adminNumbersRaw
|
|
53
|
+
.split(",")
|
|
54
|
+
.map((n) => n.trim().replace(/\D/g, ""))
|
|
55
|
+
.filter(Boolean);
|
|
56
|
+
for (const num of adminNumbers) {
|
|
57
|
+
await sendAnnouncement(ctx, num, message, phoneNumberId, accessToken, "admin", orderId);
|
|
58
|
+
}
|
|
59
|
+
const storeId = order.storeId;
|
|
60
|
+
if (storeId) {
|
|
61
|
+
try {
|
|
62
|
+
const store = await storeRepository.findBySlug(storeId);
|
|
63
|
+
if (store?.ownerId) {
|
|
64
|
+
const owner = await userRepository.findById(store.ownerId);
|
|
65
|
+
const encryptedPhone = owner?.phoneNumber;
|
|
66
|
+
if (encryptedPhone) {
|
|
67
|
+
const ownerPhone = decryptPii(encryptedPhone);
|
|
68
|
+
if (ownerPhone) {
|
|
69
|
+
await sendAnnouncement(ctx, ownerPhone, message, phoneNumberId, accessToken, "store-owner", orderId);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
catch (err) {
|
|
75
|
+
ctx.logger.error("Store owner lookup failed (non-fatal)", err, { orderId, storeId });
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
ctx.logger.info(`Order announcement complete`, {
|
|
79
|
+
orderId,
|
|
80
|
+
adminCount: adminNumbers.length,
|
|
81
|
+
storeId: storeId ?? "unknown",
|
|
82
|
+
});
|
|
83
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { FirestoreTriggerHandler } from "../runtime/types";
|
|
2
|
+
type OrderStatus = "pending" | "confirmed" | "shipped" | "delivered" | "cancelled" | "returned";
|
|
3
|
+
type OrderAfter = {
|
|
4
|
+
status: OrderStatus;
|
|
5
|
+
userId: string;
|
|
6
|
+
userEmail: string;
|
|
7
|
+
productTitle: string;
|
|
8
|
+
trackingNumber?: string;
|
|
9
|
+
};
|
|
10
|
+
type OrderBefore = {
|
|
11
|
+
status: OrderStatus;
|
|
12
|
+
};
|
|
13
|
+
export declare const onOrderStatusChangeHandler: FirestoreTriggerHandler<OrderBefore, OrderAfter>;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { notificationRepository } from "../../../../repositories";
|
|
2
|
+
import { decryptPii } from "../../../../security/index";
|
|
3
|
+
import { getAdminRealtimeDb } from "../../../../providers/db-firebase";
|
|
4
|
+
import { ORDER_MESSAGES, EMAIL_SUBJECTS, JOB_ERROR_MESSAGES } from "./messages";
|
|
5
|
+
const STATUS_CONFIG = {
|
|
6
|
+
confirmed: {
|
|
7
|
+
type: "order_confirmed",
|
|
8
|
+
title: ORDER_MESSAGES.CONFIRMED_TITLE,
|
|
9
|
+
message: (o) => ORDER_MESSAGES.CONFIRMED_MESSAGE(o.productTitle),
|
|
10
|
+
priority: "normal",
|
|
11
|
+
sendEmail: true,
|
|
12
|
+
},
|
|
13
|
+
shipped: {
|
|
14
|
+
type: "order_shipped",
|
|
15
|
+
title: ORDER_MESSAGES.SHIPPED_TITLE,
|
|
16
|
+
message: (o) => ORDER_MESSAGES.SHIPPED_MESSAGE(o.productTitle, o.trackingNumber),
|
|
17
|
+
priority: "high",
|
|
18
|
+
sendEmail: true,
|
|
19
|
+
},
|
|
20
|
+
delivered: {
|
|
21
|
+
type: "order_delivered",
|
|
22
|
+
title: ORDER_MESSAGES.DELIVERED_TITLE,
|
|
23
|
+
message: (o) => ORDER_MESSAGES.DELIVERED_MESSAGE(o.productTitle),
|
|
24
|
+
priority: "normal",
|
|
25
|
+
sendEmail: true,
|
|
26
|
+
},
|
|
27
|
+
cancelled: {
|
|
28
|
+
type: "order_cancelled",
|
|
29
|
+
title: ORDER_MESSAGES.CANCELLED_TITLE,
|
|
30
|
+
message: (o) => `Your order for "${o.productTitle}" has been cancelled.`,
|
|
31
|
+
priority: "normal",
|
|
32
|
+
sendEmail: false,
|
|
33
|
+
},
|
|
34
|
+
};
|
|
35
|
+
async function sendResendEmail(params) {
|
|
36
|
+
const subject = params.status === "confirmed"
|
|
37
|
+
? EMAIL_SUBJECTS.ORDER_CONFIRMED(params.productTitle)
|
|
38
|
+
: params.status === "shipped"
|
|
39
|
+
? EMAIL_SUBJECTS.ORDER_SHIPPED(params.productTitle)
|
|
40
|
+
: params.status === "delivered"
|
|
41
|
+
? EMAIL_SUBJECTS.ORDER_DELIVERED(params.productTitle)
|
|
42
|
+
: EMAIL_SUBJECTS.ORDER_UPDATE_FALLBACK(params.productTitle);
|
|
43
|
+
const response = await fetch("https://api.resend.com/emails", {
|
|
44
|
+
method: "POST",
|
|
45
|
+
headers: {
|
|
46
|
+
Authorization: `Bearer ${params.apiKey}`,
|
|
47
|
+
"Content-Type": "application/json",
|
|
48
|
+
},
|
|
49
|
+
body: JSON.stringify({
|
|
50
|
+
from: params.fromAddress,
|
|
51
|
+
to: [params.to],
|
|
52
|
+
subject,
|
|
53
|
+
html: `<p>Hi,</p><p>Your order for <strong>${params.productTitle}</strong> is now <strong>${params.status}</strong>.</p>${params.trackingNumber ? `<p>Tracking number: ${params.trackingNumber}</p>` : ""}<p>Thanks,<br/>${params.brandName} Team</p>`,
|
|
54
|
+
}),
|
|
55
|
+
});
|
|
56
|
+
if (!response.ok) {
|
|
57
|
+
const body = await response.text();
|
|
58
|
+
throw new Error(JOB_ERROR_MESSAGES.RESEND_API_ERROR(response.status, body));
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
export const onOrderStatusChangeHandler = async (event, ctx) => {
|
|
62
|
+
const { before, after } = event;
|
|
63
|
+
if (!before || !after)
|
|
64
|
+
return;
|
|
65
|
+
if (before.status === after.status)
|
|
66
|
+
return;
|
|
67
|
+
const orderId = event.params.orderId;
|
|
68
|
+
const newStatus = after.status;
|
|
69
|
+
const config = STATUS_CONFIG[newStatus];
|
|
70
|
+
if (!config) {
|
|
71
|
+
ctx.logger.info(`No handler for status transition → ${newStatus}`, { orderId });
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
// Decrypt PII that was encrypted at rest
|
|
75
|
+
const userEmail = decryptPii(after.userEmail);
|
|
76
|
+
try {
|
|
77
|
+
const messageText = config.message({
|
|
78
|
+
productTitle: after.productTitle,
|
|
79
|
+
trackingNumber: after.trackingNumber,
|
|
80
|
+
});
|
|
81
|
+
await notificationRepository.create({
|
|
82
|
+
userId: after.userId,
|
|
83
|
+
type: config.type,
|
|
84
|
+
priority: config.priority,
|
|
85
|
+
title: config.title,
|
|
86
|
+
message: messageText,
|
|
87
|
+
relatedId: orderId,
|
|
88
|
+
relatedType: "order",
|
|
89
|
+
});
|
|
90
|
+
try {
|
|
91
|
+
await getAdminRealtimeDb().ref(`notifications/${after.userId}`).push({
|
|
92
|
+
type: config.type,
|
|
93
|
+
title: config.title,
|
|
94
|
+
message: messageText,
|
|
95
|
+
timestamp: Date.now(),
|
|
96
|
+
read: false,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
catch (rtdbError) {
|
|
100
|
+
ctx.logger.error("Realtime DB push failed (non-fatal)", rtdbError);
|
|
101
|
+
}
|
|
102
|
+
if (config.sendEmail) {
|
|
103
|
+
const apiKey = ctx.env("RESEND_API_KEY") ?? "";
|
|
104
|
+
if (!apiKey) {
|
|
105
|
+
ctx.logger.error(JOB_ERROR_MESSAGES.RESEND_KEY_MISSING, null);
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
try {
|
|
109
|
+
const fromAddress = ctx.env("ORDER_EMAIL_FROM") ?? ctx.env("RESEND_FROM_ADDRESS") ?? "";
|
|
110
|
+
const brandName = ctx.env("APPKIT_BRAND_NAME") ?? "";
|
|
111
|
+
if (!fromAddress || !brandName) {
|
|
112
|
+
ctx.logger.error("ORDER_EMAIL_FROM / APPKIT_BRAND_NAME not configured — skipping order status email", null, { orderId });
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
await sendResendEmail({
|
|
116
|
+
to: userEmail,
|
|
117
|
+
status: newStatus,
|
|
118
|
+
orderId,
|
|
119
|
+
productTitle: after.productTitle,
|
|
120
|
+
trackingNumber: after.trackingNumber,
|
|
121
|
+
apiKey,
|
|
122
|
+
fromAddress,
|
|
123
|
+
brandName,
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
catch (emailError) {
|
|
128
|
+
ctx.logger.error("Email send failed (non-fatal)", emailError, { orderId });
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
ctx.logger.info(`Order ${orderId} status → ${newStatus}`, {
|
|
133
|
+
userId: after.userId,
|
|
134
|
+
emailSent: config.sendEmail,
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
catch (error) {
|
|
138
|
+
ctx.logger.error("Error handling order status change", error, { orderId });
|
|
139
|
+
throw error;
|
|
140
|
+
}
|
|
141
|
+
};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trigger handler: keep category metrics + store stats in sync when a
|
|
3
|
+
* product document is written. Only published products count.
|
|
4
|
+
*/
|
|
5
|
+
import type { FirestoreTriggerHandler } from "../runtime/types";
|
|
6
|
+
type ProductDoc = Record<string, unknown>;
|
|
7
|
+
export declare const onProductWriteHandler: FirestoreTriggerHandler<ProductDoc, ProductDoc>;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trigger handler: keep category metrics + store stats in sync when a
|
|
3
|
+
* product document is written. Only published products count.
|
|
4
|
+
*/
|
|
5
|
+
import { categoriesRepository, storeRepository } from "../../../../repositories";
|
|
6
|
+
import { ProductStatusValues } from "../../../../features/products/schemas/firestore";
|
|
7
|
+
async function getParentIds(categoryId) {
|
|
8
|
+
if (!categoryId)
|
|
9
|
+
return [];
|
|
10
|
+
return (await categoriesRepository.findById(categoryId))?.parentIds ?? [];
|
|
11
|
+
}
|
|
12
|
+
export const onProductWriteHandler = async (event, ctx) => {
|
|
13
|
+
const productId = event.params.productId;
|
|
14
|
+
const before = event.before;
|
|
15
|
+
const after = event.after;
|
|
16
|
+
const beforeStatus = before?.status ?? null;
|
|
17
|
+
const afterStatus = after?.status ?? null;
|
|
18
|
+
const beforeCategory = before?.category ?? null;
|
|
19
|
+
const afterCategory = after?.category ?? null;
|
|
20
|
+
const beforeStoreId = (before?.storeId || before?.sellerId) ?? null;
|
|
21
|
+
const afterStoreId = (after?.storeId || after?.sellerId) ?? null;
|
|
22
|
+
// SB1-G — counters drive product-vs-auction split off the canonical
|
|
23
|
+
// listingType discriminator. Anything not "auction" counts toward products.
|
|
24
|
+
const isAuction = after?.listingType === "auction";
|
|
25
|
+
const beforeIsAuction = before?.listingType === "auction";
|
|
26
|
+
const wasPublished = beforeStatus === ProductStatusValues.PUBLISHED;
|
|
27
|
+
const isPublished = afterStatus === ProductStatusValues.PUBLISHED;
|
|
28
|
+
const isDelete = !after;
|
|
29
|
+
try {
|
|
30
|
+
if (isDelete && wasPublished && beforeCategory) {
|
|
31
|
+
const parentIds = await getParentIds(beforeCategory);
|
|
32
|
+
const batch = ctx.db.batch();
|
|
33
|
+
categoriesRepository.updateMetricsInBatch(batch, beforeCategory, parentIds, beforeIsAuction ? 0 : -1, beforeIsAuction ? -1 : 0, productId);
|
|
34
|
+
await batch.commit();
|
|
35
|
+
if (beforeStoreId)
|
|
36
|
+
await storeRepository.incrementTotalProducts(beforeStoreId, -1);
|
|
37
|
+
ctx.logger.info("Decremented counters on hard-delete", {
|
|
38
|
+
productId,
|
|
39
|
+
category: beforeCategory,
|
|
40
|
+
storeId: beforeStoreId,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
else if (!wasPublished && isPublished && afterCategory) {
|
|
44
|
+
const parentIds = await getParentIds(afterCategory);
|
|
45
|
+
const batch = ctx.db.batch();
|
|
46
|
+
categoriesRepository.updateMetricsInBatch(batch, afterCategory, parentIds, isAuction ? 0 : 1, isAuction ? 1 : 0, productId);
|
|
47
|
+
await batch.commit();
|
|
48
|
+
if (afterStoreId)
|
|
49
|
+
await storeRepository.incrementTotalProducts(afterStoreId, 1);
|
|
50
|
+
ctx.logger.info("Incremented counters on publish", {
|
|
51
|
+
productId,
|
|
52
|
+
category: afterCategory,
|
|
53
|
+
storeId: afterStoreId,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
else if (wasPublished && !isPublished && beforeCategory) {
|
|
57
|
+
const parentIds = await getParentIds(beforeCategory);
|
|
58
|
+
const batch = ctx.db.batch();
|
|
59
|
+
categoriesRepository.updateMetricsInBatch(batch, beforeCategory, parentIds, beforeIsAuction ? 0 : -1, beforeIsAuction ? -1 : 0, productId);
|
|
60
|
+
await batch.commit();
|
|
61
|
+
if (beforeStoreId)
|
|
62
|
+
await storeRepository.incrementTotalProducts(beforeStoreId, -1);
|
|
63
|
+
ctx.logger.info("Decremented counters on unpublish", {
|
|
64
|
+
productId,
|
|
65
|
+
category: beforeCategory,
|
|
66
|
+
storeId: beforeStoreId,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
else if (wasPublished &&
|
|
70
|
+
isPublished &&
|
|
71
|
+
beforeCategory &&
|
|
72
|
+
afterCategory &&
|
|
73
|
+
beforeCategory !== afterCategory) {
|
|
74
|
+
const [beforeParents, afterParents] = await Promise.all([
|
|
75
|
+
getParentIds(beforeCategory),
|
|
76
|
+
getParentIds(afterCategory),
|
|
77
|
+
]);
|
|
78
|
+
const batch = ctx.db.batch();
|
|
79
|
+
categoriesRepository.updateMetricsInBatch(batch, beforeCategory, beforeParents, beforeIsAuction ? 0 : -1, beforeIsAuction ? -1 : 0, productId);
|
|
80
|
+
categoriesRepository.updateMetricsInBatch(batch, afterCategory, afterParents, isAuction ? 0 : 1, isAuction ? 1 : 0, productId);
|
|
81
|
+
await batch.commit();
|
|
82
|
+
ctx.logger.info("Moved product between categories", {
|
|
83
|
+
productId,
|
|
84
|
+
from: beforeCategory,
|
|
85
|
+
to: afterCategory,
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
catch (err) {
|
|
90
|
+
ctx.logger.error("Counter update failed (non-fatal)", err, { productId });
|
|
91
|
+
}
|
|
92
|
+
};
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { reviewRepository, storeRepository } from "../../../../repositories";
|
|
2
|
+
import { ReviewStatusValues } from "../../../../features/reviews/schemas/firestore";
|
|
3
|
+
import { PRODUCT_COLLECTION } from "../../../../features/products/schemas/firestore";
|
|
4
|
+
export const onReviewWriteHandler = async (event, ctx) => {
|
|
5
|
+
const reviewId = event.params.reviewId;
|
|
6
|
+
const beforeData = event.before;
|
|
7
|
+
const afterData = event.after;
|
|
8
|
+
const beforeStatus = beforeData?.status ?? null;
|
|
9
|
+
const afterStatus = afterData?.status ?? null;
|
|
10
|
+
const wasApproved = beforeStatus === ReviewStatusValues.APPROVED;
|
|
11
|
+
const isApproved = afterStatus === ReviewStatusValues.APPROVED;
|
|
12
|
+
if (!wasApproved && !isApproved)
|
|
13
|
+
return;
|
|
14
|
+
const data = afterData ?? beforeData;
|
|
15
|
+
if (!data)
|
|
16
|
+
return;
|
|
17
|
+
const productId = data.productId ?? null;
|
|
18
|
+
const storeId = data.storeId ?? null;
|
|
19
|
+
if (!productId) {
|
|
20
|
+
ctx.logger.error("Review has no productId — skipping", null, { reviewId });
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
try {
|
|
24
|
+
const { count, avgRating } = await reviewRepository.getApprovedRatingAggregate(productId);
|
|
25
|
+
await ctx.db.collection(PRODUCT_COLLECTION).doc(productId).update({
|
|
26
|
+
avgRating,
|
|
27
|
+
reviewCount: count,
|
|
28
|
+
updatedAt: new Date(),
|
|
29
|
+
});
|
|
30
|
+
ctx.logger.info("Updated product rating stats", {
|
|
31
|
+
reviewId,
|
|
32
|
+
productId,
|
|
33
|
+
count,
|
|
34
|
+
avgRating,
|
|
35
|
+
});
|
|
36
|
+
if (storeId) {
|
|
37
|
+
const storeStats = await reviewRepository.getApprovedRatingAggregateByStore(storeId);
|
|
38
|
+
await storeRepository.updateReviewStats(storeId, storeStats.count, storeStats.avgRating);
|
|
39
|
+
ctx.logger.info("Updated store review stats", {
|
|
40
|
+
reviewId,
|
|
41
|
+
storeId,
|
|
42
|
+
count: storeStats.count,
|
|
43
|
+
avgRating: storeStats.avgRating,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
catch (err) {
|
|
48
|
+
ctx.logger.error("Failed to update rating stats", err, { reviewId, productId, storeId });
|
|
49
|
+
throw err;
|
|
50
|
+
}
|
|
51
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trigger handler: stores/{id} onWrite — currently a no-op. The previous
|
|
3
|
+
* implementation synced an external search index that has since been removed.
|
|
4
|
+
* The handler stays so the binding remains canonical and can be reactivated
|
|
5
|
+
* without touching the consumer's functions/src/index.ts.
|
|
6
|
+
*/
|
|
7
|
+
import type { FirestoreTriggerHandler } from "../runtime/types";
|
|
8
|
+
type StoreDoc = Record<string, unknown>;
|
|
9
|
+
export declare const onStoreWriteHandler: FirestoreTriggerHandler<StoreDoc, StoreDoc>;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Trigger handler: stores/{id} onWrite — currently a no-op. The previous
|
|
3
|
+
* implementation synced an external search index that has since been removed.
|
|
4
|
+
* The handler stays so the binding remains canonical and can be reactivated
|
|
5
|
+
* without touching the consumer's functions/src/index.ts.
|
|
6
|
+
*/
|
|
7
|
+
export const onStoreWriteHandler = async () => {
|
|
8
|
+
// Intentionally empty — search provider removed; Firestore queries handle search now.
|
|
9
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Job handler: dispatch pending payouts via Razorpay Payouts API.
|
|
3
|
+
*
|
|
4
|
+
* Reads RAZORPAY_KEY_ID / RAZORPAY_KEY_SECRET / RAZORPAY_ACCOUNT_NUMBER from
|
|
5
|
+
* env (via `ctx.env`). On 3rd consecutive failure the record is marked failed.
|
|
6
|
+
*
|
|
7
|
+
* Brand name in the narration is taken from `ctx.env("APP_BRAND_NAME")`
|
|
8
|
+
* (default empty) so appkit stays consumer-agnostic.
|
|
9
|
+
*/
|
|
10
|
+
import type { ScheduleHandler } from "../runtime/types";
|
|
11
|
+
export declare const payoutBatchHandler: ScheduleHandler;
|