fix: remove CSP-blocked inline onclick handlers, use addEventListener
This commit is contained in:
@@ -795,5 +795,24 @@ function showToast(msg) {
|
||||
}, 3200);
|
||||
}
|
||||
|
||||
// ── Static button bindings (replaces inline onclick – blocked by CSP script-src-attr) ──
|
||||
document.getElementById('btn-logout') ?.addEventListener('click', logout);
|
||||
document.getElementById('btn-daily-challenge') ?.addEventListener('click', startDailyChallenge);
|
||||
document.getElementById('btn-start-practice') ?.addEventListener('click', startPractice);
|
||||
document.getElementById('btn-stop-practice') ?.addEventListener('click', stopPracticeUI);
|
||||
document.getElementById('match-ready-btn') ?.addEventListener('click', setReady);
|
||||
document.getElementById('btn-leave-match') ?.addEventListener('click', leaveMatch);
|
||||
document.getElementById('btn-create-user') ?.addEventListener('click', createUser);
|
||||
|
||||
// D-pad: practice and match both use data-dir buttons
|
||||
document.getElementById('practice-dpad')?.addEventListener('click', (e) => {
|
||||
const dir = e.target.closest('[data-dir]')?.dataset.dir;
|
||||
if (dir) dpadInput(dir);
|
||||
});
|
||||
document.getElementById('match-dpad')?.addEventListener('click', (e) => {
|
||||
const dir = e.target.closest('[data-dir]')?.dataset.dir;
|
||||
if (dir) dpadInput(dir);
|
||||
});
|
||||
|
||||
// ── Init ──────────────────────────────────────────────────────────────────────
|
||||
document.addEventListener('DOMContentLoaded', checkAuth);
|
||||
|
||||
Reference in New Issue
Block a user