Average Cost Per Lead
$${results.overallCpl.toFixed(2)}
`;
// Chart
html += `
`;
html += `
`;
outputDiv.innerHTML = html;
// Render Chart
const ctx = document.getElementById('leadsChart').getContext('2d');
new Chart(ctx, {
type: 'bar',
data: {
labels: results.channelResults.map(r => r.name),
datasets: [{
label: 'Estimated Leads',
data: results.channelResults.map(r => r.leads),
backgroundColor: ['#3B82F6', '#10B981', '#F59E0B', '#EF4444'],
}]
},
options: {
responsive: true,
plugins: {
legend: { display: false },
title: { display: true, text: 'Leads by Channel' }
},
scales: {
y: {
beginAtZero: true
}
}
}
});
}
// --- PDF Download ---
function downloadPDF() {
const { jsPDF } = window.jspdf;
const loader = document.getElementById('loader');
loader.style.display = 'block';
const content = document.getElementById('pdf-content');
html2canvas(content, { scale: 2 }).then(canvas => {
const imgData = canvas.toDataURL('image/png');
const pdf = new jsPDF({ orientation: 'p', unit: 'mm', format: 'a4' });
const pdfWidth = pdf.internal.pageSize.getWidth();
const imgWidth = pdfWidth - 20;
const imgHeight = canvas.height * imgWidth / canvas.width;
let heightLeft = imgHeight;
let position = 10;
pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);
heightLeft -= (pdf.internal.pageSize.getHeight() - 20);
while (heightLeft > 0) {
position = heightLeft - imgHeight + 10;
pdf.addPage();
pdf.addImage(imgData, 'PNG', 10, position, imgWidth, imgHeight);
heightLeft -= (pdf.internal.pageSize.getHeight() - 20);
}
pdf.save('Lead_Generation_Projection.pdf');
loader.style.display = 'none';
});
}