Set up a custom action menu for communication option
In Creatio, you can manage the communication options and addresses of contacts and accounts on their form pages in the Customer 360 app. Manage the communication options in the top left and manage the addresses on the Contact info tab. Learn more: Manage communication options and addresses in Freedom UI.
Creatio lets you add a custom action menu item to the following communication option elements:
- All communication options.
- Individual communication option.
- Communication option that has a custom display format.
Add a custom action menu item to all communication options
- 
Open an arbitrary form page. To do this, click  in the top right → Application management → Application Hub → select the app → select the form page. For example, Contacts form page. in the top right → Application management → Application Hub → select the app → select the form page. For example, Contacts form page.
- 
Add the source code of the Communication options component to the source code of the form page. - Select the Communication options component in the working area of the Freedom UI Designer.
- Click  in the action panel of the Freedom UI Designer and modify an arbitrary property in the setup area. For example, select the Read-only checkbox in the Editability block. in the action panel of the Freedom UI Designer and modify an arbitrary property in the setup area. For example, select the Read-only checkbox in the Editability block.
- Open the source code of the Freedom UI page. To do this, click  in the action panel of the Freedom UI Designer. After you save the page settings, Creatio opens the source code. in the action panel of the Freedom UI Designer. After you save the page settings, Creatio opens the source code.
- Find the source code that implements the Communication options component and delete the "readonly": truesnippet.
- Save the changes.
 
- 
Add a localizable string that stores the name of the custom action menu item. Instructions: Add a localizable string. 
- 
Set up the properties of the custom action menu item in the properties of the optionActionsconfiguration object.View the example that adds a custom action menu item to all communication options on the contacts form page below. viewConfigDiff schema sectionviewConfigDiff: /**SCHEMA_VIEW_CONFIG_DIFF*/[
 {
 "operation": "merge",
 /* Code of the "Communication options" component. */
 "name": "ContactCommunicationOptions",
 "values": {
 "optionActions": [
 /* Custom action menu item. */
 {
 "type": 'crt.MenuItem',
 /* The name of the custom action menu item. */
 "caption": "#ResourceString(SomeCustomCaption_caption)#",
 /* The icon of the custom action menu item. */
 "icon": 'message-warn-button-icon',
 /* Property that controls the visibility of the custom action menu item. */
 "visible": true,
 "clicked": {
 /* Bind an arbitrary request to the "clicked" event of the custom action menu item. */
 "request": 'SomeRequestName',
 /* Add custom request parameters. */
 "params": {
 ...
 },
 }
 }
 ],
 }
 },
 ...
 ]/**SCHEMA_VIEW_CONFIG_DIFF*/,
- 
Save the changes. 
- 
Clear the cache. 
- 
Refresh the page that contains the modified custom action menu. 
As a result, Creatio will add a custom action menu item to all communication options.
Detailed example: Add a custom action menu item to all communication options.
Add a custom action menu item to an individual communication option
General procedure to add a custom action menu item to an individual communication option:
- Find the communication option ID. Read more >>>
- Implement a custom action menu. Read more >>>
Detailed example: Add a custom action menu item to an individual communication option.
1. Find the communication option ID
- Open the Lookups section. To do this, click  in the top right → System setup → Lookups. in the top right → System setup → Lookups.
- Open the Communication option types lookup.
- Set up the lookup list. To do this, click View → Select fields to display on the lookup toolbar.
- Add the column to the lookup list. To do this, click  → select the Id column → Select. → select the Id column → Select.
- Save the changes.
- View the communication option ID in the Id column.
2. Implement a custom action menu
- 
Instructions: Add a custom action menu item to all communication options (steps 1–3). 
- 
Display the custom action menu item for an arbitrary communication option. To do this, bind the visibleproperty to the communication option ID.View the example that displays the custom action menu item for the Webcommunication option (6a8ba927-67cc-df11-9b2a-001d60e938c6ID) on the contacts form page below.viewConfigDiff schema sectionviewConfigDiff: /**SCHEMA_VIEW_CONFIG_DIFF*/[
 {
 "operation": "merge",
 /* Code of the "Communication options" component. */
 "name": "ContactCommunicationOptions",
 "values": {
 "optionActions": [
 /* Custom action menu item. */
 {
 "type": 'crt.MenuItem',
 /* The name of the custom action menu item. */
 "caption": "#ResourceString(SomeCustomCaption_caption)#",
 /* The icon of the custom action menu item. */
 "icon": 'message-warn-button-icon',
 /* Property that controls the visibility of the custom action menu item. Set up a display condition. */
 "visible": "$ContactCommunicationOptionsItems.ContactCommunicationOptionsDS_CommunicationType| crt.IsEqual : '6a8ba927-67cc-df11-9b2a-001d60e938c6'",
 "clicked": {
 /* Bind an arbitrary request to the "clicked" event of the custom action menu item. */
 "request": 'SomeRequestName',
 /* Add custom request parameters. */
 "params": {
 ...
 },
 }
 }
 ],
 }
 },
 ...
 ]/**SCHEMA_VIEW_CONFIG_DIFF*/,
 ...where: ContactCommunicationOptionsItemsis the name of the attribute to bind the communication options using theitemsfield.ContactCommunicationOptionsDSis the name of the data source to bind communication options.CommunicationTypeis the name of the model attribute.
- 
Save the changes. 
- 
Clear the cache. 
- 
Refresh the page that contains the modified custom action menu. 
As a result, Creatio will add a custom action menu item to an individual communication option.
Add a custom action menu item to the communication option that has a custom display format
General procedure to add a custom action menu item to the communication option that has a custom display format:
- Implement a custom template for display format. Read more >>>
- Implement a custom action menu. Read more >>>
Detailed example: Add a custom action menu item to the communication option that has a custom display format.
1. Implement a custom template for display format
- 
Implement a custom template for display format using a custom Freedom UI component. Instructions: Custom UI component implemented using remote module. 
- 
Change the display format. Instructions: Change the display format (optional). 
- 
Set up the custom display format. - 
Instructions: Add a custom action menu item to all communication options (steps 1–3). 
- 
Set up the properties of the configuration object that implements the custom display format in the properties of the templatesconfiguration object.View the example that sets up the custom_display_formatdisplay format on the contacts form page below.viewConfigDiff schema sectionviewConfigDiff: /**SCHEMA_VIEW_CONFIG_DIFF*/[
 {
 "operation": "merge",
 /* Code of the "Communication options" component. */
 "name": "ContactCommunicationOptions",
 "values": {
 "templates": {
 /* Add a custom display format. */
 "custom_display_format": {
 /* Type of the custom display format. Enter existing type in the "type" property. Otherwise, an error occurs. */
 "type": "CustomDisplayFormatType",
 ...
 }
 }
 }
 },
 ...
 ]/**SCHEMA_VIEW_CONFIG_DIFF*/,
- 
Save the changes. 
 
- 
As a result, the selected communication option will have the custom display format.
2. Implement a custom action menu
- 
Instructions: Add a custom action menu item to all communication options (steps 1, 3). 
- 
Set up the action menu properties in the toolsarray of configuration objects.
- 
Set up the properties of the action menu item in the menuItemsarray of configuration objects.View the example that sets up the custom_display_formatdisplay format on the contacts form page below.viewConfigDiff schema sectionviewConfigDiff: /**SCHEMA_VIEW_CONFIG_DIFF*/[
 {
 "operation": "merge",
 /* Code of the "Communication options" component. */
 "name": "ContactCommunicationOptions",
 "values": {
 "templates": {
 /* Add a custom display format. */
 "custom_display_format": {
 ...,
 /* Action menu of the custom display format. */
 "tools": [{
 "type": 'crt.Button',
 "icon": 'actions-button-icon',
 "iconPosition": 'only-icon',
 "color": 'default',
 "size": 'none',
 "clickMode": 'menu',
 "displayType": 'text',
 "classes": ['actions-btn'],
 "menuItems": [
 /* Action menu item. */
 {
 "type": 'crt.MenuItem',
 /* The name of the custom action menu item. */
 "caption": '#ResourceString(SomeCustomCaption_caption)#',
 /* The icon of the custom action menu item. */
 "icon": 'message-warn-button-icon',
 /* Property that controls the visibility of the custom action menu item. */
 "visible": true,
 "clicked": {
 /* Bind an arbitrary request to the "clicked" event of the custom action menu item. */
 "request": 'SomeRequestName',
 /* Add custom request parameters. */
 "params": {
 ...
 },
 }
 }
 ]
 }]
 }
 }
 }
 },
 ...
 ]/**SCHEMA_VIEW_CONFIG_DIFF*/,
- 
Save the changes. 
- 
Clear the cache. 
- 
Refresh the page that contains the modified custom action menu. 
As a result, Creatio will add a custom action menu item to the communication option that has a custom display format.
See also
Manage communication options and addresses in Freedom UI (user documentation)