{"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/views/StationEmployees.vue?vue&type=script&lang=js&","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-dispatch-mobile/src/views/StationEmployees.vue","mtime":1735821445610},{"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 { Search, List, Empty, Button, CheckboxGroup, Checkbox, Toast, Notify, ActionSheet, Cell } from "vant";
import Avatar from "@components/avatar.vue";
import { textSlice } from "@/api/common";
import { getEmployees } from "@/api/employee-controller";
import CurrentConversation from "@/components/timApp/conversation/current-conversation.vue";
import CallLayer from "@/components/timApp/trtc/calling-index.vue";
import CallingMembers from "@/components/timApp/trtc/calling-members.vue";
import tim from "@/tim";
import _webSocket from "@/utils/websocket";
import { mapState, mapActions } from "vuex";
import BlockCheckbox from "@/components/blockCheckbox/index.vue";

export default {
  name: "StationEmployees",
  components: {
    CallingMembers,
    CallLayer,
    CurrentConversation,
    [Search.name]: Search,
    [List.name]: List,
    [Empty.name]: Empty,
    [Checkbox.name]: Checkbox,
    [CheckboxGroup.name]: CheckboxGroup,
    [Button.name]: Button,
    [Toast.name]: Toast,
    [Notify.name]: Notify,
    [ActionSheet.name]: ActionSheet,
    [Cell.name]: Cell,
    Avatar,
    BlockCheckbox,
  },
  data() {
    return {
      keyword: "",
      employeeList: [],
      checked: false,
      memberList: [],
      loading: false,
      finished: false,
      pageIndex: 1,
      showConversation: false,
      callType: "video",
      groupCall: false,
      //调度类型：1视频调度 2 视频上拉：除了视频上拉传2，其他音频调度与视频调度都传1
      yardmanType: "1",
      stream: {
        audio: true,
        video: true,
      },
      callingMembersVisible: false,
      showFilter: false,
      result: [],
      onDuty: [],
      stationTypes: [],
    };
  },
  computed: {
    ...mapState({
      roomId: (state) => state.trtc.roomId,
      allStationTypes: (state) => state.app.stationTypes,
      sysUserInfo: (state) => state.user.sysUserInfo,
    }),
    stationId() {
      return this.$route.query.stationId;
    },
    selectedCount() {
      return this.employeeList.filter((x) => x.checked).length;
    },
    showAllSelect() {
      return this.employeeList.filter((item) => item.dutyStatus === "SignIn").length > 0;
    },
    stationType() {
      return this.$route.query.stationType;
    },
  },
  methods: {
    ...mapActions(["setAllStationTypes"]),
    //ws初始化
    initWs() {
      const dispatchToken = localStorage.getItem("dispatchToken");
      if (!dispatchToken) return false;
      this.webSocketUrl = `/websocket/police_incidents?dispatchToken=${dispatchToken}`;
      this.ws = _webSocket({
        url: this.webSocketUrl,
        onMessage: this.onMessage,
        heart: {
          timer: 5000,
          message: "keep alive",
        },
        isReconnect: true,
        //onClose: this.onClose,
      });
    },
    onClose() {
      this.initWs();
    },
    onMessage(evt) {
      // console.log("ws data ===", evt);
      if (evt) {
        if (evt.data.includes("keep alive")) {
          //心跳
        } else {
          const data = JSON.parse(evt.data);
          console.log("ws data ===", data);
          const { type, message } = data;
          if (type === "PoliceIncidents") {
            const content = message.contents[0];
            if (content.category === "Sos") {
              // TODO 处理SOS
            } else {
              // TODO 处理警情上报
            }
          } else if (type === "TRTC") {
            const content = message.contents[0];
            console.log(content);
            const { action, tencentUserId, roomId } = content;
            // 如果不是本人的房间直接忽略
            if (this.roomId && roomId.toString() === this.roomId.toString()) {
              if (action === "handUp" || action === "cheese") {
                // this.$message.info("有1人举手");
                Toast({
                  message: "有1人举手",
                  position: "top",
                  icon: require("@/assets/images/conversation/移动端举手.png"),
                });
              }
              this.memberList.forEach((member) => {
                if (member.tencentUserId === tencentUserId) {
                  member.action = action;
                }
              });
              console.log(this.memberList);
            }
          }
        }
      }
    },
    onSearch() {
      this.initLoading();
      this.onLoad();
    },
    initLoading() {
      this.pageIndex = 1;
      this.employeeList = [];
      this.finished = false;
    },
    getStationIds() {
      if (this.stationId) {
        return this.stationId.split(",");
      }
    },
    onLoad() {
      this.loading = true;
      let responsibleOfStationIds;
      if (this.sysUserInfo.orgInstitutional === "0201" && this.result.length > 0) {
        responsibleOfStationIds = this.result.includes("a") ? null : [...this.getStationIds()];
      } else {
        responsibleOfStationIds = null;
      }
      let onDutyValue = null;
      if (this.onDuty[0] === true && this.onDuty[1] === false) {
        onDutyValue = null;
      } else if (this.onDuty[0] === true) {
        onDutyValue = true;
      } else if (this.onDuty[0] === false) {
        onDutyValue = false;
      }
      getEmployees({
        pageIndex: this.pageIndex,
        pageSize: 10,
        searchModel: "SecurityStation",
        securityStationIds: [...this.getStationIds()],
        keyword: this.keyword,
        deskTypes: this.$route.query.stationType === "TemporarySecurity" ? ["TemporarySecurity"] : ["Normal", "Proprietor"],
        onDuty: onDutyValue,
        stationTypes: this.stationTypes,
        responsibleOfStationIds: responsibleOfStationIds,
      })
        .then((res) => {
          this.employeeList = [...this.employeeList, ...this.resetEmployeeList(res)].map((x) => {
            return {
              dutyStatus: "",
              dutyStatusText: "",
              isSecurity: x.rts.includes("Security"),
              isTemporarySecurity: x.rts.includes("Security") && x.rts.includes("TemporarySecurity"),
              ...x,
            };
          });
          // 加载状态结束
          this.loading = false;
          // 数据全部加载完成
          if ([...res].length <= 0) {
            this.finished = true;
          } else {
            this.pageIndex++;
          }
        })
        .catch((err) => {
          console.log(err);
        })
        .finally(() => {
          if (this.employeeList.length > 5) {
            this.$nextTick(() => {
              this.scrollToBottom();
            });
          }
        });
    },
    scrollToBottom() {
      const container = this.$refs.results.$el;
      console.log(container);
      container.scrollTop = container.scrollHeight;
    },
    // 重置字段
    resetEmployeeList(list) {
      return list.map((item) => {
        item.active = false;
        item["nameSlice"] = item.name.slice(-2);
        item["idCardNoHide"] = this.parseStringToStar(item.idCardNo);
        item["idVisible"] = false;
        item["contactHide"] = this.parseStringToStar(item.contact);
        item["concatVisible"] = false;
        item["companyNameSlice"] = textSlice(item.companyName);
        item["securityStationNameSlice"] = textSlice(item.securityStationName);
        item["type"] = "employee";
        item["isPhone"] = false;
        item["isIdCardNo"] = false;
        item["checked"] = false;
        return item;
      });
    },
    parseStringToStar() {
      return "**************";
      // return str.length > 2 ? str.substr(0, 2) + new Array(str.length - 2).join("*") + str.substr(-2) : str;
    },
    select(item) {
      const { dutyStatus, checked } = item;
      if (dutyStatus === "SignIn") {
        item.checked = !checked;
      }
    },
    handleCheckAll(value) {
      console.log(value);
      //  this.resResult.forEach((item) => (item.checked = value));
      this.employeeList.forEach((employee) => {
        const { dutyStatus } = employee;
        if (dutyStatus === "SignIn") {
          employee.checked = value;
        }
      });
    },
    toEmployee(item) {
      this.$router.push({
        path: "/employeeInfo",
        query: {
          queryId: item.id,
        },
      });
    },
    dispatch(type) {
      console.log(type);
      const memberList = this.employeeList.filter((x) => x.checked);
      this.onDispatch({ type, memberList });
    },
    initCalling(groupCall) {
      return new Promise((resolve) => {
        this.groupCall = groupCall;
        resolve();
      });
    },
    /**
     * @调度前参数设置
     * @param type
     * @returns {Promise<void>}
     */
    setCallProps(type) {
      if (type === "video") {
        this.stream.video = true;
        this.stream.audio = true;
        this.callType = "video";
        this.yardmanType = "1";
      } else if (type === "audio") {
        this.stream.video = false;
        this.stream.audio = true;
        this.callType = "audio";
        this.yardmanType = "1";
      } else if (type === "videoLocalMute") {
        this.stream.video = false;
        this.stream.audio = true;
        this.callType = "video";
        this.yardmanType = "2";
      }
      return Promise.resolve();
    },
    /**
     * @多人调度
     * @param type
     * @param memberList
     */
    onDispatch({ type, memberList }) {
      this.memberList = [...memberList];
      this.memberList.forEach((member) => {
        member.state = "CONNECTING";
        member.action = "";
      });
      if (this.memberList.length > 0) {
        this.setCallProps(type).then(() => {
          this.startVideoDispatch(this.memberList.length > 1);
        });
      } else {
        Toast.fail("至少选择一名被调度人");
      }
    },
    startVideoDispatch(groupCall) {
      // this.$bus.$emit("video-call");
      this.initCalling(groupCall).then(() => {
        // this.$refs.callLayer.showCalling = true;
        this.$bus.$emit("video-call");
      });
    },
    videoLocalMuteCall() {
      this.memberList = [this.employee];
      this.allMembers = [];
      this.memberList.forEach((member) => {
        member.state = "CONNECTING";
        member.action = "";
        // member.id = member.employeeId
      });
      this.stream.video = false;
      this.stream.audio = true;
      this.yardmanType = "2";
      this.callType = "video";
      return Promise.resolve();
    },
    videoLocalMute() {
      console.log("上拉", this.info);
      this.videoLocalMuteCall().then(() => {
        this.$bus.$emit("video-call");
      });
    },
    /**
     * @视频调度1v1
     */
    dispatchOneVideo() {
      this.memberList = [this.employee];
      this.memberList.forEach((member) => {
        member.state = "CONNECTING";
        member.action = "";
      });
      this.setCallProps("video").then(() => {
        this.startVideoDispatch(false);
      });
    },
    /**
     * @语音调度1v1
     */
    dispatchOneAudio() {
      this.memberList = [this.employee];
      this.memberList.forEach((member) => {
        member.state = "CONNECTING";
        member.action = "";
      });
      this.setCallProps("audio").then(() => {
        this.startVideoDispatch(false);
      });
    },
    openGroupFormDialog() {
      console.log(this.employeeList);
      const members = this.employeeList.filter((x) => x.checked);
      if (members.length > 0) {
        if (members.length > 1) {
          // 群聊
          this.createGroupConversation(members);
        } else {
          // 单人聊天
          this.character(members[0]);
        }
      } else {
        Toast.fail("至少选择一名被调度人");
      }
    },
    /**
     * @文字调度事件-单人
     */
    character(info) {
      const { tenantImUserId } = info;
      tim.getConversationProfile(`C2C${tenantImUserId}`).then(({ data }) => {
        console.log("getConversationProfile---", data);
        this.$store.commit("updateCurrentConversation", {
          ...data.conversation,
          ...{
            info,
          },
        });
        const { conversationID } = data.conversation;
        this.$store.dispatch("getMessageList", conversationID);
        this.showConversation = true;
      });
    },
    /**
     * @设置群聊创建条件
     * @param members
     * @returns {{memberList: *}}
     */
    getOptions(members) {
      return {
        type: this.TIM.TYPES.GRP_WORK,
        name: "指挥调度",
        memberList: members.map(({ tenantImUserId }) => {
          return { userID: tenantImUserId + "" };
        }),
      };
    },
    /**
     * @创建IM文字群聊
     * @param members
     */
    createGroupConversation(members) {
      console.log(members);
      const groupOptions = this.getOptions(members);
      tim
        .createGroup({ ...groupOptions })
        .then((imResponse) => {
          Toast.success(`群组：【${imResponse.data.group.name}】创建成功`);
          this.showGroupConversation(imResponse.data);
        })
        .catch((error) => {
          Toast.fail(error.message);
        });
    },
    /**
     * @打开群聊弹框
     * @param group
     */
    showGroupConversation({ group }) {
      console.log("group data ===", group);
      tim.getConversationProfile(`GROUP${group.groupID}`).then(({ data }) => {
        console.log(data);
        this.$store.commit("updateCurrentConversation", data.conversation);
        const { conversationID } = data.conversation;
        this.$store.dispatch("getMessageList", conversationID);
        console.log(this.currentConversation);
        this.showConversation = true;
      });
    },
    showMembers() {
      // 可选择的人就是调度弹框内的人，checked的人是已经在调度的人，active的人就是要加入调度的人
      console.log(this.employeeList);
      this.callingMembersVisible = true;
    },
    sendVideoRoomMsg(roomId, memberList, UseList) {
      this.callingMembersVisible = false;
      this.$refs.callLayer.sendRoomMessage(roomId, memberList, UseList);
    },
    onCloseCalling() {
      this.callingMembersVisible = false;
    },
    handleClose() {
      this.onSearch();
    },
    getStationTypesName(stationType) {
      if (!stationType) return "";
      if (this.allStationTypes.length <= 0) return "";
      let stationTypesName = "";
      const type = this.allStationTypes.filter((item) => item.code === stationType);
      if (type && type.length > 0) {
        stationTypesName = type[0].name;
      }
      return stationTypesName;
    },
  },
  created() {
    this.setAllStationTypes();
    this.onLoad();
    this.initWs();
  },
};
"},null]}