Commit c5411a99 by wangr

Merge remote-tracking branch 'origin/20210819' into wangrui

parents 25fddfb9 aad6f3a3
Subproject commit f4746173cf454453e2895964ec3ed3d6a13d0e42 Subproject commit 0a4f2d33af0abc1da40e1482e27708fb9bea6ac1
...@@ -5,9 +5,7 @@ ...@@ -5,9 +5,7 @@
</template> </template>
<script> <script>
import * as echarts from 'echarts' import mixinChart from 'runner/common/mixins/mixinChart'
import mixinChart from '@/public/mixins/mixinChart'
export default { export default {
name: 'lineBar', name: 'lineBar',
...@@ -24,7 +22,10 @@ export default { ...@@ -24,7 +22,10 @@ export default {
layout: { layout: {
type: Object, type: Object,
default () { default () {
return {} return {
width: '100%',
height: '100%'
}
} }
}, },
...@@ -46,34 +47,44 @@ export default { ...@@ -46,34 +47,44 @@ export default {
methods: { methods: {
initComponents () { initComponents () {
const { width = '', height = '', id = '', className = 'line-bar-chart-class' } = this.mergeChartConf() || {} const { width = '', height = '' } = this.layout
// 基础配置, 不含series const option = this.getChartOption() || {}
const option = this.getChartOption(this.option.base) || {}
const seriesData = this.getSeriesData(this.option.seriesData || []) || []
// if (!seriesData.length) {
// throw Error('该组件图表数据只能接受length为2的数组')
// }
option.series = seriesData
this.barChartConf = { this.barChartConf = {
className,
id,
width, width,
height, height,
option option,
id: 'line-bar-chart-id' + this.utils.randomStr()
} }
}, },
/** /**
* @method mergeChartConf 合并图表配置项 * @method getSeriesData 图表数据
*/ */
mergeChartConf () { getSeriesData (data) {
const defaultChartConf = { const defSeriesOpts = {
width: '100%', name: 'back',
height: '100%', type: 'bar',
// 不同的id(防止id重复,同一个页面,无法展示多个同组件图表) barWidth: '4px',
id: 'line-bar-chart-id' + this.utils.randomStr() itemStyle: {
borderRadius: [0, 0, 0, 0],
normal: {
color: '#233549'
}
},
barGap: '-100%',
data: []
} }
return this.deepMerge({}, defaultChartConf, this.layout) let result = [defSeriesOpts]
const { seriesData = [] } = this.option
console.log(this.option)
if (seriesData.length) {
const temp = []
seriesData.forEach(item => {
temp.push(this.deepMerge({}, defSeriesOpts, item))
})
result = temp
}
return result
}, },
/** /**
...@@ -86,7 +97,7 @@ export default { ...@@ -86,7 +97,7 @@ export default {
}, },
grid: { grid: {
left: 0, left: 0,
right: 10, right: 5,
bottom: 0, bottom: 0,
top: 0, top: 0,
containLabel: true containLabel: true
...@@ -108,7 +119,7 @@ export default { ...@@ -108,7 +119,7 @@ export default {
}, },
yAxis: [ yAxis: [
{ {
type: 'category', type: 'category', // y 轴左侧的数据
axisTick: { axisTick: {
show: false show: false
}, },
...@@ -130,7 +141,7 @@ export default { ...@@ -130,7 +141,7 @@ export default {
}, },
data: [] data: []
}, { }, {
type: 'category', type: 'category', // y 轴右侧的数据
axisLine: { axisLine: {
show: false show: false
}, },
...@@ -161,57 +172,10 @@ export default { ...@@ -161,57 +172,10 @@ export default {
} }
] ]
} }
return this.deepMerge({}, defaultOption, customOption) const result = this.deepMerge({}, defaultOption, this.option.base)
}, result.series = this.getSeriesData()
/** return result
* @method getSeriesData 图表数据
*/
getSeriesData () {
if (this.option.seriesData.length !== 2) return []
const defSeriesData = [
{
name: 'back',
type: 'bar',
barWidth: '4px',
itemStyle: {
borderRadius: [0, 0, 0, 0],
normal: {
color: '#233549'
}
},
barGap: '-100%',
data: [1, 2, 3]
},
{
name: 'show',
type: 'bar',
barWidth: '4px',
itemStyle: {
borderRadius: [0, 0, 0, 0],
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{
offset: 0,
color: 'rgba(59, 150, 235, 0.1)'
}, {
offset: 1,
color: '#3b96eb'
}], false)
}
},
markPoint: {
symbol: 'image://',
symbolSize: [10, 10],
data: []
},
data: [],
z: 3
}
]
const seriesData = [{}, {}]
seriesData[0] = this.deepMerge({}, defSeriesData[0], this.option.seriesData[0])
seriesData[1] = this.deepMerge({}, defSeriesData[1], this.option.seriesData[1])
return seriesData
} }
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment