From a836f03a5d1fbfa81e147d09ffdfa87ba3975c13 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期二, 18 三月 2025 16:45:02 +0800
Subject: [PATCH] 1

---
 admin/src/views/combo/order.vue |  211 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 211 insertions(+), 0 deletions(-)

diff --git a/admin/src/views/combo/order.vue b/admin/src/views/combo/order.vue
new file mode 100644
index 0000000..bee9272
--- /dev/null
+++ b/admin/src/views/combo/order.vue
@@ -0,0 +1,211 @@
+<template>
+  <div class="main_app">
+    <Breadcrumb />
+    <QueryForm v-model="filters" :query-form-config="queryFormConfig" @handleQuery="getList(1)" @clear="clear" />
+    <div class="table_btns">
+      <el-button type="primary" @click="handleEx()">瀵煎嚭</el-button>
+    </div>
+    <el-table v-loading="loading" :data="list" stripe border>
+      <el-table-column prop="code" align="center" label="璁㈠崟缂栧彿" min-width="200" show-overflow-tooltip>
+        <template scope="{row}">
+          <span @click="handleDetail(row.id)" class="primaryColor pointer">{{ row.code }}</span>
+        </template>
+      </el-table-column>
+      <el-table-column prop="discountName" align="center" label="濂楅鍗�" min-width="120" show-overflow-tooltip />
+      <el-table-column prop="money" align="center" label="鍚堣(鍏�)" min-width="80" show-overflow-tooltip />
+      <el-table-column prop="money" align="center" label="瀹炰粯(鍏�)" min-width="80" show-overflow-tooltip />
+      <el-table-column prop="refundMoney" align="center" label="宸查��閲戦(鍏�)" min-width="100" show-overflow-tooltip />
+      <el-table-column prop="openid" align="center" label="鐢ㄦ埛淇℃伅" min-width="200" show-overflow-tooltip />
+      <el-table-column prop="payWay" align="center" label="鏀粯鏂瑰紡" min-width="80" show-overflow-tooltip>
+        <template v-slot="{ row }">
+          <span v-if="row.payWay == 0">寰俊鏀粯</span>
+          <span v-if="row.payWay == 1">鏀粯瀹�</span>
+        </template>
+      </el-table-column>
+      <el-table-column prop="payWay" align="center" label="璁㈠崟鏉ユ簮" min-width="80" show-overflow-tooltip>
+        <template v-slot="{ row }">
+          <span>灏忕▼搴忕</span>
+        </template>
+      </el-table-column>
+      <el-table-column prop="payWay" align="center" label="璁㈠崟鐘舵��" min-width="80" show-overflow-tooltip>
+        <template v-slot="{ row }">
+          <span v-if="row.status == 0">鏈敮浠�</span>
+          <span v-if="row.status == 1">宸叉敮浠�</span>
+        </template>
+      </el-table-column>
+      <el-table-column prop="refundUserName" align="center" label="鎿嶄綔浜�" min-width="80" show-overflow-tooltip />
+      <el-table-column prop="createDate" align="center" label="鍒涘缓鏃堕棿" min-width="160" show-overflow-tooltip />
+      <el-table-column label="鎿嶄綔" fixed="right" align="center" min-width="120" show-overflow-tooltip>
+        <template v-slot="{ row }">
+          <span @click="handleDetail(row.id)" class="primaryColor pointer">鏌ョ湅璇︽儏</span>
+          <span v-if="row.status == 1 && (row.refundMoney < row.money)" @click="handRefund(row.id)"
+            class="primaryColor pointer ml10">閫�娆�</span>
+        </template>
+      </el-table-column>
+    </el-table>
+    <div class="table_btns">
+      <Pagination @size-change="handleSizeChange" @current-change="getList" :pagination="pagination" />
+    </div>
+    <!--  -->
+    <OrderDetail ref="OrderDetailRef" />
+    <Refund ref="RefundRef" @success="getList" />
+  </div>
+</template>
+
+<script>
+import BasePageTemp from '@/components/base/BasePageTemp'
+import Breadcrumb from '@/layouts/Breadcrumb'
+import OrderDetail from './components/OrderDetail.vue'
+import Refund from './components/Refund'
+import {
+  comboOrderPost,
+  comboListOrderEx,
+  comboOrderDetailPost
+} from '@/api/business/combo.js'
+import dayjs from 'dayjs'
+export default {
+  extends: BasePageTemp,
+  components: {
+    Breadcrumb,
+    OrderDetail,
+    Refund
+  },
+  data() {
+    return {
+      loading: false,
+      queryFormConfig: {
+        formItems: [
+          {
+            filed: 'id',
+            type: 'input',
+            label: '璁㈠崟缂栧彿',
+          },
+          {
+            filed: 'discountName',
+            type: 'input',
+            label: '濂楅鍗�',
+            placeholder: '璇疯緭鍏ュ崱鍚嶇О',
+          },
+          {
+            filed: 'payWay',
+            type: 'select',
+            label: '鏀粯鏂瑰紡',
+            options: [
+              { label: '寰俊', value: 0 },
+              { label: '鏀粯瀹�', value: 1 },
+            ]
+          },
+          {
+            filed: 'payStatus',
+            type: 'select',
+            label: '璁㈠崟鐘舵��',
+            options: [
+              { label: '鏈敮浠�', value: 0 },
+              { label: '宸叉敮浠�', value: 1 },
+            ]
+          },
+          {
+            filed: 'selDate',
+            type: 'daterange',
+            label: '鏀粯鏃堕棿',
+          },
+          {
+            filed: 'openid',
+            type: 'input',
+            label: '鐢ㄦ埛淇℃伅',
+          },
+        ],
+        online: true
+      }
+    }
+  },
+  created() {
+    let date = dayjs().format('YYYY-MM-DD')
+    this.$set(this.filters, 'selDate', [date, date])
+    this.getList()
+    // this.initData()
+  },
+  methods: {
+    handRefund(id) {
+      this.$refs.RefundRef.open(id)
+    },
+    handleDetail(id) {
+      comboOrderDetailPost({ id })
+        .then(res => {
+          if (res) {
+            this.$refs.OrderDetailRef.open('璁㈠崟璇︽儏', res)
+          }
+
+        })
+        .catch(err => {
+          this.$tip.apiFailed(err)
+        })
+    },
+    handleEx() {
+      const { pagination, filters } = this
+      this.$dialog.exportConfirm('纭瀵煎嚭鍚楋紵')
+        .then(() => {
+          this.loading = true
+          if (filters.selDate && filters.selDate.length > 0) {
+            filters.startDate = filters.selDate[0] + ' 00:00:00'
+            filters.endDate = filters.selDate[1] + ' 00:00:00'
+          } else {
+            filters.startDate = null
+            filters.endDate = null
+          }
+          comboListOrderEx({
+            page: 1,
+            capacity: 1000000,
+            model: {
+              ...filters,
+              type: 1
+            },
+          })
+            .then(response => {
+              this.download(response)
+            })
+            .catch(e => {
+              this.$tip.apiFailed(e)
+            })
+            .finally(() => {
+              this.loading = false
+            })
+        })
+        .catch(() => { })
+    },
+    initData() {
+      getStoreList({ capacity: 9999, page: 1, model: {} }).then(res => {
+        this.queryFormConfig.formItems[1].options = res.records || []
+      })
+    },
+    getList(page) {
+      const { pagination, filters } = this
+      this.loading = true
+      if (filters.selDate && filters.selDate.length > 0) {
+        filters.startDate = filters.selDate[0] + ' 00:00:00'
+        filters.endDate = filters.selDate[1] + ' 00:00:00'
+      } else {
+        filters.startDate = null
+        filters.endDate = null
+      }
+      if (page) { pagination.page = page }
+      comboOrderPost({
+        model: {
+          ...filters,
+          type: 1
+        },
+        capacity: pagination.pageSize,
+        page: pagination.page,
+      }).then(res => {
+        this.loading = false
+        this.list = res.records || []
+        this.pagination.total = res.total || 0
+      }, () => {
+        this.loading = false
+      })
+    },
+  }
+}
+</script>
+
+<style></style>

--
Gitblit v1.9.3