Viene ora mostrato il codice di un semplice widget che permette di effettuare o abbattere una chiamata telefonica e visualizza gli eventi ricevuti da AgentDesktop relativi ai contatti assegnati all'operatore.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
<title>AgentDesktop Widget Example - Reitek S.p.A.</title>
<!-- Font-Awesome -->
<link href="./../libs/Font-Awesome/css/font-awesome.min.css" rel="stylesheet" type="text/css">
<!-- Bootstrap -->
<link href="./../libs/Bootstrap-3.3.5/css/bootstrap.min.css" rel="stylesheet">
<!-- jQuery -->
<script type="text/javascript" src="./../libs/jQuery/jquery-1.11.3.min.js"></script>
<script>
jQuery.noConflict();
</script>
<!-- Bootstrap -->
<script src="./../libs/Bootstrap-3.3.5/js/bootstrap.min.js"></script>
<!-- AgentDesktop Widget -->
<script type="text/javascript" src="./../widget/agentdesktop_widget.js"></script>
<script type="text/javascript">
jQuery( document ).ready(function() {
AGENTDESKTOP.WIDGET.unbindContactCallback(WidgetContactCallback);
AGENTDESKTOP.WIDGET.bindContactCallback(WidgetContactCallback);
jQuery("#btnChiama").off("click");
jQuery("#btnChiama").unbind("click");
jQuery("#btnChiama").unbind();
jQuery("#btnChiama").on("click", function(e) {
var Destination = "";
var RegExprObj = null;
var isMatch = false;
Destination = jQuery("#txtComposizione").val();
Destination = Destination.replace(/ /g, '');
Destination = Destination.replace(/-/g, '');
Destination = Destination.replace(/\//g, '');
Destination = Destination.replace(/\./g, '');
RegExprObj = new RegExp("^[+0123456789]+$", "i");
isMatch = RegExprObj.test(Destination);
if (isMatch == true) {
if (Destination.length > 0) {
AGENTDESKTOP.CONTACT.MakeCall(Destination,"","","","");
}
} else {
AGENTDESKTOP.ALERT.Notify("Numerazione non valida", "Il numero telefonico selezionato contiene caratteri non validi.", "fa fa-tty fa-2x", 2);
}
});
jQuery("#btnAggancia").off("click");
jQuery("#btnAggancia").unbind("click");
jQuery("#btnAggancia").unbind();
jQuery("#btnAggancia").on("click", function(e) {
AGENTDESKTOP.CONTACT.Hangup();
});
});
function WidgetContactCallback(jQuery_eventType, data) {
try {
var ContactObj = JSON.parse(data);
jQuery("#ContactCallBackData").text( AGENTDESKTOP.WIDGET.GetTimeStamp() + " : " + data );
} catch (err_WidgetContactCallback) {
}
}
</script>
<!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->
</head>
<body>
<div class="well" style="margin-bottom: 0px;">
<div class="panel panel-primary" style="height: 160px;">
<div class="panel-heading">
<h3 class="panel-title"><span class="fa fa-phone fa-2x"></span> Nuova chiamata</h3>
</div>
<div class="panel-body">
<form class="form-horizontal">
<div class="form-group">
<label for="txtComposizione" class="control-label col-xs-2">Composizione:</label>
<div class="col-xs-10">
<input type="text" class="form-control" id="txtComposizione" placeholder="numerazione da chiamare">
</div>
</div>
</form>
<div class="col-md-12 text-center">
<button id="btnChiama" type="button" class="btn btn-success">
<span class="glyphicon glyphicon-earphone" aria-hidden="true"></span> Chiama
</button>
<button id="btnAggancia" type="button" class="btn btn-danger">
<span class="fa fa-times fa-1x" aria-hidden="true"></span> Aggancia
</button>
</div>
</div>
</div>
</div>
<br/>
<div class="well" style="margin-bottom: 0px;">
<div class="panel panel-primary" style="height: 230px;">
<div class="panel-heading">
<h3 class="panel-title"><span class="fa fa-bell-o fa-2x"></span> Ricezione evento da AgentDesktop</h3>
</div>
<div class="panel-body">
<code style="-ms-word-break: break-all; word-break: break-all; word-break: break-word; -webkit-hyphens: auto; -moz-hyphens: auto; hyphens: auto;">Qui vengono visualizzati gli eventi relativi ai contatti assegnati all'operatore.</code>
<br/>
<code id="ContactCallBackData" style="-ms-word-break: break-all; word-break: break-all; word-break: break-word; -webkit-hyphens: auto; -moz-hyphens: auto; hyphens: auto;">Evento</code>
</div>
</div>
</div>
</body>
</html>
Analizziamo il codice nel dettaglio.
Nella sezione head del documento html, dopo l'inclusione di utili librerie esterne come Font Awesome, jQuery e Bootstrap, è fondamentale importare il modulo
<script type="text/javascript" src="./../widget/agentdesktop_widget.js"></script>
per poter aver a disposizione il namespace AGENTDESKTOP e poter richiamare le API. Nel successivo tag script è contenuto il cuore della logica di funzionamento del widget. Al caricamento del documento, viene immediatamente chiamata
AGENTDESKTOP.WIDGET.bindContactCallback(WidgetContactCallback)
che effettua la bind della funzione WidgetContactCallback al fine di ricevere le notifiche sui contatti in gestione. Questa funzione, definita prima della chiusura del tag script, visualizza semplicemente nel riquadro "Ricezione evento da AgentDesktop" l'oggetto evento così come ricevuto da AgentDesktop. Ad ogni notifica di evento ricevuta, il testo nel riquadro varia dinamicamente di conseguenza. Si noti che nella funzione viene chiamata l'API
AGENTDESKTOP.WIDGET.GetTimeStamp()
per mostrare data e ora correnti. Al click dell'operatore sul pulsante "Chiama", viene verificata la numerazione inserita nel campo input "Composizione" e se contiene un numero telefonico valido, viene fatta partire una nuova chiamata tramite l'API
AGENTDESKTOP.CONTACT.MakeCall(Destination,"","","","").
Nel caso in cui il campo input sia vuoto o non contenga un numero di telefono valido, viene visualizzata una finestra informativa per un tempo di 2 secondi contenente il messaggio "Il numero telefonico selezionato contiene caratteri non validi.":
AGENTDESKTOP.ALERT.Notify("Numerazione non valida", "Il numero telefonico selezionato contiene caratteri non validi.", "fa fa-tty fa-2x", 2).
Infine, al click dell'operatore sul pulsante "Aggancia", viene abbattuta la chiamata in corso (nel caso sia attiva) tramite l'API:
AGENTDESKTOP.CONTACT.Hangup().
Il risultato finale del widget integrato in AgentDesktop è mostrato nella figura sottostante.
Questa sezione ha il compito di illustrare un esempio di integrazione che fa uso della lilbreria AgentDesktop Widget SDK al fine di poter gestire ed essere notificato dei contatti proposti all'operatore e poterne intercettare le relative notifiche all'interno della propria web-application.
Ricordiamo inoltre che AgentDesktop dispone di un Widget di esempio che illustra con del codice esemplificativo la maggior parte di situazioni e problematiche che l’integratore dovrà affrontare nel corso della realizzazione di un Widget personalizzato. Il Widget è presente in ogni distribuzione di AgentDesktop al seguente indirizzo: /AD/widget/agentdesktop_widget_sample.html
...
Figura 1 - La interfaccia principale del Widget di esempio che illustra l’utilizzo delle API suddividendole per categoria di appartenenza
Inclusione della libreria Javascript AgentDesktop Widget SDK all'interno della propria pagina:
Code Block | ||
---|---|---|
| ||
<!-- AgentDesktop SDK Widget -->
<script type="text/javascript" src="/AD/widget/agentdesktop_widget.js"></script> |
Registrazione di una propria funzione al fine di essere notificato degli eventi in corso sulla barra telefonica:
Code Block | ||
---|---|---|
| ||
// Bind Contacts/Agents Events
AGENTDESKTOP.WIDGET.unbindContactCallback(WidgetContactCallback);
AGENTDESKTOP.WIDGET.bindContactCallback(WidgetContactCallback); |
La funzione “WidgetContactCallback” verrà richiamata dalla libreria SDK automaticamente ogni qual volta si avrà una qualsiasi attività sia a livello di barra telefonica (ingresso di una chiamata, cambio di stato del contatto) oppure ogni volta che l’operatore modificherà la sua presenza sul media telefonico richiedendo per esempio la pausa o la login.
Gestione dello Stato Logico dell’Operatore
Gli eventi notificati ad AgentDesktop verso il Widget hanno una struttura JSON in cui la proprietà “event” descrive l’evento stesso. Possiamo per esempio ipotizzare una prima integrazione che riesca ad intercettare il cambiamento di stato dell’operatore al fine di poter contestualizzare la propria pagina del CRM in accordo alla disponibilità dell’agente loggato.
Code Block | ||
---|---|---|
| ||
function WidgetContactCallback(jQuery_eventType, data) {
var DataObj = null;
DataObj = JSON.parse(data);
if (DataObj.event == "AGENT:LOGGEDIN") {
// Operatore loggato
}
if (DataObj.event == "AGENT:PAUSE") {
// Operatore in pausa
}
if (DataObj.event == "AGENT:LOGGEDOUT") {
// Operatore appena sloggatosi
}
|
Gestione della assegnazione di un nuovo contatto all’operatore
Un altro scenario di integrazione è rappresentato dalla notifica sull’ingresso di un nuovo contatto telefonico schedulato dal sistema CTI ed assegnato all’operatore. In questo caso l’evento POPUP determina il primo momento utile di presa in carico di un contatto da parte dell'operatore.
Code Block | ||
---|---|---|
| ||
if (DataObj.media_type.toUpperCase() == "TELEPHONY") {
// Gestisco solo gli eventi telefonici ed escludo le tipologie di contatto chat e multimediale
if (DataObj.event.toUpperCase() == "POPUP") {
// Primo evento utile per la presa in carico di un contatto
if (DataObj.isACD == true) {
// Gestico solo le telefonate schedulate dal sistema verso l'operatore
}
}
} |
Gestione di una chiamata manuale
E' possibile individuare una chiamata gestita dal CTI rispetto ad una chiamata effettuata manualmente dall’operatore. In questo caso andremo ad intercettare il primo evento utile di impegno della linea telefonica. ovverosia l’evento CONNECTIONSTARTED.
Una nuova proprietà denominata “job_type” ci informa sulla origine del contatto. Nel caso sia valorizzata a “manual” significa che la telefonata è frutto di una esplicita richiesta da parte dell’operatore e non è gestita direttamente dal sistema ContaCT7.
Code Block |
---|
if (DataObj.media_type.toUpperCase() == "TELEPHONY") {
// Censimento delle CHIAMATE MANUALI richieste direttamente dall'operatore via AgentDesktop Toolbar o via API
if (DataObj.event.toUpperCase() == "CONNECTIONSTARTED") {
if ( (DataObj.isACD == false) && (DataObj.job_type == "manual") ) {
}
}
} |
Comporre una chiamata manuale uscente
E' possibile eseguire una chiamata uscente andando ad intercettare l’evento “click” di un pulsante definito nella propria web-app. Nell’handler dell’evento si andrà a richiamare la API di AgentDesktop “MakeCall”.
...
Code Block | ||
---|---|---|
| ||
// Make Call
jQuery("#btnMakeCall").click(
function() {
AGENTDESKTOP.CONTACT.MakeCall( jQuery("#inputDestinationNumber").val() );
}
);
// Hangup Call
jQuery("#btnHangup").click(
function() {
AGENTDESKTOP.CONTACT.Hangup();
}
);
|
Visualizzazione di messaggi di errore
E' possibile visualizzare tramite la interfaccia grafica di AgentDesktop dei messaggi di errore relativi al funzionamento del proprio Widget.
Per esempio al click dell'operatore sul pulsante "Make Call", viene verificata la numerazione inserita nel campo input "Destination Number”" e nel caso in cui il campo input sia vuoto o non contenga un numero di telefono valido, viene visualizzata una finestra informativa per un tempo di 4 secondi :
Code Block | ||
---|---|---|
| ||
//Visualizzazione come finestra di dialogo centrale
AGENTDESKTOP.ALERT.Notify("Numerazione non valida", "Il numero telefonico selezionato contiene caratteri non validi.", "fa fa-tty fa-2x", 4); |
...
Trasferimento diretto di una telefonata
Per il trasferimento diretto di un contatto telefonico o chat (senza consultazione) viene utilizzata la seguente API:
Code Block | ||
---|---|---|
| ||
AGENTDESKTOP.CONTACT.Transfer_Direct("", "0227070058") |
Il primo parametro indica l’identificativo del contatto da trasferire. Se omesso verrà utilizzata la chiamata corrente. Il secondo parametro indica la destinazione, può essere utilizzata una numerazione pubblica o l’identificativo di una risorsa dell Call Center.
Dopo la richiesta di trasferimento l’integrazione verrà notificata con una serie di eventi:
La telefonata principale verrà messa in attesa mediante la ricezione dell’evento HELD. La messa in attesa è eseguita automaticamente dal sistema. Si riporta un estratto della struttura Contatto passata nella callback di ciascuna integrazione:[EVENT] [HELD] [13b-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13b-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[f7875bc8-0db9-429f-bc7b-02013f72298d]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[online]
ani....................[3393669393]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[]
Indipendentemente dall’esito del trasferimento (positivo nel caso in cui cliente e destinazione vengano messi in comunicazione, o negativo nel caso di rifiuto) alla integrazione verrà notificato l’evento di TRANSFERRED sulla chiamata principale. La trasferta diretta di fatto è un comando lancia e dimentica, l’operatore non verrà a conoscenza dell’esito del trasferimento.[EVENT] [TRANSFERRED] [13b-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13b-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[f7875bc8-0db9-429f-bc7b-02013f72298d]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[online]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[]
La chiamata principale si concluderà con l’evento CONNECTIONCLEARED[EVENT] [CONNECTIONCLEARED] [13b-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13b-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[f7875bc8-0db9-429f-bc7b-02013f72298d]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[online]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[transferred]
Il contatto entrerà nella sua fase di gestione Offline (After Call Work) mediante la notifica dell’evento JOBCHANGED.[EVENT] [JOBCHANGED] [13b-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13b-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[f7875bc8-0db9-429f-bc7b-02013f72298d]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[offline]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[transferred]
Una volta esitato lo Script la fase di lavorazione del Contatto si concluderà[JOBFINISHED] [13b-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13b-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[f7875bc8-0db9-429f-bc7b-02013f72298d]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[finished]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[transferred]
Trasferimento di una telefonata con consultazione
Per il trasferimento con consultazione di un contatto telefonico viene utilizzata la seguente API:
Code Block | ||
---|---|---|
| ||
AGENTDESKTOP.CONTACT.Transfer_Consultation("", "02270700598"); |
Durante la consultazione la chiamata principale verrà messa automaticamente in attesa:[EVENT] [HELD] [13f-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13f-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[baabb838-ff32-4c15-afa9-78b4a7d01b59]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[online]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[]
Verrà generata una seconda telefonata manuale uscente di consultazione avente un nuovo identificativo:[EVENT] [CONNECTIONSTARTED] [3f-5e5fbc28@B2BUAEP.enghouse.com]
id.....................[3f-5e5fbc28@B2BUAEP.enghouse.com]
uuid...................[dd124824-5079-41f6-b5bc-46ae3b8362a6]
chat_id................[]
type...................[outbound]
media_type.............[telephony]
content_type...........[]
content_description....[]
job_type...............[manual]
job_state..............[]
ani....................[80165@B2BUAEP.enghouse.com]
dnis...................[consultation]
queue..................[]
reason.................[]
[EVENT] [DIALING] [3f-5e5fbc28@B2BUAEP.enghouse.com]
id.....................[3f-5e5fbc28@B2BUAEP.enghouse.com]
uuid...................[dd124824-5079-41f6-b5bc-46ae3b8362a6]
chat_id................[]
type...................[outbound]
media_type.............[telephony]
content_type...........[]
content_description....[]
job_type...............[manual]
job_state..............[]
ani....................[80165@B2BUAEP.enghouse.com]
dnis...................[consultation]
queue..................[]
reason.................[]
[EVENT] [ESTABLISHED] [3f-5e5fbc28@B2BUAEP.enghouse.com]
id.....................[3f-5e5fbc28@B2BUAEP.enghouse.com]
uuid...................[dd124824-5079-41f6-b5bc-46ae3b8362a6]
chat_id................[]
type...................[outbound]
media_type.............[telephony]
content_type...........[]
content_description....[]
job_type...............[manual]
job_state..............[]
ani....................[80165@B2BUAEP.enghouse.com]
dnis...................[consultation]
queue..................[]
reason.................[]
A questo punto si può decidere di eseguire una delle seguenti azioni:
Annullare la consultazione mediante il metodo AGENTDESKTOP.CONTACT.Hangup specificando l’identificativo della chiamata di consultazione.
Finalizzare il trasferimento mediante il metodo AGENTDESKTOP.CONTACT.Transfer_Complete
Finalizzare il trasferimento con una conference a tre partecipanti (clilente, operatore e numero consultato) mediante il metodo AGENTDESKTOP.CONTACT.Transfer_Complete_Conference
Nel nostro esempio verrà finalizzato il trasferimento richiamanto la API AGENTDESKTOP.CONTACT.Transfer_Complete.
Si riceverà l’evento di TRANSFERRED sulla chiamata principale:[EVENT] [TRANSFERRED] [13f-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13f-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[baabb838-ff32-4c15-afa9-78b4a7d01b59]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[online]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[]
La chiamata principale terminerà la sua fase Online venendo agganciata:[EVENT] [CONNECTIONCLEARED] [13f-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13f-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[baabb838-ff32-4c15-afa9-78b4a7d01b59]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[online]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[transferred]
Verrà terminata anche la chiamata di consultazione:[EVENT] [CONNECTIONCLEARED] [3f-5e5fbc28@B2BUAEP.enghouse.com]
id.....................[3f-5e5fbc28@B2BUAEP.enghouse.com]
uuid...................[dd124824-5079-41f6-b5bc-46ae3b8362a6]
chat_id................[]
type...................[outbound]
media_type.............[telephony]
content_type...........[]
content_description....[]
job_type...............[manual]
job_state..............[]
ani....................[80165@B2BUAEP.enghouse.com]
dnis...................[consultation]
queue..................[]
reason.................[transferred]
Sulla postazione dell’operatore il contatto entrerà nella sua fase di gestione Offline (After Call Work):[EVENT] [JOBCHANGED] [13f-5d9daab7@B2BUAGW1.enghouse.com]
id.....................[13f-5d9daab7@B2BUAGW1.enghouse.com]
uuid...................[baabb838-ff32-4c15-afa9-78b4a7d01b59]
chat_id................[]
type...................[inbound]
media_type.............[telephony]
content_type...........[live]
content_description....[]
job_type...............[inbound]
job_state..............[offline]
ani....................[customer]
dnis...................[225727273]
queue..................[QUEUE25]
reason.................[transferred]