Avg. CPC
$${avgBid.toFixed(2)}
`;
// Main Table
const dashboardTableBody = document.getElementById('dashboard-table-body');
dashboardTableBody.innerHTML = keywords.map(k => {
const compClass = k.competition === 'High' ? 'text-red-600' : k.competition === 'Medium' ? 'text-yellow-600' : 'text-green-600';
return `
| ${k.name} |
${k.volume.toLocaleString()} |
${k.competition} |
$${k.bidLow.toFixed(2)} |
$${k.bidHigh.toFixed(2)} |
`;
}).join('');
};
// --- EVENT HANDLERS ---
const handleFindKeywords = () => {
const seed = document.getElementById('seed-keyword-input').value.trim().toLowerCase();
if (!seed) { renderDashboard(keyword_db); return; } // Show all if seed is empty
const results = keyword_db.filter(k => k.name.toLowerCase().includes(seed));
renderDashboard(results);
};
const handleConfigChange = (e) => {
const input = e.target;
if (!input.dataset.field) return;
const id = parseInt(input.closest('tr').dataset.id);
const field = input.dataset.field;
const value = (input.type === 'number') ? parseFloat(input.value) || 0 : input.value;
const keyword = keyword_db.find(k => k.id === id);
if(keyword) keyword[field] = value;
};
const handleAddKeyword = () => {
const newId = keyword_db.length > 0 ? Math.max(...keyword_db.map(k => k.id)) + 1 : 1;
keyword_db.push({ id: newId, name: "new keyword", volume: 1000, competition: "Low", bidLow: 1.00, bidHigh: 3.00 });
renderConfigTable();
};
const handleDelete = (e) => {
const btn = e.target.closest('.delete-btn');
if (btn) {
const id = parseInt(btn.closest('tr').dataset.id);
keyword_db = keyword_db.filter(k => k.id !== id);
renderConfigTable();
}
};
const generatePDF = () => {
const pdfContent = document.getElementById('pdf-content');
html2canvas(pdfContent, { scale: 2, useCORS: true }).then(canvas => {
const imgData = canvas.toDataURL('image/png');
const pdf = new jsPDF({ orientation: 'l', unit: 'mm', format: 'a4' });
const pdfWidth = pdf.internal.pageSize.getWidth();
const imgWidth = pdfWidth - 20;
const imgHeight = (canvas.height * imgWidth) / canvas.width;
pdf.setFontSize(22).setFont('helvetica', 'bold').text('Keyword Planner Report', pdfWidth / 2, 15, { align: 'center' });
pdf.addImage(imgData, 'PNG', 10, 25, imgWidth, imgHeight);
pdf.save('keyword-planner-report.pdf');
});
};
// --- ATTACH LISTENERS ---
document.getElementById('prev-btn').addEventListener('click', () => showTab('dashboard'));
document.getElementById('next-btn').addEventListener('click', () => showTab('config'));
tabButtons.dashboard.addEventListener('click', () => showTab('dashboard'));
tabButtons.config.addEventListener('click', () => showTab('config'));
document.getElementById('find-keywords-btn').addEventListener('click', handleFindKeywords);
document.getElementById('add-keyword-btn').addEventListener('click', handleAddKeyword);
document.getElementById('config-table-body').addEventListener('change', handleConfigChange);
document.getElementById('config-table-body').addEventListener('click', handleDelete);
document.getElementById('download-pdf-btn').addEventListener('click', generatePDF);
// --- INITIAL SETUP ---
showTab('dashboard');
});