Files
orion/app/modules/loyalty/schemas/__init__.py
Samir Boulahtit 6161d69ba2 feat(loyalty): cross-persona page alignment with shared components
Align loyalty pages across admin, merchant, and store personas so each
sees the same page set scoped to their access level. Admin acts as a
superset of merchant with "on behalf" capabilities.

New pages:
- Store: Staff PINs management (CRUD)
- Merchant: Cards, Card Detail, Transactions, Staff PINs (CRUD), Settings (read-only)
- Admin: Merchant Cards, Card Detail, Transactions, PINs (read-only)

Architecture:
- 4 shared Jinja2 partials (cards-list, card-detail, transactions, pins)
- 4 shared JS factory modules parameterized by apiPrefix/scope
- Persona templates are thin wrappers including shared partials
- PinDetailResponse schema for cross-store PIN listings

API: 17 new endpoints (11 merchant, 6 admin on-behalf)
Tests: 38 new integration tests, arch-check green
i18n: ~130 new keys across en/fr/de/lb
Docs: pages-and-navigation.md with full page matrix

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-22 19:28:07 +01:00

133 lines
2.8 KiB
Python

# app/modules/loyalty/schemas/__init__.py
"""
Loyalty module Pydantic schemas.
Request and response models for the loyalty API endpoints.
Usage:
from app.modules.loyalty.schemas import (
# Program
ProgramCreate,
ProgramUpdate,
ProgramResponse,
# Card
CardEnrollRequest,
CardResponse,
# Stamp
StampRequest,
StampResponse,
# Points
PointsEarnRequest,
PointsRedeemRequest,
# PIN
PinCreate,
PinVerifyRequest,
)
"""
from app.modules.loyalty.schemas.card import (
CardDetailResponse,
# Card operations
CardEnrollRequest,
CardListResponse,
CardLookupResponse,
CardResponse,
TransactionListResponse,
# Transactions
TransactionResponse,
)
from app.modules.loyalty.schemas.pin import (
# Staff PIN
PinCreate,
PinDetailListResponse,
PinDetailResponse,
PinListResponse,
PinResponse,
PinUpdate,
PinVerifyRequest,
PinVerifyResponse,
)
from app.modules.loyalty.schemas.points import (
PointsAdjustRequest,
PointsAdjustResponse,
# Points operations
PointsEarnRequest,
PointsEarnResponse,
PointsRedeemRequest,
PointsRedeemResponse,
PointsVoidRequest,
PointsVoidResponse,
)
from app.modules.loyalty.schemas.program import (
# Merchant settings
MerchantSettingsResponse,
MerchantSettingsUpdate,
MerchantStatsResponse,
# Points rewards
PointsRewardConfig,
# Program CRUD
ProgramCreate,
ProgramListResponse,
ProgramResponse,
# Stats
ProgramStatsResponse,
ProgramUpdate,
TierConfig,
)
from app.modules.loyalty.schemas.stamp import (
StampRedeemRequest,
StampRedeemResponse,
# Stamp operations
StampRequest,
StampResponse,
StampVoidRequest,
StampVoidResponse,
)
__all__ = [
# Program
"ProgramCreate",
"ProgramUpdate",
"ProgramResponse",
"ProgramListResponse",
"PointsRewardConfig",
"TierConfig",
"ProgramStatsResponse",
"MerchantStatsResponse",
"MerchantSettingsResponse",
"MerchantSettingsUpdate",
# Card
"CardEnrollRequest",
"CardResponse",
"CardDetailResponse",
"CardListResponse",
"CardLookupResponse",
"TransactionResponse",
"TransactionListResponse",
# Stamp
"StampRequest",
"StampResponse",
"StampRedeemRequest",
"StampRedeemResponse",
"StampVoidRequest",
"StampVoidResponse",
# Points
"PointsEarnRequest",
"PointsEarnResponse",
"PointsRedeemRequest",
"PointsRedeemResponse",
"PointsVoidRequest",
"PointsVoidResponse",
"PointsAdjustRequest",
"PointsAdjustResponse",
# PIN
"PinCreate",
"PinUpdate",
"PinResponse",
"PinDetailResponse",
"PinListResponse",
"PinDetailListResponse",
"PinVerifyRequest",
"PinVerifyResponse",
]