Commit 94ae380
committed
perf: per-block fade-in for streaming markdown
Adds a soft, GPU-cheap fade-in to each newly-mounted top-level markdown
block while a message is streaming. Maps user's mental model of
"line-by-line" onto markdown blocks: paragraph, heading, list item,
fence, blockquote, table, hr — fires once per new block at mount.
Mechanics
- TypewriterMarkdown sets data-streaming="true" on its wrapper while the
message is streaming. Absent (not "false") on completed/replayed
messages so the CSS rule cannot match historical transcripts.
- MarkdownCore appends "streamdown-root" to the className passed through
to Streamdown's root div — a stable CSS hook with no extra wrapper.
- globals.css adds a keyframes + block-level selector list scoped via
prefers-reduced-motion. Inline elements (<strong>/<em>/<a>) are
intentionally excluded because parseIncompleteMarkdown can transiently
insert/remove them as remend repairs unterminated tokens.
Why this works
- Streamdown keys each block by useId+index and wraps it in React.memo,
so existing blocks are reconciled in place when their content grows.
Only newly-arriving top-level blocks mount fresh — and CSS animation
on a freshly-mounted child fires exactly once at mount.
- No JS bookkeeping, no render-phase work, no prop changes.
Per-character pacing inside SmoothTextEngine still operates inside each
block; the new fade-in layer is purely additive at block boundaries.1 parent af4912e commit 94ae380
4 files changed
Lines changed: 87 additions & 2 deletions
File tree
- src/browser
- features/Messages
- styles
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
144 | 144 | | |
145 | 145 | | |
146 | 146 | | |
147 | | - | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
148 | 150 | | |
149 | 151 | | |
150 | 152 | | |
| |||
Lines changed: 24 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
153 | 153 | | |
154 | 154 | | |
155 | 155 | | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
156 | 180 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
73 | 73 | | |
74 | 74 | | |
75 | 75 | | |
76 | | - | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
77 | 82 | | |
78 | 83 | | |
79 | 84 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1542 | 1542 | | |
1543 | 1543 | | |
1544 | 1544 | | |
| 1545 | + | |
| 1546 | + | |
| 1547 | + | |
| 1548 | + | |
| 1549 | + | |
| 1550 | + | |
| 1551 | + | |
| 1552 | + | |
| 1553 | + | |
| 1554 | + | |
| 1555 | + | |
| 1556 | + | |
| 1557 | + | |
| 1558 | + | |
| 1559 | + | |
| 1560 | + | |
| 1561 | + | |
| 1562 | + | |
| 1563 | + | |
| 1564 | + | |
| 1565 | + | |
| 1566 | + | |
| 1567 | + | |
| 1568 | + | |
| 1569 | + | |
| 1570 | + | |
| 1571 | + | |
| 1572 | + | |
| 1573 | + | |
| 1574 | + | |
| 1575 | + | |
| 1576 | + | |
| 1577 | + | |
| 1578 | + | |
| 1579 | + | |
| 1580 | + | |
| 1581 | + | |
| 1582 | + | |
| 1583 | + | |
| 1584 | + | |
| 1585 | + | |
| 1586 | + | |
| 1587 | + | |
| 1588 | + | |
| 1589 | + | |
| 1590 | + | |
| 1591 | + | |
| 1592 | + | |
| 1593 | + | |
| 1594 | + | |
| 1595 | + | |
| 1596 | + | |
| 1597 | + | |
| 1598 | + | |
1545 | 1599 | | |
1546 | 1600 | | |
1547 | 1601 | | |
| |||
0 commit comments