获取所有访客

pull/30/head
陶士涵 5 years ago
parent ab6b9d6bc7
commit 758b8b9ffd

@ -127,6 +127,7 @@ func SendNoticeToAllKefu() {
//获取当前的在线用户 //获取当前的在线用户
func getOnlineUser(w *websocket.Conn) { func getOnlineUser(w *websocket.Conn) {
result := make([]map[string]string, 0) result := make([]map[string]string, 0)
log.Println(clientList)
for _, user := range clientList { for _, user := range clientList {
userInfo := make(map[string]string) userInfo := make(map[string]string)
userInfo["uid"] = user.id userInfo["uid"] = user.id
@ -190,7 +191,11 @@ func singleBroadcaster(){
case "kfConnect": case "kfConnect":
json.Unmarshal(msgData, &clientMsg) json.Unmarshal(msgData, &clientMsg)
kefuList[clientMsg.Id] = conn kefuList[clientMsg.Id] = conn
SendKefuOnline(clientMsg, clientList[clientMsg.ToId].conn) visitor,ok := clientList[clientMsg.ToId]
if visitor==nil||!ok{
return
}
SendKefuOnline(clientMsg, visitor.conn)
case "kfChatMessage": case "kfChatMessage":
json.Unmarshal(msgData, &clientMsg) json.Unmarshal(msgData, &clientMsg)
guest,ok:=clientList[clientMsg.ToId] guest,ok:=clientList[clientMsg.ToId]

@ -3,16 +3,22 @@ package controller
import ( import (
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
"github.com/taoshihan1991/imaptool/models" "github.com/taoshihan1991/imaptool/models"
"log"
) )
func GetVisitor(c *gin.Context) { func GetVisitor(c *gin.Context) {
visitorId:=c.Query("visitorId") visitorId:=c.Query("visitorId")
vistor:=models.FindVisitorByVistorId(visitorId) vistor:=models.FindVisitorByVistorId(visitorId)
log.Println(visitorId)
c.JSON(200, gin.H{ c.JSON(200, gin.H{
"code": 200, "code": 200,
"msg": "ok", "msg": "ok",
"result":vistor, "result":vistor,
}) })
} }
func GetVisitors(c *gin.Context) {
vistors:=models.FindVisitors()
c.JSON(200, gin.H{
"code": 200,
"msg": "ok",
"result":vistors,
})
}

@ -36,4 +36,9 @@ func FindVisitorByVistorId(visitorId string)Visitor{
var v Visitor var v Visitor
DB.Where("visitor_id = ?", visitorId).First(&v) DB.Where("visitor_id = ?", visitorId).First(&v)
return v return v
}
func FindVisitors()[]Visitor{
var visitors []Visitor
DB.Find(&visitors)
return visitors
} }

@ -40,6 +40,7 @@ func main() {
engine.GET("/mysql",middleware.JwtApiMiddleware,middleware.CasbinACL, controller.MysqlGetConf) engine.GET("/mysql",middleware.JwtApiMiddleware,middleware.CasbinACL, controller.MysqlGetConf)
engine.POST("/mysql",middleware.JwtApiMiddleware,middleware.CasbinACL, controller.MysqlSetConf) engine.POST("/mysql",middleware.JwtApiMiddleware,middleware.CasbinACL, controller.MysqlSetConf)
engine.GET("/visitor",middleware.JwtApiMiddleware, controller.GetVisitor) engine.GET("/visitor",middleware.JwtApiMiddleware, controller.GetVisitor)
engine.GET("/visitors",middleware.JwtApiMiddleware, controller.GetVisitors)
//------------------old code----------------------------- //------------------old code-----------------------------
mux := &http.ServeMux{} mux := &http.ServeMux{}
//根路径 //根路径

@ -65,10 +65,10 @@
<el-row :gutter="5"> <el-row :gutter="5">
<el-col :span="6"> <el-col :span="6">
<div class="chatLeft"> <div class="chatLeft">
<el-tabs v-model="leftTabActive"> <el-tabs v-model="leftTabActive" @tab-click="handleTabClick">
<el-tab-pane label="在线用户" name="first"> <el-tab-pane label="在线用户" name="first">
<el-row v-for="item in users" :key="item.uid" class=""> <el-row v-for="item in users" :key="item.uid" class="">
<div style="cursor:pointer" class="onlineUsers" v-bind:class="{'cur': item.uid==currentGuest }" v-on:click="talkTo(item.uid)"> <div style="cursor:pointer" class="onlineUsers" v-bind:class="{'cur': item.uid==currentGuest }" v-on:click="talkTo(item.uid,item.username)">
<el-col :span="4"> <el-col :span="4">
<el-avatar :size="40" :src="item.avator"></el-avatar> <el-avatar :size="40" :src="item.avator"></el-avatar>
</el-col> </el-col>
@ -79,6 +79,16 @@
</el-row> </el-row>
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="所有访客" name="second"> <el-tab-pane label="所有访客" name="second">
<el-row v-for="item in visitors" :key="item.uid" class="">
<div style="cursor:pointer" class="onlineUsers" v-bind:class="{'cur': item.visitor_id==currentGuest }" v-on:click="talkTo(item.visitor_id,item.name)">
<el-col :span="4">
<el-avatar :size="40" :src="item.avator"></el-avatar>
</el-col>
<el-col :span="16">
<{item.name}>
</el-col>
</div>
</el-row>
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>
</div> </div>
@ -159,7 +169,8 @@
client_ip:"", client_ip:"",
city:"", city:"",
status:"", status:"",
} },
visitors:[],
}, },
methods: { methods: {
//跳转 //跳转
@ -244,14 +255,16 @@
} }
}, },
//接手客户 //接手客户
talkTo(guestId) { talkTo(guestId,name) {
this.currentGuest = guestId; this.currentGuest = guestId;
this.chatTitle=this.usersMap[guestId]+guestId+",正在处理中..."; this.chatTitle=name+"|"+guestId+",正在处理中...";
this.msgList = []; this.msgList = [];
let buf = []; let buf = [];
var i = this.msgListUser[guestId].length; if(typeof this.msgListUser[guestId]!="undefined"){
while (i--) { var i = this.msgListUser[guestId].length;
buf[i] = this.msgListUser[guestId][i]; while (i--) {
buf[i] = this.msgListUser[guestId][i];
}
} }
this.msgList = buf; this.msgList = buf;
@ -358,6 +371,30 @@
} }
}); });
}, },
//处理tab切换
handleTabClick(tab, event){
let _this=this;
if(tab.name=="second"){
$.ajax({
type:"get",
url:"/visitors",
headers:{
"token":localStorage.getItem("token")
},
success: function(data) {
if(data.result!=null){
_this.visitors=data.result;
}
if(data.code!=200){
_this.$message({
message: data.msg,
type: 'error'
});
}
}
});
}
},
}, },
created: function () { created: function () {
this.getKefuInfo(); this.getKefuInfo();

Loading…
Cancel
Save