function hoverStars(n) stars.forEach(s => s.classList.toggle('active', Number(s.dataset.value) <= n)); function updateStars() stars.forEach(s => s.classList.toggle('active', Number(s.dataset.value) <= currentRating)); ratingValue.textContent = currentRating;
const title = document.getElementById('title'); const body = document.getElementById('body'); const titleCount = document.getElementById('titleCount'); const bodyCount = document.getElementById('bodyCount');
// in-memory storage let reviews = [];
<div> <label for="title">Review title</label> <input id="title" name="title" type="text" maxlength="80" placeholder="Short headline (max 80 chars)" /> <div class="small"><span id="titleCount">0</span>/80</div> </div>
<div> <label for="body">Review (required)</label> <textarea id="body" name="body" maxlength="1200" placeholder="Share your experience..."></textarea> <div class="small"><span id="bodyCount">0</span>/1200</div> </div>
stars.forEach(s => s.addEventListener('click', () => currentRating = Number(s.dataset.value); updateStars(); ); s.addEventListener('mouseover', () => hoverStars(Number(s.dataset.value))); s.addEventListener('mouseout', () => updateStars()); );
document.getElementById('clearBtn').addEventListener('click', () => if (!confirm('Clear all stored reviews from this page?')) return; reviews = []; showSummary(); );
<div> <label>Primary category (required)</label> <select id="primaryCategory" required> <option value="">Select category</option> <option>Accommodation</option> <option>Food & Dining</option> <option>Tour / Guide</option> <option>Transport</option> <option>Attraction / Activity</option> <option>Other</option> </select> </div>
<div class="summary" id="summaryBox" aria-live="polite"> <strong>Summary</strong> <div id="summaryContent"> No reviews yet. </div> </div>
// export JSON document.getElementById('exportBtn').addEventListener('click', () => if (!reviews.length) alert('No reviews to export.'); return; const blob = new Blob([JSON.stringify(reviews, null, 2)], type:'application/json'); const url = URL.createObjectURL(blob); const a = document.createElement('a'); a.href = url; a.download = 'reviews.json'; a.click(); URL.revokeObjectURL(url); );
<script> (() => { const starWidget = document.getElementById('starWidget'); const stars = Array.from(starWidget.querySelectorAll('.star')); const ratingValue = document.getElementById('ratingValue'); let currentRating = 0;
<div> <label>Tags (optional — click to toggle)</label> <div id="tagsList" class="row"> <span class="tag">Scenic</span> <span class="tag">Crowded</span> <span class="tag">Affordable</span> <span class="tag">Family-friendly</span> <span class="tag">Adventure</span> <span class="tag">Cozy</span> <span class="tag">Authentic</span> </div> </div>