Affiliate Product Description Generator

Affiliate Product Description Generator

Create high-converting product descriptions with AI.

Product Details

Generated Descriptions

Your AI-generated product descriptions will appear here.

An error occurred: ${error.message}

`; showNotification("Error generating content."); } finally { generateBtn.disabled = false; generateBtn.textContent = 'Generate Descriptions'; } } function renderDescriptions() { resultsContainer.innerHTML = generatedDescriptions.map((desc, index) => `

${desc.style}

${desc.content}

`).join(''); } // --- UTILITY FUNCTIONS --- function showNotification(message) { notification.textContent = message; notification.classList.remove('opacity-0'); setTimeout(() => notification.classList.add('opacity-0'), 2000); } function copyToClipboard(text, message) { navigator.clipboard.writeText(text).then(() => showNotification(message)); } // --- PDF GENERATION --- async function generatePdfReport() { if (generatedDescriptions.length === 0) { showNotification("No descriptions to export."); return; } downloadPdfBtn.disabled = true; downloadPdfBtn.textContent = '...'; const descriptionCards = generatedDescriptions.map(desc => `

${desc.style}

${desc.content.replace(/\n/g, '
')}

`).join(''); const reportHtml = `

Affiliate Content Sheet

Product: ${inputsData.name}

Key Features & Audience

Features: ${inputsData.features.replace(/\n/g, ', ')}
Audience: ${inputsData.audience}

Generated Descriptions
${descriptionCards}
`; 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-page'), { scale: 2 }); const imgData = canvas.toDataURL('image/png'); const pdf = new jsPDF({ orientation: 'p', unit: 'pt', format: 'a4' }); const pdfWidth = pdf.internal.pageSize.getWidth(), pdfHeight = (canvas.height * pdfWidth) / canvas.width; pdf.addImage(imgData, 'PNG', 0, 0, pdfWidth, pdfHeight); pdf.save(`Product_Descriptions_${inputsData.name.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', generateDescriptions); copyAllBtn.addEventListener('click', () => { if (generatedDescriptions.length > 0) { const allText = generatedDescriptions.map(d => `--- ${d.style} ---\n${d.content}`).join('\n\n'); copyToClipboard(allText, 'All descriptions copied!'); } }); resultsContainer.addEventListener('click', (e) => { if (e.target.classList.contains('copy-desc-btn')) { const text = generatedDescriptions[e.target.dataset.index].content; copyToClipboard(text, 'Description copied!'); } }); downloadPdfBtn.addEventListener('click', generatePdfReport); });
Scroll to Top