{"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/Conference.vue?vue&type=template&id=14860ee2&scoped=true&","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/src/ui/voip/conference/Conference.vue","mtime":1703127644290},{"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/loaders/templateLoader.js","mtime":1702017029951},{"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:
<div class="flex-column flex-align-center flex-justify-center voip-container" style="width: 100%; height: 100%" ref="rootContainer">
    <div v-if="sharedMiscState.isElectron" ref="notClickThroughArea">
        <ElectronWindowsControlButtonView style="position: absolute; top: 0; left: 0; width: 100%; height: 30px; background: white"
                                          :title="'野火会议'"
                                          :macos="!sharedMiscState.isElectronWindowsOrLinux"/>
        <ScreenShareControlView v-if="session && session.screenSharing" type="conference"/>
        <h1 style="display: none">Voip-Conference 运行在新的window，和主窗口数据是隔离的！！</h1>
    </div>
    <div v-if="endReason !== undefined && endReason === 4" @click="rejoinConference" class="rejoin-container">
        会议断开，点击重新加入
    </div>
    <div v-if="session" class="main-slider-container"
         v-bind:style="{display: session.screenSharing && sharedMiscState.isElectron ? 'none' : 'flex'}">
        <div class="main">
            <header style="background: white; height: 20px; display: flex; justify-content: space-between">
                <a href="#">
                    <i class="icon-ion-information" style="padding: 0 10px"
                       id="info-icon"
                       v-bind:class="{active:showConferenceSimpleInfoView}"
                       @click="showConferenceSimpleInfoView = !showConferenceSimpleInfoView"/>
                </a>
                <p style="flex: 1"></p>
                <p style="padding-right: 10px">{{ duration }}</p>
                <div>
                    <a v-if="!audioOnly" href="#">
                        <i class="icon-ion-grid" style="padding: 0 10px"
                           id="grid-icon"
                           v-bind:class="{active:showChooseLayoutView}"
                           @click="showChooseLayoutView = !showChooseLayoutView">宫格布局</i>
                    </a>
                    <!--                        TODO 条件显示，展示聊天界面，或者参与者列表界面时，才展示-->
                    <a href="#" v-if="showSlider">
                        <i :class="showSlider? 'icon-ion-arrow-left-b' : 'icon-ion-arrow-right-b'" style="padding: 0 10px" @click="toggleSliderView"></i>
                    </a>
                </div>
            </header>
            <div v-if="showConferenceSimpleInfoView"
                 v-click-outside="hideConferenceSimpleInfoView"
                 style="position: absolute; left: 10px; top: 50px; z-index: 1000">
                <ConferenceSimpleInfoView
                    :session="session"
                />
            </div>
            <div v-if="showChooseLayoutView"
                 v-click-outside="hideChooseLayoutView"
                 style="position: absolute; right: 10px; top: 50px; z-index: 1000">
                <ChooseConferenceLayoutView
                    :current-layout="computedCurrentLayout"
                    :session="session"/>
            </div>
            <div style="position: absolute; left: 10px; bottom: 80px; width: 300px; max-height: 300px; overflow: hidden; background: transparent; z-index: 1000">
                <ConferenceConversationFloatingView
                    :session="session"
                />
            </div>
            <div class="conference-main-content-container">
                <!--main-->
                <!--video-->
                <div v-if="!audioOnly" style="width: 100%; height: 100%">
                    <i v-if="computedCurrentLayout=== 0 && currentGridPageIndex > 0" style="position: absolute; top: 50%; left: 0; color: #c8cacc; z-index: 1000; font-size: 40px; padding: 0 10px" class="icon-ion-arrow-left-c"
                       @click="prePage"></i>
                    <i v-if="computedCurrentLayout=== 0 && currentGridPageIndex < gridPageCount - 1" style="position: absolute; top: 50%; right: 0; color: #c8cacc; z-index: 1000; font-size: 40px; padding: 0 10px" class="icon-ion-arrow-right-c"
                       @click="nextPage"></i>
                    <!--                    宫格布局-->
                    <section v-if="computedCurrentLayout=== 0" class="content-container grid video">
                        <!--participants include self-->
                        <ConferenceParticipantVideoView v-for="(participant) in currentPageParticipants"
                                                        :key="participant.uid + '-' + participant._isScreenSharing"
                                                        :participant="participant"
                                                        :session="session">
                        </ConferenceParticipantVideoView>
                    </section>

                    <!--                    演讲者布局-->
                    <section v-else class="content-container focus video">
                        <div :style="{width: hideFocusLayoutParticipantListVideoView ? '100%' : 'calc(100% - 200px)', height: '100%', position: 'relative'}">
                            <video v-if=" computedFocusVideoParticipant && !computedFocusVideoParticipant._isAudience && (!computedFocusVideoParticipant._isVideoMuted || computedFocusVideoParticipant._isScreenSharing) && computedFocusVideoParticipant._stream"
                                   v-bind:style="{objectFit:computedFocusVideoParticipant._isScreenSharing ? 'contain' : 'fit'}"
                                   style="width: 100%; height: 100%"
                                   :srcObject.prop="computedFocusVideoParticipant._screenShareStream ? computedFocusVideoParticipant._screenShareStream : computedFocusVideoParticipant._stream"
                                   :muted="computedFocusVideoParticipant.uid === selfUserInfo.uid"
                                   playsInline
                                   autoPlay/>
                            <div @click="toggleParticipantListVideoView" style="position: absolute; top: 50%; right: 0; color: #c8cacc; z-index: 1000; font-size: 40px">
                                <i :class="hideFocusLayoutParticipantListVideoView ? 'icon-ion-arrow-left-b' : 'icon-ion-arrow-right-b'"></i>
                            </div>
                        </div>
                        <div v-show="!hideFocusLayoutParticipantListVideoView" class="focus-mode-participant-list-container">
                            <!--participants include self-->
                            <ConferenceParticipantVideoView v-for="(participant) in participantUserInfos"
                                                            :key="participant.uid + '-' + participant._isScreenSharing"
                                                            :participant="participant"
                                                            :session="session">
                            </ConferenceParticipantVideoView>
                        </div>
                    </section>
                </div>
                <!--audio-->
                <div v-else style="width: 100%; height: 100%">
                    <div
                        style="background: white; height: 50px; display: flex; justify-content: center; align-items: center">
                        <div
                            style="background: #daeafe; width: 300px; height: 40px; padding: 0 5px; border-radius: 3px; display: flex; flex-direction: column; justify-content: center">
                            <p class="single-line"> {{ '正在讲话: ' + speakingUserName }}</p>
                        </div>
                    </div>
                    <section class="content-container audio">
                        <!--participants-->
                        <div v-for="(participant) in participantUserInfos"
                             :key="participant.uid"
                             class="participant-audio-item">
                            <video v-if="audioOnly && participant._stream && !participant._isVideoMuted"
                                   class="hidden-video"
                                   :srcObject.prop="participant._stream"
                                   :muted="participant.uid === selfUserInfo.uid"
                                   playsInline autoPlay/>
                            <!-- video 标签不能播放没有视频的流 -->
                            <audio v-else-if="audioOnly && participant._stream && participant._isVideoMuted"
                                   class="hidden-video"
                                   :srcObject.prop="participant._stream"
                                   :ref="participant.uid + '-audio'"
                                   :muted="participant.uid === selfUserInfo.uid"
                                   playsInline autoPlay/>
                            <div style="position: relative">
                                <img class="avatar"
                                     v-bind:class="{highlight:participant._volume > 0}"
                                     :src="participant.portrait" :alt="participant">
                                <i v-if="participant._isHost" class="indicator icon-ion-person" style="background: #FD802E"></i>
                                <i v-if="participant._isAudience" class="indicator icon-ion-ios-mic-off" style="color: red"></i>
                            </div>
                            <p class="single-line">{{ userName(participant) }}</p>
                        </div>
                    </section>
                </div>
                <!--actions-->
                <footer>
                    <div class="duration-action-container">
                        <p v-if="false">{{ duration }}</p>
                        <div class="action-container">
                            <div class="action">
                                <img v-if="!session.audience && !session.audioMuted" @click="muteAudio" class="action-img"
                                     src='@/assets/images/av_conference_audio.png'/>
                                <img v-else @click="muteAudio" class="action-img"
                                     src='@/assets/images/av_conference_audio_mute.png'/>
                                <p>静音</p>
                            </div>
                            <div class="action"
                                 v-if="!session.screenSharing">
                                <img v-if="!session.audience && !session.videoMuted" @click="muteVideo" class="action-img"
                                     src='@/assets/images/av_conference_video.png'/>
                                <img v-else @click="muteVideo" class="action-img"
                                     src='@/assets/images/av_conference_video_mute.png'/>
                                <p>视频</p>
                            </div>
                            <div class="action">
                                <img v-if="!session.screenSharing" @click="screenShare"
                                     class="action-img"
                                     src='@/assets/images/av_conference_screen_sharing.png'/>
                                <img v-else @click="screenShare" class="action-img"
                                     src='@/assets/images/av_conference_screen_sharing_hover.png'/>
                                <p class="single-line">共享屏幕</p>
                            </div>
                            <div class="action" @click="chat">
                                <i class="icon-ion-ios-chatboxes"
                                   style="width: 40px; height: 40px; font-size: 40px; color: black"
                                   v-bind:style="{color: showConversationView ? 'white' : 'black'}"/>
                                <p>聊天</p>
                            </div>
                            <div v-if="selfUserInfo.uid !== conferenceManager.conferenceInfo.owner" class="action">
                                <img v-if="!conferenceManager.isHandUp" @click="handup"
                                     class="action-img"
                                     src='@/assets/images/av_conference_handup.png'/>
                                <img v-else @click="handup" class="action-img"
                                     src='@/assets/images/av_conference_handup_hover.png'/>
                                <p class="single-line">举手</p>
                            </div>
                            <div class="action">
                                <img @click.stop="members" class="action-img"
                                     v-bind:style="{filter: showConferenceManageView ? 'invert(100%)' : 'none'}"
                                     src='@/assets/images/av_conference_members.png'/>
                                <p>管理</p>
                            </div>
                            <div class="action">
                                <img @click="hangup" class="action-img"
                                     src='@/assets/images/av_conference_end_call.png'/>
                                <p>结束</p>
                            </div>
                        </div>
                    </div>
                </footer>
            </div>

        </div>
        <div class="slider">
            <div class="title" style="display: none">
                TODO
            </div>
            <ConferenceManageView
                v-if="showConferenceManageView"
                v-bind:class="{ active: showConferenceManageView}"
                :participants="participantUserInfos"
                :session="session"
            />
            <ConversationView v-if="showConversationView && sharedMiscState.isElectron"
                              class="conversation-view"
                              style="height: 100%"
                              :title="conferenceManager.conferenceInfo.conferenceTitle"
                              :input-options="{disableScreenShot:true, disableHistory:true, disableVoip:true, disableChannelMenu:true}"/>
        </div>
    </div>
</div>
"},null]}