Dates and times
If you're formatting dates and times, you should set up a global time zone.
Formatting plain dates
You can format plain dates and times that are not part of a message with the useFormatter
hook:
import {useFormatter} from 'next-intl';
function Component() {
const format = useFormatter();
const dateTime = new Date('2020-11-20T10:36:01.516Z');
format.dateTime(dateTime, {
year: 'numeric',
month: 'numeric',
day: 'numeric'
});
format.dateTime(dateTime, {hour: 'numeric', minute: 'numeric'});
}
See the MDN docs about DateTimeFormat
(opens in a new tab) to learn more about the options that you can provide to dateTime
(interactive explorer (opens in a new tab)).
To reuse date and time formats for multiple components, you can configure global formats.
Formatting relative time
Relative time durations can be formatted with a separate function:
import {useFormatter} from 'next-intl';
function Component() {
const format = useFormatter();
const dateTime = new Date('2020-11-20T08:30:00.000Z');
const now = new Date('2020-11-20T10:36:00.000Z');
// Renders "2 hours ago"
format.relativeTime(dateTime, now);
}
Note that values are rounded, so e.g. if 100 seconds have passed, "2 minutes ago" will be returned.
Supplying now
is necessary for the function to return consistent results. If you have configured a global value for now
on the provider, you can omit the second argument:
format.relativeTime(dateTime);
If you want the value to update over time, you can do so with the useNow
hook:
import {useNow, useFormatter} from 'next-intl';
function Component() {
const now = useNow({
// Update every 10 seconds
updateInterval: 1000 * 10
});
const format = useFormatter();
const dateTime = new Date('2020-11-20T10:36:01.516Z');
format.relativeTime(dateTime, now);
}
Dates and times within messages
Dates and times can be embedded within messages as well:
{
"expiryDate": "{expiryDate, date, ::yyyyMd}"
}
See the FormatJS docs about date time (opens in a new tab) to learn more about this syntax.
Note the leading ::
that is used to indicate that a skeleton should be used.
Additionally, you can provide custom formats based on DateTimeFormat
options (opens in a new tab): :
{
"ordered": "You've ordered this product on {orderDate, date, short}"
}
t(
'orderDate',
{date: new Date('2020-11-20T10:36:01.516Z')},
{
// Custom formats can be supplied via the third parameter
dateTime: {
short: {
day: 'numeric',
month: 'short',
year: 'numeric'
}
}
}
);