function logPDFFailure(error, context) navigator.sendBeacon('/api/log-pdf-error', JSON.stringify( errorCode: error.code, userAction: 'download_pdf', timestamp: Date.now(), page: window.location.pathname, dataSize: context.dataSize ));
// Normal PDF download const blob = await response.blob(); const url = URL.createObjectURL(blob); const a = document.createElement('a'); a.href = url; a.download = 'report.pdf'; a.click(); URL.revokeObjectURL(url); gracefully broken pdf download
"success": false, "error": "code": "PDF_GEN_FAILED", "message": "Could not render chart data: time series missing.", "recoverable": true, "suggestedAction": "retry", "userDataPreserved": true function logPDFFailure(error, context) navigator
Content-Type: application/json
// Frontend / API validation example function validatePDFRequest(data) const issues = []; if (!data.content) issues.push("No content provided"); if (data.content?.length > 500_000) issues.push("Content too large (>500k chars)"); if (data.images?.some(img => img.size > 10_000_000)) issues.push("Image exceeds 10MB limit"); return issues; JSON.stringify( errorCode: error.code
function exportRawData() const formData = collectFormData(); const blob = new Blob([JSON.stringify(formData, null, 2)], type: 'application/json' ); const url = URL.createObjectURL(blob); const a = document.createElement('a'); a.href = url; a.download = 'report-data.json'; a.click(); URL.revokeObjectURL(url); showToast("Raw data saved – you can retry PDF generation later.");