Mobile app: - Révision flashcards : liste decks, session flip-card SM-2, couleurs harmonisées web - Génération flashcards depuis note (FlashcardSheet + route /api/mobile/flashcards/generate) - Audio Whisper : hook useAudioRecorder reécrit, MicButton avec erreurs - IA : AISheet (améliorer/clarifier/résumer), TitleSheet (titre automatique) - Suppression note (soft delete + confirmation Alert) - Note du jour : titre lisible + HTML (plus JSON TipTap brut) - Parser TipTap→HTML côté mobile (tipTapToHtml) - Icône 🎓 dans header note → génération flashcards - Endpoint flashcardGenerate dans config.ts Web fixes: - Bug flashcards groupées par carnet → deck par note (migration + schema) - Bug filtre 'cartes dues' ignoré (suppression fallback buildSessionQueue) - Suppression UI création deck manuelle (inutile) - Fix setViewType is not defined dans home-client.tsx Drag handle menu: - Fix : clearNodes() avant transformation (heading→liste/code/citation) - Ajout : option 'Texte' (paragraphe) dans Transformer en - Ajout : Monter / Descendre le bloc - Ajout : Copier le contenu du bloc - Fix : sous-menu hover stable (délai 200ms) - Fix : Supprimer en rouge via classe --danger (plus :first-child) - i18n : nouvelles clés dans 15 locales Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
39 lines
1.2 KiB
TypeScript
39 lines
1.2 KiB
TypeScript
import { NextRequest, NextResponse } from 'next/server'
|
|
import prisma from '@/lib/prisma'
|
|
import { getMobileUserId } from '@/lib/mobile-auth'
|
|
|
|
export async function GET(req: NextRequest) {
|
|
const userId = getMobileUserId(req)
|
|
if (!userId) return NextResponse.json({ error: 'Unauthorized' }, { status: 401 })
|
|
|
|
const { searchParams } = new URL(req.url)
|
|
const deckId = searchParams.get('deckId')
|
|
const limit = Math.min(parseInt(searchParams.get('limit') ?? '20', 10), 50)
|
|
|
|
if (!deckId) return NextResponse.json({ error: 'deckId required' }, { status: 400 })
|
|
|
|
// Vérifier ownership
|
|
const deck = await prisma.flashcardDeck.findFirst({
|
|
where: { id: deckId, userId },
|
|
select: { id: true, name: true },
|
|
})
|
|
if (!deck) return NextResponse.json({ error: 'Deck not found' }, { status: 404 })
|
|
|
|
const now = new Date()
|
|
const cards = await prisma.flashcard.findMany({
|
|
where: { deckId, nextReviewAt: { lte: now } },
|
|
select: {
|
|
id: true,
|
|
front: true,
|
|
back: true,
|
|
interval: true,
|
|
easinessFactor: true,
|
|
type: true,
|
|
},
|
|
orderBy: { nextReviewAt: 'asc' },
|
|
take: limit,
|
|
})
|
|
|
|
return NextResponse.json({ deck: { id: deck.id, name: deck.name }, cards })
|
|
}
|