index.vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="100px">
  4. <el-form-item label="小程序" prop="appid">
  5. <el-select
  6. v-model="queryParams.appid"
  7. placeholder="请选择小程序"
  8. clearable
  9. filterable
  10. size="small"
  11. style="width: 200px"
  12. >
  13. <el-option
  14. v-for="item in appOptions"
  15. :key="item.appid"
  16. :label="item.name"
  17. :value="item.appid"
  18. />
  19. </el-select>
  20. </el-form-item>
  21. <el-form-item label="上传状态" prop="status">
  22. <el-select v-model="queryParams.status" placeholder="请选择上传状态" clearable size="small">
  23. <el-option label="待执行" value="0" />
  24. <el-option label="执行中" value="1" />
  25. <el-option label="执行成功" value="2" />
  26. <el-option label="执行失败" value="3" />
  27. <el-option label="已取消" value="4" />
  28. </el-select>
  29. </el-form-item>
  30. <el-form-item label="订单号" prop="orderCode">
  31. <el-input
  32. v-model="queryParams.orderCode"
  33. placeholder="请输入订单号"
  34. clearable
  35. size="small"
  36. @keyup.enter.native="handleQuery"
  37. />
  38. </el-form-item>
  39. <el-form-item>
  40. <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
  41. <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
  42. </el-form-item>
  43. </el-form>
  44. <el-table v-loading="loading" :data="wxExpressTaskList">
  45. <el-table-column label="ID" align="center" prop="id" width="80" />
  46. <el-table-column label="订单号" align="center" prop="orderCode" width="180" />
  47. <el-table-column label="用户ID" align="center" prop="userId" width="100" />
  48. <el-table-column label="数据" align="center" prop="data" width="200" show-overflow-tooltip />
  49. <el-table-column label="任务状态" align="center" prop="status" width="120">
  50. <template slot-scope="scope">
  51. <el-tag v-if="scope.row.status === 0" type="info">待执行</el-tag>
  52. <el-tag v-else-if="scope.row.status === 1" type="warning">执行中</el-tag>
  53. <el-tag v-else-if="scope.row.status === 2" type="success">执行成功</el-tag>
  54. <el-tag v-else-if="scope.row.status === 3" type="danger">执行失败</el-tag>
  55. <el-tag v-else-if="scope.row.status === 4" type="info">已取消</el-tag>
  56. </template>
  57. </el-table-column>
  58. <el-table-column label="重试次数" align="center" prop="retryCount" width="100" />
  59. <el-table-column label="请求体" align="center" prop="requestBody" width="200" show-overflow-tooltip />
  60. <el-table-column label="响应体" align="center" prop="responseBody" width="200" show-overflow-tooltip />
  61. <el-table-column label="创建时间" align="center" prop="createTime" width="180">
  62. <template slot-scope="scope">
  63. <span>{{ parseTime(scope.row.createTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
  64. </template>
  65. </el-table-column>
  66. <el-table-column label="快递公司" align="center" prop="expressCompany" width="120" />
  67. <el-table-column label="快递单号" align="center" prop="expressNo" width="150" />
  68. <el-table-column label="订单类型" align="center" prop="type" width="120">
  69. <template slot-scope="scope">
  70. <span v-if="scope.row.type === 0">商城订单</span>
  71. <span v-else-if="scope.row.type === 1">直播订单</span>
  72. <span v-else>-</span>
  73. </template>
  74. </el-table-column>
  75. <el-table-column label="小程序ID" align="center" prop="appid" width="180" />
  76. </el-table>
  77. <pagination
  78. v-show="total > 0"
  79. :total="total"
  80. :page.sync="queryParams.pageNum"
  81. :limit.sync="queryParams.pageSize"
  82. @pagination="getList"
  83. />
  84. </div>
  85. </template>
  86. <script>
  87. import { list } from "@/api/live/wxExpressTask";
  88. import { list as listAppConfig } from "@/api/course/coursePlaySourceConfig";
  89. export default {
  90. name: "WxExpressTask",
  91. data() {
  92. return {
  93. loading: true,
  94. showSearch: true,
  95. wxExpressTaskList: [],
  96. total: 0,
  97. appOptions: [],
  98. queryParams: {
  99. pageNum: 1,
  100. pageSize: 10,
  101. appid: null,
  102. status: null,
  103. orderCode: null
  104. }
  105. };
  106. },
  107. created() {
  108. this.getList();
  109. this.getAppList();
  110. },
  111. methods: {
  112. /** 查询微信快递任务列表 */
  113. getList() {
  114. this.loading = true;
  115. list(this.queryParams).then(response => {
  116. this.wxExpressTaskList = response.rows;
  117. this.total = response.total;
  118. this.loading = false;
  119. });
  120. },
  121. /** 获取小程序列表 */
  122. getAppList() {
  123. listAppConfig({ pageNum: 1, pageSize: 100 }).then(response => {
  124. if (response.rows) {
  125. this.appOptions = response.rows;
  126. }
  127. });
  128. },
  129. /** 搜索按钮操作 */
  130. handleQuery() {
  131. this.queryParams.pageNum = 1;
  132. this.getList();
  133. },
  134. /** 重置按钮操作 */
  135. resetQuery() {
  136. this.resetForm("queryForm");
  137. this.handleQuery();
  138. }
  139. }
  140. };
  141. </script>
  142. <style scoped>
  143. </style>