@cloudbase/weda-ui 0.2.14 → 0.2.17

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 (400) hide show
  1. package/README.md +41 -167
  2. package/package.json +51 -19
  3. package/src/configs/components/calendar.json +75 -0
  4. package/src/configs/components/carousel.json +273 -0
  5. package/src/configs/components/chart/bar.json +711 -0
  6. package/src/configs/components/chart/line.json +666 -0
  7. package/src/configs/components/chart/pie.json +487 -0
  8. package/src/configs/components/chart/statisticsCard.json +331 -0
  9. package/src/configs/components/dataView.json +139 -0
  10. package/src/configs/components/form/location.json +152 -0
  11. package/src/configs/components/form/uploaderFile.json +2 -1
  12. package/src/configs/components/graphicCard.json +399 -0
  13. package/src/configs/components/image.json +4 -0
  14. package/src/configs/components/link.json +2 -2
  15. package/src/configs/components/listView.json +231 -0
  16. package/src/configs/components/navLayout.json +350 -0
  17. package/src/configs/components/swiper.json +3 -3
  18. package/src/configs/index.js +23 -0
  19. package/src/mp/components/button/index.js +12 -13
  20. package/src/mp/components/button/index.wxml +1 -1
  21. package/src/{web/wedatheme/src/styles/assets → mp/components/calendar}/arrowright--line.svg +3 -4
  22. package/src/mp/components/calendar/index.js +238 -0
  23. package/src/mp/components/calendar/index.json +4 -0
  24. package/src/mp/components/calendar/index.wxml +37 -0
  25. package/src/mp/components/calendar/index.wxss +178 -0
  26. package/src/mp/components/carousel/index.js +88 -0
  27. package/src/mp/components/carousel/index.json +7 -0
  28. package/src/mp/components/carousel/index.wxml +6 -0
  29. package/src/mp/components/chart/bar/index.js +254 -0
  30. package/src/mp/components/chart/bar/index.json +6 -0
  31. package/src/mp/components/chart/bar/index.wxml +3 -0
  32. package/src/mp/components/chart/bar/index.wxss +9 -0
  33. package/src/mp/components/chart/common/config/bar.js +50 -0
  34. package/src/mp/components/chart/common/config/global.js +16 -0
  35. package/src/mp/components/chart/common/config/line.js +48 -0
  36. package/src/mp/components/chart/common/config/pie.js +36 -0
  37. package/src/mp/components/chart/common/core/eChartBar.js +262 -0
  38. package/src/mp/components/chart/common/core/eChartBase.js +371 -0
  39. package/src/mp/components/chart/common/core/eChartLine.js +228 -0
  40. package/src/mp/components/chart/common/core/eChartPie.js +166 -0
  41. package/src/mp/components/chart/common/lib/echarts.min.js +18 -0
  42. package/src/mp/components/chart/ec-canvas/ec-canvas.js +277 -0
  43. package/src/mp/components/chart/ec-canvas/ec-canvas.json +4 -0
  44. package/src/mp/components/chart/ec-canvas/ec-canvas.wxml +4 -0
  45. package/src/mp/components/chart/ec-canvas/ec-canvas.wxss +4 -0
  46. package/src/mp/components/chart/ec-canvas/wx-canvas.js +107 -0
  47. package/src/mp/components/chart/line/index.js +243 -0
  48. package/src/mp/components/chart/line/index.json +6 -0
  49. package/src/mp/components/chart/line/index.wxml +3 -0
  50. package/src/mp/components/chart/line/index.wxss +9 -0
  51. package/src/mp/components/chart/pie/index.js +178 -0
  52. package/src/mp/components/chart/pie/index.json +6 -0
  53. package/src/mp/components/chart/pie/index.wxml +4 -0
  54. package/src/mp/components/chart/pie/index.wxss +9 -0
  55. package/src/mp/components/chart/statisticsCard/index.js +226 -0
  56. package/src/mp/components/chart/statisticsCard/index.json +4 -0
  57. package/src/mp/components/chart/statisticsCard/index.wxml +9 -0
  58. package/src/mp/components/chart/statisticsCard/index.wxss +45 -0
  59. package/src/mp/components/container/index.js +4 -0
  60. package/src/mp/components/dataView/index.js +34 -0
  61. package/src/mp/components/dataView/index.json +7 -0
  62. package/src/mp/components/dataView/index.wxml +15 -0
  63. package/src/{web/wedatheme/src/styles/theme/_icon.scss → mp/components/dataView/index.wxss} +0 -0
  64. package/src/mp/components/form/location/components/mapChoose/index.js +201 -0
  65. package/src/mp/components/form/location/components/mapChoose/index.json +4 -0
  66. package/src/mp/components/form/location/components/mapChoose/index.wxml +42 -0
  67. package/src/mp/components/form/location/components/mapChoose/index.wxss +188 -0
  68. package/src/mp/components/form/location/index.js +341 -0
  69. package/src/mp/components/form/location/index.json +6 -0
  70. package/src/mp/components/form/location/index.wxml +25 -0
  71. package/src/mp/components/form/location/index.wxss +91 -0
  72. package/src/mp/components/form/radio/index.js +5 -0
  73. package/src/mp/components/form/select/index.wxml +4 -4
  74. package/src/mp/components/form/textarea/index.wxml +6 -5
  75. package/src/mp/components/form/uploader/index.js +64 -40
  76. package/src/mp/components/form/uploader/index.wxml +15 -3
  77. package/src/mp/components/form/uploaderFile/index.js +102 -27
  78. package/src/mp/components/graphicCard/chevron-right.svg +3 -0
  79. package/src/mp/components/graphicCard/index.js +203 -0
  80. package/src/mp/components/graphicCard/index.json +4 -0
  81. package/src/mp/components/graphicCard/index.wxml +29 -0
  82. package/src/mp/components/graphicCard/index.wxss +157 -0
  83. package/src/mp/components/image/index.js +53 -52
  84. package/src/mp/components/internals/listView/arrow-right-line.svg +3 -0
  85. package/src/mp/components/internals/listView/index.js +286 -0
  86. package/src/mp/components/internals/listView/index.json +4 -0
  87. package/src/mp/components/internals/listView/index.wxml +40 -0
  88. package/src/mp/components/internals/listView/index.wxss +150 -0
  89. package/src/mp/components/internals/listView/more-line.svg +3 -0
  90. package/src/mp/components/listView/arrow-right-line.svg +3 -0
  91. package/src/mp/components/listView/index.js +279 -0
  92. package/src/mp/components/listView/index.json +4 -0
  93. package/src/mp/components/listView/index.wxml +40 -0
  94. package/src/mp/components/listView/index.wxss +150 -0
  95. package/src/mp/components/listView/more-line.svg +3 -0
  96. package/src/mp/components/navLayout/index.js +123 -0
  97. package/src/mp/components/navLayout/index.json +7 -0
  98. package/src/mp/components/navLayout/index.wxml +25 -0
  99. package/src/mp/components/navLayout/index.wxss +1193 -0
  100. package/src/mp/components/swiper/index.wxml +2 -0
  101. package/src/mp/components/text/index.wxss +6 -6
  102. package/src/mp/index.json +12 -1
  103. package/src/mp/utils/debounce.js +133 -0
  104. package/src/mp/utils/dr_square_point.js +25 -0
  105. package/src/mp/utils/platform.js +15 -0
  106. package/src/mp/utils/qqmap-wx-jssdk1.2/qqmap-wx-jssdk.js +1336 -0
  107. package/src/mp/utils/spark-md5.js +776 -0
  108. package/src/mp/utils/tcb.js +18 -0
  109. package/src/setupTests.js +2 -1
  110. package/src/web/components/button/index.tsx +1 -1
  111. package/src/web/components/calendar/index.css +382 -0
  112. package/src/web/components/calendar/index.jsx +312 -0
  113. package/src/web/components/calendar/util.js +90 -0
  114. package/src/web/components/carousel/index.css +119 -0
  115. package/src/web/components/carousel/index.tsx +417 -0
  116. package/src/web/components/chart/bar/index.tsx +139 -0
  117. package/src/web/components/chart/common/config/bar.js +49 -0
  118. package/src/web/components/chart/common/config/global.js +16 -0
  119. package/src/web/components/chart/common/config/line.js +50 -0
  120. package/src/web/components/chart/common/config/pie.js +37 -0
  121. package/src/web/components/chart/common/core/eChartBar.js +264 -0
  122. package/src/web/components/chart/common/core/eChartBase.ts +379 -0
  123. package/src/web/components/chart/common/core/eChartLine.js +229 -0
  124. package/src/web/components/chart/common/core/eChartPie.js +170 -0
  125. package/src/web/components/chart/common/core/type.ts +34 -0
  126. package/src/web/components/chart/common/echart.css +106 -0
  127. package/src/web/components/chart/common/echarts.ts +33 -0
  128. package/src/web/components/chart/common/useChart.tsx +69 -0
  129. package/src/web/components/chart/line/index.tsx +135 -0
  130. package/src/web/components/chart/pie/index.tsx +99 -0
  131. package/src/web/components/chart/statisticsCard/index.css +62 -0
  132. package/src/web/components/chart/statisticsCard/index.tsx +286 -0
  133. package/src/web/components/chart/statisticsCard/interface.ts +14 -0
  134. package/src/web/components/dataView/index.tsx +20 -0
  135. package/src/web/components/dataView/interface.ts +6 -0
  136. package/src/web/components/form/input/index.css +5 -3
  137. package/src/web/components/form/input/index.tsx +1 -0
  138. package/src/web/components/form/location/common/mapChoose.css +178 -0
  139. package/src/web/components/form/location/common/mapChoose.jsx +343 -0
  140. package/src/web/components/form/location/common/mapView.jsx +190 -0
  141. package/src/web/components/form/location/common/propsConfig.js +54 -0
  142. package/src/web/components/form/location/common/selectModal.css +44 -0
  143. package/src/web/components/form/location/common/selectModal.jsx +82 -0
  144. package/src/web/components/form/location/common/useLocationInfo.js +100 -0
  145. package/src/web/components/form/location/components/LocationH5/index.css +243 -0
  146. package/src/web/components/form/location/components/LocationH5/location.h5.jsx +403 -0
  147. package/src/web/components/form/location/components/LocationPC/Header.jsx +109 -0
  148. package/src/web/components/form/location/components/LocationPC/index.css +44 -0
  149. package/src/web/components/form/location/components/LocationPC/location.PC.jsx +323 -0
  150. package/src/web/components/form/location/constants.js +4 -0
  151. package/src/web/{wedatheme/src/styles/theme/_timeline.scss → components/form/location/index.css} +0 -0
  152. package/src/web/components/form/location/index.jsx +25 -0
  153. package/src/web/components/form/select/h5.tsx +3 -1
  154. package/src/web/components/form/select/time.jsx +1 -0
  155. package/src/web/components/form/uploader/uploader.h5.tsx +10 -2
  156. package/src/web/components/form/uploader/uploader.pc.tsx +4 -3
  157. package/src/web/components/form/uploaderFile/uploadFile.h5.tsx +119 -106
  158. package/src/web/components/form/uploaderFile/uploadFile.pc.tsx +3 -6
  159. package/src/web/components/graphicCard/index.css +159 -0
  160. package/src/web/components/graphicCard/index.tsx +310 -0
  161. package/src/web/components/image/image.tsx +107 -94
  162. package/src/web/components/image/index.tsx +1 -1
  163. package/src/web/components/index.js +18 -3
  164. package/src/web/components/listView/arrow-right-line.svg +3 -0
  165. package/src/web/components/listView/index.css +139 -0
  166. package/src/web/components/listView/index.tsx +354 -0
  167. package/src/web/components/listView/interface.ts +98 -0
  168. package/src/web/components/navLayout/index.css +332 -0
  169. package/src/web/components/navLayout/index.tsx +247 -0
  170. package/src/web/components/swiper/index.css +4 -0
  171. package/src/web/components/swiper/index.tsx +9 -4
  172. package/src/web/components/tabs/index.tsx +2 -2
  173. package/src/web/components/tabs/tabs.h5.tsx +7 -4
  174. package/src/web/components/uploaderFileView/index.css +9 -9
  175. package/src/web/components/uploaderFileView/index.jsx +34 -25
  176. package/src/web/types.d.ts +15 -14
  177. package/src/web/utils/debounce.js +98 -0
  178. package/src/web/utils/platform.js +31 -0
  179. package/src/web/utils/tcb.js +23 -0
  180. package/src/web/utils/tmap.js +4 -0
  181. package/CHANGELOG.md +0 -240
  182. package/src/.DS_Store +0 -0
  183. package/src/configs/.DS_Store +0 -0
  184. package/src/mp/.gitignore +0 -10
  185. package/src/web/.DS_Store +0 -0
  186. package/src/web/wedatheme/.code.yml +0 -16
  187. package/src/web/wedatheme/.editorconfig +0 -9
  188. package/src/web/wedatheme/.eslintrc +0 -20
  189. package/src/web/wedatheme/.git +0 -1
  190. package/src/web/wedatheme/.gitignore +0 -5
  191. package/src/web/wedatheme/.npmrc +0 -1
  192. package/src/web/wedatheme/.orange-ci.yml +0 -55
  193. package/src/web/wedatheme/.vscode/extensions.json +0 -3
  194. package/src/web/wedatheme/.vscode/settings.json +0 -11
  195. package/src/web/wedatheme/README.md +0 -50
  196. package/src/web/wedatheme/i18n/README.md +0 -4
  197. package/src/web/wedatheme/i18n/translation/index.js +0 -10
  198. package/src/web/wedatheme/i18n/translation/zh.js +0 -15
  199. package/src/web/wedatheme/jsconfig.json +0 -15
  200. package/src/web/wedatheme/mock/app.js +0 -42
  201. package/src/web/wedatheme/mock/history-context.js +0 -8
  202. package/src/web/wedatheme/mock/index.js +0 -3
  203. package/src/web/wedatheme/mock/layout/AppLayout.jsx +0 -28
  204. package/src/web/wedatheme/mock/layout/MenuWithRouter.jsx +0 -50
  205. package/src/web/wedatheme/mock/layout/index.js +0 -1
  206. package/src/web/wedatheme/package-lock.json +0 -14335
  207. package/src/web/wedatheme/package.json +0 -61
  208. package/src/web/wedatheme/public/index.html +0 -19
  209. package/src/web/wedatheme/src/app.js +0 -22
  210. package/src/web/wedatheme/src/components/README.md +0 -4
  211. package/src/web/wedatheme/src/configs/menu.js +0 -9
  212. package/src/web/wedatheme/src/routes/wedatheme-index/Component.jsx +0 -402
  213. package/src/web/wedatheme/src/routes/wedatheme-index/Form.jsx +0 -729
  214. package/src/web/wedatheme/src/routes/wedatheme-index/FormItem.jsx +0 -18
  215. package/src/web/wedatheme/src/routes/wedatheme-index/WedathemeIndex.jsx +0 -1276
  216. package/src/web/wedatheme/src/routes/wedatheme-index/index.js +0 -1
  217. package/src/web/wedatheme/src/routes/weui2td/WEUI2TD.jsx +0 -3
  218. package/src/web/wedatheme/src/routes/weui2td/index.js +0 -1
  219. package/src/web/wedatheme/src/styles/_btn.scss +0 -24
  220. package/src/web/wedatheme/src/styles/_icon.scss +0 -653
  221. package/src/web/wedatheme/src/styles/_map.scss +0 -12
  222. package/src/web/wedatheme/src/styles/_middle.scss +0 -340
  223. package/src/web/wedatheme/src/styles/_upload.scss +0 -47
  224. package/src/web/wedatheme/src/styles/assets/alert-close.svg +0 -3
  225. package/src/web/wedatheme/src/styles/assets/and.svg +0 -12
  226. package/src/web/wedatheme/src/styles/assets/arrowdown--line.svg +0 -12
  227. package/src/web/wedatheme/src/styles/assets/arrowdown.svg +0 -12
  228. package/src/web/wedatheme/src/styles/assets/arrowleft--line.svg +0 -12
  229. package/src/web/wedatheme/src/styles/assets/arrowleft.svg +0 -12
  230. package/src/web/wedatheme/src/styles/assets/arrowright-blue--line.svg +0 -12
  231. package/src/web/wedatheme/src/styles/assets/arrowright.svg +0 -12
  232. package/src/web/wedatheme/src/styles/assets/arrowup--line.svg +0 -12
  233. package/src/web/wedatheme/src/styles/assets/arrowup.svg +0 -12
  234. package/src/web/wedatheme/src/styles/assets/bell-warning.svg +0 -3
  235. package/src/web/wedatheme/src/styles/assets/btnback.svg +0 -12
  236. package/src/web/wedatheme/src/styles/assets/calendar.svg +0 -12
  237. package/src/web/wedatheme/src/styles/assets/chartcolumn-1.svg +0 -12
  238. package/src/web/wedatheme/src/styles/assets/chartcolumn.svg +0 -12
  239. package/src/web/wedatheme/src/styles/assets/chartline-1.svg +0 -9
  240. package/src/web/wedatheme/src/styles/assets/chartline.svg +0 -9
  241. package/src/web/wedatheme/src/styles/assets/chartpie-1.svg +0 -12
  242. package/src/web/wedatheme/src/styles/assets/chartpie.svg +0 -12
  243. package/src/web/wedatheme/src/styles/assets/check-1.svg +0 -8
  244. package/src/web/wedatheme/src/styles/assets/check-2.svg +0 -1
  245. package/src/web/wedatheme/src/styles/assets/check.svg +0 -8
  246. package/src/web/wedatheme/src/styles/assets/close-1.svg +0 -8
  247. package/src/web/wedatheme/src/styles/assets/close.svg +0 -8
  248. package/src/web/wedatheme/src/styles/assets/consult.svg +0 -8
  249. package/src/web/wedatheme/src/styles/assets/convertip--blue.svg +0 -12
  250. package/src/web/wedatheme/src/styles/assets/convertip.svg +0 -12
  251. package/src/web/wedatheme/src/styles/assets/copy.svg +0 -12
  252. package/src/web/wedatheme/src/styles/assets/cur-active.svg +0 -12
  253. package/src/web/wedatheme/src/styles/assets/cur.svg +0 -12
  254. package/src/web/wedatheme/src/styles/assets/daily.svg +0 -13
  255. package/src/web/wedatheme/src/styles/assets/database.svg +0 -12
  256. package/src/web/wedatheme/src/styles/assets/datasheet.svg +0 -12
  257. package/src/web/wedatheme/src/styles/assets/delete-white.svg +0 -8
  258. package/src/web/wedatheme/src/styles/assets/delete.svg +0 -8
  259. package/src/web/wedatheme/src/styles/assets/detail.svg +0 -13
  260. package/src/web/wedatheme/src/styles/assets/dismiss.svg +0 -8
  261. package/src/web/wedatheme/src/styles/assets/download.svg +0 -12
  262. package/src/web/wedatheme/src/styles/assets/drop.svg +0 -15
  263. package/src/web/wedatheme/src/styles/assets/email-error.svg +0 -14
  264. package/src/web/wedatheme/src/styles/assets/email-warning.svg +0 -12
  265. package/src/web/wedatheme/src/styles/assets/email.svg +0 -14
  266. package/src/web/wedatheme/src/styles/assets/emailv.svg +0 -12
  267. package/src/web/wedatheme/src/styles/assets/error-1.svg +0 -8
  268. package/src/web/wedatheme/src/styles/assets/error-filled.svg +0 -3
  269. package/src/web/wedatheme/src/styles/assets/error.svg +0 -8
  270. package/src/web/wedatheme/src/styles/assets/externallink.svg +0 -12
  271. package/src/web/wedatheme/src/styles/assets/favorable.svg +0 -9
  272. package/src/web/wedatheme/src/styles/assets/filter.svg +0 -12
  273. package/src/web/wedatheme/src/styles/assets/firstpage.svg +0 -13
  274. package/src/web/wedatheme/src/styles/assets/folderclose.svg +0 -8
  275. package/src/web/wedatheme/src/styles/assets/folderopen.svg +0 -8
  276. package/src/web/wedatheme/src/styles/assets/fullscreenquit.svg +0 -12
  277. package/src/web/wedatheme/src/styles/assets/fullsreen.svg +0 -12
  278. package/src/web/wedatheme/src/styles/assets/globe-gray.svg +0 -12
  279. package/src/web/wedatheme/src/styles/assets/guide.svg +0 -9
  280. package/src/web/wedatheme/src/styles/assets/help.svg +0 -8
  281. package/src/web/wedatheme/src/styles/assets/hide.svg +0 -8
  282. package/src/web/wedatheme/src/styles/assets/info.svg +0 -8
  283. package/src/web/wedatheme/src/styles/assets/infoblue-1.svg +0 -8
  284. package/src/web/wedatheme/src/styles/assets/infoblue-filled.svg +0 -3
  285. package/src/web/wedatheme/src/styles/assets/infoblue.svg +0 -8
  286. package/src/web/wedatheme/src/styles/assets/jump-black.svg +0 -12
  287. package/src/web/wedatheme/src/styles/assets/jump.svg +0 -12
  288. package/src/web/wedatheme/src/styles/assets/lastpage.svg +0 -13
  289. package/src/web/wedatheme/src/styles/assets/loading.svg +0 -12
  290. package/src/web/wedatheme/src/styles/assets/local.svg +0 -10
  291. package/src/web/wedatheme/src/styles/assets/menu-fold-white.svg +0 -6
  292. package/src/web/wedatheme/src/styles/assets/menu-fold.svg +0 -6
  293. package/src/web/wedatheme/src/styles/assets/minus.svg +0 -12
  294. package/src/web/wedatheme/src/styles/assets/monitor.svg +0 -12
  295. package/src/web/wedatheme/src/styles/assets/more.svg +0 -8
  296. package/src/web/wedatheme/src/styles/assets/multi-line.svg +0 -12
  297. package/src/web/wedatheme/src/styles/assets/news.svg +0 -3
  298. package/src/web/wedatheme/src/styles/assets/not.svg +0 -12
  299. package/src/web/wedatheme/src/styles/assets/notice.svg +0 -8
  300. package/src/web/wedatheme/src/styles/assets/pencil.svg +0 -12
  301. package/src/web/wedatheme/src/styles/assets/pending-1.svg +0 -8
  302. package/src/web/wedatheme/src/styles/assets/pending-gray.svg +0 -8
  303. package/src/web/wedatheme/src/styles/assets/pending.svg +0 -8
  304. package/src/web/wedatheme/src/styles/assets/percent-blue.svg +0 -16
  305. package/src/web/wedatheme/src/styles/assets/percent.svg +0 -16
  306. package/src/web/wedatheme/src/styles/assets/phone-error.svg +0 -11
  307. package/src/web/wedatheme/src/styles/assets/phone-warning.svg +0 -9
  308. package/src/web/wedatheme/src/styles/assets/phone.svg +0 -12
  309. package/src/web/wedatheme/src/styles/assets/phonev.svg +0 -9
  310. package/src/web/wedatheme/src/styles/assets/plus.svg +0 -12
  311. package/src/web/wedatheme/src/styles/assets/qq.svg +0 -11
  312. package/src/web/wedatheme/src/styles/assets/realname.svg +0 -8
  313. package/src/web/wedatheme/src/styles/assets/realnamev.svg +0 -9
  314. package/src/web/wedatheme/src/styles/assets/refresh-blue.svg +0 -12
  315. package/src/web/wedatheme/src/styles/assets/refresh.svg +0 -12
  316. package/src/web/wedatheme/src/styles/assets/relationship-1.svg +0 -12
  317. package/src/web/wedatheme/src/styles/assets/relationship.svg +0 -12
  318. package/src/web/wedatheme/src/styles/assets/remind.svg +0 -8
  319. package/src/web/wedatheme/src/styles/assets/search.svg +0 -8
  320. package/src/web/wedatheme/src/styles/assets/setting.svg +0 -12
  321. package/src/web/wedatheme/src/styles/assets/shopcart.svg +0 -8
  322. package/src/web/wedatheme/src/styles/assets/show.svg +0 -8
  323. package/src/web/wedatheme/src/styles/assets/sort.svg +0 -12
  324. package/src/web/wedatheme/src/styles/assets/sortdown.svg +0 -12
  325. package/src/web/wedatheme/src/styles/assets/sortup.svg +0 -12
  326. package/src/web/wedatheme/src/styles/assets/success-1.svg +0 -8
  327. package/src/web/wedatheme/src/styles/assets/success-filled.svg +0 -3
  328. package/src/web/wedatheme/src/styles/assets/success.svg +0 -8
  329. package/src/web/wedatheme/src/styles/assets/table-1.svg +0 -12
  330. package/src/web/wedatheme/src/styles/assets/table.svg +0 -12
  331. package/src/web/wedatheme/src/styles/assets/tag.svg +0 -12
  332. package/src/web/wedatheme/src/styles/assets/time.svg +0 -12
  333. package/src/web/wedatheme/src/styles/assets/transfer.svg +0 -8
  334. package/src/web/wedatheme/src/styles/assets/trenddown.svg +0 -12
  335. package/src/web/wedatheme/src/styles/assets/trendup.svg +0 -12
  336. package/src/web/wedatheme/src/styles/assets/viewgrid.svg +0 -12
  337. package/src/web/wedatheme/src/styles/assets/viewlist.svg +0 -12
  338. package/src/web/wedatheme/src/styles/assets/warning-1.svg +0 -8
  339. package/src/web/wedatheme/src/styles/assets/warning-filled.svg +0 -3
  340. package/src/web/wedatheme/src/styles/assets/warning.svg +0 -8
  341. package/src/web/wedatheme/src/styles/assets/wechat-error.svg +0 -14
  342. package/src/web/wedatheme/src/styles/assets/wechat-warning.svg +0 -12
  343. package/src/web/wedatheme/src/styles/assets/wechat.svg +0 -12
  344. package/src/web/wedatheme/src/styles/assets/wechatv.svg +0 -12
  345. package/src/web/wedatheme/src/styles/assets/zoom-in-white.svg +0 -4
  346. package/src/web/wedatheme/src/styles/assets/zoom-in.svg +0 -4
  347. package/src/web/wedatheme/src/styles/assets/zoom-out-white.svg +0 -4
  348. package/src/web/wedatheme/src/styles/assets/zoom-out.svg +0 -4
  349. package/src/web/wedatheme/src/styles/index.scss +0 -18
  350. package/src/web/wedatheme/src/styles/main.css +0 -166
  351. package/src/web/wedatheme/src/styles/theme/_alert.scss +0 -73
  352. package/src/web/wedatheme/src/styles/theme/_badge.scss +0 -38
  353. package/src/web/wedatheme/src/styles/theme/_blank-page-v2.scss +0 -7
  354. package/src/web/wedatheme/src/styles/theme/_breadcrumb.scss +0 -8
  355. package/src/web/wedatheme/src/styles/theme/_bubble.scss +0 -24
  356. package/src/web/wedatheme/src/styles/theme/_button.scss +0 -212
  357. package/src/web/wedatheme/src/styles/theme/_card.scss +0 -12
  358. package/src/web/wedatheme/src/styles/theme/_cascader.scss +0 -43
  359. package/src/web/wedatheme/src/styles/theme/_checkbox&radio.scss +0 -83
  360. package/src/web/wedatheme/src/styles/theme/_datepicker.scss +0 -36
  361. package/src/web/wedatheme/src/styles/theme/_dialog.scss +0 -39
  362. package/src/web/wedatheme/src/styles/theme/_divider.scss +0 -1
  363. package/src/web/wedatheme/src/styles/theme/_drawer.scss +0 -15
  364. package/src/web/wedatheme/src/styles/theme/_dropdown.scss +0 -53
  365. package/src/web/wedatheme/src/styles/theme/_form.scss +0 -38
  366. package/src/web/wedatheme/src/styles/theme/_input&textarea&select.scss +0 -85
  367. package/src/web/wedatheme/src/styles/theme/_inputnumber.scss +0 -16
  368. package/src/web/wedatheme/src/styles/theme/_link.scss +0 -14
  369. package/src/web/wedatheme/src/styles/theme/_list.scss +0 -41
  370. package/src/web/wedatheme/src/styles/theme/_metrics-board.scss +0 -14
  371. package/src/web/wedatheme/src/styles/theme/_notification.scss +0 -27
  372. package/src/web/wedatheme/src/styles/theme/_pagination.scss +0 -22
  373. package/src/web/wedatheme/src/styles/theme/_popconfirm.scss +0 -4
  374. package/src/web/wedatheme/src/styles/theme/_progress.scss +0 -28
  375. package/src/web/wedatheme/src/styles/theme/_region-select.scss +0 -17
  376. package/src/web/wedatheme/src/styles/theme/_search.scss +0 -18
  377. package/src/web/wedatheme/src/styles/theme/_segment.scss +0 -69
  378. package/src/web/wedatheme/src/styles/theme/_slider.scss +0 -18
  379. package/src/web/wedatheme/src/styles/theme/_status.scss +0 -4
  380. package/src/web/wedatheme/src/styles/theme/_steps.scss +0 -68
  381. package/src/web/wedatheme/src/styles/theme/_switch.scss +0 -11
  382. package/src/web/wedatheme/src/styles/theme/_table.scss +0 -44
  383. package/src/web/wedatheme/src/styles/theme/_tabs.scss +0 -44
  384. package/src/web/wedatheme/src/styles/theme/_tag-search.scss +0 -9
  385. package/src/web/wedatheme/src/styles/theme/_tag.scss +0 -48
  386. package/src/web/wedatheme/src/styles/theme/_toast.scss +0 -3
  387. package/src/web/wedatheme/src/styles/theme/_transfer.scss +0 -9
  388. package/src/web/wedatheme/src/styles/theme/_tree.scss +0 -11
  389. package/src/web/wedatheme/src/styles/theme/_upload.scss +0 -14
  390. package/src/web/wedatheme/src/styles/theme/_variables.scss +0 -140
  391. package/src/web/wedatheme/src/styles/theme/index.scss +0 -91
  392. package/src/web/wedatheme/style-package/README.md +0 -31
  393. package/src/web/wedatheme/style-package/ef6fa527e24e354765d806b826b41391.svg +0 -627
  394. package/src/web/wedatheme/style-package/index.css +0 -3
  395. package/src/web/wedatheme/style-package/package.json +0 -15
  396. package/src/web/wedatheme/tea.config.js +0 -66
  397. package/src/web/wedatheme/webpack/css.config.js +0 -114
  398. package/src/web/wedatheme/webpack/plugins/css-package-plugin.js +0 -23
  399. package/src/web/wedatheme/webpack/plugins/inject-assets-plugin.js +0 -32
  400. package/src/web/wedatheme/webpack/plugins/package-json-plugin.js +0 -66
@@ -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
+ const { name = '', type = '', methodName = '' } = dataSource;
24
+ if (name !== '') {
25
+ const params = this.createWhere({
26
+ filterData,
27
+ xField,
28
+ xStatistics,
29
+ xIsCountEmpty,
30
+ yField,
31
+ groupKey,
32
+ groupKeyTimeSpan,
33
+ });
34
+ const arrSourData = await this.getSourceData(
35
+ name,
36
+ methodName,
37
+ type,
38
+ params,
39
+ );
40
+ // 获取 x 轴数据
41
+ const arrXaxisData = this.setXaxis(arrSourData, xField.format);
42
+ const arrXisCountEmptyIndex = []; // 记录空值的key
43
+ if (!groupKey) {
44
+ const numLine = arrSourData[0].YLabels.length;
45
+ if (numLine > 0) {
46
+ for (let j = 0; j < numLine; j++) {
47
+ this.config.series[j] = {
48
+ type: 'line',
49
+ smooth: true,
50
+ name: '',
51
+ connectNulls: true,
52
+ showSymbol: true,
53
+ label: {
54
+ show: true,
55
+ },
56
+ data: [],
57
+ };
58
+ arrSourData.forEach((itemSource,index) => {
59
+ this.config.series[j].name = itemSource.YLabels[j].Cn_Name;
60
+ if ((!itemSource.YLabels[j].Value || itemSource.YLabels[j].Value === 0 || itemSource.YLabels[j].Value === null) && !xIsCountEmpty) {
61
+ arrXisCountEmptyIndex.push(index);
62
+ } else {
63
+ const value = itemSource.YLabels[j].Value ? itemSource.YLabels[j].Value : 0;
64
+ this.config.series[j].data.push(value);
65
+ }
66
+ });
67
+ }
68
+ }
69
+ // 处理显示空值问题
70
+ this.setEmptyValue(xIsCountEmpty);
71
+ } else if (groupKey) {
72
+ // 如果是分组,则这里需要特殊处理
73
+ // 按groupKey分组存放数据值
74
+ const objGroupKey = {}; // {'分组字段':[{value:'统计的值', dimensionality:'维度名', name:'统计的数值字段名'}]}
75
+ arrSourData.forEach((itemSourData) => {
76
+ itemSourData.YLabels.forEach((yLabel) => {
77
+ if (!objGroupKey[yLabel.Group_Name]) {
78
+ objGroupKey[yLabel.Group_Name] = [];
79
+ }
80
+ objGroupKey[yLabel.Group_Name].push({
81
+ value: yLabel.Value,
82
+ dimensionality: itemSourData.XLabel.Value,
83
+ name: yLabel.Cn_Name,
84
+ });
85
+ });
86
+ });
87
+
88
+ // 组装图表需要的数据
89
+ const groupNames = Object.keys(objGroupKey);
90
+ this.config.series = groupNames.map((groupKey) => {
91
+ // groupKey分组字段中文名
92
+ const serie = {
93
+ name: groupKey,
94
+ connectNulls: true,
95
+ data: this.getSeriesDataGroup(
96
+ arrXaxisData,
97
+ objGroupKey[groupKey],
98
+ ),
99
+ type: 'line',
100
+ smooth: true,
101
+ showSymbol: true, // 是否显示线条上数据标签
102
+ label: {
103
+ show: true, // 显示线条上的数据
104
+ },
105
+ };
106
+ return serie;
107
+ });
108
+ this.config.tooltip.formatter = params => (
109
+ `${params.data.dimensionality
110
+ }\r\n${
111
+ params.data.name
112
+ }\r\n${
113
+ params.seriesName
114
+ }:${
115
+ params.value}`
116
+ );
117
+ }
118
+ }
119
+ }
120
+ setChartType({ chartType }) {
121
+ this.config.series.length > 0
122
+ && this.config.series.forEach((itemSeries) => {
123
+ itemSeries.smooth = chartType !== 'line';
124
+ });
125
+ }
126
+
127
+ // 显示图表上的数据标签 单位,标签,小数位数,后缀
128
+ setIsSeriesShowSymbol({
129
+ isSeriesShowSymbol,
130
+ isUnit,
131
+ unit,
132
+ decimalDigits,
133
+ suffix
134
+ }) {
135
+ decimalDigits = decimalDigits < 0 ? 0 : decimalDigits;
136
+ this.config.series.length > 0
137
+ && this.config.series.forEach((itemSeries) => {
138
+ itemSeries.showSymbol = isSeriesShowSymbol;
139
+ itemSeries.label.show = isSeriesShowSymbol;
140
+ if (isUnit) {
141
+ itemSeries.label.formatter = (params) => {
142
+ const objNewValue = this.getValueByUnit(params.value, unit);
143
+ return (
144
+ `${objNewValue.toFixed(decimalDigits)}${suffix}`
145
+ );
146
+ };
147
+ }
148
+ });
149
+ if (isUnit) {
150
+ this.config.yAxis.axisLabel.formatter = (value) => {
151
+ const objNewValue = this.getValueByUnit(value, unit);
152
+ return `${objNewValue.toFixed(decimalDigits)}${suffix}`;
153
+ };
154
+ } else {
155
+ this.config.yAxis.axisLabel.formatter = null;
156
+ }
157
+ }
158
+ async setOptions({
159
+ chartType,
160
+ isTitle,
161
+ title,
162
+ titleLocation,
163
+ dataSource,
164
+ filterData,
165
+ xField,
166
+ xStatistics,
167
+ groupKey,
168
+ groupKeyTimeSpan,
169
+ xIsCountEmpty,
170
+ yField,
171
+ isLegend,
172
+ legend,
173
+ legend2,
174
+ isXaxisName,
175
+ xAxisName,
176
+ isXaxisAxisLabelShow,
177
+ isXaxisAxisTickShow,
178
+ isXaxisAxisLabelRotate,
179
+ isYAxisSplitlineLinestyleWidth,
180
+ yAxisSplitlineLinestyleType,
181
+ yAxisMax,
182
+ yAxisMin,
183
+ isYAxisName,
184
+ yAxisName,
185
+ isSeriesShowSymbol,
186
+ isYAxisShow,
187
+ isUnit,
188
+ unit,
189
+ decimalDigits,
190
+ suffix
191
+ }) {
192
+ if (dataSource) {
193
+ await this.setSourceData({
194
+ dataSource,
195
+ filterData,
196
+ xField,
197
+ xStatistics,
198
+ xIsCountEmpty,
199
+ yField,
200
+ groupKey,
201
+ groupKeyTimeSpan,
202
+ });
203
+ }
204
+ legend = document.body.clientWidth < 1024 ? legend : legend2;
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,170 @@
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
+ // @ts-ignore
68
+ itemSeries.radius = ['40%', '70%'];
69
+ }
70
+ });
71
+ }
72
+
73
+ // 显示图表上的数据标签 单位,标签,小数位数,后缀
74
+ setIsSeriesShowSymbol({
75
+ isSeriesShowSymbol,
76
+ isPercent,
77
+ isUnit,
78
+ unit,
79
+ decimalDigits,
80
+ suffix
81
+ }) {
82
+ decimalDigits = decimalDigits < 0 ? 0 : decimalDigits;
83
+ let show = false;
84
+ let position = 'inner';
85
+ let formatter = null;
86
+
87
+ if (isSeriesShowSymbol || isPercent || isUnit) {
88
+ formatter = '';
89
+ }
90
+ this.config.series[0].label.show = show;
91
+ this.config.series[0].label.position = position;
92
+ if (formatter === null) {
93
+ this.config.series[0].label.normal = null;
94
+ } else {
95
+ this.config.series[0].label.normal.formatter = (objValue) => {
96
+ let reData = '';
97
+ if (isSeriesShowSymbol) { // 显示数值
98
+ reData = objValue.value;
99
+ }
100
+ if (isUnit) { // 显示单位
101
+ if (unit) {
102
+ const objNewValue = this.getValueByUnit(objValue.value, unit);
103
+ reData = `${objNewValue.toFixed(decimalDigits)}${suffix}`;
104
+ } else {
105
+ reData = `${objValue.value.toFixed(decimalDigits)}`;
106
+ }
107
+ this.config.series[0].data.forEach((itemData) => {
108
+ itemData.tooltip.formatter = (objVal) => {
109
+ const objItemData = this.getValueByUnit(objVal.value, unit);
110
+ return `${objItemData.toFixed(decimalDigits)}${suffix}`;
111
+ };
112
+ });
113
+ }
114
+ if (isPercent) { // 显示百分比
115
+ reData = `${reData}(${objValue.percent}%)`;
116
+ }
117
+ return reData;
118
+ };
119
+ }
120
+ }
121
+ async setOptions({
122
+ chartType,
123
+ isTitle,
124
+ title,
125
+ titleLocation,
126
+ dataSource,
127
+ filterData,
128
+ setColor,
129
+ xField,
130
+ xStatistics,
131
+ xIsCountEmpty,
132
+ yField,
133
+ isLegend,
134
+ legend,
135
+ legend2,
136
+ isSeriesShowSymbol,
137
+ isPercent,
138
+ isUnit,
139
+ unit,
140
+ decimalDigits,
141
+ suffix
142
+ }) {
143
+ legend = document.body.clientWidth < 1024 ? legend : legend2;
144
+ if (dataSource) {
145
+ await this.setSourceData({
146
+ dataSource,
147
+ filterData,
148
+ setColor,
149
+ xField,
150
+ xStatistics,
151
+ xIsCountEmpty,
152
+ yField,
153
+ });
154
+ }
155
+
156
+ this.setChartType({ chartType });
157
+ this.setTitle({ isTitle, title, titleLocation });
158
+ this.setLegend({ isLegend, legend });
159
+ this.setIsSeriesShowSymbol({
160
+ isSeriesShowSymbol,
161
+ isPercent,
162
+ isUnit,
163
+ unit,
164
+ decimalDigits,
165
+ suffix
166
+ });
167
+ }
168
+ }
169
+
170
+ export default EchartPie;
@@ -0,0 +1,34 @@
1
+ export interface DataSource {
2
+ name:string, // 数据源名
3
+ type:string, // 数据源类型
4
+ subType:string, // 数据源子类型
5
+ provider?:string, // 内置连接器类型
6
+ methodName:string // 数据源方法名
7
+ }
8
+ export interface ObjSource {
9
+ dataSourceName:string, // 数据源名
10
+ dataSourceType:string, // 数据源类型
11
+ dataSourceMethodName:string // 数据源方法名
12
+ }
13
+ export interface Xfield {
14
+ format:string,
15
+ type:string,
16
+ title:string,
17
+ name:string,
18
+ }
19
+ enum CountType {
20
+ 'count',
21
+ 'sum',
22
+ 'avg',
23
+ 'max',
24
+ 'min'
25
+ }
26
+ export interface YfieldOne {
27
+ key:string,
28
+ operationType:CountType,
29
+ title?:string,
30
+ }
31
+ export interface Yfield {
32
+ groupKey?:string,
33
+ numValue?:Array<YfieldOne>,
34
+ }
@@ -0,0 +1,106 @@
1
+ .weda-ui-echart .set_bottom {
2
+ padding: 4px 0;
3
+ background: #fff;
4
+ margin: 0;
5
+ }
6
+ .weda-ui-echart .pc_set_title {
7
+ height: 48px;
8
+ line-height: 48px;
9
+ font-size: 16px;
10
+ padding-left: 24px;
11
+ }
12
+ .weda-ui-echart .mobile_set_title {
13
+ height: 24px;
14
+ line-height: 24px;
15
+ font-size: 12px;
16
+ padding-left: 12px;
17
+ }
18
+ .weda-ui-echart .echart-light-box {
19
+ position: relative;
20
+ background-color: #F4F5F6;
21
+ }
22
+ .weda-ui-echart .echart-light-body {
23
+ background-color: #ffffff;
24
+ }
25
+ .weda-ui-echart .echart-dark-box {
26
+ position: relative;
27
+ background-color: #4B5D6C;
28
+ }
29
+ .weda-ui-echart .echart-dark-body {
30
+ background-color: #1D1F24;
31
+ margin: 6px;
32
+ }
33
+ .weda-ui-echart .btn-grounp {
34
+ position: absolute;
35
+ top: 60px;
36
+ left: 58px;
37
+ z-index: 999;
38
+ background: transparent;
39
+ }
40
+ .weda-ui-echart button {
41
+ text-transform: none;
42
+ }
43
+ .weda-ui-echart .ant-btn,
44
+ .weda-ui-echart .ant-btn:active,
45
+ .weda-ui-echart .ant-btn:focus {
46
+ outline: 0;
47
+ }
48
+ .weda-ui-echart .ant-btn {
49
+ margin-right: 8px;
50
+ margin-bottom: 12px;
51
+ line-height: 1.499;
52
+ display: inline-block;
53
+ font-weight: 400;
54
+ text-align: center;
55
+ touch-action: manipulation;
56
+ cursor: pointer;
57
+ background-image: none;
58
+ border: 1px solid transparent;
59
+ white-space: nowrap;
60
+ padding: 0 23px;
61
+ font-size: 14px;
62
+ border-radius: 4px;
63
+ height: 36px;
64
+ -webkit-user-select: none;
65
+ -moz-user-select: none;
66
+ -ms-user-select: none;
67
+ user-select: none;
68
+ transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
69
+ position: relative;
70
+ color: #4B5D6C;
71
+ background-color: #fff;
72
+ border-color: #CCD2D8;
73
+ }
74
+ .weda-ui-echart .button,
75
+ .weda-ui-echart html [type="button"],
76
+ .weda-ui-echart [type="reset"],
77
+ .weda-ui-echart [type="submit"] {
78
+ -webkit-appearance: button;
79
+ }
80
+ .weda-ui-echart .ant-btn-primary {
81
+ color: #fff;
82
+ background-color: #4A62E7;
83
+ border-color: #4A62E7;
84
+ }
85
+ .weda-ui-echart .ant-btn:not([disabled]):hover {
86
+ text-decoration: none;
87
+ }
88
+ .weda-ui-echart .ant-btn:hover,
89
+ .weda-ui-echart .ant-btn:focus,
90
+ .weda-ui-echart .ant-btn:active,
91
+ .weda-ui-echart .ant-btn.active {
92
+ background: #fff;
93
+ text-decoration: none;
94
+ }
95
+ .weda-ui-echart .ant-btn:hover,
96
+ .weda-ui-echart .ant-btn:focus {
97
+ color: #4A62E7;
98
+ background-color: #fff;
99
+ border-color: #4A62E7;
100
+ }
101
+ .weda-ui-echart .ant-btn-primary:hover,
102
+ .weda-ui-echart .ant-btn-primary:focus {
103
+ color: #fff;
104
+ background-color: #5f78ff;
105
+ border-color: #5f78ff;
106
+ }
@@ -0,0 +1,33 @@
1
+ // 引入 echarts 核心模块,核心模块提供了 echarts 使用必须要的接口。
2
+ import * as echarts from 'echarts/core';
3
+ // 引入图表,图表后缀都为 Chart
4
+ import { BarChart, LineChart, PieChart } from 'echarts/charts';
5
+ //组件,组件后缀都为 Component
6
+ import {
7
+ TitleComponent,
8
+ TooltipComponent,
9
+ LegendComponent,
10
+ GridComponent
11
+ } from 'echarts/components';
12
+ // 标签自动布局,全局过渡动画等特性
13
+ import { LabelLayout, UniversalTransition } from 'echarts/features';
14
+ // 引入 Canvas 渲染器,注意引入 CanvasRenderer 或者 SVGRenderer 是必须的一步
15
+ import { CanvasRenderer } from 'echarts/renderers';
16
+
17
+ // 注册必须的组件
18
+ echarts.use([
19
+ TitleComponent,
20
+ TooltipComponent,
21
+ GridComponent,
22
+ LegendComponent,
23
+ LabelLayout,
24
+ UniversalTransition,
25
+ CanvasRenderer,
26
+ BarChart,
27
+ LineChart,
28
+ PieChart
29
+ ]);
30
+
31
+ export {
32
+ echarts
33
+ };
@@ -0,0 +1,69 @@
1
+ import { useAsync, useDeepCompareEffect, useEventListener, useIsMounted, useMountEffect } from "@react-hookz/web";
2
+ import { MutableRefObject, RefObject, useCallback, useEffect, useMemo, useRef } from "react";
3
+ import { IEchartModalBase } from "./core/eChartBase";
4
+ import { echarts } from "./echarts";
5
+
6
+ export function useChart(ref: RefObject<HTMLElement> | MutableRefObject<HTMLElement>) {
7
+ const chartRef = useRef<echarts.ECharts>();
8
+ const isMounted = useIsMounted();
9
+ useMountEffect(() => {
10
+
11
+ if(!ref.current || !isMounted) {
12
+ return;
13
+ }
14
+
15
+ const echartDom = ref.current;
16
+ const chart = echarts.init(echartDom);
17
+ chartRef.current = chart;
18
+ return () => {
19
+ chart.dispose();
20
+ chartRef.current = null;
21
+ };
22
+ });
23
+
24
+ useEventListener(window, 'resize', () => {
25
+ chartRef.current && chartRef.current.resize();
26
+ });
27
+
28
+ return chartRef.current;
29
+ }
30
+
31
+
32
+ /**
33
+ * @deprecated The method should not be used
34
+ */
35
+ export function useWedaChart(domRef, ModalClass: IEchartModalBase, options: echarts.EChartsCoreOption) {
36
+ const chart = useChart(domRef);
37
+ const getOptions = async() => {
38
+ const chartModal = new ModalClass();
39
+ let finalOptions: any = await chartModal.setOptions(options);
40
+ if(!finalOptions) {
41
+ finalOptions = chartModal.getOptions() as any;
42
+ }
43
+ return finalOptions;
44
+ };
45
+ const [state, actions] = useAsync(getOptions);
46
+
47
+ useMountEffect(() => {
48
+ actions.execute();
49
+ });
50
+ useDeepCompareEffect(() => {
51
+ actions.execute();
52
+ }, [
53
+ // options 变化,包含所有配置项,包括纯前端的配置项变化都会触发setOptions里发请求,但改不动了
54
+ options,
55
+ actions]);
56
+ useEffect(() => {
57
+ if(state.status === 'success' && chart) {
58
+ console.log(ModalClass.name, options, state.result, window.location.href);
59
+ chart.setOption(
60
+ state.result,
61
+ true // noMerge 全刷
62
+ );
63
+ } else {
64
+ if(state.status === 'error') {
65
+ console.error(state.error);
66
+ }
67
+ }
68
+ }, [state]);
69
+ }