index.vue 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <template>
  2. <ele-page flex-table>
  3. <!-- 搜索表单 -->
  4. <return-search @search="reload" />
  5. <ele-card :body-style="{ paddingTop: '8px' }" flex-table>
  6. <!-- 表格 -->
  7. <ele-pro-table
  8. ref="tableRef"
  9. row-key="postId"
  10. :columns="columns"
  11. :datasource="datasource"
  12. :show-overflow-tooltip="true"
  13. v-model:selections="selections"
  14. highlight-current-row
  15. :export-config="{ fileName: '需退回订单' }"
  16. cache-key="needReturnedTable"
  17. >
  18. <template #toolbar>
  19. <!-- 0-创建(待付款) 1-已付款 2-已推送 3-已发货 4-已签收 5-已完成 6-已取消 7-超时取消 -->
  20. <el-radio-group v-model="status" @change="handleStatusChange">
  21. <el-radio-button label="全部" value="0" />
  22. <el-radio-button label="待发货" value="1" />
  23. <el-radio-button label="已发货" value="3" />
  24. <el-radio-button label="已完成" value="5" />
  25. <el-radio-button label="已取消" value="6" />
  26. </el-radio-group>
  27. </template>
  28. <template #status="{ row }">
  29. <dict-data
  30. code="refund_status"
  31. type="text"
  32. :model-value="row.status"
  33. />
  34. </template>
  35. <template #isPush="{ row }">
  36. <el-tag type="success" v-if="row.checkStatus == 1">已推送</el-tag>
  37. <el-tag type="danger" v-else>未推送</el-tag>
  38. </template>
  39. <template #isFirstOrder="{ row }">
  40. <dict-data
  41. code="is_first_order"
  42. type="tag"
  43. :model-value="row.firstOrder"
  44. />
  45. </template>
  46. <template #orderNumber="{ row }">
  47. <order-number :row="row" isReturn></order-number>
  48. </template>
  49. <template #customer="{ row }">
  50. <refund-customer :row="row"></refund-customer>
  51. </template>
  52. <template #amount="{ row }">
  53. <div class="common-text flex flex-col">
  54. <el-text>余额</el-text>
  55. <el-text>邮费:¥ {{ row.expressMoney || '0' }} </el-text>
  56. </div>
  57. </template>
  58. <template #remarks="{ row }">
  59. <el-popover
  60. trigger="hover"
  61. width="240px"
  62. @show="handleShowPopover(row)"
  63. @hide="showOrderId = ''"
  64. >
  65. <template #reference>
  66. <el-icon
  67. style="cursor: pointer"
  68. :size="24"
  69. :color="row.remarkLabel || '#777777'"
  70. @click="handleRemarks(row)"
  71. >
  72. <Flag />
  73. </el-icon>
  74. </template>
  75. <orderTimeline
  76. :orderId="showOrderId"
  77. title="备注历史记录"
  78. ></orderTimeline>
  79. </el-popover>
  80. </template>
  81. <template #action="{ row }">
  82. <div>
  83. <el-button
  84. type="success"
  85. link
  86. v-permission="'recycleOrder:needReturned:detail'"
  87. @click="toOrderDetail(row)"
  88. >
  89. [订单详情]
  90. </el-button>
  91. <el-button
  92. color="#7728f5"
  93. v-if="row.status !== '3'"
  94. link
  95. plain
  96. v-permission="'recycleOrder:needReturned:manualDelivery'"
  97. @click="handleManualDelivery(row)"
  98. >
  99. [手工发货]
  100. </el-button>
  101. <el-button
  102. type="danger"
  103. link
  104. v-if="row.status == '0'"
  105. v-permission="'recycleOrder:needReturned:cancel'"
  106. @click="cancelOrder(row)"
  107. >
  108. [取消订单]
  109. </el-button>
  110. <el-button
  111. type="warning"
  112. link
  113. v-permission="'recycleOrder:needReturned:log'"
  114. @click="openOrderLog(row)"
  115. >
  116. [订单日志]
  117. </el-button>
  118. </div>
  119. </template>
  120. </ele-pro-table>
  121. </ele-card>
  122. <slot></slot>
  123. <orderRemarks ref="remarksRef" />
  124. <orderLog ref="logRef" type="refund" />
  125. <manualDelivery ref="deliveryRef" @success="reload()" />
  126. <orderRefundDetail ref="orderDetailRef" />
  127. </ele-page>
  128. </template>
  129. <script setup>
  130. import { ref, getCurrentInstance } from 'vue';
  131. import { EleMessage } from 'ele-admin-plus/es';
  132. import { ElMessageBox } from 'element-plus/es';
  133. import { Flag } from '@element-plus/icons-vue';
  134. import returnSearch from './return-search.vue';
  135. import OrderNumber from '@/views/recycleOrder/components/order-number.vue';
  136. import RefundCustomer from '@/views/recycleOrder/components/refund-customer.vue';
  137. import { useDictData } from '@/utils/use-dict-data';
  138. import orderRemarks from '@/views/recycleOrder/components/order-remarks.vue';
  139. import orderTimeline from '@/views/recycleOrder/components/order-timeline.vue';
  140. import orderLog from '@/views/recycleOrder/components/order-log.vue';
  141. import manualDelivery from '@/views/recycleOrder/components/manual-delivery.vue';
  142. //订单详情
  143. import orderRefundDetail from '@/views/recycleOrder/needReturned/order-refund-detail.vue';
  144. const status = ref('0');
  145. let props = defineProps({
  146. pageConfig: {
  147. type: Object,
  148. default: () => ({
  149. cacheKey: 'recycleOrderTable',
  150. fileName: '需退回订单'
  151. })
  152. },
  153. pageUrl: { type: String, default: '/order/orderInfo/refund/pageList' }
  154. });
  155. let { proxy } = getCurrentInstance();
  156. /** 字典数据 */
  157. const [statusDicts] = useDictData(['sys_normal_disable']);
  158. /** 表格实例 */
  159. const tableRef = ref(null);
  160. function handleStatusChange(val) {
  161. reload({ tabStatus: val });
  162. }
  163. /** 表格列配置 */
  164. const columns = ref([
  165. {
  166. type: 'selection',
  167. columnKey: 'selection',
  168. width: 50,
  169. align: 'center',
  170. fixed: 'left'
  171. },
  172. {
  173. label: '单号',
  174. prop: 'refundOrderId',
  175. slot: 'orderNumber',
  176. minWidth: 180
  177. },
  178. { label: '客户', prop: 'userNick', slot: 'customer', minWidth: 380 },
  179. { label: '金额', prop: 'balanceMoney', slot: 'amount', minWidth: 100 },
  180. { label: '是否推送', prop: 'plat', slot: 'isPush' },
  181. {
  182. label: '订单状态',
  183. prop: 'status',
  184. slot: 'status',
  185. formatter: (row) =>
  186. statusDicts.value.find((d) => d.dictValue == row.status)?.dictLabel
  187. },
  188. {
  189. label: '入库状态',
  190. prop: 'stockStatus',
  191. formatter: (row) =>
  192. row.stockStatus == 1 ? '已入库' : row.stockStatus == 0 ? '未入库' : '-'
  193. },
  194. { label: '是否首单', prop: 'firstOrder', slot: 'isFirstOrder' },
  195. { label: '备注', prop: 'remarkLabel', slot: 'remarks' },
  196. {
  197. columnKey: 'action',
  198. label: '操作',
  199. width: 120,
  200. align: 'center',
  201. slot: 'action',
  202. hideInPrint: true,
  203. hideInExport: true
  204. }
  205. ]);
  206. /** 表格选中数据 */
  207. const selections = ref([]);
  208. async function queryPage(params) {
  209. const res = await proxy.$http.get(props.pageUrl, { params });
  210. if (res.data.code === 200) {
  211. return res.data;
  212. }
  213. return Promise.reject(new Error(res.data.msg));
  214. }
  215. /** 表格数据源 */
  216. const datasource = ({ pages, where, orders }) => {
  217. return queryPage({ ...where, ...orders, ...pages });
  218. };
  219. /** 搜索 */
  220. const reload = (where) => {
  221. tableRef.value?.reload?.({ page: 1, where: { ...where, tabStatus: status.value } });
  222. };
  223. //订单详情
  224. const orderDetailRef = ref(null);
  225. function toOrderDetail(row) {
  226. orderDetailRef.value?.handleOpen(row);
  227. }
  228. //弹窗确认
  229. function messageBoxConfirm({ message, url, row }) {
  230. ElMessageBox.confirm(message, '提示', {
  231. confirmButtonText: '确定',
  232. cancelButtonText: '关闭',
  233. type: 'warning'
  234. }).then(() => {
  235. proxy.$http.post(url, { orderIds: [row.refundOrderId] }).then((res) => {
  236. if (res.data.code === 200) {
  237. EleMessage.success('操作成功');
  238. reload();
  239. } else {
  240. EleMessage.error(res.data.msg || '操作失败');
  241. }
  242. });
  243. });
  244. }
  245. //取消订单
  246. function cancelOrder(row) {
  247. messageBoxConfirm({
  248. message: '确认取消?',
  249. url: '/order/orderInfo/refund/cancel',
  250. row
  251. });
  252. }
  253. //人工发货
  254. const deliveryRef = ref(null);
  255. function handleManualDelivery(row) {
  256. deliveryRef.value?.handleOpen(row);
  257. }
  258. //订单日志
  259. const logRef = ref(null);
  260. const openOrderLog = (row) => {
  261. logRef.value?.handleOpen(row.refundOrderId);
  262. };
  263. //修改备注
  264. const remarksRef = ref(null);
  265. function handleRemarks(row) {
  266. remarksRef.value?.handleOpen(row);
  267. }
  268. //备注弹窗显示
  269. const showOrderId = ref();
  270. function handleShowPopover(row) {
  271. showOrderId.value = row.originOrderId;
  272. }
  273. </script>