---
name: Format numbers
description: Format numbers using the formatNumber function from Shade whenever someone edits a TSX file.
autoTrigger:
- fileEdit: "**/*.tsx"
---
# Format Numbers
When editing `.tsx` files, ensure all user-facing numbers are formatted using the `formatNumber` utility from `@tryghost/shade`.
## Import
```typescript
import {formatNumber} from '@tryghost/shade';
```
## When to use formatNumber
Use `formatNumber()` when rendering any numeric value that is displayed to the user, including:
- Member counts, visitor counts, subscriber counts
- Email engagement metrics (opens, clicks, bounces)
- Revenue amounts (combine with `centsToDollars()` for monetary values)
- Post analytics (views, link clicks)
- Any count or quantity shown in UI
## Correct usage
```tsx
{formatNumber(totalMembers)}
{formatNumber(link.count || 0)}
{`${currencySymbol}${formatNumber(centsToDollars(mrr))}`}
{post.members > 0 ? `+${formatNumber(post.members)}` : '0'}
```
## Antipatterns to avoid
Do NOT use any of these patterns for formatting numbers in TSX files:
```tsx
// BAD: raw .toLocaleString()
{count.toLocaleString()}
// BAD: manual Intl.NumberFormat
{new Intl.NumberFormat('en-US').format(count)}
// BAD: raw number without formatting
{memberCount}
// BAD: manual regex formatting
{count.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',')}
```
## Related utilities
- `formatPercentage()` - for percentages (e.g., open rates, click rates)
- `abbreviateNumber()` - for compact notation (e.g., 1.2M, 50k)
- `centsToDollars()` - convert cents to dollars before passing to `formatNumber`
All are imported from `@tryghost/shade`.