| name | calendar |
| description | Use when you need to display dates and events in calendar format. |
| metadata | {"id":"calendar","category":"data-display","pattern":"Calendar View","source":"uxpatterns.dev","url":"https://uxpatterns.dev/patterns/data-display/calendar","sourcePath":"apps/web/content/patterns/data-display/calendar.mdx"} |
Calendar View
Display dates and events in calendar format
What it solves
A Calendar View pattern helps teams create a reliable way to present time-based information in a grid that helps people compare days, weeks, or months at a glance. It is most useful when teams need booking and scheduling.
Compared with adjacent patterns, this pattern should reduce friction without hiding the state, rules, or recovery paths people need to keep moving.
When to use
- Booking and scheduling
- Team availability
- Events and release planning
When to avoid
- Use a simpler view when users only need one or two values and not the full layout.
- Avoid this pattern when the task is creation or editing rather than interpretation.
- Do not force the same view onto mobile if another representation would be clearer.
Implementation workflow
- Confirm the pattern matches the problem and constraints before copying the example.
- Start from the anatomy and examples in
references/pattern.md, then choose the smallest viable variation.
- Apply accessibility, performance, and interaction guardrails before layering visual polish.
- Use the testing guidance to verify behavior across keyboard, screen reader, responsive, and failure scenarios.
Accessibility guardrails
Keyboard Interaction
Screen Reader Support
Visual Accessibility
Performance guardrails
- Measure the cost of rendering the default view before adding richer adornments such as nested actions, charts, or inline filters.
- Use pagination, windowing, or progressive disclosure when the layout would otherwise render too many items at once.
- Stabilize heights and placeholder geometry so loading and data refresh states do not cause large layout shifts.
Common mistakes
Choosing the layout before the task
The Problem:
Teams often pick a visually familiar pattern before confirming whether users need comparison, exploration, or scanning.
How to Fix It?
Start from the user task, then map the layout to comparison, chronology, hierarchy, or overview needs.
Ignoring non-happy states
The Problem:
A polished default view still feels broken when loading, empty, and error states are inconsistent.
How to Fix It?
Design the data lifecycle up front, including empty, partial, stale, and failed results.
Shipping a desktop-only density model
The Problem:
Large tables, dense dashboards, and heavy cards collapse quickly on small screens.
How to Fix It?
Define a mobile strategy such as stacked cards, progressive disclosure, or alternate summaries before implementation.
Related patterns
For full implementation detail, examples, and testing notes, see references/pattern.md.
Pattern page: https://uxpatterns.dev/patterns/data-display/calendar