{"remainingRequest":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/vue-loader/lib/index.js??vue-loader-options!/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/src/ui/voip/conference/ConferenceParticipantListView.vue?vue&type=script&lang=js&","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/src/ui/voip/conference/ConferenceParticipantListView.vue","mtime":1704706946155},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/babel-loader/lib/index.js","mtime":1702017034360},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/cache-loader/dist/cjs.js","mtime":1702017034107},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/vue-loader/lib/index.js","mtime":1702017029242}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

import ConferenceInviteMessageContent from "../../../wfc/av/messages/conferenceInviteMessageContent";
import Message from "../../../wfc/messages/message";
import {isElectron} from "../../../platform";
import ForwardType from "../../main/conversation/message/forward/ForwardType";
import localStorageEmitter from "../../../ipc/localStorageEmitter";
import UserCardView from "../../main/user/UserCardView";
import conferenceManager from "./conferenceManager";
import LocalStorageIpcEventType from "../../../ipc/localStorageIpcEventType";
import wfc from "../../../wfc/client/wfc";

export default {
    name: "ConferenceParticipantListView",
    props: {
        participants: {
            type: Array,
            required: true,
        },
        session: {
            type: Object,
            required: true,
        }
    },
    data() {
        return {
            conferenceManager: conferenceManager,
            selfUserId: conferenceManager.selfUserId,
            isContextMenuShow: false,
            currentParticipant: {},
        }
    },
    components: {
        UserCardView
    },
    methods: {
        invite() {
            let callSession = this.session;
            let inviteMessageContent = new ConferenceInviteMessageContent(callSession.callId, conferenceManager.conferenceInfo.owner, callSession.title, callSession.desc, callSession.startTime, callSession.audioOnly, callSession.defaultAudience, callSession.advance, callSession.pin)
            //type:audio语音，video视频，videoup视频上拉；initiator发起方姓名；organization组织名称
            inviteMessageContent.extra='{"type":"audio","initiator":"","organization":""}'
            console.log('invite', inviteMessageContent);
            let message = new Message(null, inviteMessageContent);
            this.$forwardMessage({
                forwardType: ForwardType.NORMAL,
                messages: [message]
            });
            this.showParticipantList = false;
        },

        requestChangeMode(user) {
            if (user.uid === this.selfUserInfo.uid) {
                // TODO 需要根据实际产品定义处理，这儿直接禁止
                //this.session.switchAudience(!user._isAudience);
                return;
            }
            this.$alert({
                content: user._isAudience ? `邀请${this.participantName(user)}参与互动?` : `取消${this.participantName(user)}参与互动?`,
                cancelCallback: () => {
                    // do nothing
                },
                confirmCallback: () => {
                    this.session.requestChangeMode(user.uid, !user._isAudience);
                }
            })
        },

        kickoff(user) {
            this.$alert({
                showIcon: true,
                content: `确认将${this.participantName(user)}移除会议?`,
                cancelCallback: () => {
                    // do nothing
                },
                confirmCallback: () => {
                    this.session.kickoffParticipant(user.uid)
                }
            })
        },

        participantName(user) {
            let name = '';
            if (user.groupAlias) {
                name = user.groupAlias;
            } else if (user.friendAlias) {
                name = user.friendAlias;
            } else if (user.displayName) {
                name = user.displayName;
            } else {
                name = user.name;
            }
            return name;
        },
        participantDesc(user) {
            let desc = '';
            if (user.uid === conferenceManager.selfUserId) {
                desc = "我"
                if (user.uid === conferenceManager.conferenceInfo.owner) {
                    desc += "、主持人"
                }
            } else if (user.uid === conferenceManager.conferenceInfo.owner) {
                desc = "主持人"
            } else if (user._isScreenSharing) {
                desc = '屏幕共享';
            }
            return desc;
        },

        buildParticipantContextMenu(participant) {
            let selfUid = conferenceManager.selfUserId;
            let items = [];
            if (!participant) {
                return items;
            }

            items.push({
                title: '查看用户信息',
                handler: () => {
                    this.showUserCard(participant);
                }
            })

            if (selfUid === participant.uid) {
                // TODO 临时屏蔽，现在不支持同时开视频和音频
                // if (participant._isAudience) {
                //     items.push({
                //         title: '开启音视频',
                //         handler: () => {
                //             this.$eventBus.$emit('muteAudio', false)
                //             this.$eventBus.$emit('muteVideo', false)
                //         }
                //     })
                // }

                if (participant._isAudience) {
                    if (participant._isAudioMuted) {
                        items.push({
                            title: '开启音频',
                            handler: () => {
                                this.$eventBus.$emit('muteAudio', false)
                            }
                        })
                    }

                    if (participant._isVideoMuted) {
                        items.push({
                            title: '开启视频',
                            handler: () => {
                                this.$eventBus.$emit('muteVideo', false)
                            }
                        })
                    }

                } else {
                    if (!participant._isAudioMuted) {
                        items.push({
                            title: '关闭音频',
                            handler: () => {
                                this.$eventBus.$emit('muteAudio', true)
                            },
                            styleObject: {
                                color: 'red',
                            }
                        })
                    }
                    if (!participant._isVideoMuted) {
                        items.push({
                            title: '关闭视频',
                            handler: () => {
                                this.$eventBus.$emit('muteVideo', true)
                            },
                            styleObject: {
                                color: 'red',
                            }
                        })
                    }
                    if (!participant._isVideoMuted && !participant._isAudioMuted) {
                        items.push({
                            title: '关闭音视频',
                            handler: () => {
                                this.$eventBus.$emit('muteAudio', true)
                                this.$eventBus.$emit('muteVideo', true)
                            },
                            styleObject: {
                                color: 'red',
                            }
                        })
                    }
                }
            }
            if (selfUid === conferenceManager.conferenceInfo.owner) {
                if (participant.uid !== selfUid) {
                    if (participant._isAudience || participant._isAudioMuted) {
                        items.push({
                            title: '邀请发言',
                            handler: () => {
                                conferenceManager.requestMemberMute(participant.uid, true, false)
                            },
                        })
                    } else if (!participant._isAudience && !participant._isAudioMuted) {
                        items.push({
                            title: '取消发言',
                            handler: () => {
                                conferenceManager.requestMemberMute(participant.uid, true, true)
                            },
                        })
                    }
                    if (participant._isAudience || participant._isVideoMuted) {
                        items.push({
                            title: '邀请打开摄像头',
                            handler: () => {
                                conferenceManager.requestMemberMute(participant.uid, false, false)
                            },
                        })
                    } else if (!participant._isAudience && !participant._isVideoMuted) {
                        items.push({
                            title: '关闭摄像头',
                            handler: () => {
                                conferenceManager.requestMemberMute(participant.uid, false, true)
                            },
                        })
                    }
                }
                if (participant.uid !== selfUid) {
                    items.push({
                        title: ' 移除成员',
                        handler: () => {
                            this.kickoff(participant);
                        },
                    })
                }
                if (conferenceManager.conferenceInfo.focus === participant.uid) {
                    items.push({
                        title: '取消焦点用户',
                        handler: () => {
                            conferenceManager.requestCancelFocus();
                        },
                    })
                } else {
                    items.push({
                        title: '设置为焦点用户',
                        handler: () => {
                            conferenceManager.requestFocus(participant.uid)
                        },
                    })
                }
            }
            return items;
        },

        showContextMenu(event, participant) {
            if (this.isContextMenuShow) {
                this.$refs.menu.close();
                this.isContextMenuShow = false;
                this.currentParticipant = {};
                return;
            }
            let ne = {
                type: 'contextmenu'
            }

            ne.clientX = event.clientX - this.$refs.rootContainer.parentElement.offsetLeft;
            // 160 menu width
            // 360 slider width
            if (ne.clientX + 160 > 350) {
                ne.clientX = ne.clientX - 160;
            }
            ne.clientY = event.clientY - this.$refs.rootContainer.offsetTop;
            this.$refs.menu.open(ne, participant);
            this.$refs.menu.$once('close', () => {
                this.isContextMenuShow = false;
                this.currentParticipant = {};
            })
            this.isContextMenuShow = true;
            this.currentParticipant = participant;
        }
        ,
        showUserCard(p) {
            this.$refs['userCardTippy-' + p.uid][0]._tippy.show();
        },

        requestMuteAll() {
            // TODO dialog
            let allowMemberUnmute = true;
            this.conferenceManager.requestMuteAll(true, allowMemberUnmute);
        },

        requestUnMuteAll() {
            // TODO dialog
            let unmute = true;
            this.conferenceManager.requestUnmuteAll(true, unmute);
        }
    }
}
"},null]}