feat(loyalty): implement Phase 2 - company-wide points system
Complete implementation of loyalty module Phase 2 features: Database & Models: - Add company_id to LoyaltyProgram for chain-wide loyalty - Add company_id to LoyaltyCard for multi-location support - Add CompanyLoyaltySettings model for admin-controlled settings - Add points expiration, welcome bonus, and minimum redemption fields - Add POINTS_EXPIRED, WELCOME_BONUS transaction types Services: - Update program_service for company-based queries - Update card_service with enrollment and welcome bonus - Update points_service with void_points for returns - Update stamp_service for company context - Update pin_service for company-wide operations API Endpoints: - Admin: Program listing with stats, company detail views - Vendor: Terminal operations, card management, settings - Storefront: Customer card/transactions, self-enrollment UI Templates: - Admin: Programs dashboard, company detail, settings - Vendor: Terminal, cards list, card detail, settings, stats, enrollment - Storefront: Dashboard, history, enrollment, success pages Background Tasks: - Point expiration task (daily, based on inactivity) - Wallet sync task (hourly) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -3,8 +3,17 @@
|
||||
Loyalty module Celery tasks.
|
||||
|
||||
Background tasks for:
|
||||
- Point expiration
|
||||
- Wallet synchronization
|
||||
- Point expiration (daily at 02:00)
|
||||
- Wallet synchronization (hourly)
|
||||
|
||||
Task registration is handled by the module definition in definition.py
|
||||
which specifies the task paths and schedules.
|
||||
"""
|
||||
|
||||
__all__: list[str] = []
|
||||
from app.modules.loyalty.tasks.point_expiration import expire_points
|
||||
from app.modules.loyalty.tasks.wallet_sync import sync_wallet_passes
|
||||
|
||||
__all__ = [
|
||||
"expire_points",
|
||||
"sync_wallet_passes",
|
||||
]
|
||||
|
||||
Reference in New Issue
Block a user