Initial commit

This commit is contained in:
2026-05-25 13:00:20 -04:00
commit e14e43da42
49 changed files with 26892 additions and 0 deletions

25
js/router.js Normal file
View File

@@ -0,0 +1,25 @@
window.GDD = window.GDD || {};
const { useState, useEffect, useCallback } = React;
/* Hash-based router */
window.GDD.useRouter = function() {
const [page, setPage] = useState(getPage());
function getPage() {
const hash = window.location.hash.slice(1) || 'overview';
return hash;
}
useEffect(() => {
const handler = () => setPage(getPage());
window.addEventListener('hashchange', handler);
return () => window.removeEventListener('hashchange', handler);
}, []);
const navigate = useCallback((path) => {
window.location.hash = path;
}, []);
return { page, navigate };
};