{"remainingRequest":"/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/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 { NavBar, Popup, RadioGroup, Radio, Icon, Toast } from "vant";
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) => {
        return a?.state?.localeCompare(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]}