// 2️⃣ update score const kakak = await Kakak.findByPk(kakakId); kakak.happinessScore += 1; await kakak.save();
return ( <> <button aria-label="Berikan genjotan untuk membuat kakak bahagia" disabled=loading onClick=handleGenjot className="genjot-btn" > loading ? '⏳' : '❤️ Genjot' </button> // 2️⃣ update score const kakak = await Kakak
const handleGenjot = async () => if (loading) return; setLoading(true); try const res = await postGenjot(kakakId); if (res.status === 'ok') setShowHappy(true); // optional audio const audio = new Audio('/sounds/cheer.mp3'); audio.play(); // hide after 2s setTimeout(() => setShowHappy(false), 2000); finally setLoading(false); ; kakak.happinessScore += 1
showHappy && ( <div className="happy-overlay" aria-live="polite"> <Lottie options= animationData: happyAnim, loop: false /> </div> ) </> ); ; // routes/kakak.js router.post('/:id/genjot', async (req, res) => const kakakId = req.params.id; const userId = req.user.id; return ( <