130 lines
2.3 KiB
Vue
130 lines
2.3 KiB
Vue
<template>
|
|
<!-- 自定义表格 -->
|
|
<div class="tableBody">
|
|
<div class="tr" v-for="(item,index) in data" :key="index">
|
|
<div class="td tdUser">
|
|
<div :class="userChecked(userIds,item)?'userList':'userList userChecked'" @click="roleChecked(item)">
|
|
<div class="userName">
|
|
<div class="avatar">{{ userAvatar(item) }}</div>
|
|
<div class="name">{{item.name}}</div>
|
|
</div>
|
|
<div class="userBtn" v-if="!userChecked(userIds,item)"><el-icon-Check></el-icon-Check></div>
|
|
</div>
|
|
</div>
|
|
<template v-if="item.children && item.isOpen">
|
|
<treeDept class="td tdCom" :data="item.children" :userIds="userIds" @roleChecked="roleChecked" />
|
|
</template>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
name:'treeDept',
|
|
data() {
|
|
return {
|
|
size: "small",
|
|
isShow:true,
|
|
};
|
|
},
|
|
props:{
|
|
data:{
|
|
type:Array,
|
|
required: true
|
|
},
|
|
userIds:{
|
|
type:Array
|
|
}
|
|
},
|
|
watch:{
|
|
|
|
},
|
|
computed:{
|
|
|
|
},
|
|
methods:{
|
|
userAvatar(row) {
|
|
return row.name.substring(0, 1)
|
|
},
|
|
userChecked(arr,em){
|
|
return arr.indexOf(em.id)!=-1?false:true
|
|
},
|
|
roleChecked(em){
|
|
this.$emit('roleChecked',em);
|
|
},
|
|
openFile(item){
|
|
this.$nextTick(()=>{
|
|
item.isOpen = !item.isOpen;
|
|
})
|
|
}
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.tableBody .tr{
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: stretch;
|
|
justify-content: space-between;
|
|
.td{
|
|
padding: 3px 0 3px 12px;
|
|
}
|
|
.td:first-child{
|
|
border-left: 0;
|
|
}
|
|
.tdTitle{
|
|
display: flex;
|
|
justify-content: flex-start;
|
|
cursor: pointer;
|
|
.file{
|
|
width: 14px;
|
|
margin-right: 5px;
|
|
}
|
|
}
|
|
.tdUser{
|
|
.userList{
|
|
padding:4px 0 4px 12px;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
.userName{
|
|
flex: 1;
|
|
display: flex;
|
|
align-items: center;
|
|
cursor: pointer;
|
|
.avatar{
|
|
background: var(--el-text-color-disabled);
|
|
color: var(--el-color-white);
|
|
border-radius: 50%;
|
|
display: inline-block;
|
|
height: 21px;
|
|
width: 21px;
|
|
text-align: center;
|
|
line-height: 21px;
|
|
}
|
|
.name{
|
|
margin-left: 10px;
|
|
}
|
|
}
|
|
.userBtn{
|
|
flex-basis: 12px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
}
|
|
.userChecked{
|
|
color: var(--el-color-primary);
|
|
.userName{
|
|
.avatar{
|
|
background:var(--el-color-primary);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.tableBody .tr:last-child{
|
|
border-bottom: 0;
|
|
}
|
|
</style>
|