import logger from '../../utils/logger'; // eslint-disable-next-line no-undef Component({ /** * 组件的属性列表 */ properties: { conversation: { type: Object, value: '', observer(newVal) { if (newVal.type === 'GROUP'); this.setData({ conversation: newVal, }); }, }, count: { type: Number, value: '', observer(newVal) { this.setData({ memberCount: newVal, }); }, }, }, /** * 组件的初始数据 */ data: { personalProfile: { }, getMemberCount: 30, count: '', userID: '', conversation: {}, memberCount: '', groupMemberProfile: [], groupMemberAvatar: [], groupMemberNick: [], hidden: true, notShow: true, isShow: false, showMore: false, addShow: false, popupToggle: false, quitPopupToggle: false, addPopupToggle: false, showText: '退出群聊', showOwner: false, noRepateOwner: [], showOwnerName: {}, showGetMore: false, offsetNumber: 0, selectedUserIDList: [], showGroupCall: false, type: 0, Profile: {}, callStatus: false, list: [], currentUserID: '', callGroupMemberProfile: [], }, lifetimes: { attached() { wx.$TUIKit.getGroupProfile({ groupID: this.data.conversation.groupProfile.groupID, }).then((imResponse) => { this.setData({ Profile: imResponse, }); }); this.setData({ currentUserID: wx.$chat_userID, memberCount: this.data.conversation.groupProfile.memberCount, }); }, }, /** * 组件的方法列表 */ methods: { // 展示更多群成员 showMore() { const { group } = this.data.Profile.data; const currentMemberCount = group.memberCount; this.setData({ showGetMore: currentMemberCount > this.data.getMemberCount, showText: group.selfInfo.role === 'Owner' ? '解散群聊' : '', }); wx.$TUIKit.getGroupMemberList({ groupID: this.data.conversation.groupProfile.groupID, count: this.data.getMemberCount, offset: 0, }) .then((imResponse) => { logger.log(`| TUI-group-profile | getGroupMemberList | getGroupMemberList-length: ${imResponse.data.memberList.length}`); if (this.data.conversation.groupProfile.type === 'Private') { this.setData({ addShow: true, }); } if (imResponse.data.memberList.length > 3) { this.setData({ showMore: true, }); } this.setData({ groupMemberProfile: imResponse.data.memberList, hidden: !this.data.hidden, notShow: !this.data.notShow, isShow: !this.data.isShow, }); }); }, // 拉取更多成员进行展示 getMoreMember() { const offset = this.data.offsetNumber + this.data.getMemberCount; this.setData({ offsetNumber: offset, }); wx.$TUIKit.getGroupMemberList({ groupID: this.data.conversation.groupProfile.groupID, count: this.data.getMemberCount, offset, }).then((imResponse) => { this.setData({ groupMemberProfile: this.data.groupMemberProfile.concat(imResponse.data.memberList), }); if (this.data.groupMemberProfile.length === this.data.memberCount) { this.setData({ showGetMore: false, }); } }); }, // 关闭显示showmore showLess() { this.setData({ isShow: false, notShow: true, hidden: true, }); }, // 展示更多群成员弹窗 showMoreMember() { this.setData({ popupToggle: true, callStatus: false, }); }, // 通话展示更多群成员 callShowMoreMember(event) { if (this.data.groupMemberProfile.length === 0) { wx.$TUIKit.getGroupMemberList({ groupID: this.data.conversation.groupProfile.groupID, count: this.data.getMemberCount, offset: 0, }) .then((imResponse) => { const index = imResponse.data.memberList.findIndex((member) => member.userID === this.data.currentUserID); imResponse.data.memberList.splice(index, 1); this.setData({ callGroupMemberProfile: imResponse.data.memberList, showGetMore: this.data.Profile.data.group.memberCount > this.data.getMemberCount, }); }); } else { const currentGroupMemberProfile = this.data.groupMemberProfile; const index = currentGroupMemberProfile.findIndex((member)=> member.userID === this.data.currentUserID); currentGroupMemberProfile.splice(index, 1); this.setData({ callGroupMemberProfile: currentGroupMemberProfile, }); } this.setData({ type: event.detail.type, popupToggle: true, callStatus: true, }); }, // 关闭显示弹窗 close() { this.setData({ selectedUserIDList: [], showGroupCall: false, popupToggle: false, addPopupToggle: false, quitPopupToggle: false, }); }, quitGroup() { if (this.data.showText === '退出群聊') { this.setData({ quitPopupToggle: true, popupToggle: false, }); } else if (this.data.showText === '解散群聊') { this.setData({ dismissPopupToggle: true, popupToggle: false, }); } }, // 解散群聊 dismissGroupConfirm() { wx.$TUIKit.dismissGroup(this.data.conversation.groupProfile.groupID) .then(() => { this.triggerEvent('showConversationList'); }) .catch((imError) => { wx.showToast({ title: '群主不能解散好友工作群', icon: 'none', }); this.setData({ dismissPopupToggle: false, }); logger.warn('dismissGroup error:', imError); }); }, // 解散群聊的按钮提示 dismissGroupAbandon() { this.setData({ dismissPopupToggle: false, }); }, // 主动退群 quitGroupConfirm() { wx.$TUIKit.quitGroup(this.data.conversation.groupProfile.groupID) .then(() => { this.triggerEvent('showConversationList'); }) .catch((imError) => { wx.showToast({ title: '该群不允许群主主动退出', icon: 'none', }); this.setData({ quitPopupToggle: false, }); logger.warn('quitGroup error:', imError); // 退出群组失败的相关信息 }); }, // 退出群聊的按钮显示 quitGroupAbandon() { this.setData({ quitPopupToggle: false, }); }, // 添加群成员按钮显示 addMember() { this.setData({ addPopupToggle: true, }); }, // 获取输入的用户ID binduserIDInput(e) { const id = e.detail.value; this.setData({ userID: id, }); }, // work群主动添加群成员 submit() { wx.$TUIKit.addGroupMember({ groupID: this.data.conversation.groupProfile.groupID, userIDList: [this.data.userID], }).then((imResponse) => { if (imResponse.data.successUserIDList.length > 0) { wx.showToast({ title: '添加成功', duration: 800 }); this.userID = ''; this.addMemberModalVisible = false; this.setData({ addPopupToggle: false, }); } if (imResponse.data.existedUserIDList.length > 0) { wx.showToast({ title: '该用户已在群中', duration: 800, icon: 'none' }); } }) .catch((imError) => { console.warn('addGroupMember error:', imError); // 错误信息 wx.showToast({ title: '添加失败,请确保该用户存在', duration: 800, icon: 'none' }); }); }, // 实时更新群成员个数 updateMemberCount(event) { if (event === 1) { // 1是有成员加群 wx.$TUIKit.getGroupMemberList({ groupID: this.data.conversation.groupProfile.groupID, count: this.data.getMemberCount, offset: 0, }).then((imResponse) => { this.setData({ groupMemberProfile: imResponse.data.memberList, memberCount: this.data.memberCount + 1, }); if (this.data.memberCount > 3) { this.setData({ showMore: true, }); } }); } if (event === 2) { // 2是有成员退群 wx.$TUIKit.getGroupMemberList({ groupID: this.data.conversation.groupProfile.groupID, count: this.data.getMemberCount, offset: 0, }).then((imResponse) => { this.setData({ groupMemberProfile: imResponse.data.memberList, memberCount: this.data.memberCount - 1, }); if (this.data.memberCount <= 3) { this.setData({ showMore: false, }); } }); } }, // 复制群ID copyGroupID() { wx.setClipboardData({ data: this.data.conversation.groupProfile.groupID, success() { wx.getClipboardData({ success(res) { logger.log(`| TUI-chat | tui-group | copyGroupID: ${res.data} `); }, }); }, }); }, // 获取群通话ID handleGroupCallUserIDList(e) { if (!this.data.callStatus) return; const { selectedUserIDList } = this.data ; const { userID } = e.currentTarget.dataset.value; const index = selectedUserIDList.indexOf(userID); if (index > -1) { selectedUserIDList.splice(index, 1); } else { selectedUserIDList.push(userID); } this.setData({ selectedUserIDList, showGroupCall: selectedUserIDList.length > 0, }); }, // 父组件传值 handleGroupCall() { const { selectedUserIDList, type } = this.data; const { groupID } = this.data.conversation.groupProfile; this.triggerEvent('groupCall', { selectedUserIDList, type, groupID }); this.setData({ popupToggle: false, showGroupCall: false, selectedUserIDList: [] }); }, }, });