This commit is contained in:
KangKang0928 2025-01-03 17:56:36 +08:00
commit 42b5c3ae76
19 changed files with 1753 additions and 541 deletions

View File

@ -212,11 +212,19 @@ export const mer_admin = {
params: data, params: data,
}); });
}, },
//订单管理 //全部订单管理
orderPage: (data) => { orderPage: (data) => {
return $http.request({ return $http.request({
method: "get", method: "get",
url: `/merchant-api/order/page`, url: `/merchant-api/manager/order/page`,
params: data,
});
},
//根据店铺查询订单
shopOrderPage: (data) => {
return $http.request({
method: "get",
url: `/merchant-api/manager/merchant/order/page`,
params: data, params: data,
}); });
}, },

View File

@ -77,6 +77,20 @@ export default {
open: null, open: null,
list: [], list: [],
}, },
{
menuId: getUUID(),
parentId: 0,
parentName: null,
name: "总订单管理",
url: "operation-management/total-order/index",
perms: "",
type: 1,
elIcon: "el-icon-menu",
orderNum: 0,
open: null,
list: [],
hideInMenu: true,
},
{ {
menuId: getUUID(), menuId: getUUID(),
parentId: 0, parentId: 0,

View File

@ -86,7 +86,7 @@ const router = new Router({
}); });
router.beforeEach((to, from, next) => { router.beforeEach((to, from, next) => {
console.log("beforeEach"); console.log("beforeEach", to);
// 添加动态(菜单)路由 // 添加动态(菜单)路由
// 1. 已经添加 or 全局路由, 直接访问 // 1. 已经添加 or 全局路由, 直接访问
// 2. 获取菜单列表, 添加并保存本地存储 // 2. 获取菜单列表, 添加并保存本地存储

View File

@ -168,6 +168,8 @@ export function getMenu(role) {
"wallet/index", "wallet/index",
"ogistics-fare", "ogistics-fare",
"logistics-fare/logistics-template/index", "logistics-fare/logistics-template/index",
"bank-card/index",
"operation-management/total-order/index"
]; ];
} else if (role == "ROLE_BRAND_MANAGER") { } else if (role == "ROLE_BRAND_MANAGER") {
return [ return [

View File

@ -5,8 +5,15 @@
:default-active="menuActiveName || 'home'" :default-active="menuActiveName || 'home'"
:collapse="sidebarFold" :collapse="sidebarFold"
:collapseTransition="false" :collapseTransition="false"
class="site-sidebar__menu"> class="site-sidebar__menu"
<el-input v-show="showSearchInput" class="search-input" v-model="keyWord" style="width" placeholder="快速搜索菜单"></el-input> >
<el-input
v-show="showSearchInput"
class="search-input"
v-model="keyWord"
style="width"
placeholder="快速搜索菜单"
></el-input>
<el-menu-item index="home" @click="$router.push({ name: 'home' })"> <el-menu-item index="home" @click="$router.push({ name: 'home' })">
<icon-svg name="shouye" class="site-sidebar__menu-icon"></icon-svg> <icon-svg name="shouye" class="site-sidebar__menu-icon"></icon-svg>
<span slot="title">首页</span> <span slot="title">首页</span>
@ -29,7 +36,8 @@
v-for="menu in filterMenu" v-for="menu in filterMenu"
:key="menu.menuId" :key="menu.menuId"
:menu="menu" :menu="menu"
:dynamicMenuRoutes="dynamicMenuRoutes"> :dynamicMenuRoutes="dynamicMenuRoutes"
>
</sub-menu> </sub-menu>
</el-menu> </el-menu>
</div> </div>
@ -37,41 +45,61 @@
</template> </template>
<script> <script>
import SubMenu from './main-sidebar-sub-menu' import SubMenu from "./main-sidebar-sub-menu";
import { isURL } from '@/utils/validate' import { isURL } from "@/utils/validate";
export default { export default {
data() { data() {
return { return {
dynamicMenuRoutes: [], dynamicMenuRoutes: [],
// //
keyWord:"" keyWord: "",
} };
}, },
components: { components: {
SubMenu SubMenu,
}, },
computed: { computed: {
sidebarLayoutSkin: { sidebarLayoutSkin: {
get () { return this.$store.state.common.sidebarLayoutSkin } get() {
return this.$store.state.common.sidebarLayoutSkin;
},
}, },
sidebarFold: { sidebarFold: {
get () { return this.$store.state.common.sidebarFold } get() {
return this.$store.state.common.sidebarFold;
},
}, },
menuList: { menuList: {
get () { return this.$store.state.common.menuList }, get() {
set (val) { this.$store.commit('common/updateMenuList', val) } return this.$store.state.common.menuList;
},
set(val) {
this.$store.commit("common/updateMenuList", val);
},
}, },
menuActiveName: { menuActiveName: {
get () { return this.$store.state.common.menuActiveName }, get() {
set (val) { this.$store.commit('common/updateMenuActiveName', val) } return this.$store.state.common.menuActiveName;
},
set(val) {
this.$store.commit("common/updateMenuActiveName", val);
},
}, },
mainTabs: { mainTabs: {
get () { return this.$store.state.common.mainTabs }, get() {
set (val) { this.$store.commit('common/updateMainTabs', val) } return this.$store.state.common.mainTabs;
},
set(val) {
this.$store.commit("common/updateMainTabs", val);
},
}, },
mainTabsActiveName: { mainTabsActiveName: {
get () { return this.$store.state.common.mainTabsActiveName }, get() {
set (val) { this.$store.commit('common/updateMainTabsActiveName', val) } return this.$store.state.common.mainTabsActiveName;
},
set(val) {
this.$store.commit("common/updateMainTabsActiveName", val);
},
}, },
// //
filterMenu() { filterMenu() {
@ -81,57 +109,71 @@
if (item.name.includes(keyWord)) return true; if (item.name.includes(keyWord)) return true;
if (item.list && item.list.length > 0) { if (item.list && item.list.length > 0) {
// //
return (item.list=item.list.filter(f)).length return (item.list = item.list.filter(f)).length;
} }
}) });
} };
let filterMenu=filterMethod(JSON.parse(JSON.stringify(this.menuList)),this.keyWord); let filterMenu = filterMethod(
console.log(filterMenu); JSON.parse(JSON.stringify(this.menuList)),
return filterMenu.filter(item=>item.hideInMenu!=true); this.keyWord
);
console.log(filterMenu, "filterMenu");
return filterMenu.filter((item) => {
item.list = item.list.filter((prop) => prop.hideInMenu != true);
return item.hideInMenu != true;
});
}, },
// //
showSearchInput() { showSearchInput() {
return this.$store.state.common.sidebarFold==false return this.$store.state.common.sidebarFold == false;
} },
}, },
watch: { watch: {
$route: 'routeHandle' $route: "routeHandle",
}, },
created() { created() {
this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]') this.menuList = JSON.parse(sessionStorage.getItem("menuList") || "[]");
this.dynamicMenuRoutes = JSON.parse(sessionStorage.getItem('dynamicMenuRoutes') || '[]') this.dynamicMenuRoutes = JSON.parse(
this.routeHandle(this.$route) sessionStorage.getItem("dynamicMenuRoutes") || "[]"
);
this.routeHandle(this.$route);
}, },
methods: { methods: {
// //
routeHandle(route) { routeHandle(route) {
if (route.meta.isTab) { if (route.meta.isTab) {
// tab, // tab,
var tab = this.mainTabs.filter(item => item.name === route.name)[0] var tab = this.mainTabs.filter((item) => item.name === route.name)[0];
if (!tab) { if (!tab) {
if (route.meta.isDynamic) { if (route.meta.isDynamic) {
route = this.dynamicMenuRoutes.filter(item => item.name === route.name)[0] route = this.dynamicMenuRoutes.filter(
(item) => item.name === route.name
)[0];
if (!route) { if (!route) {
return console.error('未能找到可用标签页!') return console.error("未能找到可用标签页!");
} }
} }
tab = { tab = {
menuId: route.meta.menuId || route.name, menuId: route.meta.menuId || route.name,
name: route.name, name: route.name,
title: route.meta.title, title: route.meta.title,
type: route.meta.isMicroApp?'microApp' : (isURL(route.meta.iframeUrl) ? 'iframe' : 'module'), type: route.meta.isMicroApp
iframeUrl: route.meta.iframeUrl || '', ? "microApp"
: isURL(route.meta.iframeUrl)
? "iframe"
: "module",
iframeUrl: route.meta.iframeUrl || "",
params: route.params, params: route.params,
query: route.query query: route.query,
} };
this.mainTabs = this.mainTabs.concat(tab) this.mainTabs = this.mainTabs.concat(tab);
}
this.menuActiveName = tab.menuId + ''
this.mainTabsActiveName = tab.name
}
}
} }
this.menuActiveName = tab.menuId + "";
this.mainTabsActiveName = tab.name;
} }
},
},
};
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.search-input { .search-input {

View File

@ -3,6 +3,7 @@
<obj-modal <obj-modal
ref="modal" ref="modal"
labelWidth="190px" labelWidth="190px"
class="popup"
:modalCols="modalCols" :modalCols="modalCols"
:modalConfig="modalConfig" :modalConfig="modalConfig"
:modalData="modalData" :modalData="modalData"
@ -316,4 +317,8 @@ export default {
}; };
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.popup ::v-deep .el-dialog__body {
overflow-y: scroll !important;
height: 65vh !important;
}
</style> </style>

View File

@ -105,7 +105,7 @@
<!-- 新粉优惠卷 --> <!-- 新粉优惠卷 -->
<newPowder @queryList="$refs.oTable.reload()" ref="newPowder"></newPowder> <newPowder @queryList="$refs.oTable.reload()" ref="newPowder"></newPowder>
<!-- 查看详情 --> <!-- 查看详情 -->
<!-- <viewDetails ref="viewDetails"></viewDetails> --> <viewDetails ref="viewDetails"></viewDetails>
</div> </div>
</template> </template>
@ -114,9 +114,9 @@ import { mapState } from "vuex";
import fullReductio from "./popup/full-reduction.vue"; import fullReductio from "./popup/full-reduction.vue";
import AddOrUpdate from "./popup/add-or-update.vue"; import AddOrUpdate from "./popup/add-or-update.vue";
import newPowder from "./popup/new-powder.vue"; import newPowder from "./popup/new-powder.vue";
// import viewDetails from "./popup/view-details.vue"; import viewDetails from "./popup/view-details.vue";
export default { export default {
components: { AddOrUpdate, fullReductio, newPowder }, components: { AddOrUpdate, fullReductio, newPowder, viewDetails },
data() { data() {
return { return {
dataList: [], dataList: [],
@ -406,9 +406,9 @@ export default {
type: "jsx", type: "jsx",
align: "center", align: "center",
width: "140px", width: "140px",
render: (row) => { render: ({ row }) => {
let edit = () => { let edit = () => {
// this.$refs.viewDetails.toggle(row).update(); this.$refs.viewDetails.toggle(row).update();
}; };
return ( return (
<div> <div>

View File

@ -0,0 +1,188 @@
<template>
<div>
<obj-modal
ref="modal"
labelWidth="150px"
:modalConfig="modalConfig"
:modalData="modalData"
:modalHandles="modalHandles"
>
<div slot="dialog__content">
<el-form
:model="ruleForm"
ref="ruleForm"
label-width="150px"
class="demo-ruleForm"
>
<el-row>
<el-col :span="8">
<el-form-item label="优惠卷名称:">
<span>{{ ruleForm.name }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="优惠卷类别:">
<span>{{ getCategory(ruleForm.category) }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="优惠金额:">
<span>{{ ruleForm.money }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="最低消费:">
<span>{{ ruleForm.minPrice }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="领取限量:">
<span>{{ ruleForm.limitedNum }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="发放总数:">
<span>{{ ruleForm.total }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="剩余数量:">
<span>{{ ruleForm.lastTotal }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="可领取开始时间:">
<span>{{ ruleForm.receiveStartTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="可领取结束时间:">
<span>{{ ruleForm.receiveEndTime }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="使用时间范围开始时间:">
<span>{{ ruleForm.useStartTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="可使用时间范围结束时间:">
<span>{{ ruleForm.useEndTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="状态:">
<span>{{ ruleForm.status == 1 ? "开启" : "结束" }}</span>
</el-form-item></el-col
>
</el-row>
</el-form>
</div>
<!-- 选择商品 -->
</obj-modal>
</div>
</template>
<script>
import { debounce, cloneDeep } from "lodash";
export default {
components: {},
props: {},
data() {
return {
isAdd: true,
//
modalConfig: {
title: "优惠卷详情",
show: false,
width: "1200px",
fullscreen: true,
},
modalData: {},
ruleForm: {},
tableData: [],
};
},
watch: {
// "modalConfig.show"(newVal) {
// if (newVal) {
// //
// setTimeout(() => {
// this.$refs.ruleForm.resetFields();
// });
// }
// },
},
methods: {
queryTableData(pageNo, pageSize) {},
toggle(e) {
if (this.modalConfig.show == false) {
this.modalConfig.show = true;
} else {
this.modalConfig.show = false;
}
if (e) {
this.init(cloneDeep(e));
}
return {
add: () => {
this.modalConfig.title = "订单详情";
this.isAdd = true;
},
update: () => {
this.modalConfig.title = "优惠卷详情";
this.isAdd = false;
},
};
},
init(row) {
console.log(row);
this.ruleForm = JSON.parse(JSON.stringify(row));
console.log(this.ruleForm);
},
handleSelectionChange(e) {
console.log(e);
},
getCategory(val) {
if (val == "NO_THRESHOLD") {
return "无门槛优惠券"
} else if (val == "MAX_OUT") {
return "满减优惠券"
} else if (val == "FIRST_ATTENTION") {
return "首次关注优惠券"
} else if (val == "BIRTHDAY") {
return "生日券"
} else if (val == "PLATFORM") {
return "平台优惠券"
}
},
},
computed: {
modalHandles() {
return [
{
label: "关闭",
handle: () => {
this.toggle();
},
},
// {
// label: "",
// type: "primary",
// // submit: true,
// handle: () => {
// },
// },
];
},
},
asyncComputed: {},
};
</script>
<style lang="scss" scoped>
</style>

View File

@ -12,7 +12,7 @@
> >
<template slot="tableTop"> <template slot="tableTop">
<el-form :inline="true" :model="formInline" class="demo-form-inline"> <el-form :inline="true" :model="formInline" class="demo-form-inline">
<el-form-item label="模块"> <!-- <el-form-item label="模块">
<el-select <el-select
@change="changeModule" @change="changeModule"
class="filter-item" class="filter-item"
@ -72,7 +72,7 @@
> >
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item> -->
<el-form-item label="应用"> <el-form-item label="应用">
<el-select <el-select
class="filter-item" class="filter-item"
@ -142,7 +142,7 @@ export default {
formInline: { formInline: {
type: 0, type: 0,
ownerId: "", ownerId: "",
module: "shop", module: "",
}, },
tableProp: { tableProp: {
"auto-resize": true, "auto-resize": true,
@ -176,12 +176,24 @@ export default {
}; };
}, },
created() { created() {
if (
JSON.parse(sessionStorage.getItem("userInfo")).role === "ROLE_MANAGER"
) {
this.formInline = {
type: 0,
ownerId: this.marketId,
module: "market",
app: 1,
};
} else {
this.formInline = { this.formInline = {
type: 0, type: 0,
ownerId: this.shopId, ownerId: this.shopId,
module: "shop", module: "shop",
app: 1, app: 1,
}; };
}
this.$nextTick(() => { this.$nextTick(() => {
this.$refs.oTable.reload(); this.$refs.oTable.reload();
}); });
@ -261,8 +273,8 @@ export default {
return ( return (
<el-image <el-image
style="width: 60px; height: 60px" style="width: 60px; height: 60px"
src={row.img} src={row.img.split(",")[0]}
preview-src-list={[row.img]} preview-src-list={row.img.split(",")}
></el-image> ></el-image>
); );
}, },

View File

@ -3,6 +3,7 @@
<obj-modal <obj-modal
ref="modal" ref="modal"
labelWidth="150px" labelWidth="150px"
class="popup"
:modalCols="modalCols" :modalCols="modalCols"
:modalConfig="modalConfig" :modalConfig="modalConfig"
:modalData="modalData" :modalData="modalData"
@ -77,12 +78,12 @@ export default {
}, },
init(row) { init(row) {
this.modalData = row; this.modalData = row;
this.fileList = [ this.fileList = row.img.split(",").map((item) => {
{ return {
name: "轮播图", name: "轮播图",
url: this.modalData.img, url: item,
}, };
]; });
}, },
}, },
computed: { computed: {
@ -100,40 +101,40 @@ export default {
trigger: "blur", trigger: "blur",
}, },
}, },
{ // {
label: "分类", // label: "",
prop: "type", // prop: "type",
maxlength: "30", // maxlength: "30",
rules: { // rules: {
required: true, // required: true,
message: "请输入轮播图名称", // message: "",
trigger: "blur", // trigger: "blur",
}, // },
type: "jsx", // type: "jsx",
render: () => { // render: () => {
return ( // return (
<el-select // <el-select
v-model={this.modalData.type} // v-model={this.modalData.type}
placeholder="请选择销售单位" // placeholder=""
> // >
{[ // {[
{ label: "菜市场", value: 0 }, // { label: "", value: 0 },
{ // {
label: "云店", // label: "",
value: 1, // value: 1,
}, // },
].map((item) => { // ].map((item) => {
return ( // return (
<el-option // <el-option
label={item.label} // label={item.label}
value={item.value} // value={item.value}
></el-option> // ></el-option>
); // );
})} // })}
</el-select> // </el-select>
); // );
}, // },
}, // },
{ {
label: "状态", label: "状态",
prop: "status", prop: "status",
@ -200,18 +201,27 @@ export default {
render: () => { render: () => {
const handleAvatarSuccess = (res, file, fileList) => { const handleAvatarSuccess = (res, file, fileList) => {
console.log(res, fileList); console.log(res, fileList);
this.modalData.img = res.data; this.modalData.img = fileList
.map((item) => {
return item.response.data;
})
.join(",");
console.log(this.modalData.img);
this.$refs.modal.validate(); this.$refs.modal.validate();
}; };
const handleRemove = (file, fileList) => { const handleRemove = (file, fileList) => {
console.log(file, fileList); console.log(file, fileList);
this.fileList = []; this.modalData.img = fileList
this.modalData.img = ""; .map((item) => {
return item.response.data;
})
.join(",");
}; };
return ( return (
<el-upload <el-upload
class="upload-demo" class="upload-demo"
drag drag
limit={3}
action={this.$api.mer_admin.uploadFile()} action={this.$api.mer_admin.uploadFile()}
{...{ {...{
props: { props: {
@ -273,4 +283,8 @@ export default {
}; };
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.popup ::v-deep .el-dialog__body {
overflow-y: scroll !important;
height: 65vh !important;
}
</style> </style>

View File

@ -12,7 +12,7 @@
> >
<template slot="tableTop"> <template slot="tableTop">
<el-form :inline="true" :model="formInline" class="demo-form-inline"> <el-form :inline="true" :model="formInline" class="demo-form-inline">
<el-form-item label="模块"> <!-- <el-form-item label="模块">
<el-select <el-select
@change="changePosition" @change="changePosition"
class="filter-item" class="filter-item"
@ -39,7 +39,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item <el-form-item
v-if="storeList.length > 1 && formInline.position === '1'" v-if="storeList.length > 1 && formInline.position === '3'"
label="摊铺" label="摊铺"
> >
<el-select <el-select
@ -72,7 +72,7 @@
> >
</el-option> </el-option>
</el-select> </el-select>
</el-form-item> </el-form-item> -->
<el-form-item label="应用"> <el-form-item label="应用">
<el-select <el-select
class="filter-item" class="filter-item"
@ -176,12 +176,23 @@ export default {
}; };
}, },
created() { created() {
if (
JSON.parse(sessionStorage.getItem("userInfo")).role === "ROLE_MANAGER"
) {
this.formInline = { this.formInline = {
type: 0, type: 0,
targetId: this.shopId, targetId: this.marketId,
position: "2",
app: 1,
};
} else {
this.formInline = {
type: 0,
ownerId: this.shopId,
position: "3", position: "3",
app: 1, app: 1,
}; };
}
this.$nextTick(() => { this.$nextTick(() => {
this.$refs.oTable.reload(); this.$refs.oTable.reload();
}); });
@ -202,7 +213,9 @@ export default {
this.$refs.addOrUpdate.toggle().add(this.formInline); this.$refs.addOrUpdate.toggle().add(this.formInline);
}, },
changePosition(e) { changePosition(e) {
if (e === "shop") { console.log(e, this.shopId, this.marketId);
if (e == 3) {
this.formInline.targetId = this.shopId; this.formInline.targetId = this.shopId;
} else { } else {
this.formInline.targetId = this.marketId; this.formInline.targetId = this.marketId;

View File

@ -1,29 +1,12 @@
<template> <template>
<div style="height: calc(100vh - 200px)"> <div style="height: calc(100vh - 200px)">
<obj-table-plus <el-form
ref="oTable" v-if="storeList.length > 1"
style="height: 100%" :inline="true"
:tableCols="tableCols" :model="formInline"
:tableProp="tableProp" class="demo-form-inline"
@query="queryList"
v-model="dataList"
:tableEvent="tableEvent"
:enableAutoQuery="false"
> >
<template slot="tableTop"> <el-form-item label="摊铺">
<el-form :inline="true" :model="formInline" class="demo-form-inline">
<el-form-item label="订单号">
<el-select v-model="formInline.group" placeholder="请选择">
<el-option
v-for="item in statusList"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item v-if="storeList.length > 1" label="摊铺">
<el-select <el-select
class="filter-item" class="filter-item"
style="width: 200px" style="width: 200px"
@ -40,27 +23,86 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" @click="$refs.oTable.reload()" <el-button type="primary" @click="getList">查询</el-button>
>查询</el-button
>
<el-button type="primary" @click="Reset">重置</el-button> <el-button type="primary" @click="Reset">重置</el-button>
<el-button
type="success"
@click="
$router.push({ name: 'operation-management-total-order/index' })
"
>菜市场总订单</el-button
>
</el-form-item> </el-form-item>
</el-form> </el-form>
<!-- <el-tabs v-model="activeName" @tab-click="handleClick"> <el-tabs v-model="formInline.group" @tab-click="handleClick">
<el-tab-pane <el-tab-pane
v-for="item in statusList" v-for="item in statusList"
:key="item.value" :key="item.value"
:label="item.label" :label="item.label"
:name="item.value" :name="item.value"
></el-tab-pane> ></el-tab-pane>
</el-tabs> --> </el-tabs>
<!-- <div class="mb-2"> <el-table :data="tableData" height="70vh" border style="width: 100%">
<el-button type="primary" size="small" @click="addProduct" <el-table-column type="expand">
>批量导出</el-button <template slot-scope="props">
<div style="padding-left: 20px" m="4">
<el-table :data="props.row.productOrders" :border="true">
<el-table-column type="index" width="50" label="序号">
</el-table-column>
<el-table-column label="商品订单号" prop="productOrderNo" />
<el-table-column label="商品名称" prop="productName" />
<el-table-column label="商品原价" prop="originPrice" />
<el-table-column label="商品终价" prop="finalPrice" />
<el-table-column label="商品订单金额" prop="productOrderMoney" />
<el-table-column label="商品数量" prop="productCount" />
<el-table-column label="商品单价" prop="productFinalPrice" />
<el-table-column label="商品图片" prop="productImg">
<template slot-scope="scope">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.productImg"
:preview-src-list="[scope.row.productImg]"
> >
</div> --> </el-image>
</template> </template>
</obj-table-plus> </el-table-column>
</el-table>
</div>
</template>
</el-table-column>
<el-table-column label="总订单号" prop="orderNo" />
<el-table-column label="结算单位订单号" prop="unitOrderNo" />
<el-table-column label="总商品数量" prop="productCount" />
<el-table-column label="顾客实际支付" prop="totalMoney" />
<el-table-column label="商品总价" prop="productMoney" />
<el-table-column label="配送费" prop="deliveryMoney" />
<el-table-column label="优惠券减免" prop="couponMoney" />
<el-table-column label="支付时间" prop="payTime" />
<el-table-column label="预计送达时间" prop="predictDeliveryTime" />
<el-table-column label="预计收入" prop="predictIncome" />
<el-table-column label="距离" prop="distance" />
<el-table-column label="备注" prop="remark" />
<el-table-column fixed="right" width="100px" label="操作" align="center">
<template slot-scope="scope">
<el-button type="primary" size="mini" @click="view(scope.row)">
查看
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<div class="pagination-container">
<el-pagination
:current-page="formInline.pageNumber"
:page-sizes="[10, 20, 30, 50]"
:page-size="formInline.pageSize"
:total="total"
background
layout="total, sizes, prev, pager, next, jumper"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
/>
</div>
<!-- 订单详情 --> <!-- 订单详情 -->
<viewDetails ref="viewDetails"></viewDetails> <viewDetails ref="viewDetails"></viewDetails>
</div> </div>
@ -68,120 +110,62 @@
<script> <script>
import viewDetails from "./popup/view-details.vue"; import viewDetails from "./popup/view-details.vue";
import content from "./popup/content.vue";
import { mapState } from "vuex"; import { mapState } from "vuex";
export default { export default {
components: { content,viewDetails }, components: { viewDetails },
data() { data() {
return { return {
activeName: "5",
value1: "1",
advanceSellStatus: "",
dataList: [],
formInline: { formInline: {
group: "", group: "",
shopId: "", shopId: "",
}, pageNumber: 1,
tableProp: { pageSize: 10,
"auto-resize": true,
border: true,
height: "auto",
"row-id": "id",
"show-overflow": false,
}, },
statusList: [ statusList: [
{ {
label: "历史订单", label: "全部订单",
value: "0", value: "0",
}, },
{ {
label: "进行中", label: "待备货",
value: "1", value: "1",
}, },
{ {
label: "新订单", label: "待取货",
value: "2", value: "2",
}, },
{ {
label: "待货", label: "待货",
value: "3", value: "3",
}, },
{ {
label: "待配送", label: "已完成",
value: "4", value: "4",
}, },
{
label: "售后订单",
value: "5",
},
], ],
productFilterType: "SALE", tableData: [],
selectList: [], total: 0,
}; };
}, },
created() { created() {
this.formInline = { this.formInline = {
group: "0", group: "0",
// marketId: this.marketId,
shopId: this.shopId, shopId: this.shopId,
}; };
this.$nextTick(() => { this.getList();
this.$refs.oTable.reload();
});
}, },
methods: { methods: {
// getData() { getList() {
// this.$api.mer_admin //
// .storeList({ marketId: this.formInline.marketId })
// .then((res) => {
// this.storeList = res.data.data;
// this.formInline.shopId = res.data.data[0].shopId;
// this.$nextTick(() => {
// this.$refs.oTable.reload();
// });
// });
// },
addProduct() {
this.$refs.addOrUpdate.toggle().add();
},
deleteProduct() {
console.log(this.selectList);
let integers = this.selectList.map((item) => {
return item.id;
});
this.$confirm("此操作将删除该商品, 是否继续?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning",
})
.then(() => {
console.log("111");
this.$api.mer_admin.BatchDeleteProducts(integers).then((res) => {
this.$refs.oTable.reload();
});
})
.catch(() => {
this.$message({
type: "info",
message: "已取消删除",
});
});
},
queryList(pageNo, pageSize) {
this.$api.mer_admin this.$api.mer_admin
.orderPage({ .shopOrderPage({
pageNumber: pageNo,
pageSize: pageSize,
...this.formInline, ...this.formInline,
}) })
.then((res) => { .then((res) => {
console.log(res); console.log(res);
this.$refs.oTable.complete( this.tableData = res.data.data.data;
res.data.data.data, this.total = Number(res.data.data.total);
Number(res.data.data.total)
);
})
.catch((err) => {
this.$refs.oTable.complete(false);
}); });
}, },
Reset() { Reset() {
@ -189,215 +173,25 @@ export default {
group: "0", group: "0",
shopId: this.shopId, shopId: this.shopId,
}; };
this.$refs.oTable.reload(); this.getList();
}, },
handleClick(e) { handleClick(e) {
console.log(e.name);
if (e.name == "5") {
this.advanceSellStatus = "";
} else {
this.advanceSellStatus = e.name; this.advanceSellStatus = e.name;
} this.getList();
this.$refs.oTable.reload();
}, },
addEarlyWarning() { view(row) {
this.$refs.earlyWarning.toggle().add(); this.$refs.viewDetails.toggle(row).update();
},
handleSizeChange(val) {
this.formInline.pageSize = val;
this.getList();
},
handleCurrentChange(val) {
this.formInline.pageNumber = val;
this.getList();
}, },
}, },
computed: { computed: {
tableCols() {
return [
// { type: "checkbox", width: "60px", fixed: "left" },
{
type: "seq",
width: "60px",
fixed: "left",
align: "center",
title: "序号",
},
{
title: "商品详情",
// align: "center",
// width: "120px",
// field: "unitOrderStatus",
type: "jsx-out",
render: (col) => {
console.log(col);
return <content />;
},
},
{
title: "总订单号",
align: "center",
width: "120px",
field: "orderNo",
},
{
title: "结算单位订单号",
align: "center",
width: "120px",
field: "unitOrderNo",
},
{
title: "总商品数量",
align: "center",
width: "120px",
field: "productCount",
},
{
title: "顾客支付",
align: "center",
width: "120px",
field: "totalMoney",
},
{
title: "配送费",
align: "center",
width: "120px",
field: "deliveryMoney",
},
{
title: "优惠券减免",
align: "center",
width: "120px",
field: "couponMoney",
},
{
title: "下单时间",
align: "center",
width: "120px",
field: "payTime",
},
{
title: "预计送达时间",
align: "center",
width: "120px",
field: "predictDeliveryTime",
},
{
title: "预计收入",
align: "center",
width: "120px",
field: "predictIncome",
},
{
title: "距离",
align: "center",
width: "120px",
field: "distance",
},
{
title: "预计自动取消时间",
align: "center",
width: "120px",
field: "predictAutoCancelTime",
},
{
title: "备注",
align: "center",
width: "120px",
field: "remark",
},
{
title: "包装费",
align: "center",
width: "120px",
field: "packageMoney",
},
{
title: "平台服务费",
align: "center",
width: "120px",
field: "platformMoney",
},
{
title: "备餐完成时间",
align: "center",
width: "120px",
field: "completePrepareTime",
},
{
title: "开始配送时间",
align: "center",
width: "120px",
field: "startDeliveryTime",
},
{
title: "配送完成时间",
align: "center",
width: "120px",
field: "startDeliveryTime",
},
{
title: "开始配送时间",
align: "center",
width: "120px",
field: "startDeliveryTime",
},
{
title: "订单退款状态",
align: "center",
width: "120px",
field: "refundStatus",
},
{
title: "申请退款原因",
align: "center",
width: "120px",
field: "refundReason",
},
{
title: "订单商品",
field: "productPhotoList",
align: "center",
width: "80px",
type: "jsx",
render: ({ row }) => {
return (
<el-image
preview-src-list={[row.refundImg]}
src={row.refundImg}
></el-image>
);
},
},
{
title: "申请退款时间",
align: "center",
width: "120px",
field: "applyRefundTime",
},
{
title: "操作",
fixed: "right",
type: "jsx",
align: "center",
width: "100px",
render: ({ row }) => {
let changeInventory = () => {
this.$refs.addStock.toggle(row).update();
};
return (
<div>
<el-button size="mini" type="primary" onClick={changeInventory}>
查看
</el-button>
</div>
);
},
},
];
},
tableEvent() {
return {
"checkbox-all": ({ records, reserves }) => {
this.selectList = [...records, ...reserves];
},
"checkbox-change": ({ records, reserves }) => {
this.selectList = [...records, ...reserves];
},
};
},
...mapState("userData", [ ...mapState("userData", [
"isMerchant", "isMerchant",
"marketList", "marketList",

View File

@ -3,23 +3,214 @@
<obj-modal <obj-modal
ref="modal" ref="modal"
labelWidth="150px" labelWidth="150px"
:modalCols="modalCols"
:modalConfig="modalConfig" :modalConfig="modalConfig"
:modalData="modalData" :modalData="modalData"
:modalHandles="modalHandles" :modalHandles="modalHandles"
> >
<template slot="dialog__after"> <div slot="dialog__content">
<div class="introduce"> <el-form
:model="ruleForm"
ref="ruleForm"
label-width="150px"
class="demo-ruleForm"
>
<el-row>
<el-col :span="8">
<el-form-item label="总订单号:">
<span>{{ ruleForm.orderNo }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label=" 结算单位订单号:">
<span>{{ ruleForm.unitOrderNo }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="总商品数量:">
<span>{{ ruleForm.productCount }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="顾客支付:">
<span>{{ ruleForm.totalMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="配送费:">
<span>{{ ruleForm.deliveryMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="优惠券减免:">
<span>{{ ruleForm.couponMoney }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="下单时间:">
<span>{{ ruleForm.payTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="预计送达时间:">
<span>{{ ruleForm.predictDeliveryTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="预计收入:">
<span>{{ ruleForm.predictIncome }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="距离:">
<span>{{ ruleForm.distance }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="预计自动取消时间:">
<span>{{ ruleForm.predictAutoCancelTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="备注:">
<span>{{ ruleForm.remark }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="包装费:">
<span>{{ ruleForm.packageMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="平台服务费:">
<span>{{ ruleForm.platformMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="备餐完成时间:">
<span>{{ ruleForm.completePrepareTime }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="开始配送时间:">
<span>{{ ruleForm.startDeliveryTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="配送完成时间:">
<span>{{ ruleForm.completeDeliveryTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="下单时间:">
<span>{{ruleForm.createTime}}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="完成取货时间:">
<span>{{ ruleForm.pickTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="订单完成时间:">
<span>{{ ruleForm.completeTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<!-- <el-form-item label="配送方式:">
<span>{{ ruleForm.deliveryType }}</span>
</el-form-item> -->
</el-col>
</el-row>
<div style="padding: 0 0 0 20px; font-size: 16px; font-weight: 600">
订单商品
</div> </div>
<div style="padding: 20px">
<div style="border-top: 1px solid #ccc; padding: 10px 0 0 0">
<el-table
border
ref="multipleTable"
:data="ruleForm.productOrders"
tooltip-effect="dark"
style="width: 100%"
@selection-change="handleSelectionChange"
>
<el-table-column
prop="shopName"
align="center"
label="店铺名称"
width="80"
>
</el-table-column>
<el-table-column
align="center"
label="商品名称"
prop="productName"
/>
<el-table-column
align="center"
label="商品图片"
prop="productImg"
>
<template slot-scope="scope">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.productImg"
:preview-src-list="[scope.row.productImg]"
>
</el-image>
</template> </template>
</el-table-column>
<el-table-column
align="center"
label="规格"
prop="productSpecName"
>
</el-table-column>
<el-table-column
align="center"
label="商品原价"
prop="originPrice"
>
</el-table-column>
<el-table-column
align="center"
label="商品终价"
prop="finalPrice"
width="120"
/>
<el-table-column
prop="productOrderMoney"
align="center"
label="商品订单金额"
width="200"
>
</el-table-column>
</el-table>
</div>
</div>
</el-form>
</div>
<!-- 选择商品 -->
</obj-modal> </obj-modal>
</div> </div>
</template> </template>
<script> <script>
import { debounce, cloneDeep } from "lodash"; import { debounce, cloneDeep } from "lodash";
import { Divider } from "element-ui";
export default { export default {
components: {}, components: {},
props: {},
data() { data() {
return { return {
isAdd: true, isAdd: true,
@ -27,13 +218,24 @@ export default {
modalConfig: { modalConfig: {
title: "订单详情", title: "订单详情",
show: false, show: false,
width: "60%", width: "1200px",
fullscreen: true,
}, },
modalData: {}, modalData: {},
value1: [], ruleForm: {},
ProductData: {}, tableData: [],
}; };
}, },
watch: {
// "modalConfig.show"(newVal) {
// if (newVal) {
// //
// setTimeout(() => {
// this.$refs.ruleForm.resetFields();
// });
// }
// },
},
methods: { methods: {
queryTableData(pageNo, pageSize) {}, queryTableData(pageNo, pageSize) {},
toggle(e) { toggle(e) {
@ -51,26 +253,52 @@ export default {
this.isAdd = true; this.isAdd = true;
}, },
update: () => { update: () => {
this.modalConfig.title = "订单详情";
this.isAdd = false; this.isAdd = false;
}, },
}; };
}, },
init(row) { init(row) {
this.modalData = row; console.log(row);
this.ruleForm = row;
},
handleSelectionChange(e) {
console.log(e);
},
getRefundStatus(val) {
if (val == 0) {
return "正常";
} else if (val == 1) {
return "退款中";
} else if (val == 2) {
return "完全退款";
} else if (val == 3) {
return "部分退款";
} else if (val == 4) {
return "拒绝用户退款";
} else if (val == -1) {
return "退款失败";
} else if (val == -2) {
return "用户申请退款中";
}
}, },
}, },
computed: { computed: {
modalCols() {
return [];
},
modalHandles() { modalHandles() {
return [ return [
{ {
label: "取消", label: "关闭",
handle: () => { handle: () => {
this.toggle(); this.toggle();
}, },
}, },
// {
// label: "",
// type: "primary",
// // submit: true,
// handle: () => {
// },
// },
]; ];
}, },
}, },

View File

@ -0,0 +1,173 @@
<template>
<div style="height: calc(100vh - 200px)">
<el-tabs v-model="formInline.group" @tab-click="handleClick">
<el-tab-pane
v-for="item in statusList"
:key="item.value"
:label="item.label"
:name="item.value"
></el-tab-pane>
</el-tabs>
<el-table :data="tableData" height="70vh" border style="width: 100%">
<el-table-column type="expand">
<template slot-scope="props">
<div style="padding-left: 20px" m="4">
<el-table :data="props.row.shopOrders" :border="true">
<el-table-column type="expand">
<template slot-scope="props">
<div style="padding-left: 20px" m="4">
<el-table :data="props.row.productOrders" :border="true">
<el-table-column type="index" width="50" label="序号">
</el-table-column>
<el-table-column
label="商品订单号"
prop="productOrderNo"
/>
<el-table-column label="商品名称" prop="productName" />
<el-table-column label="商品原价" prop="originPrice" />
<el-table-column label="商品终价" prop="finalPrice" />
<el-table-column
label="商品订单金额"
prop="productOrderMoney"
/>
<el-table-column label="商品数量" prop="productCount" />
<el-table-column
label="商品单价"
prop="productFinalPrice"
/>
<el-table-column label="商品图片" prop="productImg">
<template #default="scope">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.productImg"
:zoom-rate="1.2"
:max-scale="7"
:min-scale="0.2"
:preview-src-list="[scope.row.productImg]"
:initial-index="4"
:preview-teleported="true"
fit="cover"
/>
</template>
</el-table-column>
</el-table>
</div>
</template>
</el-table-column>
<el-table-column type="index" width="50" label="序号">
</el-table-column>
<el-table-column label="店铺名称" prop="shopName" />
</el-table>
</div>
</template>
</el-table-column>
<el-table-column label="总订单号" prop="orderNo"> </el-table-column>
<el-table-column label="顾客支付" prop="totalMoney"> </el-table-column>
<el-table-column label="配送费" prop="deliveryMoney"> </el-table-column>
<el-table-column label="优惠券减免" prop="couponMoney"> </el-table-column>
<el-table-column label="下单时间" prop="payTime"> </el-table-column>
<el-table-column label="预计送达时间" prop="predictDeliveryTime">
</el-table-column>
<el-table-column label="预计收入" prop="predictIncome"> </el-table-column>
<el-table-column label="距离" prop="distance"> </el-table-column>
</el-table>
<!-- 分页 -->
<div class="pagination-container">
<el-pagination
:current-page="formInline.pageNumber"
:page-sizes="[10, 20, 30, 50]"
:page-size="formInline.pageSize"
:total="total"
background
layout="total, sizes, prev, pager, next, jumper"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
/>
</div>
</div>
</template>
<script>
import { mapState } from "vuex";
export default {
components: {},
data() {
return {
formInline: {
group: "",
shopId: "",
pageNumber: 1,
pageSize: 10,
},
statusList: [
{
label: "全部订单",
value: "0",
},
{
label: "进行中",
value: "1",
},
{
label: "新订单",
value: "2",
},
{
label: "待备货",
value: "3",
},
{
label: "待配送",
value: "4",
},
],
total: 0,
tableData: [],
};
},
created() {
this.formInline = {
group: "0",
marketId: this.marketId,
};
this.getList();
},
methods: {
getList() {
this.$api.mer_admin
.orderPage({
...this.formInline,
})
.then((res) => {
console.log(res);
this.tableData = res.data.data.data;
this.total = Number(res.data.data.total);
})
.catch((err) => {});
},
handleClick(e) {
this.formInline.group = e.name;
this.getList();
},
handleSizeChange(val) {
this.formInline.pageSize = val;
this.getList();
},
handleCurrentChange(val) {
this.formInline.pageNumber = val;
this.getList();
},
},
computed: {
...mapState("userData", [
"isMerchant",
"marketList",
"storeList",
"marketId",
"shopId",
]),
},
};
</script>
<style lang="scss" scoped></style>

View File

@ -0,0 +1,43 @@
<template>
<vxe-column type="expand" width="60">
<template #content="{ row }">
<div class="expand-wrapper">
<vxe-table border :data="row.shopOrders.productOrders" height="200">
<vxe-column field="productOrderNo" title="商品订单号"></vxe-column>
<vxe-column field="productName" title="商品名称"></vxe-column>
<vxe-column field="productImg" title="商品图片" width="120">
<template slot-scope="{ row }">
<el-image
:preview-src-list="[row.productImg]"
:src="row.productImg"
:width="80"
:height="80"
/>
</template>
</vxe-column>
<vxe-column field="productSpecName" title="商品规格名称"></vxe-column>
<vxe-column field="originPrice" title="商品原价"></vxe-column>
<vxe-column field="finalPrice" title="商品终价"></vxe-column>
<vxe-column
field="productOrderMoney"
title="商品订单金额"
></vxe-column>
<vxe-column field="productCount" title="商品数量"></vxe-column>
<vxe-column field="productLimit" title="商品限购数量"></vxe-column>
<vxe-column field="shopName" title="店铺名称"></vxe-column>
</vxe-table>
</div>
</template>
</vxe-column>
</template>
<script>
export default {
data() {
return {};
},
};
</script>
<style>
</style>

View File

@ -0,0 +1,309 @@
<template>
<div>
<obj-modal
ref="modal"
labelWidth="150px"
:modalConfig="modalConfig"
:modalData="modalData"
:modalHandles="modalHandles"
>
<div slot="dialog__content">
<el-form
:model="ruleForm"
ref="ruleForm"
label-width="150px"
class="demo-ruleForm"
>
<el-row>
<el-col :span="8">
<el-form-item label="总订单号:">
<span>{{ ruleForm.orderNo }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label=" 结算单位订单号:">
<span>{{ ruleForm.unitOrderNo }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="总商品数量:">
<span>{{ ruleForm.productCount }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="顾客支付:">
<span>{{ ruleForm.totalMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="配送费:">
<span>{{ ruleForm.deliveryMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="优惠券减免:">
<span>{{ ruleForm.couponMoney }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="下单时间:">
<span>{{ ruleForm.payTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="预计送达时间:">
<span>{{ ruleForm.predictDeliveryTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="预计收入:">
<span>{{ ruleForm.predictIncome }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="距离:">
<span>{{ ruleForm.distance }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="预计自动取消时间:">
<span>{{ ruleForm.predictAutoCancelTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="备注:">
<span>{{ ruleForm.remark }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="包装费:">
<span>{{ ruleForm.packageMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="平台服务费:">
<span>{{ ruleForm.platformMoney }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="备餐完成时间:">
<span>{{ ruleForm.completePrepareTime }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="开始配送时间:">
<span>{{ ruleForm.startDeliveryTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="配送完成时间:">
<span>{{ ruleForm.completeDeliveryTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="订单退款状态:">
<span>{{ getRefundStatus(ruleForm.refundStatus) }}</span>
</el-form-item></el-col
>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="申请退款原因:">
<span>{{ ruleForm.refundReason }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<el-form-item label="申请退款时间:">
<span>{{ ruleForm.applyRefundTime }}</span>
</el-form-item></el-col
>
<el-col :span="8">
<!-- <el-form-item label="配送方式:">
<span>{{ ruleForm.deliveryType }}</span>
</el-form-item> -->
</el-col>
</el-row>
<div style="padding: 0 0 0 20px; font-size: 16px; font-weight: 600">
订单商品
</div>
<div style="padding: 20px">
<div style="border-top: 1px solid #ccc; padding: 10px 0 0 0">
<el-table
border
ref="multipleTable"
:data="ruleForm.productOrders"
tooltip-effect="dark"
style="width: 100%"
@selection-change="handleSelectionChange"
>
<el-table-column
prop="shopName"
align="center"
label="店铺名称"
width="80"
>
</el-table-column>
<el-table-column
align="center"
label="商品名称"
prop="productName"
/>
<el-table-column
align="center"
label="商品图片"
prop="productImg"
>
<template slot-scope="scope">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.productImg"
:preview-src-list="[scope.row.productImg]"
>
</el-image>
</template>
</el-table-column>
<el-table-column
align="center"
label="规格"
prop="productSpecName"
>
</el-table-column>
<el-table-column
align="center"
label="商品原价"
prop="originPrice"
>
</el-table-column>
<el-table-column
align="center"
label="商品终价"
prop="finalPrice"
width="120"
/>
<el-table-column
prop="productOrderMoney"
align="center"
label="商品订单金额"
width="200"
>
</el-table-column>
</el-table>
</div>
</div>
</el-form>
</div>
<!-- 选择商品 -->
</obj-modal>
</div>
</template>
<script>
import { debounce, cloneDeep } from "lodash";
export default {
components: {},
props: {},
data() {
return {
isAdd: true,
//
modalConfig: {
title: "订单详情",
show: false,
width: "1200px",
fullscreen: true,
},
modalData: {},
ruleForm: {},
tableData: [],
};
},
watch: {
// "modalConfig.show"(newVal) {
// if (newVal) {
// //
// setTimeout(() => {
// this.$refs.ruleForm.resetFields();
// });
// }
// },
},
methods: {
queryTableData(pageNo, pageSize) {},
toggle(e) {
if (this.modalConfig.show == false) {
this.modalConfig.show = true;
} else {
this.modalConfig.show = false;
}
if (e) {
this.init(cloneDeep(e));
}
return {
add: () => {
this.modalConfig.title = "订单详情";
this.isAdd = true;
},
update: () => {
this.modalConfig.title = "订单详情";
this.isAdd = false;
},
};
},
init(row) {
console.log(row);
this.ruleForm = row;
},
handleSelectionChange(e) {
console.log(e);
},
getRefundStatus(val) {
if (val == 0) {
return "正常";
} else if (val == 1) {
return "退款中";
} else if (val == 2) {
return "完全退款";
} else if (val == 3) {
return "部分退款";
} else if (val == 4) {
return "拒绝用户退款";
} else if (val == -1) {
return "退款失败";
} else if (val == -2) {
return "用户申请退款中";
}
},
},
computed: {
modalHandles() {
return [
{
label: "关闭",
handle: () => {
this.toggle();
},
},
// {
// label: "",
// type: "primary",
// // submit: true,
// handle: () => {
// },
// },
];
},
},
asyncComputed: {},
};
</script>
<style lang="scss" scoped>
</style>

View File

@ -49,16 +49,6 @@
placeholder="商品名称搜索" placeholder="商品名称搜索"
></el-input> ></el-input>
</el-form-item> </el-form-item>
<!-- <el-form-item label="状态">
<el-select v-model="formInline.status" placeholder="请选择状态">
<el-option
v-for="item in statusList"
:key="item.value"
:label="item.label"
:value="item.value"
></el-option>
</el-select>
</el-form-item> -->
<el-form-item> <el-form-item>
<el-button type="primary" @click="$refs.oTable.reload()" <el-button type="primary" @click="$refs.oTable.reload()"
>查询</el-button >查询</el-button
@ -98,15 +88,12 @@
@queryList="$refs.oTable.reload()" @queryList="$refs.oTable.reload()"
ref="addOrUpdate" ref="addOrUpdate"
></add-or-update> ></add-or-update>
<!-- 改价格 -->
<!-- <AddPrice ref="AddPrice" @queryList="$refs.oTable.reload()"></AddPrice> -->
<!-- 改库存 -->
<!-- <addStock ref="addStock" @queryList="$refs.oTable.reload()"></addStock> -->
<!-- 打折扣 -->
<earlyWarning <earlyWarning
ref="earlyWarning" ref="earlyWarning"
@queryList="$refs.oTable.reload()" @queryList="$refs.oTable.reload()"
></earlyWarning> ></earlyWarning>
<!-- 查看商品 -->
<viewProducts ref="viewProducts"></viewProducts>
</div> </div>
<div style="height: calc(100vh - 200px)" v-else> <div style="height: calc(100vh - 200px)" v-else>
<el-empty :image-size="200" description="您不是摊主哦"></el-empty> <el-empty :image-size="200" description="您不是摊主哦"></el-empty>
@ -115,13 +102,12 @@
</template> </template>
<script> <script>
// import AddDiscount from "./popup/add-discount.vue";
// import AddPrice from "./popup/add-price.vue";
import { mapState } from "vuex"; import { mapState } from "vuex";
import viewProducts from "./popup/view-products.vue";
import AddOrUpdate from "./popup/add-or-update.vue"; import AddOrUpdate from "./popup/add-or-update.vue";
import earlyWarning from "./popup/early-warning.vue"; import earlyWarning from "./popup/early-warning.vue";
export default { export default {
components: { earlyWarning, AddOrUpdate }, components: { earlyWarning, AddOrUpdate, viewProducts },
data() { data() {
return { return {
activeName: "5", activeName: "5",
@ -496,15 +482,12 @@ export default {
this.$refs.oTable.reload(); this.$refs.oTable.reload();
}); });
}; };
let changeInventory = () => { let view = () => {
this.$refs.addStock.toggle(row).update(); this.$refs.viewProducts.toggle(row).update();
};
let setDiscounts = () => {
this.$refs.AddDiscount.toggle(row).update();
}; };
return ( return (
<div> <div>
<el-button size="mini" type="primary" onClick={changeInventory}> <el-button size="mini" type="primary" onClick={view}>
查看 查看
</el-button> </el-button>
<el-button <el-button

View File

@ -0,0 +1,384 @@
<template>
<div>
<obj-modal
ref="modal"
labelWidth="150px"
:modalConfig="modalConfig"
:modalData="modalData"
:modalHandles="modalHandles"
>
<div slot="dialog__content">
<el-form
:model="ruleForm"
ref="ruleForm"
label-width="150px"
class="demo-ruleForm"
>
<el-row>
<el-col :span="12">
<el-form-item label="订金支付时间:" prop="startTime">
<el-date-picker
@change="getOrderTime"
format="yyyy-MM-dd HH:mm"
data-format="yyyy-MM-dd HH:mm"
value-format="yyyy-MM-dd HH:mm:ss"
v-model="orderTime"
type="datetimerange"
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
:editable="false"
>
</el-date-picker> </el-form-item
></el-col>
<el-col :span="12">
<el-form-item
label="尾款支付时间:"
prop="balancePaymentStartTime"
>
<el-date-picker
@change="getArrearsTime"
format="yyyy-MM-dd"
data-format="yyyy-MM-dd"
value-format="yyyy-MM-dd HH:mm:ss"
v-model="arrears"
type="datetimerange"
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
:picker-options="pickerOptions"
>
</el-date-picker> </el-form-item
></el-col>
</el-row>
<el-form-item
label="预计发货时间:"
prop="estimatedStartDeliveryTime"
>
<el-date-picker
format="yyyy-MM-dd HH:mm"
data-format="yyyy-MM-dd HH:mm"
value-format="yyyy-MM-dd HH:mm:ss"
@change="deliveryTime"
v-model="delivery"
type="datetimerange"
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
:picker-options="pickerOptions"
>
</el-date-picker>
</el-form-item>
<el-form-item label="定金可退:" prop="isRefundEarnestMoney">
<el-radio v-model="ruleForm.isRefundEarnestMoney" :label="1"
></el-radio
>
<el-radio v-model="ruleForm.isRefundEarnestMoney" :label="2"
></el-radio
>
<span>
选择是用户可在付尾款前申请退定金申请后自动退无需审核或付尾款时间结束后系统自动退定金
</span>
</el-form-item>
<div style="padding: 0 0 0 20px; font-size: 16px; font-weight: 600">
已选择商品
</div>
<div style="padding: 20px">
<div style="border-top: 1px solid #ccc; padding: 10px 0 0 0">
<div style="font-size: 16px; margin-bottom: 20px">
<span>商品ID:{{ ruleForm.productId }}</span>
<span style="margin-left: 20px"
>商品名称:{{ ruleForm.name }}</span
>
</div>
<el-table
border
ref="multipleTable"
:data="ruleForm.productSpecificationList"
tooltip-effect="dark"
style="width: 100%"
@selection-change="handleSelectionChange"
>
<el-table-column align="center" label="是否预售" width="80">
<template slot-scope="scope">
<span>{{
scope.row.isAdvanceSell == 1 ? "是" : "否"
}}</span>
<!-- <el-checkbox
:true-label="1"
:false-label="0"
v-model="scope.row.isAdvanceSell"
></el-checkbox> -->
</template>
</el-table-column>
<el-table-column align="center" label="SKU-ID" prop="id" />
<el-table-column
align="center"
label="规格"
prop="attributeList"
>
<template slot-scope="scope">
<span>{{ scope.row.attributeValue }}</span>
</template>
</el-table-column>
<el-table-column align="center" label="属性" prop="address">
<template slot-scope="scope">
<span>{{
scope.row.attributeList
? scope.row.attributeList[0].attributeName
: "无"
}}</span>
</template>
</el-table-column>
<el-table-column
align="center"
label="销售价"
prop="marketPrice"
width="120"
/>
<el-table-column
prop="presalePrice"
align="center"
label="*预售价"
width="200"
>
<template slot-scope="scope">
<span v-if="scope.row.isAdvanceSell">{{
scope.row.presalePrice
}}</span>
</template>
</el-table-column>
<el-table-column
prop="earnestMoney"
align="center"
label="*定金"
width="200"
>
<template slot-scope="scope">
<span v-if="scope.row.isAdvanceSell">{{
scope.row.earnestMoney
}}</span>
</template>
</el-table-column>
<el-table-column align="center" label="尾款" width="200">
<template slot-scope="scope">
<span v-if="scope.row.isAdvanceSell">{{
scope.row.presalePrice
? scope.row.presalePrice - scope.row.earnestMoney
: ""
}}</span>
</template>
</el-table-column>
<el-table-column align="center" label="*预售库存" width="200">
<template slot-scope="scope">
<span v-if="scope.row.isAdvanceSell">{{
scope.row.advanceSellStockNum
}}</span>
</template>
</el-table-column>
</el-table>
</div>
<el-empty
v-show="ruleForm.productList?.length == 0"
description="请选择商品"
></el-empty>
</div>
</el-form>
</div>
<!-- 选择商品 -->
</obj-modal>
</div>
</template>
<script>
import { debounce, cloneDeep } from "lodash";
export default {
components: {},
props: {
marketId: {
type: String,
default: "",
},
shopId: {
type: String,
default: "",
},
},
data() {
return {
isAdd: true,
//
modalConfig: {
title: "查看预售",
show: false,
width: "1200px",
fullscreen: true,
},
modalData: {},
ruleForm: {
productList: [],
isRefundEarnestMoney: 1, //退 1 2
},
pickerOptions: {
disabledDate(time) {
return time.getTime() < Date.now();
},
},
orderTime: [], //
arrears: [], //
delivery: [], //
tableData: [],
};
},
watch: {
"modalConfig.show"(newVal) {
if (newVal) {
//
setTimeout(() => {
this.$refs.ruleForm.resetFields();
});
}
},
},
methods: {
queryTableData(pageNo, pageSize) {},
toggle(e) {
if (this.modalConfig.show == false) {
this.modalConfig.show = true;
} else {
this.modalConfig.show = false;
}
if (e) {
this.init(cloneDeep(e));
}
return {
add: () => {
this.orderTime = [];
this.arrears = [];
this.delivery = [];
this.ruleForm = {
startTime: "",
endTime: "",
balancePaymentStartTime: "",
balancePaymentEndTime: "",
estimatedStartDeliveryTime: "",
estimatedEndDeliveryTime: "",
productList: [],
isRefundEarnestMoney: 1, //退 1 2
};
this.modalConfig.title = "新增预售";
this.isAdd = true;
},
update: () => {
this.modalConfig.title = "查看预售";
this.isAdd = false;
},
};
},
init(row) {
console.log(row.startTime, row.endTime);
this.orderTime = [row.startTime, row.endTime];
this.arrears = [row.balancePaymentStartTime, row.balancePaymentEndTime];
this.delivery = [
row.estimatedStartDeliveryTime,
row.estimatedEndDeliveryTime,
];
(this.ruleForm = {
productId: row.id,
advanceSellId: row.advanceSellId,
startTime: row.startTime,
name: row.name,
endTime: row.endTime,
balancePaymentStartTime: row.balancePaymentStartTime,
balancePaymentEndTime: row.balancePaymentEndTime,
estimatedStartDeliveryTime: row.estimatedStartDeliveryTime,
estimatedEndDeliveryTime: row.estimatedEndDeliveryTime,
isRefundEarnestMoney: row.isRefundEarnestMoney,
productSpecificationList: row.productSpecificationList,
}),
console.log(this.orderTime, this.arrears, this.delivery);
// this.ruleForm = row;
},
//
getOrderTime(e) {
if (e) {
console.log(e);
this.ruleForm.startTime = e[0];
this.ruleForm.endTime = e[1];
} else {
this.ruleForm.startTime = "";
this.ruleForm.endTime = "";
}
},
//
getArrearsTime(e) {
if (e) {
console.log(e);
this.ruleForm.balancePaymentStartTime = e[0];
this.ruleForm.balancePaymentEndTime = e[1];
} else {
this.ruleForm.balancePaymentStartTime = "";
this.ruleForm.balancePaymentEndTime = "";
}
},
//
deliveryTime(e) {
if (e) {
console.log(e);
this.ruleForm.estimatedStartDeliveryTime = e[0];
this.ruleForm.estimatedEndDeliveryTime = e[1];
} else {
this.ruleForm.estimatedStartDeliveryTime = "";
this.ruleForm.estimatedEndDeliveryTime = "";
}
},
selectProduct() {
console.log("选择商品", this.marketId, this.shopId);
this.$nextTick(() => {
this.$refs.commodity.toggle().add({
marketId: this.marketId,
shopId: this.shopId,
});
});
},
handleSelectionChange(e) {
console.log(e);
},
getProduct(row) {
this.ruleForm.productList = row.map((item) => {
return {
productId: item.id,
name: item.name,
productSpecificationList: item.productSpecificationList,
};
});
console.log(this.ruleForm.productList, this.ruleForm.productList.length);
console.log("获取商品");
},
},
computed: {
modalHandles() {
return [
{
label: "关闭",
handle: () => {
this.toggle();
},
},
// {
// label: "",
// type: "primary",
// // submit: true,
// handle: () => {
// },
// },
];
},
},
asyncComputed: {},
};
</script>
<style lang="scss" scoped>
</style>

View File

@ -13,7 +13,7 @@
</div> </div>
<div> <div>
<el-button <el-button
@click="$router.push({ path: 'bank-card-index' })" @click="$router.push({ name: 'bank-card-index' })"
type="primary" type="primary"
round round
>绑定银行卡</el-button >绑定银行卡</el-button