vue2-client 1.10.6 → 1.10.8

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 (424) hide show
  1. package/.env +19 -19
  2. package/.env.gaslink +19 -19
  3. package/.env.his +19 -19
  4. package/.env.liuli +19 -19
  5. package/.env.revenue +19 -19
  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/babel.config.js +21 -21
  11. package/docs/Logic/345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +45 -45
  12. package/docs/LowCode/lowcode.md +155 -155
  13. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  14. package/docs/index.md +30 -30
  15. package/docs//345/207/275/346/225/260/344/275/277/347/224/250/347/233/270/345/205/263.md +174 -174
  16. package/index.js +31 -31
  17. package/jest-transform-stub.js +8 -8
  18. package/jest.config.js +21 -21
  19. package/jest.setup.js +7 -7
  20. package/jsconfig.json +19 -19
  21. package/package.json +107 -107
  22. package/public/his/editor/editor.html +51 -51
  23. package/public/his/editor/mock/bind_data.html +779 -779
  24. package/public/his/editor/mock/data_table.html +40 -40
  25. package/public/his/editor/mock/sign.html +75 -75
  26. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  27. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  28. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  29. package/public/his/editor/vender/date97/calendar.js +4 -4
  30. package/public/his/editor/vender/date97/lang/en.js +13 -13
  31. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  32. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  33. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  34. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  35. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  36. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  37. package/public/his/editor/vender/diff.js +1627 -1627
  38. package/public/his/editor/vender/editor.js +1 -1
  39. package/public/his/editor/vender/fabric.js +31187 -31187
  40. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  41. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  42. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  43. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  44. package/public/his/editor/vender/mui/mui.min.css +4 -4
  45. package/public/his/editor/vender/mui/mui.min.js +5 -5
  46. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  47. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  48. package/public/his/editor/vender/qrcode.js +7 -7
  49. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  50. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  51. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  52. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  53. package/public/his/editor/vender/validator.js +5094 -5094
  54. package/public/his/editor/vender/weui/weui.css +5659 -5659
  55. package/public/his/editor/vender/weui/weui.min.css +4 -4
  56. package/public/his/editor/vender/weui/weui.min.js +11 -11
  57. package/src/App.vue +196 -196
  58. package/src/ReportView.js +19 -19
  59. package/src/assets/img/querySlotDemo.svg +15 -15
  60. package/src/assets/svg/badtwo.svg +1 -1
  61. package/src/assets/svg/goodtwo.svg +1 -1
  62. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  63. package/src/base-client/components/AI/demo.vue +31 -31
  64. package/src/base-client/components/common/AMisRender/index.js +3 -3
  65. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  66. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +470 -470
  67. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  68. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  69. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  70. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  71. package/src/base-client/components/common/CitySelect/CitySelect.vue +342 -342
  72. package/src/base-client/components/common/CitySelect/index.js +3 -3
  73. package/src/base-client/components/common/CitySelect/index.md +109 -109
  74. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  75. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  76. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  77. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  78. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  79. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  80. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  81. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  82. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +149 -149
  83. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  84. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  85. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  86. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  87. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  88. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  89. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  90. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  91. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  92. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  93. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  94. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  95. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  96. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  97. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  98. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  99. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  100. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  101. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  102. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  103. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  104. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  105. package/src/base-client/components/common/Recording/index.js +3 -3
  106. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  107. package/src/base-client/components/common/Tree/index.js +2 -2
  108. package/src/base-client/components/common/Upload/Upload.vue +239 -239
  109. package/src/base-client/components/common/Upload/index.js +3 -3
  110. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  111. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +1069 -1066
  112. package/src/base-client/components/common/XAddNativeForm/demo.vue +36 -35
  113. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  114. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  115. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  116. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  117. package/src/base-client/components/common/XAddReport/XAddReport.vue +207 -207
  118. package/src/base-client/components/common/XAddReport/index.js +3 -3
  119. package/src/base-client/components/common/XAddReport/index.md +56 -56
  120. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  121. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  122. package/src/base-client/components/common/XButtons/XButtons.vue +71 -71
  123. package/src/base-client/components/common/XButtons/index.js +3 -3
  124. package/src/base-client/components/common/XButtons/index.md +61 -61
  125. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  126. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  127. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  128. package/src/base-client/components/common/XConversation/XConversation.vue +263 -263
  129. package/src/base-client/components/common/XConversation/XConversationDemo.vue +28 -28
  130. package/src/base-client/components/common/XDataCard/XDataCard.vue +411 -411
  131. package/src/base-client/components/common/XDataCard/index.js +3 -3
  132. package/src/base-client/components/common/XDataCard/index.md +1 -1
  133. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  134. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  135. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  136. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  137. package/src/base-client/components/common/XDatePicker/index.vue +259 -259
  138. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +169 -169
  139. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +304 -304
  140. package/src/base-client/components/common/XDescriptions/demo.vue +50 -50
  141. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  142. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  143. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  144. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  145. package/src/base-client/components/common/XForm/XForm.vue +393 -393
  146. package/src/base-client/components/common/XForm/XFormItem.vue +1286 -1263
  147. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  148. package/src/base-client/components/common/XForm/XTreeSelect.vue +250 -250
  149. package/src/base-client/components/common/XForm/index.md +178 -178
  150. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  151. package/src/base-client/components/common/XFormCol/XFormCol.vue +157 -146
  152. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +295 -295
  153. package/src/base-client/components/common/XFormGroup/demo.vue +45 -45
  154. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  155. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  156. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  157. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  158. package/src/base-client/components/common/XFormTable/XFormTable.vue +854 -854
  159. package/src/base-client/components/common/XFormTable/demo.vue +60 -60
  160. package/src/base-client/components/common/XFormTable/index.md +92 -92
  161. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +167 -167
  162. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  163. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  164. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  165. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  166. package/src/base-client/components/common/XPrint/Demo.vue +41 -41
  167. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  168. package/src/base-client/components/common/XPrint/PrintBill.vue +302 -302
  169. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  170. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  171. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  172. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  173. package/src/base-client/components/common/XPrint/index.vue +97 -97
  174. package/src/base-client/components/common/XReport/XReport.vue +892 -892
  175. package/src/base-client/components/common/XReport/XReportDemo.vue +304 -304
  176. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  177. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  178. package/src/base-client/components/common/XReport/XReportTrGroup.vue +808 -808
  179. package/src/base-client/components/common/XReport/index.js +3 -3
  180. package/src/base-client/components/common/XReport/index.md +44 -44
  181. package/src/base-client/components/common/XReport/print.js +186 -186
  182. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +201 -201
  183. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  184. package/src/base-client/components/common/XReportGrid/XReport.vue +1070 -1070
  185. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +47 -47
  186. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +628 -628
  187. package/src/base-client/components/common/XReportGrid/XReportJsonRender.vue +380 -380
  188. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +1104 -1104
  189. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  190. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  191. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  192. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  193. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  194. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  195. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  196. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  197. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  198. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  199. package/src/base-client/components/common/XStepView/index.js +3 -3
  200. package/src/base-client/components/common/XStepView/index.md +31 -31
  201. package/src/base-client/components/common/XTab/XTab.vue +201 -201
  202. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  203. package/src/base-client/components/common/XTab/index.js +3 -3
  204. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  205. package/src/base-client/components/common/XTable/ExportExcel.vue +284 -284
  206. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  207. package/src/base-client/components/common/XTable/XTable.vue +1415 -1415
  208. package/src/base-client/components/common/XTable/index.md +255 -255
  209. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  210. package/src/base-client/components/common/XTree/XTree.vue +423 -423
  211. package/src/base-client/components/common/XTree/XTreePro.vue +451 -451
  212. package/src/base-client/components/common/XTree/index.js +3 -3
  213. package/src/base-client/components/common/XTree/index.md +36 -36
  214. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  215. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  216. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  217. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  218. package/src/base-client/components/his/XHisEditor/XHisEditor.vue +359 -359
  219. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  220. package/src/base-client/components/index.js +51 -51
  221. package/src/base-client/components/layout/XPageView/RenderRow.vue +63 -63
  222. package/src/base-client/components/layout/XPageView/XErrorView.vue +11 -11
  223. package/src/base-client/components/layout/XPageView/XPageView.vue +155 -155
  224. package/src/base-client/components/layout/XPageView/index.js +3 -3
  225. package/src/base-client/components/layout/XPageView/index.md +38 -38
  226. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  227. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  228. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  229. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  230. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  231. package/src/base-client/plugins/AppData.js +121 -121
  232. package/src/base-client/plugins/Config.js +19 -19
  233. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  234. package/src/base-client/plugins/Recording.js +258 -258
  235. package/src/base-client/plugins/index.js +23 -23
  236. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  237. package/src/bootstrap.js +42 -42
  238. package/src/components/Charts/Bar.vue +62 -62
  239. package/src/components/Charts/ChartCard.vue +134 -134
  240. package/src/components/Charts/Liquid.vue +67 -67
  241. package/src/components/Charts/MiniArea.vue +39 -39
  242. package/src/components/Charts/MiniBar.vue +39 -39
  243. package/src/components/Charts/MiniProgress.vue +75 -75
  244. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  245. package/src/components/Charts/Radar.vue +68 -68
  246. package/src/components/Charts/RankList.vue +77 -77
  247. package/src/components/Charts/TagCloud.vue +113 -113
  248. package/src/components/Charts/TransferBar.vue +64 -64
  249. package/src/components/Charts/Trend.vue +82 -82
  250. package/src/components/Charts/chart.less +12 -12
  251. package/src/components/Charts/smooth.area.less +13 -13
  252. package/src/components/CodeMirror/inedx.vue +118 -118
  253. package/src/components/CodeMirror/setting.js +40 -40
  254. package/src/components/FilePreview/FilePreview.vue +166 -166
  255. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  256. package/src/components/NumberInfo/index.js +3 -3
  257. package/src/components/NumberInfo/index.less +54 -54
  258. package/src/components/NumberInfo/index.md +43 -43
  259. package/src/components/STable/index.js +390 -390
  260. package/src/components/card/ChartCard.vue +79 -79
  261. package/src/components/chart/Bar.vue +60 -60
  262. package/src/components/chart/MiniArea.vue +67 -67
  263. package/src/components/chart/MiniBar.vue +59 -59
  264. package/src/components/chart/MiniProgress.vue +57 -57
  265. package/src/components/chart/Radar.vue +80 -80
  266. package/src/components/chart/RankingList.vue +60 -60
  267. package/src/components/chart/Trend.vue +79 -79
  268. package/src/components/chart/index.less +9 -9
  269. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  270. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  271. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  272. package/src/components/checkbox/index.js +9 -9
  273. package/src/components/exception/ExceptionPage.vue +70 -70
  274. package/src/components/g2Charts/constants.js +202 -202
  275. package/src/components/g2Charts/demo.vue +808 -808
  276. package/src/components/g2Charts/designer.vue +228 -228
  277. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  278. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  279. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  280. package/src/components/g2Charts/index.vue +397 -397
  281. package/src/components/index.js +36 -36
  282. package/src/components/input/IInput.vue +66 -66
  283. package/src/components/menu/SideMenu.vue +75 -75
  284. package/src/components/menu/menu.js +273 -273
  285. package/src/components/setting/Setting.vue +234 -234
  286. package/src/components/tool/AStepItem.vue +60 -60
  287. package/src/config/CreateQueryConfig.js +325 -325
  288. package/src/config/default/antd.config.js +89 -89
  289. package/src/config/default/setting.config.js +55 -55
  290. package/src/font-style/font.css +4 -4
  291. package/src/layouts/CommonLayout.vue +56 -56
  292. package/src/layouts/GridView.vue +45 -45
  293. package/src/layouts/PageLayout.vue +151 -151
  294. package/src/layouts/SinglePageView.vue +136 -136
  295. package/src/layouts/header/AdminHeader.vue +132 -132
  296. package/src/layouts/header/HeaderNotice.vue +177 -177
  297. package/src/layouts/header/InstitutionDetail.vue +181 -181
  298. package/src/layouts/tabs/TabsHead.vue +189 -189
  299. package/src/layouts/tabs/TabsView.vue +390 -390
  300. package/src/lib.js +1 -1
  301. package/src/main.js +34 -34
  302. package/src/mock/extend/index.js +84 -84
  303. package/src/mock/goods/index.js +108 -108
  304. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  305. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  306. package/src/pages/DefaultExample/index.vue +77 -77
  307. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  308. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  309. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  310. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  311. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  312. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  313. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  314. package/src/pages/DynamicStatistics/index.vue +282 -282
  315. package/src/pages/Example/childIndex.vue +15 -15
  316. package/src/pages/Example/index.vue +30 -30
  317. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  318. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  319. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  320. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  321. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  322. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  323. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  324. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  325. package/src/pages/Recording/index.vue +77 -77
  326. package/src/pages/ReportGrid/index.vue +76 -76
  327. package/src/pages/ServiceReview/index.vue +284 -284
  328. package/src/pages/SubExample/index.vue +26 -26
  329. package/src/pages/WorkflowDetail/WorkFlowDemo.vue +32 -32
  330. package/src/pages/WorkflowDetail/WorkflowDetail.vue +230 -230
  331. package/src/pages/WorkflowDetail/WorkflowPageDetail/LeaveMessage.vue +131 -131
  332. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  333. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformation.vue +302 -302
  334. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowBaseInformationDetails.vue +276 -276
  335. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +864 -864
  336. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandleReso.vue +997 -997
  337. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +222 -222
  338. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkOrderParentDetails.vue +233 -233
  339. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowDetailResso.vue +261 -261
  340. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowListResolution.vue +248 -248
  341. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkflowLog.vue +73 -73
  342. package/src/pages/XPageViewExample/index.vue +38 -38
  343. package/src/pages/XReportView/index.vue +64 -64
  344. package/src/pages/XTreeOneProExample/index.vue +67 -67
  345. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  346. package/src/pages/login/Login.vue +378 -378
  347. package/src/pages/login/LoginV3.vue +389 -389
  348. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  349. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  350. package/src/pages/report/ReportTable.js +124 -124
  351. package/src/pages/resourceManage/orgListManage.vue +98 -98
  352. package/src/pages/system/dictionary/index.vue +44 -44
  353. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  354. package/src/pages/system/monitor/operLog/index.vue +37 -37
  355. package/src/pages/system/settings/modifyPassword.vue +117 -117
  356. package/src/pages/system/ticket/index.vue +480 -480
  357. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  358. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  359. package/src/pages/userInfoDetailManage/FillCardRecordQuery/index.vue +76 -76
  360. package/src/pages/userInfoDetailManage/FillGasRecordQuery/index.vue +74 -74
  361. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  362. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  363. package/src/pages/userInfoDetailManage/MachineRecordQuery/index.vue +74 -74
  364. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  365. package/src/pages/userInfoDetailManage/OtherChargeRecordQuery/index.vue +74 -74
  366. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  367. package/src/pages/userInfoDetailManage/UserChargeRecordQuery/index.vue +92 -92
  368. package/src/pages/userInfoDetailManage/UserHandRecordQuery/index.vue +86 -86
  369. package/src/pages/userInfoDetailManage/UserRecordQuery/index.vue +73 -73
  370. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  371. package/src/pages/userInfoDetailManage/index.vue +82 -82
  372. package/src/pages/userInfoDetailManage/userInfoDetailQueryTabs.vue +132 -132
  373. package/src/plugins/EventLogPlugin.js +33 -33
  374. package/src/plugins/FindParentsData.js +17 -17
  375. package/src/plugins/HiPrintPlugin.js +124 -124
  376. package/src/router/async/config.async.js +35 -35
  377. package/src/router/async/router.map.js +188 -188
  378. package/src/router/guards.js +263 -263
  379. package/src/router/index.js +27 -27
  380. package/src/router.js +19 -19
  381. package/src/services/DataModel.js +30 -30
  382. package/src/services/LodopFuncs.js +137 -137
  383. package/src/services/api/TicketDetailsViewApi.js +46 -46
  384. package/src/services/api/cas.js +79 -79
  385. package/src/services/api/common.js +346 -346
  386. package/src/services/api/entity.js +18 -18
  387. package/src/services/api/index.js +17 -17
  388. package/src/services/api/restTools.js +145 -145
  389. package/src/services/apiService.js +15 -15
  390. package/src/services/user.js +90 -90
  391. package/src/services/v3Api.js +116 -116
  392. package/src/store/modules/account.js +115 -115
  393. package/src/store/modules/index.js +5 -5
  394. package/src/store/modules/lowCode.js +33 -33
  395. package/src/store/modules/setting.js +119 -119
  396. package/src/theme/default/style.less +58 -58
  397. package/src/theme/global.less +159 -159
  398. package/src/utils/authority-utils.js +85 -85
  399. package/src/utils/errorCode.js +6 -6
  400. package/src/utils/formatter.js +74 -74
  401. package/src/utils/htmlToPDF.js +108 -108
  402. package/src/utils/htmlToPDFApi.js +5 -5
  403. package/src/utils/indexedDB.js +263 -263
  404. package/src/utils/login.js +188 -188
  405. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  406. package/src/utils/lowcode/lowcodeLog.js +29 -29
  407. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  408. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  409. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  410. package/src/utils/map-utils.js +47 -47
  411. package/src/utils/microAppUtils.js +40 -40
  412. package/src/utils/reg.js +95 -95
  413. package/src/utils/request.js +362 -362
  414. package/src/utils/routerUtil.js +450 -450
  415. package/src/utils/runEvalFunction.js +14 -14
  416. package/src/utils/util.js +310 -310
  417. package/src/utils/waterMark.js +31 -31
  418. package/test/Amis.spec.js +163 -163
  419. package/test/Tree.spec.js +167 -167
  420. package/test/myDialog.spec.js +46 -46
  421. package/test/util.test.js +52 -52
  422. package/test/v3Api.test.js +1983 -1983
  423. package/vue.config.js +213 -213
  424. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,864 +1,864 @@
1
- <template>
2
- <div>
3
- <!-- 上方流程显示 -->
4
- <a-card :bordered="false" :loading="loading" title="项目进度">
5
- <!-- 项目进度流程 -->
6
- <work-flow-timeline
7
- :current-step-id="currentStepId"
8
- :active-step-id="activeStepId"
9
- :workflow-id="workflowId"
10
- :steps="stepsForChild"
11
- :state="workflowState"
12
- change-able
13
- @activeStep="activeStep"/>
14
- </a-card>
15
- <!-- 如果不是当前步骤,显示历史记录 -->
16
- <a-tabs default-active-key="1" @change="note = ''">
17
- <a-tab-pane key="1" :tab="!beforeStepActive && !workflowState ? '表单' : '进度详情'">
18
- <a-card :bordered="false" :loading="loadingHistory">
19
- <div v-if="beforeStepActive || workflowState">
20
- <!-- 当前步骤无记录 -->
21
- <div v-show="!formCompletedDataPreview" style="text-align: center">
22
- <h1>该步骤暂无记录</h1>
23
- </div>
24
- <!-- 当前步骤历史记录 -->
25
- <div v-if="formCompletedDataPreview">
26
- <a-descriptions
27
- v-show="formCompletedDataPreview.data"
28
- :column="{ xxl: 4, xl: 3, lg: 3, md: 3, sm: 2, xs: 1 }"
29
- title="历史记录"
30
- bordered
31
- >
32
- <a-descriptions-item
33
- v-for="(value,key) in formCompletedDataPreview.data"
34
- :key="key"
35
- >
36
- <span slot="label" style="color: #000">{{ key }}</span>
37
- <div style="white-space: pre-wrap">{{ value }}</div>
38
- </a-descriptions-item>
39
- </a-descriptions>
40
- <div v-if="formCompletedDataPreview.note">
41
- <div class="ant-descriptions-title complete-data-title">备注</div>
42
- <p style="white-space: pre-wrap">{{ formCompletedDataPreview.note }}</p>
43
- </div>
44
- <div v-if="formCompletedDataPreview.images.length">
45
- <div class="ant-descriptions-title complete-data-title">图片</div>
46
- <image-item :images="formCompletedDataPreview.images" @preview="handlePreviewFile"/>
47
- </div>
48
- <div v-if="formCompletedDataPreview.files.length">
49
- <div class="ant-descriptions-title complete-data-title">附件</div>
50
- <file-item :files="formCompletedDataPreview.files" @preview="handlePreviewFile"/>
51
- </div>
52
- </div>
53
- </div>
54
- <!-- 如果是当前步骤,填写表单,控制流程等 -->
55
- <div v-if="!beforeStepActive && !workflowState">
56
- <div v-if="canSubmit">
57
- <!-- 退回提示 -->
58
- <a-alert v-if="currentStep && currentStep.back" type="info" show-icon style="margin-bottom: 14px">
59
- <div slot="message">
60
- <span style="color: #000">被退回</span>
61
- <span style="margin-left: 14px; font-size: 14px; color: rgba(0, 0, 0, 0.65)">{{
62
- currentStep.back.f_desc
63
- }}</span>
64
- </div>
65
- <div slot="description">
66
- <div>操作人:{{ currentStep.back.f_operator }}</div>
67
- <div>操作时间:{{ currentStep.back.f_date }}</div>
68
- <div>退回原因:{{ currentStep.back.f_notes }}</div>
69
- </div>
70
- </a-alert>
71
- <!-- 任务时间提示 -->
72
- <a-alert
73
- v-if="taskIsOverdue"
74
- type="warning"
75
- message="当前任务已超过限定完成时间,联系发起人修改完成时间后即可提交"
76
- show-icon
77
- style="margin-bottom: 14px"/>
78
- <!-- 当前步骤,填写表单 -->
79
- <x-add-native-form
80
- v-if="stepDefine.length > 0"
81
- ref="xAddForm"
82
- @onSubmit="submitForm">
83
- </x-add-native-form>
84
- <a-form v-if="!lastStep" label-align="left" :label-col="{ span: 3 }" :wrapper-col="{ span: 13 }">
85
- <a-form-item v-if="showStepNextBtn" label="操作类型" required>
86
- <a-radio-group v-model="operationType" @change="handleOperationTypeChange">
87
- <a-radio value="submit">到下一步</a-radio>
88
- <a-radio value="skip">{{ stepNextBtnTitle }}</a-radio>
89
- </a-radio-group>
90
- </a-form-item>
91
- <a-form-item label="指定下一环节处理人" required>
92
- <a-select
93
- v-model="checkedChargePerson"
94
- placeholder="请选择或搜索"
95
- :options="chargePersonOptions"
96
- show-search
97
- style="width: 195px"
98
- />
99
- </a-form-item>
100
- <a-form-item
101
- label="下一环节截止时间"
102
- :validate-status="deadlineValidateStatus"
103
- :help="deadlineHelp"
104
- required>
105
- <a-date-picker
106
- v-model="deadline"
107
- value-format="YYYY-MM-DD HH:mm"
108
- format="YYYY-MM-DD HH:mm"
109
- :allow-clear="false"
110
- :show-today="false"
111
- show-time
112
- placeholder="请选择"
113
- @change="checkDeadline"/>
114
- </a-form-item>
115
- </a-form>
116
- <!-- 备注信息 -->
117
- <div class="line"></div>
118
- <a-textarea
119
- v-model="note"
120
- :auto-size="{ minRows: 3, maxRows: 5 }"
121
- placeholder="添加备注"
122
- />
123
- <!-- 当前步骤完成后,控制流程按钮 -->
124
- <div style="text-align: center">
125
- <a-radio-group style="margin-top: 20px">
126
- <a-space>
127
- <a-popover v-if="operationType === 'submit'">
128
- <template slot="content">
129
- <p>{{ nextBtnTitle }}</p>
130
- </template>
131
- <a-button
132
- v-show="!lastStep"
133
- :disabled="!showNextBtn && !stepDone"
134
- type="primary"
135
- @click="nextClick"
136
- >
137
- 提交
138
- <a-icon type="right"/>
139
- </a-button>
140
- </a-popover>
141
- <a-popover v-else :title="stepNextBtnTitle">
142
- <template slot="content">
143
- <p v-for="(item,index) in stepNextBtnText" :key="index">{{ item }}</p>
144
- </template>
145
- <a-button
146
- v-if="showStepNextBtn && !lastStep"
147
- type="primary"
148
- @click="stepNextClick"
149
- >
150
- 跳跃
151
- </a-button>
152
- </a-popover>
153
- <a-button
154
- v-show="lastStep"
155
- type="primary"
156
- @click="lastStepNextClick"
157
- >
158
- 确认完工
159
- </a-button>
160
- </a-space>
161
- </a-radio-group>
162
- </div>
163
- </div>
164
- <p v-else style="font-size:16px">
165
- <a-icon type="info-circle"/>
166
- <span style="margin-left:6px">无权操作</span>
167
- </p>
168
- </div>
169
- </a-card>
170
- </a-tab-pane>
171
- <!-- 退回 -->
172
- <a-tab-pane v-if="canSubmit && !beforeStepActive && showPrevBtn && !workflowState" key="2" tab="退回">
173
- <a-form layout="vertical">
174
- <a-form-item label="退回原因" :wrapper-col="{ span: 10 }" required>
175
- <a-textarea
176
- v-model="note"
177
- :auto-size="{ minRows: 4, maxRows: 10 }"
178
- placeholder="请填写退回原因 / 备注"
179
- />
180
- </a-form-item>
181
- <a-form-item :wrapper-col="{ offset: 4 }">
182
- <a-popover :title="preBtnTitle">
183
- <template slot="content">
184
- <p v-for="(item,index) in preBtnText" :key="index">{{ item }}</p>
185
- </template>
186
- <a-button
187
- type="danger"
188
- @click="preClick"
189
- >
190
- <a-icon type="left"/>
191
- 退回
192
- </a-button>
193
- </a-popover>
194
- </a-form-item>
195
- </a-form>
196
- </a-tab-pane>
197
- <a-tab-pane v-if="canSubmit && !beforeStepActive && showPrevBtn && !workflowState" key="3" tab="工单拆分">
198
- <!-- 分配工单 -->
199
- <workflow-list-resolution :workflow-project-id="workflowId" :details="details"></workflow-list-resolution>
200
- </a-tab-pane>
201
- </a-tabs>
202
- <!-- 文件预览 -->
203
- <a-modal v-model="previewFileVisible" :footer="null" :dialog-style="{ top: '20px' }" width="85%" :z-index="1001">
204
- <file-preview :path="filePath"/>
205
- </a-modal>
206
- </div>
207
- </template>
208
-
209
- <script>
210
- import XAddNativeForm from '@vue2-client/base-client/components/common/XAddNativeForm'
211
- import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
212
- import XAddForm from '@vue2-client/base-client/components/common/XAddForm/XAddForm'
213
- import { post, postByServiceName } from '@vue2-client/services/api/restTools'
214
- import { workFlowViewApi } from '@vue2-client/services/api/workFlow'
215
- import { formatDate } from '@vue2-client/utils/util'
216
- // import { commonApi } from '@vue2-client/services/api/common'
217
- import { mapState } from 'vuex'
218
- import moment from 'moment'
219
- import FilePreview from '@vue2-client/components/FilePreview'
220
- import WorkFlowTimeline from './WorkFlowTimeline.vue'
221
- import { FileItem, ImageItem } from '@vue2-client/components/FileImageItem'
222
- import WorkflowListResolution from './WorkflowListResolution'
223
- import { commonApi } from '@vue2-client/services/api'
224
-
225
- export default {
226
- name: 'ApplyHandle',
227
- components: {
228
- WorkflowListResolution,
229
- XAddNativeForm,
230
- WorkFlowTimeline,
231
- XFormTable,
232
- XAddForm,
233
- FilePreview,
234
- FileItem,
235
- ImageItem
236
- },
237
- computed: {
238
- ...mapState('account', { currUser: 'user' }),
239
- canSubmit () {
240
- const step = this.stepsForChild[this.currentStepId - 1]
241
- if (step && step.handler) {
242
- return step.handler.includes(this.currUser.name)
243
- }
244
- return false
245
- }
246
- },
247
- data () {
248
- return {
249
- // 显示供用户填写的当前步骤表单
250
- showForm: false,
251
- // 当前步骤表单标题
252
- formTitle: '',
253
- // 当前步骤表单定义Json
254
- stepDefine: [],
255
- // 当前步骤
256
- currentStep: undefined,
257
- // 当前步骤完成状态
258
- stepDone: false,
259
- // 所有节点连通数据
260
- directions: [],
261
- // 所有流程定义数据
262
- stepsDefine: [],
263
- // 当前步骤能通向的节点
264
- currentDirections: [],
265
- // 当前节点id
266
- currentStepId: undefined,
267
- // 当前活动节点 id
268
- activeStepId: 1,
269
- // 下一步按钮显示
270
- showNextBtn: false,
271
- // 回退按钮显示
272
- showPrevBtn: false,
273
- // 跳过按钮显示
274
- showStepNextBtn: false,
275
- // 定义三个按钮气泡提示内容
276
- preBtnTitle: '',
277
- preBtnText: [],
278
- nextBtnTitle: '',
279
- stepNextBtnTitle: '',
280
- stepNextBtnText: [],
281
- // 控制三个按钮跳转目标
282
- preBtnTo: undefined,
283
- nextBtnTo: undefined,
284
- stepNextBtnTo: undefined,
285
- // 控制当前标签页显示
286
- activeKey: '1',
287
- // 之前的节点是否激活
288
- beforeStepActive: false,
289
- // 之前节点中的数据
290
- beforeStepData: [],
291
- // 用于将已有数据,填回x-add表单中
292
- formCompletedData: {},
293
- // 用于展示提交的数据
294
- formCompletedDataPreview: null,
295
- // 切换至目标流程时,目标流程定义
296
- targetStepDefine: [],
297
- // 控制历史记录加载
298
- loadingHistory: true,
299
- // 控制表单校验
300
- formValid: false,
301
- // 备忘
302
- note: '',
303
- // 是否是最后一步
304
- lastStep: false,
305
- // 存储每一步骤填表人和时间数据
306
- stepsExtraInfo: [],
307
- // 控制基础信息页流程展示加载
308
- loading: true,
309
- createQueryVisible: false,
310
- // 激活的步骤名
311
- activeStepName: '',
312
- stepsParse: undefined,
313
- // 下一步处理人选择框数据
314
- chargePersonOptions: [],
315
- // 已选择下一步处理人
316
- checkedChargePerson: undefined,
317
- // 下一步截止时间
318
- deadline: this.getDefaultDeadline(),
319
- deadlineValidateStatus: '',
320
- deadlineHelp: '',
321
- // 当前任务是否延期
322
- taskIsOverdue: moment().isAfter(this.completeTime, 'day'),
323
- // 预览图片弹框
324
- previewFileVisible: false,
325
- filePath: '',
326
- // 操作类型,提交到下一步或跳过
327
- operationType: 'submit',
328
- // 获取微信推送是否成功信息
329
- information: []
330
- }
331
- },
332
- async mounted () {
333
- this.init()
334
- this.checkDeadline()
335
- },
336
- props: {
337
- workflowId: {
338
- type: String,
339
- required: true
340
- },
341
- visible: {
342
- type: Boolean,
343
- default: false
344
- },
345
- stepsForChild: {
346
- type: Array,
347
- required: true
348
- },
349
- workflowState: {
350
- type: [Boolean, Number],
351
- required: true
352
- },
353
- completeTime: {
354
- type: String,
355
- required: true
356
- },
357
- taskName: {
358
- type: String,
359
- required: true
360
- },
361
- details: {
362
- type: Object,
363
- required: true
364
- }
365
- },
366
- methods: {
367
- init () {
368
- this.getCurrentStep()
369
- },
370
- onClose () {
371
- this.activeStepId = this.currentStepId
372
- this.checkedChargePerson = undefined
373
- this.loadingHistory = true
374
- this.currentStepId = undefined
375
- this.directions = []
376
- this.currentDirections = []
377
- this.preBtnText = []
378
- this.stepNextBtnText = []
379
- this.stepsExtraInfo = []
380
- this.loading = true
381
- this.showNextBtn = false
382
- this.showStepNextBtn = false
383
- this.showPrevBtn = false
384
- this.stepDone = false
385
- this.formCompletedData = {}
386
- this.formCompletedDataPreview = null
387
- this.operationType = 'submit'
388
- },
389
- // 获取单个步骤的定义
390
- getSingleStepDefine (name) {
391
- for (const step of this.stepsDefine) {
392
- if (name === step.name) {
393
- return step.properties.form
394
- }
395
- }
396
- },
397
- // 日期格式化
398
- format (date, format) {
399
- return formatDate(date, format)
400
- },
401
- // 获取当前步骤
402
- getCurrentStep () {
403
- return postByServiceName(workFlowViewApi.getWorkFlowCurrentSubState, {
404
- workflowId: this.workflowId
405
- })
406
- .then(res => {
407
- res.state = this.stepsForChild[res.id - 1].name
408
- this.currentStep = res
409
- this.getDirection()
410
- }, err => {
411
- console.log(err)
412
- })
413
- },
414
- // 判断id是否为流程中最后一个
415
- isLastStep (stepId) {
416
- const lastStepId = this.stepsDefine[this.stepsDefine.length - 1].id
417
- this.lastStep = stepId === lastStepId
418
- },
419
- // 完工按钮
420
- async lastStepNextClick () {
421
- this.$refs.xAddForm.asyncSubmit().then((res) => {
422
- this.submitForm(res)
423
- postByServiceName(workFlowViewApi.afterWorkFlowFinalStepSubmit, {
424
- workflowId: this.workflowId
425
- }).then(_res => {
426
- this.saveWorkflowLog('确认完工', '最后一步: ' + this.getStepNameByStepId(this.currentStepId), { notes: this.note.trim() })
427
- this.$message.success('已完工!')
428
- this.loading = true
429
- this.loadingHistory = true
430
- this.onClose()
431
- this.$emit('success', { note: this.note.trim(), form: res.realForm, workflowId: this.workflowId })
432
- },
433
- () => {
434
- this.$message.error('提交失败!')
435
- }
436
- )
437
- })
438
- },
439
- // 三个按钮点击后逻辑
440
- async nextClick () {
441
- const extraData = this.getApplyStepExtraData(this.nextBtnTo)
442
- if (!extraData) {
443
- return
444
- }
445
- await new Promise(resolve => {
446
- this.$confirm({
447
- title: '提交确认',
448
- content: '确定提交么?提交之后数据不可更改!',
449
- onOk () {
450
- resolve()
451
- return Promise.resolve()
452
- }
453
- })
454
- })
455
- this.$refs.xAddForm.asyncSubmit().then(res => {
456
- this.submitForm(res)
457
- postByServiceName(workFlowViewApi.submitToNextStep, extraData)
458
- .then(
459
- res => {
460
- const extra = {
461
- setHandler: this.getStepHandler(),
462
- setDeadline: this.deadline,
463
- notes: this.note.trim()
464
- }
465
- this.saveWorkflowLog('提交', this.generateStepChangeText(this.currentStepId, this.nextBtnTo), extra)
466
- this.$message.success('提交成功')
467
- this.loading = true
468
- this.loadingHistory = true
469
- this.$emit('refresh')
470
- this.onClose()
471
- this.init()
472
- },
473
- err => {
474
- this.$message.error('提交失败!')
475
- console.log(err)
476
- }
477
- )
478
- })
479
- },
480
- async preClick () {
481
- const notes = this.note.trim()
482
- if (!notes) {
483
- this.$message.error('退回请在备注中填写理由')
484
- return
485
- }
486
- return postByServiceName(workFlowViewApi.updateWorkFlowState, {
487
- stepId: this.preBtnTo,
488
- workflowId: this.workflowId
489
- })
490
- .then(
491
- res => {
492
- this.saveWorkflowLog('退回', this.generateStepChangeText(this.currentStepId, this.preBtnTo), { notes })
493
- this.$message.success('退回成功')
494
- this.loading = true
495
- this.loadingHistory = true
496
- this.$emit('refresh')
497
- this.onClose()
498
- this.init()
499
- },
500
- err => {
501
- this.$message.error('退回失败!')
502
- console.log(err)
503
- }
504
- )
505
- },
506
- async stepNextClick () {
507
- const extraData = this.getApplyStepExtraData(this.stepNextBtnTo)
508
- if (!extraData) {
509
- return
510
- }
511
- this.$refs.xAddForm.asyncSubmit().then(res => {
512
- this.submitForm(res)
513
- postByServiceName(workFlowViewApi.submitToNextStep, extraData)
514
- .then(
515
- res => {
516
- const extra = {
517
- setHandler: this.getStepHandler(),
518
- setDeadline: this.deadline,
519
- notes: this.note.trim()
520
- }
521
- this.saveWorkflowLog('跳过', this.generateStepChangeText(this.currentStepId, this.stepNextBtnTo), extra)
522
- this.$message.success('提交成功')
523
- this.loading = true
524
- this.loadingHistory = true
525
- this.$emit('refresh')
526
- this.onClose()
527
- this.init()
528
- },
529
- err => {
530
- this.$message.error('提交失败!')
531
- console.log(err)
532
- }
533
- )
534
- })
535
- },
536
- // 获取当前步骤节点,连通的节点
537
- getDirection () {
538
- // 获取流程定义
539
- return postByServiceName(workFlowViewApi.getWorkFlowDefine, {
540
- id: this.workflowId
541
- })
542
- .then(res => {
543
- res = JSON.parse(res.value)
544
- this.directions = []
545
- this.stepsDefine = res.steps
546
- this.resolveDirections()
547
- this.resolveStep()
548
- }, err => {
549
- console.log(err)
550
- })
551
- },
552
- // 分析当前节点,能通向的节点
553
- resolveDirections () {
554
- for (let i = 0; i < this.stepsDefine.length; i++) {
555
- if (this.stepsDefine[i].name === this.currentStep.state) {
556
- this.currentStepId = this.stepsDefine[i].id
557
- }
558
- }
559
- let hasBack = false
560
- if (this.stepsDefine[this.currentStepId - 1]?.properties?.actions) {
561
- this.currentDirections = this.stepsDefine[this.currentStepId - 1].properties.actions.filter((item) => {
562
- if (item.type === 'back') {
563
- hasBack = true
564
- }
565
- return true
566
- })
567
- }
568
- // 默认可退回到上一步
569
- if (!hasBack && this.currentStepId !== 1) {
570
- this.currentDirections.push({ head: this.currentStepId, tail: this.currentStepId - 1, type: 'back' })
571
- }
572
- this.isLastStep(this.currentStepId)
573
- if (!this.lastStep) {
574
- this.setChargePersonOptions(this.currentStepId + 1)
575
- }
576
- this.workflowControl()
577
- },
578
- // 根据步骤id获取步骤名称
579
- getStepNameByStepId (stepId) {
580
- console.log('stepId==', stepId)
581
- console.log('this.stepsDefine==', this.stepsDefine)
582
- return this.stepsDefine[stepId - 1].name
583
- },
584
- // 表单提交的回调
585
- submitForm (obj) {
586
- this.formValid = true
587
- const formData = obj.realForm
588
- const time = this.format(new Date(), 'yyyy-MM-dd hh:mm:ss')
589
- return postByServiceName(workFlowViewApi.saveWorkFlowStepFormData, {
590
- workflowId: this.workflowId,
591
- stepId: this.currentStepId,
592
- form: formData,
593
- data: time,
594
- handler: this.currUser.name,
595
- note: this.note.trim()
596
- })
597
- .then(
598
- res => {
599
- console.log('表单提交成功')
600
- this.note = ''
601
- this.showForm = false
602
- this.stepDone = true
603
- },
604
- err => {
605
- this.$message.error('保存失败,请检查后重试')
606
- console.log(err)
607
- }
608
- )
609
- },
610
- // 打开填写表单,获取当前步骤定义内容,生成表单
611
- openForm () {
612
- this.stepDefine = this.stepsDefine[this.currentStep.id - 1].properties.form.formJson
613
- this.showForm = true
614
- this.$nextTick(() => {
615
- this.$refs.xAddForm.init({
616
- businessType: '修改',
617
- formItems: this.stepDefine,
618
- layout: this.stepsDefine[this.currentStep.id - 1].properties.form.xAddFormLayout,
619
- showSubmitBtn: false
620
- })
621
- })
622
- },
623
- // 根据当前节点,判断之后流程,以及按钮的显示
624
- workflowControl () {
625
- for (const direction of this.currentDirections) {
626
- if (direction.type === 'submit') {
627
- this.showNextBtn = true
628
- this.nextBtnTo = direction.to
629
- this.nextBtnTitle = '进行下一环节:' + this.getStepNameByStepId(direction.to)
630
- } else if (direction.type === 'skip') {
631
- this.showStepNextBtn = true
632
- this.stepNextBtnTo = direction.to
633
- this.stepNextBtnTitle = '跳至:' + this.getStepNameByStepId(direction.to) + '环节'
634
- this.stepNextBtnText.push('将跳过以下环节:')
635
- for (let i = this.currentStepId; i < direction.to - 1; i++) {
636
- this.stepNextBtnText.push(this.stepsDefine[i].name)
637
- }
638
- } else if (direction.type === 'back') {
639
- for (let i = this.currentStepId - 1; i > 0; i--) {
640
- if (direction.to >= i && this.stepsForChild[i - 1].handler) {
641
- this.preBtnTo = i
642
- this.preBtnTitle = '回退至:' + this.getStepNameByStepId(i) + '环节'
643
- this.showPrevBtn = true
644
- break
645
- } else {
646
- this.preBtnText.push(this.getStepNameByStepId(i))
647
- }
648
- }
649
- if (this.preBtnText.length) {
650
- this.preBtnText.unshift('将跳过以下环节:')
651
- }
652
- }
653
- }
654
- },
655
- // 加载完成
656
- resolveStep () {
657
- this.loading = false
658
- },
659
- // 流程图组件给当前组件传值用,stepNo为用户点击的非当前步骤
660
- async activeStep (stepId) {
661
- // 开启加载
662
- this.loadingHistory = true
663
- // 获取激活节点的步骤名
664
- this.activeStepName = this.getStepNameByStepId(stepId)
665
- // 清空回显数据
666
- this.formCompletedData = {}
667
- let formCompletedDataPreview = null
668
- this.getStepDefine(stepId)
669
- // 判断激活的节点,是不是待完成节点
670
- if (this.activeStepName !== this.currentStep.state || this.workflowState) {
671
- // 获取激活节点历史数据,和字段定义
672
- await this.getCompletedFormData(stepId)
673
- // 将回显数据拷贝,避免引用传递
674
- formCompletedDataPreview = JSON.parse(JSON.stringify(this.formCompletedData))
675
- // 使用字段定义中内容,将回显数据的列名,替换为定义的中文名
676
- const formData = formCompletedDataPreview.data
677
- for (const key in formData) {
678
- for (let i = 0; i < this.targetStepDefine.length; i++) {
679
- const stepDefine = this.targetStepDefine[i]
680
- if (key === stepDefine.model) {
681
- if (!['FilesId', 'Images'].includes(key)) {
682
- // 读取字典值
683
- if (stepDefine.formType === 'select' && stepDefine.selectType === 'key') {
684
- for (const item of this.$appdata.getDictionaryList(stepDefine.selectKey)) {
685
- if (item.value === formData[key]) {
686
- formData[stepDefine.name] = item.label
687
- break
688
- }
689
- }
690
- } else {
691
- formData[stepDefine.name] = formData[key]
692
- }
693
- }
694
- if (key !== stepDefine.name) {
695
- delete formData[key]
696
- }
697
- break
698
- }
699
- }
700
- }
701
- if (!Object.keys(formCompletedDataPreview.data).length) {
702
- formCompletedDataPreview.data = null
703
- }
704
- // 备注
705
- formCompletedDataPreview.note = this.stepsForChild[stepId - 1].note
706
- if (!formCompletedDataPreview.data && !formCompletedDataPreview.files.length && !formCompletedDataPreview.images.length && !formCompletedDataPreview.note) {
707
- formCompletedDataPreview = null
708
- }
709
- this.formCompletedDataPreview = formCompletedDataPreview
710
- // 完成
711
- this.loadingHistory = false
712
- this.beforeStepActive = this.activeStepName !== this.currentStep.state
713
- } else {
714
- this.loadingHistory = false
715
- this.beforeStepActive = false
716
- this.openForm()
717
- }
718
- },
719
- // 获取已经完成步骤的数据
720
- getCompletedFormData (stepId) {
721
- return postByServiceName(workFlowViewApi.getWorkFlowCompletedStepData, {
722
- workflowId: this.workflowId,
723
- stepId: stepId
724
- })
725
- .then(
726
- res => {
727
- this.formCompletedData = res
728
- },
729
- err => {
730
- console.log(err)
731
- }
732
- )
733
- },
734
- // 获取步骤定义表中,当前步骤定义
735
- getStepDefine (stepId) {
736
- const stepName = this.getStepNameByStepId(stepId)
737
- this.targetStepDefine = this.getSingleStepDefine(stepName).formJson
738
- },
739
- // 获取指定步骤额外数据
740
- getApplyStepExtraData (stepId) {
741
- if (!this.checkDeadline(true)) {
742
- return false
743
- }
744
- const stepHandler = this.getStepHandler()
745
- if (!stepHandler) {
746
- this.$message.error('请设置下一环节处理人')
747
- return false
748
- }
749
- return {
750
- workflowId: this.workflowId,
751
- stepId,
752
- name: this.getStepNameByStepId(stepId),
753
- handler: stepHandler,
754
- deadline: this.deadline
755
- }
756
- },
757
- // 获取当前选择的负责人
758
- getStepHandler () {
759
- let stepHandler
760
- if (this.checkedChargePerson) {
761
- stepHandler = this.checkedChargePerson.split('_')[0]
762
- }
763
- return stepHandler
764
- },
765
- // 生成工作流日志步骤变化描述
766
- generateStepChangeText (formStepId, toStepId) {
767
- return `第${formStepId}步: ${this.getStepNameByStepId(formStepId)} --> 第${toStepId}步: ${this.getStepNameByStepId(toStepId)}`
768
- },
769
- // 保存工作流日志
770
- saveWorkflowLog (operation, desc, extra) {
771
- postByServiceName(workFlowViewApi.saveWorkFlowLog, {
772
- workflowId: this.workflowId,
773
- operation,
774
- desc,
775
- operator: this.currUser.name,
776
- notes: '',
777
- setHandler: '',
778
- setDeadline: '',
779
- ...extra
780
- })
781
- },
782
- // 文件预览
783
- handlePreviewFile (url) {
784
- this.filePath = url
785
- this.previewFileVisible = true
786
- },
787
- // 获取默认截止时间
788
- getDefaultDeadline () {
789
- const date = new Date()
790
- date.setDate(date.getDate() + 1)
791
- date.setHours(date.getHours() + 2)
792
- return formatDate(date, 'yyyy-MM-dd hh:mm')
793
- },
794
- // 验证截止时间
795
- checkDeadline (alert) {
796
- const deadline = moment(this.deadline)
797
- if (deadline.isAfter(this.completeTime, 'day')) {
798
- this.deadlineValidateStatus = 'error'
799
- this.deadlineHelp = '不能超过任务限定完成时间'
800
- if (alert) {
801
- this.$message.error('下一环节截止时间不能超过任务限定完成时间,如需设置,请联系发起人修改任务完成时间', 5)
802
- }
803
- return false
804
- }
805
- if (deadline.diff(moment(), 'hours') < 1) {
806
- this.deadlineValidateStatus = 'error'
807
- this.deadlineHelp = '下一环节截止时间只能在1小时之后'
808
- return false
809
- }
810
- this.deadlineValidateStatus = 'success'
811
- this.deadlineHelp = ''
812
- return true
813
- },
814
- // 操作类型单选按钮改变时重新设置负责人选择框
815
- handleOperationTypeChange (event) {
816
- this.checkedChargePerson = undefined
817
- if (event.target.value === 'submit') {
818
- this.setChargePersonOptions(this.nextBtnTo)
819
- } else {
820
- this.setChargePersonOptions(this.stepNextBtnTo)
821
- }
822
- },
823
- // 从指定步骤设置负责人下拉选择框
824
- async setChargePersonOptions (stepId) {
825
- this.checkedChargePerson = undefined
826
- const defineProperties = this.stepsDefine[stepId - 1].properties
827
- const chargePerson = defineProperties.chargePerson
828
- let chargePersonOptions = []
829
- // 获取所有用户信息
830
- const allUser = await post(commonApi.getAllUserOptionList, {})
831
- if (chargePerson.role) {
832
- // 根据角色获取人员
833
- chargePersonOptions = allUser.filter(item => item.rolestr && item.rolestr.includes(chargePerson.role)).map(item => {
834
- return { label: item.label, value: item.label }
835
- })
836
- } else if (chargePerson.department) {
837
- // 根据部门获取人员
838
- chargePersonOptions = allUser.filter(item => item.depname === chargePerson.department).map(item => {
839
- return { label: item.label, value: item.label }
840
- })
841
- }
842
- this.chargePersonOptions = chargePersonOptions
843
- // 默认选中下一环节负责人
844
- if (this.chargePersonOptions.length === 1) {
845
- this.checkedChargePerson = this.chargePersonOptions[0].key
846
- }
847
- }
848
- },
849
- watch: {}
850
- }
851
- </script>
852
- <style lang="less" scoped>
853
- .line {
854
- width: 100%;
855
- height: 5px;
856
- border-bottom: rgb(240, 240, 240) solid 1px;
857
- margin-bottom: 30px;
858
- }
859
-
860
- .complete-data-title {
861
- margin-top: 8px;
862
- margin-bottom: 8px;
863
- }
864
- </style>
1
+ <template>
2
+ <div>
3
+ <!-- 上方流程显示 -->
4
+ <a-card :bordered="false" :loading="loading" title="项目进度">
5
+ <!-- 项目进度流程 -->
6
+ <work-flow-timeline
7
+ :current-step-id="currentStepId"
8
+ :active-step-id="activeStepId"
9
+ :workflow-id="workflowId"
10
+ :steps="stepsForChild"
11
+ :state="workflowState"
12
+ change-able
13
+ @activeStep="activeStep"/>
14
+ </a-card>
15
+ <!-- 如果不是当前步骤,显示历史记录 -->
16
+ <a-tabs default-active-key="1" @change="note = ''">
17
+ <a-tab-pane key="1" :tab="!beforeStepActive && !workflowState ? '表单' : '进度详情'">
18
+ <a-card :bordered="false" :loading="loadingHistory">
19
+ <div v-if="beforeStepActive || workflowState">
20
+ <!-- 当前步骤无记录 -->
21
+ <div v-show="!formCompletedDataPreview" style="text-align: center">
22
+ <h1>该步骤暂无记录</h1>
23
+ </div>
24
+ <!-- 当前步骤历史记录 -->
25
+ <div v-if="formCompletedDataPreview">
26
+ <a-descriptions
27
+ v-show="formCompletedDataPreview.data"
28
+ :column="{ xxl: 4, xl: 3, lg: 3, md: 3, sm: 2, xs: 1 }"
29
+ title="历史记录"
30
+ bordered
31
+ >
32
+ <a-descriptions-item
33
+ v-for="(value,key) in formCompletedDataPreview.data"
34
+ :key="key"
35
+ >
36
+ <span slot="label" style="color: #000">{{ key }}</span>
37
+ <div style="white-space: pre-wrap">{{ value }}</div>
38
+ </a-descriptions-item>
39
+ </a-descriptions>
40
+ <div v-if="formCompletedDataPreview.note">
41
+ <div class="ant-descriptions-title complete-data-title">备注</div>
42
+ <p style="white-space: pre-wrap">{{ formCompletedDataPreview.note }}</p>
43
+ </div>
44
+ <div v-if="formCompletedDataPreview.images.length">
45
+ <div class="ant-descriptions-title complete-data-title">图片</div>
46
+ <image-item :images="formCompletedDataPreview.images" @preview="handlePreviewFile"/>
47
+ </div>
48
+ <div v-if="formCompletedDataPreview.files.length">
49
+ <div class="ant-descriptions-title complete-data-title">附件</div>
50
+ <file-item :files="formCompletedDataPreview.files" @preview="handlePreviewFile"/>
51
+ </div>
52
+ </div>
53
+ </div>
54
+ <!-- 如果是当前步骤,填写表单,控制流程等 -->
55
+ <div v-if="!beforeStepActive && !workflowState">
56
+ <div v-if="canSubmit">
57
+ <!-- 退回提示 -->
58
+ <a-alert v-if="currentStep && currentStep.back" type="info" show-icon style="margin-bottom: 14px">
59
+ <div slot="message">
60
+ <span style="color: #000">被退回</span>
61
+ <span style="margin-left: 14px; font-size: 14px; color: rgba(0, 0, 0, 0.65)">{{
62
+ currentStep.back.f_desc
63
+ }}</span>
64
+ </div>
65
+ <div slot="description">
66
+ <div>操作人:{{ currentStep.back.f_operator }}</div>
67
+ <div>操作时间:{{ currentStep.back.f_date }}</div>
68
+ <div>退回原因:{{ currentStep.back.f_notes }}</div>
69
+ </div>
70
+ </a-alert>
71
+ <!-- 任务时间提示 -->
72
+ <a-alert
73
+ v-if="taskIsOverdue"
74
+ type="warning"
75
+ message="当前任务已超过限定完成时间,联系发起人修改完成时间后即可提交"
76
+ show-icon
77
+ style="margin-bottom: 14px"/>
78
+ <!-- 当前步骤,填写表单 -->
79
+ <x-add-native-form
80
+ v-if="stepDefine.length > 0"
81
+ ref="xAddForm"
82
+ @onSubmit="submitForm">
83
+ </x-add-native-form>
84
+ <a-form v-if="!lastStep" label-align="left" :label-col="{ span: 3 }" :wrapper-col="{ span: 13 }">
85
+ <a-form-item v-if="showStepNextBtn" label="操作类型" required>
86
+ <a-radio-group v-model="operationType" @change="handleOperationTypeChange">
87
+ <a-radio value="submit">到下一步</a-radio>
88
+ <a-radio value="skip">{{ stepNextBtnTitle }}</a-radio>
89
+ </a-radio-group>
90
+ </a-form-item>
91
+ <a-form-item label="指定下一环节处理人" required>
92
+ <a-select
93
+ v-model="checkedChargePerson"
94
+ placeholder="请选择或搜索"
95
+ :options="chargePersonOptions"
96
+ show-search
97
+ style="width: 195px"
98
+ />
99
+ </a-form-item>
100
+ <a-form-item
101
+ label="下一环节截止时间"
102
+ :validate-status="deadlineValidateStatus"
103
+ :help="deadlineHelp"
104
+ required>
105
+ <a-date-picker
106
+ v-model="deadline"
107
+ value-format="YYYY-MM-DD HH:mm"
108
+ format="YYYY-MM-DD HH:mm"
109
+ :allow-clear="false"
110
+ :show-today="false"
111
+ show-time
112
+ placeholder="请选择"
113
+ @change="checkDeadline"/>
114
+ </a-form-item>
115
+ </a-form>
116
+ <!-- 备注信息 -->
117
+ <div class="line"></div>
118
+ <a-textarea
119
+ v-model="note"
120
+ :auto-size="{ minRows: 3, maxRows: 5 }"
121
+ placeholder="添加备注"
122
+ />
123
+ <!-- 当前步骤完成后,控制流程按钮 -->
124
+ <div style="text-align: center">
125
+ <a-radio-group style="margin-top: 20px">
126
+ <a-space>
127
+ <a-popover v-if="operationType === 'submit'">
128
+ <template slot="content">
129
+ <p>{{ nextBtnTitle }}</p>
130
+ </template>
131
+ <a-button
132
+ v-show="!lastStep"
133
+ :disabled="!showNextBtn && !stepDone"
134
+ type="primary"
135
+ @click="nextClick"
136
+ >
137
+ 提交
138
+ <a-icon type="right"/>
139
+ </a-button>
140
+ </a-popover>
141
+ <a-popover v-else :title="stepNextBtnTitle">
142
+ <template slot="content">
143
+ <p v-for="(item,index) in stepNextBtnText" :key="index">{{ item }}</p>
144
+ </template>
145
+ <a-button
146
+ v-if="showStepNextBtn && !lastStep"
147
+ type="primary"
148
+ @click="stepNextClick"
149
+ >
150
+ 跳跃
151
+ </a-button>
152
+ </a-popover>
153
+ <a-button
154
+ v-show="lastStep"
155
+ type="primary"
156
+ @click="lastStepNextClick"
157
+ >
158
+ 确认完工
159
+ </a-button>
160
+ </a-space>
161
+ </a-radio-group>
162
+ </div>
163
+ </div>
164
+ <p v-else style="font-size:16px">
165
+ <a-icon type="info-circle"/>
166
+ <span style="margin-left:6px">无权操作</span>
167
+ </p>
168
+ </div>
169
+ </a-card>
170
+ </a-tab-pane>
171
+ <!-- 退回 -->
172
+ <a-tab-pane v-if="canSubmit && !beforeStepActive && showPrevBtn && !workflowState" key="2" tab="退回">
173
+ <a-form layout="vertical">
174
+ <a-form-item label="退回原因" :wrapper-col="{ span: 10 }" required>
175
+ <a-textarea
176
+ v-model="note"
177
+ :auto-size="{ minRows: 4, maxRows: 10 }"
178
+ placeholder="请填写退回原因 / 备注"
179
+ />
180
+ </a-form-item>
181
+ <a-form-item :wrapper-col="{ offset: 4 }">
182
+ <a-popover :title="preBtnTitle">
183
+ <template slot="content">
184
+ <p v-for="(item,index) in preBtnText" :key="index">{{ item }}</p>
185
+ </template>
186
+ <a-button
187
+ type="danger"
188
+ @click="preClick"
189
+ >
190
+ <a-icon type="left"/>
191
+ 退回
192
+ </a-button>
193
+ </a-popover>
194
+ </a-form-item>
195
+ </a-form>
196
+ </a-tab-pane>
197
+ <a-tab-pane v-if="canSubmit && !beforeStepActive && showPrevBtn && !workflowState" key="3" tab="工单拆分">
198
+ <!-- 分配工单 -->
199
+ <workflow-list-resolution :workflow-project-id="workflowId" :details="details"></workflow-list-resolution>
200
+ </a-tab-pane>
201
+ </a-tabs>
202
+ <!-- 文件预览 -->
203
+ <a-modal v-model="previewFileVisible" :footer="null" :dialog-style="{ top: '20px' }" width="85%" :z-index="1001">
204
+ <file-preview :path="filePath"/>
205
+ </a-modal>
206
+ </div>
207
+ </template>
208
+
209
+ <script>
210
+ import XAddNativeForm from '@vue2-client/base-client/components/common/XAddNativeForm'
211
+ import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
212
+ import XAddForm from '@vue2-client/base-client/components/common/XAddForm/XAddForm'
213
+ import { post, postByServiceName } from '@vue2-client/services/api/restTools'
214
+ import { workFlowViewApi } from '@vue2-client/services/api/workFlow'
215
+ import { formatDate } from '@vue2-client/utils/util'
216
+ // import { commonApi } from '@vue2-client/services/api/common'
217
+ import { mapState } from 'vuex'
218
+ import moment from 'moment'
219
+ import FilePreview from '@vue2-client/components/FilePreview'
220
+ import WorkFlowTimeline from './WorkFlowTimeline.vue'
221
+ import { FileItem, ImageItem } from '@vue2-client/components/FileImageItem'
222
+ import WorkflowListResolution from './WorkflowListResolution'
223
+ import { commonApi } from '@vue2-client/services/api'
224
+
225
+ export default {
226
+ name: 'ApplyHandle',
227
+ components: {
228
+ WorkflowListResolution,
229
+ XAddNativeForm,
230
+ WorkFlowTimeline,
231
+ XFormTable,
232
+ XAddForm,
233
+ FilePreview,
234
+ FileItem,
235
+ ImageItem
236
+ },
237
+ computed: {
238
+ ...mapState('account', { currUser: 'user' }),
239
+ canSubmit () {
240
+ const step = this.stepsForChild[this.currentStepId - 1]
241
+ if (step && step.handler) {
242
+ return step.handler.includes(this.currUser.name)
243
+ }
244
+ return false
245
+ }
246
+ },
247
+ data () {
248
+ return {
249
+ // 显示供用户填写的当前步骤表单
250
+ showForm: false,
251
+ // 当前步骤表单标题
252
+ formTitle: '',
253
+ // 当前步骤表单定义Json
254
+ stepDefine: [],
255
+ // 当前步骤
256
+ currentStep: undefined,
257
+ // 当前步骤完成状态
258
+ stepDone: false,
259
+ // 所有节点连通数据
260
+ directions: [],
261
+ // 所有流程定义数据
262
+ stepsDefine: [],
263
+ // 当前步骤能通向的节点
264
+ currentDirections: [],
265
+ // 当前节点id
266
+ currentStepId: undefined,
267
+ // 当前活动节点 id
268
+ activeStepId: 1,
269
+ // 下一步按钮显示
270
+ showNextBtn: false,
271
+ // 回退按钮显示
272
+ showPrevBtn: false,
273
+ // 跳过按钮显示
274
+ showStepNextBtn: false,
275
+ // 定义三个按钮气泡提示内容
276
+ preBtnTitle: '',
277
+ preBtnText: [],
278
+ nextBtnTitle: '',
279
+ stepNextBtnTitle: '',
280
+ stepNextBtnText: [],
281
+ // 控制三个按钮跳转目标
282
+ preBtnTo: undefined,
283
+ nextBtnTo: undefined,
284
+ stepNextBtnTo: undefined,
285
+ // 控制当前标签页显示
286
+ activeKey: '1',
287
+ // 之前的节点是否激活
288
+ beforeStepActive: false,
289
+ // 之前节点中的数据
290
+ beforeStepData: [],
291
+ // 用于将已有数据,填回x-add表单中
292
+ formCompletedData: {},
293
+ // 用于展示提交的数据
294
+ formCompletedDataPreview: null,
295
+ // 切换至目标流程时,目标流程定义
296
+ targetStepDefine: [],
297
+ // 控制历史记录加载
298
+ loadingHistory: true,
299
+ // 控制表单校验
300
+ formValid: false,
301
+ // 备忘
302
+ note: '',
303
+ // 是否是最后一步
304
+ lastStep: false,
305
+ // 存储每一步骤填表人和时间数据
306
+ stepsExtraInfo: [],
307
+ // 控制基础信息页流程展示加载
308
+ loading: true,
309
+ createQueryVisible: false,
310
+ // 激活的步骤名
311
+ activeStepName: '',
312
+ stepsParse: undefined,
313
+ // 下一步处理人选择框数据
314
+ chargePersonOptions: [],
315
+ // 已选择下一步处理人
316
+ checkedChargePerson: undefined,
317
+ // 下一步截止时间
318
+ deadline: this.getDefaultDeadline(),
319
+ deadlineValidateStatus: '',
320
+ deadlineHelp: '',
321
+ // 当前任务是否延期
322
+ taskIsOverdue: moment().isAfter(this.completeTime, 'day'),
323
+ // 预览图片弹框
324
+ previewFileVisible: false,
325
+ filePath: '',
326
+ // 操作类型,提交到下一步或跳过
327
+ operationType: 'submit',
328
+ // 获取微信推送是否成功信息
329
+ information: []
330
+ }
331
+ },
332
+ async mounted () {
333
+ this.init()
334
+ this.checkDeadline()
335
+ },
336
+ props: {
337
+ workflowId: {
338
+ type: String,
339
+ required: true
340
+ },
341
+ visible: {
342
+ type: Boolean,
343
+ default: false
344
+ },
345
+ stepsForChild: {
346
+ type: Array,
347
+ required: true
348
+ },
349
+ workflowState: {
350
+ type: [Boolean, Number],
351
+ required: true
352
+ },
353
+ completeTime: {
354
+ type: String,
355
+ required: true
356
+ },
357
+ taskName: {
358
+ type: String,
359
+ required: true
360
+ },
361
+ details: {
362
+ type: Object,
363
+ required: true
364
+ }
365
+ },
366
+ methods: {
367
+ init () {
368
+ this.getCurrentStep()
369
+ },
370
+ onClose () {
371
+ this.activeStepId = this.currentStepId
372
+ this.checkedChargePerson = undefined
373
+ this.loadingHistory = true
374
+ this.currentStepId = undefined
375
+ this.directions = []
376
+ this.currentDirections = []
377
+ this.preBtnText = []
378
+ this.stepNextBtnText = []
379
+ this.stepsExtraInfo = []
380
+ this.loading = true
381
+ this.showNextBtn = false
382
+ this.showStepNextBtn = false
383
+ this.showPrevBtn = false
384
+ this.stepDone = false
385
+ this.formCompletedData = {}
386
+ this.formCompletedDataPreview = null
387
+ this.operationType = 'submit'
388
+ },
389
+ // 获取单个步骤的定义
390
+ getSingleStepDefine (name) {
391
+ for (const step of this.stepsDefine) {
392
+ if (name === step.name) {
393
+ return step.properties.form
394
+ }
395
+ }
396
+ },
397
+ // 日期格式化
398
+ format (date, format) {
399
+ return formatDate(date, format)
400
+ },
401
+ // 获取当前步骤
402
+ getCurrentStep () {
403
+ return postByServiceName(workFlowViewApi.getWorkFlowCurrentSubState, {
404
+ workflowId: this.workflowId
405
+ })
406
+ .then(res => {
407
+ res.state = this.stepsForChild[res.id - 1].name
408
+ this.currentStep = res
409
+ this.getDirection()
410
+ }, err => {
411
+ console.log(err)
412
+ })
413
+ },
414
+ // 判断id是否为流程中最后一个
415
+ isLastStep (stepId) {
416
+ const lastStepId = this.stepsDefine[this.stepsDefine.length - 1].id
417
+ this.lastStep = stepId === lastStepId
418
+ },
419
+ // 完工按钮
420
+ async lastStepNextClick () {
421
+ this.$refs.xAddForm.asyncSubmit().then((res) => {
422
+ this.submitForm(res)
423
+ postByServiceName(workFlowViewApi.afterWorkFlowFinalStepSubmit, {
424
+ workflowId: this.workflowId
425
+ }).then(_res => {
426
+ this.saveWorkflowLog('确认完工', '最后一步: ' + this.getStepNameByStepId(this.currentStepId), { notes: this.note.trim() })
427
+ this.$message.success('已完工!')
428
+ this.loading = true
429
+ this.loadingHistory = true
430
+ this.onClose()
431
+ this.$emit('success', { note: this.note.trim(), form: res.realForm, workflowId: this.workflowId })
432
+ },
433
+ () => {
434
+ this.$message.error('提交失败!')
435
+ }
436
+ )
437
+ })
438
+ },
439
+ // 三个按钮点击后逻辑
440
+ async nextClick () {
441
+ const extraData = this.getApplyStepExtraData(this.nextBtnTo)
442
+ if (!extraData) {
443
+ return
444
+ }
445
+ await new Promise(resolve => {
446
+ this.$confirm({
447
+ title: '提交确认',
448
+ content: '确定提交么?提交之后数据不可更改!',
449
+ onOk () {
450
+ resolve()
451
+ return Promise.resolve()
452
+ }
453
+ })
454
+ })
455
+ this.$refs.xAddForm.asyncSubmit().then(res => {
456
+ this.submitForm(res)
457
+ postByServiceName(workFlowViewApi.submitToNextStep, extraData)
458
+ .then(
459
+ res => {
460
+ const extra = {
461
+ setHandler: this.getStepHandler(),
462
+ setDeadline: this.deadline,
463
+ notes: this.note.trim()
464
+ }
465
+ this.saveWorkflowLog('提交', this.generateStepChangeText(this.currentStepId, this.nextBtnTo), extra)
466
+ this.$message.success('提交成功')
467
+ this.loading = true
468
+ this.loadingHistory = true
469
+ this.$emit('refresh')
470
+ this.onClose()
471
+ this.init()
472
+ },
473
+ err => {
474
+ this.$message.error('提交失败!')
475
+ console.log(err)
476
+ }
477
+ )
478
+ })
479
+ },
480
+ async preClick () {
481
+ const notes = this.note.trim()
482
+ if (!notes) {
483
+ this.$message.error('退回请在备注中填写理由')
484
+ return
485
+ }
486
+ return postByServiceName(workFlowViewApi.updateWorkFlowState, {
487
+ stepId: this.preBtnTo,
488
+ workflowId: this.workflowId
489
+ })
490
+ .then(
491
+ res => {
492
+ this.saveWorkflowLog('退回', this.generateStepChangeText(this.currentStepId, this.preBtnTo), { notes })
493
+ this.$message.success('退回成功')
494
+ this.loading = true
495
+ this.loadingHistory = true
496
+ this.$emit('refresh')
497
+ this.onClose()
498
+ this.init()
499
+ },
500
+ err => {
501
+ this.$message.error('退回失败!')
502
+ console.log(err)
503
+ }
504
+ )
505
+ },
506
+ async stepNextClick () {
507
+ const extraData = this.getApplyStepExtraData(this.stepNextBtnTo)
508
+ if (!extraData) {
509
+ return
510
+ }
511
+ this.$refs.xAddForm.asyncSubmit().then(res => {
512
+ this.submitForm(res)
513
+ postByServiceName(workFlowViewApi.submitToNextStep, extraData)
514
+ .then(
515
+ res => {
516
+ const extra = {
517
+ setHandler: this.getStepHandler(),
518
+ setDeadline: this.deadline,
519
+ notes: this.note.trim()
520
+ }
521
+ this.saveWorkflowLog('跳过', this.generateStepChangeText(this.currentStepId, this.stepNextBtnTo), extra)
522
+ this.$message.success('提交成功')
523
+ this.loading = true
524
+ this.loadingHistory = true
525
+ this.$emit('refresh')
526
+ this.onClose()
527
+ this.init()
528
+ },
529
+ err => {
530
+ this.$message.error('提交失败!')
531
+ console.log(err)
532
+ }
533
+ )
534
+ })
535
+ },
536
+ // 获取当前步骤节点,连通的节点
537
+ getDirection () {
538
+ // 获取流程定义
539
+ return postByServiceName(workFlowViewApi.getWorkFlowDefine, {
540
+ id: this.workflowId
541
+ })
542
+ .then(res => {
543
+ res = JSON.parse(res.value)
544
+ this.directions = []
545
+ this.stepsDefine = res.steps
546
+ this.resolveDirections()
547
+ this.resolveStep()
548
+ }, err => {
549
+ console.log(err)
550
+ })
551
+ },
552
+ // 分析当前节点,能通向的节点
553
+ resolveDirections () {
554
+ for (let i = 0; i < this.stepsDefine.length; i++) {
555
+ if (this.stepsDefine[i].name === this.currentStep.state) {
556
+ this.currentStepId = this.stepsDefine[i].id
557
+ }
558
+ }
559
+ let hasBack = false
560
+ if (this.stepsDefine[this.currentStepId - 1]?.properties?.actions) {
561
+ this.currentDirections = this.stepsDefine[this.currentStepId - 1].properties.actions.filter((item) => {
562
+ if (item.type === 'back') {
563
+ hasBack = true
564
+ }
565
+ return true
566
+ })
567
+ }
568
+ // 默认可退回到上一步
569
+ if (!hasBack && this.currentStepId !== 1) {
570
+ this.currentDirections.push({ head: this.currentStepId, tail: this.currentStepId - 1, type: 'back' })
571
+ }
572
+ this.isLastStep(this.currentStepId)
573
+ if (!this.lastStep) {
574
+ this.setChargePersonOptions(this.currentStepId + 1)
575
+ }
576
+ this.workflowControl()
577
+ },
578
+ // 根据步骤id获取步骤名称
579
+ getStepNameByStepId (stepId) {
580
+ console.log('stepId==', stepId)
581
+ console.log('this.stepsDefine==', this.stepsDefine)
582
+ return this.stepsDefine[stepId - 1].name
583
+ },
584
+ // 表单提交的回调
585
+ submitForm (obj) {
586
+ this.formValid = true
587
+ const formData = obj.realForm
588
+ const time = this.format(new Date(), 'yyyy-MM-dd hh:mm:ss')
589
+ return postByServiceName(workFlowViewApi.saveWorkFlowStepFormData, {
590
+ workflowId: this.workflowId,
591
+ stepId: this.currentStepId,
592
+ form: formData,
593
+ data: time,
594
+ handler: this.currUser.name,
595
+ note: this.note.trim()
596
+ })
597
+ .then(
598
+ res => {
599
+ console.log('表单提交成功')
600
+ this.note = ''
601
+ this.showForm = false
602
+ this.stepDone = true
603
+ },
604
+ err => {
605
+ this.$message.error('保存失败,请检查后重试')
606
+ console.log(err)
607
+ }
608
+ )
609
+ },
610
+ // 打开填写表单,获取当前步骤定义内容,生成表单
611
+ openForm () {
612
+ this.stepDefine = this.stepsDefine[this.currentStep.id - 1].properties.form.formJson
613
+ this.showForm = true
614
+ this.$nextTick(() => {
615
+ this.$refs.xAddForm.init({
616
+ businessType: '修改',
617
+ formItems: this.stepDefine,
618
+ layout: this.stepsDefine[this.currentStep.id - 1].properties.form.xAddFormLayout,
619
+ showSubmitBtn: false
620
+ })
621
+ })
622
+ },
623
+ // 根据当前节点,判断之后流程,以及按钮的显示
624
+ workflowControl () {
625
+ for (const direction of this.currentDirections) {
626
+ if (direction.type === 'submit') {
627
+ this.showNextBtn = true
628
+ this.nextBtnTo = direction.to
629
+ this.nextBtnTitle = '进行下一环节:' + this.getStepNameByStepId(direction.to)
630
+ } else if (direction.type === 'skip') {
631
+ this.showStepNextBtn = true
632
+ this.stepNextBtnTo = direction.to
633
+ this.stepNextBtnTitle = '跳至:' + this.getStepNameByStepId(direction.to) + '环节'
634
+ this.stepNextBtnText.push('将跳过以下环节:')
635
+ for (let i = this.currentStepId; i < direction.to - 1; i++) {
636
+ this.stepNextBtnText.push(this.stepsDefine[i].name)
637
+ }
638
+ } else if (direction.type === 'back') {
639
+ for (let i = this.currentStepId - 1; i > 0; i--) {
640
+ if (direction.to >= i && this.stepsForChild[i - 1].handler) {
641
+ this.preBtnTo = i
642
+ this.preBtnTitle = '回退至:' + this.getStepNameByStepId(i) + '环节'
643
+ this.showPrevBtn = true
644
+ break
645
+ } else {
646
+ this.preBtnText.push(this.getStepNameByStepId(i))
647
+ }
648
+ }
649
+ if (this.preBtnText.length) {
650
+ this.preBtnText.unshift('将跳过以下环节:')
651
+ }
652
+ }
653
+ }
654
+ },
655
+ // 加载完成
656
+ resolveStep () {
657
+ this.loading = false
658
+ },
659
+ // 流程图组件给当前组件传值用,stepNo为用户点击的非当前步骤
660
+ async activeStep (stepId) {
661
+ // 开启加载
662
+ this.loadingHistory = true
663
+ // 获取激活节点的步骤名
664
+ this.activeStepName = this.getStepNameByStepId(stepId)
665
+ // 清空回显数据
666
+ this.formCompletedData = {}
667
+ let formCompletedDataPreview = null
668
+ this.getStepDefine(stepId)
669
+ // 判断激活的节点,是不是待完成节点
670
+ if (this.activeStepName !== this.currentStep.state || this.workflowState) {
671
+ // 获取激活节点历史数据,和字段定义
672
+ await this.getCompletedFormData(stepId)
673
+ // 将回显数据拷贝,避免引用传递
674
+ formCompletedDataPreview = JSON.parse(JSON.stringify(this.formCompletedData))
675
+ // 使用字段定义中内容,将回显数据的列名,替换为定义的中文名
676
+ const formData = formCompletedDataPreview.data
677
+ for (const key in formData) {
678
+ for (let i = 0; i < this.targetStepDefine.length; i++) {
679
+ const stepDefine = this.targetStepDefine[i]
680
+ if (key === stepDefine.model) {
681
+ if (!['FilesId', 'Images'].includes(key)) {
682
+ // 读取字典值
683
+ if (stepDefine.formType === 'select' && stepDefine.selectType === 'key') {
684
+ for (const item of this.$appdata.getDictionaryList(stepDefine.selectKey)) {
685
+ if (item.value === formData[key]) {
686
+ formData[stepDefine.name] = item.label
687
+ break
688
+ }
689
+ }
690
+ } else {
691
+ formData[stepDefine.name] = formData[key]
692
+ }
693
+ }
694
+ if (key !== stepDefine.name) {
695
+ delete formData[key]
696
+ }
697
+ break
698
+ }
699
+ }
700
+ }
701
+ if (!Object.keys(formCompletedDataPreview.data).length) {
702
+ formCompletedDataPreview.data = null
703
+ }
704
+ // 备注
705
+ formCompletedDataPreview.note = this.stepsForChild[stepId - 1].note
706
+ if (!formCompletedDataPreview.data && !formCompletedDataPreview.files.length && !formCompletedDataPreview.images.length && !formCompletedDataPreview.note) {
707
+ formCompletedDataPreview = null
708
+ }
709
+ this.formCompletedDataPreview = formCompletedDataPreview
710
+ // 完成
711
+ this.loadingHistory = false
712
+ this.beforeStepActive = this.activeStepName !== this.currentStep.state
713
+ } else {
714
+ this.loadingHistory = false
715
+ this.beforeStepActive = false
716
+ this.openForm()
717
+ }
718
+ },
719
+ // 获取已经完成步骤的数据
720
+ getCompletedFormData (stepId) {
721
+ return postByServiceName(workFlowViewApi.getWorkFlowCompletedStepData, {
722
+ workflowId: this.workflowId,
723
+ stepId: stepId
724
+ })
725
+ .then(
726
+ res => {
727
+ this.formCompletedData = res
728
+ },
729
+ err => {
730
+ console.log(err)
731
+ }
732
+ )
733
+ },
734
+ // 获取步骤定义表中,当前步骤定义
735
+ getStepDefine (stepId) {
736
+ const stepName = this.getStepNameByStepId(stepId)
737
+ this.targetStepDefine = this.getSingleStepDefine(stepName).formJson
738
+ },
739
+ // 获取指定步骤额外数据
740
+ getApplyStepExtraData (stepId) {
741
+ if (!this.checkDeadline(true)) {
742
+ return false
743
+ }
744
+ const stepHandler = this.getStepHandler()
745
+ if (!stepHandler) {
746
+ this.$message.error('请设置下一环节处理人')
747
+ return false
748
+ }
749
+ return {
750
+ workflowId: this.workflowId,
751
+ stepId,
752
+ name: this.getStepNameByStepId(stepId),
753
+ handler: stepHandler,
754
+ deadline: this.deadline
755
+ }
756
+ },
757
+ // 获取当前选择的负责人
758
+ getStepHandler () {
759
+ let stepHandler
760
+ if (this.checkedChargePerson) {
761
+ stepHandler = this.checkedChargePerson.split('_')[0]
762
+ }
763
+ return stepHandler
764
+ },
765
+ // 生成工作流日志步骤变化描述
766
+ generateStepChangeText (formStepId, toStepId) {
767
+ return `第${formStepId}步: ${this.getStepNameByStepId(formStepId)} --> 第${toStepId}步: ${this.getStepNameByStepId(toStepId)}`
768
+ },
769
+ // 保存工作流日志
770
+ saveWorkflowLog (operation, desc, extra) {
771
+ postByServiceName(workFlowViewApi.saveWorkFlowLog, {
772
+ workflowId: this.workflowId,
773
+ operation,
774
+ desc,
775
+ operator: this.currUser.name,
776
+ notes: '',
777
+ setHandler: '',
778
+ setDeadline: '',
779
+ ...extra
780
+ })
781
+ },
782
+ // 文件预览
783
+ handlePreviewFile (url) {
784
+ this.filePath = url
785
+ this.previewFileVisible = true
786
+ },
787
+ // 获取默认截止时间
788
+ getDefaultDeadline () {
789
+ const date = new Date()
790
+ date.setDate(date.getDate() + 1)
791
+ date.setHours(date.getHours() + 2)
792
+ return formatDate(date, 'yyyy-MM-dd hh:mm')
793
+ },
794
+ // 验证截止时间
795
+ checkDeadline (alert) {
796
+ const deadline = moment(this.deadline)
797
+ if (deadline.isAfter(this.completeTime, 'day')) {
798
+ this.deadlineValidateStatus = 'error'
799
+ this.deadlineHelp = '不能超过任务限定完成时间'
800
+ if (alert) {
801
+ this.$message.error('下一环节截止时间不能超过任务限定完成时间,如需设置,请联系发起人修改任务完成时间', 5)
802
+ }
803
+ return false
804
+ }
805
+ if (deadline.diff(moment(), 'hours') < 1) {
806
+ this.deadlineValidateStatus = 'error'
807
+ this.deadlineHelp = '下一环节截止时间只能在1小时之后'
808
+ return false
809
+ }
810
+ this.deadlineValidateStatus = 'success'
811
+ this.deadlineHelp = ''
812
+ return true
813
+ },
814
+ // 操作类型单选按钮改变时重新设置负责人选择框
815
+ handleOperationTypeChange (event) {
816
+ this.checkedChargePerson = undefined
817
+ if (event.target.value === 'submit') {
818
+ this.setChargePersonOptions(this.nextBtnTo)
819
+ } else {
820
+ this.setChargePersonOptions(this.stepNextBtnTo)
821
+ }
822
+ },
823
+ // 从指定步骤设置负责人下拉选择框
824
+ async setChargePersonOptions (stepId) {
825
+ this.checkedChargePerson = undefined
826
+ const defineProperties = this.stepsDefine[stepId - 1].properties
827
+ const chargePerson = defineProperties.chargePerson
828
+ let chargePersonOptions = []
829
+ // 获取所有用户信息
830
+ const allUser = await post(commonApi.getAllUserOptionList, {})
831
+ if (chargePerson.role) {
832
+ // 根据角色获取人员
833
+ chargePersonOptions = allUser.filter(item => item.rolestr && item.rolestr.includes(chargePerson.role)).map(item => {
834
+ return { label: item.label, value: item.label }
835
+ })
836
+ } else if (chargePerson.department) {
837
+ // 根据部门获取人员
838
+ chargePersonOptions = allUser.filter(item => item.depname === chargePerson.department).map(item => {
839
+ return { label: item.label, value: item.label }
840
+ })
841
+ }
842
+ this.chargePersonOptions = chargePersonOptions
843
+ // 默认选中下一环节负责人
844
+ if (this.chargePersonOptions.length === 1) {
845
+ this.checkedChargePerson = this.chargePersonOptions[0].key
846
+ }
847
+ }
848
+ },
849
+ watch: {}
850
+ }
851
+ </script>
852
+ <style lang="less" scoped>
853
+ .line {
854
+ width: 100%;
855
+ height: 5px;
856
+ border-bottom: rgb(240, 240, 240) solid 1px;
857
+ margin-bottom: 30px;
858
+ }
859
+
860
+ .complete-data-title {
861
+ margin-top: 8px;
862
+ margin-bottom: 8px;
863
+ }
864
+ </style>