鸿蒙访客端SDK API文档
初始化SDK
//在主页面调用,以免重复初始化
let mVisitorOptions = new VisitorOptions();
mVisitorOptions.setKefuRestServer('${客服登录地址}')
.setAppkey('${AppKey}')
.setTenantId('${租户ID}')
.setAppVersion('${app版本号}')
VisitorClient.getInstance().init(mContext, visitorOptions)
注册
VisitorClient.getInstance()
.getVisitorManager()
.register(username, password)
.then((value: string) => {
console.info("注册成功" + value)
})
.catch((reason: VisitorError) => {
console.error("注册失败" + reason.errorCode + "," + reason.description)
});
密码登录
//调接口登录
VisitorClient.getInstance()
.getVisitorManager()
.login(username, password)
.then((value: string) => {
console.info("登录成功" + value)
})
.catch((reason: VisitorError) => {
console.error("登录失败" + reason.errorCode + "," + reason.description)
})
Token登录
//调接口登录
VisitorClient.getInstance()
.getVisitorManager()
.loginWithToken(username, token)
.then((value: string) => {
console.info("登录成功" + value)
})
.catch((reason: VisitorError) => {
console.error("登录失败" + reason.errorCode + "," + reason.description)
})
登录状态
//判断是否已登录,避免重复调用登录接口
VisitorClient.getInstance().isLoggedInBefore()
退出登录
VisitorClient.getInstance()
.getVisitorManager()
.logout()
.then(() => {
console.info("退出成功")
})
.then(() => {
//TODO 移除emitter事件,避免切换用户后重复执行事件
})
.catch((reason: VisitorError) => {
console.error("退出失败" + reason.errorCode + "," + reason.description)
})
长连接监听
connectListener:IMConnectListener = {
onConnected: (): void => {
// 长连接建立
},
onDisconnected: (errorCode: number): void => {
// 长连接断开
switch (errorCode){
case VisitorError.USER_NOT_FOUND:
case VisitorError.USER_LOGIN_ANOTHER_DEVICE:
case VisitorError.USER_AUTHENTICATION_FAILED:
case VisitorError.USER_REMOVED:
VisitorClient.getInstance().getVisitorManager().logout()
//TODO 跳转到登录页面
break;
}
}
}
//添加长连接监听
VisitorClient.getInstance().addConnectionListener(connectListener)
//移除长连接监听
VisitorClient.getInstance().removeConnectionListener(connectListener)
消息监听
messageListener: MessageListener = {
onMessage(msgs: ArrayList<Message>) {
//收到上屏消息
},
onCmdMessage(msgs: ArrayList<Message>) {
//收到cmd透传消息
},
onMessageStatusUpdate() {
},
onMessageSent() {
//消息已发送
}
}
//添加消息监听
VisitorClient.getInstance().getVisitorManager().addMessageListener(messageListener);
//移除消息监听
VisitorClient.getInstance().getVisitorManager().removeMessageListener(messageListener);
绑定IM服务号
//发消息之前请点调用该API,以绑定IM服务号,可在进入聊天页面之后即调用
VisitorClient.getInstance().getVisitorManager().bindChat(toChatUsername)
解绑IM服务号
//退出聊天页面调用该API,以解绑IM服务号
VisitorClient.getInstance().getVisitorManager().unbindChat(toChatUsername)
修改AppKey
//newAppKey 新的AppKey
VisitorClient.getInstance().changeAppKey(newAppKey)
修改租户ID
//newTenantId 新的租户ID
VisitorClient.getInstance().changeTenantId(newTenantId)
消息
1.发送消息
VisitorClient.getInstance().getVisitorManager().sendMessage(message)
2.保存消息到本地
VisitorClient.getInstance().getVisitorManager().saveMessage(message)
3.删除消息
let messageId = message.messageId();
VisitorClient.getInstance().getConversationManager().getConversation(toChatUsername).removeMessage(messageId);
4.创建文本消息
//content:文本内容;toChatUsername:IM服务号;
Message.createTxtSendMessage(content, toChatUsername)
5.创建图片消息
//imgPath:图片路径;imgSize:图片大小(宽,高);toChatUsername:IM服务号;displayName:图片文件名称;
let imgSize = new VisitorImageSize(480, 640)
let message = Message.createImageSendMessage(imgPath, imgSize, toChatUsername, displayName)
6.创建语音消息
//voicePath:语音文件路径;duration:语音时长;toChatUsername:IM服务号;
Message.createVoiceSendMessage(voicePath, duration, this.toChatUsername)
7.创建短视频消息
//videoPath:短视频文件路径;duration:视频时长;toChatUsername:IM服务号;displayName:视频文件名称;thumbLocalPath:缩略图文件路径;
Message.createVideoSendMessage(videoPath, duration, this.toChatUsername, displayName, thumbLocalPath);
8.创建文件消息
//filePath:文件路径;fileLength:文件大小;toChatUsername:IM服务号;displayName:文件名称;
Message.createFileSendMessage(filePath, fileLength, this.toChatUsername, displayName)
9.创建位置消息
//latitude:维度;longitude:经度;toChatUsername:IM服务号;address:地址信息;buildingName:建筑物名称;
Message.createLocationSendMessage(latitude, longitude, this.toChatUsername, address, buildingName)
10.创建点击菜单条目后回复的选择消息
//item:ChoiceItem 点击的机器人菜单条目或者询前引导菜单条目;toChatUsername:IM服务号;transferMode:string Choice.mode 从Choice中获取的转接模式
Message.createSendMessageForMenu(item, this.toChatUsername, transferMode)
11.创建订单消息
//发送订单消息
let message = Message.createTxtSendMessage("订单",this.toChatUsername)
let orderInfo:OrderInfo = {
title:"订单消息",
order_title:"订单号:611088888",
desc:"短裤",
price:"¥200",
img_url:"https://xxx",
item_url:"https://www.easemob.com"
}
message.addOrderInfo(orderInfo)
VisitorClient.getInstance().getVisitorManager().saveMessage(message)
12.创建轨迹消息
//发送轨迹消息
let message = Message.createTxtSendMessage("轨迹",this.toChatUsername)
let trackInfo:TrackInfo = {
title:"轨迹消息",
desc:"衬衫",
price:"¥200",
img_url:"https://xxx",
item_url:"https://www.easemob.com"
}
message.addTrackInfo(trackInfo)
VisitorClient.getInstance().getVisitorManager().sendMessage(message)
13.从消息中获取坐席信息
//用于显示坐席头像、昵称
MessageHelper.getAgentInfo(message)
会话相关
获取所有本地会话
ChatClient.getInstance().chatManager().getAllConversations();
从本地会话中获取最后一条消息
//toChatUsername:IM服务号
VisitorClient.getInstance().getConversationManager().getConversation(toChatUsername)?.latestMessage()
从本地会话中获取最近的坐席信息
//根据业务需求,在会话列表中调用以显示最近坐席信息
let agentInfo = conversation.getAgentInfo();
if (agentInfo) {
this.nickName = agentInfo.userNickname ? agentInfo.userNickname : ""
this.img = agentInfo.avatar ? agentInfo.avatar : ""
}
从本地会话中获取未读消息数
//toChatUsername:IM服务号
VisitorClient.getInstance().getConversationManager().getConversation(toChatUsername)?.unreadMessagesCount()
标记IM服务号对应的本地会话中所有消息为已读
//只改变本地会话中消息状态
VisitorClient.getInstance().getConversationManager().getConversation(toChatUsername).markAllMessagesAsRead()
//TODO 本地标记后需要调用14来通知坐席消息已读
标记本地消息为已读
//本地设置消息已读,只改变本地消息状态
message.setUnRead(false)
标记该通会话中所有消息已读
//从消息中获取客服系统会话ID
let sessionId = MessageHelper.getSessionIdFromMessage(message);
//通知坐席消息已读
VisitorClient.getInstance()
.getVisitorManager()
.asyncMarkAllMessagesAsRead(VisitorClient.getInstance().getTenantId(), sessionId)
获取正在进行中的会话信息
VisitorClient.getInstance().getVisitorManager().asyncGetCurrentSessionInfo()
.then((result) => {
//result为空,没有正在进行中的会话
//result不为空,result.serviceSessionId就是正在进行中的会话ID
})
从本地会话中获取缓存的消息列表
let conversation = VisitorClient.getInstance().getConversationManager().getConversation(toChatUsername);
if(conversation){
conversation.getAllMessages();
}
从本地数据库加载会话的消息列表
//toChatUsername:IM服务号;startMsgId:开始的消息id,往前加载;pageSize:分页加载的消息数量;
//startMsgId为undefined时,从最新消息往前加载
VisitorClient.getInstance().getConversationManager().getConversation(toChatUsername).loadMessages(msgId, pageSize)
清空IM服务号对应的本地会话中的聊天记录
//toChatUsername IM服务号
VisitorClient.getInstance().getConversationManager().clearConversation(toChatUsername)
设置访客属性
设置访客通用属性
//会设置在ext的weichat字段下
//sendMessage之前调用
let visitorInfo = new VisitorInfo()
.setTrueName('真实姓名')
.setUserNickname('昵称')
.setPhone('188888888888')
.setCompanyName('公司名称')
.setEmail('88888888@qq.com')
.setQq('88888888')
.setDesc('访客描述')
.setTags(['vip1'])//vip客户
message.addVisitorInfo(visitorInfo)
设置访客自定义属性
//设置在visitorInfo访客属性对象中
//customColumn为json字符串,可自行定义其内容
let customColumn = "{\"custom\":\"自定义参数内容\",\"age\":18,\"test\":true}"
visitorInfo.setCustomColumn(customColumn)
设置进线路由指定
指定坐席技能组接待
//会设置在ext的weichat字段下
//sendMessage之前调用
message.addQueueIdentityInfo("技能组名称")
指定坐席接待
//会设置在ext的weichat字段下
//sendMessage之前调用
message.addAgentIdentityInfo("qby@77909.com")
设置业务路由标识
//会设置在ext的weichat字段下
//sendMessage之前调用
message.addRoutingRuleFlag("testFlag")
获取欢迎语
获取企业欢迎语
//获取企业欢迎语,一般需要先调用asyncGetCurrentSessionInfo判断没有正在进行中会话时调用
VisitorClient.getInstance().getVisitorManager().asyncGetEnterpriseWelcome()
.then((result) => {
if (result) {
//创建接收消息并保存在数据库
VisitorClient.getInstance().getVisitorManager().saveMessage(this.createReceiveTxtMessage(result))
//TODO 更新消息列表
}
})
获取机器人欢迎语
//获取机器人欢迎语,一般需要先调用asyncGetCurrentSessionInfo判断没有正在进行中会话时调用
VisitorClient.getInstance().getVisitorManager().asyncGetRobotWelcome()
.then((result) => {
if (result) {
let welcomeObj: RobotWelcomeData = JSON.parse(result);
if (welcomeObj) {
let welcomeStr = welcomeObj.greetingText
if (welcomeStr) {
//欢迎语内容
welcomeStr = welcomeStr.replaceAll("&quot;", "\"");
if (welcomeStr != "null") {
//欢迎语类型,TODO 根据类型创建想要展示的Message并保存在数据库,UI做相应显示
switch (welcomeObj.greetingTextType) {
//type为0代表是文字消息的机器人欢迎语
//type为1代表是菜单消息的机器人欢迎语
//type为2代表是图片消息的机器人欢迎语
//type为4代表是图文消息的机器人欢迎语
//type为5代表是答案组消息的机器人欢迎语
}
}
}
}
}
})
满意度评价
1.主动获取满意度评价邀请消息
//serviceSessionId为当前客服系统会话ID,需要先调用asyncGetCurrentSessionInfo获取
VisitorClient.getInstance().getVisitorManager().asyncGetInviteEvaluation(serviceSessionId)
2.发送评价信息
//从消息中获取满意度相关信息,例如:级别、标签列表等。
let evaluationInfo = MessageHelper.getChatEvaluation(currentMessage)
// visitor访客主动评价,agent坐席邀请,system强制邀请访客,点击关闭窗口或会话结束
let evaluateWay = "agent"
if (evaluationInfo && evaluationInfo.inviteId != undefined) {
let inviteId = this.evaluationInfo.inviteId
if (Number(inviteId) == 0) {
evaluateWay = "visitor"
}
}
//detail为评价的文字内容信息,currentDegree为选择星标后从evaluationInfo查到的对应level的AppraiseTags
//selectedTags 为选中的标签信息AppraiseTagItem的集合;selectResolutionParams为选中的问题解决评价标签集合
MessageHelper.sendEvalMessage(currentMessage, evaluateWay, detail, currentDegree,
selectedTags,
selectResolutionParams, {
onSuccess() {
//发送成功
},
onError(errCode, errDesc) {
//发送失败
}
})
3.是否显示问题解决评价
VisitorClient.getInstance()
.getVisitorManager()
.asyncGetIfShowResolution()
.then((value) => {
//true/false
this.showResolution = value
})
4.获取问题解决评价引导语
VisitorClient.getInstance()
.getVisitorManager()
.asyncGetResolutionWord(serviceSessionId)
.then((value) => {
//引导语,如:请问客服是否解决了您的问题?
if (value) {
this.resolutionTip = value
}
})
5.获取问题解决评价列表
VisitorClient.getInstance()
.getVisitorManager()
.asyncResolutionParams(serviceSessionId)
.then((value:ResolutionParam[] | undefined) => {
//返回问题解决评价列表
if (value && value.length > 1) {
//给第一个显示的标签赋值,如:已解决
let param0 = value[0].name
if (param0) {
this.solve = param0
}
//给第二个显示的标签赋值,如:未解决
let param1 = value[1].name
if (param1) {
this.reject = param1
}
}
})
6.获取邀请评价引导语
VisitorClient.getInstance().getVisitorManager().asyncGetEnquiryInviteWord(this.sessionId)
.then((value) => {
//邀请引导语,如:请对我的服务做出评价
if (value) {
this.inviteTip = value
}
})
留言功能
1.创建留言
let creator: CreatorBean = {
name: this.labelName,//标题
phone: this.phone,//电话
email: this.email//邮箱
}
let leaveMsg: LeaveMsg = {
content: this.content,//留言内容
subject: this.theme,//留言主题
creator: creator,
}
//toChatUsername:IM服务号;projectId:租户留言ID
VisitorClient.getInstance()
.getLeaveMsgManager()
.asyncCreateLeaveMessage(leaveMsg, toChatUsername, projectId)
2.获取留言列表
//toChatUsername:IM服务号;projectId:租户留言ID
VisitorClient.getInstance()
.getLeaveMsgManager()
.asyncGetLeaveMessages(toChatUsername, projectId)
3.创建留言评论
let attachments:ArrayList<AttachmentData> = new ArrayList()
//评论里可添加附件,type为image、audio或file
let attachment:AttachmentData = {
name:"附件名称",
url:"https://xxx",//附件url
type:"img",
}
attachments.add(attachment)
let creatorBen: CreatorBean = {
name: "评论人姓名",
username: VisitorClient.getInstance().currentUserName(),//当前用户ID
type: "VISITOR"//固定为”VISITOR“,不可更改
}
let commentData: NewCommentData = {
content: this.content,//评论内容
creator: creatorBen,
attachments: attachments.convertToArray()
}
//toChatUsername:IM服务号;projectId:租户留言ID;ticketId:评论的留言条目ID
VisitorClient.getInstance()
.getLeaveMsgManager()
.asyncCreateLeaveMsgComment(commentData, toChatUsername, projectId, ticketId)
4.获取留言评论列表
//toChatUsername:IM服务号;projectId:租户留言ID;ticketId:评论的留言条目ID
VisitorClient.getInstance()
.getLeaveMsgManager()
.asyncGetLeaveMsgComments(toChatUsername, projectId, ticketId)
自定义iframe参数 {updateVisitorInfoSrc}
//会在ext下设置{"cmd":{"updateVisitorInfoSrc":{"params":paramsObj}}}
//action:命令,这里可随便传个值,如:”cmd“;toChatUsername:IM服务号;
let message = Message.createCmdSendMessage(action, this.toChatUsername)
if (message) {
let paramsObj:VisitorInfoParams = {
"param1": 12,
"param2": "你好"
};
//paramsObj内的key/value可自行定义
message.updateIframeParams(paramsObj)
VisitorClient.getInstance().getVisitorManager().sendMessage(message)
}
高级功能
显示排队人数
//初始化前设置
//需要开通sessionCreatedNoticeEnable、sessionOpenedNoticeEnable、sessionTransferNoticeEnable、sessionAbortedNoticeEnable、sessionClosedNoticeEnable事件
mVisitorOptions.showVisitorWaitCount()
//聊天页面添加
waitCountListener: VisitorWaitListener = {
waitCount(num: number) {
//TODO 更新排队人数
}
}
VisitorClient.getInstance().getVisitorManager().addVisitorWaitListener(this.waitCountListener);
显示坐席输入状态
//初始化前设置
//需要开通sessionOpenedNoticeEnable、sessionAbortedNoticeEnable、sessionClosedNoticeEnable事件
mVisitorOptions.showAgentInputState()
坐席实现消息预知功能
//初始化前设置
mVisitorOptions.showMessagePredict()
访客状态通知
//开始状态上报
CecOfflineReportUtil.getInstance().startReport(toChatUsername)
//结束状态上报
CecOfflineReportUtil.getInstance().stopReport(toChatUsername)
开启/关闭本地日志(默认开启)
//初始化时调用
let mVisitorOptions = new VisitorOptions();
mVisitorOptions.setConsoleLog(false)
VisitorClient.getInstance().init(mContext, visitorOptions)
取本地日志
//在控制台使用hdc命令
hdc file recv /data/app/el2/100/base/{包名}/{AppKey}/core_log
//例:hdc file recv /data/app/el2/100/base/com.easemob.helpdesk.huawei/1197231114210800#demo/core_log
音视频部分集成
创建CEC视频邀请消息
VisitorClient.getInstance()
.getCallManager()
.callVideo("邀请客服进行实时视频", toUserName, {
onSuccess: (): void => {
//跳转到呼叫页面
}
})
创建CEC视频邀请消息
//未接通时,callId为0,isConnected为false
let callId = 0
let isConnected = false
VisitorClient.getInstance()
.getCallManager()
.endCall(callId, this.toUserName, isConnected)
发送取消/挂断CEC视频邀请消息
//接通后,callId为坐席发来的ticket中的信息,isConnected为true
let callId = AgoraMessage.getInstance().getVideoCallTicket()?.callId as number
let isConnected = true
VisitorClient.getInstance().getCallManager().endCall(callId, this.toUserName, isConnected)
注册/移除坐席CEC呼叫访客监听
let cecOptionListener: CecOptionsListener = {
onAgentAccept: (videoCallTicket?: VideoCallTicket, imServiceNum?: string) => {
//弹出CEC视频邀请页面
}
}
//添加坐席CEC呼叫监听,一般在主页面添加
VisitorClient.getInstance()
.getVisitorManager()
.addCecOptionsListener(cecOptionListener)
//移除坐席CEC呼叫监听
VisitorClient.getInstance()
.getVisitorManager()
.removeCecOptionsListener(cecOptionListener)
注册/移除CEC视频监听
let cecVideoCallListener: CecVideoCallListener = {}
cecVideoCallListener.onAgentAccept = (videoCallTicket: VideoCallTicket) => {
//收到坐席发来的ticket
}
cecVideoCallListener.onAgentHangup = () => {
//结束CEC视频通话
}
//注册监听
VisitorClient
.getInstance()
.getCallManager()
.registerCecVideoCallListener(cecVideoCallListener)
...
//取消注册
VisitorClient.getInstance()
.getCallManager()
.unregisterCecVideoCallListener()
关闭CEC在线会话
//visitorId为访客ID,可调用asyncGetVisitorInfo接口获取;sessionId可从消息中获取
let sessionId: string = MessageHelper.getSessionIdFromMessage(message)
VisitorClient.getInstance().getVisitorManager().asyncCloseCec(visitorId, sessionId)
注册/移除VEC视频通话监听
let vecVideoCallListener: VecVideoCallListener = {}
vecVideoCallListener.onAgentAccept = (message: Message, videoCallTicket: VideoCallTicket) => {
if (this.call_flag == VecCallingUtil.VEC_CALL_FLAG_RECV) {
//已经是等待状态下,访客在等待页面,此时有坐席又发起视频邀请,无操作
} else {
//访客主呼,坐席接听,解析videoCallTicket,跳转到视频接通页面
}
}
vecVideoCallListener.onAgentCanceled = (message: Message) => {
//坐席取消
}
vecVideoCallListener.onAgentRejected = (message: Message) => {
//坐席拒接
}
vecVideoCallListener.onVecCreated = (tenantId: string, rtcSessionId: string) => {
//vec会话创建成功
}
vecVideoCallListener.onVecWaitTimeout = () => {
//等待超时,挂断
}
VisitorClient
.getInstance()
.getCallManager()
.registerVecVideoCallListener(vecVideoCallListener)
注册/移除VEC视频排队监听
let vecWaitDataListener: VecWaitListener = {
waitData: (waitingFlag: boolean, waitingContent: string, sessionId: string): void => {
//获取到排队人数,显示
if (waitingContent) {
this.content = waitingContent
}
}
}
//访客主动发起视频,注册排队监听,提示排队人数
VisitorClient.getInstance()
.getVecVisitorManager()
.registerVecWaitListener(vecWaitDataListener)
//取消注册排队监听
VisitorClient.getInstance()
.getVecVisitorManager()
.unRegisterVecWaitListener()
获取VEC视频样式
//获取到VEC坐席渠道关联对应的设置信息;configId为从VEC渠道关联中获取ConfigID
VisitorClient.getInstance()
.getVecVisitorManager()
.asyncGetVecStyle(configId)
获取VEC视频信息
//获取到坐席头像、昵称;tenantId为租户ID
VisitorClient.getInstance()
.getVecVisitorManager()
.asyncGetVecInfo(tenantId)
获取租户开通的灰度功能
//tenantId租户ID
VisitorClient.getInstance()
.getVisitorManager()
.asyncGetGrayscaleOptions(tenantId)
获取屏幕共享范围设置
//是否只能共享应用内页面,默认false
AgoraMessage.getInstance()
.isShareDesktopInMobile()
发送VEC视频邀请消息
//vecImServiceNum:vec渠道关联对应的IM服务号
//sessionExt:vec发起视频时携带的扩展信息,可为undefined
VisitorClient.getInstance()
.getCallManager()
.callVecVideo("您正邀请客服进行视频通话", vecImServiceNum, sessionExt, {
onSuccess: (): void => {
//跳转到呼叫等待页面
}
})
发送取消/挂断VEC视频邀请消息
//callId从坐席接听回调中取,如果坐席尚未接听,传0,标识取消
VisitorClient.getInstance()
.getCallManager()
.cancelVecCall(this.callId, this.toUserName)
注册/移除坐席VEC操作监听
vecOptionListener: VecOptionsListener = {
onEnquiryInvite: (enquiryInvite, vecImServiceNum) => {
//VEC视频结束后,根据坐席端设置,回调满意度评价邀请
},
onAgentInvite: (vecImServiceNum) => {
//坐席VEC呼叫访客
//弹出VEC视频邀请页面
}
}
//添加坐席VEC呼叫访客监听
VisitorClient.getInstance()
.getVecVisitorManager()
.addVecOptionsListener(this.vecOptionListener)
//移除坐席VEC呼叫访客监听
VisitorClient.getInstance()
.getVecVisitorManager()
.removeVecOptionsListener(vecOptionListener)
发送接听VEC视频邀请消息
VisitorClient.getInstance()
.getCallManager()
.acceptVecCall("访客接受视频邀请", this.toUserName)
发送拒接VEC视频邀请消息
VisitorClient.getInstance()
.getCallManager()
.rejectVecCall("访客拒绝接听视频", this.toUserName)
关闭VEC视频会话
//在接通视频后访客挂断时调用,visitorId为访客ID,可调用asyncGetVisitorInfo接口获取;sessionId可从消息中获取
VisitorClient.getInstance()
.getVecVisitorManager()
.asyncCloseVec(visitorId, sessionId)
访客VEC在离线状态
//开启上报,当调用bindVecChat时,sdk内部会自动调用该方法
VecOfflineReportUtil.getInstance().startReport(this.toUserName)
//结束上报,当调用unbindVecChat时,sdk内部会自动调用该方法
VecOfflineReportUtil.getInstance().stopReport(this.toUserName)
注册/移除VEC中IM消息监听
this.vecMessageListener.onMessage = (msgs: ArrayList<Message>) => {
//收到vec聊天消息列表
//刷新VEC聊天页面,更新聊天消息未读数
}
this.vecMessageListener.onMessageSent = () => {
//刷新vec聊天消息列表
}
this.vecMessageListener.onNewChatMessageNotify = () => {
//新消息通知,调接口获取vec聊天消息
}
//添加VEC聊天监听
VisitorClient.getInstance()
.getVecVisitorManager()
.addVecMessageListener(vecMessageListener)
//取消VEC聊天监听
VisitorClient.getInstance()
.getVecVisitorManager()
.removeVecMessageListener(vecMessageListener)
绑定/解绑VEC中IM服务号
//绑定VEC渠道关联中的IM服务号
VisitorClient.getInstance()
.getVecVisitorManager()
.bindVecChat(this.toUserName, this.sessionId)
//解绑VEC渠道关联中的IM服务号
VisitorClient.getInstance()
.getVecVisitorManager()
.unbindVecChat()
请求VEC聊天消息
//在onNewChatMessageNotify中收到有新消息之后,需要调用该方法请求新消息,新消息会自动缓存在VecVisitorManager中
VisitorClient.getInstance()
.getVecVisitorManager()
.requestVecMessage(mContext)
获取VEC聊天消息列表
let messages:Message[] = VisitorClient.getInstance()
.getVecVisitorManager()
.getMessages()
.convertToArray()
获取VEC满意度评价设置
let enquiryData?: EnquiryInvite = AgoraMessage.getInstance()
.getEnquiryData()
提交VEC满意度评价
//visitorId:访客ID;rtcSessionId:VEC会话ID;currentScore:当前星级;comment:备注内容;selectedTags;selectedTags:选中的标签列表;
VisitorClient.getInstance()
.getVecVisitorManager()
.submitEvaluate(visitorId, rtcSessionId, currentScore, comment, selectedTags)
接收VEC坐席推送命令
//参考API 56,添加坐席操作监听,实现其onPushMessage方法
this.vecOptionListener.onPushMessage = (msgData: PushAction, type: string) => {
console.info("onPushMessage type=" + type + ",pushAction=" + JSON.stringify(msgData))
switch (type) {
case AgoraMessage.TYPE_IDENTITYAUTH:
if (msgData.action) {
//如果AgoraMessage.TYPE_IDENTITYAUTH_START == msgData.action,开始身份认证
}
break
case AgoraMessage.TYPE_CARD_OCR:
if (msgData.action) {
if (AgoraMessage.TYPE_CARD_OCR_FACE_START == msgData.action) {
//如果AgoraMessage.TYPE_CARD_OCR_FACE_START == msgData.action,开始识别人像面
} else if (AgoraMessage.TYPE_CARD_OCR_BACK_END == msgData.action) {
//如果AgoraMessage.TYPE_CARD_OCR_BACK_END == msgData.action,结束身份证识别
} else if (AgoraMessage.TYPE_CARD_OCR_BANK_START == msgData.action) {
//如果AgoraMessage.TYPE_CARD_OCR_BANK_START == msgData.action,开始识别银行卡
} else if (AgoraMessage.TYPE_CARD_OCR_BANK_END == msgData.action) {
//如果AgoraMessage.TYPE_CARD_OCR_BANK_END == msgData.action,结束银行卡识别
}
}
break
case AgoraMessage.TYPE_ELECSIGN:
if (msgData.action) {
if (AgoraMessage.TYPE_ELECSIGN_START == msgData.action) {
this.flowId = msgData.flowId as string
} else {
this.flowId = ""
}
//如果AgoraMessage.TYPE_ELECSIGN_START == msgData.action,开始电子签名
}
break
case AgoraMessage.TYPE_LINK_MESSAGE_PUSH:
if (msgData.action) {
this.flowId = msgData.flowId as string
this.infoPushTitle = msgData.content?.title as string
this.infoPushUrl = msgData.content?.content as string
this.infoPushHeight = msgData.content?.heightRatio as number
//收到信息推送信息
}
break
case AgoraMessage.TYPE_MICROPHONE:
if (msgData.action) {
//如果"on" == msgData.action,打开麦克风,否则,关闭麦克风
}
break
case AgoraMessage.TYPE_CAMERA:
if (msgData.action) {
//如果"on" == msgData.action,打开摄像头,否则,关闭摄像头
}
break
case AgoraMessage.TYPE_CAMERA_CHANGE_ON:
//切换摄像头
break
case AgoraMessage.TYPE_FOCUS_CAMERA:
//摄像头聚焦
break
}
}