vue2-client 1.15.34 → 1.15.35

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