`;
function renderChart(chartData) {
if (allocationChart) allocationChart.destroy();
allocationChart = new Chart(document.getElementById('allocation-chart'), {
type: 'doughnut',
data: {
labels: chartData.labels,
datasets: [{
data: chartData.data,
backgroundColor: ['#312e81', '#4338ca', '#6366f1', '#818cf8', '#a5b4fc', '#c7d2fe']
}]
}
});
}
// --- PDF GENERATION ---
async function generatePdfReport() {
if (!state.analysisResult) return alert("Please run an analysis first.");
downloadPdfBtn.disabled = true;
downloadPdfBtn.textContent = 'Generating...';
const chartImg = allocationChart.toBase64Image();
const { kpis } = state.analysisResult;
const format = (num) => num.toLocaleString('en-US', {maximumFractionDigits: 0});
const tableRows = state.allocations.map(a => `
${a.name}
${a.percentage}%
${format(state.token.totalSupply * a.percentage / 100)}
`).join('');
const reportHtml = `
`;
const pdfTemplate = document.getElementById('pdf-template');
pdfTemplate.innerHTML = reportHtml;
pdfTemplate.classList.remove('invisible');
try {
const { jsPDF } = window.jspdf;
const canvas = await html2canvas(pdfTemplate.querySelector('.pdf-report-container'), { scale: 2 });
const imgData = canvas.toDataURL('image/png');
const pdf = new jsPDF({ orientation: 'p', unit: 'pt', format: 'a4' });
pdf.addImage(imgData, 'PNG', 0, 0, pdf.internal.pageSize.getWidth(), (canvas.height * pdf.internal.pageSize.getWidth()) / canvas.width);
pdf.save(`${state.token.ticker}_Tokenomics_Report.pdf`);
} catch(e) { console.error('PDF Generation Error:', e);
} finally {
downloadPdfBtn.disabled = false;
downloadPdfBtn.textContent = 'Download Analysis Report';
pdfTemplate.classList.add('invisible');
}
}
downloadPdfBtn.addEventListener('click', generatePdfReport);
// --- INITIALIZATION ---
renderAllocations();
attachDataListeners();
runAnalysis();
switchTab(0);
});
Tokenomics Analysis Report
${state.token.name} (${state.token.ticker.toUpperCase()})
Key Metrics
Market Cap
$${format(kpis.marketCap)}
Fully Diluted Valuation
$${format(kpis.fdv)}
Circulating Supply
${kpis.circulatingPercent.toFixed(1)}%
Total Supply
${format(state.token.totalSupply)}
Token Allocation Breakdown
| Category | Percentage | Token Amount |
|---|
