{"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/components/personnelDialog/index.vue?vue&type=script&lang=js","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/components/personnelDialog/index.vue","mtime":1725615668395},{"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 { SearchDepartmentsListEmplyeeApi, employeeTableListApi } from "@/api/staffApi.js"
export default {
  components:{
    selectTree
  },
  props: ["tableData"],
  watch:{
    tableData(val){
      console.log("val",val)
    },
    inputVal(val){
      console.log(val)
      this.params.keyword = val
      this.params.pageIndex = 1
      this.getDataList()
    },
    searchVal(val){
      console.log(val)
      this.params.keyword = val
      this.params.pageIndex = 1
      this.tableDataList()
    }
  },
  computed:{
     data(){
       let searchValue=this.search
       if(searchValue){
        //  return this.tableData.filter(item=>{
        //    return Object.keys(item).some(its=>{
        //      return String(item[its]).toLowerCase().indexOf(searchValue)>-1
        //    })
        //  })
        console.log(this.tableData)
        let treeData=this.tableData
        
        let handleTreeData=this.handleTreeData(treeData,searchValue)
        // return
        console.log(handleTreeData)
        this.setExpandRow(handleTreeData)
        console.log(this.expandRow)
        this.expandRow=this.expandRow.join(",").split(",")//返回数组id ['id1','id2']
        return handleTreeData  //匹配返回过滤查询到的父子树数据
       }
       console.log(this.tableData)
       return this.tableData //没匹配返回全部
     }
  },
  data(){
    return {
      showdialogpersonnel:false,//dialog弹窗
      activeName:'first',
      tags: [],//已选择人员
      employeeList:[],//人员列表
      checkAll:false,//人员是否全选 
      department:'',//部门名称
      inputVal:'',//人员搜索
      searchVal:'',
      search:'',
      defaultProps: {
        children: 'children',
        label: 'name'
      },
      expandRow: [],
      params:{//搜索条件
            pageIndex:1,
            pageSize:10,
            keyword:'',             
            total:0,
      },
      title:'选择' + $SuperviseStr.employee,
      lable1:'按' + $SuperviseStr.depart,
      lable2:'按' + $SuperviseStr.employee,
      titlename:$SuperviseStr.depart+"：",
      placeholder:'请输入' + $SuperviseStr.depart,
    }
  },
  methods:{
    // 弹窗初始化
    SelectpopUp(value){
      this.showdialogpersonnel = true
      this.activeName = 'first'
      // console.log("value",value)
      this.tags = value
      this.department = ''
      this.searchVal = ''
      this.inputVal = ''
      this.search = ''
      this.titlename = $SuperviseStr.depart+"："
      this.params = {//搜索条件
            pageIndex:1,
            pageSize:10,
            keyword:'',             
            total:0,
      },
      this.employeeList = []
    },
    // 选项卡切换
    handleClick(tab, event){
      console.log(this.activeName)
      this.inputVal = ''
      this.searchVal = ''
      this.search = ''
      this.employeeList = []
      this.checkAll = false
      this.titlename = $SuperviseStr.depart+"："
      $SuperviseStr.depart+"："
      this.params = {
        pageIndex:1,
        pageSize:10,
        keyword:'',             
        total:0,
      };
      if(this.activeName == 'second'){
        this.getDataList()
      }
    },
    // 关闭 Tag标签
    handle(item){
      console.log(item)
      let index = this.tags.findIndex(data => {
         return data.id == item.id
      })
      // this.$set(this.tags[index],"checkStatus",false)
      this.employeeList.forEach(data => {
        if(data.id == item.id){
          this.$set(data,"checkStatus",false)
        }
      })
      this.ischeckedAll()
      this.tags.splice(index,1)  
    },
    // 根据人员获取人员列表
    getDataList(){
      console.log("params",this.params)
        employeeTableListApi(this.params).then(res => {
          // 切换选项卡过快会赋值问题
          if(this.activeName == 'first'){
            return
          }
          if(res.data&&res.data.data){
              this.employeeList=res.data.data
              this.params.total=res.data.total
              // 先绑定checkStatus值
              this.employeeList.forEach(item => {
                this.$set(item,'checkStatus',false)
              })
              console.log(this.tags)
              // console.log(this.employeeList)
              // 与选中人员匹配，相同值设为选中
              this.tags.forEach(item => {
                this.employeeList.forEach(item1 => {
                  if(item.id == item1.id){
                    this.$set(item1,"checkStatus",true)
                  }
                })
              })
              this.ischeckedAll()
            
            console.log(this.employeeList)
          }
        })
      
    },
    // 根据部门获取人员列表
    tableDataList(){
      SearchDepartmentsListEmplyeeApi(this.params).then(res => {
        console.log(res.data&&res.data.data)
        if(res.data&&res.data.data){
              this.employeeList=res.data.data
              this.params.total=res.data.total
              // 先绑定checkStatus值
              this.employeeList.forEach(item => {
                this.$set(item,'checkStatus',false)
              })
              console.log(this.tags)
              // console.log(this.employeeList)
              // 与选中人员匹配，相同值设为选中
              this.tags.forEach(item => {
                this.employeeList.forEach(item1 => {
                  if(item.id == item1.id){
                    this.$set(item1,"checkStatus",true)
                  }
                })
              })
              this.ischeckedAll()
            
            console.log(this.employeeList)
          }
      })
    },
    // 关闭弹窗
    handleClose(){
      this.showdialogpersonnel = false
    },
    // 全选
    handleCheckAllChange(val){
      console.log(val)
      if(this.checkAll){
        this.employeeList.forEach(item => {
          if(!item.checkStatus){
            this.$set(item,"checkStatus",true)
            this.tags.push(item)
          }
        })
      }else{
        this.employeeList.forEach(item => {
          let index = this.tags.findIndex(item1 => {
            return item.id == item1.id
          })
          if(index>=0){
            this.tags.splice(index,1)
          }
          // item.checkStatus = false
          this.$set(item,"checkStatus",false)
          // this.tags.splice(this.tags.indexOf(item), 1)
        })
      }
    },
    // checkedBox选项
    handleCheckedChange(item){
      console.log(item)
      console.log(this.employeeList)
      if(item.checkStatus){
        this.tags.push(item)
      }else{
        
        let index =  this.tags.findIndex(data => {
          return item.id == data.id
        })
        this.tags.splice(index,1)
      }
      this.ischeckedAll()
    },
    handleCurrentChange(val) {
        console.log(this.params)
        //分页切换页码
        console.log(val);
        this.params.pageIndex = val;
        if(this.activeName == 'first'){
          this.tableDataList()
        }else{
          this.getDataList();
        }
        
    },
    handleSizeChange(val) {
        //切换每页条数
        console.log(val);
        this.params.pageIndex=1 //重置第一页
        this.params.pageSize = val;
        this.getDataList();
    },
    // 是否全选
    ischeckedAll(){
      if(this.employeeList.length>0){
        this.checkAll = this.employeeList.every(data => {
          return data.checkStatus
        })
      }else{
        this.checkAll = false
      }
    },
    // 已选人员清除
    deleteAll(){
      this.tags = []
      this.employeeList.forEach(item => {
        this.$set(item,"checkStatus",false)
        // this.$refs.multipleTable.toggleRowSelection(item,false);
      })
      this.checkAll = false
    },
    //树形表格过滤
    handleTreeData(treeData, searchValue){
      // debugger
      if(!treeData||treeData.length==0) return [];
      const array=[];
      for(let i=0;i<treeData.length;i++){
              let match=false;
              for(let pro in treeData[i]){
                if(typeof(treeData[i][pro])=='string'){
                  match |=treeData[i][pro].includes(searchValue);
                  if(match) break;
                }
              }
              if(this.handleTreeData(treeData[i].children,searchValue).length>0||match){
                array.push({...treeData[i],children:this.handleTreeData(treeData[i].children,searchValue)})                
              }              
      } 
      console.log(array)
      return array;
    },
     //将过滤好的树形数据展开
    setExpandRow(handleTreeData){
       if(handleTreeData.length){
          for(let i of handleTreeData){
             this.expandRow.push(i.id)
             if(i.children.length){
               this.setExpandRow(i.children)
             }
          }
       }
    }, 
    // 点击节点查询部门人员
    nodeClick(val){
      console.log(val)
      this.params.departIds = [val.id]
      this.params.pageIndex = 1
      this.params.pageSize = 10
      this.searchVal = ''
      this.department = val.name
      this.titlename = $SuperviseStr.depart+"：" + this.department
      this.tableDataList()
    },
    confirm(){
      this.showdialogpersonnel = false
      let tags = this.tags.length>0 ? JSON.parse(JSON.stringify(this.tags)) : []
      this.$emit("SelectedList",tags)
    },
    
  }
    
}
"},null]}