fetch
Fetch the content of a slot.
This method gets the content of a Slot to render in the application.
For more information, see the Content rendering reference.
Signature
This method has the following signature:
croct.fetch<T extends SlotId>(id: T, options: FetchOptions): Promise<FetchResponse<T>>
The return is a Promise that resolves to the slot content.
Example
Here is a basic example of how to use this method:
import croct from '@croct/plug';croct.fetch('home-hero@1').then(console.log);
Parameters
The following list describes the supported parameters:
- idstring
The ID of the slot to fetch.
You can specify the version of the slot by passing a versioned ID in the form id@version. For example, passing home-hero@1 will fetch the content for the home-hero slot in version 1. Not specifying a version number is the same as passing home-hero@latest, which will load the content for the latest version.
Best practiceAlways specify a version to ensure the front end receives content with the expected structure despite future schema changes.
For more information, see Slot versioning.
- options(optional)object
The fetch options.
- preferredLocale(optional)string
The locale code to fetch the content.
Good to knowYou can set a default locale for your application during SDK initialization, eliminating the need to specify it each time.
The code consists of a two-part string that specifies the language and, optionally, the country. For example, en represents English, en-us stands for English (United States), and pt-br for Portuguese (Brazil). It is case-insensitive and supports both hyphens and underscores as separators to accommodate the different conventions used by browsers, libraries, and other systems.
If no content is available in the preferred locale, the default locale content is returned instead.
Default:default locale- timeout(optional)number
The maximum fetch time in milliseconds.
Good to knowYou can set a default timeout for your application during SDK initialization, eliminating the need to specify it each time.
Once reached, the SDK will abort the request and reject the promise with a timeout error.
- attributes(optional)object
The map of attributes to inject in the evaluation context.
The attributes can be referenced in audience conditions using the context variable. For example, suppose you pass the following attributes:
{cities: ["New York", "San Francisco"]}You can then reference them in queries like:
context's cities include location's cityFor more information, see Context variables.
The following restrictions apply to the attributes:
- Up to 30 entries and 5 levels deep
- Keys can be either numbers or non-empty strings with a maximum length of 50 characters
- Values can be null, numbers, booleans, strings (up to 50 characters), or nested maps
- Nested maps follow the same constraints for keys and values
- preferredLocale(optional)