income.vue 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <template>
  2. <div class="m-container">
  3. <h2>
  4. <div class="squrt"></div>订单管理
  5. </h2>
  6. <div class="m-core">
  7. <!-- 搜索类型 -->
  8. <el-form :inline="true"
  9. class="searchForm"
  10. v-model="searchForm">
  11. <el-form-item prop='organId'>
  12. <el-select class='multiple'
  13. v-model="searchForm.organId"
  14. filterable
  15. clearable
  16. placeholder="请选择分部">
  17. <el-option v-for="(item,index) in organList"
  18. :key="index"
  19. :label="item.name"
  20. :value="item.id"></el-option>
  21. </el-select>
  22. </el-form-item>
  23. <el-form-item>
  24. <el-date-picker v-model="orderDate"
  25. style="width:410px;"
  26. type="daterange"
  27. value-format="yyyy-MM-dd"
  28. @change="searchOrderDate"
  29. range-separator="至"
  30. start-placeholder="开始日期"
  31. end-placeholder="结束日期">
  32. </el-date-picker>
  33. </el-form-item>
  34. <el-form-item>
  35. <el-select v-model="searchForm.paymentType"
  36. clearable
  37. filterable
  38. placeholder="交易类型">
  39. <el-option v-for="(item, index) in orderStatus"
  40. :key="index"
  41. :label="item.label"
  42. :value="item.value"></el-option>
  43. </el-select>
  44. </el-form-item>
  45. <el-form-item>
  46. <el-select v-model="searchForm.paymentStatus"
  47. clearable
  48. filterable
  49. placeholder="交易状态">
  50. <el-option v-for="(item, index) in dealStatus"
  51. :key="index"
  52. :label="item.label"
  53. :value="item.value"></el-option>
  54. </el-select>
  55. </el-form-item>
  56. <el-form-item>
  57. <el-button @click="search"
  58. type="danger">搜索</el-button>
  59. <el-button @click="onReSet"
  60. type="primary">重置</el-button>
  61. </el-form-item>
  62. </el-form>
  63. <!-- 列表 -->
  64. <div class="tableWrap">
  65. <el-table :data='tableList'
  66. :header-cell-style="{background:'#EDEEF0',color:'#444'}">
  67. <el-table-column align='center' width="180px"
  68. prop="transNo"
  69. label="交易流水号">
  70. </el-table-column>
  71. <el-table-column align='center'
  72. width="210px"
  73. prop="orderNo"
  74. label="订单号">
  75. </el-table-column>
  76. <el-table-column align='center' width="180px"
  77. prop="createTime"
  78. label="订单日期">
  79. </el-table-column>
  80. <el-table-column align='center'
  81. label="交易类型">
  82. <template slot-scope="scope">
  83. {{ scope.row.type | orderType }}
  84. </template>
  85. </el-table-column>
  86. <el-table-column align='center'
  87. prop="expectAmount"
  88. label="应付金额">
  89. </el-table-column>
  90. <el-table-column align='center'
  91. prop="balancePaymentAmount"
  92. label="余额支付">
  93. </el-table-column>
  94. <el-table-column align='center'
  95. prop="actualAmount"
  96. label="实付金额">
  97. </el-table-column>
  98. <el-table-column align='center'
  99. prop="user.username"
  100. label="学员姓名">
  101. </el-table-column>
  102. <el-table-column align='center'
  103. prop="paymentChannel"
  104. label="交易方式">
  105. <template slot-scope="scope">
  106. {{ scope.row.paymentChannel | paymentChannelStatus }}
  107. </template>
  108. </el-table-column>
  109. <el-table-column align='center'
  110. label="收款账户">
  111. <template slot-scope="scope">
  112. {{ scope.row.merNos }}
  113. </template>
  114. </el-table-column>
  115. <el-table-column align='center'
  116. label="交易状态">
  117. <template slot-scope="scope">
  118. {{ scope.row.status | dealStatus }}
  119. </template>
  120. </el-table-column>
  121. </el-table>
  122. <pagination :total="pageInfo.total"
  123. :page.sync="pageInfo.page"
  124. :limit.sync="pageInfo.limit"
  125. :page-sizes="pageInfo.page_size"
  126. @pagination="getList" />
  127. </div>
  128. </div>
  129. </div>
  130. </template>
  131. <script>
  132. import pagination from '@/components/Pagination/index'
  133. import { orderQueryPage } from '@/api/orderManager'
  134. import { getEmployeeOrgan } from '@/api/buildTeam'
  135. import store from '@/store'
  136. import { orderStatus, dealStatus } from '@/utils/searchArray'
  137. export default {
  138. components: { pagination },
  139. name: 'income',
  140. data () {
  141. return {
  142. orderStatus: orderStatus,
  143. dealStatus: dealStatus,
  144. orderDate: null,
  145. searchForm: {
  146. orderStartDate: null,
  147. orderEndDate: null,
  148. paymentStatus: 'SUCCESS',
  149. paymentType: null,
  150. organId: null
  151. },
  152. tableList: [],
  153. organList: [],
  154. pageInfo: {
  155. // 分页规则
  156. limit: 10, // 限制显示条数
  157. page: 1, // 当前页
  158. total: 0, // 总条数
  159. page_size: [10, 20, 40, 50] // 选择限制显示条数
  160. },
  161. }
  162. },
  163. mounted () {
  164. getEmployeeOrgan().then(res => {
  165. if (res.code == 200) {
  166. this.organList = res.data;
  167. }
  168. })
  169. this.getList()
  170. },
  171. methods: {
  172. search () {
  173. this.pageInfo.page = 1;
  174. this.getList();
  175. },
  176. getList () {
  177. let params = this.searchForm
  178. params.rows = this.pageInfo.limit
  179. params.page = this.pageInfo.page
  180. orderQueryPage(params).then(res => {
  181. let result = res.data
  182. if (res.code == 200) {
  183. this.tableList = result.rows
  184. this.pageInfo.total = result.total
  185. }
  186. })
  187. },
  188. searchOrderDate (value) {
  189. if (value) {
  190. this.searchForm.orderStartDate = value[0]
  191. this.searchForm.orderEndDate = value[1]
  192. } else {
  193. this.searchForm.orderStartDate = null
  194. this.searchForm.orderEndDate = null
  195. }
  196. },
  197. onReSet () { // 重置搜索
  198. this.orderDate = null
  199. this.searchForm = {
  200. orderStartDate: null,
  201. orderEndDate: null,
  202. paymentStatus: null,
  203. paymentType: null,
  204. organId: null
  205. }
  206. this.getList()
  207. },
  208. }
  209. }
  210. </script>
  211. <style lang="scss">
  212. </style>