2023-11-06 18:01:40 +08:00
|
|
|
<template>
|
|
|
|
|
<div class="app-container">
|
|
|
|
|
<!-- 用户select选项 -->
|
2023-11-07 21:22:37 +08:00
|
|
|
<el-row :gutter="15" class="m-t-0">
|
|
|
|
|
<el-col :span="4">
|
2023-11-09 15:20:28 +08:00
|
|
|
<SelectionShopId class="w-100" v-model="shop_id" :allSel="true" />
|
2023-11-07 21:22:37 +08:00
|
|
|
</el-col>
|
2023-11-09 15:20:28 +08:00
|
|
|
<el-col :span="9">
|
|
|
|
|
<DatePickerOrder class="w-100" @dateRangepicked="handleDateRangePicked" />
|
2023-11-07 21:22:37 +08:00
|
|
|
</el-col>
|
2023-11-09 15:20:28 +08:00
|
|
|
<el-col :span="11">
|
2023-11-09 16:08:22 +08:00
|
|
|
<SearchOrder class="w-100" @input="handleSearchChange" />
|
2023-11-07 21:22:37 +08:00
|
|
|
</el-col>
|
|
|
|
|
</el-row>
|
|
|
|
|
<el-row :gutter="15">
|
2023-11-09 15:20:28 +08:00
|
|
|
<el-col :span="13">
|
|
|
|
|
<SelectionOrderStatus @selectedValuesChanged="handleOrderStatusChange" />
|
2023-11-07 21:22:37 +08:00
|
|
|
</el-col>
|
2023-11-09 15:20:28 +08:00
|
|
|
<el-col :span="11">
|
|
|
|
|
<SelectionOrderBack @selectedValuesChanged="handleOrderBackChange" />
|
2023-11-07 21:22:37 +08:00
|
|
|
</el-col>
|
|
|
|
|
</el-row>
|
2023-11-07 13:28:53 +08:00
|
|
|
<!-- 订单列表 -->
|
2023-11-06 18:01:40 +08:00
|
|
|
<el-table class="m-t-20 w-100" ref="myTable"
|
2023-11-09 15:20:28 +08:00
|
|
|
:data="orderListArr.slice((currentPage - 1) * pageSize, currentPage * pageSize)" border tooltip-effect="dark">
|
2023-11-06 18:01:40 +08:00
|
|
|
<el-table-column align="center" type="selection" width="40">
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column align="center" prop="id" label="id" width="50">
|
|
|
|
|
</el-table-column>
|
2023-11-07 13:28:53 +08:00
|
|
|
<el-table-column prop="order_sn" label="订单号" width="150" min-width="150">
|
2023-11-06 18:01:40 +08:00
|
|
|
</el-table-column>
|
2023-11-07 13:28:53 +08:00
|
|
|
<el-table-column prop="tel" label="客户电话" min-width="150">
|
2023-11-06 18:01:40 +08:00
|
|
|
</el-table-column>
|
2023-11-07 13:28:53 +08:00
|
|
|
<el-table-column label="下单时间" width="140" min-width="140">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
{{ scope.row.addtime | parseTime('{y}-{m}-{d} {h}:{i}') }}
|
2023-11-06 18:01:40 +08:00
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
2023-11-09 15:20:28 +08:00
|
|
|
<el-table-column prop="controler" label="操作" width="400" min-width="400">
|
2023-11-06 18:01:40 +08:00
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-button-group>
|
2023-11-07 21:22:37 +08:00
|
|
|
<el-button type="warning" icon="el-icon-edit">同意退款</el-button>
|
|
|
|
|
<el-button type="danger" icon="el-icon-delete" @click="deleteAdmin([scope.row.id])">拒绝退款</el-button>
|
|
|
|
|
<el-button type="primary" icon="el-icon-search"
|
|
|
|
|
@click="$router.replace(`/order/show/${scope.row.id}`)">查看</el-button>
|
2023-11-06 18:01:40 +08:00
|
|
|
</el-button-group>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
</el-table>
|
|
|
|
|
<!-- 分页 -->
|
|
|
|
|
<el-pagination class="m-t-20" layout="prev, pager, next" :current-page.sync="currentPage" :page-size="pageSize"
|
2023-11-09 15:20:28 +08:00
|
|
|
:total="orderListArr.length">
|
2023-11-06 18:01:40 +08:00
|
|
|
</el-pagination>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2023-11-07 13:28:53 +08:00
|
|
|
|
|
|
|
|
import { countSelIdArr, parseTime } from '@/utils'
|
2023-11-06 18:01:40 +08:00
|
|
|
import SelectionShopId from '@/components/SelectionShopId'
|
2023-11-07 13:28:53 +08:00
|
|
|
import SelectionOrderStatus from '@/components/SelectionOrderStatus'
|
|
|
|
|
import SelectionOrderBack from '@/components/SelectionOrderBack'
|
2023-11-07 21:22:37 +08:00
|
|
|
import DatePickerOrder from '@/components/DatePickerOrder'
|
2023-11-09 16:08:22 +08:00
|
|
|
import SearchOrder from '@/components/SearchOrder'
|
2023-11-06 18:01:40 +08:00
|
|
|
|
|
|
|
|
export default {
|
2023-11-07 13:28:53 +08:00
|
|
|
name: 'Order',
|
2023-11-06 18:01:40 +08:00
|
|
|
data () {
|
|
|
|
|
return {
|
2023-11-07 13:28:53 +08:00
|
|
|
pageSize: 50, // 每页显示记录条数
|
2023-11-06 18:01:40 +08:00
|
|
|
currentPage: 1, // 当前页
|
2023-11-09 15:20:28 +08:00
|
|
|
shop_id: '', // 搜索条件 商铺id
|
|
|
|
|
start_time: '', // 搜索条件 起始时间
|
|
|
|
|
end_time: '', // 搜索条件 结束时间
|
|
|
|
|
status: [], // 搜索条件 订单状态
|
2023-11-09 16:08:22 +08:00
|
|
|
back: [], // 搜索条件 退款状态
|
|
|
|
|
search: [] // 搜索条件 搜索
|
2023-11-06 18:01:40 +08:00
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
components: {
|
|
|
|
|
SelectionShopId,
|
2023-11-07 13:28:53 +08:00
|
|
|
SelectionOrderStatus,
|
2023-11-07 21:22:37 +08:00
|
|
|
SelectionOrderBack,
|
2023-11-09 16:08:22 +08:00
|
|
|
DatePickerOrder,
|
|
|
|
|
SearchOrder
|
2023-11-06 18:01:40 +08:00
|
|
|
},
|
|
|
|
|
computed: {
|
2023-11-07 13:28:53 +08:00
|
|
|
// 获取订单列表
|
|
|
|
|
orderList () {
|
|
|
|
|
return this.$store.state.orderList
|
2023-11-09 15:20:28 +08:00
|
|
|
},
|
|
|
|
|
// 过滤订单列表组
|
|
|
|
|
orderListArr () {
|
|
|
|
|
if (this.orderList.length > 0) {
|
|
|
|
|
let filteredList = this.orderList
|
|
|
|
|
// 过滤shop_id
|
|
|
|
|
if (this.shop_id !== '') {
|
|
|
|
|
filteredList = filteredList.filter(order => order.shop_id === this.shop_id)
|
|
|
|
|
}
|
|
|
|
|
// 过滤时间
|
|
|
|
|
if (this.start_time !== '' && this.end_time !== '') {
|
|
|
|
|
const startTime = parseInt(this.start_time)
|
|
|
|
|
const endTime = parseInt(this.end_time)
|
|
|
|
|
filteredList = filteredList.filter(order => {
|
|
|
|
|
const orderTime = parseInt(order.addtime)
|
|
|
|
|
return startTime < orderTime && orderTime < endTime
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
// 过滤订单状态
|
|
|
|
|
if (this.status.length > 0) {
|
|
|
|
|
filteredList = filteredList.filter(order => {
|
|
|
|
|
// 检查订单状态是否在this.status数组中
|
|
|
|
|
return this.status.includes(order.status)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
// 过滤订单状态
|
|
|
|
|
if (this.back.length > 0) {
|
|
|
|
|
filteredList = filteredList.filter(order => {
|
|
|
|
|
// 检查订单状态是否在this.status数组中
|
|
|
|
|
return this.back.includes(order.back)
|
|
|
|
|
})
|
|
|
|
|
}
|
2023-11-09 16:08:22 +08:00
|
|
|
// 搜索条件过滤
|
|
|
|
|
if (this.search[1] !== '') {
|
|
|
|
|
filteredList = filteredList.filter(order => {
|
|
|
|
|
if (this.search[0] === 'orderId') {
|
|
|
|
|
return order.order_sn.indexOf(this.search[1]) >= 0
|
|
|
|
|
} else if (this.search[0] === 'name') {
|
|
|
|
|
return order.receiver.indexOf(this.search[1]) >= 0
|
|
|
|
|
} else if (this.search[0] === 'tel') {
|
|
|
|
|
return order.tel.indexOf(this.search[1]) >= 0
|
|
|
|
|
} else if (this.search[0] === 'remark') {
|
|
|
|
|
return order.remark.indexOf(this.search[1]) >= 0
|
|
|
|
|
} else if (this.search[0] === 'desc') {
|
|
|
|
|
return order.describe.indexOf(this.search[1]) >= 0
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
2023-11-09 15:20:28 +08:00
|
|
|
return filteredList
|
|
|
|
|
} else {
|
|
|
|
|
return []
|
|
|
|
|
}
|
2023-11-06 18:01:40 +08:00
|
|
|
}
|
2023-11-07 13:28:53 +08:00
|
|
|
|
2023-11-06 18:01:40 +08:00
|
|
|
},
|
|
|
|
|
methods: {
|
2023-11-09 15:20:28 +08:00
|
|
|
countSelIdArr,
|
|
|
|
|
/**
|
|
|
|
|
* @description: 日期组件绑定事件
|
|
|
|
|
*/
|
|
|
|
|
handleDateRangePicked (dateRange) {
|
|
|
|
|
// 在这里处理从日期选择器组件传递过来的时间戳数据
|
|
|
|
|
this.start_time = dateRange.start
|
|
|
|
|
this.end_time = dateRange.end
|
|
|
|
|
},
|
|
|
|
|
/**
|
|
|
|
|
* @description: 订单状态选择组件绑定事件
|
|
|
|
|
*/
|
|
|
|
|
handleOrderStatusChange (val) {
|
|
|
|
|
this.status = val
|
|
|
|
|
},
|
|
|
|
|
/**
|
|
|
|
|
* @description: 退货选择组件绑定事件
|
|
|
|
|
*/
|
|
|
|
|
handleOrderBackChange (val) {
|
|
|
|
|
this.back = val
|
2023-11-09 16:08:22 +08:00
|
|
|
},
|
|
|
|
|
/**
|
|
|
|
|
* @description: 搜索组件绑定事件
|
|
|
|
|
*/
|
|
|
|
|
handleSearchChange (val) {
|
|
|
|
|
this.search = val
|
2023-11-09 15:20:28 +08:00
|
|
|
}
|
2023-11-06 18:01:40 +08:00
|
|
|
},
|
|
|
|
|
watch: {
|
|
|
|
|
},
|
|
|
|
|
created () {
|
|
|
|
|
},
|
|
|
|
|
filters: {
|
2023-11-07 13:28:53 +08:00
|
|
|
countSelIdArr,
|
|
|
|
|
parseTime
|
2023-11-06 18:01:40 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
@import "@/styles/theme.scss";
|
|
|
|
|
|
|
|
|
|
i {
|
|
|
|
|
font-size: 18px !important;
|
|
|
|
|
margin-right: 12px;
|
|
|
|
|
vertical-align: middle;
|
|
|
|
|
}
|
|
|
|
|
</style>
|