<!--
|
* @Author: shuishen 1109946754@qq.com
|
* @Date: 2023-03-13 14:54:26
|
* @LastEditors: shuishen 1109946754@qq.com
|
* @LastEditTime: 2024-12-03 13:23:57
|
* @FilePath: \bigScreen\src\views\rs\components\box\dataContent.vue
|
* @Description:
|
*
|
* Copyright (c) 2023 by ${git_name_email}, All Rights Reserved.
|
-->
|
<script setup>
|
import EventBus from 'utils/bus'
|
import { getList } from "@/api/riskSource/riskSource"
|
import { nextTick, onUnmounted, reactive } from "vue"
|
const SeachBarCondition = ref(null)
|
const loading = ref(false)
|
const TableContent = ref(null)
|
const curTableHeight = ref(0)
|
const curSelectTabType = ref('')
|
|
// 搜索项配置
|
const options = reactive({
|
searchBtnGroup: true,
|
searchBtn: true,
|
resetBtn: true,
|
exportBtn: false,
|
columns: [
|
{
|
type: 'input',
|
props: 'name',
|
placeholder: '请输入名称',
|
changeSearch: true,
|
flex: 1,
|
}
|
]
|
})
|
|
const resData = reactive({
|
data: [
|
{
|
label: '一般',
|
value: 1
|
},
|
{
|
label: '较大',
|
value: 2
|
},
|
{
|
label: '暂定',
|
value: 9
|
}
|
]
|
})
|
|
const curSelect = ref('')
|
const tableData = ref([])
|
const pages = {
|
page: 1,
|
pageSize: 20,
|
total: 0,
|
}
|
|
function positionColor () {
|
return (row) => {
|
if (
|
(row.X && row.X != 0) ||
|
(row.lng && row.lng != 0) ||
|
(row.longitude && row.longitude != 0) ||
|
(row.x && row.x != 0)
|
) {
|
return "#1AFA29"
|
} else {
|
return "#ccc"
|
}
|
}
|
}
|
|
function positionDisabled () {
|
return (row) => {
|
if (
|
(row.X && row.X != 0) ||
|
(row.lng && row.lng != 0) ||
|
(row.longitude && row.longitude != 0) ||
|
(row.x && row.x != 0)
|
) {
|
return false
|
} else {
|
return true
|
}
|
}
|
}
|
|
onMounted(() => {
|
curTableHeight.value = TableContent.value.offsetHeight
|
EventBus.emit('flyToyqfw', 'flyToyqfw')
|
EventBus.emit('destroyPop', 'destroyPop')
|
})
|
|
// 分页改变
|
const handleCurrentChange = (val) => {
|
pages.page = val
|
getLists(SeachBarCondition.value.getSeachCondition())
|
}
|
|
// 查询分页数据
|
const getLists = (param = {}) => {
|
tableData.value = []
|
param.current = pages.page
|
param.size = pages.pageSize
|
loading.value = true
|
getList({
|
...param,
|
// riskLevel: curSelectTabType.riskLevel
|
})
|
.then((res) => {
|
const data = res.data.data
|
data.records.forEach(item => {
|
if (!item.riskLevelName) {
|
item.riskLevelName = '暂定'
|
}
|
})
|
tableData.value = data.records
|
pages.total = data.total
|
loading.value = false
|
})
|
.catch((err) => {
|
loading.value = false
|
console.log(err)
|
})
|
}
|
|
let state = reactive({
|
layer: {}
|
})
|
let addPupoLayers = {}
|
// 行点击
|
function rowClick (row, column, event) {
|
EventBus.emit('destroyPop', 'destroyPop')
|
if (row.lng && row.lat) {
|
window.$viewer.flyToPosition(new DC.Position(row.lng, row.lat, 600, 0, -90, 0))
|
// 显示企业信息
|
// 删除
|
destroyPupoLayers()
|
addPupoLayers[row.firmName] = new DC.HtmlLayer(row.firmName)
|
window.$viewer.addLayer(addPupoLayers[row.firmName])
|
let iconEl = `<div class="marsBlueGradientPnl">
|
<li>企业名称:${row.firmName || ''}</li>
|
<li>行业类别:${row.category || ''}</li>
|
<li>风险等级:${row.riskLevelName || ''}</li>
|
<li>风险物资:${row.name || ''}</li>
|
</div>`
|
let divIcon = new DC.DivIcon(
|
new DC.Position(row.lng, row.lat, row.ele || 64),
|
`<div class="public-map-popup-three">
|
${iconEl}
|
</div>`
|
)
|
let incident = () => {
|
destroyPupoLayers()
|
}
|
divIcon.on(DC.MouseEventType.CLICK, incident)
|
addPupoLayers[row.firmName].addOverlay(divIcon)
|
}
|
}
|
|
|
// 查看详情
|
function goDetail (row) { }
|
|
const searchBtn = (params) => {
|
resetPage()
|
getLists(params)
|
}
|
|
const resetBtn = (params) => {
|
resetPage()
|
getLists(params)
|
}
|
|
// 重置分页数据
|
const resetPage = () => {
|
pages.page = 1
|
pages.pageSize = 20
|
pages.total = 0
|
}
|
|
// 分页树改变
|
const handleSizeChange = (val) => {
|
pages.pageSize = val
|
getLists(SeachBarCondition.value.getSeachCondition())
|
}
|
|
const spaceTabChange = (type) => {
|
curSelectTabType.riskLevel = type
|
|
nextTick(() => {
|
searchBtn(SeachBarCondition.value.getSeachCondition())
|
})
|
}
|
|
const tabClick = (item) => {
|
if (curSelect.value) EventBus.emit('restHandleDelChange', `4-${curSelect.value}`)
|
curSelect.value = item.value
|
EventBus.emit('restHandleCheckChange', `4`)
|
EventBus.emit('rsTabChange', item.value)
|
}
|
|
nextTick(() => {
|
tabClick(resData.data[0])
|
})
|
|
const showOn = computed(() => (item) => {
|
if (curSelect.value == item.value) {
|
return true
|
}
|
|
return false
|
})
|
|
EventBus.on('rsTabChange', spaceTabChange)
|
|
onUnmounted(() => {
|
EventBus.off('rsTabChange', spaceTabChange)
|
if (curSelect.value) EventBus.emit('restHandleDelChange', `4`)
|
destroyPupoLayers()
|
addPupoLayers = null
|
})
|
|
// 销毁
|
function destroyPupoLayers () {
|
let arr = Object.keys(addPupoLayers)
|
arr.forEach(i => {
|
addPupoLayers[i] && window.$viewer && window.$viewer.removeLayer(addPupoLayers[i])
|
addPupoLayers[i] = null
|
delete addPupoLayers[i]
|
})
|
addPupoLayers = {}
|
}
|
</script>
|
|
<template>
|
<div class="w100 h0 flex-1 flex f-d-c">
|
<global-search :options="options" @searchBtn="searchBtn" @resetBtn="resetBtn" ref="SeachBarCondition"></global-search>
|
<!-- <div class="cur-container">
|
<div class="tablist">
|
<div class="cursor-p" :class="{ on: showOn(item) }" v-for="item, index in resData.data" :key="index"
|
@click="tabClick(item)">
|
<div class="label-box">
|
{{ item.label }}
|
</div>
|
</div>
|
</div>
|
</div> -->
|
<div class="h0 flex-1 table-content" ref="TableContent" v-loading="loading"
|
element-loading-background="rgba(46, 81, 136, 0.9)">
|
<el-table empty-text="暂无数据" @row-click="rowClick" border :data="tableData" :height="curTableHeight"
|
style="width: 100%">
|
<el-table-column align="center" label="ID" width="42" prop="rank">
|
<template #default="{ $index, row }">
|
{{ (pages.page - 1) * pages.pageSize + $index + 1 }}
|
</template>
|
</el-table-column>
|
<el-table-column align="center" show-overflow-tooltip prop="firmName" label="企业名称" />
|
<el-table-column align="center" show-overflow-tooltip prop="name" label="名称" />
|
<el-table-column align="center" show-overflow-tooltip prop="riskLevelName" label="级别" width="72" />
|
<!-- <el-table-column align="center" show-overflow-tooltip prop="mainProduct" label="主要产品" width="112" /> -->
|
<!-- <el-table-column align="center" width="62" label="操作">
|
<template #default="scope">
|
<el-button link type="primary" size="small" :disabled="scope.row.lng == ''" @click="rowClick(scope.row)">
|
定位
|
</el-button>
|
</template>
|
</el-table-column> -->
|
</el-table>
|
</div>
|
|
<div class="el-page">
|
<el-pagination background layout="prev, pager, next" :page-size="pages.pageSize" :total="pages.total"
|
@size-change="handleSizeChange" @current-change="handleCurrentChange" size="small" />
|
</div>
|
</div>
|
</template>
|
|
<style lang="scss" scoped>
|
.el-form-item__label {
|
color: #fff !important;
|
}
|
|
.table-content {
|
flex-basis: auto;
|
height: calc(100% - 40px);
|
}
|
|
.cur-container {
|
background: transparent;
|
pointer-events: none;
|
|
|
.tablist {
|
pointer-events: all;
|
display: flex;
|
// align-items: center;
|
justify-content: space-around;
|
|
&>div {
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
margin: 5px 0;
|
padding: 5px;
|
width: 34px;
|
height: 24px;
|
|
border-radius: 30%;
|
box-shadow: inset 0 0 40px #65aef8;
|
color: #fff;
|
box-sizing: content-box;
|
|
&.on {
|
position: relative;
|
// color: #75b1ff;
|
box-shadow: inset 0 0 40px #0976e4;
|
}
|
|
.label-box {
|
line-height: 14px;
|
font-size: 14px;
|
text-align: center;
|
}
|
}
|
}
|
}
|
</style>
|