{"remainingRequest":"/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/thread-loader/dist/cjs.js!/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/babel-loader/lib/index.js!/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/cache-loader/dist/cjs.js??ref--0-0!/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=script&lang=js&","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/thread-loader/dist/cjs.js","mtime":1702017030024},{"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 "core-js/modules/es.array.filter";
import "core-js/modules/es.array.find";
import "core-js/modules/es.array.find-index";
import "core-js/modules/es.array.for-each";
import "core-js/modules/es.array.slice";
import "core-js/modules/es.array.splice";
import "core-js/modules/es.function.name";
import "core-js/modules/es.regexp.exec";
import "core-js/modules/es.string.replace";
import "core-js/modules/web.dom-collections.for-each";
import _toConsumableArray from "/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/@babel/runtime/helpers/esm/toConsumableArray";
import "regenerator-runtime/runtime";
import _asyncToGenerator from "/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/@babel/runtime/helpers/esm/asyncToGenerator";
import _createForOfIteratorHelper from "/data/jenkins/workspace/badp-bcxin-web-5.x-vuechat/node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import avenginekit from "../../../wfc/av/internal/engine.min";
import CallSessionCallback from "../../../wfc/av/engine/callSessionCallback";
import CallState from "../../../wfc/av/engine/callState";
import ClickOutside from 'vue-click-outside';
import localStorageEmitter from "../../../ipc/localStorageEmitter";
import { currentWindow, isElectron } from "../../../platform";
import ScreenOrWindowPicker from "../ScreenOrWindowPicker";
import CallEndReason from "../../../wfc/av/engine/callEndReason";
import ScreenShareControlView from "../ScreenShareControlView";
import avenginekitproxy from "../../../wfc/av/engine/avenginekitproxy";
import ElectronWindowsControlButtonView from "../../common/ElectronWindowsControlButtonView";
import store from "../../../store";
import VideoType from "../../../wfc/av/engine/videoType";
import IpcEventType from "../../../ipcEventType";
import ConferenceParticipantVideoView from "./ConferenceParticipantVideoView";
import ConversationView from "../../main/conversation/ConversationView";
import ConferenceSimpleInfoView from "./ConferenceSimpleInfoView";
import ChooseConferenceLayoutView from "./ChooseConferenceLayoutView";
import ConferenceConversationFloatingView from "./ConferenceConversationFloatingView";
import conferenceManager from "./conferenceManager";
import ConferenceManageView from "./ConferenceManageView";
import wfc from "../../../wfc/client/wfc";
import LocalStorageIpcEventType from "../../../ipc/localStorageIpcEventType";
import UserInfo from "../../../wfc/model/userInfo";
import ConversationType from "../../../wfc/model/conversationType";
import Conversation from "../../../wfc/model/conversation";
import ConversationInfo from "../../../wfc/model/conversationInfo";
import ChannelInfo from "../../../wfc/model/channelInfo";
import ChatRoomInfo from "../../../wfc/model/chatRoomInfo";
export default {
  name: 'Conference',
  data: function data() {
    return {
      session: null,
      audioOnly: false,
      status: 1,
      selfUserInfo: null,
      participantUserInfos: [],
      startTimestamp: 0,
      currentTimestamp: 0,
      showSlider: false,
      showConferenceManageView: false,
      showConversationView: false,
      sharedMiscState: store.state.misc,
      videoInputDeviceIndex: 0,
      refreshUserInfoInternal: 0,
      endReason: undefined,
      conferenceManager: conferenceManager,
      // -1，默认布局，也就是宫格布局；0, 宫格视图；1，演讲者视图
      currentLayout: -1,
      // 宫格视图
      currentGridPageIndex: 0,
      participantCountPerGridPage: 9,
      // 演讲者视图
      speakingVideoParticipant: null,
      hideFocusLayoutParticipantListVideoView: false,
      showConferenceSimpleInfoView: false,
      showChooseLayoutView: false
    };
  },
  components: {
    ConferenceManageView: ConferenceManageView,
    ConferenceConversationFloatingView: ConferenceConversationFloatingView,
    ChooseConferenceLayoutView: ChooseConferenceLayoutView,
    ConferenceSimpleInfoView: ConferenceSimpleInfoView,
    ConferenceParticipantVideoView: ConferenceParticipantVideoView,
    ScreenShareControlView: ScreenShareControlView,
    ElectronWindowsControlButtonView: ElectronWindowsControlButtonView,
    ConversationView: ConversationView
  },
  methods: {
    // 用来解决 iOS 上，不能自动播放问题
    autoPlay: function autoPlay() {
      var _this = this;

      if (isElectron()) {
        return;
      }

      console.log('auto play');

      if (!this.autoPlayInterval) {
        this.autoPlayInterval = setInterval(function () {
          try {
            var videos = document.getElementsByTagName('video');
            var allPlaying = true;

            var _iterator = _createForOfIteratorHelper(videos),
                _step;

            try {
              for (_iterator.s(); !(_step = _iterator.n()).done;) {
                var video = _step.value;

                if (video.paused) {
                  allPlaying = false;
                  break;
                }
              } // participantUserInfos 不包含自己

            } catch (err) {
              _iterator.e(err);
            } finally {
              _iterator.f();
            }

            if (allPlaying && videos.length === _this.participantUserInfos.filter(function (p) {
              return !p._isAudience;
            }).length + 1) {
              clearInterval(_this.autoPlayInterval);
              _this.autoPlayInterval = 0;
              console.log('auto play, allPlaying', videos.length);
              return;
            }

            var _iterator2 = _createForOfIteratorHelper(videos),
                _step2;

            try {
              for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
                var _video = _step2.value;

                if (_video.paused) {
                  _video.play();
                }
              }
            } catch (err) {
              _iterator2.e(err);
            } finally {
              _iterator2.f();
            }
          } catch (e) {// do nothing
          }
        }, 100);
      }
    },
    setupSessionCallback: function setupSessionCallback() {
      var _this2 = this;

      var sessionCallback = new CallSessionCallback();

      sessionCallback.didChangeState = function (state) {
        console.log('didChangeState', state);
        _this2.status = state;

        if (state === CallState.STATUS_CONNECTED) {
          // 比如没有摄像头，但发起视频通话时，会自动 muteVideo
          _this2.selfUserInfo._isVideoMuted = _this2.session.videoMuted;

          if (_this2.startTimestamp === 0) {
            _this2.startTimestamp = new Date().getTime();
            _this2.timer = setInterval(function () {
              _this2.currentTimestamp = new Date().getTime();
            }, 1000);
          }
        } else if (state === CallState.STATUS_IDLE) {
          if (_this2.timer) {
            clearInterval(_this2.timer);
          }
        }
      };

      sessionCallback.onInitial = function (session, selfUserInfo, initiatorUserInfo) {
        //this.session.rotateAng = 90;
        selfUserInfo._isHost = session.host === selfUserInfo.uid;
        selfUserInfo._isAudience = session.audience;
        selfUserInfo._isVideoMuted = session.videoMuted;
        selfUserInfo._isAudioMuted = session.audioMuted;
        selfUserInfo._volume = 0; // 先添加属性，在赋值，才能 reactive

        _this2.selfUserInfo = selfUserInfo;
        _this2.participantUserInfos = [selfUserInfo];
        console.log('oninitial', selfUserInfo._isAudience); // pls refer to: https://vuejs.org/v2/guide/reactivity.html

        _this2.$set(_this2.selfUserInfo, '_stream', null);

        _this2.$set(_this2.selfUserInfo, '_screenShareStream', null);

        _this2.$set(_this2.selfUserInfo, '_isScreenSharing', false);

        _this2.participantUserInfos.forEach(function (p) {
          return _this2.$set(p, "_stream", null);
        });

        _this2.session = session;
        document.title = session.title;
        conferenceManager.getConferenceInfo(session.callId);
      };

      sessionCallback.didCreateLocalVideoTrack = function (stream, screenShare) {
        console.log('didCreateLocalVideoTrack', screenShare);

        if (screenShare) {
          _this2.selfUserInfo._screenShareStream = stream;
        } else {
          _this2.selfUserInfo._stream = stream;
          _this2.selfUserInfo._screenShareStream = null;
          _this2.selfUserInfo._isVideoMuted = false;
        }

        _this2.selfUserInfo._isScreenSharing = screenShare;

        _this2.autoPlay();
      };

      sessionCallback.didRotateLocalVideoTrack = function (stream) {
        console.log('didRotateLocalVideoTrack', stream.getAudioTracks());
        _this2.selfUserInfo._stream = stream;
        _this2.selfUserInfo._stream.timestamp = new Date().getTime();
      };

      sessionCallback.didScreenShareEnded = function () {
        console.log('didScreenShareEnded', _this2.session.videoMuted, _this2.session.audioMuted);

        if (isElectron()) {
          currentWindow.setIgnoreMouseEvents(false);
        }

        _this2.selfUserInfo._isScreenSharing = false;
        _this2.selfUserInfo._isVideoMuted = _this2.session.videoMuted;
      };

      sessionCallback.didCreateLocalVideoTrackError = function () {// TODO
        // 没有摄像头或者麦克风，加入会议时，会回调到此处，自己断会显示自己的头像，其他端会显示黑屏
        // 可以进行相关提示
      };

      sessionCallback.didReceiveRemoteVideoTrack = function (userId, stream, screenSharing) {
        var p;
        console.log('didReceiveRemoteVideoTrack', userId, stream, screenSharing);
        var index = -1;

        for (var i = 0; i < _this2.participantUserInfos.length; i++) {
          p = _this2.participantUserInfos[i];

          if (p.uid === userId && p._isScreenSharing === screenSharing) {
            index = i;
            p._stream = stream;
            p._stream.timestamp = new Date().getTime();
            break;
          }
        } // if (index > -1) {
        //     this.$set(this.participantUserInfos, index, p);
        // }


        _this2.autoPlay();
      };

      sessionCallback.didRemoveRemoteVideoTrack = function (userId) {
        console.log('didRemoveRemoteVideoTrack', userId);
      };

      sessionCallback.didParticipantJoined = function (userId, screenSharing) {
        console.log('didParticipantJoined', userId, screenSharing);
        var userInfo = wfc.getUserInfo(userId);

        var subscriber = _this2.session.getSubscriber(userId, screenSharing);

        userInfo._stream = subscriber.stream;
        userInfo._isAudience = subscriber.audience;
        userInfo._isHost = _this2.session.host === userId;
        userInfo._isVideoMuted = subscriber.videoMuted;
        userInfo._isAudioMuted = subscriber.audioMuted;
        userInfo._volume = 0;
        userInfo._isScreenSharing = screenSharing; // 动态添加的属性不是 reactive 的，故直接创建个新的对象
        // 其实这个问题很奇怪，只有发起会议，第一次进入该会议的时候，其他端加入，参与者列表会不刷新；重新进入等，都一切正常

        _this2.participantUserInfos.push(Object.assign(new UserInfo(), userInfo));

        console.log('joined', userInfo, subscriber.audience, _this2.participantUserInfos.length);
      };

      sessionCallback.didParticipantLeft = function (userId, endReason, screenSharing) {
        console.log('didParticipantLeft', userId, endReason, screenSharing, JSON.stringify(_this2.participantUserInfos), _this2.participantUserInfos.length); //this.participantUserInfos = this.participantUserInfos.filter(p => p.uid !== userId && p._isScreenSharing !== screenSharing);

        _this2.participantUserInfos = _this2.participantUserInfos.filter(function (p) {
          return !(p.uid === userId && p._isScreenSharing === screenSharing);
        }); //fixme 上面可能会没有触发重新计算 focusVideoParticipant

        console.log('didParticipantLeft d', userId, endReason, screenSharing, _this2.participantUserInfos.length);
      };

      sessionCallback.didCallEndWithReason = function (reason) {
        console.log('callEndWithReason', reason);
        conferenceManager.addHistory(conferenceManager.conferenceInfo, new Date().getTime() - conferenceManager.conferenceInfo.startTime * 1000); // 可以根据reason，进行一些提示
        // alert('会议已结束');

        _this2.endReason = reason;

        if (reason === CallEndReason.REASON_MediaError) {
          return;
        }

        if (reason === CallEndReason.RoomNotExist) {
          console.log('join conference failed', reason, _this2.session);
          var obj = {
            reason: reason,
            session: _this2.session
          };
          localStorageEmitter.send(LocalStorageIpcEventType.joinConferenceFailed, obj);
        }

        _this2.session.closeVoipWindow();

        _this2.session = null;
      };

      sessionCallback.onRequestChangeMode = function (audience) {
        console.log('onRequestChangeMode', audience);

        if (audience) {
          _this2.session.switchAudience(true);

          return;
        }

        _this2.$alert({
          content: '主持人邀请你参与互动',
          cancelCallback: function cancelCallback() {// do nothing
          },
          confirmCallback: function confirmCallback() {
            _this2.session.switchAudience(false);
          }
        });
      };

      sessionCallback.didChangeType = function (userId, audience, screenSharing) {
        console.log('didChangeType', userId, audience, screenSharing);

        _this2.participantUserInfos.forEach(function (u) {
          if (u.uid === userId && u._isScreenSharing === screenSharing) {
            u._isAudience = audience;

            if (audience) {
              u._stream = null;
            }

            if (_this2.speakingVideoParticipant && _this2.speakingVideoParticipant.uid === u.uid) {
              _this2.speakingVideoParticipant = null;
            }
          }
        });
      };

      sessionCallback.didReportAudioVolume = function (userId, volume) {
        var userInfo;

        if (userId === _this2.selfUserInfo.uid) {
          _this2.selfUserInfo._volume = volume;
          userInfo = _this2.selfUserInfo;
        } else {
          _this2.participantUserInfos.forEach(function (u) {
            if (u.uid === userId && u._isScreenSharing === false) {
              u._volume = volume;
              userInfo = u;
            }
          });
        }

        if (_this2.currentLayout === 0) {
          return;
        }

        if (!userInfo) {
          return;
        }

        if (userInfo._isVideoMuted) {
          return;
        }

        if (_this2.conferenceFocusUser) {
          return _this2.conferenceFocusUser;
        }

        if (!_this2.speakingVideoParticipant) {
          _this2.speakingVideoParticipant = userInfo;
        } else if (userInfo._volume > _this2.speakingVideoParticipant._volume) {
          _this2.speakingVideoParticipant = userInfo;
        }
      };

      sessionCallback.didMuteStateChanged = function (participants) {
        console.log('conference', 'didMuteStateChanged', participants);
        participants.forEach(function (p) {
          // 自己
          if (p === _this2.selfUserInfo.uid) {
            console.log('conference', 'didMuteStateChanged self', _this2.session.videoMuted);
            _this2.selfUserInfo._isVideoMuted = _this2.session.videoMuted;
            return;
          }

          var s = _this2.session.getSubscriber(p);

          if (!s) {
            return;
          }

          console.log('conference', 'didMuteStateChanged', p, s.videoMuted, s.audioMuted);

          _this2.participantUserInfos.forEach(function (u) {
            if (u.uid === p && u._isScreenSharing === false) {
              var subscriber = _this2.session.getSubscriber(p);

              u._isVideoMuted = subscriber.videoMuted;
              u._isAudioMuted = subscriber.audioMuted;

              if (_this2.speakingVideoParticipant && _this2.speakingVideoParticipant.uid === u.uid) {
                _this2.speakingVideoParticipant = null;
              }
            }
          });
        });
      };

      sessionCallback.didMediaLostPacket = function (media, lostPacket, screenSharing) {
        console.log('didMediaLostPacket', media, lostPacket, screenSharing);

        if (lostPacket > 6) {
          console.log('您的网络不好');
        }
      };

      sessionCallback.didUserMediaLostPacket = function (userId, media, lostPacket, uplink, screenSharing) {
        console.log('didUserMediaLostPacket', userId, media, lostPacket, uplink, screenSharing); //如果uplink ture对方网络不好，false您的网络不好
        //接收方丢包超过10为网络不好

        if (lostPacket > 10) {
          if (uplink) {
            var userInfos = _this2.participantUserInfos.filter(function (u) {
              return u.uid === userId && u._isScreenSharing === screenSharing;
            });

            if (userInfos && userInfos.length > 0) {
              console.log(userInfos[0].displayName, "网络不好");
            }
          } else {
            console.log('您的网络不好');
          }
        }
      };

      if (isElectron()) {
        avenginekit.setup(sessionCallback);
      } else {
        avenginekit.sessionCallback = sessionCallback;
      }
    },
    hangup: function hangup() {
      this.session.leaveConference(true); //邀请方设置true,web端离开会议，app也离开--核心

      conferenceManager.addHistory(conferenceManager.conferenceInfo, new Date().getTime() - conferenceManager.conferenceInfo.startTime * 1000);
    },
    muteAudio: function muteAudio() {
      var enable = this.session.audioMuted ? true : false;

      if (enable && this.session.audience && !conferenceManager.isOwner() && !conferenceManager.conferenceInfo.allowSwitchMode) {
        this.requestUnmute(true);
        return;
      }

      this.enableAudio(enable);
    },
    enableAudio: function enableAudio(enable) {
      var _this3 = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var result;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                _context.next = 2;
                return _this3.session.setAudioEnabled(enable);

              case 2:
                result = _context.sent;

                if (result) {
                  _context.next = 5;
                  break;
                }

                return _context.abrupt("return");

              case 5:
                _this3.selfUserInfo._isAudioMuted = !enable;
                console.log('muteAudio', _this3.selfUserInfo._isAudioMuted, _this3.session.audience);

                if (!enable) {
                  _context.next = 14;
                  break;
                }

                if (!_this3.session.audience) {
                  _context.next = 12;
                  break;
                }

                _context.next = 11;
                return _this3.session.switchAudience(false);

              case 11:
                _this3.selfUserInfo._isAudience = false;

              case 12:
                _context.next = 18;
                break;

              case 14:
                if (!(_this3.session.videoMuted && !_this3.session.audience)) {
                  _context.next = 18;
                  break;
                }

                _context.next = 17;
                return _this3.session.switchAudience(true);

              case 17:
                _this3.selfUserInfo._isAudience = true;

              case 18:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }))();
    },
    muteVideo: function muteVideo() {
      var enable = this.session.videoMuted ? true : false;

      if (enable && this.session.audience && !conferenceManager.isOwner() && !conferenceManager.conferenceInfo.allowSwitchMode) {
        this.requestUnmute(false);
        return;
      }

      this.enableVideo(enable);
    },
    enableVideo: function enableVideo(enable) {
      var _this4 = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() {
        var result;
        return regeneratorRuntime.wrap(function _callee2$(_context2) {
          while (1) {
            switch (_context2.prev = _context2.next) {
              case 0:
                _context2.next = 2;
                return _this4.session.setVideoEnabled(enable);

              case 2:
                result = _context2.sent;

                if (result) {
                  _context2.next = 5;
                  break;
                }

                return _context2.abrupt("return");

              case 5:
                _this4.selfUserInfo._isVideoMuted = !enable;
                console.log('muteVideo result', _this4.selfUserInfo._isVideoMuted, _this4.session.audience);

                if (!enable) {
                  _context2.next = 14;
                  break;
                }

                if (!_this4.session.audience) {
                  _context2.next = 12;
                  break;
                }

                _context2.next = 11;
                return _this4.session.switchAudience(false);

              case 11:
                _this4.selfUserInfo._isAudience = false;

              case 12:
                _context2.next = 18;
                break;

              case 14:
                if (!(_this4.session.audioMuted && !_this4.session.audience)) {
                  _context2.next = 18;
                  break;
                }

                _context2.next = 17;
                return _this4.session.switchAudience(true);

              case 17:
                _this4.selfUserInfo._isAudience = true;

              case 18:
              case "end":
                return _context2.stop();
            }
          }
        }, _callee2);
      }))();
    },
    requestUnmute: function requestUnmute(audio) {
      if (audio && conferenceManager.allowUnmuteAudio) {
        this.enableAudio(true);
        return;
      }

      if (!audio && conferenceManager.allowUnmuteVideo) {
        this.enableVideo(true);
        return;
      }

      this.$alert({
        content: audio ? '主持人不允许解除静音，您可以向主持人申请解除静音' : '主持人不允许打开摄像头，您可以向主持人申请打开摄像头',
        confirmText: '申请',
        cancelCallback: function cancelCallback() {// do nothing
        },
        confirmCallback: function confirmCallback() {
          conferenceManager.applyUnmute(audio, false);
        }
      });
    },
    down2voice: function down2voice() {
      this.session.downgrade2Voice();
    },
    members: function members() {
      this.showConferenceManageView = !this.showConferenceManageView;
      this.toggleSliderView();
    },
    chat: function chat() {
      if (isElectron()) {
        this.showConversationView = !this.showConversationView;
        this.toggleSliderView();
      } else {
        var conversation = new Conversation(ConversationType.ChatRoom, this.session.callId, 0);
        var chatroomInfo = new ChatRoomInfo();
        chatroomInfo.chatRoomId = this.session.callId;
        chatroomInfo.title = this.session.title;
        conversation._target = chatroomInfo;
        conversation._target._displayName = chatroomInfo.title;
        var conversationInfo = new ConversationInfo();
        conversationInfo.conversation = conversation;
        store.setCurrentConversationInfo(conversationInfo);
        this.$router.replace('/home');
      }
    },
    hideParticipantList: function hideParticipantList() {
      this.showConferenceManageView && (this.showConferenceManageView = false);
      this.toggleSliderView();
    },
    toggleSliderView: function toggleSliderView() {
      if (!this.showSlider) {
        if (isElectron()) {
          var size = currentWindow.getSize();
          currentWindow.setSize(size[0] + 350, size[1], false);
        } else {
          window.resizeTo(window.innerWidth + 360, window.outerHeight);
        }

        this.$refs.rootContainer.style.setProperty('--slider-width', '350px');
      } else {
        if (isElectron()) {
          var _size = currentWindow.getSize();

          this.$refs.rootContainer.style.setProperty('--slider-width', '0px');
          currentWindow.setSize(_size[0] - 350, _size[1], false);
        } else {
          this.$refs.rootContainer.style.setProperty('--slider-width', '0px');
          window.resizeTo(window.innerWidth - 350, window.outerHeight);
        }

        this.showConferenceManageView = false;
        this.showConversationView = false;
      }

      this.showSlider = !this.showSlider;
    },
    screenShare: function screenShare() {
      var _this5 = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3() {
        var beforeClose;
        return regeneratorRuntime.wrap(function _callee3$(_context3) {
          while (1) {
            switch (_context3.prev = _context3.next) {
              case 0:
                if (!_this5.session.screenSharing) {
                  _context3.next = 6;
                  break;
                }

                _this5.session.stopScreenShare();

                console.log('stopScreenShare', _this5.session.videoMuted, _this5.session.audioMuted);

                if (_this5.session.videoMuted && _this5.session.audioMuted) {
                  _this5.session.switchAudience(true);
                } // currentWindow.setIgnoreMouseEvents(false)


                _context3.next = 15;
                break;

              case 6:
                if (!isElectron()) {
                  _context3.next = 11;
                  break;
                }

                beforeClose = function beforeClose(event) {
                  // What a gamble... 50% chance to cancel closing
                  if (!event.params) {
                    return;
                  }

                  if (event.params.source) {
                    var source = event.params.source;
                    var desktopShareOptions = {
                      sourceId: source.id,
                      minWidth: 1280,
                      maxWidth: 1280,
                      minHeight: 720,
                      maxHeight: 720
                    };

                    if (_this5.session.audience) {
                      _this5.session.switchAudience(false).then(function () {
                        _this5.session.startScreenShare(desktopShareOptions);
                      }).catch(function (err) {
                        console.error(err);
                      });
                    } else {
                      _this5.session.startScreenShare(desktopShareOptions);
                    }

                    avenginekitproxy.emitToMain(IpcEventType.START_SCREEN_SHARE, {});
                  }
                };

                _this5.$modal.show(ScreenOrWindowPicker, {}, {
                  width: 800,
                  height: 600,
                  name: 'screen-window-picker-modal',
                  clickToClose: false
                }, {
                  // 'before-open': beforeOpen,
                  'before-close': beforeClose // 'closed': closed,

                });

                _context3.next = 15;
                break;

              case 11:
                if (!_this5.session.audience) {
                  _context3.next = 14;
                  break;
                }

                _context3.next = 14;
                return _this5.session.switchAudience(false);

              case 14:
                _this5.session.startScreenShare({
                  frameRate: 30
                });

              case 15:
              case "end":
                return _context3.stop();
            }
          }
        }, _callee3);
      }))();
    },
    // 设置音频输出设备
    setAudioOutputDeviceId: function setAudioOutputDeviceId(deviceId) {
      var audioEls = this.$el.getElementsByTagName('audio');

      var _iterator3 = _createForOfIteratorHelper(audioEls),
          _step3;

      try {
        for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
          var audioEl = _step3.value;
          audioEl.setSinkId(deviceId);
        }
      } catch (err) {
        _iterator3.e(err);
      } finally {
        _iterator3.f();
      }

      var videoEls = this.$el.getElementsByTagName('video');

      var _iterator4 = _createForOfIteratorHelper(videoEls),
          _step4;

      try {
        for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
          var videoEl = _step4.value;
          videoEl.setSinkId(deviceId);
        }
      } catch (err) {
        _iterator4.e(err);
      } finally {
        _iterator4.f();
      }
    },
    handup: function handup() {
      conferenceManager.handUp(!conferenceManager.isHandUp);
    },
    userName: function userName(user) {
      var 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;
    },
    timestampFormat: function timestampFormat(timestamp) {
      timestamp = ~~(timestamp / 1000);
      var str = '';
      var hour = ~~(timestamp / 3600);
      str = hour > 0 ? (hour < 10 ? "0" : "") + hour + ':' : '';
      var min = ~~(timestamp % 3600 / 60);
      str += (min < 10 ? "0" : "") + min + ':';
      var sec = ~~(timestamp % 60);
      str += (sec < 10 ? "0" : "") + sec;
      return str;
    },
    // TODO 删除，可以直接监听用户信息变化了
    refreshUserInfos: function refreshUserInfos() {
      var _this6 = this;

      var toRefreshUsers = [];
      this.participantUserInfos.forEach(function (pu) {
        if (!pu.updateDt) {
          toRefreshUsers.push(pu.uid);
        }
      });

      if (toRefreshUsers.length > 0) {
        console.log('to refreshUsers', toRefreshUsers);
        var userInfos = wfc.getUserInfos(toRefreshUsers, '');
        userInfos.forEach(function (u) {
          var index = _this6.participantUserInfos.findIndex(function (p) {
            return p.uid === u.uid;
          });

          if (u.updateDt && index > -1) {
            var ou = _this6.participantUserInfos[index];
            u._stream = ou._stream;
            u._isAudience = ou._isAudience;
            u._isHost = ou._isHost;
            u._isVideoMuted = ou._isVideoMuted;
            u._isAudioMuted = ou._isAudioMuted;
            u._volume = ou._volume; // FYI: https://v2.vuejs.org/v2/guide/reactivity#Change-Detection-Caveats

            _this6.participantUserInfos.splice(index, 1, u);
          }
        });
      }
    },
    rejoinConference: function rejoinConference() {
      avenginekit.joinConference({
        callId: this.session.callId,
        pin: this.session.pin,
        host: this.session.host,
        tile: this.session.title,
        desc: this.session.desc,
        audioOnly: this.session.audioOnly,
        audience: this.session.audience,
        advance: this.session.advance,
        muteVideo: this.session.videoMuted,
        muteAudio: this.session.audioMuted,
        extra: this.session.extra,
        callExtra: this.session.callExtra,
        selfUserInfo: this.selfUserInfo
      });
      this.endReason = undefined;
    },
    prePage: function prePage() {
      this.currentGridPageIndex--;

      if (this.currentGridPageIndex < 0) {
        this.currentGridPageIndex = Math.ceil(this.participantUserInfos.length / this.participantCountPerGridPage) - 1;
      }
    },
    nextPage: function nextPage() {
      if (this.participantUserInfos.length / this.participantCountPerGridPage > this.currentGridPageIndex + 1) {
        this.currentGridPageIndex++;
      } else {
        this.currentGridPageIndex = 0;
      }
    },
    updateCountPerPage: function updateCountPerPage(count) {
      this.participantCountPerGridPage = count;
    },
    setCurrentLayout: function setCurrentLayout(layout) {
      var _this7 = this;

      if (this.currentLayout === layout) {
        return;
      } // 演讲者布局


      if (layout === 1) {
        // 演讲者布局，切换为小流，然后焦点用户切换为大流
        this.participantUserInfos.forEach(function (u) {
          if (u.uid !== _this7.selfUserInfo.uid && !u._isAudience && !u._isVideoMuted) {
            _this7.session.setParticipantVideoType(u.uid, u._isScreenSharing, VideoType.SMALL_STREAM);
          }
        });
      } else {
        //宫格布局， 当前页切换为大流，未显示的，取消订阅，由 currentPageParticipants 副作用触发
        this.currentGridPageIndex = 0;
        conferenceManager.currentFocusUser = null;
      }

      this.currentLayout = layout;
      this.showChooseLayoutView = false;
    },
    toggleParticipantListVideoView: function toggleParticipantListVideoView() {
      this.hideFocusLayoutParticipantListVideoView = !this.hideFocusLayoutParticipantListVideoView;
    },
    hideConferenceSimpleInfoView: function hideConferenceSimpleInfoView(event) {
      if (event.target.id === 'info-icon') {
        return;
      }

      this.showConferenceSimpleInfoView = false;
    },
    hideChooseLayoutView: function hideChooseLayoutView(event) {
      if (event.target.id === 'grid-icon') {
        return;
      }

      this.showChooseLayoutView = false;
    }
  },
  computed: {
    duration: function duration() {
      if (this.currentTimestamp <= 0) {
        return '00:00';
      }

      var escapeMillis = this.currentTimestamp - this.startTimestamp;
      return this.timestampFormat(escapeMillis);
    },
    speakingUserName: function speakingUserName() {
      var maxVolume = this.selfUserInfo._volume;
      var speakingUserInfo = this.selfUserInfo;
      this.participantUserInfos.forEach(function (u) {
        if (u._volume > maxVolume) {
          speakingUserInfo = u;
          maxVolume = u._volume;
        }
      });

      if (!maxVolume) {
        return '';
      }

      return this.userName(speakingUserInfo);
    },
    currentPageParticipants: function currentPageParticipants() {
      if (this.currentLayout === 1) {
        return [];
      }

      var focusUser = this.conferenceFocusUser; // sort not in place，避免副作用

      var sortedParticipantUserInfos = _toConsumableArray(this.participantUserInfos).sort(function (o1, o2) {
        if (focusUser) {
          if (o1.uid === focusUser.uid && o1._isScreenSharing === focusUser._isScreenSharing) {
            return -1;
          }

          if (o2.uid === focusUser.uid && o2._isScreenSharing === focusUser._isScreenSharing) {
            return 1;
          }
        }

        if (o1._isAudience && !o2._isAudience) {
          return 1;
        } else if (!o1._isAudience && o2._isAudience) {
          return -1;
        } else if (o1._isAudience && o2._isAudience) {
          return o1.uid.localeCompare(o2.uid);
        } else {
          if (o1._isScreenSharing && !o2._isScreenSharing) {
            return -1;
          }

          if (!o1._isScreenSharing && o2._isScreenSharing) {
            return 1;
          }

          if (!o1._isVideoMuted && o2._isVideoMuted) {
            return -1;
          }

          if (o1._isVideoMuted && !o2._isVideoMuted) {
            return 1;
          }

          return o1.uid.localeCompare(o2.uid);
        }
      });

      var start = this.currentGridPageIndex * this.participantCountPerGridPage;
      var end = start + this.participantCountPerGridPage > sortedParticipantUserInfos.length ? sortedParticipantUserInfos.length : start + this.participantCountPerGridPage; // side effect
      // TODO 优化
      // 相邻页切换时，不能理解取消订阅，可能还切换回去，那样的话，就会有一小段时间，不显示视频流

      for (var i = 0; i < sortedParticipantUserInfos.length; i++) {
        var u = sortedParticipantUserInfos[i];

        if (u.uid === this.selfUserInfo.uid || u._isAudience || u._isVideoMuted) {
          continue;
        }

        if (i >= start && i < end) {
          console.log('set video type big', u.uid);
          this.session.setParticipantVideoType(u.uid, u._isScreenSharing, VideoType.BIG_STREAM);
        } else {
          console.log('set video type none', u.uid);
          this.session.setParticipantVideoType(u.uid, u._isScreenSharing, VideoType.NONE);
        }
      } // side effect


      return sortedParticipantUserInfos.slice(start, end);
    },
    gridPageCount: function gridPageCount() {
      return Math.ceil(this.participantUserInfos.length / this.participantCountPerGridPage);
    },
    conferenceFocusUser: function conferenceFocusUser() {
      var focus = conferenceManager.conferenceInfo.focus;

      if (!focus) {
        return null;
      }

      var focusUser = this.participantUserInfos.find(function (u) {
        return u.uid === focus && u._isScreenSharing === true;
      });

      if (!focusUser) {
        focusUser = this.participantUserInfos.find(function (u) {
          return u.uid === focus;
        });
      }

      return focusUser;
    },
    conferenceLocalFocusUser: function conferenceLocalFocusUser() {
      return conferenceManager.localFocusUser;
    },
    // 以用户手动选择的为准
    computedCurrentLayout: function computedCurrentLayout() {
      if (this.currentLayout === -1 && this.conferenceFocusUser) {
        return 1;
      }

      return this.currentLayout;
    },
    // TODO 可以缓存到 conferenceManager 里面
    computedFocusVideoParticipant: function computedFocusVideoParticipant() {
      if (this.currentLayout === 0) {
        console.log('computedSpeakingParticipant null');
        return null;
      }

      var sp;

      if (this.conferenceFocusUser && !this.conferenceFocusUser._isVideoMuted) {
        sp = this.conferenceFocusUser;
      } else if (this.conferenceLocalFocusUser && !this.conferenceLocalFocusUser._isVideoMuted) {
        sp = this.conferenceLocalFocusUser;
      } else if (this.speakingVideoParticipant) {
        sp = this.speakingVideoParticipant;
      } else {
        sp = this.participantUserInfos.find(function (u) {
          return !u._isAudience && !u._isVideoMuted && u._isScreenSharing === true;
        });

        if (!sp) {
          sp = this.participantUserInfos.find(function (u) {
            return !u._isAudience && !u._isVideoMuted;
          });
        }
      }

      if (conferenceManager.currentFocusUser) {
        this.session.setParticipantVideoType(conferenceManager.currentFocusUser.uid, conferenceManager.currentFocusUser._isScreenSharing, VideoType.SMALL_STREAM);
      }

      if (sp) {
        conferenceManager.currentFocusUser = sp;
        this.session.setParticipantVideoType(conferenceManager.currentFocusUser.uid, conferenceManager.currentFocusUser._isScreenSharing, VideoType.BIG_STREAM);
      } else {
        if (this.session.screenSharing) {
          sp = this.selfUserInfo;
        }
      }

      console.log('computedSpeakingParticipant', sp);
      return sp;
    }
  },
  watch: {
    participantUserInfos: {
      deep: true,
      handler: function handler(infos) {
        var audioOnly = true; // console.log('participantUserInfos', this.session.screenSharing);

        if (this.session.screenSharing) {
          audioOnly = false;
        } else {
          for (var i = 0; i < this.participantUserInfos.length; i++) {
            var u = this.participantUserInfos[i];

            if (!u._isAudience && !u._isVideoMuted) {
              audioOnly = false;
              break;
            }
          }
        }

        this.audioOnly = audioOnly; // mute self audio

        var ref = this.$refs[this.selfUserInfo.uid + '-audio'];

        if (ref && ref.length > 0) {
          this.$refs[this.selfUserInfo.uid + '-audio'][0].muted = true;
        }

        if (this.audioOnly) {
          return;
        } // 宫格布局


        if (this.currentLayout === 0) {
          var start = this.currentGridPageIndex * this.participantCountPerGridPage;
          var end = start + this.participantCountPerGridPage > this.participantUserInfos.length ? this.participantUserInfos.length : start + this.participantCountPerGridPage;
          var count = end - start;
          var width = '100%';
          var height = '100%';

          if (count <= 1) {
            width = '100%';
            height = '100%';
          } else if (count <= 4) {
            width = '50%';
            height = '45%';
          } else if (count <= 9) {
            width = '33%';
            height = '33%';
          } else {
            // max 16
            width = '25%';
            height = '25%';
          }

          if (this.$refs.rootContainer) {
            this.$refs.rootContainer.style.setProperty('--participant-video-item-width', width);
            this.$refs.rootContainer.style.setProperty('--participant-video-item-height', height);
          }
        }
      }
    },
    currentPageParticipants: {
      deep: true,
      handler: function handler(infos) {
        if (this.audioOnly) {
          return;
        }

        if (this.currentLayout === 0) {
          var count = this.currentPageParticipants.length;
          var width = '100%';
          var height = '100%';

          if (count <= 1) {
            width = '100%';
            height = '100%';
          } else if (count <= 4) {
            width = '50%';
            height = '45%';
          } else if (count <= 9) {
            width = '33%';
            height = '33%';
          } else {
            // max 16
            width = '25%';
            height = '25%';
          }

          if (this.$refs.rootContainer) {
            this.$refs.rootContainer.style.setProperty('--participant-video-item-width', width);
            this.$refs.rootContainer.style.setProperty('--participant-video-item-height', height);
          }
        }
      }
    }
  },
  directives: {
    ClickOutside: ClickOutside
  },
  created: function created() {
    var _this8 = this;

    document.title = '在线会议';
    conferenceManager.setVueInstance(this);
    this.refreshUserInfoInternal = setInterval(function () {
      _this8.refreshUserInfos();
    }, 3 * 1000);
    this.$eventBus.$on('muteVideo', function (mute) {
      if (_this8.session.videoMuted !== mute) {
        var enable = _this8.session.videoMuted ? true : false;

        _this8.enableVideo(enable);
      }
    });
    this.$eventBus.$on('muteAudio', function (mute) {
      if (_this8.session.audioMuted !== mute) {
        var enable = _this8.session.audioMuted ? true : false;

        _this8.enableAudio(enable);
      }
    });
  },
  mounted: function mounted() {
    var _this9 = this;

    this.setupSessionCallback();

    if (isElectron()) {
      //
      // this.$on('stop-screen-share', () => {
      //     this.session.stopScreenShare();
      //     this.$forceUpdate();
      // })
      window.addEventListener("mousemove", function (event) {
        if (!_this9.session || !_this9.session.screenSharing) {
          return;
        }

        if (event.target.id === "main-content-container") {
          currentWindow.setIgnoreMouseEvents(true, {
            forward: true
          });
        } else {
          currentWindow.setIgnoreMouseEvents(false);
        }
      });
      window.addEventListener("mouseleave", function (event) {
        currentWindow.setIgnoreMouseEvents(false);
      });
      this.$refs.rootContainer.style.setProperty('--conference-container-margin-top', '30px');
    } else {
      this.$refs.rootContainer.style.setProperty('--conference-container-margin-top', '0px');
    }
  },
  destroyed: function destroyed() {
    var _this10 = this;

    // reset
    this.$set(this.selfUserInfo, '_stream', null);
    this.participantUserInfos.forEach(function (m) {
      return _this10.$set(m, "_stream", null);
    });
    clearInterval(this.refreshUserInfoInternal);
    this.$eventBus.$off('muteVideo');
    this.$eventBus.$off('muteAudio');
    this.conferenceManager.destroy();
  }
};"},null]}