Files
wagoo-admin/src/views/mall/pay/index.vue
初心 77a83e363a
Some checks failed
Deploy to GitHub Pages / Deploy to GitHub Pages (push) Has been cancelled
初版提交
2025-09-09 13:35:24 +08:00

338 lines
14 KiB
Vue

<template>
<div class="table-container">
<!-- <vab-page-header description="功能强大的数据表格组件,支持排序、分页、搜索等功能" :icon="['fas', 'table']" title="表格管理" /> -->
<!-- <vab-query-form> -->
<!-- <vab-query-form-left-panel style="width:200px;">
<el-button icon="el-icon-delete" type="primary" @click="handleDelete">导出</el-button>
</vab-query-form-left-panel> -->
<el-row style="display: flex;align-items: center;">
<el-col :span="12">
<el-form ref="form" style="display: flex;align-items: center;" :inline="true" :model="queryForm" @submit.native.prevent>
<el-form-item label="查询时间" >
<el-date-picker
v-model="queryForm.time"
unlink-panels
value-format="yyyy-MM-dd"
type="daterange"
range-separator="-"
start-placeholder="开始日期"
end-placeholder="结束日期"
:picker-options="pickerOptions"
></el-date-picker>
</el-form-item>
</el-form>
</el-col>
<el-col :span="12">
<el-form ref="form" style="display: flex;align-items: center;" :inline="true" :model="queryForm" @submit.native.prevent>
<el-form-item>
<el-input v-model="queryForm.status_Inquiry" placeholder="输入手机号或订单号查询" />
</el-form-item>
<el-form-item>
<el-button icon="el-icon-search" native-type="submit" type="primary" @click="handleQuery">查询</el-button>
</el-form-item>
</el-form>
</el-col>
</el-row>
<!-- <el-button type="primary" @click="testMessage">baseMessage</el-button>
<el-button type="primary" @click="testALert">baseAlert</el-button>
<el-button type="primary" @click="testConfirm">baseConfirm</el-button>
<el-button type="primary" @click="testNotify">baseNotify</el-button> -->
<!-- <vab-query-form-right-panel>
</vab-query-form-right-panel> -->
<!-- </vab-query-form> -->
<el-table
ref="tableSort"
v-loading="listLoading"
:data="list"
:element-loading-text="elementLoadingText"
:height="height"
@selection-change="setSelectRows"
@sort-change="tableSortChange"
>
<!-- <el-table-column type="selection" width="55" /> -->
<!-- <el-table-column label="序号" width="95">
<template #default="scope">
{{ scope.$index + 1 }}
</template>
</el-table-column> -->
<el-table-column align="center" label="订单ID" prop="订单ID" />
<el-table-column align="center" width="180" label="订单号" prop="订单号" />
<el-table-column align="center" width="120" label="订单状态" prop="订单状态" />
<el-table-column align="center" label="客户姓名" prop="客户姓名" />
<el-table-column align="center" width="120" label="电话" prop="电话" />
<el-table-column align="center" width="200" label="地址" prop="地址" />
<el-table-column align="center" width="100" label="时段ID" prop="时段ID" />
<el-table-column align="center" width="100" label="车辆ID" prop="车辆ID" />
<el-table-column align="center" width="100" label="小哇ID" prop="小哇ID" />
<el-table-column align="center" width="180" label="预约时段" prop="预约时段" />
<el-table-column align="center" width="120" label="预约日期" prop="预约日期" />
<el-table-column align="center" label="种类" prop="种类" />
<el-table-column align="center" label="重量ID" prop="重量ID" />
<el-table-column align="center" label="重量区间" prop="重量区间" />
<el-table-column align="center" label="宠物昵称" prop="宠物昵称" />
<el-table-column align="center" label="宠物品种" prop="宠物品种" />
<el-table-column align="center" label="抵扣券ID" prop="抵扣券ID" />
<el-table-column align="center" label="补款链接" prop="补款链接" />
<el-table-column align="center" label="基础洗护" prop="基础洗护" />
<el-table-column align="center" label="刷牙" prop="刷牙" />
<el-table-column align="center" label="头部修剪" prop="头部修剪" />
<el-table-column align="center" label="屁屁修剪" prop="屁屁修剪" />
<el-table-column align="center" label="贵宾脚" prop="贵宾脚" />
<el-table-column align="center" label="全身美容" prop="全身美容" />
<el-table-column align="center" label="纯手剪" prop="纯手剪" />
<el-table-column align="center" label="去除废毛" prop="去除废毛" />
<el-table-column align="center" label="开结" prop="开结" />
<el-table-column width="120" align="center" label="附加项合计" prop="附加项合计" />
<el-table-column align="center" label="调度费" prop="调度费" />
<el-table-column align="center" label="夜间费" prop="夜间费" />
<el-table-column width="120" align="center" label="抵扣券名称" prop="抵扣券名称" />
<el-table-column align="center" label="抵扣金额" prop="抵扣金额" />
<el-table-column width="200" align="center" label="会员价" prop="会员价" />
<el-table-column width="130" align="center" label="是否绑定会员" prop="是否绑定会员" />
<el-table-column align="center" label="折扣" prop="折扣" />
<el-table-column align="center" label="会员首单" prop="会员首单" />
<el-table-column align="center" label="订单合计" prop="订单合计" />
<el-table-column width="150" align="center" label="会员折扣后金额" prop="会员折扣后金额" />
<el-table-column align="center" label="结算金额" prop="结算金额" />
<el-table-column width="150" align="center" label="订单实际支付金额" prop="订单实际支付金额" />
<el-table-column width="120" align="center" label="最终支付总额" prop="最终支付总额" />
<el-table-column align="center" label="追加刷牙" prop="追加刷牙" />
<el-table-column width="120" align="center" label="追加头部修建" prop="追加头部修建" />
<el-table-column width="120" align="center" label="追加屁屁修建" prop="追加屁屁修建" />
<el-table-column width="120" align="center" label="追加贵宾脚" prop="追加贵宾脚" />
<el-table-column width="120" align="center" label="追加全身美容" prop="追加全身美容" />
<el-table-column width="120" align="center" label="追加纯手剪" prop="追加纯手剪" />
<el-table-column width="120" align="center" label="追加去除废毛" prop="追加去除废毛" />
<el-table-column width="120" align="center" label="追加开结" prop="追加开结" />
<!-- <el-table-column label="头像" >
<template #default="{ row }">
<el-image v-if="imgShow" :preview-src-list="imageList" :src="row.img" />
</template>
</el-table-column> -->
<!-- <el-table-column label="点击量" prop="pageViews" sortable /> -->
<!-- <el-table-column label="状态" >
<template #default="{ row }">
<el-tooltip class="item" :content="row.status" effect="dark" placement="top-start">
<el-tag :type="row.status | statusFilter">
{{ row.status }}
</el-tag>
</el-tooltip>
</template>
</el-table-column> -->
<!-- <el-table-column label="时间" prop="datetime" width="200" /> -->
<el-table-column label="操作" fixed="right" width="60px">
<template #default="{ row }">
<el-button v-if="row.订单状态 == '已派单' || row.订单状态 == '已支付' " type="text" @click="handleEdit(row)">编辑</el-button>
<!-- <el-button type="text" @click="handleDelete(row)">删除</el-button> -->
</template>
</el-table-column>
</el-table>
<el-pagination
:background="background"
:current-page="queryForm.pageNo"
:layout="layout"
:page-size="queryForm.pageSize"
:total="total"
@current-change="handleCurrentChange"
@size-change="handleSizeChange"
/>
<table-edit ref="edit" />
</div>
</template>
<script>
import { doDelete, getList,exportUserOperateAdmin } from '@/api/table'
import TableEdit from './components/TableEdit'
import VabPageHeader from '@/components/VabPageHeader'
export default {
name: 'ComprehensiveTable',
components: {
TableEdit,
VabPageHeader,
},
filters: {
statusFilter(status) {
const statusMap = {
published: 'success',
draft: 'gray',
deleted: 'danger',
}
return statusMap[status]
},
},
data() {
return {
pickerOptions: {
shortcuts: [{
text: '最近一周',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
picker.$emit('pick', [start, end]);
}
}, {
text: '最近一个月',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
picker.$emit('pick', [start, end]);
}
}, {
text: '最近三个月',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
picker.$emit('pick', [start, end]);
}
}]
},
imgShow: true,
list: [],
imageList: [],
listLoading: true,
layout: 'total, sizes, prev, pager, next, jumper',
total: 0,
background: true,
selectRows: '',
elementLoadingText: '正在加载...',
queryForm: {
pageNo: 1,
pageSize: 20,
title: '',
},
timeOutID: null,
}
},
computed: {
height() {
return this.$baseTableHeight()
},
},
created() {
this.fetchData()
},
beforeDestroy() {
clearTimeout(this.timeOutID)
},
mounted() {},
methods: {
tableSortChange() {
const imageList = []
this.$refs.tableSort.tableData.forEach((item, index) => {
imageList.push(item.img)
})
this.imageList = imageList
},
setSelectRows(val) {
this.selectRows = val
},
handleAdd() {
this.$refs['edit'].showEdit()
},
handleEdit(row) {
console.log(row,'---')
this.$refs['edit'].showEdit(row)
},
handleDelete(row) {
exportUserOperateAdmin(this.queryParams, { responseType: 'blob' }).then(
response => {
console.log(response,'----')
const url = window.URL.createObjectURL(new Blob([response.data])) // 创建下载链接
const link = document.createElement('a')
link.href = url
link.download = '全文导入模板.xlsx' // 设置文件名
document.body.appendChild(link)
link.click() // 触发下载
document.body.removeChild(link) // 下载后移除元素
}
).catch(error => {
console.error('下载失败', error)
this.loading = false // 停止加载,隐藏加载状态
})
// if (row.id) {
// this.$baseConfirm('你确定要导出当前项吗', null, async () => {
// const { msg } = await doDelete({ ids: row.id })
// this.$baseMessage(msg, 'success')
// this.fetchData()
// })
// } else {
// if (this.selectRows.length > 0) {
// const ids = this.selectRows.map((item) => item.id).join()
// this.$baseConfirm('你确定要导出选中项吗', null, async () => {
// const { msg } = await doDelete({ ids: ids })
// this.$baseMessage(msg, 'success')
// this.fetchData()
// })
// } else {
// this.$baseMessage('未选中任何行', 'error')
// return false
// }
// }
},
handleSizeChange(val) {
this.queryForm.pageSize = val
this.fetchData()
},
handleCurrentChange(val) {
this.queryForm.pageNo = val
this.fetchData()
},
handleQuery() {
this.queryForm.pageNo = 1
this.fetchData()
},
async fetchData() {
this.listLoading = true
const { data, total } = await getList(this.queryForm)
this.list = data
const imageList = []
data.forEach((item, index) => {
imageList.push(item.img)
})
this.imageList = imageList
this.total = total
this.timeOutID = setTimeout(() => {
this.listLoading = false
}, 500)
},
testMessage() {
this.$baseMessage('test1', 'success')
},
testALert() {
this.$baseAlert('11')
this.$baseAlert('11', '自定义标题', () => {
/* 可以写回调; */
})
this.$baseAlert('11', null, () => {
/* 可以写回调; */
})
},
testConfirm() {
this.$baseConfirm(
'你确定要执行该操作?',
null,
() => {
/* 可以写回调; */
},
() => {
/* 可以写回调; */
}
)
},
testNotify() {
this.$baseNotify('测试消息提示', 'test', 'success', 'bottom-right')
},
},
}
</script>