XuqmGroup-Web/docs-site/docs/miniprogram/im.md

138 行
2.3 KiB
Markdown

# 微信小程序 IM 接入
**模块**`xuqm-group-wechat-mini-program-sdk`
---
## 登录
```ts
import { XuqmMiniProgramSDK } from 'xuqm-group-wechat-mini-program-sdk'
const sdk = new XuqmMiniProgramSDK()
sdk.init({ appKey: 'your_app_key' })
// 使用 UserSig 登录
await sdk.login('user_001', 'your_user_sig_jwt')
```
---
## 监听消息
```ts
sdk.on('connected', () => {
console.log('IM 已连接')
})
sdk.on('message', (msg) => {
console.log('收到消息:', msg.msgType, msg.content)
})
sdk.on('read', (msg) => {
console.log('已读回执:', msg.id)
})
sdk.on('revoke', (data) => {
console.log('消息被撤回:', data.msgId)
})
sdk.on('disconnected', (reason) => {
console.log('断开连接:', reason)
})
sdk.on('error', (error) => {
console.error('IM 错误:', error)
})
```
---
## 发送消息
```ts
const msg = await sdk.send({
toId: 'user_002',
chatType: 'SINGLE',
msgType: 'TEXT',
content: 'Hello!',
})
```
### 发送文本消息(快捷方法)
```ts
await sdk.sendTextMessage('user_002', 'SINGLE', 'Hello!')
```
---
## 历史消息
```ts
const history = await sdk.fetchHistory('user_002')
const groupHistory = await sdk.fetchGroupHistory('group_xxx')
```
---
## 会话列表
```ts
const conversations = await sdk.listConversations()
await sdk.markRead('user_002')
await sdk.setConversationPinned('user_002', 'SINGLE', true)
await sdk.setConversationMuted('user_002', 'SINGLE', true)
```
---
## 群聊
```ts
const groups = await sdk.listGroups()
const group = await sdk.getGroupInfo('group_xxx')
const members = await sdk.listGroupMembers('group_xxx')
```
---
## 好友管理
```ts
const friends = await sdk.listFriends()
await sdk.addFriend('user_002')
await sdk.removeFriend('user_002')
```
---
## 离线消息同步
```ts
const count = await sdk.offlineMessageCount()
const messages = await sdk.syncOfflineMessages()
```
---
## 消息类型
| MsgType | 说明 |
|---------|------|
| `TEXT` | 纯文本 |
| `IMAGE` | 图片 |
| `VIDEO` | 视频 |
| `AUDIO` | 语音 |
| `FILE` | 文件 |
| `LOCATION` | 位置 |
| `CUSTOM` | 自定义 |
| `NOTIFY` | 系统通知 |
| `RICH_TEXT` | 富文本 |
| `CALL_AUDIO` | 语音通话信令 |
| `CALL_VIDEO` | 视频通话信令 |
| `QUOTE` | 引用 |
| `MERGE` | 合并转发 |
| `FORWARD` | 转发 |
| `REVOKED` | 撤回 |