Methods
sendTextMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送文本消息
Examples
// 发送普通文本消息
let promise = TUIChatService.sendTextMessage({
payload: {
text: 'Hello world!'
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
// 发送普通文本消息并携带消息自定义数据
let promise = TUIChatService.sendTextMessage({
payload: {
text: 'Hello world!'
},
cloudCustomData: 'your cloud custom data'
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
文本消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendTextAtMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送附带 @ 提醒功能的文本消息
Example
// 发送 @ 消息
let promise = TUIChatService.sendTextAtMessage({
payload: {
text: '@denny @lucy @所有人 今晚聚餐,收到的请回复1',
atUserList: ['denny', 'lucy', TUIChatEngine.TYPES.MSG_AT_ALL] // 'denny' 'lucy' 都是 userID,而非昵称
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
附带 @ 提醒功能的文本消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendImageMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送图片消息
Example
// 发送图片消息
let promise = TUIChatService.sendImageMessage({
payload: {
file: file
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
图片消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendAudioMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送音频消息
Example
// 发送音频消息
let promise = TUIChatService.sendAudioMessage({
payload: {
file: file
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
音频消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendVideoMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送视频消息
Example
// 发送视频消息
let promise = TUIChatService.sendVideoMessage({
payload: {
file: file
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
视频消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendFileMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送文件消息
Example
// 发送文件消息
let promise = TUIChatService.sendFileMessage({
payload: {
file: file
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
文件消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendCustomMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送自定义消息
Example
// 发送自定义消息
let promise = TUIChatService.sendCustomMessage({
payload: {
data: 'dice', // 用于标识该消息是骰子类型消息
description: String(random(1,6)), // 获取骰子点数
extension: ''
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
自定义消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendFaceMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送表情消息
Example
// 发送自定义消息
let promise = TUIChatService.sendFaceMessage({
payload: {
index: 1, // Number 表情索引,用户自定义
data: 'tt00' // String 额外数据
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
表情消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendLocationMessage(options, sendMessageOptionsopt) → {Promise.<any>}
发送地理位置消息
Example
// 发送地理位置消息
let promise = TUIChatService.sendLocationMessage({
payload: {
description: '深圳市深南大道10000号腾讯大厦',
longitude: 113.941079, // 经度
latitude: 22.546103 // 纬度
},
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
SendMessageParams |
地理位置消息相关参数 |
|
sendMessageOptions |
SendMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
sendForwardMessage(conversationList, messageList, sendForwardMessageOptionsopt) → {Promise.<any>}
转发消息
- 注意:支持逐条转发和合并转发
Examples
// 逐条转发,把当前会话的 message1,message2 逐条转发给会话 conversation1, conversation2
let promise = TUIChatService.sendForwardMessage([conversation1, conversation2], [message1, message2]);
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
// 合并转发,把当前会话的 message1,message2 合并转发给会话conversation1, conversation2
let promise = TUIChatService.sendForwardMessage([conversation1, conversation2], [message1, message2], { needMerge: true });
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
// 合并转发,把当前会话的 message1,message2 合并转发给会话 conversation1, conversation2, 自定义合并后的消息 title
const sendForwardMessageOptions = {
needMerge: true,
// 合并转发配置项,needMerge = true 时生效。
` mergeInfo: {
title: '自定义合并后的消息 title'
}
}
let promise = TUIChatService.sendForwardMessage([conversation1, conversation2], [message1, message2], sendForwardMessageOptions);
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
conversationList |
Array.<(Conversation|IConversationModel)> |
接收转发消息的会话列表 |
|
messageList |
Array.<(Message|MessageModel)> |
待转发的消息列表 |
|
sendForwardMessageOptions |
SendForwardMessageOptions |
<optional> |
消息发送选项 |
Returns:
- Type
- Promise.<any>
enterTypingState() → {void}
开始输入
- 注意: 只支持 C2C 会话
Example
TUIChatService.enterTypingState();
Returns:
- Type
- void
leaveTypingState() → {void}
结束输入
- 注意: 只支持 C2C 会话
Example
TUIChatService.leaveTypingState();
Returns:
- Type
- void
sendMessageReadReceipt(messageList) → {Promise.<any>}
发送消息已读回执
Example
let promise = TUIChatService.sendMessageReadReceipt([messageModel1, messageModel2, messageModel3]);
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Description |
---|---|---|
messageList |
Array.<MessageModel> |
messageModel 列表 |
Returns:
- Type
- Promise.<any>
getGroupMessageReadMemberList(options) → {Promise.<any>}
获取群消息已读(或未读)群成员列表
Examples
// 获取已读群成员列表
let promise = TUIChatService.getGroupMessageReadMemberList({
message,
filter: 0,
cursor: '', // 第一次拉取传''
count: 30,
});
promise.then(function(response) {
const { isCompleted, cursor, messageID, readUserInfoList } = response;
// isCompleted - true,拉取完成;false 未完成
// cursor - 当 isCompleted 为 false 的时候用于续拉
// messageID - 群消息的 ID
// readUserInfoList - 已读的群成员用户信息列表
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
// 获取未读群成员列表
let promise = TUIChatService.getGroupMessageReadMemberList({
message,
filter: 1,
cursor: '', // 第一次拉取传''
count: 30,
});
promise.then(function(response) {
const { isCompleted, cursor, messageID, unreadUserInfoList } = response;
// isCompleted - true,拉取完成;false 未完成
// cursor - 当 isCompleted 为 false 的时候用于续拉
// messageID - 群消息的 ID
// unreadUserInfoList - 未读的群成员用户信息列表
});
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Description |
---|---|---|
options |
GetGroupMessageReadParams |
参数选项 |
Returns:
- Type
- Promise.<any>
getMessageList(optionsopt) → {Promise.<any>}
分页拉取指定会话的消息列表的接口,当用户进入会话首次渲染消息列表或者用户“下拉查看更多消息”时,需调用该接口。
Example
let promise = TUIChatService.getMessageList();
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Attributes | Description |
---|---|---|---|
options |
GetMessageListParams |
<optional> |
获取漫游消息参数 |
Returns:
- Type
- Promise.<any>
downloadMergedMessages(message) → {Promise.<any>}
下载合并后的消息。如果发送方发送的合并消息较大,Chat SDK 会将此消息存储到云端,消息接收方查看消息时,需要先把消息从云端下载到本地。
Example
if (message.type === TUIChatEngine.TYPES.MSG_MERGER && message.payload.downloadKey !== '') {
// 下载成功后,SDK会更新 message.payload.messageList 等信息
let promise = TUIChatService.downloadMergedMessages(message);
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
}
Parameters:
Name | Type | Description |
---|---|---|
message |
Record.<string, any> |
消息对象或合并消息对象的 messageBody |
Returns:
- Type
- Promise.<any>
setTranslationLanguage(language) → {void}
设置文本消息翻译的目标语言
注意:v2.1.0 起支持。
Example
TUIChatService.setTranslationLanguage('en');
Parameters:
Name | Type | Description |
---|---|---|
language |
string |
目标语言,支持的目标语言有多种,例如:英语-"en",简体中文-"zh",法语-"fr",德语-"de"等。 |
Returns:
- Type
- void
translateText(options) → {Promise.<any>}
翻译文本消息
Example
let promise = TUIChatService.translateText({
sourceTextList: ['مرحبًا'],
sourceLanguage: 'auto',
});
promise.then((chatResponse) => {
// 翻译成功 translatedTextList 和 sourceTextList 的元素一一对应
const { translatedTextList } = chatResponse.data;
});
Parameters:
Name | Type | Description |
---|---|---|
options |
TranslateTextParams |
需要翻译的消息及配置信息 |
Returns:
- Type
- Promise.<any>
searchCloudMessages(options) → {Promise.<any>}
搜索云端消息
【v0.1.2起支持】
注意1:此功能当前处于限免阶段,您可通过即时通信 IM 功能及购买咨询交流群联系我们为您开通体验完整功能。
注意2:此接口本地限频 2 次/秒。
注意3:搜索【全部会话】的消息,如果匹配到的消息数量 messageCount > 1,则接口返回的 messageList 为 [],您可以在 UI 上展示 【${messageCount} 条相关记录】。如果您想高亮展示匹配到的消息,请参考【指定搜索】,将接口返回的 messageList 高亮展示。
注意4:搜索【全部会话】的消息,如果某个会话中匹配到的消息条数 = 1,则 messageList 为匹配到的那条消息。
注意5:社群、topic、直播群,不支持搜索云端消息。
Examples
// 全量搜索,指定关键字
// - 搜索消息里出现 ‘你好’ 或 ‘在哪里’
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
});
// 全量搜索,指定关键字和匹配类型搜索
// - 搜索消息里出现了 ‘你好’ 与 ‘在哪里’ 的消息
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
keywordListMatchType: 'and',
});
// 全量搜索,指定关键字列表和消息发送者搜索
// - 搜索消息发送者为 ‘user1’ 或 ‘user2’,且消息里出现了 ‘你好’ 或 ‘在哪里’ 的消息
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
senderUserIDList: ['user1', 'user2'],
});
// 全量搜索,指定关键字和消息类型搜索
// - 搜索消息类型为 ‘文本消息’ 或 ‘自定义消息’,且消息里出现了 ‘你好’ 或 ‘在哪里’ 的消息
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
messageTypeList: [TUIChatEngine.TYPES.MSG_TEXT, TUIChatEngine.TYPES.MSG_CUSTOM],
});
// 全量搜索,搜索所有图片消息(当指定发送者或消息类型时,关键字列表可以为空)
let promise = TUIChatService.searchCloudMessages({
messageTypeList: [TUIChatEngine.TYPES.MSG_IMAGE],
});
// 全量搜索,只指定消息发送者和消息类型搜索(当指定发送者或消息类型时,关键字列表可以为空)
// - 搜索消息发送者为 ‘user1’ 或 ‘user2’,且消息类型为 ‘文本消息’ 或 ‘自定义消息’ 的消息
let promise = TUIChatService.searchCloudMessages({
senderUserIDList: ['user1', 'user2'],
messageTypeList: [TUIChatEngine.TYPES.MSG_TEXT, TUIChatEngine.TYPES.MSG_CUSTOM],
});
// 全量搜索,指定关键字和时间(过去一天)搜索
// - 搜索过去一天,消息里出现了 ‘你好’ 或 ‘在哪里’的消息
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
timePosition: Number((new Date().getTime()/1000).toFixed(0)),
timePeriod: 24 * 60 * 60,
});
promise.then(function(imResponse) {
// 搜索消息成功
const { totalCount, cursor,searchResultList } = imResponse.data;
console.log(totalCount); // 满足搜索条件的消息所在的所有会话总数量
console.log(cursor); // 下一次云端搜索的起始位置, 如果没有表示搜索结果拉取完成
console.log(searchResultList); // 满足搜索条件的消息根据会话 ID 分组,分页返回分组结果
for (let i = 0; i < searchResultList.length; i++) {
const searchResultItem = searchResultList[i];
const { conversationID, messageCount, messageList } = searchResultItem;
console.log(conversationID); // 会话 ID
console.log(messageCount); // 当前会话一共搜索到了多少条符合要求的消息
// 本次搜索【全部会话】,那么 messageList 中装载的消息条数会有如下两种可能:
// - 如果某个会话中匹配到的消息条数 > 1,则 messageList 为空,您可以在 UI 上显示“ messageCount 条相关记录”。
// - 如果某个会话中匹配到的消息条数 = 1,则 messageList 为匹配到的那条消息,您可以在 UI 上显示之,并高亮匹配关键词。
console.log(messageList);
}
}).catch(function(imError) {
console.error(imError); // 搜索消息失败
});
// 指定会话,指定关键字搜索
// - 搜索在 'GROUPPublic001' 会话中,消息里出现 ‘你好’ 或 ‘在哪里’ 的消息。
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
conversationID: 'GROUPPublic001'
});
// 指定会话,指定消息类型搜索(当指定发送者或消息类型时,关键字列表可以为空)
// - 在 'GROUPPublic001' 会话中,搜索图片消息。
let promise = TUIChatService.searchCloudMessages({
conversationID: 'GROUPPublic001',
messageTypeList: [TUIChatEngine.TYPES.MSG_IMAGE],
});
// 指定会话,指定关键字和消息类型搜索
// - 搜索在 'GROUPPublic001' 会话中,消息里出现 ‘你好’ 或 ‘在哪里’,且消息类型为 ‘文本消息’ 或 ’自定义消息’ 的消息。
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
conversationID: 'GROUPPublic001'
messageTypeList: [TUIChatEngine.TYPES.MSG_TEXT, TUIChatEngine.TYPES.MSG_CUSTOM],
});
// 指定会话,指定关键字和时间(过去一天)搜索
// - 搜索过去一天,在 'GROUPPublic001' 会话中,消息里出现 ‘你好’ 或 ‘在哪里’ 的消息。
let promise = TUIChatService.searchCloudMessages({
keywordList: ['你好', '在哪里'],
conversationID: 'GROUPPublic001'
timePosition: Number((new Date().getTime()/1000).toFixed(0)),
timePeriod: 24 * 60 * 60,
});
promise.then(function(imResponse) {
// 搜索消息成功
const { totalCount, cursor, searchResultList } = imResponse.data;
console.log(totalCount); // 满足搜索条件的消息总数量
console.log(cursor); // 下一次云端搜索的起始位置, 如果没有表示搜索结果拉取完成
console.log(searchResultList); // 当前会话搜索的消息结果
const { conversationID, messageCount, messageList } = searchResultList[0];
console.log(conversationID); // 会话ID
console.log(messageCount); // 当前会话一共搜索到了多少条符合要求的消息
console.log(messageList); // 本会话中所有满足搜索条件的消息列表
}).catch(function(imError); {
console.error(imError); // 搜索消息失败
});
Parameters:
Name | Type | Description |
---|---|---|
options |
SearchCloudMessagesParams |
需要搜索的消息的参数 |
Returns:
- Type
- Promise.<any>
addMessageReaction(message, reactionID) → {Promise.<any>}
添加消息回应
Example
let promise = TUIChatService.addMessageReaction(message, 'smile');
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Description |
---|---|---|
message |
MessageModel |
消息实实例 Model |
reactionID |
string |
消息回应 ID |
Returns:
- Type
- Promise.<any>
removeMessageReaction(message, reactionID) → {Promise.<any>}
删除消息回应
Example
let promise = TUIChatService.removeMessageReaction(message, 'smile');
promise.catch((error) => {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Description |
---|---|---|
message |
MessageModel |
消息实实例 Model |
reactionID |
string |
消息回应 ID |
Returns:
- Type
- Promise.<any>
getAllUserListOfMessageReaction(options) → {Promise.<any>}
分页拉取指定消息回应的用户列表
Example
let promise = TUIChatService.getAllUserListOfMessageReaction({
message: message,
reactionID: 'smile',
nextSeq: 0,
count: 100,
});
promise.then(function(response) {
// 获取成功
const { userList, nextSeq, isCompleted } = response.data;
// userList - 用户信息列表,包含用户的 userID、nick、avatar 信息
// nextSeq - 用于续拉,分页续拉时需传入该字段
// isCompleted - 表示是否已经拉完所有的用户信息。isCompleted 为 true 时,nextSeq 为 0
}).catch(function(error) {
// 调用异常时业务侧可以通过 promise.catch 捕获异常进行错误处理
});
Parameters:
Name | Type | Description |
---|---|---|
options |
GetAllUserListOfMessageReactionParams |
分页拉取指定消息回应的用户列表参数 |
Returns:
- Type
- Promise.<any>
convertVoiceToText(options) → {Promise.<any>}
语音转文字
Examples
// 将语音转为中文
let promise = TUIChatService.convertVoiceToText({
message: audioMessageModel,
});
promise.then((chatResponse) => {
const { result } = chatResponse.data;
});
// 将语音转为日文
let promise = TUIChatService.convertVoiceToText({
message: audioMessageModel,
language: 'ja-JP',
});
promise.then((chatResponse) => {
const { result } = chatResponse.data;
});
Parameters:
Name | Type | Description |
---|---|---|
options |
ConvertVoiceToTextParams |
语音转文字参数信息 |
Returns:
- Type
- Promise.<any>
clearHistoryMessage(string) → {Promise.<any>}
清空单聊或群聊本地及云端的消息(不删除会话)
Example
// 清空群聊 groupID 为 test 的历史消息
let promise = TUIChatService.clearHistoryMessage('GROUPtest');
promise.then((chatResponse) => {
const { result } = chatResponse.data;
});
Parameters:
Name | Type | Description |
---|---|---|
string |
conversationID |
会话 ID |
Returns:
- Type
- Promise.<any>