| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
 | | <template> |  |   <div class="chart-wrapper" ref="turnoverLine"></div> |  | </template> |  |   |  | <script> |  | import resize from '@/mixins/resize'; |  | const echarts = require('echarts'); |  | export default { |  |   name: 'turnoverLine', |  |   props: { |  |     chartData: { |  |       type: Object, |  |       default: () => {} |  |     }, |  |     colorList: { |  |       type: Array, |  |       default: () => [] |  |     }, |  |     colors: { |  |       type: String, |  |       default: '#636972' |  |     } |  |   }, |  |   mixins: [resize], |  |   data() { |  |     return {}; |  |   }, |  |   mounted() { |  |     this.initEchart(); |  |   }, |  |   methods: { |  |     initEchart() { |  |       // 基于准备好的dom,初始化echarts实例 |  |       let serieslist = []; |  |       let data = this.chartData.data; |  |       if (data) { |  |         data.forEach((element, index) => { |  |           serieslist.push({ |  |             name: element.name, |  |             type: 'bar', |  |             showBackground: false, |  |             barBorderRadius: 30, |  |             yAxisIndex: 0, |  |             barMaxWidth: 30, |  |             itemStyle: { |  |               normal: { |  |                 color: new echarts.graphic.LinearGradient( |  |                   0, |  |                   1, |  |                   1, |  |                   0, |  |                   [ |  |                     { |  |                       offset: 0, |  |                       color: this.colorList[index] |  |                     }, |  |   |  |                     { |  |                       offset: 1, |  |                       color: this.colorList[index] |  |                     } |  |                   ], |  |                   false |  |                 ), |  |                 barBorderRadius: 10 |  |               }, |  |               barBorderRadius: 4 |  |             }, |  |   |  |             data: element.xdata, |  |             label: { |  |               show: true, |  |               position: 'top', |  |               distance: 10, |  |               fontSize: 36, |  |               color: this.colors |  |             } |  |           }); |  |         }); |  |       } |  |       this.myChart = echarts.init(this.$refs.turnoverLine); |  |       this.myChart.setOption( |  |         { |  |           title: { |  |             show: true, |  |             text: data ? '制件周转时间' : '暂无数据', |  |             x: 'center', |  |             y: data ? '2%' : 'center', |  |             textAlign: null, //水平对齐方式,默认根据x设置自动调整,可选为: left' | 'right' | 'center |  |             textStyle: { |  |               //主标题文本样式{"fontSize": 18,"fontWeight": "bolder",} |  |               color: this.colors, |  |               fontWeight: 'normal', |  |               fontSize: 50 |  |             } |  |           }, |  |   |  |           color: this.colorList, |  |           legend: { |  |             right: '1%', |  |             top: '10%', |  |             textStyle: { |  |               color: this.colors, |  |               fontSize: 36 |  |             } |  |           }, |  |           tooltip: { |  |             trigger: 'axis', |  |   |  |             axisPointer: { |  |               type: 'shadow' |  |             }, |  |             textStyle: { |  |               fontSize: 36 |  |             } |  |           }, |  |           grid: { |  |             left: '5%', |  |             right: '1%', |  |             bottom: '1%', |  |             top: '20%', |  |             //    padding:'0 0 10 0', |  |             containLabel: true |  |           }, |  |           xAxis: [ |  |             { |  |               type: 'category', |  |               axisLabel: { |  |                 interval: 0, //设置为 1,表示『隔一个标签显示一个标签』 |  |                 margin: 10, |  |                 textStyle: { |  |                   fontSize: 16 |  |                 } |  |               }, |  |               axisLine: { show: true, lineStyle: { color: this.colors, width: 10 } }, |  |               splitLine: { |  |                 show: false, |  |                 lineStyle: { color: this.colors, width: 10 } |  |               }, |  |               axisTick: { |  |                 show: false |  |               }, |  |               data: this.chartData.xdata |  |             } |  |           ], |  |           yAxis: [ |  |             { |  |               name: '周转天数(天)', |  |               nameTextStyle: { fontSize: 28 }, |  |               type: 'value', |  |               splitNumber: 5, |  |               min: function (value) { |  |                 let max = value.max; |  |                 let min = value.min; |  |                 let minimum = max - ((max - min) * 3) / 2; |  |                 if (minimum > 0) { |  |                   return minimum; |  |                 } else { |  |                   return 0; |  |                 } |  |               }, |  |               axisLabel: { |  |                 textStyle: { |  |                   fontSize: 36 |  |                 } |  |               }, |  |               axisLine: { |  |                 lineStyle: { |  |                   color: this.colors, |  |                   width: 10 |  |                 } |  |               }, |  |               axisTick: { |  |                 show: false |  |               }, |  |               splitLine: { |  |                 show: true, |  |                 lineStyle: { |  |                   color: this.colors, |  |                   width: 10 |  |                 } |  |               } |  |             } |  |           ], |  |           dataZoom: [ |  |             { |  |               type: 'inside', |  |               startValue: 10, |  |               endValue: 20 |  |             } |  |           ], |  |           series: serieslist |  |         }, |  |         true |  |       ); |  |     } |  |   }, |  |   watch: { |  |     chartData: { |  |       handler() { |  |         this.initEchart(); |  |       }, |  |       deep: true |  |     } |  |   } |  | }; |  | </script> | 
 |