Skip to main content
Since Shoelace 2.0 Code stable

Format Date

<sl-format-date> | SlFormatDate

Formats a date/time using the specified locale and options.

Examples

Date Formatter Basics

Localization is handled by the browser’s Intl.DateTimeFormat API. No language packs are required.

<!-- Shoelace 2 release date πŸŽ‰ -->
<sl-format-date date="2020-07-15T09:17:00-04:00"></sl-format-date>
/ Shoelace 2 release date πŸŽ‰
sl-format-date date="2020-07-15T09:17:00-04:00"
import SlFormatDate from '@teamshares/shoelace/dist/react/format-date';

const App = () => <SlFormatDate date="2020-07-15T09:17:00-04:00" />;

The date attribute determines the date/time to use when formatting. It must be a string that Date.parse() can interpret or a Date object set via JavaScript. If omitted, the current date/time will be assumed.

Date & Time Formatting

Formatting options are based on those found in the Intl.DateTimeFormat API. When formatting options are provided, the date/time will be formatted according to those values. When no formatting options are provided, a localized, numeric date will be displayed instead.






<!-- Human-readable date -->
<sl-format-date month="long" day="numeric" year="numeric"></sl-format-date><br />

<!-- Time -->
<sl-format-date hour="numeric" minute="numeric"></sl-format-date><br />

<!-- Weekday -->
<sl-format-date weekday="long"></sl-format-date><br />

<!-- Month -->
<sl-format-date month="long"></sl-format-date><br />

<!-- Year -->
<sl-format-date year="numeric"></sl-format-date><br />

<!-- No formatting options -->
<sl-format-date></sl-format-date>
/ Human-readable date
sl-format-date month="long" day="numeric" year="numeric"
br
/ Time
sl-format-date hour="numeric" minute="numeric"
br
/ Weekday
sl-format-date weekday="long"
br
/ Month
sl-format-date month="long"
br
/ Year
sl-format-date year="numeric"
br
/ No formatting options
sl-format-date
import SlFormatDate from '@teamshares/shoelace/dist/react/format-date';

const App = () => (
  <>
    {/* Human-readable date */}
    <SlFormatDate month="long" day="numeric" year="numeric" />
    <br />

    {/* Time */}
    <SlFormatDate hour="numeric" minute="numeric" />
    <br />

    {/* Weekday */}
    <SlFormatDate weekday="long" />
    <br />

    {/* Month */}
    <SlFormatDate month="long" />
    <br />

    {/* Year */}
    <SlFormatDate year="numeric" />
    <br />

    {/* No formatting options */}
    <SlFormatDate />
  </>
);

Hour Formatting

By default, the browser will determine whether to use 12-hour or 24-hour time. To force one or the other, set the hour-format attribute to 12 or 24.


<sl-format-date hour="numeric" minute="numeric" hour-format="12"></sl-format-date><br />
<sl-format-date hour="numeric" minute="numeric" hour-format="24"></sl-format-date>
sl-format-date hour="numeric" minute="numeric" hour-format="12"
br
sl-format-date hour="numeric" minute="numeric" hour-format="24"
import SlFormatDate from '@teamshares/shoelace/dist/react/format-date';

const App = () => (
  <>
    <SlFormatDate hour="numeric" minute="numeric" hour-format="12" />
    <br />
    <SlFormatDate hour="numeric" minute="numeric" hour-format="24" />
  </>
);

Localization

Use the lang attribute to set the date/time formatting locale.

English:
French:
Russian:
English: <sl-format-date lang="en"></sl-format-date><br />
French: <sl-format-date lang="fr"></sl-format-date><br />
Russian: <sl-format-date lang="ru"></sl-format-date>
| English:
sl-format-date lang="en"
br
| French:
sl-format-date lang="fr"
br
| Russian:
sl-format-date lang="ru"
import SlFormatDate from '@teamshares/shoelace/dist/react/format-date';

const App = () => (
  <>
    English: <SlFormatDate lang="en" />
    <br />
    French: <SlFormatDate lang="fr" />
    <br />
    Russian: <SlFormatDate lang="ru" />
  </>
);

Component Props

Property Default Details
date new Date()

Date | string

The date/time to format. If not set, the current date and time will be used. When passing a string, it’s strongly recommended to use the ISO 8601 format to ensure timezones are handled correctly. To convert a date to this format in JavaScript, use date.toISOString().

weekday β€”

'narrow' | 'short' | 'long'

The format for displaying the weekday.

era β€”

'narrow' | 'short' | 'long'

The format for displaying the era.

year β€”

'numeric' | '2-digit'

The format for displaying the year.

month β€”

'numeric' | '2-digit' | 'narrow' | 'short' | 'long'

The format for displaying the month.

day β€”

'numeric' | '2-digit'

The format for displaying the day.

hour β€”

'numeric' | '2-digit'

The format for displaying the hour.

minute β€”

'numeric' | '2-digit'

The format for displaying the minute.

second β€”

'numeric' | '2-digit'

The format for displaying the second.

timeZoneName
time-zone-name
β€”

'short' | 'long'

The format for displaying the time.

timeZone
time-zone
β€”

string

The time zone to express the time in.

hourFormat
hour-format
'auto'

'auto' | '12' | '24'

The format for displaying the hour.

updateComplete A read-only promise that resolves when the component has finished updating.

Learn more about attributes and properties.