fix : 人员组件和组织结构组件改为懒加载模式

This commit is contained in:
2024-07-16 21:56:39 +08:00
parent a934176986
commit ad4f2f5ba9
2 changed files with 86 additions and 151 deletions

View File

@@ -2,27 +2,29 @@
<div class="organization-layout"> <div class="organization-layout">
<div class="layout-left"> <div class="layout-left">
<div class="candidate" v-loading="loading"> <div class="candidate" v-loading="loading">
<el-form :model="queryType" @submit.prevent="getList(1)"> <el-form :model="queryType" @submit.prevent="getList">
<el-form-item prop="dictName"> <el-form-item prop="dictName">
<el-input v-model="queryType.chooseName" @change="getList(1)" <el-input v-model="queryType.chooseName" @change="getList"
clearable placeholder="输入公司或部门名称进行搜索"> clearable placeholder="输入公司或部门名称进行搜索">
<template #append> <template #append>
<el-button @click="getList(1)">搜索</el-button> <el-button @click="getList">搜索</el-button>
</template> </template>
</el-input> </el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
<el-empty :image-size="100" description="似乎没有数据" v-show="dataList.length === 0"/>
<el-scrollbar> <el-scrollbar>
<div class="tree scrollbar-dict"> <div class="tree scrollbar-dict">
<el-tree :data="dataList" ref="tree" :props="defaultProps" empty-text="" node-key="value" <el-tree :data="dataList" ref="tree" :props="defaultProps" empty-text="" node-key="value"
:default-expanded-keys="expandedKeys" default-expand-all :default-expanded-keys="expandedKeys" :lazy="true" :load="handleLoad"
@node-click="handleClick" @node-expand="handleClick"> @node-expand="handleNodeExpand" @node-click="handleClick"
>
<template #default="{ node, data }"> <template #default="{ node, data }">
<div class="tree-node"> <div class="tree-node">
<div style="display: flex;align-items: center;padding: 3px 0;" :class="data.value === selectNodeKey ? 'highlight': ''"> <div style="display: flex;align-items: center;padding: 3px 0;"
:class="data.value === selectNodeKey ? 'highlight': ''">
<svg-icon name="oran" v-if="data.type===0" class-name="oran-icon"/> <svg-icon name="oran" v-if="data.type===0" class-name="oran-icon"/>
<el-icon v-else-if="data.type===1" :color="data.matrix?'#67C23A':'#fa3534'" style="margin-right: 4px;"> <el-icon v-else-if="data.type===1" :color="data.matrix?'#67C23A':'#fa3534'"
style="margin-right: 4px;">
<FolderOpened/> <FolderOpened/>
</el-icon> </el-icon>
{{ data.organizationalStructureName }} {{ data.organizationalStructureName }}
@@ -36,7 +38,7 @@
</div> </div>
<div class="layout-right"> <div class="layout-right">
<depart-component v-if="showDept" v-model:value="deptId"/> <depart-component v-if="showDept" v-model:value="deptId"/>
<company-detail v-if="showCompany" v-model:value="companyId"></company-detail> <company-detail v-if="showCompany" v-model:value="companyId"></company-detail>
<!-- <department v-if="selectItem.type===2" :id="selectItem.value"></department>--> <!-- <department v-if="selectItem.type===2" :id="selectItem.value"></department>-->
</div> </div>
</div> </div>
@@ -53,12 +55,10 @@ import CompanyDetail from "@/components/organizationalStructure/CompanyDetail.vu
const queryType = reactive({ const queryType = reactive({
chooseName: "" chooseName: ""
}); });
const chooseId = ref(0);
const deptId = ref(0); const deptId = ref(0);
const companyId = ref(0); const companyId = ref(0);
const showDept = ref(false); const showDept = ref(false);
const showCompany = ref(false); const showCompany = ref(false);
const organizationStructureType = ref(0);
let selectItem = reactive({ let selectItem = reactive({
type: -1, type: -1,
value: "0" value: "0"
@@ -67,16 +67,12 @@ const loading = ref(false);
const dataList = ref([]); const dataList = ref([]);
const tree = ref([]); const tree = ref([]);
const selectNodeKey = ref("") const selectNodeKey = ref("")
const isSearch = ref(false);
const expandedKeys = ref([]); const expandedKeys = ref([]);
const defaultProps = { const defaultProps = {
value: "value", value: "value",
label: "organizationalStructureName", label: "organizationalStructureName",
children: "children", children: "children",
isLeaf: (data) => { isLeaf: (data) => {
// if (data.isLeaf) {
// return true
// }
} }
}; };
const emit = defineEmits(); const emit = defineEmits();
@@ -90,39 +86,18 @@ const _value = computed({
} }
}); });
const getList = (flag, type) => { const getList = () => {
let params = {} let params = {
if (flag === 1) { chooseId: 0,
isSearch.value = true; type: 0,
params = { chooseName: queryType.chooseName
chooseId: 0,
type: 0,
chooseName: queryType.chooseName
}
selectItem = {
type: -1,
value: "0"
};
} else {
params = {
chooseId: chooseId.value,
type: organizationStructureType.value,
chooseName: queryType.chooseName
}
} }
selectItem = {
type: -1,
value: "0"
};
getOrganizationStructure(params).then(res => { getOrganizationStructure(params).then(res => {
if (selectItem.type === -1) { dataList.value = res.data;
dataList.value = res.data;
} else if (type === 2) {
selectItem.children = [...res.data]
if (res.data.length === 0) {
selectItem.isLeaf = true
// selectItem.children = [{
// type: 2
// }
}
}
console.log(selectItem.children,"selectItem.children")
}); });
}; };
const init = () => { const init = () => {
@@ -131,11 +106,30 @@ const init = () => {
value: "0" value: "0"
}; };
dataList.value = []; dataList.value = [];
chooseId.value = 0;
expandedKeys.value = []; expandedKeys.value = [];
queryType.chooseName = "" queryType.chooseName = ""
getList();
}; };
async function handleLoad(node, resolve, reject) {
let data = node.data
let params
if (data.organizationalStructureId) {
params = {
chooseId: data.organizationalStructureId,
type: data.type
}
} else {
params = {
chooseId: 0,
type: 0,
}
}
let result = await getOrganizationStructure(params).then(res => {
return res.data
})
resolve(result)
}
const handleClick = (item, data) => { const handleClick = (item, data) => {
selectNodeKey.value = item.value selectNodeKey.value = item.value
if (item.type === 1) { if (item.type === 1) {
@@ -145,41 +139,25 @@ const handleClick = (item, data) => {
showDept.value = true showDept.value = true
}) })
deptId.value = item.organizationalStructureId deptId.value = item.organizationalStructureId
}else{ } else {
showDept.value = false showDept.value = false
showCompany.value = false showCompany.value = false
nextTick(() => { nextTick(() => {
showCompany.value = true showCompany.value = true
}) })
companyId.value=item.organizationalStructureId companyId.value = item.organizationalStructureId
} }
selectItem = item; selectItem = item;
if (isSearch.value) {
queryType.chooseName = ""
chooseId.value = item.organizationalStructureId;
getList('', 2);
return;
} else {
//渲染子节点用户或部门及用户数据
if (data.expanded) {
if (expandedKeys.value.indexOf(item.value) === -1) {
expandedKeys.value.push(item.value);
organizationStructureType.value = item.type
chooseId.value = item.organizationalStructureId;
getList('', 2);
return;
}
}
}
}; };
init() init()
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.highlight{ .highlight {
color: black; //节点的字体颜色 color: black; //节点的字体颜色
font-weight: bold; font-weight: bold;
} }
$containWidth: 550px; $containWidth: 550px;
.organization-layout { .organization-layout {
display: flex; display: flex;

View File

@@ -4,19 +4,18 @@
:destroy-on-close="true"> :destroy-on-close="true">
<div class="picker"> <div class="picker">
<div class="candidate" v-loading="loading"> <div class="candidate" v-loading="loading">
<el-input v-model="filterText" @change="getList(1)" <el-input v-model="filterText" @change="getList"
clearable placeholder="输入昵称进行搜索"> clearable placeholder="输入昵称进行搜索">
<template #append> <template #append>
<el-button @click="getList(1)">搜索</el-button> <el-button @click="getList">搜索</el-button>
</template> </template>
</el-input> </el-input>
<!-- 人员选择 --> <!-- 人员选择 -->
<el-empty :image-size="100" description="似乎没有数据" v-show="dataList.length === 0"/>
<el-scrollbar style="height:90%;"> <el-scrollbar style="height:90%;">
<div class="tree"> <div class="tree">
<el-tree :data="dataList" ref="tree" :props="defaultProps" empty-text="" node-key="value" <el-tree :data="dataList" ref="tree" :props="defaultProps" empty-text="" node-key="value"
:default-expanded-keys="expandedKeys" default-expand-all accordion :default-expanded-keys="expandedKeys" lazy :load="loadNode" accordion
@node-click="handleChange" @node-expand="handleChange"> @node-click="handleClick">
<template #default="{ node, data }"> <template #default="{ node, data }">
<div class="tree-node"> <div class="tree-node">
<div v-if="data.type === 0" style="display: flex;align-items: center;padding: 3px 0"> <div v-if="data.type === 0" style="display: flex;align-items: center;padding: 3px 0">
@@ -100,12 +99,10 @@ const props = defineProps({
} }
}); });
const radio = ref(0); const radio = ref(0);
const chooseId = ref(0);
let selectItem = reactive({ let selectItem = reactive({
type: -1, type: -1,
value: "0" value: "0"
}); });
const activeNames = ref(["1"]);
const visible = ref(false); const visible = ref(false);
const loading = ref(false); const loading = ref(false);
const title = ref("请选择"); const title = ref("请选择");
@@ -140,56 +137,15 @@ watch(() => filterText.value, (newVal) => {
filterText.value = newVal filterText.value = newVal
}); });
const getList = (flag) => { const getList = () => {
let params = {} let params = {
if (flag === 1) { chooseId: 0,
isSearch.value = true; chooseName: filterText.value
params = {
chooseId: 0,
chooseName: filterText.value
}
selectItem = {
type: -1,
value: "0"
};
} else {
params = {
chooseId: radio.value,
chooseName: filterText.value
}
} }
getMosrUser(params).then(res => { getMosrUser(params).then(res => {
// if (res.data) { dataList.value = res.data;
if (selectItem.type === -1) {
dataList.value = res.data;
} else if (selectItem.type === 1) {
selectItem.children = res.data;
if (res.data.length === 0) {
selectItem.children = [{
type: 1,
name: '暂无数据'
}]
}
} else if (selectItem.type === 2) {
selectItem.children = res.data;
}
// }
}); });
}; };
const setData = (source) => {
// for (let item of source) {
// this.$set(item, "value", selectItem.value + "-" + item.id)
// }
return source;
};
//通过关键字过滤树节点
// filterNode(value, data) {
// if (!value) return true;
// return data.name.indexOf(value) !== -1;
// },
//用于用户选择 //用于用户选择
const showUserPicker = () => { const showUserPicker = () => {
selectItem = { selectItem = {
@@ -197,26 +153,41 @@ const showUserPicker = () => {
value: "0" value: "0"
}; };
dataList.value = []; dataList.value = [];
// console.log('_value.value',_value.value) selectList.value = _value.value
// if(props.setNullToSelectList){
// selectList.value = []
// }else {
selectList.value =_value.value
// }
chooseId.value = 0;
radio.value = 0; radio.value = 0;
visible.value = true; visible.value = true;
expandedKeys.value = []; expandedKeys.value = [];
filterText.value = '' filterText.value = ''
getList();
}; };
const handleChange = (item, data) => {
async function loadNode(node, resolve) {
let data = node.data
let params = {}
if (data.id) {
params = {
chooseId: data.id
}
} else {
params = {
chooseId: 0
}
}
let result = await getMosrUser(params).then(res => {
if (res.data.length === 0) {
return []
} else {
return res.data
}
})
resolve(result)
}
const handleClick = (item, data) => {
selectItem = item; selectItem = item;
if (isSearch.value && item.type !== 0) { if (isSearch.value && item.type !== 0) {
filterText.value = "" filterText.value = ""
radio.value = item.id; radio.value = item.id;
getList();
return; return;
} else if (!isSearch.value) { } else if (!isSearch.value) {
//渲染子节点用户或部门及用户数据 //渲染子节点用户或部门及用户数据
@@ -225,25 +196,12 @@ const handleChange = (item, data) => {
expandedKeys.value.push(item.value); expandedKeys.value.push(item.value);
if (item.type !== 0) { if (item.type !== 0) {
radio.value = item.id; radio.value = item.id;
getList();
return; return;
} }
} }
} }
} }
// if(expandedKeys.value.indexOf(item.value)==-1){
// expandedKeys.value.push(item.value);
// }else {
// if (data.expanded === true) {
// if (item.type !== 0) {
// chooseId.value = item.id;
// getList();
// return;
// }
// }
// }
//仅选择用户 //仅选择用户
if (item.type === 0) { if (item.type === 0) {
if (props.multiple) { if (props.multiple) {
@@ -259,7 +217,6 @@ const handleChange = (item, data) => {
selectList.value = [item]; selectList.value = [item];
} }
} }
// _value = selectList.value
}; };
const noSelected = (selectItem) => { const noSelected = (selectItem) => {
@@ -284,22 +241,22 @@ const clearSelected = () => {
}; };
const selectConfirm = () => { const selectConfirm = () => {
//确定按钮 //确定按钮
if (props.checkMatrix){ if (props.checkMatrix) {
checkMatrix(selectList.value[0].id).then(res=>{ checkMatrix(selectList.value[0].id).then(res => {
console.log(res) console.log(res)
if (res.code === 2000){ if (res.code === 2000) {
ElNotification({ ElNotification({
title: '提示', title: '提示',
message: res.msg, message: res.msg,
type: 'error' type: 'error'
}) })
}else { } else {
emit("ok", selectList.value); emit("ok", selectList.value);
dataList.value = [] dataList.value = []
visible.value = false; visible.value = false;
} }
}) })
}else { } else {
emit("ok", selectList.value); emit("ok", selectList.value);
dataList.value = [] dataList.value = []
visible.value = false; visible.value = false;