@ebay/skin/calendar

DS v1

The calendar module offers readonly and interactive calendar capabilities.

Both types of calendar are structured as data tables; each column representing a day of the week.

Readonly Calendar

A readonly calendar has cells containing static text or hypertext.

The current date is conveyed using calendar__cell--current and clipped text.

August 2023
SuMoTuWeThFrSa
12345
6789101112
1314 - today1516171819
20212223242526
2728293031

NOTE: for the eagle-eyed BEM afionados, we are saying each span has an implicit class of calendar__cell.

Read-Only Calendar with Inactive Dates

Inactive/unavailable dates are conveyed using calendar__cell--disabled and offscreen text.

August 2023
SuMoTuWeThFrSa
1 - inactive2 - inactive3 - inactive4 - inactive5 - inactive
6 - inactive7 - inactive8 - inactive9 - inactive10 - inactive11 - inactive12 - inactive
13 - inactive14 - today1516171819
20212223242526
2728293031

Read-Only Calendar with Date Range

Date ranges are conveyed using calendar__cell--selected, calendar__range, calendar__range--start, calendar__range-end and clipped text.

August 2023
SuMoTuWeThFrSa
1 - inactive2 - inactive3 - inactive4 - inactive5 - inactive
6 - inactive7 - inactive8 - inactive9 - inactive10 - inactive11 - inactive12 - inactive
13 - inactive14 - today151617 - start of range18 - in range19 - in range
20 - in range21 - in range22 - in range23 - in range24 - in range25 - end of range26
2728293031

Interactive Calendar

An interactive calendar uses toggle buttons to allow the input of single dates or date ranges.

NOTE: a fully functional and accessible interactive calendar requires JavaScript and is outside the scope of a CSS library such as eBay Skin. The examples below are NOT fully functional and serve to demonstrate the necessary HTML semantics and styling hooks only.

Interactive Calendar With Single Date Selection

A single date selection is conveyed using aria-pressed.

NOTE: in comparison to the readonly calendar, with buttons we can now leverage the disabled property and aria-current instead of clipped text.

August 2023
SuMoTuWeThFrSa

Interactive Calendar With Date Range Selection

Date ranges are bookended by two buttons with the aria-pressed property. All buttons in between these dates leverage clipped text for assistive technology.

August 2023
SuMoTuWeThFrSa

Calendar With Header Pagination

The calendar module allows an optional header section for pagination between months.

August 2023

August 2023
SuMoTuWeThFrSa
12345
6789101112
1314 - today1516171819
20212223242526
2728293031

Multi-month Calendar with Header Pagination

Multiple instances of calendar__month can be rendered inside of the calendar__body.

July 2023

August 2023

September 2023

July 2023
SuMoTuWeThFrSa
1
2345678
9101112131415
16171819202122
23242526272829
3031
August 2023
SuMoTuWeThFrSa
12345
6789101112
1314 - today1516171819
20212223242526
2728293031
September 2023
SuMoTuWeThFrSa
12
3456789
10111213141516
17181920212223
24252627282930