vue2-client 1.16.90 → 1.16.93

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 (329) hide show
  1. package/.claude/settings.local.json +20 -20
  2. package/.cursorrules +19 -19
  3. package/.env.apply +19 -19
  4. package/.env.gaslink +19 -19
  5. package/.env.his +19 -19
  6. package/.env.liuli +20 -20
  7. package/.env.scada +19 -19
  8. package/.eslintrc.js +90 -90
  9. package/CHANGELOG.md +830 -830
  10. package/CLAUDE.md +97 -97
  11. package/Components.md +60 -60
  12. package/docs/LowCode/lowcode.md +155 -155
  13. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  14. package/docs/index.md +30 -30
  15. package/index.js +31 -31
  16. package/jest-transform-stub.js +8 -8
  17. package/jest.setup.js +7 -7
  18. package/jsconfig.json +19 -19
  19. package/package.json +1 -1
  20. package/public/his/editor/editor.html +51 -51
  21. package/public/his/editor/mock/bind_data.html +779 -779
  22. package/public/his/editor/mock/data_table.html +40 -40
  23. package/public/his/editor/mock/sign.html +75 -75
  24. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  25. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  26. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  27. package/public/his/editor/vender/date97/calendar.js +4 -4
  28. package/public/his/editor/vender/date97/lang/en.js +13 -13
  29. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  30. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  31. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  32. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  33. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  34. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  35. package/public/his/editor/vender/diff.js +1627 -1627
  36. package/public/his/editor/vender/editor.js +1 -1
  37. package/public/his/editor/vender/fabric.js +31187 -31187
  38. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  39. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  40. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  41. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  42. package/public/his/editor/vender/mui/mui.min.css +4 -4
  43. package/public/his/editor/vender/mui/mui.min.js +5 -5
  44. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  45. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  46. package/public/his/editor/vender/qrcode.js +7 -7
  47. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  48. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  49. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  50. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  51. package/public/his/editor/vender/validator.js +5094 -5094
  52. package/public/his/editor/vender/weui/weui.css +5659 -5659
  53. package/public/his/editor/vender/weui/weui.min.css +4 -4
  54. package/public/his/editor/vender/weui/weui.min.js +11 -11
  55. package/src/assets/img/querySlotDemo.svg +15 -15
  56. package/src/assets/svg/badtwo.svg +1 -1
  57. package/src/assets/svg/goodtwo.svg +1 -1
  58. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  59. package/src/base-client/components/AI/demo.vue +31 -31
  60. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  61. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  62. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  63. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  64. package/src/base-client/components/common/CitySelect/index.js +3 -3
  65. package/src/base-client/components/common/CitySelect/index.md +109 -109
  66. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  67. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  68. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  69. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  70. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  71. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  72. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  73. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  74. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  75. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  76. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  77. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  78. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  79. package/src/base-client/components/common/HIS/HButtons/HButtons.vue +1 -0
  80. package/src/base-client/components/common/HIS/demo.vue +61 -61
  81. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  82. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  83. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  84. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  85. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  86. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  87. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  88. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  89. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  90. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  92. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  93. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  94. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  95. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  96. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  97. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  98. package/src/base-client/components/common/Recording/index.js +3 -3
  99. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  100. package/src/base-client/components/common/Tree/index.js +2 -2
  101. package/src/base-client/components/common/Upload/Upload.vue +334 -334
  102. package/src/base-client/components/common/Upload/index.js +3 -3
  103. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  104. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  105. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +304 -304
  106. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  107. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  108. package/src/base-client/components/common/XAddReport/index.js +3 -3
  109. package/src/base-client/components/common/XAddReport/index.md +56 -56
  110. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  111. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  112. package/src/base-client/components/common/XButtons/index.js +3 -3
  113. package/src/base-client/components/common/XButtons/index.md +61 -61
  114. package/src/base-client/components/common/XCalendar/XCalendar.vue +4 -4
  115. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  116. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  117. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  118. package/src/base-client/components/common/XDataCard/index.js +3 -3
  119. package/src/base-client/components/common/XDataCard/index.md +1 -1
  120. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  121. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  122. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  123. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  124. package/src/base-client/components/common/XDatePicker/index.vue +8 -4
  125. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  126. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  127. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  128. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  129. package/src/base-client/components/common/XForm/XFormItem.vue +2 -1
  130. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  131. package/src/base-client/components/common/XForm/index.md +178 -178
  132. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  133. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  134. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  135. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  136. package/src/base-client/components/common/XFormTable/demo.vue +1 -1
  137. package/src/base-client/components/common/XFormTable/index.md +92 -92
  138. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  139. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  140. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  141. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  142. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  143. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  144. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  145. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  146. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  147. package/src/base-client/components/common/XPrint/index.vue +97 -97
  148. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  149. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  150. package/src/base-client/components/common/XReport/index.js +3 -3
  151. package/src/base-client/components/common/XReport/print.js +186 -186
  152. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  153. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  154. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  155. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  156. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  157. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  158. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  159. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  160. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  161. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  162. package/src/base-client/components/common/XStepView/index.js +3 -3
  163. package/src/base-client/components/common/XStepView/index.md +31 -31
  164. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  165. package/src/base-client/components/common/XTab/index.js +3 -3
  166. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  167. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  168. package/src/base-client/components/common/XTable/index.md +255 -255
  169. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  170. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  171. package/src/base-client/components/common/XTree/index.js +3 -3
  172. package/src/base-client/components/common/XTree/index.md +36 -36
  173. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  174. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  175. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  176. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  177. package/src/base-client/components/his/XCharge/XChargeDemo.vue +145 -145
  178. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  179. package/src/base-client/components/his/XImportExcelButton/XFrontImportExcel.vue +36 -11
  180. package/src/base-client/components/index.js +51 -51
  181. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  182. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  183. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  184. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  185. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  186. package/src/base-client/plugins/Config.js +19 -19
  187. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  188. package/src/base-client/plugins/Recording.js +258 -258
  189. package/src/base-client/plugins/index.js +23 -23
  190. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  191. package/src/components/Charts/Bar.vue +62 -62
  192. package/src/components/Charts/ChartCard.vue +134 -134
  193. package/src/components/Charts/Liquid.vue +67 -67
  194. package/src/components/Charts/MiniArea.vue +39 -39
  195. package/src/components/Charts/MiniBar.vue +39 -39
  196. package/src/components/Charts/MiniProgress.vue +75 -75
  197. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  198. package/src/components/Charts/Radar.vue +68 -68
  199. package/src/components/Charts/RankList.vue +77 -77
  200. package/src/components/Charts/TagCloud.vue +113 -113
  201. package/src/components/Charts/TransferBar.vue +64 -64
  202. package/src/components/Charts/Trend.vue +82 -82
  203. package/src/components/Charts/chart.less +12 -12
  204. package/src/components/Charts/smooth.area.less +13 -13
  205. package/src/components/CodeMirror/inedx.vue +118 -118
  206. package/src/components/CodeMirror/setting.js +40 -40
  207. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  208. package/src/components/NumberInfo/index.js +3 -3
  209. package/src/components/NumberInfo/index.less +54 -54
  210. package/src/components/NumberInfo/index.md +43 -43
  211. package/src/components/card/ChartCard.vue +79 -79
  212. package/src/components/chart/Bar.vue +60 -60
  213. package/src/components/chart/MiniArea.vue +67 -67
  214. package/src/components/chart/MiniBar.vue +59 -59
  215. package/src/components/chart/MiniProgress.vue +57 -57
  216. package/src/components/chart/Radar.vue +80 -80
  217. package/src/components/chart/RankingList.vue +60 -60
  218. package/src/components/chart/Trend.vue +79 -79
  219. package/src/components/chart/index.less +9 -9
  220. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  221. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  222. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  223. package/src/components/checkbox/index.js +9 -9
  224. package/src/components/exception/ExceptionPage.vue +70 -70
  225. package/src/components/g2Charts/constants.js +202 -202
  226. package/src/components/g2Charts/demo.vue +808 -808
  227. package/src/components/g2Charts/designer.vue +228 -228
  228. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  229. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  230. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  231. package/src/components/g2Charts/index.vue +397 -397
  232. package/src/components/index.js +36 -36
  233. package/src/components/input/IInput.vue +66 -66
  234. package/src/components/menu/SideMenu.vue +75 -75
  235. package/src/components/menu/menu.js +273 -273
  236. package/src/components/setting/Setting.vue +234 -234
  237. package/src/components/tool/AStepItem.vue +60 -60
  238. package/src/config/CreateQueryConfig.js +325 -325
  239. package/src/config/default/antd.config.js +89 -89
  240. package/src/config/default/setting.config.js +55 -55
  241. package/src/font-style/font.css +60 -60
  242. package/src/layouts/CommonLayout.vue +56 -56
  243. package/src/layouts/PageLayout.vue +151 -151
  244. package/src/layouts/SinglePageView.vue +136 -136
  245. package/src/layouts/header/AdminHeader.vue +132 -132
  246. package/src/layouts/header/HeaderNotice.vue +177 -177
  247. package/src/layouts/header/InstitutionDetail.vue +181 -181
  248. package/src/layouts/tabs/TabsHead.vue +189 -189
  249. package/src/lib.js +1 -1
  250. package/src/mock/extend/index.js +84 -84
  251. package/src/mock/goods/index.js +108 -108
  252. package/src/pages/DefaultExample/index.vue +77 -77
  253. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  254. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  255. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  256. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  257. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  258. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  259. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  260. package/src/pages/DynamicStatistics/index.vue +282 -282
  261. package/src/pages/Example/childIndex.vue +15 -15
  262. package/src/pages/Example/index.vue +30 -30
  263. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  264. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  265. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  266. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  267. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  268. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  269. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  270. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  271. package/src/pages/Recording/index.vue +77 -77
  272. package/src/pages/ServiceReview/index.vue +284 -284
  273. package/src/pages/SubExample/index.vue +26 -26
  274. package/src/pages/WorkflowDetail/WorkFlowDemo3.vue +203 -203
  275. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  276. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +3 -1
  277. package/src/pages/XReportView/index.vue +64 -64
  278. package/src/pages/XTreeOneProExample/index.vue +67 -67
  279. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  280. package/src/pages/login/Login.vue +379 -379
  281. package/src/pages/login/LoginV3.vue +389 -389
  282. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  283. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  284. package/src/pages/report/ReportTable.js +124 -124
  285. package/src/pages/resourceManage/orgListManage.vue +98 -98
  286. package/src/pages/system/dictionary/index.vue +44 -44
  287. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  288. package/src/pages/system/monitor/operLog/index.vue +37 -37
  289. package/src/pages/system/settings/modifyPassword.vue +117 -117
  290. package/src/pages/system/ticket/index.vue +480 -480
  291. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  292. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  293. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  294. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  295. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  296. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  297. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  298. package/src/pages/userInfoDetailManage/uploadFilesHistory/index.vue +33 -3
  299. package/src/plugins/EventLogPlugin.js +33 -33
  300. package/src/plugins/FindParentsData.js +17 -17
  301. package/src/services/DataModel.js +30 -30
  302. package/src/services/LodopFuncs.js +137 -137
  303. package/src/services/api/TicketDetailsViewApi.js +46 -46
  304. package/src/services/api/cas.js +79 -79
  305. package/src/services/api/entity.js +18 -18
  306. package/src/services/api/index.js +17 -17
  307. package/src/store/modules/account.js +115 -115
  308. package/src/store/modules/index.js +5 -5
  309. package/src/store/modules/lowCode.js +33 -33
  310. package/src/store/modules/setting.js +119 -119
  311. package/src/theme/default/style.less +58 -58
  312. package/src/utils/authority-utils.js +85 -85
  313. package/src/utils/errorCode.js +6 -6
  314. package/src/utils/formatter.js +74 -74
  315. package/src/utils/htmlToPDF.js +108 -108
  316. package/src/utils/htmlToPDFApi.js +5 -5
  317. package/src/utils/login.js +188 -188
  318. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  319. package/src/utils/lowcode/lowcodeLog.js +29 -29
  320. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  321. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  322. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  323. package/src/utils/map-utils.js +47 -47
  324. package/src/utils/reg.js +95 -95
  325. package/src/utils/runEvalFunction.js +14 -14
  326. package/src/utils/theme-color-replacer-extend.js +92 -92
  327. package/src/utils/util.js +329 -329
  328. package/src/utils/waterMark.js +31 -31
  329. 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>