Scalars
Scalars are simple types that donât have any fields. Examples of these include string, int32, boolean, and so on.
You can declare a scalar by using the scalar keyword. Its name must be an identifier.
scalar ternary;Extending a scalar
Section titled âExtending a scalarâYou can create a new scalar that extends an existing one by using the extends keyword.
scalar Password extends string;Scalars with template parameters
Section titled âScalars with template parametersâScalars can also support template parameters. These template parameters are primarily used for decorators.
@doc(Type)scalar Unreal<Type extends valueof string>;Scalar constructors
Section titled âScalar constructorsâScalars can be declared with a constructor for creating specific scalar values based on other values. For example:
scalar ipv4 extends string { init fromInt(value: uint32);}
const homeIp = ipv4.fromInt(2130706433);Constructors do not have any runtime code associated with them. Instead, they merely record the scalar constructor invoked along with the arguments passed so that emitters can construct the proper value when needed.
Date/time constructors
Section titled âDate/time constructorsâThe built-in date and time scalars provide constructors for common use cases:
fromISO: create from ISO 8601 string
Section titled âfromISO: create from ISO 8601 stringâconst date = plainDate.fromISO("2024-05-06");const time = plainTime.fromISO("12:34");const timestamp = utcDateTime.fromISO("2024-05-06T12:20:00Z");const offsetTime = offsetDateTime.fromISO("2024-05-06T12:20:00-07:00");const period = duration.fromISO("P1Y1D");now: current date/time
Section titled ânow: current date/timeâThe now() constructor indicates that the current date or time should be used. Emitters interpret this as the appropriate runtime value (e.g., database CURRENT_TIMESTAMP, JavaScript Date.now(), etc.).
model Record { createdAt: utcDateTime = utcDateTime.now(); updatedAt: utcDateTime = utcDateTime.now();}
model Event { date: plainDate = plainDate.now(); time: plainTime = plainTime.now();}