Total Sales
$${results.totalSales.toLocaleString()}
Total Commissions
$${results.totalCommissions.toLocaleString()}
| Affiliate | Direct Comm. | Downline Comm. | Total Earnings |
|---|---|---|---|
| ${affiliate.name} (ID: ${affiliate.id}) | $${affiliate.directCommission.toFixed(2)} | $${affiliate.downlineCommission.toFixed(2)} | $${affiliate.totalCommission.toFixed(2)} |
${pdfContent}
`;
html2canvas(pdfRenderContainer, { scale: 2 }).then(canvas => {
const imgData = canvas.toDataURL('image/png');
const { jsPDF } = window.jspdf;
const pdf = new jsPDF({ orientation: 'portrait', unit: 'pt', format: 'a4' });
const pdfWidth = pdf.internal.pageSize.getWidth(), margin = 40;
const contentWidth = pdfWidth - margin * 2;
const pdfHeight = (canvas.height * contentWidth) / canvas.width;
pdf.addImage(imgData, 'PNG', margin, margin, contentWidth, pdfHeight);
pdf.save('Affiliate-Commission-Report.pdf');
});
};
// --- EVENT LISTENERS ---
window.switchTab = switchTab;
window.navigateTabs = navigateTabs;
calculateBtn.addEventListener('click', handleCalculation);
downloadPdfBtn.addEventListener('click', handlePdfDownload);
addAffiliateBtn.addEventListener('click', () => { affiliates.push({ id: nextAffiliateId++, name: 'New Affiliate', uplineId: null }); renderConfigTables(); });
addSaleBtn.addEventListener('click', () => { sales.push({ id: nextSaleId++, affiliateId: 1, amount: 0 }); renderConfigTables(); });
document.getElementById('config-table-container').addEventListener('input', e => {
if (!e.target.classList.contains('cfg-input')) return;
const id = parseInt(e.target.closest('tr').dataset.id);
const prop = e.target.dataset.prop;
const container = e.target.closest('tbody').id;
const dataArray = container === 'affiliates-table-body' ? affiliates : sales;
const item = dataArray.find(i => i.id === id);
if (item) item[prop] = e.target.type === 'number' ? (parseFloat(e.target.value) || null) : e.target.value;
});
document.getElementById('config-table-container').addEventListener('click', e => {
if (!e.target.classList.contains('rm-btn')) return;
const id = parseInt(e.target.closest('tr').dataset.id);
const container = e.target.closest('tbody').id;
if (container === 'affiliates-table-body') affiliates = affiliates.filter(i => i.id !== id);
else sales = sales.filter(i => i.id !== id);
renderConfigTables();
});
// --- INITIALIZATION ---
renderConfigTables();
updateNavButtons();
switchTab('dashboard');
});
