Commit 2e2dee0
committed
Replace CPU color transitions with GPU View Transitions for dark mode
The dark mode toggle previously animated background-color, color, and
border-color on every element via a wildcard CSS rule, causing full-page
CPU repaints for 0.8 seconds. On weaker browser engines this was visibly
choppy.
Now uses the View Transitions API: the browser takes a GPU-composited
screenshot, swaps the theme instantly, then crossfades between old and
new states in 0.4s using only opacity (compositor-only). Falls back to
instant swap on unsupported browsers.
Removed all 0.8s color transitions from body, sections, sidebar, and
mobile top bar that existed solely for the dark mode toggle.1 parent ba00265 commit 2e2dee0
1 file changed
Lines changed: 17 additions & 11 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
140 | 140 | | |
141 | 141 | | |
142 | 142 | | |
143 | | - | |
144 | | - | |
145 | | - | |
146 | | - | |
147 | | - | |
148 | 143 | | |
149 | 144 | | |
150 | 145 | | |
| |||
280 | 275 | | |
281 | 276 | | |
282 | 277 | | |
283 | | - | |
284 | 278 | | |
285 | 279 | | |
286 | 280 | | |
| |||
340 | 334 | | |
341 | 335 | | |
342 | 336 | | |
343 | | - | |
| 337 | + | |
344 | 338 | | |
345 | 339 | | |
346 | 340 | | |
| |||
823 | 817 | | |
824 | 818 | | |
825 | 819 | | |
| 820 | + | |
| 821 | + | |
| 822 | + | |
| 823 | + | |
| 824 | + | |
| 825 | + | |
826 | 826 | | |
827 | 827 | | |
828 | 828 | | |
| |||
997 | 997 | | |
998 | 998 | | |
999 | 999 | | |
1000 | | - | |
1001 | 1000 | | |
1002 | 1001 | | |
1003 | 1002 | | |
| |||
1033 | 1032 | | |
1034 | 1033 | | |
1035 | 1034 | | |
1036 | | - | |
1037 | 1035 | | |
1038 | 1036 | | |
1039 | 1037 | | |
1040 | 1038 | | |
1041 | 1039 | | |
1042 | | - | |
| 1040 | + | |
1043 | 1041 | | |
1044 | 1042 | | |
1045 | 1043 | | |
| |||
2560 | 2558 | | |
2561 | 2559 | | |
2562 | 2560 | | |
2563 | | - | |
| 2561 | + | |
2564 | 2562 | | |
2565 | 2563 | | |
2566 | 2564 | | |
2567 | 2565 | | |
2568 | 2566 | | |
| 2567 | + | |
| 2568 | + | |
| 2569 | + | |
| 2570 | + | |
| 2571 | + | |
| 2572 | + | |
| 2573 | + | |
| 2574 | + | |
2569 | 2575 | | |
2570 | 2576 | | |
2571 | 2577 | | |
| |||
0 commit comments