Templates

Helper Functions

The following helper functions are available in the template.ejs file of invoice and proposal templates.

#t

Returns a translated string for key.

t (key: string): string

#formatDate

Returns a formatted date string, respecting the language of the invoice/proposal.

formatDate (date: string): string

#formatMoneyValue

Returns a formatted money value, respecting the language of the invoice/proposal and the currency of the money value.

formatMoneyValue (value: MoneyValue): string

#formatQuantity

Returns a string containing the quantity of an item and its unit label in the correct language of the invoice or proposal. If the language of the invoice or proposal is not part of the unit's labels, it will fallback to show the unit in another language.

formatQuantity (quantity: number, unit: Unit | null): string

#Example

// item.unit is a unit for "hours":
formatQuantity(1, item.unit) // "1 Hour"

// item.unit is a unit for "days":
formatQuantity(2, item.unit) // "2 Days"

// item.unit is null
formatQuantity(2, item.unit) // "2"

#formatUnit

Returns a unit's plural or singular label in the correct language of the invoice or proposal. If the language of the invoice or proposal is not part of the unit's labels, it will fallback to show the unit in another language.

formatUnit is used internally by formatQuantity and can be used to show only the label of a unit.

formatUnit (quantity: number, unit: Unit | null): string

#Example

// item.unit is a unit for "hours":
formatUnit(1, item.unit) // "Hour"

// item.unit is a unit for "days":
formatUnit(2, item.unit) // "Days"

// item.unit is null
formatUnit(2, item.unit) // ""

#join

Joins together an array of strings by a given separator, skipping falsey values.

join (strings: Array, separator: string): string

#Example

join(['Hello', '', 'World', undefined], ' • ') // "Hello • World"

#joinAddress

Joins together the components of an address by a given separator, skipping falsey values.

This helper handles several known address formats, such as German, US and UK addresses.

joinAddress (address: Address, separator: string): string

#Example

joinAddress(invoice.seller.address, ' • ') // "Company Name • Some street 76 • 99999 Berlin • Germany"

#countryCode

Returns the name of the country, respecting the language of the invoice/proposal.

countryCode (code: string): string

#field

Returns the value of the given custom field.

field (fieldName: string): any

#clsx

The popular clsx function for generating class names.