{"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/main/conversation/ConversationView.vue?vue&type=template&id=c7087e22&scoped=true&","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/src/ui/main/conversation/ConversationView.vue","mtime":1703226585034},{"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:
<section>
    <div v-if="sharedConversationState.currentConversationInfo == null" class="conversation-empty-container">
        <h1>^~^</h1>
    </div>
    <div v-else class="conversation-container">
        <header>
            <div class="title-container">
                <div>
                    <h1 class="single-line" @click.stop="toggleConversationInfo">{{ conversationTitle }}</h1>
                    <p class="single-line user-online-status" @click="clickConversationDesc">{{ targetUserOnlineStateDesc }}</p>
                </div>
                <div
                    v-bind:style="{marginTop:sharedMiscState.isElectronWindowsOrLinux ?  '30px' : '0'}"
                >
                    <a v-if="sharedMiscState.isElectron" href="#">
                        <i class="icon-ion-pin"
                           style="display: inline-block"
                           v-bind:class="{active : isWindowAlwaysTop}"
                           @click="setWindowAlwaysTop"
                        />
                    </a>
                    <a href="#">
                        <i class="icon-ion-ios-settings-strong"
                           style="display: inline-block"
                           ref="setting"
                           v-bind:class="{active : showConversationInfo}"
                           @click="toggleConversationInfo"
                        />
                    </a>
                </div>
            </div>
        </header>
        <div ref="conversationContentContainer" class="conversation-content-container"
             @dragover="dragEvent($event, 'dragover')"
             @dragleave="dragEvent($event, 'dragleave')"
             @dragenter="dragEvent($event,'dragenter')"
             @drop="dragEvent($event, 'drop')"
             :dummy_just_for_reactive="currentVoiceMessage"
        >
            <div v-if="ongoingCalls && ongoingCalls.length > 0" class="ongoing-call-container">
                <div v-for="(value, index) in ongoingCalls" :key="index" class="ongoing-call-item">
                    <p>{{ value.messageContent.digest(value) }}</p>
                    <button @click="joinMultiCall(value)">加入</button>
                </div>
            </div>
            <div v-show="dragAndDropEnterCount > 0" class="drag-drop-container">
                <div class="drag-drop">
                    <p>{{ $t('conversation.drag_to_send_to', [conversationTitle]) }}</p>
                </div>
            </div>
            <div ref="conversationMessageList" class="conversation-message-list" v-on:scroll="onScroll"
                 infinite-wrapper>
                <infinite-loading :identifier="loadingIdentifier" :distance="10" :force-use-infinite-wrapper="true" direction="top"
                                  @infinite="infiniteHandler">
                    <!--            <template slot="spinner">加载中...</template>-->
                    <template slot="no-more">{{ $t('conversation.no_more_message') }}</template>
                    <template slot="no-results">{{ $t('conversation.all_message_load') }}</template>
                </infinite-loading>
                <div v-for="(message) in sharedConversationState.currentConversationMessageList"
                        :key="message.messageId">
                        <!--todo 不同的消息类型 notification in out-->

                        <NotificationMessageContentView :message="message" v-if="isNotificationMessage(message)"/>
                        <RecallNotificationMessageContentView :message="message" v-else-if="isRecallNotificationMessage(message)"/>
                        <ContextableNotificationMessageContentContainerView
                            v-else-if="isContextableNotificationMessage(message)"
                            @click.native.capture="sharedConversationState.enableMessageMultiSelection? clickMessageItem($event, message) : null"
                            :message="message"
                        />
                        <NormalOutMessageContentView
                            @click.native.capture="sharedConversationState.enableMessageMultiSelection? clickMessageItem($event, message) : null"
                            :message="message"
                            v-else-if="message.direction === 0"/>
                        <NormalInMessageContentView
                            @click.native.capture="sharedConversationState.enableMessageMultiSelection ? clickMessageItem($event, message) : null"
                            :message="message"
                            v-else/>
                </div>
            </div>
            <div v-if="sharedConversationState.inputtingUser" class="inputting-container">
                <img class="avatar" :src="sharedConversationState.inputtingUser.portrait"/>
                <ScaleLoader :color="'#d2d2d2'" :height="'15px'" :width="'3px'"/>
            </div>
            <div v-if="unreadMessageCount > 0" class="unread-count-tip-container" @click="showUnreadMessage">
                {{ '' + this.unreadMessageCount + '条新消息' }}
            </div>
            <div v-show="!sharedConversationState.enableMessageMultiSelection && !sharedContactState.showChannelMenu" v-on:mousedown="dragStart"
                 class="divider-handler"></div>
            <MessageInputView :conversationInfo="sharedConversationState.currentConversationInfo"
                              v-show="!sharedConversationState.enableMessageMultiSelection"
                              :input-options="inputOptions"
                              :muted="muted"
                              ref="messageInputView"/>
            <MultiSelectActionView v-show="sharedConversationState.enableMessageMultiSelection"/>
            <SingleConversationInfoView
                v-if="showConversationInfo &&  sharedConversationState.currentConversationInfo.conversation.type === 0"
                v-click-outside="hideConversationInfo"
                :conversation-info="sharedConversationState.currentConversationInfo"
                v-bind:class="{ active: showConversationInfo }"
                class="conversation-info-container"
            />
            <GroupConversationInfoView
                v-if="showConversationInfo &&  sharedConversationState.currentConversationInfo.conversation.type === 1"
                v-click-outside="hideConversationInfo"
                :conversation-info="sharedConversationState.currentConversationInfo"
                v-bind:class="{ active: showConversationInfo }"
                class="conversation-info-container"
            />

            <SecretConversationInfoView
                v-if="showConversationInfo &&  sharedConversationState.currentConversationInfo.conversation.type === 5"
                v-click-outside="hideConversationInfo"
                :conversation-info="sharedConversationState.currentConversationInfo"
                v-bind:class="{ active: showConversationInfo }"
                class="conversation-info-container"
            />

            <ChannelConversationInfoView
                v-if="showConversationInfo &&  sharedConversationState.currentConversationInfo.conversation.type === 3"
                v-click-outside="hideConversationInfo"
                :conversation-info="sharedConversationState.currentConversationInfo"
                v-bind:class="{ active: showConversationInfo }"
                class="conversation-info-container"
            />

            <vue-context ref="menu" v-slot="{data:message}" :close-on-scroll="true" v-on:close="onMenuClose">
                <!--          更多menu item-->
                <li v-if="isCopyable(message)">
                    <a @click.prevent="copy(message)">{{ $t('common.copy') }}</a>
                </li>
                <li v-if="isDownloadable(message)">
                    <a @click.prevent="download(message)">{{ $t('common.save') }}</a>
                </li>
                <li>
                    <a @click.prevent="delMessage(message)">{{ $t('common.delete') }}</a>
                </li>
                <li v-if="isForwardable(message)">
                    <a @click.prevent="_forward(message)">{{ $t('common.forward') }}</a>
                </li>
                <li v-if="isFavable(message)">
                    <a @click.prevent="favMessage(message)">{{ $t('common.fav') }}</a>
                </li>
                <li v-if="isQuotable(message)">
                    <a @click.prevent="quoteMessage(message)">{{ $t('common.quote') }}</a>
                </li>
                <li>
                    <a @click.prevent="multiSelect(message)">{{ $t('common.multi_select') }}</a>
                </li>
                <li v-if="isRecallable(message)">
                    <a @click.prevent="recallMessage(message)">{{ $t('common.recall') }}</a>
                </li>
                <li v-if="isCancelable(message)">
                    <a @click.prevent="cancelMessage(message)">{{ $t('common.cancel_send') }}</a>
                </li>
                <li v-if="isLocalFile(message)">
                    <a @click.prevent="openFile(message)">{{ $t('common.open') }}</a>
                </li>
                <li v-if="isLocalFile(message)">
                    <a @click.prevent="openDir(message)">{{ $t('common.open_dir') }}</a>
                </li>
            </vue-context>
            <vue-context ref="messageSenderContextMenu" v-slot="{data: message}" :close-on-scroll="true" v-on:close="onMessageSenderContextMenuClose">
                <!--          更多menu item，比如添加到通讯录等-->
                <li>
                    <a @click.prevent="mentionMessageSender(message)">{{ mentionMessageSenderTitle(message) }}</a>
                </li>
            </vue-context>
        </div>
    </div>
</section>
"},null]}