import { GetRoomInfo, GetRoomUser, GetShowUser, GetApplySpeak, PostMuteAll, PostOpenMicr, PostOpenCamera, DeleteRoomManager } from '../../api/meeting/index' import { GetRoomRtcToken } from '../../api/form/index' import { agora } from '../../utils/agora' import { onInvoke, onSignalr, getSignIr, offSignalr } from '../../utils/singlr' import { role, getStorage } from '../../utils/utils' import { Message } from 'tdesign-miniprogram'; import * as signalR from "signalr-for-wx"; import dayjs from 'dayjs'; const computedBehavior = require('miniprogram-computed').behavior; let reconnectTime = "" as any; let refreshTime = "" as any; let isReconnecTimeSetTimeout = "" as any; let isAutoApplySpeakTime = "" as any; Page({ behaviors: [computedBehavior], data: { footerList: [ { title: '关闭听筒', titleActive: '开启听筒', active: true, icon: '/assets/icon1.png', iconActive: '/assets/icon1-active.png', show: false, }, { title: '静音', titleActive: '解除静音', active: false, icon: '/assets/icon2.png', iconActive: '/assets/icon2-active.png', show: true, }, { title: '关闭视频', titleActive: '打开视频', active: false, icon: '/assets/icon3.png', iconActive: '/assets/icon3-active.png', show: true, }, { title: '翻转', titleActive: '翻转', active: true, icon: '/assets/icon4.png', iconActive: '/assets/icon4.png', show: false, }, { title: '聊天', titleActive: '聊天', active: true, icon: '/assets/icon5.png', iconActive: '/assets/icon5.png', show: true, }, { title: '成员', titleActive: '成员', active: true, icon: '/assets/icon6.png', iconActive: '/assets/icon6.png', show: true, }, { title: '申请发言', titleActive: '结束发言', active: true, icon: '/assets/icon7.png', iconActive: '/assets/icon7-active.png', show: true, }, ], channelId: '', roomInfo: '', roomUserList: [], audioList: [], userVolume: 0, chatList: [], isAdmin: 0, currentUid: '', currentUser: '', userNumer: 0, scrollTop: 0, noViewChatList: 0, applySpeakDialog: false, leaveDialog: false, userPopupVisible: false, chatPopupVisible: false, isFullscreen: false, muted: false, currentRequestSpeakType: '', user: '', messageStr: '', commonlyChatList: [ '能听到我说话吗?', '听得到', '听不到', '我要发言', ], isFirstShow: true, isCurrePage: true, isReconnec: false, isReconnecTime: false, isAutoApplySpeakDialog: false, showScroll: false, }, watch: { 'roomUserList.**': function (roomUserList) { this.setData({ isAdmin: roomUserList.filter((item: any) => (role.ID.includes(item.roleId) || item.isRoomManager) && item.isRoom).length, userNumer: roomUserList.filter((item: any) => item.isRoom).length, audioList: roomUserList.map(item => { return { volume: 0, uid: item.uid, } }) }) const item = roomUserList.find(row => row.uid == this.data.currentUid || row.screenShareId == this.data.currentUid) if (item) { this.setData({ currentUser: item, }) if (!((role.ID.includes(item.roleId) || item.isRoomManager) && item.isRoom)) { this.getShowUser() } } }, 'footerList.**': function (footerList) { const footerListTemplate = [...footerList]; footerListTemplate[3].show = footerListTemplate[2].active if (!footerListTemplate[1].active && !footerListTemplate[2].active) { if (isAutoApplySpeakTime) { clearTimeout(isAutoApplySpeakTime) isAutoApplySpeakTime = '' } isAutoApplySpeakTime = setTimeout(() => { let userItem = this.data.roomUserList.find((item: any) => item.uid === this.data.user.uid) if (!role.ID.includes(this.data.user.roleId) && userItem && userItem.isRoomManager) { DeleteRoomManager({ roomId: this.data.roomInfo.id, roomNum: this.data.channelId, userId: userItem.uid }) this.setData({ isAutoApplySpeakDialog: true }) } clearTimeout(isAutoApplySpeakTime) isAutoApplySpeakTime = '' }, 1000 * 60 * 5); } else { if (isAutoApplySpeakTime) { clearTimeout(isAutoApplySpeakTime) isAutoApplySpeakTime = '' } } this.setData({ footerList: footerListTemplate }) }, 'isClicked': function (isClicked) { if (isClicked) { let timer = setTimeout(() => { this.setData({ isClicked: false, }) clearTimeout(timer) }, 10000); } }, 'isReconnecTime': function (isReconnecTime) { if (isReconnecTime) { isReconnecTimeSetTimeout = setTimeout(() => { clearTimeout(isReconnecTimeSetTimeout) this.setData({ isReconnec: true, isReconnecTime: false, }) isReconnecTimeSetTimeout = '' wx.hideLoading() }, 10000) } else { if (isReconnecTimeSetTimeout) { clearTimeout(isReconnecTimeSetTimeout) isReconnecTimeSetTimeout = '' wx.hideLoading() } } }, 'isCurrePage': function (isCurrePage) { if (isCurrePage) { if (refreshTime) { clearInterval(refreshTime) refreshTime = '' } } else { refreshTime = setInterval(() => { GetRoomUser(this.data.channelId).then(res => { if (res.code === 200) { res.data.forEach((item: any) => { let row = this.data.roomUserList.find((row: any) => row.uid == item.uid); if (row) { row.enableCamera = item.enableCamera; row.enableMicr = item.enableMicr; row.isRoomManager = item.isRoomManager; row.isAdmin = role.ID.includes(item.roleId) || item.isRoomManager; } }); this.changeAgoraDevice() } }) }, 1000 * 30) } }, 'currentUid': function (currentUid) { this.data.roomUserList.forEach(item => { if (item.src) { if (item.uid == currentUid) { agora.setRemoteVideoStreamType(Number(item.uid), 0) } else { agora.setRemoteVideoStreamType(Number(item.uid), 1) } } }); const item = this.data.roomUserList.find(row => row.uid == currentUid || row.screenShareId == currentUid) if (item) { this.setData({ currentUser: item, }) } }, 'isAdmin': function () { const query = wx.createSelectorQuery() query.select('#meeting-content-smallvideo').fields({ size: true, scrollOffset: true }, (res) => { this.setData({ showScroll: Math.ceil(res.scrollHeight) > Math.ceil(res.height) }) }) query.exec() } }, async onLoad(option) { wx.enableAlertBeforeUnload({ message: "确定要离开房间吗?" }) this.setData({ channelId: option.roomNum, user: await getStorage('user') }) await this.joinChannel() await this.getRoomUser() await this.getShowUser() this.startClientEvent() this.startSignalr() await this.getRoomInfo() const that = this; wx.getStorage({ key: 'historicalList', success(res: any) { const list = [...res.data] if (list.length >= 3) { list.splice(0, 1) } list.push({ nickName: option.nickName, roomNum: option.roomNum, roomName: that.data.roomInfo.roomName }) wx.setStorage({ key: "historicalList", data: list }) }, fail() { wx.setStorage({ key: "historicalList", data: [{ nickName: option.nickName, roomNum: option.roomNum, roomName: that.data.roomInfo.roomName }] }) } }) }, onReady() { wx.onNetworkStatusChange(this.listener) }, onShow() { wx.setKeepScreenOn({ keepScreenOn: true, }); this.setData({ isCurrePage: false }) if (this.data.isFirstShow) { this.setData({ isFirstShow: false, }) } else { const item = this.data.roomUserList.find(row => row.uid === this.data.user.uid) if (item && !item.isRoomManager) { wx.showLoading({ title: '重连中', mask: true }) this.setData({ isReconnecTime: true, }) agora.destroy(() => { reconnectTime = setInterval(() => { if (getSignIr() === signalR.HubConnectionState.Connected) { this.reconnecFun() clearInterval(reconnectTime) reconnectTime = '' } }, 2000) }) } } }, onHide() { this.setData({ isCurrePage: true, isReconnecTime: false }) if (reconnectTime) { clearInterval(reconnectTime) reconnectTime = '' } if (isReconnecTimeSetTimeout) { clearInterval(isReconnecTimeSetTimeout) isReconnecTimeSetTimeout = '' } if (refreshTime) { clearInterval(refreshTime) refreshTime = '' } }, onUnload() { wx.offNetworkStatusChange(this.listener) if (reconnectTime) { clearInterval(reconnectTime) reconnectTime = '' } if (isReconnecTimeSetTimeout) { clearInterval(isReconnecTimeSetTimeout) isReconnecTimeSetTimeout = '' } if (refreshTime) { clearInterval(refreshTime) refreshTime = '' } if (isAutoApplySpeakTime) { clearTimeout(isAutoApplySpeakTime) isAutoApplySpeakTime = '' } }, confirmIsAutoApplySpeakDialog() { if (!this.data.isClicked) { GetApplySpeak(this.data.channelId).then(res => { if (res.code === 200) { this.setData({ isClicked: true, }) this.message('申请发言成功').success() } this.setData({ isAutoApplySpeakDialog: false }) }).catch(() => { this.setData({ isAutoApplySpeakDialog: false }) }) } else { this.message('申请太频繁了,请稍后重试!').error(); } }, cancelIsAutoApplySpeakDialog() { this.setData({ isAutoApplySpeakDialog: false }) }, async reconnecFun() { offSignalr() await GetRoomRtcToken(this.data.channelId).then(res => { if (res.code === 200) { agora.reconnecSetOption(res.data, async (bool) => { if (bool) { await this.joinChannel() this.startClientEvent() this.startSignalr() await this.getRoomUser() await this.getShowUser() Message.success({ context: this, offset: [20, 32], duration: 3000, content: '重连成功', }); this.setData({ isReconnecTime: false, isReconnec: false }) } else { this.setData({ isReconnec: true }) } wx.hideLoading() }) } else { wx.hideLoading() this.setData({ isReconnec: true }) } }).catch(() => { wx.hideLoading() this.setData({ isReconnec: true }) }) }, startSignalr() { onSignalr(async (item) => { if (this.data.isCurrePage) { const item = this.data.roomUserList.find(row => row.uid === this.data.user.uid) if (item && !item.isRoomManager) { return } } const userInfo: any = await getStorage('user') switch (item.key) { // 聊天 case 'ReceiveMessage': if (!this.data.chatPopupVisible) { this.setData({ noViewChatList: this.data.noViewChatList += 1 }) } item.timestamp = dayjs(item.timestamp).format('HH:mm:ss') this.setData({ chatList: [...this.data.chatList, item] }) this.scrollToBottom() break; // 扩展操作 case 'Operation': // 4:屏幕共享 break; // 全员离开房间 case 'AllLeave': this.message('管理员已结束会议!').success() setTimeout(() => { wx.disableAlertBeforeUnload({ complete: () => { wx.navigateBack() } }) }, 1000); break; // 移出会议 case 'ForceExitRoom': this.message('管理员已将你移出会议!').success() setTimeout(() => { wx.disableAlertBeforeUnload({ complete: () => { wx.navigateBack() } }) }, 1000); break; // 更新视图模式 case 'RefreshView': break; // 全员看他 case 'ShowUser': if (item.operUid && item.operUserName) { if (item.operUid !== userInfo.uid) { if (item.uid === userInfo.uid) { this.message(`${item.operUserName}设置全员看你`).success() } else { this.message(`${item.operUserName}设置全员看${item.uname}`).success() } } } this.getShowUser() break; // 用户加入频道回调 case 'UserJoined': this.setAllUserListData('UserJoined', item) break; // 用户退出频道回调 case 'UserLeave': this.setAllUserListData('UserLeave', item) if (item.uid === this.data.currentUid) { this.getShowUser(); } break; // 所有用户开闭麦 case 'OperAllMicr': this.setAllUserListData('OperAllMicr', item) break; // 用户关闭开启麦克风 case 'OperMicr': if (item.operUid !== userInfo.uid) { if (item.user.uid === userInfo.uid) { this.message(item.user.enableMicr ? '管理员已取消你的静音' : '你已被管理员静音').success() } } this.setAllUserListData('OperMicr', item) break; // 用户开启关闭摄像头 case 'OperCamera': if (item.operUid !== userInfo.uid) { if (item.user.uid === userInfo.uid) { this.message(item.user.enableCamera ? '管理员已开启你的摄像头' : '管理员已关闭你摄像头').success() } } this.setAllUserListData('OperCamera', item) break; // 发言人用户信息刷新 case 'ManagerRefresh': this.setAllUserListData('ManagerRefresh', item, async () => { if (item.user.uid === item.uid) { if (item.user.uid === userInfo.uid) { // await agora.allLeaveChannelEx() this.message(`操作成功`).success() await agora.setRole(item.user.isRoomManager, (url: string) => { const roomUserListTemp = [...this.data.roomUserList] const itemUser = roomUserListTemp.find(row => row.uid == userInfo.uid) itemUser.src = url this.setData({ roomUserList: roomUserListTemp, }) }) await this.postOpenMicrApi(item.user.isRoomManager, userInfo.uid, false) await this.postOpenCameraApi(false, userInfo.uid) // 不管身份如何改变都关闭摄像头 } else { this.message(`${item.user.userName}已结束发言`).success() } } else { if (item.user.uid === userInfo.uid) { if (item.user.isRoomManager) { // await agora.allLeaveChannelEx() } this.message(`管理员${item.user.isRoomManager ? '设置' : '取消'}您为发言人`).success() await agora.setRole(item.user.isRoomManager, (url: string) => { const roomUserListTemp = [...this.data.roomUserList] const itemUser = roomUserListTemp.find(row => row.uid == userInfo.uid) itemUser.src = url this.setData({ roomUserList: roomUserListTemp, }) }) if (this.data.currentRequestSpeakType === 'video') { await this.postOpenCameraApi(item.user.isRoomManager, userInfo.uid) } else if (this.data.currentRequestSpeakType === 'audio') { await this.postOpenMicrApi(item.user.isRoomManager, userInfo.uid, false) } else { await this.postOpenMicrApi(item.user.isRoomManager, userInfo.uid, false) await this.postOpenCameraApi(false, userInfo.uid) } this.setData({ currentRequestSpeakType: '' }) } else { this.message(`管理员${item.user.isRoomManager ? '设置' : '取消'}${item.user.userName}为发言人`).success() } } }) break; // 申请发言 case 'ApplyToSpeak': break; // 管理员查看随机用户 case 'Watch': if (!role.ID.includes(userInfo.roleId)) { let userId = item.watchUids.find((uid: any) => uid === userInfo.uid) if (userId) { // await agora.allJoinChannelEx() } else { // await agora.allLeaveChannelEx() } } break; // 设备列表 case 'DriverList': break; // 设置设备 case 'SaveDriver': break; // 显示设备列表 case 'ShowDriverList': break; case 'SetSpeaker': await onInvoke('SetSpeakerCallback', item.RoomManagerInputDTO) break; } }) }, startClientEvent() { agora.clientEvent({ streamAdded: async (url: string, uid: number | string) => { const roomUserListTemp = [...this.data.roomUserList] const item = roomUserListTemp.find(row => row.uid == uid || row.screenShareId == uid) if (item) { if (String(uid).length === 9) { item.shareSrc = url } else { item.src = url } } this.setData({ roomUserList: roomUserListTemp, }) }, streamRemoved: (uid) => { const roomUserListTemp = [...this.data.roomUserList] uid.forEach(id => { if (String(id).length === 9) { const item = roomUserListTemp.find(row => row.uid == id || row.screenShareId == id) item.shareSrc = '' this.setData({ roomUserList: roomUserListTemp, }) } }); }, tokenRef: () => { GetRoomRtcToken(this.data.channelId).then(res => { if (res.code === 200) { agora.renewToken(res.data) } }) } }) }, async getRoomUser(): Promise { await GetRoomUser(this.data.channelId).then(res => { if (res.code === 200) { res.data.forEach((item) => { item.isRoom = true; item.isAdmin = role.ID.includes(item.roleId) || item.isRoomManager item.avatarName = item.userName?.slice(-2) }) this.setData({ roomUserList: res.data }) } }) }, async getShowUser(): Promise { await GetShowUser(this.data.channelId).then(async (res) => { if (res.code === 200 && res.data) { this.setData({ currentUid: res.data, }) } }) }, async getRoomInfo(): Promise { await GetRoomInfo(this.data.channelId).then(async (res) => { if (res.code === 200) { this.setData({ roomInfo: res.data, }) } }) }, async joinChannel(): Promise { await onInvoke('joinChannel', { roomNum: this.data.channelId, enableMicr: this.data.footerList[1].active, enableCamera: this.data.footerList[2].active, }) await agora.joinChannel() }, async setAllUserListData(key: string, item: any, callBack?: Function): Promise { const { roomUserList } = this.data; const userInfo: any = await getStorage('user') switch (key) { case 'OperMicr': case 'OperCamera': case 'ManagerRefresh': let userItem = roomUserList.find((row: any) => row.uid === item.user.uid) if (userItem) { for (const keys in item.user) { if (keys !== 'enableCamera' && keys !== 'enableMicr') { userItem[keys] = item.user[keys]; } } if (key === 'OperCamera') { userItem.enableCamera = item.user.enableCamera; if (userItem.uid === userInfo.uid) { // userItem.enableCamera ? agora.startCameraCapture() : agora.stopCameraCapture() } } if (key === 'OperMicr') { userItem.enableMicr = item.user.enableMicr; } userItem.isAdmin = role.ID.includes(item.user.roleId) || item.user.isRoomManager; this.setData({ roomUserList }) } if (key === 'ManagerRefresh') { callBack && callBack() } break; case 'UserJoined': let userJoinedItem = roomUserList.find((row: any) => row.uid === item.user.uid) if (userJoinedItem) { for (const key in item.user) { userJoinedItem[key] = item.user[key]; } userJoinedItem.isRoom = true; userJoinedItem.isAdmin = role.ID.includes(item.user.roleId) || item.user.isRoomManager; this.setData({ roomUserList }) } else { item.user.isRoom = true; item.user.isAdmin = role.ID.includes(item.user.roleId) || item.user.isRoomManager; item.user.avatarName = item.user.userName?.slice(-2) this.setData({ roomUserList: [...roomUserList, item.user] }) } break; case 'UserLeave': let userLeaveItem = roomUserList.find((row: any) => row.uid === item.uid) if (userLeaveItem) { userLeaveItem.isRoom = false userLeaveItem.isAdmin = false this.setData({ roomUserList }) } break; case 'OperAllMicr': roomUserList.forEach((row: any) => { if (row.uid !== item.uid) { row.enableMicr = item.enableMicr } }) this.setData({ roomUserList }) break; } this.changeAgoraDevice() }, async changeFooterList(e): Promise { const userInfo: any = await getStorage('user') const { index } = e.currentTarget.dataset; const { footerList } = this.data; const footerListTemplate = [...footerList] const item = footerListTemplate[index]; let title = item.active ? item.title : item.titleActive; switch (title) { case '关闭听筒': case '开启听筒': break; case '解除静音': case '静音': if (item.active) { // 静音 await this.postOpenMicrApi(false, userInfo.uid, false, true) } else { // 解除静音 await this.getUserRoomInfo().then(async (res) => { if (res) { await this.postOpenMicrApi(true, userInfo.uid, false, true) } else { if (!this.data.isClicked) { this.setData({ applySpeakDialog: true, currentRequestSpeakType: 'audio' }) } else { this.message('申请太频繁了,请稍后重试!').error(); } } }) } break; case '关闭视频': case '打开视频': if (item.active) { // 关闭视频 await this.postOpenCameraApi(false, userInfo.uid, true) } else { // 打开视频 await this.getUserRoomInfo().then(async (res) => { if (res) { await this.postOpenCameraApi(true, userInfo.uid, true) } else { if (!this.data.isClicked) { this.setData({ applySpeakDialog: true, currentRequestSpeakType: 'video' }) } else { this.message('申请太频繁了,请稍后重试!').error(); } } }) } break; case '申请发言': case '结束发言': if (item.active) { // 申请发言 if (!this.data.isClicked) { this.setData({ applySpeakDialog: true, currentRequestSpeakType: '' }) } else { this.message('申请太频繁了,请稍后重试!').error(); } } else { // 结束发言 DeleteRoomManager({ roomId: this.data.roomInfo.id, roomNum: this.data.channelId, userId: userInfo.uid }) } break; case '翻转': await this.getUserRoomInfo().then(async (res) => { if (res) { wx.createLivePusherContext().switchCamera() } else { this.message('暂无权限').error(); } }) break; case '聊天': this.setData({ chatPopupVisible: true, noViewChatList: 0 }) this.scrollToBottom() break; case '成员': this.setData({ userPopupVisible: true }) break; } }, async postOpenMicrApi(enableMicr: boolean, uid: string, isAll: boolean, isMessage: boolean = false): Promise { if (isAll) { await PostMuteAll({ roomNum: this.data.channelId, enableMicr }) } else { await PostOpenMicr({ roomNum: this.data.channelId, uid, enableMicr }) } if (isMessage) { this.message('操作成功').success() } }, async postOpenCameraApi(enableCamera: boolean, uid: string, isMessage: boolean = false): Promise { if (enableCamera) { // await agora.startCameraCapture() } else { // await agora.stopCameraCapture(); } await PostOpenCamera({ roomNum: this.data.channelId, uid, enableCamera }) if (isMessage) { this.message('操作成功').success() } }, async closeDialog(e) { const { type } = e.currentTarget.dataset; switch (e.type) { case "confirm": switch (type) { case "applySpeakDialog": await GetApplySpeak(this.data.channelId).then(res => { if (res.code === 200) { this.setData({ isClicked: true, [type]: false, }) this.message('申请发言成功').success() } }) break; case "leaveDialog": wx.disableAlertBeforeUnload({ complete: () => { wx.navigateBack() } }) break; } break; case "cancel": this.setData({ [type]: false }) break; } }, playerStateChange(e) { }, recorderStateChange(e) { }, playerAudioVolumenotify(e) { const { uid } = e.currentTarget.dataset; const { volume } = e.detail; const audioListTemp = [...this.data.audioList] const percentage = (volume / 100) * 100 const item = audioListTemp.find(row => row.uid == uid) if (item) { item.volume = Math.floor(percentage) + '%' } this.setData({ audioList: audioListTemp, userVolume: audioListTemp.find(row => row.uid == this.data.user.uid).volume }) }, clickChangeVideo(e) { const { item } = e.currentTarget.dataset; this.setData({ currentUid: item.uid }) }, message(content: string) { return { success: () => { Message.success({ context: this, offset: [20, 32], duration: 2000, content, }); }, error: () => { Message.error({ context: this, offset: [20, 32], duration: 2000, content, }); } } }, async getUserRoomInfo(): Promise { const userInfo: any = await getStorage('user') return new Promise((resolve, _reject) => { let userItem = this.data.roomUserList.find((item: any) => item.uid === userInfo.uid) if (userItem && (role.ID.includes(userItem.roleId) || userItem.isRoomManager)) { resolve(userItem) } else { resolve('') } }) }, async changeAgoraDevice(): Promise { const userInfo: any = await getStorage('user') this.data.roomUserList.forEach(async (item: any) => { if (item.uid == userInfo.uid) { const footerListTemplate = [...this.data.footerList] footerListTemplate[1].active = item.enableMicr footerListTemplate[2].active = item.enableCamera item.enableMicr ? await agora.unmuteLocal('audio') : await agora.muteLocal('audio') item.enableCamera ? await agora.unmuteLocal('video') : await agora.muteLocal('video') if (!role.ID.includes(userInfo.roleId)) { footerListTemplate[6].active = !item.isRoomManager; } this.setData({ footerList: footerListTemplate }) } }); }, async back() { this.setData({ leaveDialog: true }) }, onVisibleChange() { this.setData({ userPopupVisible: false, chatPopupVisible: false, }) }, changeMessageStr(e) { this.setData({ messageStr: e.detail.value }) }, async sendMeg(e) { if (this.data.messageStr || e.target.dataset.item) { await onInvoke('sendChannelMsg', { roomNum: this.data.channelId, msg: e.target.dataset.item || this.data.messageStr }) this.setData({ chatList: [...this.data.chatList, { userName: this.data.user.userName, message: e.target.dataset.item || this.data.messageStr, timestamp: dayjs(+new Date()).format('HH:mm:ss'), me: true }], }) if (!e.target.dataset.item) { this.setData({ messageStr: '' }) } this.scrollToBottom() } else { this.message('请输入文字!').error() } }, changeFullscreen() { this.setData({ isFullscreen: !this.data.isFullscreen }) }, scrollToBottom() { wx.createSelectorQuery() .select('#chatView') .node() .exec((res) => { const scrollView = res[0].node; scrollView.scrollTo({ top: 10000000000000 }) }) }, async listener(res) { if (res.isConnected && (res.networkType !== 'none' || res.networkType !== 'unknown')) { } else { wx.setStorage({ key: "isConnected", data: true }) wx.disableAlertBeforeUnload({ complete: () => { wx.navigateBack() } }) } }, closeRoom() { wx.disableAlertBeforeUnload({ complete: () => { this.setData({ isReconnec: false }) wx.navigateBack() } }) }, scroll() { }, scrollUp() { const query = wx.createSelectorQuery() query.select('#meeting-content-smallvideo').scrollOffset((res => { this.setData({ scrollTop: res.scrollTop - 50 }) })) query.exec() }, scrollDown() { const query = wx.createSelectorQuery() query.select('#meeting-content-smallvideo').scrollOffset((res => { this.setData({ scrollTop: res.scrollTop + 50 }) })) query.exec() }, })