CN-53 perf: cn-53第一条,饼图legend事件完善
This commit is contained in:
@@ -454,8 +454,7 @@ export default {
|
|||||||
tableQueryParams[chartParams.nameColumn] = [] // 处理两个图表不一样的地方
|
tableQueryParams[chartParams.nameColumn] = [] // 处理两个图表不一样的地方
|
||||||
get(replaceUrlPlaceholder(chartParams.url, queryParams)).then(response => {
|
get(replaceUrlPlaceholder(chartParams.url, queryParams)).then(response => {
|
||||||
if (response.code === 200) {
|
if (response.code === 200) {
|
||||||
const data = response.data.result
|
const data = response.data.result.map(d => {
|
||||||
this.chartOption.series[0].data = data.map(d => {
|
|
||||||
tableQueryParams[chartParams.nameColumn].push(d[chartParams.nameColumn])
|
tableQueryParams[chartParams.nameColumn].push(d[chartParams.nameColumn])
|
||||||
return {
|
return {
|
||||||
data: d,
|
data: d,
|
||||||
@@ -463,6 +462,7 @@ export default {
|
|||||||
value: parseInt(d[chartParams.valueColumn])
|
value: parseInt(d[chartParams.valueColumn])
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
this.chartOption.series[0].data = data
|
||||||
if (this.chartOption.series[0].data && this.chartOption.series[0].data.length > 10) { // pieWithTable 图例超过10个改为滚动显示
|
if (this.chartOption.series[0].data && this.chartOption.series[0].data.length > 10) { // pieWithTable 图例超过10个改为滚动显示
|
||||||
this.chartOption.legend.type = 'scroll'
|
this.chartOption.legend.type = 'scroll'
|
||||||
}
|
}
|
||||||
@@ -477,26 +477,51 @@ export default {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
// legend点击事件
|
||||||
this.myChart.on('legendselectchanged', function (params) {
|
this.myChart.on('legendselectchanged', function (params) {
|
||||||
self.myChart.setOption({
|
self.myChart.setOption({
|
||||||
legend: { selected: { [params.name]: true } }
|
legend: { selected: { [params.name]: true } }
|
||||||
})
|
})
|
||||||
})
|
self.chartOption.series[0].data.forEach((d, i) => {
|
||||||
this.myChart.on('click', function (echartParams) {
|
if (self.selectPieChartName === d.name) {
|
||||||
const childrenParams = { startTime: parseInt(self.startTime / 1000), endTime: parseInt(self.endTime / 1000), limit: 10, order: self.orderPieTable }
|
self.myChart.dispatchAction({
|
||||||
childrenParams[chartParams.nameColumn] = echartParams.name
|
type: 'unselect',
|
||||||
if (self.selectPieChartName === echartParams.name) {
|
seriesIndex: 0,
|
||||||
self.selectPieChartName = ''
|
dataIndex: i
|
||||||
childrenParams[chartParams.nameColumn] = tableQueryParams[chartParams.nameColumn]
|
})
|
||||||
} else {
|
self.loadPieTableData()
|
||||||
self.selectPieChartName = echartParams.name
|
} else {
|
||||||
}
|
if (d.name === params.name) {
|
||||||
get(replaceUrlPlaceholder(chartParams.urlTable, childrenParams)).then(response2 => {
|
self.selectPieChartName = d.name
|
||||||
if (response2.code === 200) {
|
self.myChart.dispatchAction({
|
||||||
self.pieTableData = response2.data.result
|
type: 'select',
|
||||||
|
seriesIndex: 0,
|
||||||
|
dataIndex: i
|
||||||
|
})
|
||||||
|
self.loadPieTableData(params.name)
|
||||||
|
} else {
|
||||||
|
self.myChart.dispatchAction({
|
||||||
|
type: 'unselect',
|
||||||
|
seriesIndex: 0,
|
||||||
|
dataIndex: i
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
// 饼图色块点击事件
|
||||||
|
this.myChart.on('click', function (echartParams) {
|
||||||
|
self.loadPieTableData(echartParams.name)
|
||||||
|
})
|
||||||
|
},
|
||||||
|
loadPieTableData (name = '') {
|
||||||
|
const childrenParams = { startTime: parseInt(this.startTime / 1000), endTime: parseInt(this.endTime / 1000), limit: 10, order: this.orderPieTable }
|
||||||
|
childrenParams[this.chartInfo.params.nameColumn] = name
|
||||||
|
get(replaceUrlPlaceholder(this.chartInfo.params.urlTable, childrenParams)).then(response => {
|
||||||
|
if (response.code === 200) {
|
||||||
|
this.pieTableData = response.data.result
|
||||||
|
}
|
||||||
|
})
|
||||||
},
|
},
|
||||||
tableLimitChange () {
|
tableLimitChange () {
|
||||||
const chartParams = this.chartInfo.params || null // 图表参数
|
const chartParams = this.chartInfo.params || null // 图表参数
|
||||||
|
|||||||
Reference in New Issue
Block a user