vue2-client 1.16.20 → 1.16.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 (331) hide show
  1. package/.cursorrules +19 -19
  2. package/.env.apply +19 -19
  3. package/.env.gaslink +19 -19
  4. package/.env.his +19 -19
  5. package/.env.liuli +20 -20
  6. package/.env.scada +19 -19
  7. package/.eslintrc.js +90 -90
  8. package/CHANGELOG.md +824 -824
  9. package/Components.md +60 -60
  10. package/docs/LowCode/lowcode.md +155 -155
  11. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  12. package/docs/index.md +30 -30
  13. package/index.js +31 -31
  14. package/jest-transform-stub.js +8 -8
  15. package/jest.setup.js +7 -7
  16. package/jsconfig.json +19 -19
  17. package/package.json +112 -112
  18. package/public/his/editor/editor.html +51 -51
  19. package/public/his/editor/mock/bind_data.html +779 -779
  20. package/public/his/editor/mock/data_table.html +40 -40
  21. package/public/his/editor/mock/sign.html +75 -75
  22. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  23. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  24. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  25. package/public/his/editor/vender/date97/calendar.js +4 -4
  26. package/public/his/editor/vender/date97/lang/en.js +13 -13
  27. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  28. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  29. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  30. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  31. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  32. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  33. package/public/his/editor/vender/diff.js +1627 -1627
  34. package/public/his/editor/vender/editor.js +1 -1
  35. package/public/his/editor/vender/fabric.js +31187 -31187
  36. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  37. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  38. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  39. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  40. package/public/his/editor/vender/mui/mui.min.css +4 -4
  41. package/public/his/editor/vender/mui/mui.min.js +5 -5
  42. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  43. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  44. package/public/his/editor/vender/qrcode.js +7 -7
  45. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  46. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  47. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  48. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  49. package/public/his/editor/vender/validator.js +5094 -5094
  50. package/public/his/editor/vender/weui/weui.css +5659 -5659
  51. package/public/his/editor/vender/weui/weui.min.css +4 -4
  52. package/public/his/editor/vender/weui/weui.min.js +11 -11
  53. package/src/assets/img/querySlotDemo.svg +15 -15
  54. package/src/assets/svg/badtwo.svg +1 -1
  55. package/src/assets/svg/goodtwo.svg +1 -1
  56. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  57. package/src/base-client/components/AI/demo.vue +31 -31
  58. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  59. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  60. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  61. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  62. package/src/base-client/components/common/CitySelect/index.js +3 -3
  63. package/src/base-client/components/common/CitySelect/index.md +109 -109
  64. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  65. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  66. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  67. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  68. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  69. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  70. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  71. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  72. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  73. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  74. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  75. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  76. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  77. package/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm.vue +478 -466
  78. package/src/base-client/components/common/HIS/HAddNativeForm/index.js +3 -3
  79. package/src/base-client/components/common/HIS/HButtons/HButtons.vue +365 -365
  80. package/src/base-client/components/common/HIS/HFormTable/HFormTable.vue +219 -219
  81. package/src/base-client/components/common/HIS/HTab/HTab.vue +293 -293
  82. package/src/base-client/components/common/HIS/demo.vue +54 -54
  83. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  84. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  85. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  86. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  87. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  88. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  89. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  90. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  92. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  93. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  94. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  95. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  96. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  97. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  98. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  99. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  100. package/src/base-client/components/common/Recording/index.js +3 -3
  101. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  102. package/src/base-client/components/common/Tree/index.js +2 -2
  103. package/src/base-client/components/common/Upload/index.js +3 -3
  104. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  105. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  106. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  107. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  108. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  109. package/src/base-client/components/common/XAddReport/index.js +3 -3
  110. package/src/base-client/components/common/XAddReport/index.md +56 -56
  111. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  112. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  113. package/src/base-client/components/common/XButtons/index.js +3 -3
  114. package/src/base-client/components/common/XButtons/index.md +61 -61
  115. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  116. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  117. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  118. package/src/base-client/components/common/XDataCard/index.js +3 -3
  119. package/src/base-client/components/common/XDataCard/index.md +1 -1
  120. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  121. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  122. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  123. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  124. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  125. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  126. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  127. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  128. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  129. package/src/base-client/components/common/XForm/index.md +178 -178
  130. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  131. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  132. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  133. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  134. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  135. package/src/base-client/components/common/XFormTable/index.md +92 -92
  136. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  137. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  138. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  139. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  140. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  141. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  142. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  143. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  144. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  145. package/src/base-client/components/common/XPrint/index.vue +97 -97
  146. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  147. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  148. package/src/base-client/components/common/XReport/index.js +3 -3
  149. package/src/base-client/components/common/XReport/print.js +186 -186
  150. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  151. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +813 -813
  152. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  153. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  154. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  155. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  156. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  157. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  158. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  159. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  160. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  161. package/src/base-client/components/common/XStepView/index.js +3 -3
  162. package/src/base-client/components/common/XStepView/index.md +31 -31
  163. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  164. package/src/base-client/components/common/XTab/index.js +3 -3
  165. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  166. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  167. package/src/base-client/components/common/XTable/index.md +255 -255
  168. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  169. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  170. package/src/base-client/components/common/XTree/index.js +3 -3
  171. package/src/base-client/components/common/XTree/index.md +36 -36
  172. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  173. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  174. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  175. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  176. package/src/base-client/components/his/XCharge/XCharge.vue +610 -610
  177. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  178. package/src/base-client/components/his/XSidebar/XSidebar.vue +283 -283
  179. package/src/base-client/components/his/XSimpleTable/XSimpleTable.vue +119 -119
  180. package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +481 -481
  181. package/src/base-client/components/index.js +51 -51
  182. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  183. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  184. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  185. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  186. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  187. package/src/base-client/plugins/Config.js +19 -19
  188. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  189. package/src/base-client/plugins/Recording.js +258 -258
  190. package/src/base-client/plugins/index.js +23 -23
  191. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  192. package/src/components/Charts/Bar.vue +62 -62
  193. package/src/components/Charts/ChartCard.vue +134 -134
  194. package/src/components/Charts/Liquid.vue +67 -67
  195. package/src/components/Charts/MiniArea.vue +39 -39
  196. package/src/components/Charts/MiniBar.vue +39 -39
  197. package/src/components/Charts/MiniProgress.vue +75 -75
  198. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  199. package/src/components/Charts/Radar.vue +68 -68
  200. package/src/components/Charts/RankList.vue +77 -77
  201. package/src/components/Charts/TagCloud.vue +113 -113
  202. package/src/components/Charts/TransferBar.vue +64 -64
  203. package/src/components/Charts/Trend.vue +82 -82
  204. package/src/components/Charts/chart.less +12 -12
  205. package/src/components/Charts/smooth.area.less +13 -13
  206. package/src/components/CodeMirror/inedx.vue +118 -118
  207. package/src/components/CodeMirror/setting.js +40 -40
  208. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  209. package/src/components/NumberInfo/index.js +3 -3
  210. package/src/components/NumberInfo/index.less +54 -54
  211. package/src/components/NumberInfo/index.md +43 -43
  212. package/src/components/card/ChartCard.vue +79 -79
  213. package/src/components/chart/Bar.vue +60 -60
  214. package/src/components/chart/MiniArea.vue +67 -67
  215. package/src/components/chart/MiniBar.vue +59 -59
  216. package/src/components/chart/MiniProgress.vue +57 -57
  217. package/src/components/chart/Radar.vue +80 -80
  218. package/src/components/chart/RankingList.vue +60 -60
  219. package/src/components/chart/Trend.vue +79 -79
  220. package/src/components/chart/index.less +9 -9
  221. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  222. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  223. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  224. package/src/components/checkbox/index.js +9 -9
  225. package/src/components/exception/ExceptionPage.vue +70 -70
  226. package/src/components/g2Charts/constants.js +202 -202
  227. package/src/components/g2Charts/demo.vue +808 -808
  228. package/src/components/g2Charts/designer.vue +228 -228
  229. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  230. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  231. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  232. package/src/components/g2Charts/index.vue +397 -397
  233. package/src/components/index.js +36 -36
  234. package/src/components/input/IInput.vue +66 -66
  235. package/src/components/menu/SideMenu.vue +75 -75
  236. package/src/components/menu/menu.js +273 -273
  237. package/src/components/setting/Setting.vue +234 -234
  238. package/src/components/tool/AStepItem.vue +60 -60
  239. package/src/config/CreateQueryConfig.js +325 -325
  240. package/src/config/default/antd.config.js +89 -89
  241. package/src/config/default/setting.config.js +55 -55
  242. package/src/font-style/font.css +60 -60
  243. package/src/layouts/CommonLayout.vue +56 -56
  244. package/src/layouts/PageLayout.vue +151 -151
  245. package/src/layouts/SinglePageView.vue +136 -136
  246. package/src/layouts/header/AdminHeader.vue +132 -132
  247. package/src/layouts/header/HeaderNotice.vue +177 -177
  248. package/src/layouts/header/InstitutionDetail.vue +181 -181
  249. package/src/layouts/tabs/TabsHead.vue +189 -189
  250. package/src/lib.js +1 -1
  251. package/src/mock/extend/index.js +84 -84
  252. package/src/mock/goods/index.js +108 -108
  253. package/src/pages/DefaultExample/index.vue +77 -77
  254. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  255. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  256. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  257. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  258. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  259. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  260. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  261. package/src/pages/DynamicStatistics/index.vue +282 -282
  262. package/src/pages/Example/childIndex.vue +15 -15
  263. package/src/pages/Example/index.vue +30 -30
  264. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  265. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  266. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  267. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  268. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  269. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  270. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  271. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  272. package/src/pages/Recording/index.vue +77 -77
  273. package/src/pages/ServiceReview/index.vue +284 -284
  274. package/src/pages/SubExample/index.vue +26 -26
  275. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  276. package/src/pages/XReportView/index.vue +64 -64
  277. package/src/pages/XTreeOneProExample/index.vue +67 -67
  278. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  279. package/src/pages/login/Login.vue +379 -379
  280. package/src/pages/login/LoginV3.vue +389 -389
  281. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  282. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  283. package/src/pages/report/ReportTable.js +124 -124
  284. package/src/pages/resourceManage/orgListManage.vue +98 -98
  285. package/src/pages/system/dictionary/index.vue +44 -44
  286. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  287. package/src/pages/system/monitor/operLog/index.vue +37 -37
  288. package/src/pages/system/settings/modifyPassword.vue +117 -117
  289. package/src/pages/system/ticket/index.vue +480 -480
  290. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  291. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  292. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  293. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  294. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  295. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  296. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  297. package/src/plugins/EventLogPlugin.js +33 -33
  298. package/src/plugins/FindParentsData.js +17 -17
  299. package/src/router/async/config.async.js +35 -35
  300. package/src/router/async/router.map.js +129 -129
  301. package/src/router/index.js +27 -27
  302. package/src/services/DataModel.js +30 -30
  303. package/src/services/LodopFuncs.js +137 -137
  304. package/src/services/api/TicketDetailsViewApi.js +46 -46
  305. package/src/services/api/cas.js +79 -79
  306. package/src/services/api/common.js +346 -346
  307. package/src/services/api/entity.js +18 -18
  308. package/src/services/api/index.js +17 -17
  309. package/src/store/modules/account.js +115 -115
  310. package/src/store/modules/index.js +5 -5
  311. package/src/store/modules/lowCode.js +33 -33
  312. package/src/store/modules/setting.js +119 -119
  313. package/src/theme/default/style.less +58 -58
  314. package/src/utils/authority-utils.js +85 -85
  315. package/src/utils/errorCode.js +6 -6
  316. package/src/utils/formatter.js +74 -74
  317. package/src/utils/htmlToPDF.js +108 -108
  318. package/src/utils/htmlToPDFApi.js +5 -5
  319. package/src/utils/login.js +188 -188
  320. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  321. package/src/utils/lowcode/lowcodeLog.js +29 -29
  322. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  323. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  324. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  325. package/src/utils/map-utils.js +47 -47
  326. package/src/utils/reg.js +95 -95
  327. package/src/utils/runEvalFunction.js +14 -14
  328. package/src/utils/theme-color-replacer-extend.js +92 -92
  329. package/src/utils/util.js +329 -329
  330. package/src/utils/waterMark.js +31 -31
  331. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,331 +1,331 @@
1
- <template>
2
- <div class="chart-card">
3
- <a-row type="flex" align="middle" justify="center" :gutter="16">
4
- <a-col>
5
- 分组条件:
6
- <a-select v-model="selectedGroup" style="width: 200px" @change="updateCharts">
7
- <a-select-option v-for="option in groupOptions" :key="option" :value="option">{{ option }}</a-select-option>
8
- </a-select>
9
- </a-col>
10
- <a-col>
11
- 汇总数值列:
12
- <a-select v-model="selectedValues" mode="multiple" style="width: 200px" @change="updateCharts">
13
- <a-select-option v-for="option in valueOptions" :key="option" :value="option">{{ option }}</a-select-option>
14
- </a-select>
15
- </a-col>
16
- <a-col>
17
- 对比项:
18
- <a-select v-model="selectedProjectColumn" style="width: 200px" @change="updateCharts">
19
- <a-select-option v-for="project in projectOptions" :key="project" :value="project">{{ project }}</a-select-option>
20
- </a-select>
21
- </a-col>
22
-
23
- </a-row>
24
- <a-divider/>
25
- <a-row align="middle" justify="space-around" :gutter="24">
26
- <a-col :span="24">
27
- <div ref="columnChart" class="chart-content"></div>
28
- </a-col>
29
- </a-row>
30
- <a-row align="middle" justify="space-around" :gutter="24">
31
- <a-col :span="12">
32
- <div ref="pieChart" class="chart-content"></div>
33
- </a-col>
34
- <a-col :span="12">
35
- <div id="lineChart" ref="lineChart" class="chart-content"></div>
36
- </a-col>
37
- </a-row>
38
- </div>
39
- </template>
40
-
41
- <script>
42
- import * as echarts from 'echarts'
43
-
44
- export default {
45
- data () {
46
- return {
47
- selectedGroup: null,
48
- groupOptions: [],
49
- valueOptions: [],
50
- projectOptions: [],
51
- selectedValues: [], // 更新为数组,支持多选
52
- selectedProjects: [],
53
- selectedProjectColumn: undefined,
54
- pieChart: null,
55
- columnChart: null,
56
- lineChart: null,
57
- componentKey: 0,
58
- commonOptions: {
59
- tooltip: {
60
- trigger: 'item'
61
- },
62
- grid: {
63
- left: '3%',
64
- right: '4%',
65
- bottom: '3%',
66
- containLabel: true
67
- },
68
- legend: {},
69
- }
70
- }
71
- },
72
- mounted () {
73
- this.initData()
74
- },
75
- props: {
76
- rawData: {
77
- type: Array,
78
- required: true
79
- }
80
- },
81
- watch: {
82
- rawData: {
83
- deep: true,
84
- handler (newVal) {
85
- this.initData()
86
- }
87
- }
88
- },
89
- methods: {
90
- initData () {
91
- this.initializeOptions()
92
- if (this.groupOptions.includes('year')) {
93
- this.selectedGroup = 'year'
94
- } else {
95
- this.selectedGroup = this.groupOptions[0]
96
- }
97
- if (this.valueOptions.length > 0) {
98
- this.selectedValues = [this.valueOptions[0]] // 默认选择第一个数值列
99
- }
100
- this.updateCharts()
101
- },
102
- initializeOptions () {
103
- if (this.rawData.length > 0) {
104
- const row = this.rawData[0]
105
- const columns = Object.keys(row)
106
- this.groupOptions = columns.filter(key => typeof row[key] === 'string' ||
107
- this.isYearArray(this.rawData, key))
108
- this.valueOptions = columns.filter(key => {
109
- return !isNaN(parseFloat(row[key])) && isFinite(row[key]) && !this.isYear(row[key])
110
- })
111
- this.projectOptions = columns.filter(key => typeof row[key] === 'string')
112
- }
113
- },
114
- isYearArray (arr, key) {
115
- if (arr.some(item => this.isYear(item[key]))) {
116
- this.updateNonYearItems(arr, key)
117
- return true
118
- }
119
- return false
120
- },
121
- // 修改数组中不满足条件的元素的特定键值为1970
122
- updateNonYearItems (arr, key) {
123
- arr.forEach(item => {
124
- if (!this.isYear(item[key])) {
125
- item[key] = 1970
126
- }
127
- })
128
- },
129
- // 判断数值或者字符串是不是年份
130
- isYear (value) {
131
- return /^(19|20)\d{2}$/.test(value)
132
- },
133
- updateCharts () {
134
- this.renderPieChart()
135
- this.renderColumnChart()
136
- this.renderLineChart()
137
- },
138
- renderPieChart () {
139
- const transformedData = this.transformDataForChart('pie')
140
- const options = {
141
- series: [
142
- {
143
- type: 'pie',
144
- radius: '50%',
145
- data: transformedData,
146
- emphasis: {
147
- itemStyle: {
148
- shadowBlur: 10,
149
- shadowOffsetX: 0,
150
- shadowColor: 'rgba(0, 0, 0, 0.5)'
151
- }
152
- }
153
- }
154
- ]
155
- }
156
- if (!this.pieChart) {
157
- this.pieChart = echarts.init(this.$refs.pieChart)
158
- }
159
- this.pieChart.setOption(Object.assign({},
160
- this.commonOptions,
161
- options
162
- )
163
- )
164
- },
165
- getProjectList () {
166
- let selectedProjects
167
- if (this.selectedProjectColumn) {
168
- selectedProjects = [...new Set(this.rawData.map(item => item[this.selectedProjectColumn]))]
169
- } else {
170
- selectedProjects = []
171
- }
172
- return selectedProjects
173
- },
174
- renderColumnChart () {
175
- const selectedProjects = this.getProjectList()
176
- let items
177
- if (selectedProjects.length > 0) {
178
- items = selectedProjects
179
- } else {
180
- items = this.selectedValues
181
- }
182
- const transformedData = this.transformDataForChart()
183
- const options = {
184
- dataZoom: [
185
- {
186
- type: 'inside'
187
- },
188
- {
189
- type: 'slider'
190
- }
191
- ],
192
- legend: false,
193
- dataset: {
194
- dimensions: ['category', ...items],
195
- source: transformedData
196
- },
197
- xAxis: { type: 'category' },
198
- yAxis: {},
199
- series: items.map(item => {
200
- return { type: 'bar' }
201
- })
202
- }
203
- if (!this.columnChart) {
204
- this.columnChart = echarts.init(this.$refs.columnChart)
205
- }
206
- this.columnChart.clear()
207
- this.columnChart.setOption(Object.assign({},
208
- this.commonOptions,
209
- options
210
- )
211
- )
212
- },
213
- renderLineChart () {
214
- const transformedData = this.transformDataForChart('line')
215
- const options = {
216
- tooltip: {
217
- trigger: 'axis'
218
- },
219
- legend: {
220
- data: this.selectedValues
221
- },
222
- grid: {
223
- left: '3%',
224
- right: '4%',
225
- bottom: '3%',
226
- containLabel: true
227
- },
228
- xAxis: {
229
- type: 'category',
230
- boundaryGap: false,
231
- data: this.rawData.map(item => item[this.selectedGroup])
232
- },
233
- yAxis: {
234
- type: 'value'
235
- },
236
- series: transformedData,
237
- animationDuration: 2000
238
- }
239
- if (!this.lineChart) {
240
- this.lineChart = echarts.init(this.$refs.lineChart)
241
- }
242
- this.lineChart.clear()
243
- this.lineChart.setOption(Object.assign({},
244
- this.commonOptions,
245
- options
246
- ), true)
247
- },
248
- transformDataForChart (type) {
249
- this.selectedGroup = this.selectedGroup || this.groupOptions[0]
250
- if (type === 'pie') {
251
- // 饼图数据转换逻辑:将选中的数值列汇总
252
- // 以 selectedGroup 分组求和
253
- const transformedData = {}
254
- this.rawData.forEach(item => {
255
- this.selectedValues.forEach(
256
- valueKey => {
257
- let key
258
- if (this.selectedValues.length > 1) {
259
- key = item[this.selectedGroup] + '_' + valueKey
260
- } else {
261
- key = item[this.selectedGroup]
262
- }
263
- if (transformedData[key]) {
264
- transformedData[key] += item[valueKey]
265
- } else {
266
- transformedData[key] = item[valueKey]
267
- }
268
- }
269
- )
270
- })
271
- return Object.keys(transformedData).map(key => ({
272
- name: key,
273
- value: transformedData[key]
274
- }))
275
- } else if (type === 'line') {
276
- // 饼图数据转换逻辑:将选中的数值列汇总
277
- return this.selectedValues.map(valueKey => ({
278
- name: valueKey,
279
- type: 'line',
280
- stack: 'Total',
281
- data: this.rawData.map(item => item[valueKey]),
282
- }))
283
- } else {
284
- const selectedProjects = this.getProjectList()
285
- const transformedData = []
286
- if (selectedProjects.length > 0 && this.selectedValues.length > 0) {
287
- // 柱状图的数据转换逻辑
288
- const categoryMap = {}
289
- this.rawData.forEach(item => {
290
- const category = item[this.selectedGroup]
291
- const key = item[this.selectedProjectColumn]
292
- if (item[this.selectedValues[0]] > 0) {
293
- if (!categoryMap[category]) {
294
- categoryMap[category] = {}
295
- }
296
- categoryMap[category][key] = item[this.selectedValues[0]]
297
- }
298
- })
299
-
300
- Object.keys(categoryMap).forEach(category => {
301
- const tempData = { category }
302
- Object.keys(categoryMap[category]).forEach(key => {
303
- tempData[key] = categoryMap[category][key]
304
- })
305
- transformedData.push(tempData)
306
- })
307
- } else {
308
- // 柱状图数据转换逻辑:为每个分组条件和选中的数值列创建条目
309
- this.rawData.forEach(item => {
310
- const tempData = {
311
- category: item[this.selectedGroup]
312
- }
313
- this.selectedValues.forEach(valueKey => {
314
- tempData[valueKey] = item[valueKey]
315
- })
316
- transformedData.push(tempData)
317
- })
318
- }
319
- return transformedData
320
- }
321
- },
322
- }
323
- }
324
- </script>
325
- <style lang="less" scoped>
326
- .chart-card {
327
- .chart-content {
328
- height: 400px;
329
- }
330
- }
331
- </style>
1
+ <template>
2
+ <div class="chart-card">
3
+ <a-row type="flex" align="middle" justify="center" :gutter="16">
4
+ <a-col>
5
+ 分组条件:
6
+ <a-select v-model="selectedGroup" style="width: 200px" @change="updateCharts">
7
+ <a-select-option v-for="option in groupOptions" :key="option" :value="option">{{ option }}</a-select-option>
8
+ </a-select>
9
+ </a-col>
10
+ <a-col>
11
+ 汇总数值列:
12
+ <a-select v-model="selectedValues" mode="multiple" style="width: 200px" @change="updateCharts">
13
+ <a-select-option v-for="option in valueOptions" :key="option" :value="option">{{ option }}</a-select-option>
14
+ </a-select>
15
+ </a-col>
16
+ <a-col>
17
+ 对比项:
18
+ <a-select v-model="selectedProjectColumn" style="width: 200px" @change="updateCharts">
19
+ <a-select-option v-for="project in projectOptions" :key="project" :value="project">{{ project }}</a-select-option>
20
+ </a-select>
21
+ </a-col>
22
+
23
+ </a-row>
24
+ <a-divider/>
25
+ <a-row align="middle" justify="space-around" :gutter="24">
26
+ <a-col :span="24">
27
+ <div ref="columnChart" class="chart-content"></div>
28
+ </a-col>
29
+ </a-row>
30
+ <a-row align="middle" justify="space-around" :gutter="24">
31
+ <a-col :span="12">
32
+ <div ref="pieChart" class="chart-content"></div>
33
+ </a-col>
34
+ <a-col :span="12">
35
+ <div id="lineChart" ref="lineChart" class="chart-content"></div>
36
+ </a-col>
37
+ </a-row>
38
+ </div>
39
+ </template>
40
+
41
+ <script>
42
+ import * as echarts from 'echarts'
43
+
44
+ export default {
45
+ data () {
46
+ return {
47
+ selectedGroup: null,
48
+ groupOptions: [],
49
+ valueOptions: [],
50
+ projectOptions: [],
51
+ selectedValues: [], // 更新为数组,支持多选
52
+ selectedProjects: [],
53
+ selectedProjectColumn: undefined,
54
+ pieChart: null,
55
+ columnChart: null,
56
+ lineChart: null,
57
+ componentKey: 0,
58
+ commonOptions: {
59
+ tooltip: {
60
+ trigger: 'item'
61
+ },
62
+ grid: {
63
+ left: '3%',
64
+ right: '4%',
65
+ bottom: '3%',
66
+ containLabel: true
67
+ },
68
+ legend: {},
69
+ }
70
+ }
71
+ },
72
+ mounted () {
73
+ this.initData()
74
+ },
75
+ props: {
76
+ rawData: {
77
+ type: Array,
78
+ required: true
79
+ }
80
+ },
81
+ watch: {
82
+ rawData: {
83
+ deep: true,
84
+ handler (newVal) {
85
+ this.initData()
86
+ }
87
+ }
88
+ },
89
+ methods: {
90
+ initData () {
91
+ this.initializeOptions()
92
+ if (this.groupOptions.includes('year')) {
93
+ this.selectedGroup = 'year'
94
+ } else {
95
+ this.selectedGroup = this.groupOptions[0]
96
+ }
97
+ if (this.valueOptions.length > 0) {
98
+ this.selectedValues = [this.valueOptions[0]] // 默认选择第一个数值列
99
+ }
100
+ this.updateCharts()
101
+ },
102
+ initializeOptions () {
103
+ if (this.rawData.length > 0) {
104
+ const row = this.rawData[0]
105
+ const columns = Object.keys(row)
106
+ this.groupOptions = columns.filter(key => typeof row[key] === 'string' ||
107
+ this.isYearArray(this.rawData, key))
108
+ this.valueOptions = columns.filter(key => {
109
+ return !isNaN(parseFloat(row[key])) && isFinite(row[key]) && !this.isYear(row[key])
110
+ })
111
+ this.projectOptions = columns.filter(key => typeof row[key] === 'string')
112
+ }
113
+ },
114
+ isYearArray (arr, key) {
115
+ if (arr.some(item => this.isYear(item[key]))) {
116
+ this.updateNonYearItems(arr, key)
117
+ return true
118
+ }
119
+ return false
120
+ },
121
+ // 修改数组中不满足条件的元素的特定键值为1970
122
+ updateNonYearItems (arr, key) {
123
+ arr.forEach(item => {
124
+ if (!this.isYear(item[key])) {
125
+ item[key] = 1970
126
+ }
127
+ })
128
+ },
129
+ // 判断数值或者字符串是不是年份
130
+ isYear (value) {
131
+ return /^(19|20)\d{2}$/.test(value)
132
+ },
133
+ updateCharts () {
134
+ this.renderPieChart()
135
+ this.renderColumnChart()
136
+ this.renderLineChart()
137
+ },
138
+ renderPieChart () {
139
+ const transformedData = this.transformDataForChart('pie')
140
+ const options = {
141
+ series: [
142
+ {
143
+ type: 'pie',
144
+ radius: '50%',
145
+ data: transformedData,
146
+ emphasis: {
147
+ itemStyle: {
148
+ shadowBlur: 10,
149
+ shadowOffsetX: 0,
150
+ shadowColor: 'rgba(0, 0, 0, 0.5)'
151
+ }
152
+ }
153
+ }
154
+ ]
155
+ }
156
+ if (!this.pieChart) {
157
+ this.pieChart = echarts.init(this.$refs.pieChart)
158
+ }
159
+ this.pieChart.setOption(Object.assign({},
160
+ this.commonOptions,
161
+ options
162
+ )
163
+ )
164
+ },
165
+ getProjectList () {
166
+ let selectedProjects
167
+ if (this.selectedProjectColumn) {
168
+ selectedProjects = [...new Set(this.rawData.map(item => item[this.selectedProjectColumn]))]
169
+ } else {
170
+ selectedProjects = []
171
+ }
172
+ return selectedProjects
173
+ },
174
+ renderColumnChart () {
175
+ const selectedProjects = this.getProjectList()
176
+ let items
177
+ if (selectedProjects.length > 0) {
178
+ items = selectedProjects
179
+ } else {
180
+ items = this.selectedValues
181
+ }
182
+ const transformedData = this.transformDataForChart()
183
+ const options = {
184
+ dataZoom: [
185
+ {
186
+ type: 'inside'
187
+ },
188
+ {
189
+ type: 'slider'
190
+ }
191
+ ],
192
+ legend: false,
193
+ dataset: {
194
+ dimensions: ['category', ...items],
195
+ source: transformedData
196
+ },
197
+ xAxis: { type: 'category' },
198
+ yAxis: {},
199
+ series: items.map(item => {
200
+ return { type: 'bar' }
201
+ })
202
+ }
203
+ if (!this.columnChart) {
204
+ this.columnChart = echarts.init(this.$refs.columnChart)
205
+ }
206
+ this.columnChart.clear()
207
+ this.columnChart.setOption(Object.assign({},
208
+ this.commonOptions,
209
+ options
210
+ )
211
+ )
212
+ },
213
+ renderLineChart () {
214
+ const transformedData = this.transformDataForChart('line')
215
+ const options = {
216
+ tooltip: {
217
+ trigger: 'axis'
218
+ },
219
+ legend: {
220
+ data: this.selectedValues
221
+ },
222
+ grid: {
223
+ left: '3%',
224
+ right: '4%',
225
+ bottom: '3%',
226
+ containLabel: true
227
+ },
228
+ xAxis: {
229
+ type: 'category',
230
+ boundaryGap: false,
231
+ data: this.rawData.map(item => item[this.selectedGroup])
232
+ },
233
+ yAxis: {
234
+ type: 'value'
235
+ },
236
+ series: transformedData,
237
+ animationDuration: 2000
238
+ }
239
+ if (!this.lineChart) {
240
+ this.lineChart = echarts.init(this.$refs.lineChart)
241
+ }
242
+ this.lineChart.clear()
243
+ this.lineChart.setOption(Object.assign({},
244
+ this.commonOptions,
245
+ options
246
+ ), true)
247
+ },
248
+ transformDataForChart (type) {
249
+ this.selectedGroup = this.selectedGroup || this.groupOptions[0]
250
+ if (type === 'pie') {
251
+ // 饼图数据转换逻辑:将选中的数值列汇总
252
+ // 以 selectedGroup 分组求和
253
+ const transformedData = {}
254
+ this.rawData.forEach(item => {
255
+ this.selectedValues.forEach(
256
+ valueKey => {
257
+ let key
258
+ if (this.selectedValues.length > 1) {
259
+ key = item[this.selectedGroup] + '_' + valueKey
260
+ } else {
261
+ key = item[this.selectedGroup]
262
+ }
263
+ if (transformedData[key]) {
264
+ transformedData[key] += item[valueKey]
265
+ } else {
266
+ transformedData[key] = item[valueKey]
267
+ }
268
+ }
269
+ )
270
+ })
271
+ return Object.keys(transformedData).map(key => ({
272
+ name: key,
273
+ value: transformedData[key]
274
+ }))
275
+ } else if (type === 'line') {
276
+ // 饼图数据转换逻辑:将选中的数值列汇总
277
+ return this.selectedValues.map(valueKey => ({
278
+ name: valueKey,
279
+ type: 'line',
280
+ stack: 'Total',
281
+ data: this.rawData.map(item => item[valueKey]),
282
+ }))
283
+ } else {
284
+ const selectedProjects = this.getProjectList()
285
+ const transformedData = []
286
+ if (selectedProjects.length > 0 && this.selectedValues.length > 0) {
287
+ // 柱状图的数据转换逻辑
288
+ const categoryMap = {}
289
+ this.rawData.forEach(item => {
290
+ const category = item[this.selectedGroup]
291
+ const key = item[this.selectedProjectColumn]
292
+ if (item[this.selectedValues[0]] > 0) {
293
+ if (!categoryMap[category]) {
294
+ categoryMap[category] = {}
295
+ }
296
+ categoryMap[category][key] = item[this.selectedValues[0]]
297
+ }
298
+ })
299
+
300
+ Object.keys(categoryMap).forEach(category => {
301
+ const tempData = { category }
302
+ Object.keys(categoryMap[category]).forEach(key => {
303
+ tempData[key] = categoryMap[category][key]
304
+ })
305
+ transformedData.push(tempData)
306
+ })
307
+ } else {
308
+ // 柱状图数据转换逻辑:为每个分组条件和选中的数值列创建条目
309
+ this.rawData.forEach(item => {
310
+ const tempData = {
311
+ category: item[this.selectedGroup]
312
+ }
313
+ this.selectedValues.forEach(valueKey => {
314
+ tempData[valueKey] = item[valueKey]
315
+ })
316
+ transformedData.push(tempData)
317
+ })
318
+ }
319
+ return transformedData
320
+ }
321
+ },
322
+ }
323
+ }
324
+ </script>
325
+ <style lang="less" scoped>
326
+ .chart-card {
327
+ .chart-content {
328
+ height: 400px;
329
+ }
330
+ }
331
+ </style>