mirror of
https://github.com/kjanat/livedash-node.git
synced 2026-02-13 23:35:45 +01:00
- Update tsconfig to ES2024 target and bundler moduleResolution - Add dynamic imports for chart.js and recharts (bundle optimization) - Consolidate 17 useState into useReducer in sessions page - Fix 18 .js extension imports across lib files - Add type declarations for @rapideditor/country-coder - Fix platform user types (PlatformUserRole enum) - Fix Calendar component prop types - Centralize next-auth type augmentation - Add force-dynamic to all API routes (prevent build-time prerender) - Fix Prisma JSON null handling with Prisma.DbNull - Fix various type mismatches (SessionMessage, ImportRecord, etc.) - Export ButtonProps from button component - Update next-themes import path - Replace JSX.Element with React.ReactElement - Remove obsolete debug scripts and pnpm lockfile - Downgrade eslint to v8 for next compatibility
41 lines
1.0 KiB
Markdown
41 lines
1.0 KiB
Markdown
---
|
|
title: Use Transitions for Non-Urgent Updates
|
|
impact: MEDIUM
|
|
impactDescription: maintains UI responsiveness
|
|
tags: rerender, transitions, startTransition, performance
|
|
---
|
|
|
|
## Use Transitions for Non-Urgent Updates
|
|
|
|
Mark frequent, non-urgent state updates as transitions to maintain UI responsiveness.
|
|
|
|
**Incorrect (blocks UI on every scroll):**
|
|
|
|
```tsx
|
|
function ScrollTracker() {
|
|
const [scrollY, setScrollY] = useState(0)
|
|
useEffect(() => {
|
|
const handler = () => setScrollY(window.scrollY)
|
|
window.addEventListener('scroll', handler, { passive: true })
|
|
return () => window.removeEventListener('scroll', handler)
|
|
}, [])
|
|
}
|
|
```
|
|
|
|
**Correct (non-blocking updates):**
|
|
|
|
```tsx
|
|
import { startTransition } from 'react'
|
|
|
|
function ScrollTracker() {
|
|
const [scrollY, setScrollY] = useState(0)
|
|
useEffect(() => {
|
|
const handler = () => {
|
|
startTransition(() => setScrollY(window.scrollY))
|
|
}
|
|
window.addEventListener('scroll', handler, { passive: true })
|
|
return () => window.removeEventListener('scroll', handler)
|
|
}, [])
|
|
}
|
|
```
|