{"remainingRequest":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/node_modules/babel-loader/lib/index.js!/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/node_modules/cache-loader/dist/cjs.js??ref--1-0!/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/node_modules/vue-loader/lib/index.js??vue-loader-options!/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/src/components/timApp/trtc/calling-index.vue?vue&type=script&lang=js&","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/src/components/timApp/trtc/calling-index.vue","mtime":1735983065218},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/babel.config.js","mtime":1703661155587},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/node_modules/babel-loader/lib/index.js","mtime":456789000000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/node_modules/vue-loader/lib/index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "vant/es/toast/style/less";
import _Toast from "vant/es/toast";
import "vant/es/icon/style/less";
import _Icon from "vant/es/icon";
import "vant/es/radio/style/less";
import _Radio from "vant/es/radio";
import "vant/es/radio-group/style/less";
import _RadioGroup from "vant/es/radio-group";
import "vant/es/nav-bar/style/less";
import _NavBar from "vant/es/nav-bar";
import "vant/es/popup/style/less";
import _Popup from "vant/es/popup";
import "core-js/modules/es.array.push.js";
import rtc from "@/components/mixins/rtc";
import { getRooms, leave } from "@/api/room-controller";
import { exitRoom, sendVideoRoomMsg } from "@/api/bcxin/identify";
import Avatar from "@components/avatar.vue";
import { mapState } from "vuex";
import dayjs from "dayjs";
import duration from "dayjs/plugin/duration";
dayjs.extend(duration);
export default {
  name: "CallLayer",
  components: {
    Avatar,
    [_Popup.name]: _Popup,
    [_NavBar.name]: _NavBar,
    [_RadioGroup.name]: _RadioGroup,
    [_Radio.name]: _Radio,
    [_Icon.name]: _Icon,
    [_Toast.name]: _Toast
  },
  mixins: [rtc],
  props: {
    visible: Boolean,
    groupCall: Boolean,
    // 是否多人模式
    memberList: {
      type: Array,
      default() {
        return [];
      }
    },
    allMembers: {
      // 除调度人外所有可选的参与者
      type: Array,
      default() {
        return [];
      }
    },
    type: {
      type: String,
      default: "video",
      validate: value => {
        return ["video", "audio"].includes(value);
      }
    },
    audio: {
      type: Boolean,
      default: true
    },
    video: {
      type: Boolean,
      default: true
    },
    yardmanType: {
      // 调度类型：1视频调度 2 视频上拉：除了视频上拉传2，其他音频调度与视频调度都传1
      type: String,
      default: "1"
    }
  },
  data() {
    return {
      dialling: false,
      // 是否拨打电话中
      calling: false,
      // 是否通话中
      isDialled: false,
      // 是否被呼叫
      currentDatetime: "00:00",
      startTime: null,
      timer: null,
      layout: 3,
      showLayout: false,
      diallingTime: 0,
      // 1V1拨号倒计时
      diallingTimer: null,
      // 1V1拨号倒计时定时器
      roomId: "",
      allMembersTimer: null
    };
  },
  computed: {
    ...mapState({
      currentUserProfile: state => state.user.currentUserProfile,
      userID: state => state.user.userID,
      userSig: state => state.user.userSig,
      sdkAppID: state => state.user.sdkAppID,
      sysUserInfo: state => state.user.sysUserInfo
    }),
    title() {
      return "紧急呼叫中";
    },
    showCalling: {
      get() {
        return this.dialling || this.calling || this.isDialled;
      },
      set(value) {
        this.dialling = value;
        this.calling = value;
        this.isDialled = value;
      }
    },
    memberListSort() {
      return [...this.memberList].sort((a, b) => {
        var _a$state;
        return a === null || a === void 0 || (_a$state = a.state) === null || _a$state === void 0 ? void 0 : _a$state.localeCompare(b === null || b === void 0 ? void 0 : b.state);
      });
    }
  },
  watch: {
    memberList: {
      handler(value) {
        if (value.length > 0) {
          this.layout = 3;
          if (value.length >= 3) {
            this.layout = 6;
            if (value.length >= 6) {
              this.layout = 9;
            }
          }
          /**
           * 调度通讯中以下几种情况，调度窗口直接关闭：
           * 第一、全员接听后都挂断
           * 第二、全员都被移除
           * 第三、全员全部超时未接听
           * 第四、调度窗口中，只剩调度员一个
           */
          const offlineMembers = [...value].filter(x => x.state === "DISCONNECTED").length;
          console.log("offline members", offlineMembers, value.length);
          if (offlineMembers >= value.length && (this.calling || this.dialling)) {
            this.onClose();
          }
        }
      },
      deep: true,
      immediate: true
    },
    /**
     * @一对一被调度方没有接的话1分钟后调度方直接结束
     * @param value
     */
    diallingTime(value) {
      if (value && value >= 60 /* && process.env.VUE_APP_ENV !== "development" */) {
        this.onClose();
      }
    }
  },
  methods: {
    onOpen() {
      this.startTime = new Date();
      this.setTimer();
    },
    onClose() {
      this.showCalling = false;
    },
    handleLeave() {
      this.endDialingTimeCounting();
      this.endMemberTimer();
      this.endCurrentTimer();
      this.leave().then(async () => {
        try {
          await exitRoom({
            roomNo: this.roomId
          });
          this.close();
        } catch (error) {
          console.error("leave room error", error);
          this.addFailedLog(`Leave room failed. Error: ${error.message}`);
          // this.reportFailedEvent("leaveRoom", error);
          throw error;
        }
      });
    },
    close() {
      leave(this.roomId).then(res => {
        console.log(res);
        const memberList = this.memberList.map(x => {
          return {
            ...x,
            state: "CONNECTING",
            action: "",
            timer: 0,
            timeout: false,
            beKickOut: false,
            hangup: false
          };
        });
        this.$emit("update:memberList", memberList);
        // this.$store.commit("TOGGLE_DISPATCHING", false);
        this.$store.commit("SET_ROOM_ID", null);
        this.$emit("close");
      });
    },
    timeFormat(hours, minutes, seconds) {
      if (hours > 0) {
        if (hours < 10) {
          hours = "0" + hours;
        }
        if (minutes < 10) {
          minutes = "0" + minutes;
        }
        if (seconds < 10) {
          seconds = "0" + seconds;
        }
        return hours + ":" + minutes + ":" + seconds;
      } else {
        if (minutes > 0) {
          if (minutes < 10) {
            minutes = "0" + minutes;
          }
          if (seconds < 10) {
            seconds = "0" + seconds;
          }
          return minutes + ":" + seconds;
        } else {
          if (seconds < 10) {
            seconds = "0" + seconds;
          }
          return "00:" + seconds;
        }
      }
    },
    setTimer() {
      this.timer = setTimeout(() => {
        const x = dayjs();
        const y = dayjs(this.startTime);
        const currentHour = dayjs.duration(x.diff(y)).get("hours");
        const currentMin = dayjs.duration(x.diff(y)).get("minutes");
        const currentSecond = dayjs.duration(x.diff(y)).get("seconds");
        this.currentDatetime = this.timeFormat(currentHour, currentMin, currentSecond);
        this.setTimer();
      }, 1000);
    },
    /**
     * @后台拨号接口
     * @param roomId
     * @param MemberList
     * @param UseList
     */
    sendRoomMessage(roomId, MemberList, UseList) {
      const userInfo = localStorage.getItem("userInfo");
      if (userInfo) {
        const user = JSON.parse(userInfo);
        const params = {
          RoomNo: roomId,
          //房间
          type: this.type,
          //video or audio
          MemberList,
          name: user.name,
          //调度者名称
          Yardman_Name: user.tencentUserId,
          //调度者名称
          Yardman_Task_Name: "个人调度",
          //调度任务名称
          Yardman_Type: this.yardmanType,
          //调度类型：1视频调度 2 视频上拉：除了视频上拉传2，其他音频调度与视频调度都传1
          yardmanType: this.yardmanType,
          //调度类型：1视频调度 2 视频上拉：除了视频上拉传2，其他音频调度与视频调度都传1
          Yardman_Task_Explain: "任务说明",
          //调度任务说明，非必填
          // Transcriber: "", //录制人员cid,多个逗号隔开，非必填
          Originator: user.tencentUserId + ";" + user.tencentUserId,
          //发起人cid;useid
          //被调度视频人员,跟MemberList一一对应uid;employeeid;organizationId;name;type,...
          UseList,
          ComId: user.organizationId //调度者公司id
        };
        // 后端去给被调度者的app拨号
        sendVideoRoomMsg(params).then(res => {
          console.log(res);
        });
      }
    },
    /**
     * @1v1或者视频上拉时，计算拨号时长
     */
    startDialingTimeCounting() {
      if (this.yardmanType === "2" || this.memberList.length < 2) {
        this.diallingTimer = setInterval(() => {
          this.diallingTime += 1;
        }, 1000);
      }
    },
    /**
     * @结束拨号计时
     */
    endDialingTimeCounting() {
      if (this.diallingTimer) {
        clearInterval(this.diallingTimer);
        this.diallingTimer = null;
        this.diallingTime = 0;
      }
    },
    /**
     * @结束成员计时
     */
    endMemberTimer() {
      if (this.allMembersTimer) {
        clearInterval(this.allMembersTimer);
        this.allMembersTimer = null;
      }
    },
    /**
     * @结束显示计时
     */
    endCurrentTimer() {
      this.currentDatetime = "00:00";
      if (this.timer) {
        clearTimeout(this.timer);
        this.timer = null;
      }
    },
    async videoCalling() {
      const userInfo = localStorage.getItem("userInfo");
      let roomUsers = [];
      if (userInfo) {
        const user = JSON.parse(userInfo);
        console.log(user);
        roomUsers.push({
          employeeId: user.employeeId,
          organizationId: user.organizationId,
          tencentUserId: user.tencentUserId,
          securityStationId: "",
          superviseDepartId: "",
          sponsor: true
        });
        getRooms({
          roomUsers: roomUsers.concat(this.memberList.map(x => {
            return {
              employeeId: x.id,
              organizationId: x.organizationId,
              tencentUserId: x.tencentUserId,
              securityStationId: x.securityStationId,
              superviseDepartId: x.superviseDepartId,
              sponsor: false
            };
          })),
          communicatedType: this.type === "video" ? "Video" : "Audio",
          //新增传参
          yardmanType: this.yardmanType,
          //调度类型：1视频调度 2 视频上拉：除了视频上拉传2，其他音频调度与视频调度都传1
          deskType: this.$route.query.stationType === "TemporarySecurity" ? "TemporarySecurity" : "Normal"
        }).then(async res => {
          const {
            id,
            roomUsers
          } = res;
          console.log(id);
          if (id <= 0) {
            this.addFailedLog(`被调度人所在企业联动值不足, 无法进行调度。`);
            return false;
          } else {
            this.dialling = true; // 拨号中
            // 1v1或者视频上拉时，计算拨号时长
            this.startDialingTimeCounting();
            // 分别对所有参会人计时
            this.setAllMembersTimer();
            // 初始化客户端
            await this.initClient();
            this.roomId = id;
            this.$store.commit("SET_ROOM_ID", this.roomId);
            // 加入房间
            await this.join();
            await this.initLocalStream({
              audio: this.audio,
              video: this.video
            }); // 初始话本地流
            await this.playLocalStream(); // 播放本地流
            await this.publish(); // 发布本地流
            // let uidList = []//视频人员uid
            // const { mobilePhone, id, organizationId, deviceNumber, tencentUserId, name, cid, securityStationId, superviseDepartId } = item;
            // const item_cid = cid || tencentUserId
            // uidList.push(`${tencentUserId};${id};${organizationId};${name};${type}`)
            console.log("~~~~~user", user);
            console.log("~~~~~", this.memberList);
            const memberList = roomUsers.filter(item => item.cid && item.sponsor === false).map(x => {
              return x.cid;
            }).join(",");
            const UseList = this.memberList.map(x => {
              const {
                id,
                organizationId,
                tencentUserId,
                name
              } = x;
              // const item_cid = cid || tencentUserId
              // uidList.push(`${tencentUserId};${id};${organizationId};${name};${type}`)
              return `${tencentUserId};${id};${organizationId};${name};${this.type}`;
            }).join(",");
            this.sendRoomMessage(this.roomId, memberList, UseList);
          }
        }).catch(({
          response
        }) => {
          console.log(response);
          this.addFailedLog(`${response.data.message}`);
        });
      }
    },
    audioCalling() {},
    /**
     * @显示用户名的提示
     * @param id
     * @param message
     * @param err
     */
    userLog(id, message, err = false) {
      const user = this.memberList.find(member => member.tencentUserId === id);
      if (user) {
        console.log(user);
        if (err) {
          this.addFailedLog(`[${user.name}] ${message}`);
        } else {
          this.addSuccessLog(`[${user.name}] ${message}`);
        }
      }
    },
    addSuccessLog(message) {
      console.log(message);
      _Toast.success(message);
      // Notify({ type: 'success', message });
    },

    addFailedLog(message) {
      // Notify({ type: "danger", message });
      _Toast.fail(message);
    },
    handleMuteAudio() {
      if (this.isMutedAudio) {
        this.unmuteAudio();
      } else {
        this.muteAudio();
      }
    },
    handleMuteVideo() {
      if (this.isMutedVideo) {
        this.unmuteVideo();
      } else {
        this.muteVideo();
      }
    },
    showMembers() {
      // this.close();
      this.$emit("showMembers");
    },
    setAllMembersTimer() {
      this.allMembersTimer = setInterval(() => {
        this.memberList.forEach(member => {
          const hasKey = Object.prototype.hasOwnProperty.call(member, "timer");
          const beKickOut = member.beKickOut;
          if (!hasKey || beKickOut || member.state === "CONNECTED") {
            member.timer = 0;
          } else {
            console.log("现在的人员状态是。。", member.state);
            if (member.timer < 60 && member.state === "CONNECTING") {
              member.timer++;
              member.timeout = false;
            } else {
              console.log("进入了超时判断", member.state);
              if (member.state !== "DISCONNECTED") {
                member.timer = 0;
                member.timeout = true;
                member.state = "DISCONNECTED";
              }
            }
          }
        });
        this.$emit("update:memberList", JSON.parse(JSON.stringify(this.memberList)));
        console.log("%c memberList", "background: #00cc00; color: #fff; border-radius: 3px;padding:2px 5px", this.memberList);
      }, 1000);
    }
  },
  mounted() {
    this.$bus.$on("video-call", this.videoCalling); // 发起通话
    this.$bus.$on("audio-call", this.audioCalling); // 发起通话
  },

  beforeDestroy() {
    if (this.timer) {
      clearTimeout(this.timer);
      this.timer = null;
    }
    this.$bus.$off("video-call", this.videoCalling);
    this.$bus.$off("audio-call", this.audioCalling); // 发起通话
  }
};"},null]}