vue2-client 1.16.28 → 1.16.29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (320) hide show
  1. package/.cursorrules +19 -19
  2. package/.env.apply +19 -19
  3. package/.env.gaslink +19 -19
  4. package/.env.his +19 -19
  5. package/.env.liuli +20 -20
  6. package/.env.scada +19 -19
  7. package/.eslintrc.js +90 -90
  8. package/CHANGELOG.md +824 -824
  9. package/Components.md +60 -60
  10. package/docs/LowCode/lowcode.md +155 -155
  11. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  12. package/docs/index.md +30 -30
  13. package/index.js +31 -31
  14. package/jest-transform-stub.js +8 -8
  15. package/jest.setup.js +7 -7
  16. package/jsconfig.json +19 -19
  17. package/package.json +1 -1
  18. package/public/his/editor/editor.html +51 -51
  19. package/public/his/editor/mock/bind_data.html +779 -779
  20. package/public/his/editor/mock/data_table.html +40 -40
  21. package/public/his/editor/mock/sign.html +75 -75
  22. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  23. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  24. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  25. package/public/his/editor/vender/date97/calendar.js +4 -4
  26. package/public/his/editor/vender/date97/lang/en.js +13 -13
  27. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  28. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  29. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  30. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  31. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  32. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  33. package/public/his/editor/vender/diff.js +1627 -1627
  34. package/public/his/editor/vender/editor.js +1 -1
  35. package/public/his/editor/vender/fabric.js +31187 -31187
  36. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  37. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  38. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  39. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  40. package/public/his/editor/vender/mui/mui.min.css +4 -4
  41. package/public/his/editor/vender/mui/mui.min.js +5 -5
  42. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  43. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  44. package/public/his/editor/vender/qrcode.js +7 -7
  45. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  46. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  47. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  48. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  49. package/public/his/editor/vender/validator.js +5094 -5094
  50. package/public/his/editor/vender/weui/weui.css +5659 -5659
  51. package/public/his/editor/vender/weui/weui.min.css +4 -4
  52. package/public/his/editor/vender/weui/weui.min.js +11 -11
  53. package/src/assets/img/querySlotDemo.svg +15 -15
  54. package/src/assets/svg/badtwo.svg +1 -1
  55. package/src/assets/svg/goodtwo.svg +1 -1
  56. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  57. package/src/base-client/components/AI/demo.vue +31 -31
  58. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  59. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  60. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  61. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  62. package/src/base-client/components/common/CitySelect/index.js +3 -3
  63. package/src/base-client/components/common/CitySelect/index.md +109 -109
  64. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  65. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  66. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  67. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  68. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  69. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  70. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  71. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  72. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  73. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  74. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  75. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  76. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  77. package/src/base-client/components/common/HIS/HForm/HForm.vue +1 -1
  78. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  79. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  80. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  81. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  82. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  83. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  84. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  85. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  86. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  87. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  88. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  89. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  90. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  92. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  93. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  94. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  95. package/src/base-client/components/common/Recording/index.js +3 -3
  96. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  97. package/src/base-client/components/common/Tree/index.js +2 -2
  98. package/src/base-client/components/common/Upload/index.js +3 -3
  99. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  100. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  101. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  102. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  103. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  104. package/src/base-client/components/common/XAddReport/index.js +3 -3
  105. package/src/base-client/components/common/XAddReport/index.md +56 -56
  106. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  107. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  108. package/src/base-client/components/common/XButtons/index.js +3 -3
  109. package/src/base-client/components/common/XButtons/index.md +61 -61
  110. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  111. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  112. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  113. package/src/base-client/components/common/XDataCard/index.js +3 -3
  114. package/src/base-client/components/common/XDataCard/index.md +1 -1
  115. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  116. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  117. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  118. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  119. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  120. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  121. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  122. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  123. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  124. package/src/base-client/components/common/XForm/index.md +178 -178
  125. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  126. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  127. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  128. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  129. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  130. package/src/base-client/components/common/XFormTable/demo.vue +16 -45
  131. package/src/base-client/components/common/XFormTable/index.md +92 -92
  132. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  133. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  134. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  135. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  136. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  137. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  138. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  139. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  140. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  141. package/src/base-client/components/common/XPrint/index.vue +97 -97
  142. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  143. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  144. package/src/base-client/components/common/XReport/index.js +3 -3
  145. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  146. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +4 -1
  147. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  148. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  149. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  150. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  151. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  152. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  153. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  154. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  155. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  156. package/src/base-client/components/common/XStepView/index.js +3 -3
  157. package/src/base-client/components/common/XStepView/index.md +31 -31
  158. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  159. package/src/base-client/components/common/XTab/index.js +3 -3
  160. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  161. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  162. package/src/base-client/components/common/XTable/index.md +255 -255
  163. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  164. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  165. package/src/base-client/components/common/XTree/index.js +3 -3
  166. package/src/base-client/components/common/XTree/index.md +36 -36
  167. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  168. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  169. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  170. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  171. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  172. package/src/base-client/components/index.js +51 -51
  173. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  174. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  175. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  176. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  177. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  178. package/src/base-client/plugins/Config.js +19 -19
  179. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  180. package/src/base-client/plugins/Recording.js +258 -258
  181. package/src/base-client/plugins/index.js +23 -23
  182. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  183. package/src/components/Charts/Bar.vue +62 -62
  184. package/src/components/Charts/ChartCard.vue +134 -134
  185. package/src/components/Charts/Liquid.vue +67 -67
  186. package/src/components/Charts/MiniArea.vue +39 -39
  187. package/src/components/Charts/MiniBar.vue +39 -39
  188. package/src/components/Charts/MiniProgress.vue +75 -75
  189. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  190. package/src/components/Charts/Radar.vue +68 -68
  191. package/src/components/Charts/RankList.vue +77 -77
  192. package/src/components/Charts/TagCloud.vue +113 -113
  193. package/src/components/Charts/TransferBar.vue +64 -64
  194. package/src/components/Charts/Trend.vue +82 -82
  195. package/src/components/Charts/chart.less +12 -12
  196. package/src/components/Charts/smooth.area.less +13 -13
  197. package/src/components/CodeMirror/inedx.vue +118 -118
  198. package/src/components/CodeMirror/setting.js +40 -40
  199. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  200. package/src/components/NumberInfo/index.js +3 -3
  201. package/src/components/NumberInfo/index.less +54 -54
  202. package/src/components/NumberInfo/index.md +43 -43
  203. package/src/components/card/ChartCard.vue +79 -79
  204. package/src/components/chart/Bar.vue +60 -60
  205. package/src/components/chart/MiniArea.vue +67 -67
  206. package/src/components/chart/MiniBar.vue +59 -59
  207. package/src/components/chart/MiniProgress.vue +57 -57
  208. package/src/components/chart/Radar.vue +80 -80
  209. package/src/components/chart/RankingList.vue +60 -60
  210. package/src/components/chart/Trend.vue +79 -79
  211. package/src/components/chart/index.less +9 -9
  212. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  213. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  214. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  215. package/src/components/checkbox/index.js +9 -9
  216. package/src/components/exception/ExceptionPage.vue +70 -70
  217. package/src/components/g2Charts/constants.js +202 -202
  218. package/src/components/g2Charts/demo.vue +808 -808
  219. package/src/components/g2Charts/designer.vue +228 -228
  220. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  221. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  222. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  223. package/src/components/g2Charts/index.vue +397 -397
  224. package/src/components/index.js +36 -36
  225. package/src/components/input/IInput.vue +66 -66
  226. package/src/components/menu/SideMenu.vue +75 -75
  227. package/src/components/menu/menu.js +273 -273
  228. package/src/components/setting/Setting.vue +234 -234
  229. package/src/components/tool/AStepItem.vue +60 -60
  230. package/src/config/CreateQueryConfig.js +325 -325
  231. package/src/config/default/antd.config.js +89 -89
  232. package/src/config/default/setting.config.js +55 -55
  233. package/src/font-style/font.css +60 -60
  234. package/src/layouts/CommonLayout.vue +56 -56
  235. package/src/layouts/PageLayout.vue +151 -151
  236. package/src/layouts/SinglePageView.vue +136 -136
  237. package/src/layouts/header/AdminHeader.vue +132 -132
  238. package/src/layouts/header/HeaderNotice.vue +177 -177
  239. package/src/layouts/header/InstitutionDetail.vue +181 -181
  240. package/src/layouts/tabs/TabsHead.vue +189 -189
  241. package/src/lib.js +1 -1
  242. package/src/mock/extend/index.js +84 -84
  243. package/src/mock/goods/index.js +108 -108
  244. package/src/pages/DefaultExample/index.vue +77 -77
  245. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  246. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  247. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  248. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  249. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  250. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  251. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  252. package/src/pages/DynamicStatistics/index.vue +282 -282
  253. package/src/pages/Example/childIndex.vue +15 -15
  254. package/src/pages/Example/index.vue +30 -30
  255. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  256. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  257. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  258. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  259. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  260. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  261. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  262. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  263. package/src/pages/Recording/index.vue +77 -77
  264. package/src/pages/ServiceReview/index.vue +284 -284
  265. package/src/pages/SubExample/index.vue +26 -26
  266. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  267. package/src/pages/XReportView/index.vue +64 -64
  268. package/src/pages/XTreeOneProExample/index.vue +67 -67
  269. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  270. package/src/pages/login/Login.vue +379 -379
  271. package/src/pages/login/LoginV3.vue +389 -389
  272. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  273. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  274. package/src/pages/report/ReportTable.js +124 -124
  275. package/src/pages/resourceManage/orgListManage.vue +98 -98
  276. package/src/pages/system/dictionary/index.vue +44 -44
  277. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  278. package/src/pages/system/monitor/operLog/index.vue +37 -37
  279. package/src/pages/system/settings/modifyPassword.vue +117 -117
  280. package/src/pages/system/ticket/index.vue +480 -480
  281. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  282. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  283. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  284. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  285. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  286. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  287. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  288. package/src/plugins/EventLogPlugin.js +33 -33
  289. package/src/plugins/FindParentsData.js +17 -17
  290. package/src/router/async/config.async.js +35 -35
  291. package/src/router/index.js +27 -27
  292. package/src/services/DataModel.js +30 -30
  293. package/src/services/LodopFuncs.js +137 -137
  294. package/src/services/api/TicketDetailsViewApi.js +46 -46
  295. package/src/services/api/cas.js +79 -79
  296. package/src/services/api/common.js +350 -346
  297. package/src/services/api/entity.js +18 -18
  298. package/src/services/api/index.js +17 -17
  299. package/src/store/modules/account.js +115 -115
  300. package/src/store/modules/index.js +5 -5
  301. package/src/store/modules/lowCode.js +33 -33
  302. package/src/store/modules/setting.js +119 -119
  303. package/src/theme/default/style.less +58 -58
  304. package/src/utils/authority-utils.js +85 -85
  305. package/src/utils/errorCode.js +6 -6
  306. package/src/utils/formatter.js +74 -74
  307. package/src/utils/htmlToPDF.js +108 -108
  308. package/src/utils/htmlToPDFApi.js +5 -5
  309. package/src/utils/login.js +188 -188
  310. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  311. package/src/utils/lowcode/lowcodeLog.js +29 -29
  312. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  313. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  314. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  315. package/src/utils/reg.js +95 -95
  316. package/src/utils/runEvalFunction.js +14 -14
  317. package/src/utils/theme-color-replacer-extend.js +92 -92
  318. package/src/utils/util.js +329 -329
  319. package/src/utils/waterMark.js +31 -31
  320. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,484 +1,484 @@
1
- <template>
2
- <a-card :bordered="false" class="result-success">
3
- <result :description="description" :is-success="icon" :title="title">
4
- <template slot="action">
5
- <span v-if="countDown > 0" style="margin-right: 10px">{{ countDown }}</span>
6
- <!-- <a-button type="primary" v-if="UrgentAvailable" :disabled="urgentAccess" style="margin-right: 20px" @click="urgent">请求加急处理</a-button> -->
7
- <!-- <a-button type="danger" @click="closeBtn">撤销工单</a-button> -->
8
- </template>
9
- <a-modal
10
- :visible="closeVisible"
11
- :zIndex="1002"
12
- title="关闭工单"
13
- @cancel="handleCloseCancel"
14
- @ok="handleCloseOk"
15
- >
16
- <p>是否确认手动关闭工单?</p>
17
- <p style="color: red">(该操作不可撤销,请谨慎操作!)</p>
18
- </a-modal>
19
- <div>
20
- <div class="project-name">工单处理进度</div>
21
- <detail-list size="small" style="max-width: 800px; margin-bottom: 8px">
22
- <detail-list-item term="工单编号">{{ serialNumber }}</detail-list-item>
23
- <detail-list-item v-if="details.name" term="负责人">{{ details.name }}</detail-list-item>
24
- <detail-list-item term="提交时间">{{ details.createdTime }}</detail-list-item>
25
- </detail-list>
26
- <a-steps :current="step" progressDot>
27
- <a-step title="工单提交">
28
- <a-step-item-group slot="description">
29
- <a-step-item :title="details.uploader" />
30
- <a-step-item :title="details.createdTime"/>
31
- </a-step-item-group>
32
- </a-step>
33
- <a-step title="工单处理中" >
34
- <a-step-item-group slot="description">
35
- <a-step-item v-if="step >= 1" :title="details.phone ? `${details.name} (${details.phone})` : details.name" />
36
- <a-step-item v-if="step >= 1" :title="details.confirmTime"/>
37
- </a-step-item-group>
38
- </a-step>
39
- <a-step title="工单待确认" >
40
- <a-step-item-group slot="description">
41
- <a-step-item v-if="step >= 2" :title="`是否完成: ${verifyDetails.sfwc}`"/>
42
- <a-step-item v-if="step >= 2" :title="`售后评价: ${verifyDetails.shpj}`"/>
43
- <a-step-item v-if="step >= 2" :title="`反馈意见: ${verifyDetails.fkyj}`"/>
44
- </a-step-item-group>
45
- </a-step>
46
- <a-step title="工单完成" >
47
- <a-step-item-group slot="description">
48
- <a-step-item v-if="step >= 3" :title="details.finishedTime"/>
49
- </a-step-item-group>
50
- </a-step>
51
- </a-steps>
52
- </div>
53
- </result>
54
- <div class="ticket-detail">
55
- <a-tabs :default-active-key="tabActiveKey">
56
- <a-tab-pane key="1" tab="工单问题">
57
- <a-row class="item">
58
- <a-col :span="3"><span class="title">问题描述</span></a-col>
59
- <a-col :span="17"><span>{{ details.description }}</span></a-col>
60
- </a-row>
61
- <a-row class="item">
62
- <a-col :span="3"><span class="title">问题截图</span></a-col>
63
- <a-col :span="21"><image-item :images="details.images" :width="120" @preview="handleFilePreview" /></a-col>
64
- </a-row>
65
- <a-row v-if="details.files.length" class="item">
66
- <a-col :span="3"><span class="title">附件</span></a-col>
67
- <a-col :span="21"><file-item :files="details.files" :downloadable="false" @preview="handleFilePreview" /></a-col>
68
- </a-row>
69
- <a-row v-if="details.resultrecord" class="item">
70
- <a-col :span="3"><span class="title">处理结果</span></a-col>
71
- <a-col :span="17"><span>{{ details.resultrecord }}</span></a-col>
72
- </a-row>
73
- </a-tab-pane>
74
- <a-tab-pane key="2" tab="工单确认" v-show="this.details.status === 4">
75
- <a-row class="item">
76
- <a-form :label-col="{ span: 5 }" :wrapper-col="{ span: 12 }">
77
- <!-- 是否完成 -->
78
- <a-form-item label="是否完成">
79
- <a-select placeholder="请选择" v-model="customerSure.sfwc">
80
- <a-select-option value="是">
81
-
82
- </a-select-option>
83
- <a-select-option value="否">
84
-
85
- </a-select-option>
86
- </a-select>
87
- </a-form-item>
88
- <!-- 退回原因 -->
89
- <a-form-item label="退回截图" v-show="customerSure.sfwc === '否'">
90
- <div class="clearfix">
91
- <upload v-if="uploadVisible" :model="imageUploadModel" @setFiles="setImages" />
92
- <a-modal
93
- :footer="null"
94
- :visible="previewVisible"
95
- @cancel="handleCancel"
96
- >
97
- <img :src="previewImage" alt="图片上传" style="width: 100%"/>
98
- </a-modal>
99
- </div>
100
- </a-form-item>
101
- <!-- 退回原因 -->
102
- <a-form-item label="退回原因" v-show="customerSure.sfwc === '否'">
103
- <a-textarea placeholder="请输入退回原因" v-model="customerSure.thyy"></a-textarea>
104
- </a-form-item>
105
- <!-- 售后评价 -->
106
- <a-form-item label="售后评价" v-show="customerSure.sfwc === '是'">
107
- <a-select placeholder="请选择" v-model="customerSure.shpj">
108
- <a-select-option value="满意">
109
- 满意
110
- </a-select-option>
111
- <a-select-option value="不满意">
112
- 不满意
113
- </a-select-option>
114
- </a-select>
115
- </a-form-item>
116
- <!-- 反馈意见 -->
117
- <a-form-item label="反馈意见" v-show="customerSure.sfwc === '是'">
118
- <a-textarea placeholder="请输入反馈意见" v-model="customerSure.fkyj"></a-textarea>
119
- </a-form-item>
120
- <!-- 表单底部按钮 -->
121
- <a-form-item :wrapper-col="{ span: 12, offset: 5 }">
122
- <a-button type="primary" @click="rollBack" :disabled="customerSure.sfwc === '是'" style="margin-right: 10px">
123
- 退回
124
- </a-button>
125
- <a-button type="primary" @click="submit" :disabled="customerSure.sfwc === '否'">
126
- 提交
127
- </a-button>
128
- </a-form-item>
129
- </a-form>
130
- </a-row>
131
- </a-tab-pane>
132
- </a-tabs>
133
- </div>
134
- <a-modal v-model="filePreviewVisible" :footer="null" :dialog-style="{ top: '30px' }" width="80%" :z-index="1001">
135
- <file-preview :path="filePath" />
136
- </a-modal>
137
- </a-card>
138
- </template>
139
-
140
- <script>
141
- import Result from '@vue2-client/components/result/Result'
142
- import DetailList from '@vue2-client/components/tool/DetailList'
143
- import AStepItem from '@vue2-client/components/tool/AStepItem'
144
- import { TicketDetailsViewApi, post } from '@vue2-client/services/api'
145
- import { formatDate } from '@vue2-client/utils/util'
146
- import { FileItem, ImageItem } from '@vue2-client/components/FileImageItem'
147
- import FilePreview from '@vue2-client/components/FilePreview'
148
- import Upload from '@vue2-client/base-client/components/common/Upload'
149
-
150
- const AStepItemGroup = AStepItem.Group
151
- const DetailListItem = DetailList.Item
152
- const fileUploadModel = JSON.parse('{"addOrEdit":"all","resUploadStock":1,"pathKey":"cs","rule":{"type":"string","required":"false"},"isOnlyAddOrEdit":true,"acceptCount":3,"type":"file","accept":["*"],"stockAlias":"webmeter","fileRootPath":"D:\\\\nginx-resource\\\\resource\\\\","name":"附件","resUploadMode":"server","model":"FilesId"}')
153
- const imageUploadModel = JSON.parse('{"addOrEdit":"all","resUploadStock":1,"pathKey":"cs","rule":{"type":"string","required":"false"},"isOnlyAddOrEdit":true,"acceptCount":5,"type":"image","accept":[".jpg,.jpeg,.ico,.gif,svg,.webp,.png,.bmp,.pjpeg,"],"stockAlias":"webmeter","fileRootPath":"D:\\\\nginx-resource\\\\resource\\\\","name":"图片","resUploadMode":"server","model":"Images"}')
154
-
155
- export default {
156
- name: 'SubmitTicketSuccess',
157
- components: { AStepItemGroup, AStepItem, DetailListItem, DetailList, Result, FileItem, ImageItem, FilePreview, Upload },
158
- props: {
159
- // 工单序列号
160
- serialNumber: {
161
- type: String,
162
- required: true
163
- }
164
- },
165
- data () {
166
- return {
167
- fileUploadModel,
168
- imageUploadModel,
169
- title: '提交成功',
170
- description: '您创建的工单已成功提交,请保持电话畅通,我们的工作人员将尽快与您取得联系。', // +
171
- // '如果需要加急,请在倒计时结束后点击加急按钮,加急后我们将优先处理您的工单',
172
- // 工单详情
173
- details: {
174
- uploader: '',
175
- status: 0,
176
- name: '',
177
- phone: '',
178
- createdTime: '',
179
- confirmTime: '',
180
- finishedTime: '',
181
- description: '',
182
- resultrecord: '',
183
- files: [],
184
- images: []
185
- },
186
- // 控制加急按钮
187
- urgentAccess: true,
188
- // 倒计时
189
- countDown: 0,
190
- // 控制加急按钮显示
191
- UrgentAvailable: true,
192
- // 取消工单确认框可见性
193
- closeVisible: false,
194
- // 控制页面大图标
195
- icon: true,
196
- // 文件预览
197
- filePreviewVisible: false,
198
- filePath: '',
199
- tabActiveKey: '1',
200
- customerSure: {
201
- shpj: '满意',
202
- fkyj: undefined,
203
- sfwc: '是',
204
- thyy: ''
205
- },
206
- // 工单id
207
- applyId: 0,
208
- // 工单步骤
209
- stepId: 0,
210
- // 确认详情
211
- verifyDetails: {
212
- shpj: '',
213
- sfwc: '',
214
- fkyj: ''
215
- },
216
- uploadVisible: true,
217
- // 控制预览显示
218
- previewVisible: false,
219
- // 图片真实地址
220
- previewImage: '',
221
- imageList: []
222
- }
223
- },
224
- mounted () {
225
- this.getTicketDetail()
226
- },
227
- methods: {
228
- format (date, format) {
229
- return formatDate(date, format)
230
- },
231
- // 关闭工单确认后操作
232
- handleCloseOk () {
233
- return post(TicketDetailsViewApi.manualCloseTicketByCustomer, {
234
- serialNumber: this.serialNumber,
235
- time: new Date()
236
- })
237
- .then(res => {
238
- this.closeVisible = false
239
- this.title = '工单已关闭'
240
- this.description = ''
241
- this.icon = false
242
- }, err => {
243
- console.error(err)
244
- })
245
- },
246
- // 关闭工单取消后业务逻辑
247
- handleCloseCancel () {
248
- this.closeVisible = false
249
- },
250
- // 关闭工单按钮
251
- closeBtn () {
252
- this.closeVisible = true
253
- },
254
- // 对工单进行加急处理
255
- urgent () {
256
- return post(TicketDetailsViewApi.rushTicket, {
257
- serialNumber: this.serialNumber
258
- })
259
- .then(res => {
260
- if (res.data === 1) {
261
- this.$message.success(
262
- '操作成功',
263
- 5
264
- )
265
- this.description = '您的工单已经被加急处理,我们的工作人员会优先处理您的请求。'
266
- this.UrgentAvailable = false
267
- } else {
268
- this.$message.error(
269
- '操作失败',
270
- 5
271
- )
272
- }
273
- }, err => {
274
- console.log(err)
275
- })
276
- },
277
- // 获取工单详情
278
- getTicketDetail () {
279
- return post(TicketDetailsViewApi.getTicketDetailsForUploader, {
280
- serialNumber: this.serialNumber
281
- })
282
- .then(res => {
283
- this.stepId = res.stepId
284
- this.applyId = res.apply_id
285
- this.details.uploader = res.uploader
286
- // 判断负责人有没有值
287
- if (res.name === undefined) {
288
- this.details.name = ''
289
- } else {
290
- this.details.name = res.name
291
- }
292
- // 判断工单被确认时间
293
- if (res.confirmtime === undefined) {
294
- this.details.confirmTime = ''
295
- } else {
296
- this.details.confirmTime = this.format(res.confirmtime, 'yyyy-MM-dd hh:mm:ss')
297
- }
298
- // 判断工单完成时间
299
- if (res.finishedtime === undefined) {
300
- this.details.finishedTime = ''
301
- } else {
302
- this.details.finishedTime = this.format(res.finishedtime, 'yyyy-MM-dd hh:mm:ss')
303
- }
304
- this.details.createdTime = this.format(res.createdtime, 'yyyy-MM-dd hh:mm:ss')
305
- this.details.status = res.status
306
- this.details.phone = res.phone
307
- this.details.description = res.description
308
- this.details.files = res.files
309
- this.details.images = res.images
310
- this.details.resultrecord = res.resultrecord
311
- // 如果工单已经关闭, 获取用户确认信息
312
- if (res.status === 3) {
313
- post(TicketDetailsViewApi.getApplyCompletedStepData, {
314
- applyId: this.applyId,
315
- stepId: this.stepId
316
- }).then(res => {
317
- if (res.data) {
318
- this.verifyDetails.fkyj = res.data.fkyj ? res.data.fkyj : '无'
319
- this.verifyDetails.shpj = res.data.shpj ? res.data.shpj : '满意'
320
- this.verifyDetails.sfwc = res.data.sfwc ? res.data.sfwc : '是'
321
- }
322
- })
323
- }
324
- }, err => {
325
- console.log(err)
326
- })
327
- },
328
- handleFilePreview (path) {
329
- this.filePath = path
330
- this.filePreviewVisible = true
331
- },
332
- // 用户确认提交
333
- submit () {
334
- return post(TicketDetailsViewApi.afterApplyFinalStepSubmit, {
335
- applyId: this.applyId
336
- })
337
- .then(
338
- res => {
339
- this.onSubmit()
340
- this.saveWorkflowLog('确认完工', '最后一步: 客户确认', { notes: '' })
341
- this.$message.success('已完工!')
342
- // 修改工单状态为 3(已关闭)
343
- post(TicketDetailsViewApi.clientSubmit, {
344
- status: 3,
345
- serial_number: this.serialNumber
346
- }).then(res => {
347
- console.log('res', res)
348
- })
349
- this.getTicketDetail()
350
- this.$emit('afterSubmit')
351
- },
352
- err => {
353
- this.$message.error('提交失败!')
354
- console.log(err)
355
- }
356
- )
357
- },
358
- // 回退
359
- rollBack () {
360
- if (this.customerSure.thyy === '') {
361
- this.$message.warn('请填写退回原因')
362
- return
363
- }
364
- const notes = this.customerSure.thyy
365
- return post(TicketDetailsViewApi.updateApplySubState, {
366
- stepId: this.stepId - 1,
367
- applyId: this.applyId
368
- }).then(
369
- res => {
370
- this.saveWorkflowLog('退回', `第${this.stepId}步: 客户确认 ---> 第${this.stepId - 1}步: 售后确认`, { notes })
371
- this.$message.success('退回成功')
372
- // 修改工单状态为 1(待处理)
373
- post(TicketDetailsViewApi.clientSubmit, {
374
- status: 1,
375
- serial_number: this.serialNumber,
376
- Images: this.imageList,
377
- applyId: this.applyId
378
- }).then(res => {
379
- console.log('res', res)
380
- })
381
- this.uploadVisible = false
382
- this.getTicketDetail()
383
- this.$emit('afterSubmit')
384
- },
385
- err => {
386
- this.$message.error('退回失败!')
387
- console.log(err)
388
- }
389
- )
390
- },
391
- // 保存工作流日志
392
- saveWorkflowLog (operation, desc, extra) {
393
- post(TicketDetailsViewApi.saveApplyWorkflowLog, {
394
- applyId: this.applyId,
395
- operation,
396
- desc,
397
- operator: '客户确认',
398
- notes: '客户确认',
399
- setHandler: '客户确认',
400
- setDeadline: '',
401
- ...extra
402
- })
403
- },
404
- //
405
- onSubmit () {
406
- const time = this.format(new Date(), 'yyyy-MM-dd hh:mm:ss')
407
- const form = {
408
- shpj: this.customerSure.shpj,
409
- fkyj: this.customerSure.fkyj,
410
- sfwc: this.customerSure.sfwc
411
- }
412
- return post(TicketDetailsViewApi.saveApplyStepFormData, {
413
- applyId: this.applyId,
414
- stepId: this.stepId,
415
- form: form,
416
- data: time,
417
- handler: '客户确认',
418
- note: ''
419
- })
420
- .then(
421
- res => {
422
- console.log('表单提交成功')
423
- this.note = ''
424
- this.showForm = false
425
- this.stepDone = true
426
- },
427
- err => {
428
- this.$message.error('保存失败,请检查后重试')
429
- console.log(err)
430
- }
431
- )
432
- },
433
- handleCancel () {
434
- this.previewVisible = false
435
- },
436
- setImages (imageIds) {
437
- this.imageList = imageIds
438
- },
439
- },
440
- computed: {
441
- // 用于进度条,进度显示控制
442
- // eslint-disable-next-line vue/return-in-computed-property
443
- step () {
444
- switch (this.details.status) {
445
- case 0:
446
- return 0
447
- case 1:
448
- return 1
449
- case 2:
450
- return 2
451
- case 3:
452
- return 3
453
- case 4:
454
- return 2
455
- }
456
- }
457
- }
458
- }
459
- </script>
460
-
461
- <style lang="less" scoped>
462
- .result-success{
463
- .action:not(:first-child){
464
- margin-left: 8px;
465
- }
466
- .project-name{
467
- font-size: 16px;
468
- color: @title-color;
469
- font-weight: 500;
470
- margin-bottom: 20px;
471
- }
472
- }
473
- .ticket-detail {
474
- width: 72%;
475
- margin: 0 auto;
476
- .item {
477
- margin-bottom: 14px;
478
- }
479
- .title {
480
- font-size: 14px;
481
- font-weight: 600;
482
- }
483
- }
484
- </style>
1
+ <template>
2
+ <a-card :bordered="false" class="result-success">
3
+ <result :description="description" :is-success="icon" :title="title">
4
+ <template slot="action">
5
+ <span v-if="countDown > 0" style="margin-right: 10px">{{ countDown }}</span>
6
+ <!-- <a-button type="primary" v-if="UrgentAvailable" :disabled="urgentAccess" style="margin-right: 20px" @click="urgent">请求加急处理</a-button> -->
7
+ <!-- <a-button type="danger" @click="closeBtn">撤销工单</a-button> -->
8
+ </template>
9
+ <a-modal
10
+ :visible="closeVisible"
11
+ :zIndex="1002"
12
+ title="关闭工单"
13
+ @cancel="handleCloseCancel"
14
+ @ok="handleCloseOk"
15
+ >
16
+ <p>是否确认手动关闭工单?</p>
17
+ <p style="color: red">(该操作不可撤销,请谨慎操作!)</p>
18
+ </a-modal>
19
+ <div>
20
+ <div class="project-name">工单处理进度</div>
21
+ <detail-list size="small" style="max-width: 800px; margin-bottom: 8px">
22
+ <detail-list-item term="工单编号">{{ serialNumber }}</detail-list-item>
23
+ <detail-list-item v-if="details.name" term="负责人">{{ details.name }}</detail-list-item>
24
+ <detail-list-item term="提交时间">{{ details.createdTime }}</detail-list-item>
25
+ </detail-list>
26
+ <a-steps :current="step" progressDot>
27
+ <a-step title="工单提交">
28
+ <a-step-item-group slot="description">
29
+ <a-step-item :title="details.uploader" />
30
+ <a-step-item :title="details.createdTime"/>
31
+ </a-step-item-group>
32
+ </a-step>
33
+ <a-step title="工单处理中" >
34
+ <a-step-item-group slot="description">
35
+ <a-step-item v-if="step >= 1" :title="details.phone ? `${details.name} (${details.phone})` : details.name" />
36
+ <a-step-item v-if="step >= 1" :title="details.confirmTime"/>
37
+ </a-step-item-group>
38
+ </a-step>
39
+ <a-step title="工单待确认" >
40
+ <a-step-item-group slot="description">
41
+ <a-step-item v-if="step >= 2" :title="`是否完成: ${verifyDetails.sfwc}`"/>
42
+ <a-step-item v-if="step >= 2" :title="`售后评价: ${verifyDetails.shpj}`"/>
43
+ <a-step-item v-if="step >= 2" :title="`反馈意见: ${verifyDetails.fkyj}`"/>
44
+ </a-step-item-group>
45
+ </a-step>
46
+ <a-step title="工单完成" >
47
+ <a-step-item-group slot="description">
48
+ <a-step-item v-if="step >= 3" :title="details.finishedTime"/>
49
+ </a-step-item-group>
50
+ </a-step>
51
+ </a-steps>
52
+ </div>
53
+ </result>
54
+ <div class="ticket-detail">
55
+ <a-tabs :default-active-key="tabActiveKey">
56
+ <a-tab-pane key="1" tab="工单问题">
57
+ <a-row class="item">
58
+ <a-col :span="3"><span class="title">问题描述</span></a-col>
59
+ <a-col :span="17"><span>{{ details.description }}</span></a-col>
60
+ </a-row>
61
+ <a-row class="item">
62
+ <a-col :span="3"><span class="title">问题截图</span></a-col>
63
+ <a-col :span="21"><image-item :images="details.images" :width="120" @preview="handleFilePreview" /></a-col>
64
+ </a-row>
65
+ <a-row v-if="details.files.length" class="item">
66
+ <a-col :span="3"><span class="title">附件</span></a-col>
67
+ <a-col :span="21"><file-item :files="details.files" :downloadable="false" @preview="handleFilePreview" /></a-col>
68
+ </a-row>
69
+ <a-row v-if="details.resultrecord" class="item">
70
+ <a-col :span="3"><span class="title">处理结果</span></a-col>
71
+ <a-col :span="17"><span>{{ details.resultrecord }}</span></a-col>
72
+ </a-row>
73
+ </a-tab-pane>
74
+ <a-tab-pane key="2" tab="工单确认" v-show="this.details.status === 4">
75
+ <a-row class="item">
76
+ <a-form :label-col="{ span: 5 }" :wrapper-col="{ span: 12 }">
77
+ <!-- 是否完成 -->
78
+ <a-form-item label="是否完成">
79
+ <a-select placeholder="请选择" v-model="customerSure.sfwc">
80
+ <a-select-option value="是">
81
+
82
+ </a-select-option>
83
+ <a-select-option value="否">
84
+
85
+ </a-select-option>
86
+ </a-select>
87
+ </a-form-item>
88
+ <!-- 退回原因 -->
89
+ <a-form-item label="退回截图" v-show="customerSure.sfwc === '否'">
90
+ <div class="clearfix">
91
+ <upload v-if="uploadVisible" :model="imageUploadModel" @setFiles="setImages" />
92
+ <a-modal
93
+ :footer="null"
94
+ :visible="previewVisible"
95
+ @cancel="handleCancel"
96
+ >
97
+ <img :src="previewImage" alt="图片上传" style="width: 100%"/>
98
+ </a-modal>
99
+ </div>
100
+ </a-form-item>
101
+ <!-- 退回原因 -->
102
+ <a-form-item label="退回原因" v-show="customerSure.sfwc === '否'">
103
+ <a-textarea placeholder="请输入退回原因" v-model="customerSure.thyy"></a-textarea>
104
+ </a-form-item>
105
+ <!-- 售后评价 -->
106
+ <a-form-item label="售后评价" v-show="customerSure.sfwc === '是'">
107
+ <a-select placeholder="请选择" v-model="customerSure.shpj">
108
+ <a-select-option value="满意">
109
+ 满意
110
+ </a-select-option>
111
+ <a-select-option value="不满意">
112
+ 不满意
113
+ </a-select-option>
114
+ </a-select>
115
+ </a-form-item>
116
+ <!-- 反馈意见 -->
117
+ <a-form-item label="反馈意见" v-show="customerSure.sfwc === '是'">
118
+ <a-textarea placeholder="请输入反馈意见" v-model="customerSure.fkyj"></a-textarea>
119
+ </a-form-item>
120
+ <!-- 表单底部按钮 -->
121
+ <a-form-item :wrapper-col="{ span: 12, offset: 5 }">
122
+ <a-button type="primary" @click="rollBack" :disabled="customerSure.sfwc === '是'" style="margin-right: 10px">
123
+ 退回
124
+ </a-button>
125
+ <a-button type="primary" @click="submit" :disabled="customerSure.sfwc === '否'">
126
+ 提交
127
+ </a-button>
128
+ </a-form-item>
129
+ </a-form>
130
+ </a-row>
131
+ </a-tab-pane>
132
+ </a-tabs>
133
+ </div>
134
+ <a-modal v-model="filePreviewVisible" :footer="null" :dialog-style="{ top: '30px' }" width="80%" :z-index="1001">
135
+ <file-preview :path="filePath" />
136
+ </a-modal>
137
+ </a-card>
138
+ </template>
139
+
140
+ <script>
141
+ import Result from '@vue2-client/components/result/Result'
142
+ import DetailList from '@vue2-client/components/tool/DetailList'
143
+ import AStepItem from '@vue2-client/components/tool/AStepItem'
144
+ import { TicketDetailsViewApi, post } from '@vue2-client/services/api'
145
+ import { formatDate } from '@vue2-client/utils/util'
146
+ import { FileItem, ImageItem } from '@vue2-client/components/FileImageItem'
147
+ import FilePreview from '@vue2-client/components/FilePreview'
148
+ import Upload from '@vue2-client/base-client/components/common/Upload'
149
+
150
+ const AStepItemGroup = AStepItem.Group
151
+ const DetailListItem = DetailList.Item
152
+ const fileUploadModel = JSON.parse('{"addOrEdit":"all","resUploadStock":1,"pathKey":"cs","rule":{"type":"string","required":"false"},"isOnlyAddOrEdit":true,"acceptCount":3,"type":"file","accept":["*"],"stockAlias":"webmeter","fileRootPath":"D:\\\\nginx-resource\\\\resource\\\\","name":"附件","resUploadMode":"server","model":"FilesId"}')
153
+ const imageUploadModel = JSON.parse('{"addOrEdit":"all","resUploadStock":1,"pathKey":"cs","rule":{"type":"string","required":"false"},"isOnlyAddOrEdit":true,"acceptCount":5,"type":"image","accept":[".jpg,.jpeg,.ico,.gif,svg,.webp,.png,.bmp,.pjpeg,"],"stockAlias":"webmeter","fileRootPath":"D:\\\\nginx-resource\\\\resource\\\\","name":"图片","resUploadMode":"server","model":"Images"}')
154
+
155
+ export default {
156
+ name: 'SubmitTicketSuccess',
157
+ components: { AStepItemGroup, AStepItem, DetailListItem, DetailList, Result, FileItem, ImageItem, FilePreview, Upload },
158
+ props: {
159
+ // 工单序列号
160
+ serialNumber: {
161
+ type: String,
162
+ required: true
163
+ }
164
+ },
165
+ data () {
166
+ return {
167
+ fileUploadModel,
168
+ imageUploadModel,
169
+ title: '提交成功',
170
+ description: '您创建的工单已成功提交,请保持电话畅通,我们的工作人员将尽快与您取得联系。', // +
171
+ // '如果需要加急,请在倒计时结束后点击加急按钮,加急后我们将优先处理您的工单',
172
+ // 工单详情
173
+ details: {
174
+ uploader: '',
175
+ status: 0,
176
+ name: '',
177
+ phone: '',
178
+ createdTime: '',
179
+ confirmTime: '',
180
+ finishedTime: '',
181
+ description: '',
182
+ resultrecord: '',
183
+ files: [],
184
+ images: []
185
+ },
186
+ // 控制加急按钮
187
+ urgentAccess: true,
188
+ // 倒计时
189
+ countDown: 0,
190
+ // 控制加急按钮显示
191
+ UrgentAvailable: true,
192
+ // 取消工单确认框可见性
193
+ closeVisible: false,
194
+ // 控制页面大图标
195
+ icon: true,
196
+ // 文件预览
197
+ filePreviewVisible: false,
198
+ filePath: '',
199
+ tabActiveKey: '1',
200
+ customerSure: {
201
+ shpj: '满意',
202
+ fkyj: undefined,
203
+ sfwc: '是',
204
+ thyy: ''
205
+ },
206
+ // 工单id
207
+ applyId: 0,
208
+ // 工单步骤
209
+ stepId: 0,
210
+ // 确认详情
211
+ verifyDetails: {
212
+ shpj: '',
213
+ sfwc: '',
214
+ fkyj: ''
215
+ },
216
+ uploadVisible: true,
217
+ // 控制预览显示
218
+ previewVisible: false,
219
+ // 图片真实地址
220
+ previewImage: '',
221
+ imageList: []
222
+ }
223
+ },
224
+ mounted () {
225
+ this.getTicketDetail()
226
+ },
227
+ methods: {
228
+ format (date, format) {
229
+ return formatDate(date, format)
230
+ },
231
+ // 关闭工单确认后操作
232
+ handleCloseOk () {
233
+ return post(TicketDetailsViewApi.manualCloseTicketByCustomer, {
234
+ serialNumber: this.serialNumber,
235
+ time: new Date()
236
+ })
237
+ .then(res => {
238
+ this.closeVisible = false
239
+ this.title = '工单已关闭'
240
+ this.description = ''
241
+ this.icon = false
242
+ }, err => {
243
+ console.error(err)
244
+ })
245
+ },
246
+ // 关闭工单取消后业务逻辑
247
+ handleCloseCancel () {
248
+ this.closeVisible = false
249
+ },
250
+ // 关闭工单按钮
251
+ closeBtn () {
252
+ this.closeVisible = true
253
+ },
254
+ // 对工单进行加急处理
255
+ urgent () {
256
+ return post(TicketDetailsViewApi.rushTicket, {
257
+ serialNumber: this.serialNumber
258
+ })
259
+ .then(res => {
260
+ if (res.data === 1) {
261
+ this.$message.success(
262
+ '操作成功',
263
+ 5
264
+ )
265
+ this.description = '您的工单已经被加急处理,我们的工作人员会优先处理您的请求。'
266
+ this.UrgentAvailable = false
267
+ } else {
268
+ this.$message.error(
269
+ '操作失败',
270
+ 5
271
+ )
272
+ }
273
+ }, err => {
274
+ console.log(err)
275
+ })
276
+ },
277
+ // 获取工单详情
278
+ getTicketDetail () {
279
+ return post(TicketDetailsViewApi.getTicketDetailsForUploader, {
280
+ serialNumber: this.serialNumber
281
+ })
282
+ .then(res => {
283
+ this.stepId = res.stepId
284
+ this.applyId = res.apply_id
285
+ this.details.uploader = res.uploader
286
+ // 判断负责人有没有值
287
+ if (res.name === undefined) {
288
+ this.details.name = ''
289
+ } else {
290
+ this.details.name = res.name
291
+ }
292
+ // 判断工单被确认时间
293
+ if (res.confirmtime === undefined) {
294
+ this.details.confirmTime = ''
295
+ } else {
296
+ this.details.confirmTime = this.format(res.confirmtime, 'yyyy-MM-dd hh:mm:ss')
297
+ }
298
+ // 判断工单完成时间
299
+ if (res.finishedtime === undefined) {
300
+ this.details.finishedTime = ''
301
+ } else {
302
+ this.details.finishedTime = this.format(res.finishedtime, 'yyyy-MM-dd hh:mm:ss')
303
+ }
304
+ this.details.createdTime = this.format(res.createdtime, 'yyyy-MM-dd hh:mm:ss')
305
+ this.details.status = res.status
306
+ this.details.phone = res.phone
307
+ this.details.description = res.description
308
+ this.details.files = res.files
309
+ this.details.images = res.images
310
+ this.details.resultrecord = res.resultrecord
311
+ // 如果工单已经关闭, 获取用户确认信息
312
+ if (res.status === 3) {
313
+ post(TicketDetailsViewApi.getApplyCompletedStepData, {
314
+ applyId: this.applyId,
315
+ stepId: this.stepId
316
+ }).then(res => {
317
+ if (res.data) {
318
+ this.verifyDetails.fkyj = res.data.fkyj ? res.data.fkyj : '无'
319
+ this.verifyDetails.shpj = res.data.shpj ? res.data.shpj : '满意'
320
+ this.verifyDetails.sfwc = res.data.sfwc ? res.data.sfwc : '是'
321
+ }
322
+ })
323
+ }
324
+ }, err => {
325
+ console.log(err)
326
+ })
327
+ },
328
+ handleFilePreview (path) {
329
+ this.filePath = path
330
+ this.filePreviewVisible = true
331
+ },
332
+ // 用户确认提交
333
+ submit () {
334
+ return post(TicketDetailsViewApi.afterApplyFinalStepSubmit, {
335
+ applyId: this.applyId
336
+ })
337
+ .then(
338
+ res => {
339
+ this.onSubmit()
340
+ this.saveWorkflowLog('确认完工', '最后一步: 客户确认', { notes: '' })
341
+ this.$message.success('已完工!')
342
+ // 修改工单状态为 3(已关闭)
343
+ post(TicketDetailsViewApi.clientSubmit, {
344
+ status: 3,
345
+ serial_number: this.serialNumber
346
+ }).then(res => {
347
+ console.log('res', res)
348
+ })
349
+ this.getTicketDetail()
350
+ this.$emit('afterSubmit')
351
+ },
352
+ err => {
353
+ this.$message.error('提交失败!')
354
+ console.log(err)
355
+ }
356
+ )
357
+ },
358
+ // 回退
359
+ rollBack () {
360
+ if (this.customerSure.thyy === '') {
361
+ this.$message.warn('请填写退回原因')
362
+ return
363
+ }
364
+ const notes = this.customerSure.thyy
365
+ return post(TicketDetailsViewApi.updateApplySubState, {
366
+ stepId: this.stepId - 1,
367
+ applyId: this.applyId
368
+ }).then(
369
+ res => {
370
+ this.saveWorkflowLog('退回', `第${this.stepId}步: 客户确认 ---> 第${this.stepId - 1}步: 售后确认`, { notes })
371
+ this.$message.success('退回成功')
372
+ // 修改工单状态为 1(待处理)
373
+ post(TicketDetailsViewApi.clientSubmit, {
374
+ status: 1,
375
+ serial_number: this.serialNumber,
376
+ Images: this.imageList,
377
+ applyId: this.applyId
378
+ }).then(res => {
379
+ console.log('res', res)
380
+ })
381
+ this.uploadVisible = false
382
+ this.getTicketDetail()
383
+ this.$emit('afterSubmit')
384
+ },
385
+ err => {
386
+ this.$message.error('退回失败!')
387
+ console.log(err)
388
+ }
389
+ )
390
+ },
391
+ // 保存工作流日志
392
+ saveWorkflowLog (operation, desc, extra) {
393
+ post(TicketDetailsViewApi.saveApplyWorkflowLog, {
394
+ applyId: this.applyId,
395
+ operation,
396
+ desc,
397
+ operator: '客户确认',
398
+ notes: '客户确认',
399
+ setHandler: '客户确认',
400
+ setDeadline: '',
401
+ ...extra
402
+ })
403
+ },
404
+ //
405
+ onSubmit () {
406
+ const time = this.format(new Date(), 'yyyy-MM-dd hh:mm:ss')
407
+ const form = {
408
+ shpj: this.customerSure.shpj,
409
+ fkyj: this.customerSure.fkyj,
410
+ sfwc: this.customerSure.sfwc
411
+ }
412
+ return post(TicketDetailsViewApi.saveApplyStepFormData, {
413
+ applyId: this.applyId,
414
+ stepId: this.stepId,
415
+ form: form,
416
+ data: time,
417
+ handler: '客户确认',
418
+ note: ''
419
+ })
420
+ .then(
421
+ res => {
422
+ console.log('表单提交成功')
423
+ this.note = ''
424
+ this.showForm = false
425
+ this.stepDone = true
426
+ },
427
+ err => {
428
+ this.$message.error('保存失败,请检查后重试')
429
+ console.log(err)
430
+ }
431
+ )
432
+ },
433
+ handleCancel () {
434
+ this.previewVisible = false
435
+ },
436
+ setImages (imageIds) {
437
+ this.imageList = imageIds
438
+ },
439
+ },
440
+ computed: {
441
+ // 用于进度条,进度显示控制
442
+ // eslint-disable-next-line vue/return-in-computed-property
443
+ step () {
444
+ switch (this.details.status) {
445
+ case 0:
446
+ return 0
447
+ case 1:
448
+ return 1
449
+ case 2:
450
+ return 2
451
+ case 3:
452
+ return 3
453
+ case 4:
454
+ return 2
455
+ }
456
+ }
457
+ }
458
+ }
459
+ </script>
460
+
461
+ <style lang="less" scoped>
462
+ .result-success{
463
+ .action:not(:first-child){
464
+ margin-left: 8px;
465
+ }
466
+ .project-name{
467
+ font-size: 16px;
468
+ color: @title-color;
469
+ font-weight: 500;
470
+ margin-bottom: 20px;
471
+ }
472
+ }
473
+ .ticket-detail {
474
+ width: 72%;
475
+ margin: 0 auto;
476
+ .item {
477
+ margin-bottom: 14px;
478
+ }
479
+ .title {
480
+ font-size: 14px;
481
+ font-weight: 600;
482
+ }
483
+ }
484
+ </style>