Workspace: Field Decorators open a URL
Creating a way to deep link to an external system is a great for avoiding lengthy & unnecessary integrations. Providing agents a way to get directly into a system without multiple clicks can be a huge time saver.
Prior to Workspace, adding a Field Decorator was accomplished by creating a UI Macro. To implement a UI macro a few steps were needed to getting your decorator on a form, including writing code.
Similarly, if you are using one of the Baseline Workspaces (SOW, ITAM, CSM/FSM, HR) or a custom workspace there are some steps to create a Field Decorator. Luckily no Jelly, HTML, or JS is involved. There is mostly no code, there is a bit of JSON to copy/paste, and the rest is all configuration driven.
These steps seems pretty simple/straightforward, but depending on your workspace configuration there may be a few additional steps to make your Field Decorator launch an external URL.
Creating the Field Decorator
- Navigate to Now Experience Framework > Declarative Actions > Field Decorators
- Fill in the following fields:
- Action label: Provide a descriptive label
- Implemented as: UXF Client Action
- Specify client action: Open URL
- Decorator applies to: Specific field
- Field Name: Select a field name to display the icon near
- Icon: Select an icon
- Table: Select table
- Save the form
- Click Related Links > Advanced view
- Set URL:
- Action Attributes > Payload Map > URL
- Fill in your URL
- use
{{actionModelField}}
syntax for examplenotion.so/{{displayValue}}
- Save the Form
- Navigate to the Workspace:
- Select a Record from the table you configured on the Action Assignment
- Confirm your Icon appears next to your field
At this point if you click your field decorator icon, nothing will happen. One additional (undocumented) set of steps is required to make the decorator actually launch/open a URL.
Creating the UX Add-on Event Mapping
- Navigate to the Action Assignment (Decorator) you created
- Related List > UX Add-on Event Mapping
- Create a new UX Add-on Event Mapping
- Fill in the following fields:
- Event Mapping Name: Provide a unique name
- Source Component: Form
- Source Declarative Action: Action Assignment from previous steps
- Controller: UI Controller Record Page
- Target Event: [Record Page] Item Selected
- Target Payload Mapping: Use payload below:
- Fill in the following fields:
{
"type": "MAP_CONTAINER",
"container": {
"route": {
"type": "JSON_LITERAL",
"value": "external"
},
"fields": {
"type": "JSON_LITERAL",
"value": null
},
"params": {
"type": "JSON_LITERAL",
"value": null
},
"redirect": {
"type": "JSON_LITERAL",
"value": null
},
"passiveNavigation": {
"type": "JSON_LITERAL",
"value": null
},
"title": {
"type": "JSON_LITERAL",
"value": null
},
"multiInstField": {
"type": "JSON_LITERAL",
"value": null
},
"external": {
"type": "MAP_CONTAINER",
"container": {
"url": {
"type": "EVENT_PAYLOAD_BINDING",
"binding": {
"address": [
"url"
]
}
}
}
}
}
}