index.vue 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380
  1. <template>
  2. <view class="mainBox">
  3. <uni-nav-bar background-color="#157A2C" color="#fff" fixed="true" statusBar="true" left-icon="back" title="售后工单"
  4. @clickLeft="back">
  5. </uni-nav-bar>
  6. <view class="top-wrapper">
  7. <uni-section>
  8. <uni-easyinput prefixIcon="search" style="width: 460rpx" v-model="searchVal" placeholder="名称">
  9. </uni-easyinput>
  10. </uni-section>
  11. <button class="search_btn" @click="doSearch">搜索</button>
  12. <image class="menu_icon" src="~@/static/pda/menu.svg"></image>
  13. </view>
  14. <view class="">
  15. <view class="tab_box rx-sc">
  16. <view class="tab_item" v-for="(item,index) in tabList" :key="index"
  17. :class="{active: pickTabIndex == item.value}">
  18. <view @click="changeChartsTab(item.value)">
  19. {{item.label}}
  20. </view>
  21. </view>
  22. </view>
  23. </view>
  24. <view class="wrapper">
  25. <u-list @scrolltolower="scrolltolower" class="listContent">
  26. <view v-for="(item, index) in tableList" :key="index" style="position: relative;">
  27. <myCard @del="del(item)" @edit="edit('edit',item.id)" @details="edit('view',item.id)" :item="item"
  28. :index="index+1" :columns="columns" :btnList="btnList">
  29. </myCard>
  30. </view>
  31. </u-list>
  32. </view>
  33. <u-toast ref="uToast"></u-toast>
  34. </view>
  35. </template>
  36. <script>
  37. import {
  38. getSalesWorkOrder,
  39. } from '@/api/salesServiceManagement/workOrder/index.js'
  40. import myCard from '@/pages/saleManage/components/myCard.vue'
  41. export default {
  42. components: {
  43. myCard,
  44. },
  45. data() {
  46. return {
  47. tabList: [{
  48. value: 'all',
  49. label: '全部',
  50. },
  51. {
  52. value: '0',
  53. label: '待执行',
  54. },
  55. {
  56. value: '1',
  57. label: '执行中',
  58. },
  59. {
  60. value: '3',
  61. label: '待验收',
  62. },
  63. {
  64. value: '5',
  65. label: '已完成',
  66. },
  67. ],
  68. workOrderStatus: [
  69. // { code: 0, label: '待接收' },
  70. {
  71. code: 0,
  72. label: '待执行'
  73. },
  74. {
  75. code: 1,
  76. label: '已接收'
  77. },
  78. {
  79. code: 2,
  80. label: '执行中'
  81. },
  82. {
  83. code: 3,
  84. label: '待验收'
  85. },
  86. {
  87. code: 4,
  88. label: '待评价'
  89. },
  90. {
  91. code: 5,
  92. label: '已完成'
  93. },
  94. {
  95. code: 6,
  96. label: '验收不通过'
  97. }
  98. ],
  99. pickTabIndex: 'all',
  100. searchVal: '',
  101. isEnd: false,
  102. page: 1,
  103. size: 10,
  104. tableList: [],
  105. columns: [
  106. [{
  107. label: '工单编号:',
  108. prop: 'code',
  109. type: 'title',
  110. className: 'perce100',
  111. }],
  112. [{
  113. label: '计划单号:',
  114. prop: 'planCode'
  115. }, ],
  116. [{
  117. label: '计划名称:',
  118. prop: 'planName',
  119. }],
  120. [{
  121. label: '报工人:',
  122. prop: 'executeUserName'
  123. }, {
  124. label: '验收人:',
  125. prop: 'accepterUserName',
  126. }],
  127. [{
  128. label: '故障等级:',
  129. prop: 'faultLevel'
  130. }, {
  131. label: '客户名称:',
  132. prop: 'contactName',
  133. }],
  134. [{
  135. label: '设备名称:',
  136. prop: 'categoryName',
  137. formatter: (row) => {
  138. if (!row.deviceDetails) return '';
  139. let str = '';
  140. row.deviceDetails.map((el, idx) => {
  141. if (idx + 1 == row.deviceDetails.length) {
  142. str += el.categoryName;
  143. } else {
  144. str = str + '' + el.categoryName + ',';
  145. }
  146. });
  147. return str;
  148. }
  149. }],
  150. [{
  151. label: '验收时间:',
  152. prop: 'accepterTime'
  153. }, {
  154. label: '开始时间:',
  155. prop: 'acceptTime',
  156. }],
  157. [{
  158. label: '结束时间:',
  159. prop: 'finishTime'
  160. }, {
  161. label: '计划完成时间:',
  162. prop: 'planFinishTime',
  163. }],
  164. [{
  165. label: '实际售后时长:',
  166. prop: 'inFactDuration',
  167. formatter: (row) => {
  168. if (row.inFactDuration || row.inFactDuration == 0) {
  169. let str = ((row.inFactDuration - 0) / 60).toFixed(1);
  170. return str + ' 小时';
  171. }
  172. }
  173. }, {
  174. label: '状态:',
  175. prop: 'orderStatus',
  176. formatter: (row) => {
  177. return this.workOrderStatus.find(
  178. (item) => item.code == row.orderStatus
  179. )?.label;
  180. }
  181. }],
  182. [{
  183. label: '操作:',
  184. prop: 'action',
  185. type: 'action',
  186. className: 'perce100',
  187. }],
  188. ],
  189. btnList: [{
  190. name: '详情',
  191. apiName: 'details',
  192. btnType: 'primary',
  193. type: '2',
  194. pageUrl: '',
  195. }, {
  196. name: '修改',
  197. apiName: 'edit',
  198. btnType: 'primary',
  199. type: '2',
  200. pageUrl: '',
  201. judge: [{
  202. authorities: '',
  203. }, {
  204. key: 'orderStatus',
  205. value: [1, 6],
  206. }],
  207. },
  208. {
  209. name: '报工',
  210. apiName: 'edit',
  211. btnType: 'error ',
  212. type: '2',
  213. pageUrl: '',
  214. judge: [{
  215. authorities: '',
  216. }, {
  217. key: 'planStatus',
  218. value: [0, 4, 5],
  219. }],
  220. }, {
  221. name: '转派',
  222. apiName: 'handleAudit',
  223. btnType: 'primary',
  224. type: '2',
  225. pageUrl: '',
  226. judge: [{
  227. authorities: '',
  228. }, {
  229. key: 'planStatus',
  230. value: [0, 4, 5],
  231. }],
  232. },
  233. {
  234. name: '申请配件',
  235. apiName: 'handleAudit',
  236. btnType: 'primary',
  237. type: '2',
  238. pageUrl: '',
  239. judge: [{
  240. authorities: '',
  241. }, {
  242. key: 'planStatus',
  243. value: [1],
  244. }],
  245. },
  246. ],
  247. }
  248. },
  249. computed: {
  250. },
  251. onShow() {
  252. this.isEnd = false
  253. this.page = 1
  254. this.getList()
  255. },
  256. methods: {
  257. changeChartsTab(value) {
  258. this.pickTabIndex = value;
  259. this.doSearch();
  260. },
  261. doSearch() {
  262. this.isEnd = false
  263. this.page = 1
  264. this.getList()
  265. },
  266. //获取列表信息
  267. getList() {
  268. if (this.isEnd) {
  269. return
  270. }
  271. uni.showLoading({
  272. title: '加载中'
  273. })
  274. let data = {
  275. pageNum: this.page,
  276. size: this.size,
  277. }
  278. if (this.pickTabIndex != 'all') {
  279. data.orderStatus = this.pickTabIndex;
  280. }
  281. getSalesWorkOrder(data).then(res => {
  282. if (this.page === 1) {
  283. this.tableList = res.list
  284. } else {
  285. this.tableList.push(...res.list)
  286. }
  287. this.page += 1
  288. this.isEnd = this.tableList.length >= res.count;
  289. uni.hideLoading();
  290. }).catch((e) => {
  291. uni.hideLoading()
  292. })
  293. },
  294. scrolltolower() {
  295. if (this.isEnd) {
  296. return
  297. }
  298. this.getList();
  299. },
  300. del(item) {
  301. },
  302. edit(type, id) {
  303. console.log(type,'type');
  304. uni.navigateTo({
  305. url: `/pages/salesServiceManagement/workOrder/components/editPlan?type=${type}&id=${id}`
  306. })
  307. }
  308. }
  309. }
  310. </script>
  311. <style lang="scss" scoped>
  312. .top-wrapper {
  313. background-color: #fff;
  314. display: flex;
  315. width: 750rpx;
  316. height: 88rpx;
  317. padding: 16rpx 32rpx;
  318. align-items: center;
  319. gap: 16rpx;
  320. /deep/.uni-section {
  321. margin-top: 0px;
  322. }
  323. /deep/.uni-section-header {
  324. padding: 0px;
  325. }
  326. .search_btn {
  327. width: 120rpx;
  328. height: 70rpx;
  329. line-height: 70rpx;
  330. padding: 0 24rpx;
  331. background: $theme-color;
  332. font-size: 32rpx;
  333. color: #fff;
  334. margin: 0;
  335. margin-left: 26rpx;
  336. }
  337. .menu_icon {
  338. width: 44rpx;
  339. height: 44rpx;
  340. margin-left: 14rpx;
  341. }
  342. }
  343. .tab_box {
  344. width: 100%;
  345. height: 68rpx;
  346. border-bottom: 1rpx solid #E1E1E1;
  347. .tab_item {
  348. height: 68rpx;
  349. line-height: 68rpx;
  350. padding: 0 20rpx;
  351. font-size: 32rpx;
  352. color: #979C9E;
  353. }
  354. .active {
  355. box-sizing: border-box;
  356. border-bottom: 6rpx solid $theme-color;
  357. color: $theme-color;
  358. }
  359. }
  360. </style>