`).join('');
}
// --- UTILITY FUNCTIONS ---
function showNotification(message, duration = 2000) {
notification.textContent = message;
notification.classList.remove('opacity-0');
setTimeout(() => {
notification.classList.add('opacity-0');
}, duration);
}
function copyToClipboard(text, message) {
navigator.clipboard.writeText(text).then(() => {
showNotification(message);
}, () => {
showNotification('Failed to copy.');
});
}
// --- PDF GENERATION ---
async function generatePdfReport() {
if (generatedTitles.length === 0) {
showNotification("No titles to generate a report for.");
return;
}
downloadPdfBtn.disabled = true;
downloadPdfBtn.textContent = 'Generating...';
const titleListItems = generatedTitles.map(title => `${title} `).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' });
const pdfWidth = pdf.internal.pageSize.getWidth();
const pdfHeight = (canvas.height * pdfWidth) / canvas.width;
pdf.addImage(imgData, 'PNG', 0, 0, pdfWidth, pdfHeight);
pdf.save(`Blog_Titles_${keywordInput.value.trim().replace(/\s+/g, '_')}.pdf`);
} catch (e) { console.error('PDF Generation Error:', e); } finally {
downloadPdfBtn.disabled = false;
downloadPdfBtn.textContent = 'Download PDF';
pdfTemplate.classList.add('invisible');
pdfTemplate.innerHTML = '';
}
}
// --- EVENT LISTENERS ---
generateBtn.addEventListener('click', generateTitles);
copyAllBtn.addEventListener('click', () => {
if (generatedTitles.length === 0) {
showNotification("Nothing to copy.");
return;
}
copyToClipboard(generatedTitles.join('\n'), 'All titles copied!');
});
resultsContainer.addEventListener('click', (e) => {
if (e.target.classList.contains('copy-title-btn')) {
const titleText = e.target.previousElementSibling.textContent;
copyToClipboard(titleText, 'Title copied!');
}
});
downloadPdfBtn.addEventListener('click', generatePdfReport);
// --- INITIALIZATION ---
// No tabs to initialize
});
Blog Title Idea Sheet
Generated for Keyword: ${keywordInput.value.trim()}
Generated Titles
- ${titleListItems}
