<template>
|
<j-modal
|
title="选择车间"
|
:width="modalWidth"
|
:visible="visible"
|
:confirmLoading="confirmLoading"
|
@ok="handleSubmit"
|
@cancel="handleCancel"
|
@update:fullscreen="isFullscreen"
|
wrapClassName="j-production-select-modal"
|
switchFullscreen
|
cancelText="关闭">
|
<a-spin tip="Loading..." :spinning="false">
|
<a-input-search style="margin-bottom: 1px" placeholder="请输入车间名称按回车进行搜索" @search="onSearch" />
|
<a-tree
|
checkable
|
:class="treeScreenClass"
|
:treeData="treeData"
|
:checkStrictly="checkStrictly"
|
@check="onCheck"
|
@select="onSelect"
|
@expand="onExpand"
|
:autoExpandParent="autoExpandParent"
|
:expandedKeys="expandedKeys"
|
:checkedKeys="checkedKeys">
|
|
<template slot="title" slot-scope="{title}">
|
<span v-if="title.indexOf(searchValue) > -1">
|
{{title.substr(0, title.indexOf(searchValue))}}
|
<span style="color: #f50">{{searchValue}}</span>
|
{{title.substr(title.indexOf(searchValue) + searchValue.length)}}
|
</span>
|
<span v-else>{{title}}</span>
|
</template>
|
</a-tree>
|
</a-spin>
|
<!--底部父子关联操作和确认取消按钮-->
|
<!--<template slot="footer">-->
|
<!--<div class="drawer-bootom-button">-->
|
<!--<a-dropdown style="float: left" :trigger="['click']" placement="topCenter">-->
|
<!--<a-menu slot="overlay">-->
|
<!--<a-menu-item key="1" @click="switchCheckStrictly(1)">父子关联</a-menu-item>-->
|
<!--<a-menu-item key="2" @click="switchCheckStrictly(2)">取消关联</a-menu-item>-->
|
<!--</a-menu>-->
|
<!--<a-button>-->
|
<!--树操作 <a-icon type="up" />-->
|
<!--</a-button>-->
|
<!--</a-dropdown>-->
|
<!--<a-button @click="handleCancel" type="primary" style="margin-right: 0.8rem">关闭</a-button>-->
|
<!--<a-button @click="handleSubmit" type="primary" >确认</a-button>-->
|
<!--</div>-->
|
<!--</template>-->
|
</j-modal>
|
</template>
|
|
<script>
|
import { queryProductionTreeList } from '@/api/api'
|
import { getAction } from '@/api/manage'
|
export default {
|
name: 'JSelectEquipmentProductionModal',
|
props:['modalWidth','multi','rootOpened','productionId', 'store', 'text','treeOpera'],
|
data(){
|
return {
|
visible:false,
|
confirmLoading:false,
|
treeData:[],
|
autoExpandParent:true,
|
expandedKeys:[],
|
dataList:[],
|
checkedKeys:[],
|
checkedRows:[],
|
searchValue:"",
|
checkStrictly: true,
|
fullscreen:false,
|
allTreeKeys:[],
|
url:{
|
queryTreeIdList:'/mdc/mdcProduction/queryTreeIdList'
|
}
|
}
|
},
|
created(){
|
this.loadProductionTree();
|
},
|
watch:{
|
productionId(){
|
this.initDepartComponent()
|
},
|
visible: {
|
handler() {
|
this.initDepartComponent(true)
|
}
|
}
|
},
|
computed:{
|
treeScreenClass() {
|
return {
|
'my-dept-select-tree': true,
|
'fullscreen': this.fullscreen,
|
}
|
},
|
},
|
methods:{
|
loadProductionTree(){
|
getAction(this.url.queryTreeIdList).then(res => {
|
if (res.success) {
|
this.allTreeKeys = res.result
|
this.loadDepart()
|
} else {
|
// this.$message.warning(res.message)
|
this.$notification.warning({
|
message:'消息',
|
description:res.message
|
});
|
}
|
}).finally(() => {
|
this.loading = false
|
})
|
},
|
matterTree(data) {
|
for (var i = 0; i < data.length; i++) {
|
if(data[i].leaf == false){
|
data[i].disabled = true
|
}
|
|
// // 这里面就是你处理数据的地方
|
// data[i].width = '200'
|
if (data[i].children && data[i].children.length > 0) {
|
// children若不为空数组,则继续 递归调用 本方法
|
this.matterTree(data[i].children)
|
}
|
}
|
return data
|
},
|
show(){
|
this.visible=true
|
this.checkedRows=[]
|
this.checkedKeys=[]
|
},
|
loadDepart(){
|
// 这个方法是找到所有的部门信息
|
queryProductionTreeList().then(res=>{
|
if(res.success){
|
let arr = [...res.result]
|
this.reWriterWithSlot(arr)
|
this.treeData = arr
|
this.initDepartComponent()
|
if(this.rootOpened){
|
this.initExpandedKeys(res.result)
|
}
|
this.matterTree(this.treeData)
|
this.expandedKeys = this.allTreeKeys
|
}
|
})
|
},
|
initDepartComponent(flag){
|
let arr = []
|
//该方法两个地方用 1.visible改变事件重新设置选中项 2.组件编辑页面回显
|
let fieldName = flag==true?'key':this.text
|
if(this.productionId){
|
let arr2 = this.productionId.split(',')
|
for(let item of this.dataList){
|
if(arr2.indexOf(item[this.store])>=0){
|
arr.push(item[fieldName])
|
}
|
}
|
}
|
if(flag==true){
|
this.checkedKeys = [...arr]
|
}else{
|
this.$emit("initComp", arr.join(','))
|
}
|
},
|
reWriterWithSlot(arr){
|
for(let item of arr){
|
if(item.children && item.children.length>0){
|
this.reWriterWithSlot(item.children)
|
let temp = Object.assign({},item)
|
temp.children = {}
|
this.dataList.push(temp)
|
}else{
|
this.dataList.push(item)
|
item.scopedSlots={ title: 'title' }
|
}
|
}
|
},
|
initExpandedKeys(arr){
|
if(arr && arr.length>0){
|
let keys = []
|
for(let item of arr){
|
if(item.children && item.children.length>0){
|
keys.push(item.id)
|
}
|
}
|
this.expandedKeys=[...keys]
|
//全部keys
|
//this.allTreeKeys = [...keys]
|
}else{
|
this.expandedKeys=[]
|
//this.allTreeKeys = []
|
}
|
},
|
onCheck (checkedKeys,info) {
|
if(!this.multi){
|
let arr = checkedKeys.checked.filter(item => this.checkedKeys.indexOf(item) < 0)
|
this.checkedKeys = [...arr]
|
this.checkedRows = (this.checkedKeys.length === 0) ? [] : [info.node.dataRef]
|
}else{
|
if(this.checkStrictly){
|
this.checkedKeys = checkedKeys.checked
|
}else{
|
this.checkedKeys = checkedKeys
|
}
|
this.checkedRows = this.getCheckedRows(this.checkedKeys)
|
}
|
},
|
onSelect(selectedKeys,info) {
|
//取消关联的情况下才走onSelect的逻辑
|
if(this.checkStrictly){
|
let keys = []
|
keys.push(selectedKeys[0])
|
if(!this.checkedKeys || this.checkedKeys.length===0 || !this.multi){
|
this.checkedKeys = [...keys]
|
this.checkedRows=[info.node.dataRef]
|
}else{
|
let currKey = info.node.dataRef.key
|
if(this.checkedKeys.indexOf(currKey)>=0){
|
this.checkedKeys = this.checkedKeys.filter(item=> item !==currKey)
|
}else{
|
this.checkedKeys.push(...keys)
|
}
|
}
|
this.checkedRows = this.getCheckedRows(this.checkedKeys)
|
}
|
},
|
onExpand (expandedKeys) {
|
this.expandedKeys = expandedKeys
|
this.autoExpandParent = false
|
},
|
handleSubmit(){
|
if(!this.checkedKeys || this.checkedKeys.length==0){
|
this.$emit("ok",'')
|
}else{
|
let checkRow = this.getCheckedRows(this.checkedKeys)
|
let keyStr = this.checkedKeys.join(",")
|
this.$emit("ok", checkRow, keyStr)
|
}
|
this.handleClear()
|
},
|
handleCancel(){
|
this.handleClear()
|
},
|
handleClear(){
|
this.visible=false
|
this.checkedKeys=[]
|
},
|
getParentKey(currKey,treeData){
|
let parentKey
|
for (let i = 0; i < treeData.length; i++) {
|
const node = treeData[i]
|
if (node.children) {
|
if (node.children.some(item => item.key === currKey)) {
|
parentKey = node.key
|
} else if (this.getParentKey(currKey, node.children)) {
|
parentKey = this.getParentKey(currKey, node.children)
|
}
|
}
|
}
|
return parentKey
|
},
|
onSearch(value){
|
const expandedKeys = this.dataList.map((item) => {
|
if (item.title.indexOf(value) > -1) {
|
return this.getParentKey(item.key,this.treeData)
|
}
|
return null
|
}).filter((item, i, self) => item && self.indexOf(item) === i)
|
|
Object.assign(this, {
|
expandedKeys,
|
searchValue: value,
|
autoExpandParent: true,
|
})
|
|
|
},
|
// 根据 checkedKeys 获取 rows
|
getCheckedRows(checkedKeys) {
|
const forChildren = (list, key) => {
|
for (let item of list) {
|
if (item.id === key) {
|
return item
|
}
|
if (item.children instanceof Array) {
|
let value = forChildren(item.children, key)
|
if (value != null) {
|
return value
|
}
|
}
|
}
|
return null
|
}
|
|
let rows = []
|
for (let key of checkedKeys) {
|
let row = forChildren(this.treeData, key)
|
if (row != null) {
|
rows.push(row)
|
}
|
}
|
return rows
|
},
|
switchCheckStrictly (v) {
|
if(v==1){
|
this.checkStrictly = false
|
}else if(v==2){
|
this.checkStrictly = true
|
}
|
},
|
isFullscreen(val){
|
this.fullscreen=val
|
}
|
}
|
}
|
|
</script>
|
|
<style lang="less" scoped>
|
// 限制部门选择树高度,避免部门太多时点击确定不便
|
.my-dept-select-tree{
|
height:350px;
|
|
&.fullscreen{
|
height: calc(100vh - 250px);
|
}
|
overflow-y: scroll;
|
}
|
.drawer-bootom-button {
|
position: absolute;
|
bottom: 0;
|
width: 100%;
|
border-top: 1px solid #e8e8e8;
|
padding: 10px 16px;
|
text-align: right;
|
left: 0;
|
background: #fff;
|
border-radius: 0 0 2px 2px;
|
}
|
</style>
|