Form elements
Configure form elements that may require input from users in Optimizely Connect Platform (OCP).
A form can have one or more sections
letting you organize input required from the user, such as having a section just for authentication and a separate section for configuration. See the following example:
sections:
- key: auth
label: Authenticate
properties:
- authorized
elements:
- ...
- key: config
label: Configuration
disabled:
key: auth.authorized
equals: false
elements:
- type: instructions
text: Finish installing the app by filling out the form below:
- ...
Sections are accordions where users can only open and interact with one section at a time. The previous example displays the following sections on the app's Settings tab in the Optimizely Connect Platform (OCP) App Directory:

Form element attributes
All form elements
include the following base attributes:
type
– The element type (for example,toggle
,text
,secret
, and so on).- (Optional)
visible
– A predicate that determines whether to show the element.
All input elements
include the following attributes:
type
– The element type (for example, toggle, text, secret, and so on).key
– A unique identifier used to access the data associated with this form field.label
– The label that displays above the field.help
– An explanation of the input value or instructions to help the user complete the form.- (Optional)
defaultValue
– The default value if the user has not edited the field. - (Optional)
required
– A predicate that, if evaluated totrue
, requires the field not to be empty before the user can submit the form. - (Optional)
validations
– A list of form validations that the app must perform before the user submits the form. - (Optional)
disabled
– A predicate that determines whether the element should display disabled (and be non-interactable). - (Optional)
readonly
– A predicate that determines whether to display the element.
You can dynamically show and hide any form element, and can also dynamically disable or require any input depending on the state of the entire form using predicates. You can also use predicates in validations to reduce the amount of logic you need for your app to process the form.
Form element types
Each form section must have one or more of the following element types:
Toggle
type: toggle
Displays a switch to turn an option on or off. This results in a boolean value.
- type: toggle
key: mms
label: MMS
help: Send an image along with the message. Additional messaging rates may apply.
- type: toggle
key: shortenLinks
defaultValue: true
label: Shorten links and enable click tracking
help: Shorten links to reduce message character counts and record click activity when links are followed.

Text input
type: text
Lets the user input plain text, configurable as a single or multi-line input.
- type: text
key: message
label: Message
multiline: true
help: The SMS message to deliver. Aim to stay under 140 characters for optimal formatting on mobile devices. Messages longer than 70 characters may be split into multiple messages.
required: true
- type: text
key: image
label: Image URL (optional)
help: The URL of an image to send along with the message. The URL must be publicly accessible and the image size must be **less than 525KB**.
required: true

Additional attributes fortext
elements
- (Optional)
dataType
– The preferred input data type if supported by the browser. Allowed values:text
,number
,email
,phone
. - (Optional)
hint
– Hint text that displays to the user until they make a selection. Only applicable toselect
display mode. - (Optional)
multiline
– Set totrue
if the text input should allow multiple lines of text. Otherwise, set tofalse
or do not include.
Secret
type: secret
Lets the user input sensitive text. Hides input as the user types and once they save it, displays the input as asterisks to keep the data protected. The user cannot access the original value after submitting the form.
- type: secret
key: client_secret
label: Client Secret
help: Get your [Client Secret](https://support.vendor.com/s/article?article=API-Getting-Started&language=en_US) from Vendor

Additional attributes forsecret
elements
- (Optional)
hint
– Hint text that displays to the user until they make a selection. Only applicable toselect
display mode.
Select
type: select
Displays multiple selectable options as either a toggle, radio buttons, or a drop-down list depending on the number of options.
- If there is only one option, OCP displays a
switch
, which is like a toggle. - If there are two or three options, OCP displays radio buttons.
- If there are four or more options, OCP displays a drop-down list.
NoteIf the data source is remote, OCP always displays a drop-down list.
To display radio buttons, see the following example:
- type: select
key: resync_day
label: Re-sync Day
help: Choose a day of the week to re-sync your attributes
options:
- text: Monday
value: 1
- text: Wednesday
value: 3
- text: Friday
value: 5

To display a drop-down list, see the following example:
- type: select
key: advertiser_id
label: Advertiser ID
help: Choose the advertiser in your portfolio to sync to
dataSource:
type: app
function: vendor_portfolio
disabled:
key: auth.authConfirmed
equals: false

Additional attributes forselect
elements
- (Optional)
display
– The preferred display format for the select element. Allowed values include:auto
,radio
, orselect
. - (Optional)
options
– A hard-coded list of options you can display to the user in the form of objects containingtext
andvalue
(see the previous example). - (Optional)
dataSource
– For dynamic select options, specify a data source instead of options. Supportshttp
orapp
as the source type. See remote select options for allowed values and implementation. - (Optional)
hint
– Hint text that displays to the user until they make a selection. Only applicable toselect
display mode.
Multi-select
type: multi_select
Lets the user choose one or more options from a set of switches (toggles) or a multi-select drop-down list, depending on the number of options.
- If there are more than three options, OCP displays switches (toggles).
- If there are four or more options, OCP displays a multi-select drop-down list.
- type: multi_select
key: fields
label: Fields to Sync
help: Select the fields you want to sync from ODP. Selecting a new field will require to click save for that field to start sending. Removing a field from the list will NOT delete the data in your Vendor
dataSource:
type: app
function: get_odp_field_options
defaultValue:
- insights.order_likelihood
- insights.ttno_days
- observations.discount_usage
- observations.average_order_revenue
- observations.order_revenue_percentile
- observations.total_revenue
- observations.total_revenue_percentile
- observations.order_count
- observations.order_count_percentile

Additional attributes formulti-select
elements
- (Optional)
display
– The preferred display format for the select element. Allowed values:auto
,checkbox
,select
. - (Optional)
options
– A hard-coded list of options you can display to the user in the form of objects containingtext
andvalue
(see previous example). - (Optional)
dataSource
– For dynamic select options, specify a data source instead of options. Supportshttp
orapp
as the source type. See remote select options for allowed values and implementation. - (Optional)
hint
– Hint text that displays to the user until they make a selection. Only applicable toselect
display mode.
Button
type: button
Lets the user perform an action by clicking the button. Each section that contains form data must have at least one submit style button. You can also use buttons to link to external sites when the user should perform an action outside the app's Settings tab in the OCP App Directory.
- type: button
label: Save
action: save
style: primary
- type: button
label: Start Sync
action: sync
disabled:
key: fieldsSaved
equals: false

Additional attributes forbutton
elements
action
– A string value representing the action this button performs, which the app handles using theonFormSubmit
handler (is not displayed to the user).- (Optional)
style
– The style of the button including:primary
,none
(default),danger
.
Link button
type: link_button
Displays a button that opens a URL in a new tab instead of submitting a form, which can be useful for directing the user to a settings page in the third-party product that the app is integrating with.
- type: link_button
label: Begin Integration
help: Creating a new integration in your Vendor
style: primary
href: https://{{{setup.store_domain}}}/integrations/new

Additional attributes forlink_button
elements
href
– A URL to the page you want to open in a new tab. Usehttps
when possible. Supports Mustache substitutions.- (Optional)
style
– The style of the button, including:primary
,none
(default),danger
.
OAuth button
type: oauth_button
Displays a button that opens a URL in a new tab instead of submitting a form, which is useful for directing the user to a settings page in the third-party product that the app is integrating with.
- type: oauth_button
label: Authorize
help: Creating a new integration in your Vendor
style: primary
href: https://{{{setup.store_domain}}}/integrations/new

Divider
type: divider
Displays a divider line between form elements.
- type: divider
This displays the following line between form elements.

Instructions
type: instructions
Displays a markdown formatted text paragraph you can add to the form to provide the user with detailed instructions or information. Use markdown to add links and images.
- type: instructions
text:
Visit your Vendors settings page ([https://app.vendor.com/settings](https://app.vendor.com/settings)) and paste the URL above in the Webhook URL field.
Once you save the Webhook URL, ODP will start receiving future Vendor data as it happens. 

Updated about 2 months ago