Skip to content

Flex Plugin that adds the Barge-In and Coach feature/button to the UI. These buttons are usable when a Supervisor/User begins to monitor a call.

Notifications You must be signed in to change notification settings

aestellwag/plugin-supervisor-barge-coach

Repository files navigation

Twilio

Notice - Legacy Code

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 Plugin - Supervisor Barge-In and Coach

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
Plugin Demo

Click the Monitor button to enable the Barge-In Button (Middle Button) and the Coach Button (Right Button)
Plugin Demo

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)
Plugin Demo

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
Plugin Demo

Pre-req

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

Twilio Account Settings

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.

Setup

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"

Development

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.

Deploy

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.

View your plugin in the Plugins Dashboard

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!


Changelog

2.2.1

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.

2.2.0

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

2.1.0

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

2.0.0

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)

1.0.0

May 4, 2021

  • Updated README - added changelog

Disclaimer

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.

About

Flex Plugin that adds the Barge-In and Coach feature/button to the UI. These buttons are usable when a Supervisor/User begins to monitor a call.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published