| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675 |
- var ws, n = 0,
- timer;
- var lockReconnect = false; //避免重复连接
- var obj = {};
- var eorrorConnect;
- var cls = 0;
- var directType;
- var sendType;
- var mesCont;
- var lasttime = new Date().getTime();
- var errorState;
- var reconnecTion;
- var recon;
- var loginOr;
- //创建scoket连接
- function createWebSocket() {
- try {
- $("#top-search li i").removeClass("active");
- ws = new WebSocket("ws://" + huayi.config.socket_ip + ":" + huayi.config.socket_port);
- Connect();
- } catch(e) {
- reconnect();
- }
- }
- //连接
- function Connect() {
- try {
- ws.onopen = function() {
- //console.log(new Date() + " " + "建立连接");
- //心跳检测重置
- heartCheck.reset().start();
- cls = 0;
- $(".Login").addClass("active");
- if (errorState) {
- //自动签入
- lasttime = new Date().getTime();
- obj.Type = "Login";
- obj.AgentType = "0";
- Send();
- clearInterval(timer);
- //loginOr=false;
- errorState=false;
- }else{
- //签入
- Send();
-
- }
-
-
- };
- //接收到消息的回调方法
- ws.onmessage = function(evt) {
- //如果获取到消息,心跳检测重置
- //拿到任何消息都说明当前连接是正常的
- heartCheck.reset().start();
- var myDate = new Date();
- console.log(myDate + " receive " + evt.data);
- var data = JSON.parse(evt.data)[0];
- //打印日志
- directType="recive";
- sendType=data.Type; //JSON.stringify(data)
- mesCont=JSON.stringify(evt);
- debuggerLog()
- if(data) {
- var rlt = data.Result;
- if(rlt == true) {
- var type = data.Type;
- if (eorrorConnect) {
- LoginBack();
- obj.Type = "Login";
- Send();
- eorrorConnect=false;
- }
- switch(type.toLowerCase()) {
- //case "heart": HeartBack(); break;//心跳
- case "login":
- LoginBack();
- break; //签入
- case "logout":
- LogoutBack();
- break; //签出
- case "dropcall":
- DropCallBack();
- break; //挂断
- case "makecall":
- MakeCallBack();
- break; //外呼
- case "setstate":
- SetState(data);
- break; //置忙置闲
- break;
- case "meeting":
- MeetingBack();
- break; //多方通话
- case "transfer":
- TransferBack();
- break; //转移
- case "hold":
- HoldBack();
- break; //保持
- case "retrieve":
- RetrieveBack();
- break; //接回
- case "incoming":
- IncomingBack(data);
- break; //来电
- case "subscribe":
- SubScribeBack();
- break; //监测
- case "subscribecancel":
- SubScribeCancelBack();
- break; //停止监测
- case "agentstate":
- AgentStateBack(data);
- break; //坐席状态
- case "linestate":
- LineStateBack(data);
- break; //线路状态
- case "motorsetstate":
- SayFreeBack();
- break; //班长置闲
- case "linestateagent":
- LineStateAgentBack(data);
- break; //线路状态通知
- case "callid":
- CallIDBack(data);
- break; //获取callid
- case "recordpath":
- RecordPathBack(data);
- break; //录音返回
- }
- } else {
- if(rlt == false) {
- if (data.Type=="AcdConnectNotify") {
- //LogoutBack();
- $(".hwzt").text('连接异常!');
- setTimeout(function () {
- // 签入
- obj.Type = "login";
- Send();
- }, 5000);
- }
- $(".hwzt").text('操作失败!');
- } else {
- $(".hwzt").text(rlt);
- }
- }
- }
- };
- //连接关闭的回调方法
- ws.onclose = function(evt) {
- //打印日志
- LogoutBack();
- directType="recive";
- sendType="close"; //JSON.stringify(data)
- mesCont=JSON.stringify(evt);
- debuggerLog();
- //$(".hwzt").text('连接关闭!');
- // if(cls == 0) {
- // cls = 1;
- // $(".hwzt").text('连接关闭!');
- // $("#top-search li i").removeClass("active");
- // reconnect();
- // }
- };
- //连接发生错误的回调方法
- ws.onerror = function(evt) {
- //产生异常
- //打印日志
- //var data = JSON.parse(evt.data)[0];
- directType="recive";
- sendType="连接错误 "; //JSON.stringify(data)
- mesCont=JSON.stringify(evt);
- debuggerLog();
- //LogoutBack();
- $(".hwzt").text('连接异常!');
- console.log(ws);
- if(ws == null || ws.readyState != ws.OPEN) {
- directType="send";
- sendType="开始重连 "; //JSON.stringify(data)
- mesCont=mesCont;
- debuggerLog()
- console.log(new Date() + "开始重连");
- reconnect();
- eorrorConnect=true
- }
- };
- } catch(ex) {
- $(".hwzt").text('连接关闭 try-catch!');
- $("#top-search li i").removeClass("active");
- reconnect();
- }
- }
- //重连
- function reconnect() {
- if(lockReconnect){return};
- lockReconnect = true;
- //没连接上会一直重连,设置延迟避免请求过多
- setTimeout(function() {
- directType="send";
- sendType="重连中 "; //JSON.stringify(data)
- mesCont="重连中";
- debuggerLog();
- console.log(new Date() + " " + "重连中……");
- createWebSocket("ws://" + huayi.config.socket_ip + ":" + huayi.config.socket_port);
- lockReconnect = false;
- }, 5000);
- }
- function debuggerLog(){
- $.post(huayi.config.callcenter_url + 'Log/CallOpt', {
- direct: directType,
- type: sendType,
- cont: mesCont,
- "token": $.cookie("token")
- }, function(result) {
- result = $.parseJSON(result);
- if(result.state.toLowerCase() == "warning") {
- //layer.msg("创建工单成功");
- }
- })
- }
- //异常重连
- function errorFun(){
- clearInterval(timer);
- var errorNum=0
- timer = setInterval(function() {
- errorNum++;
- if (errorNum>2) {
- //$("#top-search li i").removeClass("active");
- $(".hwzt").text('连接异常!');
- }else{
- LogoutBack();
- }
- reconnect();
- $(".hwzt").text('连接异常!');
- }, 15000);
- }
- noLine();
- clearInterval(recon);
- recon = setInterval(function () {
- if(loginOr){
- noLine();
- setTimeout(function () {
- lineState();
- }, 2000);
- }
- }, 1000*10);
- function lineState(){
- if (reconnecTion) {
- reconnecTion=false;
- }else{
- errorState=true;
- LogoutBack();
- errorFun();
- var numEorr=0;
- numEorr++;
- if (numEorr>2) {
- $("#top-search li i").removeClass("active");
- }
- $(".hwzt").text('网络异常!');
- }
- }
- function noLine(){
- $.ajax({
- type: "get",
- url: huayi.config.callcenter_url + 'UserAccount/GetNowUser',
- async: true,
- dataType: 'json',
- data: {
- "token": $.cookie("token")
- },
- success: function(data) {
- reconnecTion = data.data.user.F_UserCode;
- }
- });
- }
- //发送
- function Send() {
- if(ws.readyState != ws.OPEN) {
-
- errorState=true;
- LogoutBack();
- errorFun();
- $(".hwzt").text('连接异常!');
- }
- if(ws.readyState == ws.OPEN) {
- console.log(new Date() + " send " + JSON.stringify(obj));
- if (obj.Type) {
- directType="send";
- sendType=obj.Type;
- mesCont=JSON.stringify(obj);
- debuggerLog()
- }else{
- directType="send";
- sendType="建立连接";
- mesCont=JSON.stringify(obj);
- debuggerLog()
- }
- ws.send(JSON.stringify(obj));
- }
- }
- //心跳检测
- var heartCheck = {
- timeout: 1000, //25秒
- timeoutObj: null,
- serverTimeoutObj: null,
- reset: function() {
- clearTimeout(this.timeoutObj);
- clearTimeout(this.serverTimeoutObj);
- return this;
- },
- start: function() {
- var self = this;
- this.timeoutObj = setTimeout(function() {
- //这里发送一个心跳,后端收到后,返回一个心跳消息,
- //onmessage拿到返回的心跳就说明连接正常
- obj.Type = "Heart";
- Send();
- self.serverTimeoutObj = setTimeout(function() { //如果超过一定时间还没重置,说明后端主动断开了
- ws.close(); //如果onclose会执行reconnect,我们执行ws.close()就行了.如果直接执行reconnect 会触发onclose导致重连两次
- LogoutBack();
- directType="recive";
- sendType="close"; //JSON.stringify(data)
- mesCont="心跳未收到";
- debuggerLog();
- //$(".hwzt").text('连接关闭!');
- reconnect();
- }, self.timeout)
- }, this.timeout)
- }
- }
- //签入
- function LoginBack() {
- loginOr=true;
- $("#top-search li i").removeClass("active");
- $(".Logout").addClass("active");
- $(".SayBusy").addClass("active");
- $(".MakeCall").addClass("active");
- $(".zxzt").removeClass("br").addClass("bl");
- $(".fwzt").removeClass("br").addClass("bl");
- $(".hwzt").text('');
- }
- //签出
- function LogoutBack() {
- loginOr=false;
- $("#top-search li i").removeClass("active");
- $(".Login").addClass("active");
- $(".zxzt").removeClass("bl").addClass("br");
- $(".fwzt").removeClass("bl").addClass("br");
- $(".hwzt").text('');
- }
- //来电
- function IncomingBack(data) {
- var UserCode
- $(".hidTel").val(data.Number);
- $(".tel").text(data.Number);
- $("#zxdh_").val(data.Number);
- $("#tsdh").val(data.Number);
- $(".ldtime").text(getNowFormatDate());
- $(".thsc").text("00:00");
- //获取callid
- $.ajaxSettings.async = false;
- $.getJSON(huayi.config.callcenter_url + 'CallInScreen/GetCallIdByPhone', {
- "tel": $(".hidTel").val(),
- "token": $.cookie("token")
- }, function(result) {
- $.ajaxSettings.async = true;
- if(result.state.toLowerCase() == "success") {
- $(".hidCallID").val(result.data.CallId);
- }
- })
- //获取信息
- $.getJSON(huayi.config.callcenter_url + 'UserAccount/GetNowUser', {
- "token": $.cookie("token")
- }, function(result) {
- if(result.state.toLowerCase() == "success") {
- console.log(result);
- if(result.data.role) {
- console.log(result.data);
- UserCode = result.data.user.F_UserCode;
- }
- }
- })
- //获取电话所属地
- $.getJSON(huayi.config.callcenter_url + 'CallInScreen/GetPhoneLocation', {
- "tel": $(".hidTel").val(),
- "token": $.cookie("token")
- }, function(result) {
- if(result.state.toLowerCase() == "success") {
- $(".khgsd").text(result.data);
- $(".ldlocation").text(result.data);
- }
- })
- //获取客户信息
- $(".ldtel").text($(".hidTel").val());
- $("#tsdh").val($(".hidTel").val());
- $(".ldtel1").val($(".hidTel").val());
- $.getJSON(huayi.config.callcenter_url + 'CallInScreen/GetCustomerByTel', {
- "tel": $(".hidTel").val(),
- "token": $.cookie("token")
- }, function(result) {
- if(result.state.toLowerCase() == "success") {
- if(result.data.length > 0) {
- $("#zxr_").val(result.data[0].F_CustomerName);
- $("#tskh").val(result.data[0].F_CustomerName);
- $("#khid").val(result.data[0].F_CustomerId);
- $(".khbh").val(result.data[0].F_CustomerCode);
- $(".ldtel1").val(result.data[0].F_Telephone);
- $(".ldtel2").val(result.data[0].F_Mobile);
- $(".ldtel3").val(result.data[0].F_ChargeTelephone);
- }
- }
- })
- loadOld();
- $('.maxOpen').trigger("click");
- $('.head-pic .lahei .la-before').show();
- $('.head-pic .lahei .la-after').hide();
- $(".Bacha").hide();
- }
- function CallIDBack(data) {
- //$(".hidCallID").val(data.CurrID);
- }
- //挂断
- function DropCallBack() {
- $("#top-search li i").removeClass("active");
- $(".Logout").addClass("active");
- $(".SayBusy").addClass("active");
- $(".MakeCall").addClass("active");
- $(".td-call").hide();
- //$('.ldtp-con').css("display", 'none');
- }
- function LineStateAgentBack(data) {
- //0分机不可用,1空闲,2摘机等待拨号,3正在拨号,4呼出振铃,5来电振铃,6通话中,7播放忙音中,8移除IP分机,9通话保持中
- if(data.State == '0') {
- $(".hwzt").text('分机不可用'); //左下角状态显示
- }
- if(data.State == '1') {
- $(".hwzt").text('空闲'); //左下角状态显示
- $(".fwzt").removeClass("br").addClass("bl");
- clearInterval(timer);
- if($(".hidTel").val() && $(".hidCallID").val()) {
- $.post(huayi.config.callcenter_url + 'CallInScreen/UpdateGJ', {
- callid: $(".hidCallID").val(),
- "token": $.cookie("token")
- }, function(result) {
- result = JSON.parse(result);
- if(result.state.toLowerCase() == "success") {}
- })
- }
- $("#top-search li i").removeClass("active");
- $(".Logout").addClass("active");
- $(".SayBusy").addClass("active");
- $(".MakeCall").addClass("active");
- $(".td-call").hide();
- $(".Bacha").show();
- //$(".hidTel").val("");
- //$(".hidCallID").val("");
- }
- if(data.State == '2') {
- $(".hwzt").text('摘机等待拨号'); //左下角状态显示
- }
- if(data.State == '3') {
- $(".hwzt").text('正在拨号'); //左下角状态显示
- }
- if(data.State == '4') {
- $(".hwzt").text('呼出振铃'); //左下角状态显示
- }
- if(data.State == '5') {
- $(".hwzt").text('来电振铃'); //左下角状态显示
- $(".fwzt").removeClass("bl").addClass("br");
- if($(".hidTel").val() && $(".hidCallID").val()) {
- $.post(huayi.config.callcenter_url + 'CallInScreen/UpdateZL', {
- callid: $(".hidCallID").val(),
- "token": $.cookie("token")
- }, function(result) {
- result = JSON.parse(result);
- if(result.state.toLowerCase() == "success") {}
- })
- }
- }
- if(data.State == '6') {
- $(".hwzt").text('通话中'); //左下角状态显示
- $(".fwzt").removeClass("bl").addClass("br");
- if($(".hidTel").val() && $(".hidCallID").val()) {
- $.post(huayi.config.callcenter_url + 'CallInScreen/UpdateZJ', {
- callid: $(".hidCallID").val(),
- "token": $.cookie("token")
- }, function(result) {
- result = JSON.parse(result);
- if(result.state.toLowerCase() == "success") {}
- })
- }
- ///
- var timestamp = Date.parse(new Date());
- //呼叫中心传入城管平台参数
- $.ajax({
- type: "get",
- url: 'http://10.50.80.21:8086/callcenter/PutTel?',
- async: true,
- dataType: 'json',
- data: {
- id: $('.user_code').text(),
- tel: $(".tel").text(),
- time: timestamp
- },
- success: function(data) {}
- });
- $(".td-call").show();
- n = 0;
- $("#top-search li i").removeClass("active");
- $(".DropCall").addClass("active");
- $(".Hold").addClass("active");
- $(".Transfer").addClass("active");
- $(".Meeting").addClass("active");
- clearInterval(timer);
- timer = setInterval(function() {
- n++;
- var m = parseInt(n / 60 % 60);
- var s = parseInt(n % 60);
- $(".thsc").text(toDub(m) + ":" + toDub(s));
- }, 1000);
- }
- if(data.State == '7') {
- $(".hwzt").text('播放忙音中'); //左下角状态显示
- }
- if(data.State == '8') {
- $(".hwzt").text('移除IP分机'); //左下角状态显示
- }
- if(data.State == '9') {
- $(".hwzt").text('通话保持中'); //左下角状态显示
- }
- }
- function toDub(i) {
- return i < 10 ? "0" + i : "" + i;
- }
- //外呼
- function MakeCallBack() {
- $("#top-search li i").removeClass("active");
- $(".DropCall").addClass("active");
- }
- //置忙置闲
- function SetState(obj) {
- if(obj.State == '5') {
- $(".SayBusy").removeClass("active");
- $(".SayFree").addClass("active");
- $(".zxzt").removeClass("bl").addClass("br");
- $(".hwzt").text('置忙');
- }
- if(obj.State == '2') {
- $(".SayBusy").addClass("active");
- $(".SayFree").removeClass("active");
- $(".zxzt").removeClass("br").addClass("bl");
- $(".hwzt").text('空闲');
- }
- }
- //置忙
- function SayBusyBack() {
- $(".SayBusy").removeClass("active");
- $(".SayFree").addClass("active");
- }
- //置闲
- function SayFreeBack() {
- $(".SayBusy").addClass("active");
- $(".SayFree").removeClass("active");
- }
- //多方通话
- function MeetingBack() {
- }
- //转移
- function TransferBack() {
- $("#top-search li i").removeClass("active");
- $(".Logout").addClass("active");
- $(".SayBusy").addClass("active");
- $(".MakeCall").addClass("active");
- }
- //保持
- function HoldBack() {
- $(".Hold").removeClass("active");
- $(".Retrieve").addClass("active");
- }
- //接回
- function RetrieveBack() {
- $(".Hold").addClass("active");
- $(".Retrieve").removeClass("active");
- }
- //监测
- function SubScribeBack() {
- var obj = $("iframe:visible")
- if(obj.attr("data-id") == "./TelCall/SeatMonitor.html") {
- window.frames[obj.attr("name")].Start();
- }
- }
- //取消监测
- function SubScribeCancelBack() {
- var obj = $("iframe:visible")
- if(obj.attr("data-id") == "./TelCall/SeatMonitor.html") {
- window.frames[obj.attr("name")].Stop();
- }
- }
- //班长监测返回状态
- //坐席状态
- function AgentStateBack(data) {
- var obj = $("iframe:visible")
- if(obj.attr("data-id") == "./TelCall/SeatMonitor.html") {
- window.frames[obj.attr("name")].UpdateAgentState(data.AgentID, data.State);
- }
- }
- //线路状态
- function LineStateBack(data) {
- var obj = $("iframe:visible")
- if(obj.attr("data-id") == "./TelCall/SeatMonitor.html") {
- window.frames[obj.attr("name")].UpdateLineState(data.AgentID, data.State);
- }
- }
- //录音返回
- function RecordPathBack(data) {
- //if ($(".hidTel").val() && $(".hidCallID").val()) {
- // $.post(huayi.config.callcenter_url + 'CallInScreen/UpdateLY', { callid: $(".hidCallID").val(),path:data.RecPath, "token": $.cookie("token") }, function (result) {
- // result = JSON.parse(result);
- // if (result.state.toLowerCase() == "success") {
- // }
- // })
- //}
- if($(".hidTel").val()) {
- $.post(huayi.config.callcenter_url + 'CallInScreen/UpdateLY', {
- callid: data.CallID,
- path: data.RecPath,
- "token": $.cookie("token")
- }, function(result) {
- result = JSON.parse(result);
- if(result.state.toLowerCase() == "success") {}
- })
- }
- }
- //获取当前的日期时间 格式“yyyy-MM-dd HH:mm:ss”
- function getNowFormatDate() {
- var date = new Date();
- var seperator1 = "-";
- var seperator2 = ":";
- var month = date.getMonth() + 1;
- var strDate = date.getDate();
- if(month >= 1 && month <= 9) {
- month = "0" + month;
- }
- if(strDate >= 0 && strDate <= 9) {
- strDate = "0" + strDate;
- }
- var currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate +
- " " + date.getHours() + seperator2 + date.getMinutes() +
- seperator2 + date.getSeconds();
- return currentdate;
- }
|