`;
// Chart
html += ``;
html += `
`;
outputDiv.innerHTML = html;
// Render Chart
const ctx = document.getElementById('costChart').getContext('2d');
new Chart(ctx, {
type: 'pie',
data: {
labels: ['Accommodation', 'Food', 'Co-working'],
datasets: [{
data: [results.accommodationCost, results.foodCost, results.coworkingCost],
backgroundColor: ['#22D3EE', '#06B6D4', '#0891B2'],
}]
},
options: {
responsive: true,
plugins: {
legend: { position: 'top' },
title: { display: true, text: 'Expense Distribution' }
}
}
});
}
// --- 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('Workcation_Cost_Estimate.pdf');
loader.style.display = 'none';
});
}
