Commit 9e8f85f
feat(mdxish): add new MDXish engine (#1243)
[![PR App][icn]][demo] | Fix RM-XYZ
:-------------------:|:----------:
> [!WARNING]
> As of `5 Dec 2025` (keeping this to track timeline) SSR for `mdxish`
has been disabled. All contents that are rendered by `mdxish` will be
done client-side. For more context, refer to this
[thread](#1243 (comment))
## 🧰 Changes
#### Context
This PR exports 2 new libraries which provides a new way to render mixed
Markdown + MDX content in our application.
This allows customers to flexibly embed MDX inside Markdown without
relying on the strict MDX renderer or needing to migrate everything to
MDX (which currently causes many errors and requires hours of cleanup)
> [!IMPORTANT]
> With the addition of the new libraries, we unfortunately have exceeded
the maximum bundle size allowed. Specifically the current bundle size is
`762KB` and the limit was `750KB`, this has been increased to `775KB`
#### Changes
1. `mdxish.ts`
- Engine to convert a Markdown + MDX string into an HTML AST.
- Based on Greg’s prototype and uses Unified plugins.
- Handles MDX by preprocessing its syntax.
- Additional logic:
- Reuses existing transformers (e.g., callouts).
- Adjusts MDX nodes when spacing breaks the AST.
- Custom component handling:
- Recursively parses inner content.
- Renames nodes to PascalCase.
- Includes heuristics to determine whether a tag is a real component vs.
an HTML tag.
2. `renderMdxish.tsx`
- Converts the HTML AST into React JSX components
- Mimics the existing `run.tsx` behaviour used in production, returns an
RMDXModule which contains the content react component, and the table of
contents
> _We also expose another library called `mix` but this isnt actually
used for rendering. This is simply a wrapper around `mdxish` that
returns stringified HTML instead of HAST. This can be useful for
testing/development or when we need a stringified version of the HAST._
## 🧬 QA & Testing
#### How to Test Locally
To test this new rendering engine directly in the ReadMe app:
- Open two terminals:
- ReadMe (branch: mdxish-demo)
- Markdown (this branch)
- Link Markdown to ReadMe:
- In markdown: `npm ci` && `npm run build`
- In readme: `make link-markdown`
- Run the ReadMe repo and open any project — it should not crash
- Create docs using mixed Markdown/MDX (via Raw mode) and verify they
render correctly
- You can use the files in `tests/lib/mdxish/demo-docs` as examples in
your editor
#### Testing In The PR App
We have prepared a PR app that has the new mdxish engine enabled by
default for all projects. See it
[here](https://readme-pr-16565.readme.ninja/)
#### Things to Test in Docs
- Built-in ReadMe components
- User-defined components
- Table of contents
- Unclosed tags (e.g., `<br>`)
- Links, headings, formatting, etc.
## 📸 Some Screenshots
These screenshots are sample MD/MDX pages that is rendered using the new
libraries. All screenshots here and all demo does not have correct
validation _yet_. We purposefuly disabled validation to demo this new
engine/library.
| | | |
| --- | --- | --- |
| <img width="1920" height="1113" alt="Screenshot 2025-11-27 at 01 05
44"
src="https://github.com/user-attachments/assets/1b8037c2-1d80-4980-8417-5f61411c5df8"
/> | <img width="1920" height="1113" alt="Screenshot 2025-11-27 at 01 06
10"
src="https://github.com/user-attachments/assets/37e597a3-6ef2-4844-b5fd-86604936b0b3"
/> | <img width="1920" height="1113" alt="Screenshot 2025-11-27 at 01 06
27"
src="https://github.com/user-attachments/assets/012b92f6-56f9-41b4-b000-6db4a1d346f1"
/> |
[demo]: https://markdown-pr-PR_NUMBER.herokuapp.com
[prod]: https://SUBDOMAIN.readme.io
[icn]:
https://user-images.githubusercontent.com/886627/160426047-1bee9488-305a-4145-bb2b-09d8b757d38a.svg
---------
Co-authored-by: Dimas Putra Anugerah <[email protected]>
Co-authored-by: eagletrhost <[email protected]>
Co-authored-by: Rafe Goldberg <[email protected]>1 parent 8662f6b commit 9e8f85f
File tree
65 files changed
+6913
-257
lines changed- __tests__
- benchmarks
- compilers
- lib
- mdxish
- demo-docs
- render-mdxish
- processor/plugin
- transformers
- components
- CodeTabs
- HTMLBlock
- docs
- lib
- utils
- mdxish
- processor
- plugin
- transform
- mdxish
- scripts
- utils
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
65 files changed
+6913
-257
lines changedLarge diffs are not rendered by default.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
| 2 | + | |
| 3 | + | |
2 | 4 | | |
3 | 5 | | |
4 | 6 | | |
| |||
15 | 17 | | |
16 | 18 | | |
17 | 19 | | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
1 | 2 | | |
2 | 3 | | |
3 | | - | |
| 4 | + | |
4 | 5 | | |
5 | 6 | | |
6 | 7 | | |
| |||
156 | 157 | | |
157 | 158 | | |
158 | 159 | | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
1 | 4 | | |
2 | 5 | | |
3 | 6 | | |
4 | | - | |
5 | 7 | | |
6 | 8 | | |
7 | 9 | | |
8 | | - | |
| 10 | + | |
9 | 11 | | |
10 | 12 | | |
11 | 13 | | |
| |||
507 | 509 | | |
508 | 510 | | |
509 | 511 | | |
| 512 | + | |
| 513 | + | |
| 514 | + | |
| 515 | + | |
| 516 | + | |
| 517 | + | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
| 527 | + | |
| 528 | + | |
| 529 | + | |
| 530 | + | |
| 531 | + | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
| 567 | + | |
| 568 | + | |
| 569 | + | |
| 570 | + | |
| 571 | + | |
| 572 | + | |
| 573 | + | |
| 574 | + | |
| 575 | + | |
| 576 | + | |
| 577 | + | |
| 578 | + | |
| 579 | + | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
0 commit comments