vue2-client 1.13.28 → 1.13.29

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