UI Extensions - Parameters
What are parameters?
It's important to achieve separation of the code that forms your UI extension and the configuration that is used by it. This way it can be shared, reused and reconfigured without any code changes.
Below are some examples of the use cases for parameters:
- Default values.
- Project, category or entity identifiers when loading data from external APIs.
- Slack channel name to post messages to.
- Content types to process (e.g. for publishing content trees).
- Kinds of validation to apply.
There are the following types of configuration parameters that can be set up:
- Installation parameters — Are set during installation in a space environment and which can be modified in subsequent configuration updates. Their values are available across all usages of the UI extension in the environment.
- Instance parameters — Are set when a space member with access to the content model assigns a UI extension to a location. Values provided are available only in the specific location and content type where they were entered.
Parameter definition
Parameter definition is an object constructed as described in the table below.
Property | Type and value | Is required? | Remarks |
---|---|---|---|
id |
String | yes | Can contain only letters, numbers and underscores |
name |
String | yes | Human readable name of the parameter |
description |
String | no | Further explanation of the purpose of the parameter |
type |
String, one of Symbol , Enum , Number , Boolean |
yes | Enum parameters hold a predefined list of Symbol s |
required |
Boolean | no, defaults to false |
Whether the parameter value needs to be provided |
default |
Should match type |
no | Default value to use for the parameter. For Enum s it has to be defined on the options list |
options |
|
yes |
|
labels |
|
no | Used for rendering a form. All labels are optional and have sensible defaults in English |
Parameter definition for UI Extensions
Up to 8 instance and 8 installation parameters can be defined as a part of the Extension
entity:
{
"extension": {
"name": "My parametrized object editor",
"fieldTypes": [{type: "Object"}],
"srcdoc": "<!DOCTYPE html>...",
"parameters": {
"installation": [
{
"id": "devMode",
"type": "Boolean",
"name": "Run in development mode"
},
{
"id": "retries",
"type": "Number",
"name": "Number of retries for API calls",
"required": true,
"default": 3
}
],
"instance": [
{
"id": "helpText",
"type": "Symbol",
"name": "Help text",
"description": "Help text for a user to help them understand the editor"
},
{
"id": "theme",
"type": "Enum",
"name": "Theme",
"options": [{"light": "Solarized light"}, {"dark": "Solarized dark"}],
"default": "light",
"required": true
}
]
}
}
}
Set and read parameter values
Instance parameters are set in the Editor Interface entity.
Installation parameters are provided as a top-level parameters
property of the Extension
entity:
{
"parameters": {
"devMode": true,
"retries": 10
}
}
Values, for both instance and installation parameters, can be read with the App SDK:
init((sdk) => {
console.log(sdk.parameters.instance);
console.log(sdk.parameters.installation);
});
Next steps
Not what you’re looking for? Try our FAQ.