This plugin is no longer maintained as of September 28, 2022. Supervisor Barge Coach has been migrated to Twilio Professional Services Flex Template. Supervisor Barge Coach has been updated to support both 1.X and 2.X Flex versions within the template.
Twilio Flex Plugins allow you to customize the appearance and behavior of Twilio Flex. If you want to learn more about the capabilities and how to use the API, check out our Flex documentation.
This plugin adds a barge-in and coach button to the Monitor call canvas. You can get to this via the Team View, click on the agent you wish to monitor and the buttons will be available once you begin to monitor the live calls. The left button is the Barge-In button which allows you to join the conference all with the agent(s) and customer(s). Toggling this button will mute/unmute yourself. The right button is the Coach button which allows you to talk to the agent you are monitoring. The no other member of the call will be able to hear you except for the monitored agent. Toggling this button enables Coach and the left button converts to a Mute/Un-Mute button for the coaching mode.
First select the call/worker you wish to monitor
Click the Monitor button to enable the Barge-In Button (Middle Button) and the Coach Button (Right Button)
As of the Version 2 Update to the plugin, there has been an addition of the Coach Status Panel to the Agent's UI. This UI change can be enabled/disabled by the below button (as of Version 2.1 of this plugin)
As of the Version 2.1 Update to the plugin, there is a private toggle to enable/disable the agent's ability to see who is coaching them
To deploy this plugin, you will need:
- An active Twilio account with Flex provisioned. Refer to the Flex Quickstart to create one.
- npm version 5.0.0 or later installed (type
npm -v
in your terminal to check) - Node.js version 10.12.0 or later installed (type
node -v
in your terminal to check) - Twilio CLI along with the Flex CLI Plugin and the Serverless Plugin. Run the following commands to install them:
# Install the Twilio CLI npm install twilio-cli -g # Install the Serverless and Flex as Plugins twilio plugins:install @twilio-labs/plugin-serverless twilio plugins:install @twilio-labs/plugin-flex@beta
- A GitHub account
Before we begin, we need to collect all the config values we need to run this Flex plugin:
Config Value | Description |
---|---|
Account Sid | Your primary Twilio account identifier - find this in the Console. |
Auth Token | Used to create an API key for future CLI access to your Twilio Account - find this in the Console. |
Workspace SID | Your Flex Task Assignment workspace SID - find this in the Console TaskRouter Workspaces page. |
Make sure you have Node.js as well as npm
installed.
Navigate to the primary plugin folder and run NPM install for the plugin
cd plugin-supervisor-barge-coach
npm install
Navigate to the serverless folder, create and modify the .env file
cd ..
cd serverless
***rename the .env.example file to .env and change the below:
ACCOUNT_SID= Found at https://www.twilio.com/console
AUTH_TOKEN= Found at https://www.twilio.com/console
TWILIO_WORKSPACE_SID = WSXXXXXXXXXXXXXXXXXX
Run NPM install for the serverless functions
Run: (from the serverless directory)
npm install
Install the twilio plugin-serverless
Run:
twilio plugins:install @twilio-labs/plugin-serverless
Deploy the serverless functions into Twilio Do this if you haven't deployed the serverless functions already
Run:
twilio serverless:deploy
Copy the domain as you'll need this for the .env in the next step
From the root plugin directory rename the .env.example file to .env and change the below:
cd ..
cd plugin-supervisor-barge-coach
var REACT_APP_SERVICE_BASE_URL =
Points to the Twilio Function Service URL (example: https://barge-coach-XXXX-dev.twil.io)
Can be found by by going to https://www.twilio.com/console/functions/overview/services then click on barge-coach (should look like barge-coach-XXXX-dev.twil.io)
var REACT_APP_TASK-CHANNEL_SID =
Points to Voice Channel SID - Can be found by going to https://www.twilio.com/console/taskrouter/dashboard > click on Workspaces > then Task Channels
From the public folder, create the appConfig.js and change on variable within it
cd public
rename appConfig.example.js to appConfig.js
change serviceBaseUrl: "https://barge-coach-XXXX.twil.io"
In order to develop locally, you can use the Webpack Dev Server by running (from the root plugin directory):
Twilio flex:plugins:start
This will automatically start up the Webpack Dev Server and open the browser for you. Your app will run on http://localhost:3000
. If you want to change that you can do this by setting the PORT
environment variable:
When you make changes to your code, the browser window will be automatically refreshed.
When you are ready to deploy your plugin, in your terminal run:
Run:
twilio flex:plugins:deploy --major --changelog "Notes for this version" --description "Functionality of the plugin"
For more details on deploying your plugin, refer to the deploying your plugin guide.
After running the suggested next step with a meaningful name and description, navigate to the Plugins Dashboard to review your recently deployed and released plugin. Confirm that the latest version is enabled for your contact center.
You are all set to test the Supervisor Barge/Coach features on your Flex instance!
September 24, 2021
- Improved how the Render works within the Coach and Supervisor Panels. Previous design was causing those components to re-subscribe to sync docs.
June 7, 2021
- Updated Sync Doc with an array of Supervisors, coaching panel now supports an array of supervisors if multiple are coaching at the same time
- Optimized initSync function
May 24, 2021
- Added a Private Toggle to to the Supervisor UI to enable/disable the ability for the agent to see who is coaching them
- Fixed a minor bug when the coaching panel was rendering
May 12, 2021
- Added the Coach Status Panel to allow the agent to see who is coaching them (this leverages Sync Documents)
- Updated the Button Layout to be more user friendly (now has a Mute, Barge, and Coach button)
May 4, 2021
- Updated README - added changelog
This software is to be considered "sample code", a Type B Deliverable, and is delivered "as-is" to the user. Twilio bears no responsibility to support the use or implementation of this software.