Files
trade-assistant/backend/app/api/v1/interaction.py
T
TradeMate Dev 7b62c2f8b4 feat: 修复 H5 底部导航覆盖 + 更新项目进度文档
## H5 底部导航修复 (Bug #10)
- 精简 App.vue,移除重复 tabbar,仅保留全局样式
- uni-page 设置 height: calc(100% - 50px) + overflow-y: auto
- 内容区域精确停在底部导航上方,独立滚动不再叠加
- 恢复 custom-tab-bar 组件

## 项目进度文档
- PROGRESS.md 更新至 10 个 Bug 修复
- 新增 H5 底部导航修复记录
- 新增历史变更条目
2026-05-12 20:24:42 +08:00

103 lines
3.3 KiB
Python

from fastapi import APIRouter, Depends, HTTPException
from sqlalchemy.ext.asyncio import AsyncSession
from typing import Annotated
from app.database import get_db
from app.services.preference import UserPreferenceService
from app.services.marketing_effect import MarketingEffectService
from app.api.v1.deps import get_current_user_id
router = APIRouter()
@router.post("/select")
async def record_selection(
data: dict,
user_id: str = Depends(get_current_user_id),
db: Annotated[AsyncSession, Depends(get_db)] = None,
):
message_id = data.get("message_id")
selected_index = data.get("selected_index")
if message_id is None or selected_index is None:
raise HTTPException(status_code=400, detail="message_id and selected_index required")
service = UserPreferenceService(db)
success = await service.record_selection(user_id, message_id, selected_index)
if not success:
raise HTTPException(status_code=404, detail="Message not found")
return {"status": "ok"}
@router.post("/edit")
async def record_edit(
data: dict,
user_id: str = Depends(get_current_user_id),
db: Annotated[AsyncSession, Depends(get_db)] = None,
):
message_id = data.get("message_id")
edited_text = data.get("edited_text")
if not message_id or edited_text is None:
raise HTTPException(status_code=400, detail="message_id and edited_text required")
service = UserPreferenceService(db)
success = await service.record_edit(user_id, message_id, edited_text)
if not success:
raise HTTPException(status_code=404, detail="Message not found")
return {"status": "ok"}
@router.post("/analyze")
async def analyze_preferences(
user_id: str = Depends(get_current_user_id),
db: Annotated[AsyncSession, Depends(get_db)] = None,
):
service = UserPreferenceService(db)
preferences = await service.analyze_preferences(user_id)
return preferences
@router.get("/preferences")
async def get_preferences(
user_id: str = Depends(get_current_user_id),
db: Annotated[AsyncSession, Depends(get_db)] = None,
):
service = UserPreferenceService(db)
return await service.get_analysis(user_id)
@router.post("/marketing-effect")
async def track_marketing_effect(
data: dict,
user_id: str = Depends(get_current_user_id),
db: Annotated[AsyncSession, Depends(get_db)] = None,
):
service = MarketingEffectService(db)
result = await service.track_event(
user_id=user_id,
content=data.get("content", ""),
product_id=data.get("product_id"),
product_name=data.get("product_name"),
channel=data.get("channel", "copy"),
event_type=data.get("event_type", "copy"),
target_audience=data.get("target_audience", ""),
metadata=data.get("metadata"),
)
return result
@router.get("/marketing-effects")
async def get_marketing_effects(
page: int = 1,
size: int = 20,
user_id: str = Depends(get_current_user_id),
db: Annotated[AsyncSession, Depends(get_db)] = None,
):
service = MarketingEffectService(db)
return await service.get_effects(user_id, page, size)
@router.get("/marketing-effects/stats")
async def get_marketing_effect_stats(
user_id: str = Depends(get_current_user_id),
db: Annotated[AsyncSession, Depends(get_db)] = None,
):
service = MarketingEffectService(db)
return await service.get_stats(user_id)