{"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/UserEmployeeInviteInDialog.vue?vue&type=script&lang=js","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Employee/components/UserEmployeeInviteInDialog.vue","mtime":1734234639234},{"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 { AddUserEmplyeeApi,AddInviteDepartApi } 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 {
  inject:['permissions'],
  computed:{
    permissionsStr(){
        return this.permissions()
    }
  },
  props: ["showdialogIn"],
  watch: {
    showdialogIn() {
      this.dialogFormVisible = this.showdialogIn;
      this.defaulDataParent=[]
    },
    "formList.departId"(){
      if(this.formList.departId){
        this.$refs.ruleForm.clearValidate(['departId'])//清除验证
      }
    }
  },
  components: {
    selectTree //注册组件
  },
  data() {
    return {     
      title: "邀请入职",
      dialogFormVisible: this.showdialogIn,
      OperType: 0, //0 新增  1修改
      formList: {
        departId:'',
        occupationType:'Normal',
        endTime:''
      },
      rules: {       
        departId:[{required: true, message: "请选择入职部门", trigger: "blur"}],
        occupationType:[{required: true, message: "请选择职业类型", trigger: "change"}],
        endTime:[{required: true, message: "请选择链接有效截止日期", trigger: "blur"}],  
      },
      defaulDataParent:'',//上级部门默认回选数据
      defaulData:[],
      qrcodeShow:false,
      shareUrl:'',
      occupationTypeArr:[],
      departlabel:`入职${$SuperviseStr.depart}：`,
      getTreeDepartlist:[],
      homeTemplateBoradType:localStorage.getItem('homeTemplateBoradType')||'',
    };
  },
  mounted(){
     if(this.homeTemplateBoradType=='rtpayTemplate'){
         this.occupationTypeArr=[{label:'一般职员',value:'Normal'}]
     }else if(localStorage.getItem('appidSupervise')&&JSON.parse(localStorage.getItem('appidSupervise')).appId=='__d1qEDy3wYq8VF5KvUoE'){//监控端--机构用户管理
        this.occupationTypeArr=[{label:'一般职员',value:'Normal'},{label:'保安员',value:'SecurityGuard'},{label:'警官',value:'Police'}]
     }
     else{
         this.occupationTypeArr=[{label:'一般职员',value:'Normal'},{label:'保安员',value:'SecurityGuard'}]
     }
  },
  methods: { 
    selectClickT(val){
       console.log(val)
       this.getTreeDepartlist=val
    },    
    getTableRow(data, type) {       
      let newRowData = JSON.parse(JSON.stringify(data)); //拷贝一份存储对象
      this.formList = newRowData; //拷贝一份存储对象引用不同地址
      this.OperType = type;  
      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)
    },
    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  AddInviteDepartApi(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/#/employeeIn?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:showdialogIn", false);
      this.$nextTick(function () {
        this.$refs.ruleForm.resetFields(); //重置输入框提示
      });
    },
  },
};
"},null]}