Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 | // API route for generating addition worksheet previews (SVG) import { NextResponse } from 'next/server' import { generateWorksheetPreview } from '@/app/create/worksheets/generatePreview' import type { WorksheetFormState } from '@/app/create/worksheets/types' import { withAuth } from '@/lib/auth/withAuth' export const dynamic = 'force-dynamic' export const POST = withAuth(async (request) => { const requestStart = Date.now() try { const body: WorksheetFormState = await request.json() // Parse pagination parameters from query string const { searchParams } = new URL(request.url) console.log('[API] Preview request:', { pages: body.pages, problemsPerPage: body.problemsPerPage, total: (body.problemsPerPage ?? 20) * (body.pages ?? 1), startPage: searchParams.get('startPage'), endPage: searchParams.get('endPage'), mode: body.mode, operator: body.operator, displayRules: body.displayRules, additionDisplayRules: (body as any).additionDisplayRules, subtractionDisplayRules: (body as any).subtractionDisplayRules, }) // Support cursor-based pagination (GraphQL style) const cursor = searchParams.get('cursor') const limit = searchParams.get('limit') // Support range-based pagination (traditional) const startPageParam = searchParams.get('startPage') const endPageParam = searchParams.get('endPage') let startPage: number | undefined let endPage: number | undefined // Cursor-based: cursor=3&limit=5 means pages [3, 4, 5, 6, 7] if (cursor !== null) { startPage = Number.parseInt(cursor, 10) if (limit !== null) { const limitNum = Number.parseInt(limit, 10) endPage = startPage + limitNum - 1 } } // Range-based: startPage=3&endPage=7 means pages [3, 4, 5, 6, 7] else if (startPageParam !== null || endPageParam !== null) { if (startPageParam !== null) { startPage = Number.parseInt(startPageParam, 10) } if (endPageParam !== null) { endPage = Number.parseInt(endPageParam, 10) } } // Generate preview using shared logic with pagination const result = await generateWorksheetPreview(body, startPage, endPage) if (!result.success) { return NextResponse.json( { error: result.error, details: result.details, }, { status: 400 } ) } const requestTime = Date.now() - requestStart console.log(`[API] Preview request completed in ${requestTime}ms`) // Return pages with metadata return NextResponse.json({ pages: result.pages, totalPages: result.totalPages, startPage: result.startPage, endPage: result.endPage, warnings: result.warnings, // Include cursor for next page (GraphQL style) nextCursor: result.endPage !== undefined && result.totalPages !== undefined && result.endPage < result.totalPages - 1 ? result.endPage + 1 : null, }) } catch (error) { console.error('Error generating preview:', error) const errorMessage = error instanceof Error ? error.message : String(error) return NextResponse.json( { error: 'Failed to generate preview', message: errorMessage, }, { status: 500 } ) } }) |