Skip to contentSkip to navigationSkip to topbar
On this page

Flex UI 1.x.x components


(information)

This page applies to Flex UI 1.x.x.

For the Flex UI 2.x.x version of this content, see Flex UI Components.

(information)

Info

Auto-Generated Documentation for the Flex UI(link takes you to an external page) is now available. The auto-generated documentation is accurate and comprehensive, and so may differ from what you see in the official Flex UI documentation.

Flex UI is a library of programmable or dynamic components that expose a Content property and allow you to add, replace, or remove any component and its children.


Content property and add / replace / remove methods

content-property-and-add--replace--remove-methods page anchor

This article provdies a list of UI components and their details. You can override these components programmatically using the add, replace, and remove methods with options.

(warning)

Warning

You must declare a key for all components.

Syntax for the add and replace methods

syntax-for-the-add-and-replace-methods page anchor
1
Flex.Component.Content.add(<MyComponent key="demo-component"/>, {options});
2
Flex.Component.Content.replace(<MyComponent key="demo-component"/>, {options});

Example

The following example adds a component called AnotherMuteButton to the MainHeader component. The AnotherMuteButton component appers aligned to the end (left, in the example) and placed as the first component in front of native components MuteButton and UserControls:

1
Flex.MainHeader.Content.add(<AnotherMuteButton key="mute"/>, {
2
sortOrder: -1,
3
align: “end”
4
});

Syntax for the remove method

syntax-for-the-remove-method page anchor

The remove method allows you to remove immediate children of a programmable component by their key.

Flex.Component.Content.remove(key, {options});

Example

The following example shows removing the AnotherMuteButton component from the MainHeader component mute key set in the previous example.

Flex.MainHeader.Content.remove("mute");

Options for the add, replace, and remove methods

options-for-the-add-replace-and-remove-methods page anchor

if (Expression)

if-expression page anchor

Used in both add and replace methods to add conditions on which component is added or replaced.

Example

1
Flex.MainHeader.Content.add(<AnotherMuteButton key="mute"/>, {
2
if : props => props.task.source.taskChannelUniqueName === "custom1"
3
});

Used in the add method to specify the order in which the new component is placed in relation to other children of the parent component. Native children components take priority. Sort order counter starts with 0. To always place a new component at the start or end of the order, use large numbers like -100 or 100, depending on the direction.

Example

1
Flex.MainHeader.Content.add(<AnotherMuteButton key="mute"/>, {
2
sortOrder: -1
3
});

align ('start' | 'end')

align-start--end page anchor

Used in the add method to align new components either to the top/bottom or right/left, depending on the direction of the parent component. Possible values are:

  • start: aligns new component on the left or top
  • end: aligns new component on the right or bottom

Example

1
Flex.MainHeader.Content.add(<AnotherMuteButton key="mute"/>, {
2
align: “end”
3
});

Each immediate child of a component has a key (required for the add and replace methods) and a set of properties that its children inherit. To find a component's key or explore component props, go to the Flex UI API Reference(link takes you to an external page).

Agent Desktop View components overview

agent-desktop-view-components-overview page anchor
Overview-agentUI_2.

Teams View components overview

teams-view-components-overview page anchor
Overview-Supervisor_UI_2.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

MainHeader_2.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

MainContainer-V2.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

LiveCommsBar.

Direction: Horizontal

Customizing the NotificationsBar is described in Notifications Framework

NotificationBar.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Sidenav.

Agent Desktop View Components

agent-desktop-view-components page anchor

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

AgentDesktopView-V2.

AgentDesktopView.Panel1

agentdesktopviewpanel1 page anchor

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

AgentDesktopViewPanel1-v2.

AgentDesktopView.Panel2

agentdesktopviewpanel2 page anchor

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Flex.AgentDesktopView.Panel2.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

NoCRM.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

NoTasksCanvas_v3.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

TaskListContainer-v2.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

For details on how to configure filters for the task list, see the UI configuration page.

TaskList.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Add / Replace / Remove and properties of the TaskListItem are described in the Task Channel Definition API.

TaskListItem.

Direction: Horizontal

Add, replace, or remove and properties of the TaskListItem are described in the Task Channel Definition API.

TaskListItemButtons.

Examples

Adding a button to Chat type task

1
Flex.DefaultTaskChannels.Chat.addedComponents = [{
2
target: "TaskListButtons",
3
component: <Flex.IconButton key="eye_button" icon="Eye" />
4
}];

Adding a button to Chat type task when it is in accepted state

1
Flex.DefaultTaskChannels.Chat.addedComponents = [{
2
target: "TaskListButtons",
3
component: <Flex.IconButton key="eye_button" icon="Eye" />,
4
options: { if: props.task.status === "accepted" }
5
}];
6

Removing a reject button from Chat type task

1
Flex.DefaultTaskChannels.Chat.removedComponents = [{
2
target: "TaskListButtons",
3
key: "reject"
4
}];

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Taskcanvas-v2.width-500.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

Flex.TaskCanvasHeader.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

Flex.TaskCanvasTabs.

Example

Add tabs and content

1
import { Tab } from "@twilio/flex-ui"
2
3
init(flex, manager) {
4
const Img = <img src="http://someimage.jpg" />;
5
6
flex.TaskCanvasTabs.Content.add(
7
<Tab icon={Img} iconActive={Img} key="my-new-tab">
8
<MyNewTabComponent/>
9
</Tab>
10
);
11
}

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Flex.TaskInfoPanel.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Flex.IncomingTaskCanvas.

IncomingTaskCanvasActions

incomingtaskcanvasactions page anchor

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

IncomingTaskCanvasActions.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

CallCanvas-v2.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

CallCanvasActions.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

MessagingCanvas-v2.width-500.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

Flex.MessageList.

MessageList.WelcomeMessage

messagelistwelcomemessage page anchor

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

MessageList.WelcomeMessage-v2.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Flex.MessageListItem.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Flex.MessageBubble.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Flex.MessageInput.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

WorkerDirectory.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

WorkerDirectoryTabs.

The Worker directory contains 2 tabs by default:

  • Agents - key workers
  • Queues- key queues

Example: Add new custom tab

1
Flex.WorkerDirectory.Tabs.Content.add(
2
<Flex.Tab key="my-tab" label="My Tab">
3
<div> "Hello World"
4
</div>
5
</Flex.Tab>
6
);

Worker Directory Tabs Hidden Filters

WorkerDirectoryTabs accepts 2 default props:

  • hiddenWorkerFilter
  • hiddenQueueFilter

Flex applies filters to the list in combination with the filter the user applies by typing in a search string. You can programmatically apply a filter that's hidden from the user, which means the user can't disable it. You could use this feature to pre-filter the list of available transferees an agent can search and choose from to show their team members or available agents only. The following example uses live query to do the following:

  • Flexilter the agents list to only show agents with a specific team_name attribute (you can set user attributes via your SSO provider)
  • Filter the agents list to only show agents that are in the Available activity
  • Filter the queues list to only show queues with a specific queue_name attribute
1
// Filter Agents by Worker Attributes or activity_name
2
Flex.WorkerDirectoryTabs.defaultProps.hiddenWorkerFilter = 'data.attributes.team_name CONTAINS "sales"'
3
Flex.WorkerDirectoryTabs.defaultProps.hiddenWorkerFilter = 'data.activity_name CONTAINS "Available"'
4
5
// Filter Queues by queue_name or queue_sid
6
Flex.WorkerDirectoryTabs.defaultProps.hiddenQueueFilter = 'data.queue_name CONTAINS "sales"'

The hidden filter feature is only available in @twilio/flex-ui@1.26.0 and later. Starting in 1.33.3, the hiddenWorkerFilter has been changed to queueFilter which takes a predicate function.

Flex.WorkerDirectoryTabs.defaultProps.queueFilter = (queue) => queue.queueName.includes("HR")

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

ParticipantsCanvas is a responsive component and will switch between regular mode and list mode depending on the size of the container its placed in. Regular mode and list mode contain different children - ParticipantCanvas and ParticipantCanvasListItem respectively. When customizing ParticipantsCanvas children, like adding an additional button, remember to do customization to both children components

Regular mode

ParticipantsCanvas.

List mode

ParticipantsCanvas in ListMode.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

ParticipantCanvas.

ParticipantCanvasListItem

participantcanvaslistitem page anchor

Direction: Vertical

ParticipantCanvas.ListItem.

WorkersDataTable is a programmable component. It is a Material UI table styled to the Flex theme with data from the Insights SDK.

View Full Component Reference >(link takes you to an external page)

(warning)

Warning

As of flex-ui v1.12.0 new exports were added to refer to workers instead of agents:

  • WorkersDataTable
  • WorkerListFilterSelect
  • WorkersDataTable
  • WorkersDataTableProps
  • WorkerListFilter

For example, AgentsDataTable is now referred to as WorkersDataTable. However, previous exports (like AgentsDataTable) are kept for backwards compatibility

By default, WorkersDataTable contains the following rows:

  • Agent - UserCard component

    • SupervisorUserCardFirstLine - default value retrieves the full name of the worker if it exists, and the identity if not. Variables provided to the template: worker
    • SupervisorUserCardSecondLine - default value shows the availability of the worker. Variables provided to the template: worker
    • The first and second row are template strings with names.
  • Calls -TaskCardList component, showing tasks of the voice channel in assigned and wrapping state

  • Other tasks - TaskCardList component, showing tasks of all channels (apart from voice) in assigned and wrapping state

Add columns to WorkersDataTable

add-columns-to-workersdatatable page anchor

You can add columns to the table programmatically. Columns can't be removed. You can add columns with different types of content:

  • TaskCardList component
  • Any custom component
  • String

TaskCardList

1
import { TaskCardList, ColumnDefinition } from "@twilio/flex-ui";
2
3
Flex.WorkersDataTable.Content.add(
4
<ColumnDefinition key="calls" header={"My Custom Header"} content={(items, context) => <TaskCardList tasks={items.tasks} />} />);

TaskCardList also has an optional filter property. If you don't set the filter property, Flex renders all tasks in the list:

1
export interface TaskCardListProps {
2
compareFunction?: (a: TaskData, b: TaskData) => number;
3
filter?: (task: TaskData) => boolean;
4
tasks: TaskData[];
5
}

Any custom component

1
import { ColumnDefinition } from "@twilio/flex-ui";
2
3
Flex.WorkersDataTable.Content.add(<ColumnDefinition key="hello" header={"Helloxxx"} content={<div>hello</div>}/>);

String

You can use Worker attributes as follows:

1
import { ColumnDefinition } from "@twilio/flex-ui";
2
3
Flex.WorkersDataTable.Content.add(<ColumnDefinition key="team" header={"Team"} content={item => item.worker.attributes.team_name}/>);

By default, WorkersDataTable has 2 filters:

  • All agents
  • Active agents - worker with current activity state set of type available

Filters for the Workers Table can be programmatically changed, by defining filters property of WorkersDataTable component

Example of creating a filter to show workers with activity "Break"

With configuration object

1
componentProps: {
2
WorkersDataTable: {
3
filters: [
4
{
5
query: 'data.activity_name == "Break"',
6
text: "Workers on break"
7
}
8
]
9
}
10
},...

With defaultProps API

1
Flex.WorkersDataTable.defaultProps.filters = [
2
{
3
query: 'data.activity_name == "Break"',
4
text: "Workers on break"
5
},...
6
]

Query data schema

data object in the query refers to TaskRouter worker resource. The following attributes on a worker can be used for filters query:

Object nameDescriptionFormat
data.activity_nameworker's current activity friendly nameString
data.attributesworker's attributesKey value pair
data.date_activity_changeddate of the last activity change of the current workerDatetime ISO8601
data.friendly_nameworker's friendly nameString
data.worker_activity_sidworker's current activity sidString
data.worker_sidworker's sidString
data.workspace_sidworker's workspace sidString

Query operators

WorkersDataTable is powered by Twilio Sync and Flex uses Twilio Sync Live Query for filtering of the workers. See Live Query docs for supported query operators.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

TaskCardList.

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

TaskCard.width-800.

Direction: Horizontal

AgentsDataTable.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Supervisor.TaskCanvas.

Supervisor.TaskCanvasHeader

supervisortaskcanvasheader page anchor

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

Supervisor.TaskCanvasHeader.

Supervisor.TaskCanvasTabs

supervisortaskcanvastabs page anchor

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

Supervisor.TaskCanvasTabs.

Worker directory contains 2 tabs by default:

Examples

Adding tabs and content

1
Flex.Supervisor.TaskCanvasTabs.Content.add(
2
<Flex.Tab key="my-tab" label="My Tab">
3
<div> "Hello World"
4
</div>
5
</Flex.Tab>
6
);

View Full Component Reference >(link takes you to an external page)

Direction: Horizontal

Flex.TaskInfoPanel.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

WorkerCanvas_2.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

WorkerCanvasHeader.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

WorkerProfile_2.

View Full Component Reference >(link takes you to an external page)

Direction: Vertical

WorkerSkills.

Need some help?

Terms of service

Copyright © 2025 Twilio Inc.