This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
nezha-nezha-fronted/nezha-fronted/src/components/page/dashboard/panel.vue

847 lines
30 KiB
Vue
Raw Normal View History

<template>
<div class="panel list-page" v-loading="panelTabLoading">
2021-04-26 21:42:15 +08:00
<div class="main-list">
<div>
<transition name="el-zoom-in-center">
2021-11-01 17:23:01 +08:00
<div v-if="isLoading" class="panel-loading"></div>
</transition>
</div>
2021-11-15 14:00:54 +08:00
<div class="main-container">
2021-10-08 15:08:14 +08:00
<div class="top-tools">
2021-11-19 09:40:21 +08:00
<div v-if="panelData.length === 0" class="top-tool-left" style="margin-left: 10px;">
2021-04-26 21:42:15 +08:00
<button id="panel-add-panel" class="nz-btn nz-btn-style-light nz-btn-size-small" @click="toAdd"><i class="nz-icon nz-icon-create-square"></i>&nbsp;&nbsp;{{$t("dashboard.panel.createPanelTitleSec")}}</button>
</div>
2021-04-26 21:42:15 +08:00
<template v-else>
<div class="top-tool-left" style="cursor: pointer;">
2021-04-26 21:42:15 +08:00
<select-panel ref="selectPanel" :filter-panel="filterPanel" :panel-data="panelData" :panel-lock="panelLock" :placement="'bottom-start'"
:show-panel="showPanel" style="display: inline-block;padding: 0" @deletePanel="del" @editPanel="edit" @selectPanel="panelChange">
2021-04-26 21:42:15 +08:00
<template v-slot:header>
<div class="panel-select-header">
<el-input id="panel-list-search" v-model="filterPanel" :placeholder="$t('overall.search')" clearable size="mini" style="width: 286px;"></el-input>
<!-- <span id="panel-list-toadd" v-has="'panel_add'" :title='$t("dashboard.panel.createPanelTitleSec")' class="panel-select-add" @click="toAdd"><i class="nz-icon nz-icon-plus"></i></span>-->
2021-04-26 21:42:15 +08:00
</div>
</template>
<template v-slot:trigger>
<i style="color: #BEBEBE" class="el-icon-menu"></i>
2021-09-24 17:57:24 +08:00
<span :title="showPanel.name + ' (' + showPanel.chartNum +' charts' " class="show-panel-name">{{showPanel.name}}</span>
<i style="font-size: 12px;color: #BEBEBE;" class="nz-icon nz-icon-arrow-down"></i>
2021-04-26 21:42:15 +08:00
</template>
<template v-slot:tail>
<div class="panel-select-tail">
2021-08-30 10:48:04 +08:00
<span id="panel-list-toadd" v-has="'panel_add'" :title='$t("dashboard.panel.createPanelTitleSec")' class="panel-select-add" @click="toAdd"><i class="nz-icon nz-icon-create-square"></i>&nbsp;&nbsp;{{ $t('overall.addProject') }}</span>
</div>
</template>
2021-04-26 21:42:15 +08:00
</select-panel>
</div>
<div class="top-tool-right">
<div class="top-tool-search margin-r-20">
<el-input id="queryPanel" ref="queryPanel" v-model="filter.searchName" class="query-input-inactive" clearable size="small" @blur="blurInput" @clear="clearInput" @focus="focusInput">
<i slot="suffix" class="el-input__icon nz-icon nz-icon-search" style="float: right" @click="focusInput"></i>
</el-input>
</div>
2021-08-02 19:51:53 +08:00
<pick-time id="panel" ref="pickTime" v-model="searchTime" :refresh-data-func="dateChange" :use-chart-unit="false" class="margin-r-10"></pick-time>
<button id="panel-add-chart" v-has="'panel_chart_add'" :title="$t('overall.createChart')" class="top-tool-btn margin-r-10"
type="button" @click="addChartBefore">
<i class="nz-icon-create-square nz-icon"></i>
</button>
2021-11-02 15:47:17 +08:00
<top-tool-more-options
:delete-objs="batchDeleteObjs"
2021-04-26 21:42:15 +08:00
id="panel"
:params="filter"
:permissions="{
import: 'panel_chart_add',
export: 'panel_view'
2021-04-26 21:42:15 +08:00
}"
:paramsType="'dashboard'"
2021-04-26 21:42:15 +08:00
class="top-tool-export"
export-file-name="chart"
export-url="/visual/panel/export"
import-url="/visual/panel/import"
@afterImport="dateChange"
>
<template v-slot:before>
<el-dropdown-item>
2021-05-14 17:51:02 +08:00
<div id="panel-lock" @click="panelLock=!panelLock"><i :class="{'nz-icon nz-icon-lock':panelLock,'nz-icon nz-icon-unlock':!panelLock}"></i>{{panelLock ? $t('overall.locked') : $t('overall.unlocked')}}</div>
</el-dropdown-item>
</template>
<template v-slot:after>
<el-dropdown-item v-has="'panel_chart_add'">
2021-05-19 23:17:24 +08:00
<div id="chart-temp-add" @click="addChartByTemp"><i class="nz-icon nz-icon-add"></i>{{$t('overall.AddByTemplate')}}</div>
</el-dropdown-item>
<el-dropdown-item v-has="'panel_chart_edit'">
<div id="chart-temp-sync" @click="chartBySync"><i class="nz-icon nz-icon-sync"></i>{{ $t('overall.syncChart') }}</div>
</el-dropdown-item>
2021-04-26 21:42:15 +08:00
</template>
</top-tool-more-options>
2021-04-26 21:42:15 +08:00
</div>
</template>
</div>
2021-04-26 21:42:15 +08:00
<div id="tableList" class="table-list">
<div id="dashboardScrollbar" ref="dashboardScrollbar" class="table-list-box">
<div class="box-content" v-loading="chartListLoading">
2021-11-19 09:40:21 +08:00
<chart-list
ref="chartList"
2021-12-13 17:07:41 +08:00
name="panel"
:panelId="showPanel.id"
2021-11-19 09:40:21 +08:00
:class="{'show-top':showTopBtn}"
:data-list="dataList"
:nowTimeType="nowTimeType"
2021-11-19 09:40:21 +08:00
:from="fromRoute.panel"
:panel-lock="panelLock"
:time-range="searchTime"
2021-12-06 15:25:09 +08:00
@edit-chart="editChart"
2021-11-19 09:40:21 +08:00
@on-refresh-time="refreshTime"
@on-remove-chart="delChart"
@on-add-group-item-chart="addGroupItem"
:loading="chartListLoading"
2021-11-19 09:40:21 +08:00
></chart-list>
2021-04-26 21:42:15 +08:00
</div>
</div>
</div>
2020-12-14 20:25:24 +08:00
</div>
</div>
2021-04-26 21:42:15 +08:00
2020-12-14 20:25:24 +08:00
<button :class="{'to-top-is-hover': tableHover}" @click="toTop(scrollbarWrap)" class="to-top" style="bottom: 0;" v-show="showTopBtn"><i class="nz-icon nz-icon-top"></i></button>
<transition name="right-box">
<!-- <chart-box-->
2021-11-30 16:39:21 +08:00
<!-- v-if="rightBox.chart.show"-->
<!-- ref="addChartModal"-->
<!-- :chart="chart"-->
<!-- :from="fromRoute.panel"-->
<!-- :panel-data="panelData"-->
<!-- :show-panel="showPanel"-->
<!-- @close="closeChartBox"-->
<!-- @reload="panelReload"-->
<!-- @reloadOnlyPanel="panelReloadOnlyPanel"-->
<!-- @delete-chart="delChart"-->
<!-- @on-create-success="createSuccess"-->
<!-- @on-delete-success="delChartOk"-->
<!-- ></chart-box>-->
<chart-right-box
v-if="chartRightBoxShow"
2021-12-09 14:15:06 +08:00
v-loading="rightBox.loading"
ref="addChartModal"
:chart="chart"
:from="fromRoute.panel"
:panel-data="panelData"
:show-panel="showPanel"
@close="closeChartBox"
@reload="panelReload"
@reloadOnlyPanel="panelReloadOnlyPanel"
@delete-chart="delChart"
@on-create-success="createSuccess"
@on-delete-success="delChartOk"
></chart-right-box>
</transition>
<transition name="right-box">
<chart-temp-box v-if="rightBox.chartTemp.show" :from="fromRoute.panel" :obj="chart" :panel-data="panelData" :show-panel="showPanel" @close="closeChartTempBox" @on-create-success="createSuccess"></chart-temp-box>
</transition>
<transition name="right-box">
<panel-box v-if="rightBox.panel.show" ref="panelBox" :obj="panel" @close="closePanelBox" @reload="panelReload" @reloadForDel="panelReloadForDel" ></panel-box>
</transition>
</div>
</template>
2020-01-17 16:50:17 +08:00
<script>
2021-03-19 18:52:19 +08:00
import ChartBox from './chartBox'
2021-11-30 16:39:21 +08:00
import chartRightBox from '@/components/common/rightBox/chart/chartRightBox'
2021-03-19 18:52:19 +08:00
import bus from '../../../libs/bus'
import pickTime from '../../common/pickTime'
import selectPanel from '../../common/popBox/selectPanel'
2021-04-09 15:07:15 +08:00
import panelBox from '@/components/common/rightBox/panelBox'
import chartTempBox from '@/components/common/rightBox/chartTempBox'
import topToolMoreOptions from '@/components/common/popBox/topToolMoreOptions'
import { fromRoute } from '@/components/common/js/constants'
2021-12-07 14:19:16 +08:00
import { randomcolor } from '@/components/common/js/radomcolor/randomcolor'
2021-03-19 18:52:19 +08:00
export default {
name: 'panel',
data () {
return {
fromRoute,
panelTabLoading: false,
overScroll10: false,
isLoading: true,
2021-11-19 09:40:21 +08:00
panelLock: false,
2021-03-19 18:52:19 +08:00
showTopBtn: false, // top按钮
visible: false,
chartListLoading: true,
2021-03-19 18:52:19 +08:00
rightBox: { // 面板弹出框相关
chart: { show: false },
chartTemp: { show: false },
2021-12-09 14:15:06 +08:00
panel: { show: false },
loading: false
2021-03-19 18:52:19 +08:00
},
tableHover: false,
searchTime: bus.getTimezontDateRange(),
intervalTimer: null,
interval: 0,
showPanel: { // panel下拉列表
id: '',
name: '',
type: 'panel'
2021-03-19 18:52:19 +08:00
},
panel: { // 新增panel
id: '',
name: ''
},
chart: {},
blankChart: {
id: '',
2021-04-07 16:41:11 +08:00
name: '',
2021-03-19 18:52:19 +08:00
type: 'line',
span: 4,
2021-12-06 15:25:09 +08:00
datasource: 'metrics',
height: 4,
2021-03-19 18:52:19 +08:00
unit: 2,
param: {
stack: 0,
nullType: 'null',
legend: { placement: 'bottom', values: [], show: true },
thresholdShow: true,
2021-12-07 14:19:16 +08:00
thresholds: [{ value: undefined, color: randomcolor() }]
},
elements: [{ expression: '', legend: '', type: 'expert', id: '', name: 'A' }],
2021-03-19 18:52:19 +08:00
panel: '',
2021-04-07 16:41:11 +08:00
sync: 0,
remark: '',
2021-12-06 15:25:09 +08:00
groupId: ''
2021-03-19 18:52:19 +08:00
},
pageObj: {
pageNo: 1,
pageSize: -1, // 此处获取所有数据,所以设置一个较大的值
total: 0
},
blankChartTemp: {
varType: 1,
pid: '',
panelId: '',
varIds: []
},
2021-03-19 18:52:19 +08:00
panelData: [],
panelDataDragTmp: [],
searchMsg: { // 给搜索框子组件传递的信息
searchLabelList: [
2021-05-10 15:59:39 +08:00
{
name: 'ID',
type: 'input',
label: 'ids',
disabled: false
},
{
name: this.$t('overall.name'),
type: 'input',
label: 'name',
disabled: false
},
{
name: this.$t('overall.type'),
type: 'selectString',
label: 'chartType',
disabled: false
},
{
name: this.$t('dashboard.panel.chartForm.varType'),
type: 'select',
label: 'varType',
disabled: false
}
2021-03-19 18:52:19 +08:00
]
},
searchLabel: {}, // 搜索参数
// ---图表相关参数--start
dataList: [], // 数据列表
filter: { // 过滤条件
panelId: 0,
2021-03-19 18:52:19 +08:00
start_time: '',
end_time: '',
2021-03-31 10:02:12 +08:00
searchName: '',
id: 4
2021-03-19 18:52:19 +08:00
},
panelId: 0,
filterPanel: '',
// ---图表相关参数--end
2021-11-02 15:47:17 +08:00
scrollbarWrap: null,
batchDeleteObjs: [],
nowTimeType: {}
2021-03-19 18:52:19 +08:00
}
},
components: {
'chart-box': ChartBox,
'pick-time': pickTime,
'panel-box': panelBox,
topToolMoreOptions,
selectPanel,
2021-11-30 16:39:21 +08:00
chartTempBox,
chartRightBox
2021-03-19 18:52:19 +08:00
},
computed: {
chartRightBoxShow () {
return this.$store.getters.getShowRightBox
},
delChartFlag () {
return this.$store.getters.getDelChart
}
},
2021-03-19 18:52:19 +08:00
methods: {
// 刷新
Refresh () {
const curTime = this.$refs.calendarPanel.getCurrentTime()
this.filter.start_time = bus.timeFormate(curTime[0], 'yyyy-MM-dd hh:mm:ss')
this.filter.end_time = bus.timeFormate(curTime[1], 'yyyy-MM-dd hh:mm:ss')
this.getTableData()
},
// 面板相关操作
panelChange (val) {
if (!val) {
return false
}
2021-03-19 18:52:19 +08:00
this.filter.searchName = ''
// this.$refs.searchInput.select();
this.showPanel = val
this.showPanel.type = 'dashboard'
2021-03-19 18:52:19 +08:00
this.filter.panelId = this.showPanel.id
2021-12-09 14:15:06 +08:00
// this.dateChange()
this.getTableData()
this.getData(this.filter)
2021-03-19 18:52:19 +08:00
this.$refs.chartList.cleanData()
},
2021-01-12 20:39:59 +08:00
2021-03-19 18:52:19 +08:00
del (u) {
this.$confirm(this.$t('tip.confirmDelete'), {
confirmButtonText: this.$t('tip.yes'),
cancelButtonText: this.$t('tip.no'),
type: 'warning'
}).then(() => {
this.$delete('visual/panel?ids=' + u.id).then(response => {
2021-03-19 18:52:19 +08:00
if (response.code === 200) {
this.$message({
duration: 1000,
type: 'success',
message: this.$t('tip.deleteSuccess')
})
this.getTableData(true)
} else {
this.$message.error(response.msg)
}
})
})
},
edit (u) {
this.panel = Object.assign({}, u)
this.rightBox.panel.show = true
2021-03-19 18:52:19 +08:00
},
toAdd () {
if (!this.hasButton('panel_view')) {
return
}
2021-05-12 16:19:43 +08:00
this.rightBox.panel.show = true
2021-03-19 18:52:19 +08:00
this.$refs.panelBox.show(true)
this.panel = {
id: '',
name: ''
}
this.$refs.panelBox.setTitle(this.$t('dashboard.panel.createPanelTitle'))
},
panelReload (clearShowPanel) {
this.getTableData(clearShowPanel)
},
refreshTime (st, et) {
const startTime = bus.timeFormate(st, 'yyyy-MM-dd hh:mm')
const endTime = bus.timeFormate(et, 'yyyy-MM-dd hh:mm')
2021-03-31 10:02:12 +08:00
this.searchTime = [startTime, endTime, '']
2021-03-19 18:52:19 +08:00
},
panelReloadForDel: function () {
if (this.showPanel.id === this.panel.id) {
this.showPanel.id = ''
}
this.getTableData()
},
/* 图表相关操作--start */
addChart () {
this.chart = this.newChart()
this.chart.param.thresholds = [{ value: undefined, color: randomcolor() }]
this.chart.panelId = this.showPanel.id
this.chart.panelName = this.showPanel.name
2021-03-19 18:52:19 +08:00
},
addChartByTemp () {
2021-12-08 15:15:18 +08:00
this.chart = JSON.parse(JSON.stringify(this.blankChartTemp))
this.chart.panelId = this.showPanel.id
this.rightBox.chartTemp.show = true
},
chartBySync () {
this.panelTabLoading = true
this.$post('visual/panel/chart/syncTmpl', { panelId: this.showPanel.id }).then(res => {
this.panelTabLoading = false
if (res.code === 200) {
this.getData(this.filter)
this.$message.success(this.$t('tip.syncSuccess'))
} else {
this.$message.error(res.msg)
}
})
},
addGroupItem (groupId) {
this.chart = this.newChart()
this.chart.groupId = groupId
this.chart.panelId = this.showPanel.id
this.chart.panelName = this.showPanel.name
this.chart.isGroup = true
},
2021-03-19 18:52:19 +08:00
newChart () {
return JSON.parse(JSON.stringify(this.blankChart))
},
// 编辑图表信息,打开编辑弹窗
editChart (data, copy) {
if (copy) {
this.chart = JSON.parse(JSON.stringify(data))
this.chart.panelId = this.showPanel.id
this.chart.panelName = this.showPanel.name
this.chart.id = ''
} else {
2021-12-09 14:15:06 +08:00
this.rightBox.loading = true
this.$get('visual/panel/chart/' + data.id).then(res => {
2021-12-09 14:15:06 +08:00
this.rightBox.loading = false
if (res.code === 200) {
const chartData = res.data.data
this.chart = JSON.parse(JSON.stringify(chartData))
this.chart.panelId = this.showPanel.id
this.chart.panelName = this.showPanel.name
2021-12-06 15:25:09 +08:00
this.chart.param = JSON.parse(this.chart.param)
if (!this.chart.groupId || this.chart.groupId == -1) {
this.chart.groupId = ''
}
} else {
this.$message.error(res.msg)
}
})
}
2021-03-19 18:52:19 +08:00
},
closeChartBox (refresh) {
// this.rightBox.chart.show = false
2021-12-09 14:15:06 +08:00
this.chart = {}
this.$store.dispatch('clearPanel')
2021-03-19 18:52:19 +08:00
/* if (refresh) {
2021-05-18 19:18:14 +08:00
this.getData(this.filter)
2021-03-19 18:52:19 +08:00
} */
},
2021-05-18 19:18:14 +08:00
closeChartTempBox (refresh) {
this.rightBox.chartTemp.show = false
2021-05-18 19:18:14 +08:00
if (refresh) {
this.getData(this.filter)
}
},
2021-03-19 18:52:19 +08:00
closePanelBox (refresh) {
this.rightBox.panel.show = false
2021-05-12 16:19:43 +08:00
if (refresh) {
this.getTableData()
}
2021-03-19 18:52:19 +08:00
},
// 移除图表:弹出确认框询问
delChart (data, from) {
this.$confirm(this.$t('tip.confirmDelete'), {
confirmButtonText: this.$t('tip.yes'),
cancelButtonText: this.$t('tip.no'),
type: 'warning'
}).then(() => {
this.$delete('visual/panel/chart?ids=' + data.id).then(response => {
2021-03-19 18:52:19 +08:00
if (response.code === 200) {
this.$message({
duration: 2000,
type: 'success',
message: this.$t('tip.deleteSuccess')
})
this.getData(this.filter)
2021-12-09 14:15:06 +08:00
this.chart = {}
this.$store.dispatch('clearPanel')
2021-11-30 16:39:21 +08:00
// this.$refs.chartList.loadChartData(this.scrollbarWrap.scrollTop)
2021-03-19 18:52:19 +08:00
// if(nextChart&&prevChart){ //删除图表为中间位置
// prevChart.next = nextChart.id;
// nextChart.prev = prevChart.id;
// }else{
// if(!nextChart) prevChart.next = -1;
// if(!prevChart) nextChart.prev = 0;
// }
// this.getTableData(); //删除相关图表后,刷新面板数据
} else {
this.$message.error(response.msg)
}
2021-03-19 18:52:19 +08:00
})
})
},
delChartOk () {
this.filter.panelId = this.showPanel.id
this.getData(this.filter)
},
// 图表创建成功回调panel页面进行图表的刷新
createSuccess (msg, data, params, panel) {
this.filter.panelId = this.showPanel.id
this.getData(this.filter)
},
// 获取数据,用在子页面
getData (params) {
if (!this.hasButton('panel_view')) {
return
}
2021-11-19 09:40:21 +08:00
this.chartListLoading = true
2021-03-19 18:52:19 +08:00
if (params.start_time === '' || params.end_time === '') {
const now = bus.getTimezontDateRange()
const endTimeTmp = bus.timeFormate(now[1].getTime(), 'yyyy-MM-dd hh:mm:ss')
const startTimeTmp = bus.timeFormate(now[0].getTime(), 'yyyy-MM-dd hh:mm:ss')
params.start_time = startTimeTmp
params.end_time = endTimeTmp
}
2021-11-19 09:40:21 +08:00
this.$get('visual/panel/chart?panelId=' + params.panelId + '&groupId=0' + '&pageSize=-1').then(response => {
if (response.code === 200) {
this.chartListLoading = false
this.dataList = response.data.list.map(item => {
2021-11-19 09:40:21 +08:00
return {
...item,
hide: item.name.indexOf(this.filter.searchName) === -1, // 搜索条件
loaded: false
}
})
}
})
2021-03-19 18:52:19 +08:00
},
/* 图表相关操作--end */
/* 时间条件查询--start */
// 选择日期变化
dateChange (val) {
const nowTimeType = this.$refs.pickTime.$refs.timePicker.nowTimeType
this.nowTimeType = this.$refs.pickTime.$refs.timePicker.nowTimeType
2021-03-31 10:02:12 +08:00
this.setSearchTime(nowTimeType.type, nowTimeType.value, nowTimeType)
2021-03-19 18:52:19 +08:00
this.filter.start_time = bus.timeFormate(this.searchTime[0], 'yyyy-MM-dd hh:mm:ss')
this.filter.end_time = bus.timeFormate(this.searchTime[1], 'yyyy-MM-dd hh:mm:ss')
2021-03-31 10:02:12 +08:00
this.filter.end_time = bus.timeFormate(this.searchTime[1], 'yyyy-MM-dd hh:mm:ss')
this.filter.value = this.searchTime[2]
this.filter.id = this.$refs.pickTime.$refs.timePicker.showTime.id
2021-03-19 18:52:19 +08:00
this.getTableData()
this.getData(this.filter)
2021-12-09 16:59:46 +08:00
this.$store.dispatch('dispatchPanelTime',{
time: this.searchTime,
nowTimeType: this.nowTimeType
})
2021-03-19 18:52:19 +08:00
},
2021-03-31 10:02:12 +08:00
setSearchTime (type, val, nowTimeType) { // 设置searchTime
2021-03-19 18:52:19 +08:00
if (type === 'minute') {
const startTime = bus.timeFormate(new Date(bus.computeTimezone(new Date().getTime())).setMinutes(new Date(bus.computeTimezone(new Date().getTime())).getMinutes() - val), 'yyyy-MM-dd hh:mm:ss')
const endTime = bus.timeFormate(new Date(bus.computeTimezone(new Date().getTime())), 'yyyy-MM-dd hh:mm:ss')
this.$set(this.searchTime, 0, startTime)
this.$set(this.searchTime, 1, endTime)
this.$set(this.searchTime, 2, val + 'm')
} else if (type === 'hour') {
const startTime = bus.timeFormate(new Date(bus.computeTimezone(new Date().getTime())).setHours(new Date(bus.computeTimezone(new Date().getTime())).getHours() - val), 'yyyy-MM-dd hh:mm:ss')
const endTime = bus.timeFormate(new Date(bus.computeTimezone(new Date().getTime())), 'yyyy-MM-dd hh:mm:ss')
this.$set(this.searchTime, 0, startTime)
this.$set(this.searchTime, 1, endTime)
this.$set(this.searchTime, 2, val + 'h')
} else if (type === 'date') {
const startTime = bus.timeFormate(new Date(bus.computeTimezone(new Date().getTime())).setDate(new Date(bus.computeTimezone(new Date().getTime())).getDate() - val), 'yyyy-MM-dd hh:mm:ss')
const endTime = bus.timeFormate(new Date(bus.computeTimezone(new Date().getTime())), 'yyyy-MM-dd hh:mm:ss')
this.$set(this.searchTime, 0, startTime)
this.$set(this.searchTime, 1, endTime)
this.$set(this.searchTime, 2, val + 'd')
}
this.$refs.pickTime.$refs.timePicker.searchTime = this.searchTime
},
/* 时间条件查询--end */
// 公用操作
jumpTo (data, id) {
bus.$emit('menu-change', data)
this.$router.push({
path: '/' + data,
query: {
t: +new Date()
}
2021-03-19 18:52:19 +08:00
})
},
panelReloadOnlyPanel () { // 仅刷新panel数据
if (!this.hasButton('panel_view')) {
return
}
this.$get('visual/panel?pageSize=-1').then(response => {
2021-03-19 18:52:19 +08:00
if (response.code === 200) {
this.panelData = response.data.list
for (let i = 0; i < this.panelData.length; i++) {
if (this.panelData[i].id == this.showPanel.id) {
this.showPanel = this.panelData[i]
2021-03-19 18:52:19 +08:00
break
}
}
2021-03-19 18:52:19 +08:00
}
})
},
2021-03-19 18:52:19 +08:00
getTableData (clearShowPanel) {
const vm = this
this.$get('visual/panel?type=dashboard&pageSize=-1').then(response => {
2021-03-19 18:52:19 +08:00
if (response.code === 200) {
this.panelData = response.data.list
let isInitData = false
if (response.data.list.length > 0) {
if (this.$store.state.showPanel.id > 0 && this.$store.state.showPanel.name) {
this.showPanel = JSON.parse(JSON.stringify(this.$store.state.showPanel))
}
2021-03-19 18:52:19 +08:00
if (clearShowPanel) {
this.showPanel.id = ''
}
2021-03-19 18:52:19 +08:00
if (!this.showPanel.id) {
this.showPanel = response.data.list[0]
this.filter.panelId = this.showPanel.id
this.getData(this.filter)
isInitData = true
} else {
handler(response.data.list)
this.filter.panelId = this.showPanel.id
}
2021-03-19 18:52:19 +08:00
this.$nextTick(() => {
2021-05-26 14:15:35 +08:00
try {
this.$refs.selectPanel.$refs.panelTree.setCurrentKey(this.showPanel)
} catch (e) {}
2021-03-19 18:52:19 +08:00
})
this.isLoading = false
2021-03-19 18:52:19 +08:00
} else {
this.showPanel.id = ''
this.filter.panelId = ''
this.isLoading = !response.data.list.length === 0
}
2021-03-19 18:52:19 +08:00
this.pageObj.total = response.data.total
if (!isInitData && (this.panel.id === '' || this.panel.id === this.showPanel.id)) {
this.getData(this.filter)
}
2021-03-19 18:52:19 +08:00
this.$store.state.showPanel.id = 0
this.$store.state.showPanel.name = ''
this.$store.state.showPanel.type = 'dashboard'
} else {
if (response.msg) {
this.$message.error(response.msg)
} else if (response.error) {
this.$message.error(response.error)
} else {
this.$message.error(response)
}
}
2021-03-19 18:52:19 +08:00
}).catch((error) => {
// console.log('error................'+JSON.stringify(error));
if (error) {
console.error(error)
this.$message.error(error.toString())
}
2021-03-19 18:52:19 +08:00
})
function handler (panelData) {
panelData.forEach(panel => {
if (panel.id == vm.showPanel.id) {
vm.showPanel = panel
} else {
if (panel.children && panel.children.length > 0) {
handler(panel.children)
}
}
})
}
},
// 定期刷新
selectInterval (val) {
this.visible = false
clearInterval(this.intervalTimer)
if (val) {
this.interval = val
const start = new Date(this.searchTime[1])
const now = new Date()
const interval = Math.floor((now.getTime() - start.getTime()) / 1000) // 计算当前结束时间到现在的间隔(秒)
if (interval >= 60) { // 如果结束时间到现在超过1分钟
this.getIntervalData(interval)
}
2021-03-19 18:52:19 +08:00
this.intervalTimer = setInterval(() => {
this.getIntervalData(this.interval)
}, val * 1000)
}
},
getIntervalData (interval) { // interval:结束时间到现在的秒数
const start = new Date(this.searchTime[0])
const end = new Date(this.searchTime[1])
start.setSeconds(start.getSeconds() + interval)
end.setSeconds(end.getSeconds() + interval)
const startTime = bus.timeFormate(start, 'yyyy-MM-dd hh:mm')
const endTime = bus.timeFormate(end, 'yyyy-MM-dd hh:mm')
this.searchTime = [startTime, endTime]
// 刷新数据
this.dateChange()
},
pageNo (val) {
this.pageObj.pageNo = val
this.getTableData()
},
pageSize (val) {
this.pageObj.pageSize = val
this.getTableData()
},
search: function () {
if (this.$refs.chartList) {
2021-11-19 09:40:21 +08:00
// this.$refs.chartList.searchCharts(this.filter.searchName)
2021-03-19 18:52:19 +08:00
}
},
// 滚动事件触发下拉加载
onScroll () {
const _self = this
this.scrollbarWrap.addEventListener('scroll', bus.debounce(function () {
_self.showTopBtn = _self.scrollbarWrap.scrollTop > 50
_self.overScroll10 = _self.scrollbarWrap.scrollTop > 50
2021-11-19 09:40:21 +08:00
// _self.$refs.chartList.loadChartData(_self.scrollbarWrap.scrollTop)
2021-03-19 18:52:19 +08:00
}, 300))
},
focusInput () {
let classVal = document.getElementById('queryPanel').parentElement.getAttribute('class')
classVal = classVal.replace('query-input-inactive', 'query-input-active')
document.getElementById('queryPanel').parentElement.setAttribute('class', classVal)
this.$refs.queryPanel.focus()
},
blurInput () {
if (!this.filter.searchName || this.filter.searchName == '') {
setTimeout(function () {
let classVal = document.getElementById('queryPanel').parentElement.getAttribute('class')
classVal = classVal.replace('query-input-active', 'query-input-inactive')
document.getElementById('queryPanel').parentElement.setAttribute('class', classVal)
}, 100)
}
},
clearInput () {
this.$refs.queryPanel.focus()
},
tableListEnter () {
this.tableHover = true
},
2021-03-19 18:52:19 +08:00
tableListLeave () {
this.tableHover = false
},
toTop (wrap) {
let currentTop = wrap.scrollTop
const interval = currentTop / 10
const intervalFunc = setInterval(function () { // 花200ms分10次回到顶部模拟动画效果
if (currentTop === 0) {
clearInterval(intervalFunc)
} else {
currentTop = (currentTop - interval) < interval * 0.5 ? 0 : currentTop - interval
wrap.scrollTop = currentTop
}
}, 20)
2021-11-30 16:39:21 +08:00
},
load () {
},
addChartBefore () {
this.$store.dispatch('dispatchEditChart', {
chart: '',
type: 'add'
})
},
disposeChart () {
const chartInfo = this.$store.getters.getChart
const groupId = this.$store.getters.getGroupId
const type = this.$store.getters.getType
if (type === 'add') {
this.addChart()
}
if (type === 'edit') {
this.editChart(chartInfo)
}
if (type === 'addGroupItem') {
this.addGroupItem(groupId)
}
if (type === 'delete') {
this.delChart(chartInfo)
}
if (type === 'duplicate') {
this.editChart(chartInfo, true)
}
2021-03-19 18:52:19 +08:00
}
},
created () {
this.getTableData()
2021-12-09 16:59:46 +08:00
this.$store.dispatch('dispatchPanelTime',{
time: this.searchTime,
nowTimeType: {
id: 4,
text: this.$t('dashboard.panel.lastOneHour'),
type: 'hour',
value: 1
}
})
2021-03-19 18:52:19 +08:00
},
mounted () {
this.scrollbarWrap = this.$refs.dashboardScrollbar
this.onScroll()
document.querySelector('#tableList').addEventListener('mouseenter', this.tableListEnter)
document.querySelector('#tableList').addEventListener('mouseleave', this.tableListLeave)
},
watch: {
'filter.searchName': function (n, o) {
const temp = this
setTimeout(function () {
temp.search()
}, 1000)
2021-05-12 16:19:43 +08:00
},
searchTime: {
immediate: true,
deep: true,
handler (n) {
localStorage.setItem('panelTime', JSON.stringify(n))
}
},
chartRightBoxShow: {
immediate: false,
deep: true,
handler (n) {
if (n) {
this.disposeChart()
}
}
},
delChartFlag: {
immediate: false,
deep: true,
handler (n) {
if (n) {
this.disposeChart()
}
}
},
2021-05-12 16:19:43 +08:00
$route: {
immediate: true,
handler () {
// 是否弹出侧滑
const add = this.$route.query.add
this.$nextTick(() => {
if (add) {
if (add === 'chart') {
2021-12-09 14:15:06 +08:00
this.addChartBefore()
2021-05-12 16:19:43 +08:00
}
if (add === 'panel') {
this.toAdd()
}
}
})
}
2021-03-19 18:52:19 +08:00
}
},
beforeDestroy () {
if (document.querySelector('#tableList')) {
document.querySelector('#tableList').removeEventListener('mouseenter', this.tableListEnter)
document.querySelector('#tableList').removeEventListener('mouseleave', this.tableListLeave)
}
2021-03-19 18:52:19 +08:00
if (this.scrollbarWrap) {
this.scrollbarWrap.removeEventListener('scroll', bus.debounce)
2021-11-01 17:23:01 +08:00
}
localStorage.removeItem('panelTime')
}
2021-03-19 18:52:19 +08:00
}
</script>