{"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=script&lang=js&","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/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 SingleConversationInfoView from "../../main/conversation/SingleConversationInfoView";
import SecretConversationInfoView from "../../main/conversation/SecretConversationInfoView";
import GroupConversationInfoView from "../../main/conversation/GroupConversationInfoView";
import MessageInputView from "../../main/conversation/MessageInputView";
import ClickOutside from 'vue-click-outside'
import NormalOutMessageContentView from "../../main/conversation/message/NormalOutMessageContentContainerView";
import NormalInMessageContentView from "../../main/conversation/message/NormalInMessageContentContainerView";
import NotificationMessageContentView from "../../main/conversation/message/NotificationMessageContentView";
import RecallNotificationMessageContentView from "../../main/conversation/message/RecallNotificationMessageContentView";
import NotificationMessageContent from "../../../wfc/messages/notification/notificationMessageContent";
import TextMessageContent from "../../../wfc/messages/textMessageContent";
import store from "../../../store";
import wfc from "../../../wfc/client/wfc";
import {numberValue} from "../../../wfc/util/longUtil";
import InfiniteLoading from 'vue-infinite-loading';
import MultiSelectActionView from "../../main/conversation/MessageMultiSelectActionView";
import ScaleLoader from 'vue-spinner/src/ScaleLoader'
import ForwardType from "../../main/conversation/message/forward/ForwardType";
import {fs, isElectron, shell} from "../../../platform";
import FileMessageContent from "../../../wfc/messages/fileMessageContent";
import ImageMessageContent from "../../../wfc/messages/imageMessageContent";
import {copyImg, copyText} from "../../util/clipboard";
import Message from "../../../wfc/messages/message";
import {downloadFile} from "../../../platformHelper";
import VideoMessageContent from "../../../wfc/messages/videoMessageContent";
import localStorageEmitter from "../../../ipc/localStorageEmitter";
import SoundMessageContent from "../../../wfc/messages/soundMessageContent";
import MessageContentType from "../../../wfc/messages/messageContentType";
import BenzAMRRecorder from "benz-amr-recorder";
import ConversationType from "../../../wfc/model/conversationType";
import GroupMemberType from "../../../wfc/model/groupMemberType";
import CompositeMessageContent from "../../../wfc/messages/compositeMessageContent";
import EventType from "../../../wfc/client/wfcEvent";
import MultiCallOngoingMessageContent from "../../../wfc/av/messages/multiCallOngoingMessageContent";
import JoinCallRequestMessageContent from "../../../wfc/av/messages/joinCallRequestMessageContent";
import RichNotificationMessageContent from "../../../wfc/messages/notification/richNotificationMessageContent";
import MessageStatus from "../../../wfc/messages/messageStatus";
import MediaMessageContent from "../../../wfc/messages/mediaMessageContent";
import ArticlesMessageContent from "../../../wfc/messages/articlesMessageContent";
import ContextableNotificationMessageContentContainerView from "./message/ContextableNotificationMessageContentContainerView";
import ChannelConversationInfoView from "./ChannelConversationInfoView";
import FriendRequestView from "../contact/FriendRequestView";
import {currentWindow, ipcRenderer} from "../../../platform";
import appServerApi from "../../../api/appServerApi";
import Config from "../../../config";
import IPCEventType from "../../../ipcEventType";
import LocalStorageIpcEventType from "../../../ipc/localStorageIpcEventType";
import {imageThumbnail} from "../../util/imageUtil";
import GroupInfo from "../../../wfc/model/groupInfo";

var amr;
export default {
    components: {
        ChannelConversationInfoView,
        ContextableNotificationMessageContentContainerView,
        MultiSelectActionView,
        NotificationMessageContentView,
        RecallNotificationMessageContentView,
        NormalInMessageContentView,
        NormalOutMessageContentView,
        MessageInputView,
        GroupConversationInfoView,
        SingleConversationInfoView,
        SecretConversationInfoView,
        InfiniteLoading,
        ScaleLoader,
    },
    props: {
        inputOptions: {
            type: Object,
            required: false,
        },
        title: {
            type: String,
            required: false,
        }
    },
    data() {
        return {
            conversationInfo: null,
            showConversationInfo: false,
            sharedConversationState: store.state.conversation,
            sharedContactState: store.state.contact,
            sharedPickState: store.state.pick,
            sharedMiscState: store.state.misc,
            isHandlerDragging: false,

            savedMessageListViewHeight: -1,
            saveMessageListViewFlexGrow: -1,

            dragAndDropEnterCount: 0,
            // FIXME 选中一个会话，然后切换到其他page，比如联系人，这时该会话收到新消息或发送消息，会导致新收到/发送的消息的界面错乱，尚不知道原因，但这么做能解决。
            fixTippy: true,
            ongoingCalls: [],
            ongoingCallTimer: 0,
            messageInputViewResized: false,
            unreadMessageCount: 0,
            isWindowAlwaysTop: currentWindow && currentWindow.isAlwaysOnTop(),
        };
    },

    activated() {
        this.fixTippy = true;
    },

    deactivated() {
        this.fixTippy = false;
    },

    methods: {
        async dragEvent(e, v) {
            if (v === 'dragenter') {
                this.dragAndDropEnterCount++;
            } else if (v === 'dragleave') {
                this.dragAndDropEnterCount--;
            } else if (v === 'drop') {
                this.dragAndDropEnterCount--;
                let isFile;
                if (e.dataTransfer.items && e.dataTransfer.items.length > 0) {
                    if (e.dataTransfer.items[0].kind === 'file') {
                        if (typeof (e.dataTransfer.items[0].webkitGetAsEntry) == "function") {
                            isFile = e.dataTransfer.items[0].webkitGetAsEntry().isFile;
                        } else if (typeof (e.dataTransfer.items[0].getAsEntry) == "function") {
                            isFile = e.dataTransfer.items[0].getAsEntry().isFile;
                        }

                        if (!isFile) {
                            this.$notify({
                                // title: '不支持',
                                text: this.$t('conversation.not_support_send_folder'),
                                type: 'warn'
                            });
                            return true;
                        }
                    }
                }

                let length = e.dataTransfer.files.length;
                if (length > 0 && length <= 5) {
                    for (let i = 0; i < length; i++) {
                        this.$eventBus.$emit('uploadFile', e.dataTransfer.files[i])
                        store.sendFile(this.sharedConversationState.currentConversationInfo.conversation, e.dataTransfer.files[i]);
                    }
                } else if (length > 5) {
                    this.$notify({
                        // title: '大文件提示',
                        text: this.$t('conversation.drag_to_send_limit_tip'),
                        type: 'warn'
                    });
                }

                let dragUrl = e.dataTransfer.getData('URL');
                if (dragUrl) {
                    // 根据后缀判断类型
                    if (dragUrl.endsWith('.png') || dragUrl.endsWith('.jpg') || dragUrl.endsWith('jpeg')) {
                        //constructor(fileOrLocalPath, remotePath, thumbnail) {
                        let {thumbnail: it, width: iw, height: ih} = await imageThumbnail(dragUrl);
                        it = it ? it : Config.DEFAULT_THUMBNAIL_URL;
                        if (it.length > 15 * 1024) {
                            it = Config.DEFAULT_THUMBNAIL_URL;
                        }
                        let content = new ImageMessageContent(null, dragUrl, it.split(',')[1]);
                        content.imageWidth = iw;
                        content.imageHeight = ih;
                        wfc.sendConversationMessage(this.conversationInfo.conversation, content);
                    } else {
                        // TODO blob uri
                    }
                }
                console.log('drag Url', dragUrl);
            } else if (v === 'dragover') {
                // TODO 可以判断一些，不支持的，dropEffect 置为 none
                // 支持那些类型的数据 drop，参考上面 drop 部分的处理
                // If not st as 'copy', electron will open the drop file
                e.dataTransfer.dropEffect = 'copy';
            }
        },
        toggleConversationInfo() {
            this.showConversationInfo = !this.showConversationInfo;
        },

        setWindowAlwaysTop() {
            this.isWindowAlwaysTop = !currentWindow.isAlwaysOnTop();
            currentWindow.setAlwaysOnTop(this.isWindowAlwaysTop)
        },

        clickConversationDesc() {
            if (this.conversationInfo.conversation.type === ConversationType.Single && !wfc.isMyFriend(this.conversationInfo.conversation.target)) {
                this.$modal.show(
                    FriendRequestView,
                    {
                        userInfo: this.conversationInfo.conversation._target,
                    },
                    {
                        name: 'friend-request-modal',
                        width: 600,
                        height: 250,
                        clickToClose: false,
                    }, {})
            }
        },

        toggleMessageMultiSelectionActionView(message) {
            if (!this.sharedConversationState.enableMessageMultiSelection) {
                this.saveMessageListViewFlexGrow = this.$refs['conversationMessageList'].style.flexGrow;
                this.savedMessageListViewHeight = this.$refs['conversationMessageList'].style.height;
                this.$refs['conversationMessageList'].style.flexGrow = 1;
            } else {
                if (this.saveMessageListViewFlexGrow !== -1 && this.savedMessageListViewHeight !== -1) {
                    this.$refs['conversationMessageList'].style.height = this.savedMessageListViewHeight;
                    this.$refs['conversationMessageList'].style.flexGrow = this.saveMessageListViewFlexGrow;
                }
            }
            this.sharedPickState.messages.forEach(m => console.log(m.messageId));
            store.toggleMessageMultiSelection(message);
        },

        clickMessageItem(event, message) {
            if (message.messageContent instanceof NotificationMessageContent) {
                return;
            }
            if (this.sharedConversationState.enableMessageMultiSelection) {
                store.selectOrDeselectMessage(message);
                event.stopPropagation();
            }
        },

        hideConversationInfo() {
            // TODO
            // 是否在创建群聊，或者是在查看会话参与者信息
            this.showConversationInfo && (this.showConversationInfo = false);
        },

        isNotificationMessage(message) {
            return message && message.messageContent instanceof NotificationMessageContent
                && message.messageContent.type !== MessageContentType.RecallMessage_Notification
                && message.messageContent.type !== MessageContentType.Rich_Notification;
        },

        isContextableNotificationMessage(message) {
            return message && (message.messageContent instanceof RichNotificationMessageContent || message.messageContent instanceof ArticlesMessageContent);
        },

        isRecallNotificationMessage(message) {
            return message && message.messageContent.type === MessageContentType.RecallMessage_Notification;
        },

        isCancelable(message) {
            return message && message.messageContent instanceof MediaMessageContent && message.status === MessageStatus.Sending;
        },

        reedit(message) {
            this.$refs.messageInputView.insertText(message.messageContent.originalSearchableContent);
        },

        onScroll(e) {
            // hide tippy userCard
            for (const popper of document.querySelectorAll('.tippy-popper')) {
                const instance = popper._tippy;
                if (instance.state.isVisible) {
                    instance.hide();
                }
            }
            // hide message context menu
            this.$refs.menu && this.$refs.menu.close();

            // 当用户往上滑动一段距离之后，收到新消息，不自动滚到到最后
            if (e.target.scrollHeight > e.target.clientHeight + e.target.scrollTop + e.target.clientHeight / 2) {
                store.setShouldAutoScrollToBottom(false)
            } else {
                store.setShouldAutoScrollToBottom(true)
                this.clearConversationUnreadStatus();
            }
        },

        dragStart() {
            if (this.muted) {
                return;
            }
            this.isHandlerDragging = true;
            console.log('drag start')
        },

        drag(e) {
            // Don't do anything if dragging flag is false
            if (!this.isHandlerDragging) {
                return false;
            }

            // Get offset
            let containerOffsetTop = this.$refs['conversationContentContainer'].offsetTop;

            // Get x-coordinate of pointer relative to container
            let pointerRelativeYpos = e.clientY - containerOffsetTop;

            // Arbitrary minimum width set on box A, otherwise its inner content will collapse to width of 0
            let boxAminHeight = 150;

            // Resize box A
            // * 8px is the left/right spacing between .handler and its inner pseudo-element
            // * Set flex-grow to 0 to prevent it from growing
            this.$refs['conversationMessageList'].style.height = (Math.max(boxAminHeight, pointerRelativeYpos)) + 'px';
            this.$refs['conversationMessageList'].style.flexGrow = 0;
            this.messageInputViewResized = true;

        },

        dragEnd() {
            this.isHandlerDragging = false;
        },

        onMenuClose() {
            this.$emit('contextMenuClosed')
        },
        onMessageSenderContextMenuClose() {
            console.log('onMessageSenderContextMenuClose')
        },

        // message context menu
        isCopyable(message) {
            return message
                && (message.messageContent instanceof TextMessageContent
                    || message.messageContent instanceof ImageMessageContent
                    || ((message.messageContent instanceof VideoMessageContent
                        || message.messageContent instanceof FileMessageContent) && this.isLocalFile(message))
                );
        },
        isDownloadable(message) {
            return message && (message.messageContent instanceof ImageMessageContent
                || message.messageContent instanceof FileMessageContent
                || message.messageContent instanceof VideoMessageContent);
        },

        isForwardable(message) {
            if (message && message.messageContent instanceof SoundMessageContent) {
                return false;
            }
            return true;
        },

        isFavable(message) {
            if (!message) {
                return false;
            }
            return [MessageContentType.VOIP_CONTENT_TYPE_START,
                MessageContentType.CONFERENCE_CONTENT_TYPE_INVITE].indexOf(message.messageContent.type) <= -1;
        },

        isRecallable(message) {
            if (message) {
                if (message.conversation.type === ConversationType.Group) {
                    let groupInfo = wfc.getGroupInfo(message.conversation.target);
                    let selfUserId = wfc.getUserId();
                    if (groupInfo && groupInfo.owner === selfUserId) {
                        return true;
                    }

                    let fromGroupMember = wfc.getGroupMember(message.conversation.target, message.from);
                    let groupMember = wfc.getGroupMember(message.conversation.target, selfUserId);
                    if (!fromGroupMember || !groupMember){
                        return false;
                    }
                    if (groupMember.type === GroupMemberType.Manager && [GroupMemberType.Manager, GroupMemberType.Owner].indexOf(fromGroupMember.type) === -1) {
                        return true;
                    }
                }
                let delta = wfc.getServerDeltaTime();
                let now = new Date().getTime();
                if (message.direction === 0 && now - (numberValue(message.timestamp) - delta) < 60 * 1000) {
                    return true;
                }
            }
            return false;
        },

        isLocalFile(message) {
            if (message && isElectron()) {
                let media = message.messageContent;
                let localPath = media.localPath;
                if (localPath) {
                    return fs.existsSync(localPath);
                }
            }
            return false;
        },

        isQuotable(message) {
            if (!message) {
                return false;
            }
            return [MessageContentType.VOIP_CONTENT_TYPE_START,
                MessageContentType.Voice,
                MessageContentType.Video,
                MessageContentType.Composite_Message,
                MessageContentType.Articles,
                MessageContentType.CONFERENCE_CONTENT_TYPE_INVITE].indexOf(message.messageContent.type) <= -1;
        },

        copy(message) {
            let content = message.messageContent;
            if (content instanceof TextMessageContent) {
                let selectedText = window.getSelection().toString()
                if (selectedText) {
                    copyText(selectedText);
                } else {
                    copyText(content.content)
                }
            } else if (content instanceof ImageMessageContent) {
                copyImg(content.remotePath)
            } else if (content instanceof MediaMessageContent) {
                if (isElectron()) {
                    ipcRenderer.send(IPCEventType.FILE_COPY, {path: content.localPath});
                }
            }
        },
        download(message) {
            if (!store.isDownloadingMessage(message.messageId)) {
                downloadFile(message)
                store.addDownloadingMessage(message.messageId)
            } else {
                // TODO toast 下载中
                console.log('file isDownloading')
            }
        },

        openFile(message) {
            let file = message.messageContent;
            shell.openItem(file.localPath);
        },

        openDir(message) {
            let file = message.messageContent;
            shell.showItemInFolder(file.localPath);
        },

        recallMessage(message) {
            wfc.recallMessage(message.messageUid, null, null);
        },
        cancelMessage(message) {
            let canceled = wfc.cancelSendingMessage(message.messageId);
            if (!canceled) {
                this.$notify({
                    text: '取消失败',
                    type: 'warn',
                });
            }
        },

        delMessage(message) {
            this.$alert({
                title: ' 删除消息',
                content: '确定删除消息？',
                confirmText: '本地删除',
                cancelText: '远程删除',
                cancelCallback: () => {
                    wfc.deleteRemoteMessageByUid(message.messageUid, null, null)
                },
                confirmCallback: () => {
                    wfc.deleteMessage(message.messageId);
                }
            })
        },

        forward(message) {
            return this.$forwardMessage({
                forwardType: ForwardType.NORMAL,
                messages: [message],
            });
        },

        _forward(message) {
            this.forward(message).catch((reason) => {
                // do nothing
                console.log('foward errro', reason)
            });
        },

        quoteMessage(message) {
            store.quoteMessage(message);
        },

        // call from child
        favMessages(messages) {
            console.log('fav messages');
            let compositeMessageContent = new CompositeMessageContent();
            let title = '';
            let msgConversation = messages[0].conversation;
            if (msgConversation.type === ConversationType.Single) {
                let users = store.getUserInfos([wfc.getUserId(), msgConversation.target], '');
                title = users[0]._displayName + '和' + users[1]._displayName + '的聊天记录';
            } else {
                title = '群的聊天记录';
            }
            compositeMessageContent.title = title;
            compositeMessageContent.messages = messages;

            let message = new Message(msgConversation, compositeMessageContent);
            message.from = wfc.getUserId();
            this.favMessage(message);
        },

        favMessage(message) {
            appServerApi.favMessage(message)
                .then(data => {
                    this.$notify({
                        // title: '收藏成功',
                        text: '收藏成功',
                        type: 'info'
                    });
                })
                .catch(err => {
                    console.log('fav error', err)
                    this.$notify({
                        // title: '收藏失败',
                        text: '收藏失败',
                        type: 'error'
                    });
                })
        },

        multiSelect(message) {
            this.toggleMessageMultiSelectionActionView(message);
        },

        infiniteHandler($state) {
            console.log('to load more message');
            store.loadConversationHistoryMessages(() => {
                console.log('loaded')
                $state.loaded();
            }, () => {
                console.log('complete')
                $state.complete()
            });
        },

        playVoice(message) {
            if (amr) {
                amr.stop();
            }
            amr = new BenzAMRRecorder();
            let voice = message.messageContent;
            amr.initWithUrl(voice.remotePath).then(() => {
                message._isPlaying = true;
                amr.play();
            });
            amr.onEnded(() => {
                message._isPlaying = false;
                store.playVoice(null)
                if (message.status === MessageStatus.Unread) {
                    wfc.updateMessageStatus(message.messageId, MessageStatus.Played);
                }
            })
        },
        mentionMessageSenderTitle(message) {
            if (!message) {
                return ''
            }
            let displayName = wfc.getGroupMemberDisplayName(message.conversation.target, message.from);
            return '@' + displayName;
        },

        mentionMessageSender(message) {
            this.$refs.messageInputView.mention(message.conversation.target, message.from);
        },

        onReceiveMessage(message, hasMore) {
            if (this.conversationInfo && this.conversationInfo.conversation.equal(message.conversation)
                && message.messageContent instanceof MultiCallOngoingMessageContent
                && Config.ENABLE_MULTI_CALL_AUTO_JOIN
            ) {
                // 自己是不是已经在通话中
                console.log('MultiCallOngoingMessageContent', message.messageContent)
                if (message.messageContent.targets.indexOf(wfc.getUserId()) >= 0) {
                    return;
                }
                let index = this.ongoingCalls.findIndex(call => call.messageContent.callId === message.messageContent.callId);
                if (index > -1) {
                    this.ongoingCalls[index] = message;
                } else {
                    this.ongoingCalls.push(message);
                }
                if (!this.ongoingCallTimer) {
                    this.ongoingCallTimer = setInterval(() => {
                        this.ongoingCalls = this.ongoingCalls.filter(call => {
                            return (new Date().getTime() - (numberValue(call.timestamp) - numberValue(wfc.getServerDeltaTime()))) < 3 * 1000;
                        })
                        if (this.ongoingCalls.length === 0) {
                            clearInterval(this.ongoingCallTimer);
                            this.ongoingCallTimer = 0;
                        }
                        console.log('ongoing calls', this.ongoingCalls.length);
                    }, 1000)
                }
            }
        },

        joinMultiCall(message) {
            let request = new JoinCallRequestMessageContent(message.messageContent.callId, wfc.getClientId());
            wfc.sendConversationMessage(this.conversationInfo.conversation, request);
        },

        showUnreadMessage() {
            let messageListElement = this.$refs['conversationMessageList'];
            messageListElement.scroll({top: messageListElement.scrollHeight, left: 0, behavior: 'auto'})
            this.unreadMessageCount = 0;
        },

        clearConversationUnreadStatus() {
            let info = this.sharedConversationState.currentConversationInfo;
            if (info.unreadCount.unread + info.unreadCount.unreadMention + info.unreadCount.unreadMentionAll > 0) {
                store.clearConversationUnreadStatus(info.conversation);
                // this.unreadMessageCount = 0;
            }
        }
    },

    mounted() {
        this.popupItem = this.$refs['setting'];
        document.addEventListener('mouseup', this.dragEnd);
        document.addEventListener('mousemove', this.drag);

        this.$on('openMessageContextMenu', (event, message) => {
            this.$refs.menu.open(event, message);
        });

        this.$on('openMessageSenderContextMenu', (event, message) => {
            // 目前只支持群会话里面，消息发送者右键@
            if (message.conversation.type === ConversationType.Group) {
                this.$refs.messageSenderContextMenu.open(event, message);
            }
        });

        this.$eventBus.$on('send-file', args => {
            let fileMessageContent = new FileMessageContent(null, args.remoteUrl, args.name, args.size);
            let message = new Message(null, fileMessageContent);
            this.forward(message)
        });

        this.$eventBus.$on('forward-fav', args => {
            let favItem = args.favItem;
            let message = favItem.toMessage();
            this.forward(message);
        });

        wfc.eventEmitter.on(EventType.ReceiveMessage, this.onReceiveMessage)
    },

    beforeDestroy() {
        document.removeEventListener('mouseup', this.dragEnd);
        document.removeEventListener('mousemove', this.drag);
        this.$eventBus.$off('send-file');
        this.$eventBus.$off('forward-fav');
        this.$off('openMessageContextMenu')
        this.$off('openMessageSenderContextMenu')
        wfc.eventEmitter.removeListener(EventType.ReceiveMessage, this.onReceiveMessage);
    },

    updated() {
        if (!this.sharedConversationState.currentConversationInfo) {
            return;
        }
        this.popupItem = this.$refs['setting'];
        // refer to http://iamdustan.com/smoothscroll/
        console.log('conversationView updated', this.sharedConversationState.currentConversationInfo, this.sharedConversationState.shouldAutoScrollToBottom, this.sharedMiscState.isPageHidden)
        if (this.sharedConversationState.shouldAutoScrollToBottom && !this.sharedMiscState.isPageHidden) {
            let messageListElement = this.$refs['conversationMessageList'];
            messageListElement.scroll({top: messageListElement.scrollHeight, left: 0, behavior: 'auto'})
            this.clearConversationUnreadStatus();
        } else {
            // 用户滑动到上面之后，收到新消息，不自动滑动到最下面
        }
        if (this.sharedConversationState.currentConversationInfo) {
            let unreadCount = this.sharedConversationState.currentConversationInfo.unreadCount;
            if (unreadCount.unread > 0) {
                if (this.sharedMiscState.isPageHidden) {
                    this.unreadMessageCount = unreadCount.unread;
                }
            } else {
                this.unreadMessageCount = 0;
            }
        }

        // 切换到新的会话
        if (this.conversationInfo && this.sharedConversationState.currentConversationInfo && !this.conversationInfo.conversation.equal(this.sharedConversationState.currentConversationInfo.conversation)) {
            this.showConversationInfo = false;
            this.ongoingCalls = [];
            if (this.ongoingCallTimer) {
                clearInterval(this.ongoingCallTimer);
                this.ongoingCallTimer = 0;
            }
        }
        this.conversationInfo = this.sharedConversationState.currentConversationInfo;
    },

    computed: {
        conversationTitle() {
            if (this.title) {
                return this.title;
            }
            let info = this.sharedConversationState.currentConversationInfo;
            if (info.conversation._target) {
                if (info.conversation.type === ConversationType.Group) {
                    return info.conversation._target._displayName + " (" + info.conversation._target.memberCount + ")";
                } else {
                    return info.conversation._target._displayName;
                }
            } else {
                return '会话';
            }
        },
        targetUserOnlineStateDesc() {
            let info = this.sharedConversationState.currentConversationInfo;
            if (info.conversation.type === ConversationType.Single && info.conversation.target !== Config.FILE_HELPER_ID) {
                if (!wfc.isMyFriend(info.conversation.target)) {
                    return '你们还不是好友，点击添加好友';
                }
                if (info.conversation._target.type === 0) {
                    return info.conversation._targetOnlineStateDesc;
                } else if (info.conversation._target.type === 1) {
                    return 'bot';
                }
            } else if (info.conversation.type === ConversationType.Channel) {
                let desc = info.conversation._target.desc;
                if (!desc) {
                    desc = 'channel'
                }
                return desc;
            } else {
                return '';
            }
        },
        loadingIdentifier() {
            let conversation = this.sharedConversationState.currentConversationInfo.conversation;
            return conversation.type + '-' + conversation.target + '-' + conversation.line;
        },
        currentVoiceMessage() {
            let voice = this.sharedConversationState.currentVoiceMessage;
            if (voice) {
                this.playVoice(voice);
            } else {
                if (amr) {
                    amr.stop();
                }
            }
            return null;
        },
       
        muted() {
            if (!this.conversationInfo) {
                return false;
            }
            let target = this.conversationInfo.conversation._target;
            if (target instanceof GroupInfo) {
                let groupInfo = target;
                let groupMember = wfc.getGroupMember(groupInfo.target, wfc.getUserId());
                if (groupInfo.mute === 1) {
                    return [GroupMemberType.Owner, GroupMemberType.Manager, GroupMemberType.Allowed].indexOf(groupMember.type) < 0;
                } else {
                    return groupMember && groupMember.type === GroupMemberType.Muted;
                }
            }
            return false;
        },
    },
    // watch: {
    //     conversationInfo() {
    //         console.log('conversationInfo changed', this.conversationInfo);
    //     }
    // },

    directives: {
        ClickOutside
    },
};
"},null]}