This library enables the usage of classes from the java.time
package from Enonic XP application code.
Other JavaScript-based time libraries like Moment.js or date-fns will negatively impact your bundle size and build time. This library is only a thin TypeScript-wrapper around the excellent core java.time
library already present in your system!
To install this library you need to add a new dependency to your app's build.gradle file.
repositories {
maven { url "https://repo.itemtest.no/releases" }
}
dependencies {
include "no.item:lib-xp-time:1.1.0"
}
To update the version of enonic-types in package.json using npm, run the following command:
npm i -D @item-enonic-types/lib-time
You can add the following changes to your tsconfig.json to get TypeScript-support.
{
"compilerOptions": {
+ "baseUrl": "./",
+ "paths": {
+ "/lib/xp/*": ["./node_modules/@enonic-types/lib-*"],
+ "/lib/*": [ "./node_modules/@item-enonic-types/lib-*" ,"./src/main/resources/lib/*"],
+ }
}
}
You can import java.time
and java.time.format
classes from "/lib/time"
.
Example of date math on a LocalDateTime
using "/lib/time"
:
import { LocalDateTime, DateTimeFormatter } from "/lib/time";
const today = LocalDateTime.parse("2023-02-21T12:15:30");
const formatter = DateTimeFormatter.ofPattern("dd.MM hh:mm")
const inThreeWeeksStr = today
.plusWeeks(3)
.format(formatter);
// inThreeWeeksStr = "14.03 12:15"
Example of doing time math using a ZonedDateTime
:
import { ZonedDateTime } from "/lib/time";
const date = ZonedDateTime.parse("2023-02-21T12:15:30+01:00");
const fiftyMinutesAgo = date.minusMinutes(50);
const time = fiftyMinutesAgo.toLocalTime();
// time = "11:25:30"
This library also exposes a utility function formatDate()
to simply format a date:
import { formatDate } from "/lib/time";
const today = formatDate({
date: "2023-02-21",
pattern: "dd-MM-yyyy",
locale: "no"
});
// today = "21-02-2023"
Use formatDate()
with a given timezoneId
import { formatDate } from "/lib/time";
const today = formatDate({
date: "2023-02-21",
pattern: "dd-MM-yyyy",
locale: "no",
timezoneId: "Europe/Oslo"
});
// today = "21-02-2023"
Example of using Locale
in formatting a LocalDateTime
and get a normalized timestamp :
import { LocalDateTime, DateTimeFormatter, Locale } from "/lib/time";
const today = LocalDateTime.parse("2023-02-21T12:15:30");
const formatter = DateTimeFormatter.ofPattern("EEEE d. MMMM yyyy hh:mm:ss", new Locale("no"));
const time = today.format(formatter);
// time = "tirsdag 21. februar 2023 12:15:30"
Example of using hte LanguageRange
utility to find the preferred locale among the ones supported by the application.
import { LanguageRange, Locale } from "/lib/time";
import { getSupportedLocales } from "/lib/xp/i18n";
import type { Request, Response } from "@enonic-types/core";
export function get(req: Request): Response {
const languageRange = LanguageRange.parse(req.headers["Accept-Language"]);
const locale: string = Locale.filterTags(
languageRange,
getSupportedLocales(["i18n/phrases"])
)[0];
...
}
The following classes is exposed/exported from "/lib/time"
:
DateTimeFormatter
DayOfWeek
Instant
LanguageRange
LocalDate
LocalDateTime
Locale
LocalTime
Month
OffsetDateTime
OffsetTime
ZonedDateTime
ZoneId
ZoneOffset
To build the project, run the following command
enonic project build
You will find the jar-file at ./build/libs/item.jar
To deploy to a local sandbox, run the following command
enonic project deploy
./gradlew publish -P com.enonic.xp.app.production=true