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

1050 lines
37 KiB
Vue
Raw Normal View History

<template>
<div class="panel">
<div class="top-tools">
<div class="top-tool-main-left" v-if="panelData.length == 0" style="margin-left: 10px;">
2020-12-16 11:26:51 +08:00
<button @click="toAdd" class="nz-btn nz-btn-style-light nz-btn-size-small"><i class="nz-icon nz-icon-create-square"></i>&nbsp;&nbsp;{{$t("dashboard.panel.createPanelTitleSec")}}</button>
</div>
<template v-else>
<div class="top-tool-main-left">
<select-panel :filter-panel="filterPanel" :panel-data="panelData" :panel-lock="panelLock" :placement="'bottom-start'" :show-panel="showPanel"
@deletePanel="del" @editPanel="edit" @selectPanel="panelChange" ref="selectPanel" style="width: 300px;">
2021-01-12 20:39:59 +08:00
<template v-slot:header>
<div class="panel-select-header">
<el-input :placeholder="$t('overall.search')" clearable size="mini" style="width: 340px; margin-right: 5px;" v-model="filterPanel"></el-input>
<span :title='$t("dashboard.panel.createPanelTitleSec")' @click="toAdd" class="panel-select-add" v-has="'panel_toAdd'"><i class="nz-icon nz-icon-plus"></i></span>
</div>
</template>
<template v-slot:trigger>
<el-input class="panel-name input-x-mini-26" placeholder="" readonly="readonly" v-model="showPanel.name">
<i class="el-icon-menu" slot="prefix"></i>
</el-input>
</template>
</select-panel>
<!--<el-dropdown @command="panelChange" class="panel-dropdown-title" trigger="click" placement="bottom-start" >
<el-row :gutter="10" class="el-dropdown-link" style="padding-right: 5px">
<el-col :span="21" class="panel-list-title" :title="showPanel.name">{{showPanel.name}}</el-col>
2020-09-10 17:00:32 +08:00
<el-col :span="3" style="padding-left:0px !important;"><i class="nz-icon nz-icon-arrow-down"></i></el-col>
</el-row>
<el-dropdown-menu class="nz-dashboard-dropdown panel-dropdown-title-space" slot="dropdown" >
2021-01-12 20:39:59 +08:00
&lt;!&ndash;<el-dropdown-item>{{$t('dashboard.panel.createPanelTitleSec')}}</el-dropdown-item>&ndash;&gt;
2020-12-14 20:25:24 +08:00
<div ref="dashboardScrollbar" style="height: 100%; overflow: auto">
<el-dropdown-item >
<el-row class="panel-list-width" :gutter="10" >
2020-12-14 20:25:24 +08:00
<el-col :span="21"><el-input :placeholder="$t('overall.search')" @click.native.stop="filterPanelFocus($event)" @input="filterPanelFunc" clearable size="mini" v-model="filterPanel"></el-input></el-col>
<el-col :span="3"><span :title='$t("dashboard.panel.createPanelTitleSec")' @click="toAdd" v-has="'panel_toAdd'"><i class="nz-icon nz-icon-plus"></i></span></el-col>
</el-row>
</el-dropdown-item>
<draggable v-model="panelData" @start="start" @end="end" :move="move" :key
:scroll-sensitivity="150"
:options="{
group:{name:'chartGroup',pull:'false'},
dragClass:'drag-chart-class',
fallbackClass:'fallback-class',
forceFallback:true,
ghostClass:'chart-ghost',
chosenClass:'choose-class',
scroll:true,
scrollFn:function(offsetX,offsetY,originalEvent,touchEvt,hoverTargetEI){},
animation:150,
handle:'.panelContent',
}" >
<el-dropdown-item v-for="item in showPanelList" :key="item.id+1" class="panel-title-li"
:class="showPanel.id==item.id?'nz-dashboard-dropdown-bg':''" :command="item">
<el-row :gutter="10" class="panel-list-width" >
<el-col :span="2" class="panelContent move-area"><i class="nz-icon nz-icon-sort4"></i></el-col>
<el-col :span="17" class="panel-list-item" :title="item.name">{{item.name}}</el-col>
<el-col :span="1"><span @click.stop="del(item)" class="panel-dropdown-btn panel-dropdown-btn-delete" v-has="'panel_delete'"><i class="nz-icon nz-icon-delete"></i></span></el-col>
<el-col :span="1">&nbsp;</el-col>
<el-col :span="1"><span @click.stop="edit(item)" class="panel-dropdown-btn" v-has="'panel_toEdit'"><i class="nz-icon nz-icon-edit"></i></span></el-col>
</el-row>
</el-dropdown-item>
</draggable>
2020-12-14 20:25:24 +08:00
</div>
</el-dropdown-menu>
2021-01-12 20:39:59 +08:00
</el-dropdown>-->
</div>
<div class="top-tool-main-right">
<div class="top-tool-search relative-position margin-r-20">
<el-input ref="queryPanel" @clear="clearInput" id="queryPanel" @focus="focusInput" @blur="blurInput" v-model="filter.searchName" class="query-input-inactive" size="mini" clearable >
2020-09-10 17:00:32 +08:00
<i slot="suffix" class="el-input__icon nz-icon nz-icon-search" @click="focusInput" style="float: right"></i>
</el-input>
</div>
<pick-time :refresh-data-func="dateChange" v-model="searchTime" :use-chart-unit="false" ref="pickTime"></pick-time>
<export-excel
export-file-name="chart"
export-url="/panel/export"
import-url="/panel/import"
:params="filter"
:permissions="{
import: 'panel_chart_import',
export: 'panel_chart_export'
}"
@afterImport="dateChange"
class="margin-r-20"
>
<template slot="optionZone">
<button :title="$t('overall.createChart')" @click="addChart" v-has="'panel_chart_toAdd'"
class="nz-btn nz-btn-size-normal nz-btn-style-light ">
<i class="nz-icon-create-square nz-icon"></i>
</button>
</template>
</export-excel>
<div class="relative-position ">
2020-12-16 13:59:24 +08:00
<button @click="panelLock=!panelLock" class="nz-btn nz-btn-size-normal nz-btn-style-light" type="button"><i :class="{'nz-icon nz-icon-lock':panelLock,'nz-icon nz-icon-unlock':!panelLock}"></i></button>
</div>
</div>
</template>
</div>
<div class="table-list" id="tableList">
2020-12-14 20:25:24 +08:00
<div ref="dashboardScrollbar" style="height: 100%; overflow: auto;">
<div class="box-content">
<chart-list :from="$CONSTANTS.fromRoute.panel" @on-edit-chart="editChart" @on-refresh-time="refreshTime" @on-remove-chart="delChart" ref="chartList" :panel-lock="panelLock"></chart-list>
</div>
2020-12-14 20:25:24 +08:00
</div>
</div>
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 :chart="chart" :from="$CONSTANTS.fromRoute.panel" :panel-data="panelData" :show-panel="showPanel" @close="closeChartBox" @delete-chart="delChart" @on-create-success="createSuccess" @on-delete-success="delChartOk" @reload="panelReload" @reloadOnlyPanel="panelReloadOnlyPanel" ref="addChartModal" v-if="rightBox.chart.show"></chart-box>
</transition>
<transition name="right-box">
<panel-box v-if="closePanelBox" :panel="panel" @reload="panelReload" @reloadForDel="panelReloadForDel" ref="panelBox"></panel-box>
</transition>
</div>
</template>
2020-01-17 16:50:17 +08:00
<script>
import ChartBox from "./chartBox";
import ChartList from '../../charts/chart-list';
import bus from '../../../libs/bus';
import timePicker from '../../common/timePicker'
import draggable from 'vuedraggable'
import pickTime from "../../common/pickTime";
import exportXLSX from "../../common/exportXLSX";
2021-01-12 20:39:59 +08:00
import selectPanel from "../../common/popBox/selectPanel";
export default {
name: "panel",
data() {
return {
panelLock:true,
showTopBtn: false, //top按钮
visible: false,
rightBox: { //面板弹出框相关
chart: {show: false},
panel: {show: false},
},
tableHover: false,
2020-09-07 11:43:45 +08:00
searchTime: bus.getTimezontDateRange(),
intervalTimer: null,
interval: 0,
showPanel: { //panel下拉列表
id: '',
name: ''
2020-01-17 16:50:17 +08:00
},
panel: { //新增panel
id: '',
name: ''
2020-01-17 16:50:17 +08:00
},
chart: {},
blankChart: {
id:'',
title: '',
type:'line',
span:12,
height:'400',
unit:2,
param:{
url:'',
threshold:'',
},
elements:[],
panel: '',
sync: 0
2020-01-17 16:50:17 +08:00
},
pageObj: {
pageNo: 1,
pageSize: -1, //此处获取所有数据,所以设置一个较大的值
total: 0
2020-01-17 16:50:17 +08:00
},
chartsData: [], //中间部分图表相关数据
panelData: [],
panelDataDragTmp:[],
searchMsg: { //给搜索框子组件传递的信息
zheze_none: true,
searchLabelList: [
2020-01-17 16:50:17 +08:00
/*
{
id: 1,
name: this.$t("dashboard.panel.searchItem.name"),
type: 'input',
label: 'name',
disabled: false
}*/
],
},
searchLabel: {}, //搜索参数
//---图表相关参数--start
dataList: [], // 数据列表
filter: { // 过滤条件
panelId: 0,
start_time: '',
end_time: '',
searchName: '',
},
panelId: 0,
filterPanel:'',
//---图表相关参数--end
2020-12-14 20:25:24 +08:00
scrollbarWrap: null,
}
},
components: {
'chart-box': ChartBox,
'chart-list': ChartList,
'time-picker':timePicker,
draggable,
'pick-time':pickTime,
'export-excel':exportXLSX,
2021-01-12 20:39:59 +08:00
selectPanel,
},
methods: {
//刷新
Refresh() {
let 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;
}
this.filter.searchName='';
//this.$refs.searchInput.select();
this.showPanel = val;
this.filter.panelId = this.showPanel.id;
2020-06-09 14:18:27 +08:00
// let curTime = this.$refs.calendarPanel.getCurrentTime();
let curTime=this.searchTime;
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.$refs.chartList.initCurrentRecordNum();
this.$refs.chartList.cleanData();
this.getData(this.filter);
},
2021-01-12 20:39:59 +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("panel?ids=" + u.id).then(response => {
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.$refs.panelBox.setTitle(this.$t("dashboard.panel.editPanelTitle"));
this.$refs.panelBox.show(true);
},
toAdd() {
2020-12-16 11:26:51 +08:00
if (!this.hasButton('panel_view')) {
return;
}
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');
this.searchTime = [startTime, endTime];
},
panelReloadForDel: function () {
if (this.showPanel.id === this.panel.id) {
this.showPanel.id = '';
}
this.getTableData();
},
/*图表相关操作--start*/
addChart() {
this.chart = this.newChart();
this.rightBox.chart.show = true;
},
newChart() {
return JSON.parse(JSON.stringify(this.blankChart));
},
// 编辑图表信息,打开编辑弹窗
editChart(data) {
if (!data.param) {
data.param = {url: '', threshold: '',};
}
this.chart = JSON.parse(JSON.stringify(data));
this.rightBox.chart.show = true;
},
closeChartBox(refresh) {
this.rightBox.chart.show = false;
if (refresh) {
}
},
closePanelBox(refresh) {
this.rightBox.panel.show = false;
if (refresh) {
}
},
// 移除图表:弹出确认框询问
delChart(data,from) {
this.$confirm(this.$t("tip.confirmDelete"), {
confirmButtonText: this.$t("tip.yes"),
cancelButtonText: this.$t("tip.no"),
type: 'warning'
}).then(() => {
this.$delete("panel/" + data.panelId + "/charts?ids=" + data.id).then(response => {
if (response.code === 200) {
this.$message({
duration: 2000,
type: 'success',
message: this.$t("tip.deleteSuccess")
});
this.rightBox.chart.show = false;
let chartList=this.$refs.chartList.dataList;
let nextChart=null,prevChart=null
for (let i =0;i< chartList.length;i++){
if(chartList[i].id === data.id){
chartList.splice(i,1);
}
if(data.next != -1){
if(chartList[i].id === data.next){
nextChart = chartList[i]
}
}
if(data.prev != 0){
if(chartList[i].id === data.prev){
prevChart = chartList[i]
}
}
}
this.$refs.chartList.loadChartData(this.scrollbarWrap.scrollTop);
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);
2020-01-17 16:50:17 +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;
}
if (params.start_time === '' || params.end_time === '') {
2020-09-07 11:43:45 +08:00
let now = bus.getTimezontDateRange();
let endTimeTmp = bus.timeFormate(now[1].getTime(), 'yyyy-MM-dd hh:mm:ss');
let startTimeTmp = bus.timeFormate(now[0].getTime(), 'yyyy-MM-dd hh:mm:ss');
params.start_time = startTimeTmp;
params.end_time = endTimeTmp;
}
if(this.$refs.chartList){
this.$refs.chartList.initData(params);
}
//this.panelReloadOnlyPanel();
},
/*图表相关操作--end*/
/*时间条件查询--start*/
// 选择日期变化
dateChange(val) {
let nowTimeType = this.$refs.pickTime.$refs.timePicker.nowTimeType;
this.setSearchTime(nowTimeType.type,nowTimeType.value);
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');
this.filter.panelId = this.showPanel.id;
this.getTableData();
this.getData(this.filter);
},
setSearchTime(type,val){//设置searchTime
if(type==='minute'){
let 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');
let 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'){
let 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');
let 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'){
let 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');
let 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()
}
});
},
panelReloadOnlyPanel() { //仅刷新panel数据
if (!this.hasButton('panel_view')) {
return;
}
this.$get('panel').then(response => {
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.name = this.panelData[i].name;
break;
}
}
}
});
},
getTableData(clearShowPanel) {
let vm = this;
this.$get('panel?type=dashboard').then(response => {
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));
}
if (clearShowPanel) {
this.showPanel.id = '';
}
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;
}
this.$nextTick(() => {
this.$refs.selectPanel.$refs.panelTree.setCurrentKey(this.showPanel);
});
} else {
this.showPanel.id = '';
this.filter.panelId = '';
}
this.pageObj.total = response.data.total;
if (!isInitData &&(this.panel.id === '' || this.panel.id === this.showPanel.id)) {
this.getData(this.filter);
}
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);
}
}
}).catch((error) => {
//console.log('error................'+JSON.stringify(error));
if (error) {
console.error(error);
this.$message.error(error.toString());
}
});
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);
}
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){
this.$refs.chartList.searchCharts(this.filter.searchName);
}
},
// 滚动事件触发下拉加载
onScroll() {
let _self = this;
2020-12-14 20:25:24 +08:00
this.scrollbarWrap.addEventListener('scroll', bus.debounce(function() {
_self.showTopBtn = _self.scrollbarWrap.scrollTop > 50;
_self.$refs.chartList.loadChartData(_self.scrollbarWrap.scrollTop);
}, 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();
},
/*start (event) {
// console.log('start', event, this.panelData);
event.item.querySelector('.panelContent').style.background = '#d8dce1';
let projectAndAssetFeatureInfos = event.item.querySelectorAll(".feature-content");
if (projectAndAssetFeatureInfos && projectAndAssetFeatureInfos.length > 0) {
projectAndAssetFeatureInfos.forEach(item => {
item.classList.remove("unfold");
item.classList.remove("fold");
});
}
this.panelDataDragTmp = [...this.panelData];
//console.log(this.panelDataDragTmp)
},
end (event) {
// console.info("end event:", event)
let item = event.item;
let oldIndex = event.oldIndex;
let newIndex = event.newIndex;
let newItem = this.panelData[newIndex];
//移动前移动元素前后元素next及prev修改移动后移动元素前后元素next及prev修改--start
let len = this.panelDataDragTmp.length;//移动之前的元素列表
let endIndex = len-1;
if(oldIndex===0){//挪动之前为第一个元素
let oldNextItem = this.panelDataDragTmp[oldIndex+1];
let nextItem = this.panelData.find(item => item.id === oldNextItem.id);
nextItem.prev = 0;
}else if(oldIndex===endIndex){//挪动之前为最后一个元素
let oldPrevItem = this.panelDataDragTmp[oldIndex-1];
let prevItem = this.panelData.find(item => item.id === oldPrevItem.id);
prevItem.next = -1;
}else{//挪动之前为中间元素
let oldPrevItem = this.panelDataDragTmp[oldIndex-1];
let oldNextItem = this.panelDataDragTmp[oldIndex+1];
let nextItem = this.panelData.find(item => item.id === oldNextItem.id);
let prevItem = this.panelData.find(item => item.id === oldPrevItem.id);
prevItem.next = oldNextItem.id;
nextItem.prev = oldPrevItem.id;
}
if(newIndex===0){//挪动之后为第一个元素
let newNextItem = this.panelData[newIndex+1];
newNextItem.prev = newItem.id;
}else if(newIndex===endIndex){//挪动之后为最后一个元素
let newPrevItem = this.panelData[newIndex-1];
newPrevItem.next =newItem.id;
}else{//挪动之后为中间元素
let newPrevItem = this.panelData[newIndex-1];
let newNextItem = this.panelData[newIndex+1];
newPrevItem.next = newItem.id;
newNextItem.prev = newItem.id;
}
//移动前移动元素前后元素next及prev修改移动后移动元素前后元素next及prev修改--end
//前台总列表中的顺序也得修改dataTotalList及dataTotalListBak后台接口也得调用
if(newIndex<oldIndex){//从后往前移动
//console.log('从后往前移动oldIndex='+oldIndex+',newIndex='+newIndex)
let newNextItem = this.panelData[newIndex+1];
newItem.next = newNextItem.id;
let nextItemIndexInTotal = -1;
this.dataTotalListBak.forEach((item,index)=>{
if(item.id===newNextItem.id){
nextItemIndexInTotal = index;
}
})
// console.log('从后往前移动next元素在总列表中之前的元素的index='+nextItemIndexInTotal)
if(nextItemIndexInTotal>0){//总列表中:移动之后的当前元素后面的元素之前有元素
let prevItem = this.dataTotalListBak[nextItemIndexInTotal-1];
newItem.prev = prevItem.id;
}else{//之前无元素
newItem.prev = 0;
}
}else if(newIndex>oldIndex){//从前往后移动
//console.log('从前往后移动oldIndex='+oldIndex+',newIndex='+newIndex)
let newPrevItem = this.panelData[newIndex-1];
newItem.prev = newPrevItem.id;
let prevItemIndexInTotal = -1;
this.dataTotalListBak.forEach((item,index)=>{
if(item.id===newPrevItem.id){
prevItemIndexInTotal = index;
}
});
//console.log('从前往后移动prev元素在总列表中之后的元素的index='+prevItemIndexInTotal)
if(prevItemIndexInTotal<this.dataTotalListBak.length-1){//总列表中移动之后的当前元素前面的元素之后有元素
let nextItem = this.dataTotalListBak[prevItemIndexInTotal+1];
newItem.next = nextItem.id;
}else{//之后无元素
newItem.next = -1;
}
}else {//oldIndex = newIndex
}
//更新图表prev和next
const modifyParams = {
id:newItem.id,
type:'dashboard',
prev:newItem.prev,
next:newItem.next,
};
if(this.panelData.length>1 && oldIndex !== newIndex){
this.$put('panel/modify',modifyParams).then(response => {
if (response.code === 200) {
//修改前台列表中元素的顺序
let curItem = this.dataTotalListBak.find((item,index)=>{return newItem.id===item.id});
let curIndex = this.dataTotalListBak.indexOf(curItem);
this.dataTotalListBak.splice(curIndex,1);
let nextItemTmp = this.dataTotalListBak.find((item)=>{return item.id===newItem.next});
if(nextItemTmp){
let nextIndex = this.dataTotalListBak.indexOf(nextItemTmp);
this.dataTotalListBak.splice(nextIndex,0,newItem);
}else{//移动到最后一个元素
this.dataTotalListBak.push(newItem);
}
this.panelData = this.dataTotalListBak;
this.showPanelList = this.panelData.filter(item=> this.showPanelList.find(t=> t.id == item.id))
}else {
if(response.msg){
this.$message.error(response.msg);
}else if(response.error){
this.$message.error(response.error);
}else {
this.$message.error(response);
}
}
});
}
let chartTitle = item.querySelector('.panelContent');
chartTitle.style.background = '';
},
move (event, orgin) {
// console.log('move', event, orgin);
let dragClass = document.querySelector('.drag-chart-class');//drag-chart-class:yellow chart-ghost:green fallback-class choose-class:purple
// console.log('move---class', dragClass);
//dragClass.style.opacity = 1;
//dragClass.style.pointerEvents = 'auto';//设置此属性end事件里newIndex为 列表长度
let panelContent = dragClass.querySelector('.panelContent');
panelContent.style.background = '#d8dce1';
},*/
2021-01-12 20:39:59 +08:00
/*filterPanelFocus:function(e){
e.stopPropagation();
},
filterPanelFunc:function(){
let $self=this;
if($self.filterPanel&&$self.filterPanel.trim() != ''){
this.showPanelList=this.panelData.filter(item=>item.name.toLowerCase().indexOf($self.filterPanel.toLowerCase()) != -1)
}else{
this.showPanelList = this.panelData;
}
2021-01-12 20:39:59 +08:00
},*/
2020-12-14 20:25:24 +08:00
tableListEnter(){
this.tableHover = true;
},
2020-12-14 20:25:24 +08:00
tableListLeave(){
this.tableHover = false;
},
},
created() {
this.getTableData();
},
mounted() {
2020-12-14 20:25:24 +08:00
this.scrollbarWrap = this.$refs.dashboardScrollbar;
this.onScroll();
2020-12-14 20:25:24 +08:00
document.querySelector("#tableList").addEventListener("mouseenter", this.tableListEnter);
document.querySelector("#tableList").addEventListener("mouseleave", this.tableListLeave);
},
watch: {
'filter.searchName': function(n,o){
let temp=this;
setTimeout(function(){
temp.search();
},1000)
},
},
beforeDestroy(){
2020-12-21 10:06:48 +08:00
if(document.querySelector("#tableList")){
document.querySelector("#tableList").removeEventListener("mouseenter", this.tableListEnter);
document.querySelector("#tableList").removeEventListener("mouseleave", this.tableListLeave);
}
if(this.scrollbarWrap){
this.scrollbarWrap.removeEventListener('scroll', bus.debounce);
};
}
}
</script>
2020-01-17 16:50:17 +08:00
<style scoped lang="scss">
.panel {
2020-01-17 16:50:17 +08:00
height: 100%;
}
2020-01-17 16:50:17 +08:00
.panel .el-table {
2020-01-17 16:50:17 +08:00
border-radius: 5px;
}
2020-01-17 16:50:17 +08:00
.panel-list-width {
2021-01-12 20:39:59 +08:00
width: 400px;
}
.panel-dropdown-title {
line-height:24px;
padding-left:5px;
2020-10-12 13:46:31 +08:00
/*margin-left:10px;*/
margin-top: 3px;
text-align:left;
border-radius:4px;
width:260px;
height:24px;
border:solid 1px #d8dce1;
white-space: nowrap;
overflow-x: hidden;
text-overflow: ellipsis;
}
.panel-list-title {
min-height:24px;
white-space: nowrap;
overflow-x: hidden;
text-overflow: ellipsis;
}
.panel-list-item {
width:190px;
white-space: nowrap;
overflow-x: hidden;
text-overflow: ellipsis;
}
.content-right-option {
2020-01-17 16:50:17 +08:00
cursor: pointer;
display: inline-block;
margin-right: 6px;
}
2020-01-17 16:50:17 +08:00
2020-09-10 17:00:32 +08:00
.content-right-option .nz-icon-delete {
2020-01-17 16:50:17 +08:00
color: #F98D9A;
}
2020-01-17 16:50:17 +08:00
2020-09-10 17:00:32 +08:00
.content-right-option .nz-icon-delete:hover {
2020-01-17 16:50:17 +08:00
color: #D96D7A;
}
2020-01-17 16:50:17 +08:00
2020-09-10 17:00:32 +08:00
.content-right-option .nz-icon-view {
2020-01-17 16:50:17 +08:00
color: #60BEFF;
}
2020-01-17 16:50:17 +08:00
2020-09-10 17:00:32 +08:00
.content-right-option .nz-icon-view:hover {
2020-01-17 16:50:17 +08:00
color: #409EFF;
}
2020-01-17 16:50:17 +08:00
/* begin-chart list*/
.table-list {
margin-top: 0px;
2020-01-17 16:50:17 +08:00
overflow-y: auto;
height: calc(100% - 92px);
}
2020-01-17 16:50:17 +08:00
.box-content {
2020-01-17 16:50:17 +08:00
position: relative;
min-height: 100%;
}
2020-01-17 16:50:17 +08:00
/* end-chart list*/
/* begin--Panel-自定义可编辑的el-select下拉框样式*/
.panel-dropdown-btn {
2020-01-17 16:50:17 +08:00
display: inline-block;
margin-left: 7px;
float: right;
color: #60BEFF;
font-size: 13px
}
2020-01-17 16:50:17 +08:00
.panel-dropdown-btn:hover {
2020-01-17 16:50:17 +08:00
color: #409EFF;
}
2020-01-17 16:50:17 +08:00
.panel-dropdown-btn-create {
2020-01-17 16:50:17 +08:00
display: inline-block;
float: left;
font-size: 13px;
color: #F98D9A;
width: 100%;
}
2020-01-17 16:50:17 +08:00
.panel-dropdown-btn-create:hover {
2020-01-17 16:50:17 +08:00
color: #D96D7A;
}
2020-01-17 16:50:17 +08:00
.panel-dropdown-btn-delete {
2020-01-17 16:50:17 +08:00
color: #F98D9A;
2020-10-22 10:16:03 +08:00
font-size: 13px
}
2020-01-17 16:50:17 +08:00
.panel-dropdown-btn-delete:hover {
2020-01-17 16:50:17 +08:00
color: #D96D7A;
}
2020-01-17 16:50:17 +08:00
.panel-dropdown-error-message {
2020-01-17 16:50:17 +08:00
color: #F98D9A;
}
2020-01-17 16:50:17 +08:00
/* end--Panel-自定义可编辑的el-select下拉框样式*/
.panel-refresh-interval {
2020-01-17 16:50:17 +08:00
margin-right: 5px;
float: right;
}
2020-01-17 16:50:17 +08:00
.panel-refresh-interval-select {
2020-01-17 16:50:17 +08:00
width: 95px;
}
2020-01-17 16:50:17 +08:00
.panel-calendar {
2020-01-17 16:50:17 +08:00
float: right;
margin-right: 1px;
}
2020-01-17 16:50:17 +08:00
.top-tools {
button {
background: $btn-light-background-color;
outline: none;
border: 1px solid #ccc;
}
button:hover {
2020-01-17 18:23:24 +08:00
background: $btn-light-background-color-hover;
}
2020-01-17 18:23:24 +08:00
}
.nz-dashboard-dropdown {
2020-01-17 16:50:17 +08:00
height: 300px;
overflow-y: hidden;
li {
/*padding: 0 20px !important;*/
padding-left:20px !important;
padding-right:0px !important;
width:240px;
white-space:nowrap;
overflow-x:hidden;
text-overflow:ellipsis;
2020-01-17 16:50:17 +08:00
}
}
2020-01-17 16:50:17 +08:00
.nz-dashboard-dropdown-bg {
background: $global-text-color-active;
2020-01-17 16:50:17 +08:00
color: #fff;
}
2020-01-17 16:50:17 +08:00
.el-dropdown-link {
2020-01-17 16:50:17 +08:00
cursor: pointer;
font-weight: bold;
}
.refresh {
2020-01-17 16:50:17 +08:00
display: flex;
background: #fff;
border-radius: 4px;
align-items: center;
2020-01-17 18:23:24 +08:00
justify-content: center;
2020-01-17 16:50:17 +08:00
margin: 0 10px;
border: 1px solid #ccc;
background: $btn-light-background-color;
span {
2020-01-17 16:50:17 +08:00
display: inline-block;
2020-01-17 18:23:24 +08:00
padding: 1px 8px;
2020-01-17 16:50:17 +08:00
}
}
.popover_ul li {
2020-01-17 16:50:17 +08:00
padding: 10px 3px;
cursor: pointer;
}
.popover_ul li:hover {
background: $dropdown-hover-background-color !important;
color: $global-text-color-active !important;
}
.nz-dashboard-refresh {
border-right: 1px solid #ccc;
color: #F0BF84;
}
.nz-dashboard-picker {
}
.move-area:hover{
cursor: move;
}
</style>
<style lang="scss">
2021-01-12 20:39:59 +08:00
.panel-name {
position: relative;
.el-input__prefix i {
position: absolute;
left: 3px;
top: calc(50% + 1px);
transform: translateY(-50%);
}
}
.panel-name>input {
cursor: pointer;
padding-left: 27px !important;
}
.panel-select-header {
padding: 0 0 10px 16px;
width: 400px;
}
.panel-select-add {
cursor: pointer;
}
.panel-select-add:hover {
color: $global-text-color-active;
}
.panel .top-tools input {
background-color: $content-right-background-color;
}
.panel .top-tools .el-input__inner {
background-color: $content-right-background-color;
}
.panel-calendar .el-range-editor--mini.el-input__inner {
height: 25px !important;
border-color: #d8d8d8;
}
.panel-calendar .el-range-editor--mini .el-range__close-icon {
line-height: 18px;
}
.panel-calendar .el-range-editor--mini .el-range__icon {
display: none;
}
.panel-calendar .el-range-editor--mini .el-range-separator {
line-height: 17px;
}
.panel-calendar .el-date-editor--datetimerange.el-input, .panel-calendar .el-date-editor--datetimerange.el-input__inner {
padding-right: 0;
vertical-align: top;
}
.nz-dashboard-dropdown .nz-icon-edit {
2020-10-22 10:16:03 +08:00
font-size: 16px;
vertical-align: middle;
}
.nz-dashboard-dropdown .nz-icon-delete {
vertical-align: middle;
}
.panel-title-li{
.panel-dropdown-btn{
visibility: hidden;
}
}
.panel-title-li:hover{
.panel-dropdown-btn{
visibility: visible;
}
}
2020-01-17 16:50:17 +08:00
</style>