Navigate any GitHub repo in your browser. Zero install. Single HTML file.
| Try | What it demos |
|---|---|
| octocat/hello-world | Tiny repo — see the basic UI in two seconds |
| facebook/react @ React README | Big repo, deep-linked to a specific file |
| openai/openai-cookbook | Markdown-heavy repo with notebooks |
| torvalds/linux @ master | Stress test — token recommended for big trees |
More demos
- https://pushme-pullyou.github.io/tootoo/?owner=microsoft&repo=vscode
- https://pushme-pullyou.github.io/tootoo/?owner=anthropics&repo=claude-code
- https://pushme-pullyou.github.io/tootoo/?owner=d3&repo=d3#API.md
- https://pushme-pullyou.github.io/tootoo/?owner=xai-org&repo=grok-1
- https://pushme-pullyou.github.io/tootoo/?owner=xai-org&repo=grok-prover-v1
- https://pushme-pullyou.github.io/tootoo/?owner=openai&repo=whisper
- https://pushme-pullyou.github.io/tootoo/?owner=openai&repo=openai-python
- https://pushme-pullyou.github.io/tootoo/?owner=pushme-pullyou&repo=pushme-pullyou.github.io
- Instant cross-tree filter. Type a few letters, see every matching path. GitHub's web UI only filters the current folder.
- Sticky sidebar, sticky breadcrumbs. Scroll a long file without losing context.
- Built for phones too. A−/A+ buttons resize everything; the sidebar collapses to a sensible width on narrow screens; dark mode is one tap.
- Works next to a local checkout. Drop
index.htmlnext to a cloned repo and TooToo reads it from disk viafile://— no API quota burn, no internet required. - Drag-and-drop friendly. One file. Copy it into any repo, push, enable Pages, done.
- Single file — one
index.htmlwith HTML, CSS, and JS inline - Auto-detect — reads
.git/config, parses GitHub Pages URLs, or caches to localStorage - File tree — sidebar with collapsible folders, filter input, keyboard navigation
- Content viewer — Markdown (rendered via marked), syntax-highlighted code, images, audio, video, PDF, spreadsheets (SheetJS)
- Dark mode — toggle with persisted preference
- Resizable sidebar — drag to resize, width saved across visits
- Collapsible sidebar — toggle with the header button or Ctrl/⌘ B, state persisted
- Font size controls — A−/A+ buttons, helpful on phones
- GitHub token support — optional PAT for private repos and higher rate limits (5,000/hr vs 60/hr)
- File text cache — LRU in-memory + sessionStorage cache to reduce API calls without persisting file contents after the tab session
- Hash routing — deep-link to any file via
#path/to/file - Copy / New Tab / Download — copy raw text, open viewable files in a new tab, or save non-viewable files (3D, fonts, archives, spreadsheets, binaries) straight to disk
- Rendered ↔ Raw toggle — for Markdown, HTML, and SVG files; preference saved per file type
- Safer HTML previews — rendered HTML uses a strict iframe sandbox so repository scripts do not run by default
- Self-test — render every file off-screen and report which fail to display (About → 🧪 Run self-test)
On GitHub Pages — visit the live URL above.
Drop-in mode — copy index.html into any GitHub repo folder. Open it in a browser. It walks up the directory tree looking for .git/config to find the owner and repo.
Pre-configured — edit the CONFIG object at the top of the script:
const CONFIG = {
owner: 'pushme-pullyou',
repo: 'tootoo',
branch: 'main',
storagePrefix: 'tootoo',
appName: 'TooToo',
sourceRepoUrl: 'https://github.com/pushme-pullyou/tootoo',
};These are the common knobs; CONFIG also supports theming and filtering options (themeColor, subtitle, hiddenFolders/hiddenFiles, faviconLetters, headingFont, maxRepoFiles) — see FORKING.md for the full set.
Want your own TooToo pointing at your own repo? It takes about a minute.
-
Fork this repository on GitHub (top-right of the repo page).
-
Edit
CONFIGat the top of the<script>block inindex.html:const CONFIG = { owner: '', // optional: pre-load a specific repo repo: '', branch: '', // empty = use the default branch storagePrefix: 'mybrowser', // localStorage namespace appName: 'MyBrowser', // <title> + About heading sourceRepoUrl: 'https://github.com/you/your-fork', // file:// fallback for the header };
On GitHub Pages, the top-header label and link auto-detect from the hostname (
<you>.github.io/<fork>/), so you don't even need to setsourceRepoUrlfor the Pages deploy. It's only used as a fallback forfile://and custom domains. -
Customize the favicon (optional) — the inline SVG
<link rel="icon" ...>in<head>. -
Enable Pages: in your fork's Settings → Pages, deploy from the
mainbranch root. Your fork goes live athttps://<you>.github.io/<your-fork>/.
For deeper customization (adding renderers, new buttons, etc.), see FORKING.md — covers the architecture, render pipelines, and the gotchas (file://, rate limits, blob lifecycle).
TooToo stores preferences and the GitHub token in the browser's localStorage. Recently viewed file contents are cached in sessionStorage, so they expire when the tab session ends. Keys are scoped per location.pathname, so two TooToo instances on the same origin keep separate state.
| Key | Purpose |
|---|---|
tootoo:<pathname>:repo |
Detected owner / repo / default branch |
tootoo:<pathname>:darkMode |
Dark mode on/off |
tootoo:<pathname>:fontSize |
Font size override (px) |
tootoo:<pathname>:sidebarWidth |
Last sidebar width (px) |
tootoo:<pathname>:sidebarHidden |
Sidebar collapsed on/off (Ctrl/⌘ B) |
tootoo:<pathname>:fileTextCache |
Session-only LRU cache of recently viewed file contents |
tootoo:<pathname>:viewPref:<ext> |
Rendered / Raw toggle per file extension |
tootoo:<pathname>:currentFile:<owner>/<repo>/<branch> |
Last-opened file in that repo (sessionStorage — clears with the tab) |
tootoo:<pathname>:githubToken |
GitHub Personal Access Token for this TooToo instance |
To wipe state, click ⚙️ Token → Reset all TooToo data, or clear both localStorage and sessionStorage in DevTools.
- Vanilla JavaScript — no frameworks, no build tools, no Node.js
- ES2020+ —
const/let, arrow functions, template literals, async/await - Static hosting only — GitHub Pages or open from
file:// - External CDN deps: marked, highlight.js, DOMPurify, SheetJS
TooToo stays intentionally small: single-file, vanilla JavaScript, static hosting, and file:// friendly. These ideas are candidates, not promises.
- Add better text search: search within the current file first, then loaded/cached text files, with optional rate-limit-aware search across small repo text files.
- Add richer previews for common data files, starting with friendlier
.csvand.jsonviews. - Add visible local-mode/rate-limit status so users know whether TooToo is reading local files, raw GitHub files, or the GitHub API.
- Add an in-app keyboard-shortcut help overlay (the About page already lists
/,\, arrows, Ctrl/⌘ B, and Esc).
- Improve Markdown navigation: README anchors, relative links with query/hash, and GitHub folder links.
- Add search results with matching file paths, line snippets, next/previous navigation, and clear filename-vs-content search modes.
- Add share/copy actions for deep links, raw URLs, and GitHub URLs.
- Polish mobile behavior with an easier sidebar toggle and simpler header layout.
- Expand
examples/for CSV, extensionless files, Markdown links, text search, and New Tab routing.
- Lightweight image/file metadata panels.
- Optional JSON tree viewer.
- More fork-customization helpers for app name, favicon, storage prefix, and source repo URL.
index.html ← canonical single-file app
README.md ← user-facing docs (this file)
FORKING.md ← architecture + recipes for forkers
AGENTS.md ← AI agent guidance
CLAUDE.md ← Claude-specific pointer file
0-tootoo-agenda.md ← priorities and ideas
0-tootoo-journal.md ← development notes
tootoo-test.html ← standalone test harness for pure helpers
tootoo-test-load.html ← manual GitHub raw-file load tester for this repo
examples/ ← sample content + render fixtures, organized by file type (with index README)
.archive/ ← older snapshots
.github/prompts/ ← generation/merge/rebuild prompts
.gemini/ ← alternate-model experiments
MIT — Copyright pushme-pullyou. See LICENSE.
- 2026-06-08 — About and Token header buttons now toggle: clicking again closes the panel and returns to the file you were viewing, with the active button shown pressed
- 2026-06-08 — New Tab is now an honest action — viewable files (HTML, PDF, images, media, text/source) open in a tab, while non-viewable files (3D models, fonts, archives, spreadsheets, binaries, extensionless) get a Download button that saves directly; local downloads no longer flash a throwaway tab
- 2026-06-08 — Viewable vs downloadable is now decided by an allowlist of browser-renderable types instead of a blocklist, so new binary formats (e.g.
.stl) are handled correctly without chasing the list - 2026-06-08 — About page now shows the current branch with links to its tree and the repo's full branch list; the keyboard-shortcut list adds Ctrl/⌘ B and Esc
- 2026-06-08 — Broken in-repo links now show a plain "file not found" message instead of misfiring the private-repo token panel
- 2026-06-08 — Rate-limit handling now distinguishes a real quota 403/429 (token panel) from other 403s (reported plainly)
- 2026-06-08 — Sidebar file rows expose
role="button"so screen readers announce them as actionable - 2026-05-18 — Restored repo-local agent guidance as
AGENTS.mdwithCLAUDE.mdas a small pointer file, so TooToo-specific workflow rules are active again - 2026-05-18 — File-content cache now uses sessionStorage instead of localStorage; legacy persistent file-cache entries are cleared on restore/reset
- 2026-05-18 — Markdown link rewriting now keeps custom schemes intact, avoids treating query strings/fragments as filenames, and handles GitHub blob links on branches containing
/ - 2026-05-18 — New Tab now opens data/media files such as
.csvand extensionless files through raw URLs instead of GitHub Pages, and opens the tab synchronously to avoid popup blockers - 2026-04-25 — Top-header label and GitHub icon now derive from
APP_ORIGIN(where this app instance is hosted), independent of the currently browsed repo; onfile://it reads the surrounding.git/config - 2026-04-25 — Token panel auto-opens on rate-limit (403) with explanation of why a token is needed and where to get one
- 2026-04-25 — Pinned CDN versions (marked@12.0.2, dompurify@3.4.1, xlsx@0.20.3) to insulate against upstream breakage
- 2026-04-25 — README auto-select now matches more variants (
README,README.markdown,README.mkd,README.mdown,README.txt); falls back to the About page if no root README exists - 2026-04-25 —
probeLocalModenow respects the abort signal so probes stop when the user navigates away mid-load - 2026-04-25 — Filter and visible-tree-item logic now use an
.is-hiddenclass instead of inline-style sniffing - 2026-04-25 — View-toggle buttons (Rendered/Raw) drive their styling from
aria-pressedinstead of inlinestyle="opacity:..." - 2026-04-25 — Removed duplicate
/keyboard handler; merged the twobeforeunloadlisteners - 2026-04-25 — Active tree-item scroll uses
behavior: 'auto'so rapid keyboard navigation no longer fights smooth-scroll - 2026-04-25 —
renderCodenow always builds viatextContent, skipping the escape pass for very large files - 2026-04-25 — Configured defaults now act as a fallback after repo auto-detection instead of short-circuiting URL, cache, Pages, and .git/config detection
- 2026-04-25 — 403 responses in repo-info and authenticated file fetches now surface the same rate-limit warning used by tree loading
- 2026-04-25 — Repo breadcrumb now resets to a true home state instead of leaving the previously opened file view onscreen
- 2026-04-25 — Last-opened file persistence is now scoped per owner/repo/branch and ignores stale paths not present in the current tree
- 2026-04-25 — Markdown now resolves relative image paths against the current file location in the repository browser
- 2026-04-25 — Renamed: the app is now simply "TooToo" (the previous "LT" suffix is dropped); older/full TooToo files moved to their own repository
- 2026-04-25 — HTML rendered previews now use a strict sandbox so repository scripts do not run by default
- 2026-04-09 — Help button with live rate limit, tips section
- 2026-04-09 — GitHub Pages URL auto-detection, file:// XHR detection
- 2026-04-07 — Style adjustments, About button
- 2026-04-06 — New tab: use raw URL when not on Pages