{"remainingRequest":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js??vue-loader-options!/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Employee/components/UserEmployeeDutyDialog.vue?vue&type=script&lang=js","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Employee/components/UserEmployeeDutyDialog.vue","mtime":1737612804146},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/thread-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/babel-loader/lib/index.js","mtime":456789000000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
import selectTree from "@/components/SelectTree";
import {AddDutyApi,dutyListApi } from "@/api/staffApi.js"
import QRCode from 'qrcodejs2';
import Clipboard from 'clipboard'
export function validatePhone(rule,value,callback){//校验手机号
  setTimeout(() => {
     if (!/^[1][3,4,5,7,8,9][0-9]{9}$/.test(value)) {
      callback(new Error('请输入正确的手机号'))
    } else {
      callback()
    }
  }, 500);
}
export default {
  props: ["showdialogDuty", 'deptDataList'],
  watch: {
    showdialogDuty() {
      this.dialogFormVisible = this.showdialogDuty;
      this.defaulDataParent=[]
    },
    "formList.departId"(){
      if(this.formList.departId){
        this.$refs.ruleForm.clearValidate(['departId'])//清除验证
      }
    },
    deptDataList(v) {
      this.getTreeDepartlist = v
    }
  },
  components: {
    selectTree //注册组件
  },
  data() {
    return {     
      title: "邀请驻勤人员",
      dialogFormVisible: this.showdialogDuty,
      OperType: 0, //0 新增  1修改
      formList: {
        attendSiteId:'',
        departId:'',
        endTime:''
      },
      rules: {       
        attendSiteId:[{required: true, message: "请选择驻勤点", trigger: "blur"}],
        departId:[{required: true, message: `请选择入职${$SuperviseStr.depart}`, trigger: "blur"}],
        endTime:[{required: true, message: "请选择链接有效截止日期", trigger: "blur"}],  
      },
      defaulDataParent:'',//上级部门默认回选数据
      defaulData:[],
      qrcodeShow:false,
      shareUrl:'',
      dutylist:[],
      departlabel:`入职${$SuperviseStr.depart}：`,
      getTreeDepartlist:[],
    };
  },
  methods: {   
    selectClickT(val){
       this.getTreeDepartlist=val
    },   
    getTableRow(data, type) {       
      let newRowData = JSON.parse(JSON.stringify(data)); //拷贝一份存储对象
      this.formList = newRowData; //拷贝一份存储对象引用不同地址
      this.OperType = type; 
      this.dutyList()//获取驻勤点列表
      this.getTreeData(this.getTreeDepartlist)
    },
    checkChangeParent(key, data) {//selectTree组件-复选框选中的数据
        console.log(key)
        console.log(data)
        this.$set(this.formList,"departId",key)
        console.log(this.formList.departId)
    },
    checkChange(key, data) {//selectTree组件-复选框选中的数据
        // console.log(key)
        // console.log(data)
        // this.$set(this.formList,"allowedDepartIds",key)
    },
    dutyList(){//查询驻勤列表
        let obj2={domainId:this.$route.query.domainId} 
        dutyListApi(obj2).then(response=>{
            if(response.status==200){
              console.log(response)
              this.dutylist=response.data
              // this.dutylist.forEach(item=>{
              //   item.value=item.id
              //   item.label=item.attendSiteName
              // })
              // console.log(this.dutylist)
            }
        })
    },
    dutySelectChange(){
       this.dutylist.forEach(item=>{
           if(item.id==this.formList.attendSiteId){
             this.formList.attendSiteName=item.attendSiteName
           }
       })
    },
    getTreeData(arr){//递归遍历部门
        arr.forEach(item=>{
             item.label=item.name;
             item.value=item.id;
             if(item.children&&item.children.length<1){
                 item.children=undefined
             }else if(item.children&&item.children.length>0){
               this.getTreeData(item.children)  
             }
         })
    },  
    async qrCodeBtn(){//点击生成二维码-请求接口返回url
       //api接口位置
     let  orgData=new Promise((resolve,reject)=>{
         let obj2={domainId:this.$route.query.domainId}     
         this.$refs.ruleForm.validate((valid) => {
            if (valid) { 
           return  AddDutyApi(this.formList,obj2).then((response) => {
                  //新增
                  if (response.status==200) {
                    if(response.data){
                      console.log(1)
                      resolve(response.data)                      
                    }
                  }
                });
            }
          })
       })
      
      orgData.then(res=>{
         if(res){
            this.qrcodeShow=true  
            if(parent.location.origin){
              this.shareUrl=parent.location.origin+'/static/signon/staffMobile/#/duty?inviteDepartId='+res
            }
            this.$nextTick(()=>{
                document.getElementById("qrCode").innerHTML=""  
                new QRCode(this.$refs.qrCodeDiv,{
                  text:this.shareUrl,
                  width:200,
                  height:200,
                  colorDark: "#333333", //二维码颜色
                  colorLight: "#ffffff", //二维码背景色
                  correctLevel: QRCode.CorrectLevel.L//容错率，L/M/H
                })
            })
         }
      })
      
       
    },   
    downloadQrcode(){//下载二维码图片
       var img = document.querySelectorAll('#qrCode img')
        for(var i = 0; i < img.length; i++){
            var url = img[i].src
            var a = document.createElement("a");
            var event = new MouseEvent("click"); // 创建一个单击事件
            a.href = url;
            a.download = 'qr.png'// 图片名称
            a.dispatchEvent(event); // 触发a的单击事件
        }    
    },
    CopyclipboardUrl(){//复制邀请链接
      console.log(this.shareUrl)
      let link=this.shareUrl
      this.$nextTick(()=>{
          let clipboard=new Clipboard('.copyText', {
              text: function () {
                return link
              }
            });
            clipboard.on("success", e => {
                this.$message({
                  type: "success",
                  message: "复制成功，请到微信打开!"
                });
                clipboard.destroy(); // 释放内存
          });
          clipboard.on("error", e => {
              this.$message({
                type: "warning",
                message: "该浏览器不支持自动复制!"
              }); // 不支持复制
              clipboard.destroy(); // 释放内存
          });
      });
    },
    submitForm() {  
      // let credential={
      //   number:this.formList.number,
      //   type:this.formList.type
      // }
      // this.formList.credential=credential
      // console.log(this.formList)
      // let obj2={domainId:this.$route.query.domainId}     
      // this.$refs.ruleForm.validate((valid) => {
      //   if (valid) {          
      //       AddUserEmplyeeApi(this.formList,obj2).then((response) => {
      //         //新增
      //         if (response.status==200) {
      //           let newobj = JSON.parse(JSON.stringify(this.formList));
      //           this.$emit("refurlist", newobj); //确定后发送$emit绑定父数据
      //           this.cancelForm();
      //         }
      //       });          
      //   } else {
      //     return false;
      //   }
      // });
    },
    cancelForm() {
      this.qrcodeShow=false
      //取消关闭
      this.$emit("update:showdialogDuty", false);
      this.$nextTick(function () {
        this.$refs.ruleForm.resetFields(); //重置输入框提示
      });
    },
  },
};
"},null]}