|
|
|
|
@@ -12,23 +12,24 @@
|
|
|
|
|
</el-input>
|
|
|
|
|
<el-button v-if="isChooseAll" @click="chooseAll">全选</el-button>
|
|
|
|
|
<el-button v-else @click="cancelAll">不全选</el-button>
|
|
|
|
|
<!-- <el-checkbox-group v-model="checkBtn" @change="handleChange">-->
|
|
|
|
|
<!-- <el-checkbox label="全选" value="1" />-->
|
|
|
|
|
<!-- <el-checkbox label="Option B" value="Value B" />-->
|
|
|
|
|
<!-- <el-checkbox label="Option C" value="Value C" />-->
|
|
|
|
|
<!-- <el-checkbox label="disabled" value="Value disabled" disabled />-->
|
|
|
|
|
<!-- <el-checkbox-->
|
|
|
|
|
<!-- label="selected and disabled"-->
|
|
|
|
|
<!-- value="Value selected and disabled"-->
|
|
|
|
|
<!-- disabled-->
|
|
|
|
|
<!-- />-->
|
|
|
|
|
<!-- </el-checkbox-group>-->
|
|
|
|
|
<!-- <el-checkbox-group v-model="checkBtn" @change="handleChange">-->
|
|
|
|
|
<!-- <el-checkbox label="全选" value="1" />-->
|
|
|
|
|
<!-- <el-checkbox label="Option B" value="Value B" />-->
|
|
|
|
|
<!-- <el-checkbox label="Option C" value="Value C" />-->
|
|
|
|
|
<!-- <el-checkbox label="disabled" value="Value disabled" disabled />-->
|
|
|
|
|
<!-- <el-checkbox-->
|
|
|
|
|
<!-- label="selected and disabled"-->
|
|
|
|
|
<!-- value="Value selected and disabled"-->
|
|
|
|
|
<!-- disabled-->
|
|
|
|
|
<!-- />-->
|
|
|
|
|
<!-- </el-checkbox-group>-->
|
|
|
|
|
<!-- 人员选择 -->
|
|
|
|
|
<el-empty :image-size="100" description="似乎没有数据" v-show="dataList.length === 0"/>
|
|
|
|
|
<el-scrollbar style="height:87%;">
|
|
|
|
|
<div class="tree">
|
|
|
|
|
<el-tree :data="dataList" ref="tree" :props="defaultProps" empty-text="" node-key="value"
|
|
|
|
|
default-expand-all :show-checkbox="showCheckbox" highlight-current :default-checked-keys="defaultChecked"
|
|
|
|
|
default-expand-all :show-checkbox="showCheckbox" highlight-current
|
|
|
|
|
:default-checked-keys="defaultChecked"
|
|
|
|
|
:check-strictly="true" @node-click="(node,check)=>handle(node,check)"
|
|
|
|
|
@check-change="handleChange" :filter-node-method="filterNode">
|
|
|
|
|
<template #default="{ node, data }">
|
|
|
|
|
@@ -85,7 +86,7 @@ const props = defineProps({
|
|
|
|
|
type: Boolean
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
const checkBtn=ref(1)
|
|
|
|
|
const checkBtn = ref(1)
|
|
|
|
|
const isChooseAll = ref(true);
|
|
|
|
|
let selectItem = reactive({
|
|
|
|
|
type: -1,
|
|
|
|
|
@@ -117,25 +118,31 @@ const _value = computed({
|
|
|
|
|
watch(() => filterText.value, (newVal) => {
|
|
|
|
|
tree.value.filter(newVal);
|
|
|
|
|
});
|
|
|
|
|
const matterTree=(list)=>{
|
|
|
|
|
list.forEach(item=>{
|
|
|
|
|
tree.value.setChecked(item,true)
|
|
|
|
|
if(item.children!==undefined){
|
|
|
|
|
const matterTree = (list) => {
|
|
|
|
|
list.forEach(item => {
|
|
|
|
|
tree.value.setChecked(item, true)
|
|
|
|
|
if (item.children !== undefined) {
|
|
|
|
|
matterTree(item.children)
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
const cancelAll=()=>{
|
|
|
|
|
isChooseAll.value=true
|
|
|
|
|
const cancelAll = () => {
|
|
|
|
|
isChooseAll.value = true
|
|
|
|
|
tree.value.setCheckedNodes([])
|
|
|
|
|
}
|
|
|
|
|
const chooseAll=()=>{
|
|
|
|
|
isChooseAll.value=false
|
|
|
|
|
const chooseAll = () => {
|
|
|
|
|
isChooseAll.value = false
|
|
|
|
|
matterTree(dataList.value)
|
|
|
|
|
}
|
|
|
|
|
const getList = () => {
|
|
|
|
|
getSubCompOpt().then(res => {
|
|
|
|
|
dataList.value = res.data;
|
|
|
|
|
dataList.value = [
|
|
|
|
|
{
|
|
|
|
|
label: "全选",
|
|
|
|
|
value: -1,
|
|
|
|
|
children: res.data
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
@@ -149,47 +156,47 @@ const filterNode = (value, data) => {
|
|
|
|
|
const show = () => {
|
|
|
|
|
//用于弹开部门选择
|
|
|
|
|
visible.value = true;
|
|
|
|
|
selectList.value=_value.value
|
|
|
|
|
defaultChecked.value=_value.value.map(item=>item.value)
|
|
|
|
|
selectList.value = _value.value
|
|
|
|
|
defaultChecked.value = _value.value.map(item => item.value)
|
|
|
|
|
getList()
|
|
|
|
|
};
|
|
|
|
|
const handleChange = (data, checked) => {
|
|
|
|
|
// 左侧有选择框
|
|
|
|
|
// if (props.showCheckbox) {
|
|
|
|
|
// 左侧有选择框 + 多选
|
|
|
|
|
if (props.multiple) {
|
|
|
|
|
//不添加重复的数据到右边
|
|
|
|
|
for (let i = 0; i < selectList.value.length; i++) {
|
|
|
|
|
if (selectList.value[i].value === data.value) {
|
|
|
|
|
selectList.value.splice(i, 1);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (checked) {
|
|
|
|
|
// if (data.children === undefined) {
|
|
|
|
|
selectList.value.push(data);
|
|
|
|
|
// }
|
|
|
|
|
} else if (data === "1") {
|
|
|
|
|
tree.value.setCheckedKeys([]);
|
|
|
|
|
selectList.value = [];
|
|
|
|
|
}
|
|
|
|
|
} else {// 左侧有选择框 + 单选
|
|
|
|
|
//不添加重复的数据到右边
|
|
|
|
|
for (let i = 0; i < selectList.value.length; i++) {
|
|
|
|
|
if (selectList.value[i].value === data.value) {
|
|
|
|
|
selectList.value.splice(i, 1);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (checked) {
|
|
|
|
|
tree.value.setCheckedNodes([data]);
|
|
|
|
|
// this.$refs.tree.setCheckedKeys([]);
|
|
|
|
|
selectList.value = [data];
|
|
|
|
|
} else if (data === "1") {
|
|
|
|
|
selectList.value = [];
|
|
|
|
|
tree.value.setCheckedKeys([]);
|
|
|
|
|
// 左侧有选择框 + 多选
|
|
|
|
|
if (props.multiple) {
|
|
|
|
|
//不添加重复的数据到右边
|
|
|
|
|
for (let i = 0; i < selectList.value.length; i++) {
|
|
|
|
|
if (selectList.value[i].value === data.value) {
|
|
|
|
|
selectList.value.splice(i, 1);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (checked) {
|
|
|
|
|
// if (data.children === undefined) {
|
|
|
|
|
selectList.value.push(data);
|
|
|
|
|
// }
|
|
|
|
|
} else if (data === "1") {
|
|
|
|
|
tree.value.setCheckedKeys([]);
|
|
|
|
|
selectList.value = [];
|
|
|
|
|
}
|
|
|
|
|
} else {// 左侧有选择框 + 单选
|
|
|
|
|
//不添加重复的数据到右边
|
|
|
|
|
for (let i = 0; i < selectList.value.length; i++) {
|
|
|
|
|
if (selectList.value[i].value === data.value) {
|
|
|
|
|
selectList.value.splice(i, 1);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (checked) {
|
|
|
|
|
tree.value.setCheckedNodes([data]);
|
|
|
|
|
// this.$refs.tree.setCheckedKeys([]);
|
|
|
|
|
selectList.value = [data];
|
|
|
|
|
} else if (data === "1") {
|
|
|
|
|
selectList.value = [];
|
|
|
|
|
tree.value.setCheckedKeys([]);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// }
|
|
|
|
|
};
|
|
|
|
|
const handle = (node, check) => {
|
|
|
|
|
@@ -215,7 +222,7 @@ const noSelected = (selectItem) => {
|
|
|
|
|
//左侧无选择框时,右侧显示×
|
|
|
|
|
for (let i = 0; i < selectList.value.length; i++) {
|
|
|
|
|
if (selectList.value[i].value === selectItem.value) {
|
|
|
|
|
tree.value.setChecked(selectList.value[i].value,false);
|
|
|
|
|
tree.value.setChecked(selectList.value[i].value, false);
|
|
|
|
|
selectList.value.splice(i, 1);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|