p-honggang.li
5 天以前 22cc8ce22157a32bfcd4ee14d824769c6e318cec
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
<template>
    <div>
        <el-select
              style="width: 170px; margin-right: 10px"
              clearable
              v-model="state.industrialChainId"
              placeholder="请选择行业领域"
              @change="industrialChainIdCh"
              @clear="industrialChainIdClear"
              class="hangye"
            >
              <el-option
                v-for="item in state.directionData"
                :key="item.id"
                :label="item.name"
                :value="item.id"
              />
            </el-select>
            <el-tree-select
                  ref="areaIdTreeRef"
                  v-model="state.importantAreaIdList"
                  :data="state.regionData"
                  placeholder="请选择单位工程"
                  multiple
                  collapse-tags
                  collapse-tags-tooltip
                  clearable
                  :default-expand-all="true"
                  :render-after-expand="false"
                  show-checkbox
                  style="width: 170px;"
                  @change="importantAreaCh"
                  @clear="importantAreaClear"
              />
    </div>
</template>
<script setup lang="ts">
import productService from '@/api/zhongjian/productApi' // 接口文件
import optionService from '@/api/zhongjian/optionApi' // 接口文件
import achievementService from '@/api/zhongjian/achievementApi' // 接口文件
 
const state = reactive<any>({
    directionData:[],
    regionData:[],
    industrialChainId: '', // 行业领域
    importantDistrictIdList:[], // 单位工程二级
    importantAreaIdList:[],
    currentType:'product'
})
const areaIdTreeRef=ref()
const emit = defineEmits(['returnData'])
 
// 行业领域下拉change
const industrialChainIdCh = () => {
    if (state.industrialChainId != '') {
      // 单位工程
      categoryListUrlqyFun()
    }
    importantAreaClear()
    state.regionData = []
}
const importantAreaClear=()=>{
    state.importantAreaIdList = []
    areaIdTreeRef.value.setCheckedKeys([])
    emit("returnData",{
        industrialChainId: state.industrialChainId,
        importantDistrictIdList:[],
        importantAreaIdList:[],
    })
}
// 行业领域清空
const industrialChainIdClear = () => {
    state.importantAreaIdList = []
  state.regionData = []
  emit("returnData",{
        industrialChainId:'',
        importantDistrictIdList:[],
        importantAreaIdList:[],
    })
}
 
const importantAreaCh=()=>{
    let checkedKeys = areaIdTreeRef.value!.getCheckedNodes(false, true)
    if(checkedKeys&&checkedKeys.length>0&& state.importantAreaIdList.length>0){
        state.importantDistrictIdList=[]
        checkedKeys.forEach((item:any)=>{
            if(item.children&&item.children.length>0){
                state.importantDistrictIdList.push(item.value)
            }
        })
    }
    emit("returnData",{
        industrialChainId: state.industrialChainId,
        importantDistrictIdList:state.importantDistrictIdList,
        importantAreaIdList:state.importantAreaIdList,
    })
}
 
// 下拉数据-行业领域
const categoryListUrlFun = () => {
  const searchList = {
    parentCode: 'business_direction',
  }
  if(state.currentType=='benchmark'){
    // 标杆
    optionService.getResourceCategories({ ...searchList }).then((res: any) => {
    if (res.code == 200) {
      state.directionData = [...res.data]
    }
  })
  }else if(state.currentType=="knowledge"){
    // 知识
    achievementService.getResourceCategories({ ...searchList }).then((res: any) => {
    if (res.code == 200) {
      state.directionData = [...res.data]
    }
  })
  }else if(state.currentType=="product"){
    // 产品
    productService.getProductDict({ ...searchList }).then((res: any) => {
      if (res.code == 200) {
        state.directionData = [...res.data]
      }
    })
  }
}
// 下拉数据-单位工程
const categoryListUrlqyFun = () => {
  const param={parentIdList: [state.industrialChainId]}
  if(state.currentType=='benchmark'){
    // 标杆
    optionService.getResourceCategories({ ...param }).then((res: any) => {
      let data=handleIndustryData(res.data)
          state.regionData = data
      })
  }else if(state.currentType=="knowledge"){
    // 知识
    achievementService.getResourceCategories({ ...param}).then((res: any) => {
      if (res.code == 200) {
        let data=handleIndustryData(res.data)
        state.regionData = data
      }
    })
  }else if(state.currentType=="product"){
    // 产品
    productService.getResourceCategory({...param}).then((res: any) => {
      let data=handleIndustryData(res.data)
      state.regionData = data
    })
  }
}
const handleIndustryChildData=(parentItem:any,childList:any)=>{
    if(childList&& childList.length>0){
  let data=childList.map((item:any)=>{
            return {
                parentId:parentItem.id,
                parentName:parentItem.name,
                label:item.name,
                value:item.id,
                children:item.children?handleIndustryChildData(item,item.children):[]
            }
        })
        return data
    }
}
const handleIndustryData=(list:any)=>{
    if(list&& list.length>0){
  let data=list.map((item:any)=>{
            return {
                label:item.name,
                value:item.id,
                parentId:item.parentId,           
                parentName:item.parentName,
                children:item.children?handleIndustryChildData(item,item.children):[]
            }
        })
        return data
    }
}
const clearData=()=>{
    state.regionData=[]
    state.importantAreaIdList=[]
    state.importantDistrictIdList=[]
    state.industrialChainId=''
}
const getData=(currentType:string)=>{
  state.currentType=currentType
  // 下拉数据-行业领域
  categoryListUrlFun()
}
defineExpose({
  clearData,
  getData
})
</script>