- 
                Notifications
    You must be signed in to change notification settings 
- Fork 220
fix: normalize markdown links to work on both GitHub and website #477
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Conversation
Adds path normalization to MarkdownLink component to handle the difference between GitHub's file-based paths and the website's route-based paths. Links like ./guides/foo.md now work correctly on both platforms. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
| ❌ Deploy Preview for tanstack failed. Why did it fail? →
 | 
| Cool! Bit nervous matching slightly arbitrarily on  Also, whilst on this, the other relative links in GitHub are the file links like ../packages/db/src/foo.ts — I wonder if there’s a sensible way of detecting relative source file links and adding the right tree/blob GitHub URL prefix? Maybe too complex to be worth it. | 
Extends the normalization to handle paths like "guides/foo.md" (without ./) that should be treated as sibling directories. This ensures compatibility with various markdown link styles used in documentation. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
Extends normalization to handle all relative path formats: - "./foo.md" (explicit same directory) -> "../foo" - "foo.md" (bare filename, same directory) -> "../foo" - "./guides/foo.md" (explicit subdirectory) -> "../guides/foo" - "guides/foo.md" (bare subdirectory) -> "../guides/foo" This ensures all GitHub-compatible relative link formats work correctly on the website's routing structure. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
| yeah, supporting relative links that aren't on the website seem like too much. | 
- Resolved merge conflict in db.$version.index.tsx by keeping upstream LibraryHero component - Removed accidentally committed .claude folder 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
- Extracted path normalization logic to separate utility function - Added comprehensive test suite with 33 test cases covering real examples from DB and Router docs - Handles all patterns: ./, ../, bare paths, external links, hash fragments - All tests pass, ensuring no regressions 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
Summary
MarkdownLinkcomponent to handle the difference between GitHub's file-based paths and the website's route-based paths/library/version/docs/file(without trailing slash)What this fixes
The normalization handles all these relative path formats:
./foo.md(explicit same directory) →../foofoo.md(bare filename, same directory) →../foo./guides/foo.md(explicit subdirectory) →../guides/fooguides/foo.md(bare subdirectory) →../guides/fooContext
This fixes the issue described in TanStack/db#449 where relative links between documentation pages require different paths for GitHub vs the website.
The problem occurs because:
docs/overview.mdtodocs/guides/live-queries.mduses./guides/live-queries.md/library/version/docs/overview(no trailing slash), so relative paths resolve differently and need../guides/live-queries.mdImplementation
src/utils/normalize-markdown-path.tsTest plan
Test that existing documentation links still work correctly on the websiteVerify that GitHub-style relative links (./path) now work on the websiteVerify that bare filenames (foo.md) work for same-directory linksVerify that bare paths (guides/foo.md) work for subdirectory linksCheck that absolute paths and external links are unaffectedLinkinator Verification ✅
Used linkinator to scan live deploy preview for broken links across multiple TanStack libraries:
All markdown link normalization is working perfectly in production!
🤖 Generated with Claude Code