@cloudbase/weda-ui 0.2.15 → 1.0.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (250) hide show
  1. package/README.md +41 -169
  2. package/package.json +28 -15
  3. package/src/configs/components/calendar.json +78 -0
  4. package/src/configs/components/carousel.json +273 -0
  5. package/src/configs/components/chart/bar.json +724 -0
  6. package/src/configs/components/chart/line.json +679 -0
  7. package/src/configs/components/chart/pie.json +497 -0
  8. package/src/configs/components/chart/statisticsCard.json +379 -0
  9. package/src/configs/components/container.json +7 -2
  10. package/src/configs/components/dataView.json +154 -0
  11. package/src/configs/components/form/checkbox.json +97 -5
  12. package/src/configs/components/form/location.json +152 -0
  13. package/src/configs/components/form/radio.json +96 -4
  14. package/src/configs/components/form/select.json +245 -11
  15. package/src/configs/components/form/uploaderFile.json +2 -1
  16. package/src/configs/components/graphicCard.json +410 -0
  17. package/src/configs/components/image.json +7 -2
  18. package/src/configs/components/link.json +20 -4
  19. package/src/configs/components/listView.json +277 -0
  20. package/src/configs/components/modal.json +37 -5
  21. package/src/configs/components/navLayout.json +362 -0
  22. package/src/configs/components/navigationBar.json +59 -0
  23. package/src/configs/components/richtextview.json +4 -1
  24. package/src/configs/components/scrollVeiw.json +74 -22
  25. package/src/configs/components/swiper.json +6 -3
  26. package/src/configs/components/tabs.json +51 -8
  27. package/src/configs/components/text.json +33 -25
  28. package/src/configs/components/wxOpenApi/phone.json +141 -0
  29. package/src/configs/components/wxOpenApi/phoneCode.json +121 -0
  30. package/src/configs/components/wxOpenApi/share.json +167 -0
  31. package/src/configs/components/wxOpenApi/userInfo.json +174 -0
  32. package/src/configs/index.js +34 -0
  33. package/src/mp/components/button/index.js +12 -13
  34. package/src/mp/components/button/index.wxml +1 -1
  35. package/src/mp/components/calendar/arrowright--line.svg +11 -0
  36. package/src/mp/components/calendar/index.js +238 -0
  37. package/src/mp/components/calendar/index.json +4 -0
  38. package/src/mp/components/calendar/index.wxml +37 -0
  39. package/src/mp/components/calendar/index.wxss +178 -0
  40. package/src/mp/components/carousel/index.js +88 -0
  41. package/src/mp/components/carousel/index.json +7 -0
  42. package/src/mp/components/carousel/index.wxml +6 -0
  43. package/src/mp/components/chart/bar/index.js +258 -0
  44. package/src/mp/components/chart/bar/index.json +6 -0
  45. package/src/mp/components/chart/bar/index.wxml +3 -0
  46. package/src/mp/components/chart/bar/index.wxss +9 -0
  47. package/src/mp/components/chart/common/config/bar.js +50 -0
  48. package/src/mp/components/chart/common/config/global.js +16 -0
  49. package/src/mp/components/chart/common/config/line.js +48 -0
  50. package/src/mp/components/chart/common/config/pie.js +36 -0
  51. package/src/mp/components/chart/common/core/eChartBar.js +263 -0
  52. package/src/mp/components/chart/common/core/eChartBase.js +375 -0
  53. package/src/mp/components/chart/common/core/eChartLine.js +229 -0
  54. package/src/mp/components/chart/common/core/eChartPie.js +166 -0
  55. package/src/mp/components/chart/common/lib/echarts.min.js +18 -0
  56. package/src/mp/components/chart/ec-canvas/ec-canvas.js +277 -0
  57. package/src/mp/components/chart/ec-canvas/ec-canvas.json +4 -0
  58. package/src/mp/components/chart/ec-canvas/ec-canvas.wxml +4 -0
  59. package/src/mp/components/chart/ec-canvas/ec-canvas.wxss +4 -0
  60. package/src/mp/components/chart/ec-canvas/wx-canvas.js +107 -0
  61. package/src/mp/components/chart/line/index.js +247 -0
  62. package/src/mp/components/chart/line/index.json +6 -0
  63. package/src/mp/components/chart/line/index.wxml +3 -0
  64. package/src/mp/components/chart/line/index.wxss +9 -0
  65. package/src/mp/components/chart/pie/index.js +182 -0
  66. package/src/mp/components/chart/pie/index.json +6 -0
  67. package/src/mp/components/chart/pie/index.wxml +4 -0
  68. package/src/mp/components/chart/pie/index.wxss +9 -0
  69. package/src/mp/components/chart/statisticsCard/index.js +253 -0
  70. package/src/mp/components/chart/statisticsCard/index.json +4 -0
  71. package/src/mp/components/chart/statisticsCard/index.wxml +9 -0
  72. package/src/mp/components/chart/statisticsCard/index.wxss +45 -0
  73. package/src/mp/components/dataView/index.js +34 -0
  74. package/src/mp/components/dataView/index.json +7 -0
  75. package/src/mp/components/dataView/index.wxml +15 -0
  76. package/src/mp/components/dataView/index.wxss +0 -0
  77. package/src/mp/components/form/checkbox/index.js +41 -2
  78. package/src/mp/components/form/checkbox/index.wxml +1 -1
  79. package/src/mp/components/form/input/index.js +1 -1
  80. package/src/mp/components/form/location/components/mapChoose/index.js +201 -0
  81. package/src/mp/components/form/location/components/mapChoose/index.json +4 -0
  82. package/src/mp/components/form/location/components/mapChoose/index.wxml +42 -0
  83. package/src/mp/components/form/location/components/mapChoose/index.wxss +188 -0
  84. package/src/mp/components/form/location/index.js +382 -0
  85. package/src/mp/components/form/location/index.json +6 -0
  86. package/src/mp/components/form/location/index.wxml +25 -0
  87. package/src/mp/components/form/location/index.wxss +91 -0
  88. package/src/mp/components/form/radio/index.js +38 -0
  89. package/src/mp/components/form/select/index.js +360 -40
  90. package/src/mp/components/form/select/index.wxml +21 -6
  91. package/src/mp/components/form/select/region/index.js +98 -0
  92. package/src/mp/components/form/textarea/index.wxml +6 -5
  93. package/src/mp/components/form/uploader/index.js +84 -48
  94. package/src/mp/components/form/uploader/index.wxml +15 -3
  95. package/src/mp/components/form/uploaderFile/index.js +106 -27
  96. package/src/mp/components/graphicCard/chevron-right.svg +3 -0
  97. package/src/mp/components/graphicCard/index.js +203 -0
  98. package/src/mp/components/graphicCard/index.json +4 -0
  99. package/src/mp/components/graphicCard/index.wxml +29 -0
  100. package/src/mp/components/graphicCard/index.wxss +157 -0
  101. package/src/mp/components/image/index.js +0 -1
  102. package/src/mp/components/listView/arrow-right-line.svg +3 -0
  103. package/src/mp/components/listView/index.js +285 -0
  104. package/src/mp/components/listView/index.json +4 -0
  105. package/src/mp/components/listView/index.wxml +40 -0
  106. package/src/mp/components/listView/index.wxss +155 -0
  107. package/src/mp/components/listView/more-line.svg +3 -0
  108. package/src/mp/components/navLayout/index.js +123 -0
  109. package/src/mp/components/navLayout/index.json +7 -0
  110. package/src/mp/components/navLayout/index.wxml +25 -0
  111. package/src/mp/components/navLayout/index.wxss +1193 -0
  112. package/src/mp/components/navigationBar/index.js +193 -0
  113. package/src/mp/components/navigationBar/index.json +6 -0
  114. package/src/mp/components/navigationBar/index.wxml +88 -0
  115. package/src/mp/components/navigationBar/index.wxss +1257 -0
  116. package/src/mp/components/swiper/index.wxml +2 -0
  117. package/src/mp/components/tabs/index.js +7 -2
  118. package/src/mp/components/tabs/index.wxml +2 -1
  119. package/src/mp/components/text/index.js +0 -25
  120. package/src/mp/components/text/index.wxml +3 -3
  121. package/src/mp/components/wxOpenApi/phone/index.js +117 -0
  122. package/src/mp/components/wxOpenApi/phone/index.json +4 -0
  123. package/src/mp/components/wxOpenApi/phone/index.wxml +15 -0
  124. package/src/mp/components/wxOpenApi/phone/index.wxss +22 -0
  125. package/src/mp/components/wxOpenApi/phoneCode/index.js +89 -0
  126. package/src/mp/components/wxOpenApi/phoneCode/index.json +4 -0
  127. package/src/mp/components/wxOpenApi/phoneCode/index.wxml +15 -0
  128. package/src/mp/components/wxOpenApi/phoneCode/index.wxss +22 -0
  129. package/src/mp/components/wxOpenApi/share/index.js +117 -0
  130. package/src/mp/components/wxOpenApi/share/index.json +4 -0
  131. package/src/mp/components/wxOpenApi/share/index.wxml +15 -0
  132. package/src/mp/components/wxOpenApi/share/index.wxss +22 -0
  133. package/src/mp/components/wxOpenApi/userInfo/index.js +88 -0
  134. package/src/mp/components/wxOpenApi/userInfo/index.json +4 -0
  135. package/src/mp/components/wxOpenApi/userInfo/index.wxml +14 -0
  136. package/src/mp/components/wxOpenApi/userInfo/index.wxss +22 -0
  137. package/src/mp/index.json +18 -2
  138. package/src/mp/style/weda-ui.wxss +2 -0
  139. package/src/mp/utils/debounce.js +133 -0
  140. package/src/mp/utils/destr.js +48 -0
  141. package/src/mp/utils/dr_square_point.js +25 -0
  142. package/src/mp/utils/platform.js +25 -0
  143. package/src/mp/utils/qqmap-wx-jssdk1.2/qqmap-wx-jssdk.js +1336 -0
  144. package/src/mp/utils/spark-md5.js +776 -0
  145. package/src/mp/utils/tcb.js +62 -0
  146. package/src/setupTests.js +2 -1
  147. package/src/web/components/button/index.css +8 -1
  148. package/src/web/components/button/index.tsx +3 -2
  149. package/src/web/components/calendar/index.css +382 -0
  150. package/src/web/components/calendar/index.jsx +312 -0
  151. package/src/web/components/calendar/util.js +90 -0
  152. package/src/web/components/carousel/index.css +119 -0
  153. package/src/web/components/carousel/index.tsx +417 -0
  154. package/src/web/components/chart/bar/index.tsx +140 -0
  155. package/src/web/components/chart/common/config/bar.js +49 -0
  156. package/src/web/components/chart/common/config/global.js +16 -0
  157. package/src/web/components/chart/common/config/line.js +50 -0
  158. package/src/web/components/chart/common/config/pie.js +37 -0
  159. package/src/web/components/chart/common/core/eChartBar.js +265 -0
  160. package/src/web/components/chart/common/core/eChartBase.ts +383 -0
  161. package/src/web/components/chart/common/core/eChartLine.js +231 -0
  162. package/src/web/components/chart/common/core/eChartPie.js +170 -0
  163. package/src/web/components/chart/common/core/type.ts +34 -0
  164. package/src/web/components/chart/common/echart.css +106 -0
  165. package/src/web/components/chart/common/echarts.ts +33 -0
  166. package/src/web/components/chart/common/useChart.tsx +69 -0
  167. package/src/web/components/chart/line/index.tsx +136 -0
  168. package/src/web/components/chart/pie/index.tsx +99 -0
  169. package/src/web/components/chart/statisticsCard/index.css +62 -0
  170. package/src/web/components/chart/statisticsCard/index.tsx +307 -0
  171. package/src/web/components/chart/statisticsCard/interface.ts +14 -0
  172. package/src/web/components/dataView/index.tsx +20 -0
  173. package/src/web/components/dataView/interface.ts +6 -0
  174. package/src/web/components/form/checkbox/index.tsx +55 -23
  175. package/src/web/components/form/location/common/mapChoose.css +178 -0
  176. package/src/web/components/form/location/common/mapChoose.jsx +343 -0
  177. package/src/web/components/form/location/common/mapView.jsx +190 -0
  178. package/src/web/components/form/location/common/propsConfig.js +54 -0
  179. package/src/web/components/form/location/common/selectModal.css +44 -0
  180. package/src/web/components/form/location/common/selectModal.jsx +82 -0
  181. package/src/web/components/form/location/common/useLocationInfo.js +100 -0
  182. package/src/web/components/form/location/components/LocationH5/index.css +243 -0
  183. package/src/web/components/form/location/components/LocationH5/location.h5.jsx +403 -0
  184. package/src/web/components/form/location/components/LocationPC/Header.jsx +109 -0
  185. package/src/web/components/form/location/components/LocationPC/index.css +44 -0
  186. package/src/web/components/form/location/components/LocationPC/location.PC.jsx +323 -0
  187. package/src/web/components/form/location/constants.js +4 -0
  188. package/src/web/components/form/location/index.css +0 -0
  189. package/src/web/components/form/location/index.jsx +25 -0
  190. package/src/web/components/form/radio/index.tsx +84 -53
  191. package/src/web/components/form/select/h5.tsx +389 -71
  192. package/src/web/components/form/select/index.css +10 -0
  193. package/src/web/components/form/select/index.tsx +404 -144
  194. package/src/web/components/form/select/region/index.ts +122 -31
  195. package/src/web/components/form/select/time.jsx +90 -0
  196. package/src/web/components/form/select/year.tsx +170 -0
  197. package/src/web/components/form/uploader/uploader.h5.tsx +19 -4
  198. package/src/web/components/form/uploader/uploader.pc.tsx +8 -7
  199. package/src/web/components/form/uploaderFile/uploadFile.h5.tsx +132 -113
  200. package/src/web/components/form/uploaderFile/uploadFile.pc.tsx +16 -11
  201. package/src/web/components/graphicCard/index.css +159 -0
  202. package/src/web/components/graphicCard/index.tsx +310 -0
  203. package/src/web/components/image/image.tsx +1 -2
  204. package/src/web/components/image/index.tsx +1 -1
  205. package/src/web/components/index.js +24 -2
  206. package/src/web/components/link/index.tsx +6 -3
  207. package/src/web/components/listView/arrow-right-line.svg +3 -0
  208. package/src/web/components/listView/index.css +143 -0
  209. package/src/web/components/listView/index.tsx +359 -0
  210. package/src/web/components/listView/interface.ts +98 -0
  211. package/src/web/components/modal/index.tsx +3 -1
  212. package/src/web/components/navLayout/index.css +332 -0
  213. package/src/web/components/navLayout/index.tsx +247 -0
  214. package/src/web/components/navigationBar/chevron-right--double.svg +3 -0
  215. package/src/web/components/navigationBar/common.tsx +198 -0
  216. package/src/web/components/navigationBar/h5Menu.tsx +179 -0
  217. package/src/web/components/navigationBar/horizontalMenu.tsx +200 -0
  218. package/src/web/components/navigationBar/index.css +762 -0
  219. package/src/web/components/navigationBar/index.tsx +231 -0
  220. package/src/web/components/navigationBar/type.d.ts +111 -0
  221. package/src/web/components/navigationBar/verticalMenu.tsx +81 -0
  222. package/src/web/components/phone/index.css +0 -0
  223. package/src/web/components/phone/index.tsx +22 -0
  224. package/src/web/components/phoneCode/index.css +0 -0
  225. package/src/web/components/phoneCode/index.tsx +22 -0
  226. package/src/web/components/richTextView/index.tsx +3 -5
  227. package/src/web/components/share/index.css +0 -0
  228. package/src/web/components/share/index.tsx +38 -0
  229. package/src/web/components/tabs/index.tsx +4 -2
  230. package/src/web/components/tabs/tabs.h5.tsx +50 -37
  231. package/src/web/components/tabs/tabs.pc.tsx +23 -10
  232. package/src/web/components/text/index.tsx +6 -14
  233. package/src/web/components/uploaderFileView/index.css +9 -9
  234. package/src/web/components/uploaderFileView/index.jsx +32 -23
  235. package/src/web/components/userInfo/index.css +0 -0
  236. package/src/web/components/userInfo/index.tsx +30 -0
  237. package/src/web/types.d.ts +15 -14
  238. package/src/web/utils/debounce.js +98 -0
  239. package/src/web/utils/platform.js +40 -0
  240. package/src/web/utils/tcb.js +49 -0
  241. package/src/web/utils/tmap.js +4 -0
  242. package/src/web/weda-ui.css +2 -0
  243. package/CHANGELOG.md +0 -240
  244. package/src/.DS_Store +0 -0
  245. package/src/configs/.DS_Store +0 -0
  246. package/src/mp/.gitignore +0 -10
  247. package/src/web/.DS_Store +0 -0
  248. package/src/web/components/form/select/region/cities.ts +0 -2410
  249. package/src/web/components/form/select/region/provinces.ts +0 -240
  250. package/src/web/components/form/select/region/regions.ts +0 -20645
@@ -0,0 +1,229 @@
1
+ import EchartBase from './eChartBase';
2
+ import getConfig from '../config/line';
3
+ /**
4
+ * 折线图表
5
+ * @author loonglong
6
+ **/
7
+ class EchartLine extends EchartBase {
8
+ constructor() {
9
+ super();
10
+ const config = getConfig();
11
+ this.config = { ...this.config, ...config };
12
+ }
13
+ async setSourceData({
14
+ dataSource,
15
+ filterData,
16
+ xField,
17
+ xStatistics,
18
+ xIsCountEmpty,
19
+ yField,
20
+ groupKey,
21
+ groupKeyTimeSpan,
22
+ }) {
23
+ xField = xField || {}; // 向前兼容
24
+ const { name = '', type = '', methodName = '' } = dataSource;
25
+ if (name !== '') {
26
+ const params = this.createWhere({
27
+ filterData,
28
+ xField,
29
+ xStatistics,
30
+ xIsCountEmpty,
31
+ yField,
32
+ groupKey,
33
+ groupKeyTimeSpan,
34
+ });
35
+ const arrSourData = await this.getSourceData(
36
+ name,
37
+ methodName,
38
+ type,
39
+ params,
40
+ );
41
+ // 获取 x 轴数据
42
+ const sortedXAxisData = this.sortXAxisData(arrSourData, xField.format);
43
+ const arrXaxisData = this.setXaxis(sortedXAxisData, xField.format);
44
+ const arrXisCountEmptyIndex = []; // 记录空值的key
45
+ if (Object.keys(groupKey ?? {}).length === 0) {
46
+ const numLine = arrSourData[0].YLabels.length;
47
+ if (numLine > 0) {
48
+ for (let j = 0; j < numLine; j++) {
49
+ this.config.series[j] = {
50
+ type: 'line',
51
+ smooth: true,
52
+ name: '',
53
+ connectNulls: true,
54
+ showSymbol: true,
55
+ label: {
56
+ show: true,
57
+ },
58
+ data: [],
59
+ };
60
+ sortedXAxisData.forEach((itemSource,index) => {
61
+ this.config.series[j].name = itemSource.YLabels[j].Cn_Name;
62
+ if ((!itemSource.YLabels[j].Value === undefined || itemSource.YLabels[j].Value === null) && !xIsCountEmpty) {
63
+ arrXisCountEmptyIndex.push(index);
64
+ } else {
65
+ const value = itemSource.YLabels[j].Value ? itemSource.YLabels[j].Value : 0;
66
+ this.config.series[j].data.push(value);
67
+ }
68
+ });
69
+ }
70
+ }
71
+ // 处理显示空值问题
72
+ this.setEmptyValue(xIsCountEmpty);
73
+ } else if (groupKey) {
74
+ // 如果是分组,则这里需要特殊处理
75
+ // 按groupKey分组存放数据值
76
+ const objGroupKey = {}; // {'分组字段':[{value:'统计的值', dimensionality:'维度名', name:'统计的数值字段名'}]}
77
+ sortedXAxisData.forEach((itemSourData) => {
78
+ itemSourData.YLabels.forEach((yLabel) => {
79
+ if (!objGroupKey[yLabel.Group_Name]) {
80
+ objGroupKey[yLabel.Group_Name] = [];
81
+ }
82
+ objGroupKey[yLabel.Group_Name].push({
83
+ value: yLabel.Value,
84
+ dimensionality: itemSourData.XLabel.Value,
85
+ name: yLabel.Cn_Name,
86
+ });
87
+ });
88
+ });
89
+
90
+ // 组装图表需要的数据
91
+ const groupNames = Object.keys(objGroupKey);
92
+ this.config.series = groupNames.map((groupKey) => {
93
+ // groupKey分组字段中文名
94
+ const serie = {
95
+ name: groupKey,
96
+ connectNulls: true,
97
+ data: this.getSeriesDataGroup(
98
+ arrXaxisData,
99
+ objGroupKey[groupKey],
100
+ ),
101
+ type: 'line',
102
+ smooth: true,
103
+ showSymbol: true, // 是否显示线条上数据标签
104
+ label: {
105
+ show: true, // 显示线条上的数据
106
+ },
107
+ };
108
+ return serie;
109
+ });
110
+ this.config.tooltip.formatter = params => (
111
+ `${params.data.dimensionality
112
+ }\r\n${
113
+ params.data.name
114
+ }\r\n${
115
+ params.seriesName
116
+ }:${
117
+ params.value}`
118
+ );
119
+ }
120
+ }
121
+ }
122
+ setChartType({ chartType }) {
123
+ this.config.series.length > 0
124
+ && this.config.series.forEach((itemSeries) => {
125
+ itemSeries.smooth = chartType !== 'line';
126
+ });
127
+ }
128
+
129
+ // 显示图表上的数据标签 单位,标签,小数位数,后缀
130
+ setIsSeriesShowSymbol({
131
+ isSeriesShowSymbol,
132
+ isUnit,
133
+ unit,
134
+ decimalDigits,
135
+ suffix
136
+ }) {
137
+ decimalDigits = decimalDigits < 0 ? 0 : decimalDigits;
138
+ this.config.series.length > 0
139
+ && this.config.series.forEach((itemSeries) => {
140
+ itemSeries.showSymbol = isSeriesShowSymbol;
141
+ itemSeries.label.show = isSeriesShowSymbol;
142
+ if (isUnit) {
143
+ itemSeries.label.formatter = (params) => {
144
+ const objNewValue = this.getValueByUnit(params.value, unit);
145
+ return (
146
+ `${objNewValue.toFixed(decimalDigits)}${suffix}`
147
+ );
148
+ };
149
+ }
150
+ });
151
+ if (isUnit) {
152
+ this.config.yAxis.axisLabel.formatter = (value) => {
153
+ const objNewValue = this.getValueByUnit(value, unit);
154
+ return `${objNewValue.toFixed(decimalDigits)}${suffix}`;
155
+ };
156
+ } else {
157
+ this.config.yAxis.axisLabel.formatter = null;
158
+ }
159
+ }
160
+ async setOptions({
161
+ chartType,
162
+ isTitle,
163
+ title,
164
+ titleLocation,
165
+ dataSource,
166
+ filterData,
167
+ xField,
168
+ xStatistics,
169
+ groupKey,
170
+ groupKeyTimeSpan,
171
+ xIsCountEmpty,
172
+ yField,
173
+ isLegend,
174
+ legend,
175
+ isXaxisName,
176
+ xAxisName,
177
+ isXaxisAxisLabelShow,
178
+ isXaxisAxisTickShow,
179
+ isXaxisAxisLabelRotate,
180
+ isYAxisSplitlineLinestyleWidth,
181
+ yAxisSplitlineLinestyleType,
182
+ yAxisMax,
183
+ yAxisMin,
184
+ isYAxisName,
185
+ yAxisName,
186
+ isSeriesShowSymbol,
187
+ isYAxisShow,
188
+ isUnit,
189
+ unit,
190
+ decimalDigits,
191
+ suffix
192
+ }) {
193
+ if (dataSource) {
194
+ await this.setSourceData({
195
+ dataSource,
196
+ filterData,
197
+ xField,
198
+ xStatistics,
199
+ xIsCountEmpty,
200
+ yField,
201
+ groupKey,
202
+ groupKeyTimeSpan,
203
+ });
204
+ }
205
+ this.setChartType({ chartType });
206
+ this.setTitle({ isTitle, title, titleLocation });
207
+ this.setLegend({ isLegend, legend });
208
+ this.setIsXaxisAxisLabelShow({ isXaxisAxisLabelShow });
209
+ this.setIsXaxisName({ isXaxisName, xAxisName });
210
+ this.setIsXaxisAxisTickShow({ isXaxisAxisTickShow });
211
+ this.setIsXaxisAxisLabelRotate({ isXaxisAxisLabelRotate, xStatistics });
212
+ this.setIsYAxisSplitlineLinestyleWidth({
213
+ isYAxisSplitlineLinestyleWidth,
214
+ yAxisSplitlineLinestyleType,
215
+ });
216
+ this.setYAxisMaxMin({ yAxisMax, yAxisMin });
217
+ this.setIsYAxisName({ isYAxisName, yAxisName });
218
+ this.setIsYAxisShow({ isYAxisShow });
219
+ this.setIsSeriesShowSymbol({
220
+ isSeriesShowSymbol,
221
+ isUnit,
222
+ unit,
223
+ decimalDigits,
224
+ suffix
225
+ });
226
+ }
227
+ }
228
+
229
+ export default EchartLine;
@@ -0,0 +1,166 @@
1
+ import EchartBase from './eChartBase';
2
+ import getConfig from '../config/pie';
3
+ /**
4
+ * 饼状图表
5
+ * @author loonglong
6
+ **/
7
+ class EchartPie extends EchartBase {
8
+ constructor() {
9
+ super();
10
+ const config = getConfig();
11
+ this.config = { ...this.config, ...config };
12
+ }
13
+ async setSourceData({
14
+ dataSource,
15
+ filterData,
16
+ setColor,
17
+ xField,
18
+ xStatistics,
19
+ xIsCountEmpty,
20
+ yField,
21
+ }) {
22
+ const { name = '', type = '', methodName = '' } = dataSource;
23
+ if (name !== '') {
24
+ const params = this.createWhere({
25
+ filterData,
26
+ xField,
27
+ xStatistics,
28
+ xIsCountEmpty,
29
+ yField,
30
+ });
31
+ const arrSourData = await this.getSourceData(
32
+ name,
33
+ methodName,
34
+ type,
35
+ params,
36
+ );
37
+ // 获取 x 轴数据
38
+ if (arrSourData.length >= 0) {
39
+ const numPie = arrSourData[0].YLabels.length;
40
+ if (numPie > 0) {
41
+ const arrData = [];
42
+ let i = 0;
43
+ arrSourData.forEach((itemSource) => {
44
+ const numc = setColor ? setColor.length : 0;
45
+ const strColor = numc > 0 ? { color: setColor[i % numc] } : {};
46
+ arrData.push({
47
+ value: itemSource.YLabels[0].Value,
48
+ name: itemSource.XLabel.Value,
49
+ tooltip: {},
50
+ itemStyle: strColor,
51
+ });
52
+ i = i + 1;
53
+ });
54
+ this.config.series[0].data = arrData;
55
+ }
56
+ } else {
57
+ // this.config['series'][0].data = [];
58
+ }
59
+ }
60
+ }
61
+ setChartType({ chartType }) {
62
+ this.config.series.length > 0
63
+ && this.config.series.forEach((itemSeries) => {
64
+ if (chartType === 'pie') {
65
+ itemSeries.radius = '70%';
66
+ } else {
67
+ itemSeries.radius = ['40%', '70%'];
68
+ }
69
+ });
70
+ }
71
+
72
+ // 显示图表上的数据标签 单位,标签,小数位数,后缀
73
+ setIsSeriesShowSymbol({
74
+ isSeriesShowSymbol,
75
+ isPercent,
76
+ isUnit,
77
+ unit,
78
+ decimalDigits,
79
+ suffix
80
+ }) {
81
+ decimalDigits = decimalDigits < 0 ? 0 : decimalDigits;
82
+ let show = false;
83
+ let position = 'inner';
84
+ let formatter = null;
85
+ if (isSeriesShowSymbol || isPercent || isUnit) {
86
+ formatter = '';
87
+ }
88
+ this.config.series[0].label.show = show;
89
+ this.config.series[0].label.position = position;
90
+ if (formatter === null) {
91
+ this.config.series[0].label.normal = null;
92
+ } else {
93
+ this.config.series[0].label.normal.formatter = (objValue) => {
94
+ let reData = '';
95
+ if (isSeriesShowSymbol) { // 显示数值
96
+ reData = objValue.value;
97
+ }
98
+ if (isUnit) { // 显示单位
99
+ if (unit) {
100
+ const objNewValue = this.getValueByUnit(objValue.value, unit);
101
+ reData = `${objNewValue.toFixed(decimalDigits)}${suffix}`;
102
+ } else {
103
+ reData = `${objValue.value.toFixed(decimalDigits)}`;
104
+ }
105
+ this.config.series[0].data.forEach((itemData) => {
106
+ itemData.tooltip.formatter = (objVal) => {
107
+ const objItemData = this.getValueByUnit(objVal.value, unit);
108
+ return `${objItemData.toFixed(decimalDigits)}${suffix}`;
109
+ };
110
+ });
111
+ }
112
+ if (isPercent) { // 显示百分比
113
+ reData = `${reData}(${objValue.percent}%)`;
114
+ }
115
+ return reData;
116
+ };
117
+ }
118
+ }
119
+ async setOptions({
120
+ chartType,
121
+ isTitle,
122
+ title,
123
+ titleLocation,
124
+ dataSource,
125
+ filterData,
126
+ setColor,
127
+ xField,
128
+ xStatistics,
129
+ xIsCountEmpty,
130
+ yField,
131
+ isLegend,
132
+ legend,
133
+ isSeriesShowSymbol,
134
+ isPercent,
135
+ isUnit,
136
+ unit,
137
+ decimalDigits,
138
+ suffix
139
+ }) {
140
+ if (dataSource) {
141
+ await this.setSourceData({
142
+ dataSource,
143
+ filterData,
144
+ setColor,
145
+ xField,
146
+ xStatistics,
147
+ xIsCountEmpty,
148
+ yField,
149
+ });
150
+ }
151
+
152
+ this.setChartType({ chartType });
153
+ this.setTitle({ isTitle, title, titleLocation });
154
+ this.setLegend({ isLegend, legend });
155
+ this.setIsSeriesShowSymbol({
156
+ isSeriesShowSymbol,
157
+ isPercent,
158
+ isUnit,
159
+ unit,
160
+ decimalDigits,
161
+ suffix
162
+ });
163
+ }
164
+ }
165
+
166
+ export default EchartPie;