Skip to content

Commit 5dceda6

Browse files
author
puhui999
committed
订单列表:列表重构 添加门店、物流检索条件
1 parent 83e780d commit 5dceda6

File tree

4 files changed

+95
-61
lines changed

4 files changed

+95
-61
lines changed

src/api/mall/trade/delivery/express/index.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,7 @@ export const getDeliveryExpress = async (id: number) => {
1919
return await request.get({ url: '/trade/delivery/express/get?id=' + id })
2020
}
2121

22-
// 获得商品品牌精简信息列表
22+
// 获得快递公司精简信息列表
2323
export const getSimpleDeliveryExpressList = () => {
2424
return request.get({ url: '/trade/delivery/express/list-all-simple' })
2525
}

src/api/mall/trade/delivery/pickUpStore/index.ts

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ export interface DeliveryPickUpStoreVO {
1616
}
1717

1818
// 查询自提门店列表
19-
export const getDeliveryPickUpStorePage = async (params: DeliveryPickUpStorePageReqVO) => {
19+
export const getDeliveryPickUpStorePage = async (params) => {
2020
return await request.get({ url: '/trade/delivery/pick-up-store/page', params })
2121
}
2222

@@ -25,6 +25,11 @@ export const getDeliveryPickUpStore = async (id: number) => {
2525
return await request.get({ url: '/trade/delivery/pick-up-store/get?id=' + id })
2626
}
2727

28+
// 查询自提门店精简列表
29+
export const getListAllSimple = async () => {
30+
return await request.get({ url: '/trade/delivery/pick-up-store/list-all-simple' })
31+
}
32+
2833
// 新增自提门店
2934
export const createDeliveryPickUpStore = async (data: DeliveryPickUpStoreVO) => {
3035
return await request.post({ url: '/trade/delivery/pick-up-store/create', data })
@@ -39,8 +44,3 @@ export const updateDeliveryPickUpStore = async (data: DeliveryPickUpStoreVO) =>
3944
export const deleteDeliveryPickUpStore = async (id: number) => {
4045
return await request.delete({ url: '/trade/delivery/pick-up-store/delete?id=' + id })
4146
}
42-
43-
// 导出自提门店 Excel
44-
export const exportDeliveryPickUpStoreApi = async (params) => {
45-
return await request.download({ url: '/trade/delivery/pick-up-store/export-excel', params })
46-
}

src/views/mall/trade/delivery/pickUpStore/index.vue

Lines changed: 31 additions & 49 deletions
Original file line numberDiff line numberDiff line change
@@ -1,27 +1,27 @@
11
<template>
22
<!-- 搜索工作栏 -->
33
<ContentWrap>
4-
<el-form class="-mb-15px" :model="queryParams" ref="queryFormRef" :inline="true">
4+
<el-form ref="queryFormRef" :inline="true" :model="queryParams" class="-mb-15px">
55
<el-form-item label="门店手机" prop="phone">
66
<el-input
77
v-model="queryParams.phone"
8-
placeholder="请输门店手机"
8+
class="!w-240px"
99
clearable
10+
placeholder="请输门店手机"
1011
@keyup.enter="handleQuery"
11-
class="!w-240px"
1212
/>
1313
</el-form-item>
1414
<el-form-item label="门店名称" prop="name">
1515
<el-input
1616
v-model="queryParams.name"
17-
placeholder="请输门店名称"
17+
class="!w-240px"
1818
clearable
19+
placeholder="请输门店名称"
1920
@keyup.enter="handleQuery"
20-
class="!w-240px"
2121
/>
2222
</el-form-item>
2323
<el-form-item label="门店状态" prop="status">
24-
<el-select v-model="queryParams.status" placeholder="门店状态" clearable class="!w-240px">
24+
<el-select v-model="queryParams.status" class="!w-240px" clearable placeholder="门店状态">
2525
<el-option
2626
v-for="dict in getIntDictOptions(DICT_TYPE.COMMON_STATUS)"
2727
:key="dict.value"
@@ -33,32 +33,30 @@
3333
<el-form-item label="创建时间" prop="createTime">
3434
<el-date-picker
3535
v-model="queryParams.createTime"
36-
value-format="YYYY-MM-DD HH:mm:ss"
37-
type="datetimerange"
38-
start-placeholder="开始日期"
39-
end-placeholder="结束日期"
4036
class="!w-240px"
37+
end-placeholder="结束日期"
38+
start-placeholder="开始日期"
39+
type="datetimerange"
40+
value-format="YYYY-MM-DD HH:mm:ss"
4141
/>
4242
</el-form-item>
4343
<el-form-item>
44-
<el-button @click="handleQuery"><Icon icon="ep:search" class="mr-5px" /> 搜索</el-button>
45-
<el-button @click="resetQuery"><Icon icon="ep:refresh" class="mr-5px" /> 重置</el-button>
46-
<el-button
47-
type="primary"
48-
plain
49-
@click="openForm('create')"
50-
v-hasPermi="['trade:delivery:pick-up-store:create']"
51-
>
52-
<Icon icon="ep:plus" class="mr-5px" /> 新增
44+
<el-button @click="handleQuery">
45+
<Icon class="mr-5px" icon="ep:search" />
46+
搜索
47+
</el-button>
48+
<el-button @click="resetQuery">
49+
<Icon class="mr-5px" icon="ep:refresh" />
50+
重置
5351
</el-button>
5452
<el-button
55-
type="success"
53+
v-hasPermi="['trade:delivery:pick-up-store:create']"
5654
plain
57-
@click="handleExport"
58-
:loading="exportLoading"
59-
v-hasPermi="['trade:delivery:pick-up-store:export']"
55+
type="primary"
56+
@click="openForm('create')"
6057
>
61-
<Icon icon="ep:download" class="mr-5px" /> 导出
58+
<Icon class="mr-5px" icon="ep:plus" />
59+
新增
6260
</el-button>
6361
</el-form-item>
6462
</el-form>
@@ -75,34 +73,34 @@
7573
</el-table-column>
7674
<el-table-column label="门店名称" prop="name" />
7775
<el-table-column label="门店手机" prop="phone" />
78-
<el-table-column label="门店详细地址" align="center" prop="detailAddress" />
79-
<el-table-column label="开启状态" align="center" prop="status">
76+
<el-table-column align="center" label="门店详细地址" prop="detailAddress" />
77+
<el-table-column align="center" label="开启状态" prop="status">
8078
<template #default="scope">
8179
<dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="scope.row.status" />
8280
</template>
8381
</el-table-column>
8482
<el-table-column
85-
label="创建时间"
83+
:formatter="dateFormatter"
8684
align="center"
85+
label="创建时间"
8786
prop="createTime"
8887
width="180"
89-
:formatter="dateFormatter"
9088
/>
91-
<el-table-column label="操作" align="center">
89+
<el-table-column align="center" label="操作">
9290
<template #default="scope">
9391
<el-button
92+
v-hasPermi="['trade:delivery:pick-up-store:update']"
9493
link
9594
type="primary"
9695
@click="openForm('update', scope.row.id)"
97-
v-hasPermi="['trade:delivery:pick-up-store:update']"
9896
>
9997
编辑
10098
</el-button>
10199
<el-button
100+
v-hasPermi="['trade:delivery:pick-up-store:delete']"
102101
link
103102
type="danger"
104103
@click="handleDelete(scope.row.id)"
105-
v-hasPermi="['trade:delivery:pick-up-store:delete']"
106104
>
107105
删除
108106
</el-button>
@@ -113,18 +111,17 @@
113111
<!-- 表单弹窗:添加/修改 -->
114112
<DeliveryPickUpStoreForm ref="formRef" @success="getList" />
115113
</template>
116-
<script setup lang="ts" name="DeliveryPickUpStore">
114+
<script lang="ts" name="DeliveryPickUpStore" setup>
117115
import * as DeliveryPickUpStoreApi from '@/api/mall/trade/delivery/pickUpStore'
118116
import DeliveryPickUpStoreForm from './PickUpStoreForm.vue'
119117
import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
120118
import { dateFormatter } from '@/utils/formatTime'
121-
import download from '@/utils/download'
119+
122120
const message = useMessage() // 消息弹窗
123121
const { t } = useI18n() // 国际化
124122
125123
const total = ref(0) // 列表的总页数
126124
const loading = ref(true) // 列表的加载中
127-
const exportLoading = ref(false) // 导出的加载中
128125
const list = ref<any[]>([]) // 列表的数据
129126
const queryParams = reactive({
130127
pageNo: 1,
@@ -179,21 +176,6 @@ const resetQuery = () => {
179176
handleQuery()
180177
}
181178
182-
/** 导出按钮操作 */
183-
const handleExport = async () => {
184-
try {
185-
// 导出的二次确认
186-
await message.exportConfirm()
187-
// 发起导出
188-
exportLoading.value = true
189-
const data = await DeliveryPickUpStoreApi.exportDeliveryPickUpStoreApi(queryParams)
190-
download.excel(data, '自提门店.xls')
191-
} catch {
192-
} finally {
193-
exportLoading.value = false
194-
}
195-
}
196-
197179
/** 初始化 **/
198180
onMounted(() => {
199181
getList()

src/views/mall/trade/order/index.vue

Lines changed: 57 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -64,8 +64,34 @@
6464
/>
6565
</el-select>
6666
</el-form-item>
67-
68-
<el-form-item label="订单搜索">
67+
<el-form-item label="快递公司" prop="type">
68+
<el-select v-model="queryParams.logisticsId" class="!w-280px" clearable placeholder="全部">
69+
<el-option
70+
v-for="item in deliveryExpressList"
71+
:key="item.id as string"
72+
:label="item.name"
73+
:value="item.id"
74+
/>
75+
</el-select>
76+
</el-form-item>
77+
<el-form-item label="自提门店" prop="type">
78+
<el-select
79+
v-model="queryParams.pickUpStoreId"
80+
class="!w-280px"
81+
clearable
82+
multiple
83+
placeholder="全部"
84+
>
85+
<el-option
86+
v-for="item in pickUpStoreList"
87+
:key="item.id as string"
88+
:label="item.name"
89+
:value="item.id"
90+
/>
91+
</el-select>
92+
</el-form-item>
93+
<!-- TODO 考虑是否移除或重构-->
94+
<el-form-item label="聚合搜索">
6995
<el-input
7096
v-show="true"
7197
v-model="queryType.v"
@@ -86,7 +112,6 @@
86112
</el-input>
87113
</el-form-item>
88114
<el-form-item>
89-
<!-- TODO 订单按钮相关权限等订单完善后补齐 -->
90115
<el-button @click="handleQuery">
91116
<Icon class="mr-5px" icon="ep:search" />
92117
搜索
@@ -153,13 +178,31 @@
153178
</el-table-column>
154179
<el-table-column label="买家/收货人" min-width="160">
155180
<template #default>
156-
<div class="flex flex-col">
181+
<!-- 快递发货 -->
182+
<div v-if="scope.row.deliveryType === 1" class="flex flex-col">
157183
<span>买家:{{ scope.row.user.nickname }}</span>
158184
<span>
159185
收货人:{{ scope.row.receiverName }} {{ scope.row.receiverMobile }}
160186
{{ scope.row.receiverAreaName }} {{ scope.row.receiverDetailAddress }}
161187
</span>
162188
</div>
189+
<!-- 自提 -->
190+
<div v-if="scope.row.deliveryType === 2" class="flex flex-col">
191+
<span>
192+
门店名称:
193+
{{ pickUpStoreList.find((p) => p.id === scope.row.pickUpStoreId)?.name }}
194+
</span>
195+
<span>
196+
门店手机:
197+
{{ pickUpStoreList.find((p) => p.id === scope.row.pickUpStoreId)?.phone }}
198+
</span>
199+
<span>
200+
自提门店:
201+
{{
202+
pickUpStoreList.find((p) => p.id === scope.row.pickUpStoreId)?.detailAddress
203+
}}
204+
</span>
205+
</div>
163206
</template>
164207
</el-table-column>
165208
<el-table-column align="center" label="配送方式" width="120">
@@ -169,6 +212,7 @@
169212
</el-table-column>
170213
<el-table-column align="center" fixed="right" label="操作" width="160">
171214
<template #default>
215+
<!-- TODO 权限后续补齐 -->
172216
<div class="flex justify-center items-center">
173217
<el-button link type="primary" @click="openForm(scope.row.id)">
174218
<Icon icon="ep:notification" />
@@ -263,9 +307,11 @@ import OrderRemarksForm from './components/OrderRemarksForm.vue'
263307
import { dateFormatter } from '@/utils/formatTime'
264308
import * as TradeOrderApi from '@/api/mall/trade/order'
265309
import { OrderItemRespVO, OrderVO } from '@/api/mall/trade/order'
310+
import { getListAllSimple } from '@/api/mall/trade/delivery/pickUpStore'
266311
import { DICT_TYPE, getStrDictOptions } from '@/utils/dict'
267312
import { formatToFraction } from '@/utils'
268313
import { createImageViewer } from '@/components/ImageViewer'
314+
import * as DeliveryExpressApi from '@/api/mall/trade/delivery/express'
269315
270316
const { currentRoute, push } = useRouter() // 路由跳转
271317
@@ -320,7 +366,7 @@ const handleCommand = (command: string, row: OrderVO) => {
320366
}
321367
}
322368
const queryFormRef = ref<FormInstance>() // 搜索的表单
323-
//表单搜索 TODO 订单相关操作完成后立马实现
369+
//表单搜索
324370
const queryParams = reactive({
325371
pageNo: 1, //首页
326372
pageSize: 10, //页面大小
@@ -337,6 +383,8 @@ const queryParams = reactive({
337383
createTime: [],
338384
spuName: '',
339385
itemCount: '',
386+
pickUpStoreId: [],
387+
logisticsId: null,
340388
all: ''
341389
})
342390
@@ -383,8 +431,12 @@ watch(
383431
}
384432
)
385433
434+
const pickUpStoreList = ref([]) // 自提门店精简列表
435+
const deliveryExpressList = ref([]) // 物流公司
386436
/** 初始化 **/
387437
onMounted(async () => {
388438
await getList()
439+
pickUpStoreList.value = await getListAllSimple()
440+
deliveryExpressList.value = await DeliveryExpressApi.getSimpleDeliveryExpressList()
389441
})
390442
</script>

0 commit comments

Comments
 (0)