...
Convenzioni
Di seguito le convenzioni utilizzate nella descrizione delle funzioni.
nome_parametro: descrizione breve del parametro obbligatorio
<nome_parametro>: descrizione breve del parametro opzionale
ContactID: ID del contatto (telefonico/chat/multimediale). Identifica in modo univoco ciascun contatto in gestione sulla postazione operatore.
...
Gestione Contatto
Funzione | Descrizione |
---|---|
AGENTDESKTOP.CONTACT.MakeCall String DestinationNumber, String <ResourceType>, String <ServiceID>, String <CallProfileID>, String <CallData> | Effettua una chiamata telefonica. |
AGENTDESKTOP.CONTACT.Hangup
String <ContactIDE' possibile specificare i seguenti parametri aggiuntivi:
| |
AGENTDESKTOP.CONTACT.Hangup String <ContactID> | Conclude la fase online di un contatto telefonico o chat terminando la conversazione in corso. |
AGENTDESKTOP.CONTACT.HangupByContactID String ContactID | Conclude la fase online del contatto avente come identificativo il valore del parametro "ContactID" |
AGENTDESKTOP.CONTACT.Hold String ContactID | Mette o riprende dallo stato di attesa una chiamata telefonica. |
AGENTDESKTOP.CONTACT.Answer String ContactID | Risponde ad un contatto in ingresso/fase di accettazione sulla postazione operatore. |
AGENTDESKTOP.CONTACT.OfflineEnd String ContactID | Esce dallo stato offline (After Call Work) di un contatto e termina la fase di gestione del contatto stesso. |
AGENTDESKTOP.CONTACT. |
SetCallData String ContactID, |
Abilita/Disabilita pulsante di offline presente sulla toolbar principale.
AGENTDESKTOP.CONTACT.SetCallData
String ContactID, String CallData
String CallData | Imposta una variabile di CallData associata al contatto. Le variabili di CallData consentono di memorizzare sul singolo contatto dei dati personalizzati nel formato chiave=valore. AGENTDESKTOP.CONTACT.SetCallData("2d-5e5fbc28@B2BUAEP.enghouse.com", "CUSTOMERID=12345"); |
AGENTDESKTOP.CONTACT.StartRecording String ContactID, String <CallRecorders>, String <CallData>, String <Message> | Richiede la registrazione della chiamata telefonica. E' possibile specificare l'identificativo di un Registratore configurato sul sistema CTI o un eventuale identificativo di un messaggio da riprodurre in concomitanza della registrazione. Il messaggio deve essere preventivamente configurato sul sistema ContaCT. |
AGENTDESKTOP.CONTACT.StopRecording String ContactID, String <CallRecorders> | Interrompe la registrazione in corso della chiamata telefonica. |
AGENTDESKTOP.CONTACT.PlayDTMF String DTMF | Riproduce uno o più toni DTMF sulla chiamata in corso. AGENTDESKTOP.CONTACT.PlayDTMF("1#"); |
AGENTDESKTOP.CONTACT.Transfer_Direct String ContactID, String Destination, String ResourceType, String CallData | Richiede il trasferimento diretto di una telefonata. Come destinazione del trasferimento è possibile specificare una delle seguenti tipologie di risorsa: |
Destination: |
ResourceType:
|
...
Funzione
...
Descrizione
...
AGENTDESKTOP.CHAT.SendText(String Text)
...
TODO
...
AGENTDESKTOP.CHAT.GetEvents(String ContactID)
...
Restituisce array contenente lista di eventi per l'ID del contatto specificato
...
Funzione
Descrizione
AGENTDESKTOP.UI.bindModalCallback(function callback)
Effettua la bind di una propria funzione al fine di essere notificati sugli eventi relativi all'apertura/chiusura di finestre di dialogo in AgentDesktop
AGENTDESKTOP.UI.unbindModalCallback(function callback)
CallData: eventuale CallData da valorizzare prima di eseguire il trasferimento | |
AGENTDESKTOP.CONTACT.Transfer_Consultation String ContactID, String DestinationNumber, String ResourceType, String CallProfileID, String CallData | Richiede il trasferimento con consultazione di una telefonata. La telefonata del cliente in linea verrà messa in attesa e l'operatore verrà automaticamente rediretto verso la chiamata di consultazione con la numerazione specificata nel parametro DestinationNumber. CallProfileID: identificativo di un profilo di chiamata configurato sul sistema CTI CallData: eventuale CallData aggiuntivo che deve essere creato al momento del trasferimento. |
AGENTDESKTOP.CONTACT.Transfer_Complete String ResourceType, String <CallData> | Viene richiesto il completamento della chiamata di consultazione ed il trasferimento della telefonata verso il destinatario della consultazione. |
AGENTDESKTOP.CONTACT.Transfer_Complete_Conference String ResourceType | Viene richiesto il completamento della chiamata di consultazione mediante la instaurazione di una conference a tre partecipanti: cliente in linea, operatore che ha gestito la telefonata e destinatario della consultazione. |
...
Funzione
...
Descrizione
...
AGENTDESKTOP.WIDGET.getToken
...
Restituisce il token ottenuto dalla login Single Sign On di EasyCIM
...
AGENTDESKTOP.WIDGET.getTokenOneShot
...
Restituisce il token OneShot ottenuto dalla login Single Sign On di EasyCIM
...
AGENTDESKTOP.WIDGET.getContainerID
...
Restituisce l'identificativo del WIDGET
...
AGENTDESKTOP.WIDGET.bindContactCallback(javascript function)
...
Effettua la bind di una propria funzione javascript al fine di ricevere le notifiche sui contatti in gestione.
...
AGENTDESKTOP.WIDGET.unbindContactCallback(javascript function)
...
Effettua la unbind della vostra funzione
...
AGENTDESKTOP.WIDGET.bindWidgetDataCallback(function callback)
...
Effettua la bind di una vostra funzione al fine di ricevere le notifiche relative alla ricezione di dati custom da un altro Widget
...
AGENTDESKTOP.WIDGET.unbindWidgetDataCallback(function callback)
...
Effettua la unbind della vostra funzione
...
AGENTDESKTOP.WIDGET.sendDataToWidget(String destinationWidgetID, String data)
...
Invia dei dati custom ad un altro WIDGET identificato nel parametro (o paradossalmente anche a se stessi se si specifica il proprio ID)
...
AGENTDESKTOP.WIDGET.addCustomMenu(JSON String menu)
...
Inserisce un menu contestuale sul TAB di selezione del proprio WIDGET. Vedi sintassi JSON (vedi 9.4.1)
...
AGENTDESKTOP.WIDGET.enableCustomMenuItem(String ItemID, boolean [true/false])
...
Abilita/Disabilita una singola voce di menu nel TAB di selezione del WIDGET
...
AGENTDESKTOP.WIDGET.LOG(String testo)
...
LOG: Scrive una propria stringa nel log applicativo di AgentDesktop situato in %appdata%\Reitek\Contact\BrowserPlugin
...
AGENTDESKTOP.WIDGET.bindWidgetFocusCallback(function callback)
...
Effettua la bind di una vostra funzione al fine di notificare al Widget la selezione dell'utente e la conseguente ricezione del Focus sul proprio Tab.
...
AGENTDESKTOP.WIDGET.unbindWidgetFocusCallback (function callback)
...
Effettua la unbind della vostra funzione
...
AGENTDESKTOP.WIDGET.Reload(String < JumpToWidget>)
...
Ricarica Widget
...
AGENTDESKTOP.WIDGET.triggerContactCallback( String param)
...
Scatena la vostra funzione di cui avete fatto la bind con bindContactCallback()
...
AGENTDESKTOP.WIDGET.triggerWidgetDataCallback (String param)
...
Scatena la vostra funzione di cui avete fatto la bind con bindWidgetDataCallback()
...
AGENTDESKTOP.WIDGET. triggerWidgetFocusCallback(String param)
...
Scatena la vostra funzione di cui avete fatto la bind con bindWidgetFocusCallback()
...
AGENTDESKTOP.WIDGET.receiveDataFromWidget (String senderWidgetID, String data)
...
Riceve dei dati custom ad un altro WIDGET
...
AGENTDESKTOP.WIDGET.GetTimeStamp()
...
Restituisce stringa contenente data e ora attuale nel formato:
dd/mm/yyyy – hh:mm:ss
...
AGENTDESKTOP.WIDGET.getLanguage
...
Restituisce la lingua utilizzata in AgentDesktop. Esempio: "it", "en".
...
AGENTDESKTOP.WIDGET.activateCustomMenuItem(String itemID, param)
...
Permette di attivare la voce del menu contestuale con id itemID sul TAB di selezione del proprio WIDGET
Esempio di gestione di un evento CTI
InteGli eventi notificati da AD verso l'SDK hanno una struttura JSON, in cui la proprietà "event" descrive l'evento stesso.
Come esempio, osserviamo la sequenza di eventi notificati alla ricezione di un contatto inbound telefonico.
Tra di essi, una particolare attenzione si deve prestare verso l'evento di POPUP (del quale viene riportato il JSON completo) che determina il primo momento utile di presa in carico di un contatto da parte dell'operatore.
...
"event": "jobscheduled",
"event": "connectionstarted",
"event": "POPUP":
{
"event": "POPUP",
"eventPrevious": "connectionstarted",
"id": "1d-56cc5ff0@B2BUAGW1.reitek.com",
"uuid": "4fdab7ad-9cc5-42f2-b5cc-7a1def99ff8a",
"chat_id": "",
"type": "inbound",
"media_type": "telephony",
"content_type": "live",
"content_description": "",
"job_type": "inbound",
"job_state": "scheduled",
"service": "DefaultEnqueue",
"ani": "2270701",
"dnis": "225727113",
"queue": "QUEUE25",
"reason": "",
"primary_call": "",
"isACD": true,
"missed": false,
"other_id": "",
"startTime": 1456825081117,
"endTime": null,
"duration": "",
"startTime_hold": null,
"contactTimer": null,
"PopupShown": true,
"PopupShowing": true,
"PopupProposedShown": false,
"isChatStarted": false,
"connectionStarted": true,
"invite": false,
"join": false,
"dialing": false,
"ringing": false,
"hold": false,
"established": false,
"transferred": false,
"connectionCleared": false,
"partyChanged": false,
"held": false,
"retrieved": false,
"dataChanged": true,
"jobScheduled": true,
"jobStarted": false,
"jobFinished": false,
"jobProposed": false,
"jobSuspended": false,
"CallData": [
{
"name": "EC_MACROACTIVITY",
"value": "DEFAULT_INB"
},
{
"name": "CTHISTORY_1_Q",
"value": "QUEUE25@acd.reitek.com"
}
]
},
"event": "datachanged",
"event": "jobchanged",
"event": "ringing",
"event": "established",
"event": "jobstarted",
"event": "datachanged",
"event": "connectioncleared",
"event": "jobchanged", --> inizio stato offline, gestione acw da parte dell'operatore (proprietà "job_state": "offline")
"event": "jobfinished",
"event": "DELETE"
.
Un eventuale integratore, dopo aver importato l'SDK (<script type="text/javascript" src="./agentdesktop_widget.js"></script>), dovrebbe effettuare la bind della funzione di callback:
AGENTDESKTOP.WIDGET.bindContactCallback(WidgetContactCallback);
Questa funzione può essere definita per intercettare e gestire certi titpi di eventi:
function WidgetContactCallback(jQuery_eventType, data) {
try {
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 == "POPUP") {
if (DataObj.isACD == true) {
// Gestione chiamata ACD, non manual
if (DataObj.type == "inbound") {
// Gestione chiamata inbound
}
if (DataObj.type == "outbound") {
// Gestione chiamata outbound
}
}
}
} catch (err_WidgetContactCallback) {
}
}
In particolare, la proprietà "media_type" indica il canale su cui sta viaggiando il contatto (telephony, chat, channel), la proprietà "type" indica la tipologia della chiamata (inbound, outbound, calltask), la proprietà "job_type" descrive la natura del contatto (manual/non manual), la proprietà "job_state" descrive lo stato in cui si trova il contatto (scheduled, setup, online, offline).
Si noti la differenza tra gli eventi che sono pura segnalazione SIP (connectionstarted, ringing, established, connectioncleared,…) da quelli che sono job, cioè che arricchiscono la segnalazione e fanno capire che l'operatore sta gestendo un contatto gestito dal Sistema (isACD = true) (jobscheduled, jobchenged, jobstarted, jobfinished).
...
La loggata avrà il seguente formato:
"14/01/2015 - 14:57:52 [ID WIDGET] " + testo
...
Funzione
...
Descrizione
...
AGENTDESKTOP.TAB.Badge(String Badge)
...
Imposta il Badge all'interno del Tab di selezione del WIDGET. Se stringa vuota il Badge viene cancellato
...
AGENTDESKTOP.TAB.Focus()
...
Sposta la selezione sul TAB del proprio WIDGET
...
AGENTDESKTOP.TAB.Home()
...
Sposta la selezione sul TAB di HOME di AGENTDESKTOP (il primo)
...
AGENTDESKTOP.TAB.Add(String ID, String Title, String URL, String Icon)
...
Permette di inserire voci di menu all'interno di un TAB
...
AGENTDESKTOP.TAB.Remove(String ID)
...
Rimuove voce di menu con ID specificato dal TAB
...
AGENTDESKTOP.TAB.GoTo(String ID)
...
Sposta la selezione sul TAB del WIDGET con l'ID specificato
...
Funzione
...
Descrizione
...
AGENTDESKTOP.ALERT.Notify(String Title, String Text, String Icon, Integer Timeout)
...
Visualizza una finestra informativa specificando anche un tempo di visualizzazione.
Title: titolo della finestra
Testo: contenuto della finestra (formato HTML)
Icon: Icona di Font Awesome nel formato fa fa-XXX fa-2x
Timeout: numero di secondi di visualizzazione. 0 per tenerlo fisso sullo schermo, liberamente chiudibile dall'utente.
...
AGENTDESKTOP.ALERT.CustomDialog(String URL, Integer width, Integer heigth)
...
Apre una finestra di dialogo custom ridimensionabile e trascinabile a piacere all'interno di AD. La finestra non può essere chiusa tramite interfaccia.
url: percorso del documento da integrare
width: larghezza in pixel della dialog
heigth: altezza in pixel della dialog
...
AGENTDESKTOP.ALERT.CustomDialogClose()
...
Chiude la finestra di dialogo custom aperta
...
Funzione
...
Descrizione
...
AGENTDESKTOP.AGENT.PauseSubStateFilter(String filter)
...
Permette di aggiungere un sottostato di pausa
...
AGENTDESKTOP.AGENT.PauseSubState(String SubStateCode)
...
Richiede sottostato di pausa indicato dal codice
...
AGENTDESKTOP.AGENT.Login()
...
Richiede stato disponibile per operatore
...
AGENTDESKTOP.AGENT.Pause()
...
Richiede stato di pausa per operatore
...
AGENTDESKTOP.AGENT.getAgentID()
...
Restituisce l'ID dell' operatore
...
AGENTDESKTOP.AGENT.getMediaID()
...
Restituisce l'ID del media
...
AGENTDESKTOP.AGENT.getAgentState()
...
Restituisce lo stato in cui si trova l'operatore
AGENTDESKTOP.CONTACT.PlayMessage String value, String <bundle>, String <prefetch> | Avvia la riproduzione di un messaggio o di un un bundle oppure effettua il prefetch di un bundle. Al fine di potere fare la play delle sequenze di messaggi e pause richieste, è stato introdotto il concetto di “bundle” che non è altro che un identificativo univoco che rappresenta la sequenza da riprodurre.
|
AGENTDESKTOP.CONTACT.StopMessage | Termina la riproduzione di un messaggio o di un bundle. |
AGENTDESKTOP.CONTACT.PauseMessage String onOff | Interrompe o riprende la riproduzione di un messaggio o di un bundle; nel caso di un bundle la ripresa della riproduzione riprende dal successivo primo messaggio non di pausa della sequenza.
|
Gestione WIDGET
Funzione | Descrizione | |||||
AGENTDESKTOP.WIDGET.getToken | Restituisce il token ottenuto dalla login Single Sign On di EasyCIM | |||||
AGENTDESKTOP.WIDGET.getTokenOneShot | Restituisce il token OneShot ottenuto dalla login Single Sign On di EasyCIM | |||||
AGENTDESKTOP.WIDGET.getContainerID | Restituisce l'identificativo del WIDGET definito in fase di configurazione. | |||||
AGENTDESKTOP.WIDGET.bindContactCallback(javascript function) | Effettua la bind di una propria funzione javascript al fine di ricevere le notifiche sui contatti in gestione. | |||||
AGENTDESKTOP.WIDGET.bindCustomContactClose(javascript function, String ContactID) | Effettua la bind di una propria funzione javascript al fine di personalizzare e gestire la fase di chiusura del Tab di gestione contatto in AgentDesktop/CTToolbar7. Nel caso venga definita una propria funzione personalizzata la vita del contatto sulla barra telefonica seguirà un percorso differente al termine della fase di offline (fine After Call Work). Anzichè chiudere automaticamente il Tab di gestione del contatto e quindi rimuovere dalla interfaccia grafica anche tutti i Widget di terze parti caricati verrà demandata la chiusura al Widget che ha registrato una propria funzione JS custom. Sarà compito quindi del Widget richiamare successivamente la API AGENTDESKTOP.WIDGET.CloseContactTab al fine di chiudere il tab di gestione contatto sulla interfaccia della barra telefonica.
Esempio di utilizzo:
| |||||
AGENTDESKTOP.WIDGET.unbindContactCallback(javascript function) | Effettua la unbind della vostra funzione | |||||
AGENTDESKTOP.WIDGET.unbindCustomContactClose(javascript function, String ContactID) | Effettua la unbind della vostra funzione | |||||
AGENTDESKTOP.WIDGET.bindWidgetDataCallback(function function) | Effettua la bind di una propria funzione javascript al fine di ricevere le notifiche relative alla ricezione di dati custom da parte di un altro Widget. | |||||
AGENTDESKTOP.WIDGET.unbindWidgetDataCallback(function callback) | Effettua la unbind della vostra funzione | |||||
AGENTDESKTOP.WIDGET.sendDataToWidget String destinationWidgetID, String data | Invia dei dati custom ad un altro WIDGET identificato nel parametro destinationWidgetID (o paradossalmente anche a se stessi se si specifica il proprio ID) E' possibile inviare anche dati strutturati come array ed oggetti anche se è fortemente raccomandato convertirli in formato stringa mediante l'utilizzo dell'istruzione JSON.stringify. | |||||
AGENTDESKTOP.WIDGET.sendDataToAllWidget String data | Invia dei dati custom a tutti i Widget presenti in AgentDesktop, sia di primo livello sia quelli caricati all'interno di ciascun contatto nel Widget Multi-Contatto. Alla ricezione del data sul singolo Widget verrà risvegliata la callback custom agganciata mediante il metodo AGENTDESKTOP.WIDGET.bindWidgetDataCallback | |||||
AGENTDESKTOP.WIDGET.sendDataToMultiContactWidget String destinationMultiContactWidgetID, String data | Invia dei dati custom ad un singolo Widget caricato in una scheda o tab del Multi-Contatto. NOTA: L'invio dei dati tra Widgets avverrà solo all'interno del contesto del singolo contatto in gestione e non potrà essere propagato cross-tab, ovverosia tra contatti differenti in gestione all'operatore. | |||||
AGENTDESKTOP.WIDGET.addCustomMenu JSON String menu | Inserisce un menu contestuale sul TAB di selezione del proprio WIDGET. E' possibile inserire due tipologie di collegamento. Il primo una volta cliccato andrà ad essere caricato nel frame principale del Widget sostituendo quindi il contenuto visualizzato. Il secono andrà a visualizzare una finestra di dialogo che si posizionerà al di sopra della intrerfaccia di AgentDesktop. Il JSON specificato nel parametro menu dovrà avere la seguente struttura:
| |||||
AGENTDESKTOP.WIDGET.enableCustomMenuItem String ItemID, boolean [true/false] | Abilita/Disabilita una singola voce di menu nel TAB di selezione del WIDGET | |||||
AGENTDESKTOP.WIDGET.LOG String testo | Consente ad un Widget di scrivere all'interno dei log applicativi di AgentDesktop situati in %appdata%\Reitek\Contact\BrowserPlugin. Ogni loggata sarà preceduta dal timestamp generato automaticamente e dall'identificativo del Widget che ha generato la riga di log:
| |||||
AGENTDESKTOP.WIDGET.bindWidgetFocusCallback(function callback) | Effettua la bind di una vostra funzione al fine di notificare al Widget la selezione dell'utente e la conseguente ricezione del Focus sul proprio Tab. | |||||
AGENTDESKTOP.WIDGET.unbindWidgetFocusCallback (function callback) | Effettua la unbind della vostra funzione | |||||
AGENTDESKTOP.WIDGET.Reload(String < JumpToWidget>) | Ricarica il contenuto del Widget | |||||
AGENTDESKTOP.WIDGET.GetTimeStamp() | Restituisce stringa contenente data e ora attuale nel formato: dd/mm/yyyy – hh:mm:ss | |||||
AGENTDESKTOP.WIDGET.getLanguage | Restituisce la lingua utilizzata in AgentDesktop. Esempio: "it", "en". |
Gestione TAB
Funzione | Descrizione |
---|---|
AGENTDESKTOP.TAB.Badge(String Badge) | Imposta il Badge all'interno del Tab di selezione del Widget. Se il parametro stringa è vuoto il Badge viene cancellato |
AGENTDESKTOP.TAB.Focus() | Sposta la selezione sul TAB del proprio Widget |
AGENTDESKTOP.TAB.Home() | Sposta la selezione sul TAB di HOME di AgentDesktop |
AGENTDESKTOP.TAB.Add(String ID, String Title, String URL, String Icon) | Aggiunge dinamicamente da codice un nuovo Widget di primo livello. |
AGENTDESKTOP.TAB.Remove(String ID) | Rimuove il Widget il cui ID è specificato dal parametro stringa. |
AGENTDESKTOP.TAB.GoTo(String ID) | Sposta la selezione sul TAB del Widget con l'ID specificato |
Finestre Informative
Funzione | Descrizione |
---|---|
AGENTDESKTOP.ALERT.Notify(String Title, String Text, String Icon, Integer Timeout) | Visualizza una finestra informativa specificando anche un tempo di visualizzazione.
|
AGENTDESKTOP.ALERT.CustomDialog(String URL, Integer width, Integer heigth) | Apre una finestra di dialogo custom ridimensionabile e trascinabile a piacere all'interno di AD. La finestra non può essere chiusa tramite interfaccia ma mediante API dedicata.
|
AGENTDESKTOP.ALERT.CustomDialogClose() | Chiude la finestra di dialogo custom aperta |
Gestione dello Stato dell'Operatore
Funzione | Descrizione |
---|---|
AGENTDESKTOP.AGENT.PauseSubStateFilter(String filter) | Permette di aggiungere un filtro alla visualizzazione dei sottostati di pausa riservati all'operatore. Il filtro è rappresentato mediante regular expression. |
AGENTDESKTOP.AGENT.PauseSubState(String SubStateCode) | Richiede il sottostato di pausa indicato dal codice SubStateCode |
AGENTDESKTOP.AGENT.Login | Richiede la login (disponibile) per l'operatore |
AGENTDESKTOP.AGENT.Pause | Richiede stato di pausa per l'operatore |
AGENTDESKTOP.AGENT.getAgentID | Restituisce l'identificativo completo dell' operatore (esempio: agent1@acd.engouse.com) |
AGENTDESKTOP.AGENT.getMediaID | Restituisce l'identificativo completo del media attestato sull'operatore (esempio: 80400@B2BUAEP.enghouse.com) |
AGENTDESKTOP.AGENT.getAgentState | Restituisce lo stato in cui si trova l'operatore. Possono essere restituiti i seguenti valori:
|
AGENTDESKTOP.AGENT.getGroups | Restituisce un array di tutti i Gruppi di lavoro visibili all'operatore. Ciascun elemento dell'array ha le seguenti proprietà:
|
AGENTDESKTOP.AGENT.getAgentGroups | Restituisce un array di tutti i Gruppi di lavoro dove risulta loggato l'operatore. Il formato dell'array è identico a quello del metodo AGENTDESKTOP.AGENT.getGroups. |
AGENTDESKTOP.AGENT.getAgentName | Restituisce il nome dell'operatore come da configurazione sul sistema ContaCT7 |
AGENTDESKTOP.AGENT.getAgentSurname | Restituisce il cognome dell'operatore come da configurazione sul sistema ContaCT7 |
AGENTDESKTOP.AGENT.setAgentGroups(String Groups) | Modifica i Gruppi di lavoro associati all'operatore. Il parametro Groups è una stringa contenente la lista di tutti gli identificativi separati da ";" |
Gestione Chat CTLive
Funzione | Descrizione |
---|---|
AGENTDESKTOP.CHAT.SendText String Text | Invia un messaggio testuale verso la chat in gestione all'interno del Tab/Scheda corrente del Widget MultiContatto |
AGENTDESKTOP.CHAT.GetEvents String ContactID | Restituisce un array contenente lista di eventi intercorsi per l'identificativo della chat specificato dal parametro ContactID |
AGENTDESKTOP.CHAT.enableChatTextArea Boolean enabled, String chatID | A seconda del valore del parametro enabled abilita o disabilita sulla interfaccia grafica di AgentDesktop l’area di immissione testo della chat il cui identificativo CTLive corrisponde al parametro chatID. |
AGENTDESKTOP.CHAT.getWhatsappTemplates | Richiede la definizione dei Templates Whatsapp configurati sul sistema. Verrà restituito mediante una Promise Javascript un’oggetto JSON contenente un array dove ciascun elemento rappresenta un template. |
AGENTDESKTOP.CHAT.getActiveTranscript String chatID | Restituisce la trascrizione completa fino all’istante della richiesta alla API di una chat ancora attiva il cui identificativo corrisponde al parametro chatID. Verrà restituito mediante una Promise Javascript un’oggetto JSON contenente un array dove ciascun elemento rappresenta una interazione nella chat, come per esempio un messaggio testuale oppure l’invio di un documento. |
AGENTDESKTOP.CHAT.getOfflineTranscript String chatID | Restituisce la trascrizione completa di una chat già conclusasi il cui identificativo corrisponde al parametro chatID. Verrà restituito mediante una Promise Javascript un’oggetto JSON contenente un array dove ciascun elemento rappresenta una interazione nella chat, come per esempio un messaggio testuale oppure l’invio di un documento. |
Funzionalità avanzate sulla User Interface
Funzione | Descrizione |
---|---|
AGENTDESKTOP.UI.bindModalCallback(function javascript) | Effettua la bind di una propria funzione al fine di essere notificati sugli eventi relativi all'apertura/chiusura di finestre di dialogo in AgentDesktop. Questa funzionalità è utile per conoscere e venire informati ogni volta che l'operatore clicca ed apre alcuni pannelli di gestione come per esempio "Gestione Gruppi di lavoro" o la maschera dei "Trasferimenti". |
AGENTDESKTOP.UI.unbindModalCallback(function javascript) | Effettua la unbind della vostra funzione |
Gestione dei dati aggiuntivi del contatto da easyCIM (namespace AGENTDESKTOP.EASYCIM)
Metodo Javascript | Descrizione | |||||||
---|---|---|---|---|---|---|---|---|
AGENTDESKTOP.EASYCIM.openScriptInbound String ContactID | Chiede la apertura di un nuovo script per un contatto Inbound generando un nuovo ECID di lavorazione su easyCIM. Per questa API si è scelto di eseguirla in automatico da CTToolbar7 solo nel caso lo Script non sia stato abilitato dalla configurazione del profilo in AgentDesktopManager. In questo modo l’integratore non dovrà preoccuparsi di richiamarla ad ogni contatto Inbound ACD mentre sarà altresì suo compito richiamare la API di esitazione e salvataggio TOOLBAR.EASYCIM.saveScript. | |||||||
AGENTDESKTOP.EASYCIM.openScript String ContactID, String ECID | Chiede la apertura dello Script per un contatto esistente avente come identificativo il parametro ECID. La chiamata a questa API serve per riservare il contatto all’operatore va utilizzata sull’evento di ESTABLISHED della chiamata, quando si è sicuri che il cliente ha risposto. Verrà restituito mediante una Promise Javascript una struttura JSON contenente i seguenti parametri:
In caso di risposta positiva nell’oggetto JSON verranno valorizzati i seguenti campi:
Esempio di chiamata della API openScript:
| |||||||
AGENTDESKTOP.EASYCIM.getContactInfo | Restituisce mediante una Promise Javascript tutta la struttura ContactInfo memorizzata su easyCIM per il contatto in corso.
| |||||||
AGENTDESKTOP.EASYCIM.saveScript String ContactID, String outcomeResult, Boolean offlineEnd, String note, Object Array labels, Boolean closeTab | Salva lo script specificando un esito di chiusura ed eventualmente terminando la lavorazione del contatto sulla postazione operatore (termina lo stato di Offline/ACW del contatto stesso). E’ possibile specificare come esito uno dei seguenti valori preconfigurati:
Il parametro offlineEnd indica se terminare o meno anche il contatto CTI facendo di conseguenza terminare lo stato di Offline (After Call Work) del contatto stesso e rendendo nuovamente schedulabile l’operatore. Il parametro note consente di specificare annotazioni aggiuntive associate alla chiusura del contatto. Con il parametro labels è possibile aggiungere informazioni strutturate organizzate in un array di uno o più oggetti aventi la seguente struttura:
Esempio di chiamata:
Il parametro closeTab consente di specificare se chiudere automaticamente il Tab di gestione contatto aperto sulla barra telefonica. |