1011 lines
38 KiB
Vue
1011 lines
38 KiB
Vue
<template>
|
|
<div>
|
|
<Card style="padding: 10px 12px 0px">
|
|
<div class="head-title">基本信息</div>
|
|
<div class="detail-body">
|
|
<div class="ant-col-md-6" style="width: 25%;">
|
|
<div class="info">
|
|
<div class="head-info">
|
|
<Avatar size="large" :src="storeInfo.storeLogo"/>
|
|
<div>
|
|
<div class="name" v-if="storeInfo.storeName && storeInfo.storeName.length > 15">
|
|
{{storeInfo.storeName.slice(0,15)}}...
|
|
</div>
|
|
<div class="name" v-else>
|
|
{{storeInfo.storeName}}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="bottom-info">
|
|
<p v-if="storeInfo.createTime">{{storeInfo.createTime}} 开店</p>
|
|
<p v-if="storeInfo.selfOperated == 1">
|
|
<Tag color="success">自营</Tag>
|
|
</p>
|
|
<p v-else>
|
|
<Tag color="error">非自营</Tag>
|
|
</p>
|
|
<p>
|
|
<i-switch size="large" v-model="storeInfo.storeDisable" :true-value="true" :false-value="false"
|
|
@on-change="shopStatusChange">
|
|
<span slot="open">启用</span>
|
|
<span slot="close">禁用</span>
|
|
</i-switch>
|
|
</p>
|
|
</div>
|
|
<div style="margin-top: 20px">
|
|
<p class="item">
|
|
<span class="label">公司名称:</span>
|
|
<span class="info">{{storeInfo.companyName}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">公司电话:</span>
|
|
<span class="info">{{storeInfo.companyPhone}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">电子邮箱:</span>
|
|
<span class="info">{{storeInfo.companyEmail}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">员工总数:</span>
|
|
<span class="info">{{storeInfo.employeeNum}}人</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">注册资金:</span>
|
|
<span class="info">{{storeInfo.registeredCapital}}万</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">电子邮箱:</span>
|
|
<span class="info">{{storeInfo.companyEmail}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">联系人姓名:</span>
|
|
<span class="info">{{storeInfo.linkName}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">联系人电话:</span>
|
|
<span class="info">{{storeInfo.linkPhone}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">公司地址:</span>
|
|
<span class="info">
|
|
{{storeInfo.companyAddressPath || storeInfo.companyAddress?storeInfo.companyAddressPath + ' '+storeInfo.companyAddress:"暂未完善"}}
|
|
</span>
|
|
</p>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
<div class="ant-col-md-6">
|
|
<p class="item">
|
|
<span class="label">商家账号:</span>
|
|
<span class="info">{{storeInfo.memberName}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">库存预警数:</span>
|
|
<span class="info">{{storeInfo.stockWarning?storeInfo.stockWarning:'0'}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">店铺所在地:</span>
|
|
<span class="info">
|
|
{{storeInfo.storeAddressPath || storeInfo.storeAddressDetail?storeInfo.storeAddressPath +storeInfo.storeAddressDetail:"暂未完善"}}
|
|
</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">退货地址:</span>
|
|
<span class="info">
|
|
{{storeInfo.salesConsigneeName || storeInfo.salesConsigneeMobile || storeInfo.salesConsigneeAddressPath || storeInfo.salesConsigneeDetail?storeInfo.salesConsigneeName + storeInfo.salesConsigneeMobile +' '+ storeInfo.salesConsigneeAddressPath + storeInfo.salesConsigneeDetail:'暂未完善'}}
|
|
</span>
|
|
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">店铺定位:</span>
|
|
<span class="info">{{storeInfo.storeCenter?'已定位':'未定位'}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">经营范围:</span>
|
|
<span class="info">
|
|
<CheckboxGroup v-model="checkAllGroup">
|
|
<Checkbox disabled v-for="(item, i) in categories" :key="i + 1" :label="item.id">{{ item.name }}
|
|
</Checkbox>
|
|
</CheckboxGroup>
|
|
</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">店铺简介:</span>
|
|
<span class="info">
|
|
{{storeInfo.storeDesc?storeInfo.storeDesc:'暂未完善'}}
|
|
</span>
|
|
</p>
|
|
</div>
|
|
|
|
|
|
|
|
<div class="ant-col-md-6">
|
|
<p class="item">
|
|
<span class="label">法人姓名:</span>
|
|
<span class="info">{{storeInfo.legalName}}人</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">法人身份证:</span>
|
|
<span class="info">{{storeInfo.legalId}}人</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">身份证照片:</span>
|
|
<span class="info">
|
|
<img style="height: 100px;width: 90px" :src="storeInfo.legalPhoto">
|
|
</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">营业执照号:</span>
|
|
<span class="info">{{storeInfo.licenseNum}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">法定经营范围:</span>
|
|
<span class="info">{{storeInfo.scope}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">营业执照电子版:</span>
|
|
<span class="info">
|
|
<img style="height: 100px;width: 90px" :src="storeInfo.licencePhoto">
|
|
</span>
|
|
</p>
|
|
|
|
<p class="item">
|
|
<span class="label">银行名称:</span>
|
|
<span class="info">{{storeInfo.settlementBankAccountName}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">银行账号:</span>
|
|
<span class="info">{{storeInfo.settlementBankAccountNum}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">银行开户支行名称:</span>
|
|
<span class="info">{{storeInfo.settlementBankBranchName}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">银行支行联行号:</span>
|
|
<span class="info">{{storeInfo.settlementBankJointName}}</span>
|
|
</p>
|
|
<p class="item">
|
|
<span class="label">结算周期:</span>
|
|
<span class="info" v-if="storeInfo.settlementCycle">
|
|
<template v-for="item in storeInfo.settlementCycle.split(',')">
|
|
<Tag
|
|
:key="item"
|
|
v-if="item!==''"
|
|
:name="item"
|
|
style="marrgin-left: 10px"
|
|
>{{ item }}
|
|
</Tag>
|
|
</template>
|
|
|
|
</span>
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</Card>
|
|
|
|
<Card>
|
|
<Tabs type="order" @on-click="storeInfoChange">
|
|
<TabPane label="TA的订单" name="order" style="min-height: 200px">
|
|
<Row>
|
|
<Form ref="searchForm" :model="orderSearchForm" inline :label-width="70" class="search-form">
|
|
<Form-item label="订单号" prop="orderSn">
|
|
<Input
|
|
type="text"
|
|
v-model="orderSearchForm.orderSn"
|
|
placeholder="请输入订单号"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Form-item label="订单状态" prop="orderStatus">
|
|
<Select v-model="orderSearchForm.orderStatus" placeholder="请选择" clearable style="width: 200px">
|
|
<Option value="UNPAID">未付款</Option>
|
|
<Option value="PAID">已付款</Option>
|
|
<Option value="UNDELIVERED">待发货</Option>
|
|
<Option value="DELIVERED">已发货</Option>
|
|
<Option value="COMPLETED">已完成</Option>
|
|
<Option value="TAKE">待核验</Option>
|
|
<Option value="CANCELLED">已取消</Option>
|
|
</Select>
|
|
</Form-item>
|
|
<Form-item label="支付状态" prop="payStatus">
|
|
<Select v-model="orderSearchForm.payStatus" placeholder="请选择" clearable style="width: 200px">
|
|
<Option value="UNPAID">未付款</Option>
|
|
<Option value="PAID">已付款</Option>
|
|
</Select>
|
|
</Form-item>
|
|
<Form-item label="订单类型" prop="orderType">
|
|
<Select v-model="orderSearchForm.orderType" placeholder="请选择" clearable style="width: 200px">
|
|
<Option value="NORMAL">普通订单</Option>
|
|
<Option value="VIRTUAL">虚拟订单</Option>
|
|
<Option value="GIFT">赠品订单</Option>
|
|
<Option value="PINTUAN">拼团订单</Option>
|
|
</Select>
|
|
</Form-item>
|
|
<Form-item label="订单来源" prop="clientType">
|
|
<Select v-model="orderSearchForm.clientType" placeholder="请选择" clearable style="width: 200px">
|
|
<Option value="H5">移动端</Option>
|
|
<Option value="PC">PC端</Option>
|
|
<Option value="WECHAT_MP">小程序</Option>
|
|
<Option value="APP">移动应用端</Option>
|
|
<Option value="UNKNOWN">未知</Option>
|
|
</Select>
|
|
</Form-item>
|
|
<Form-item label="下单时间">
|
|
<DatePicker
|
|
v-model="selectDate"
|
|
type="datetimerange"
|
|
format="yyyy-MM-dd HH:mm:ss"
|
|
clearable
|
|
@on-change="selectDateRange"
|
|
placeholder="选择起始时间"
|
|
style="width: 200px"
|
|
></DatePicker>
|
|
</Form-item>
|
|
<Button @click="getOrderData" type="primary" icon="ios-search" class="search-btn">搜索</Button>
|
|
</Form>
|
|
</Row>
|
|
<div style="min-height: 180px">
|
|
<Table
|
|
:loading="loading"
|
|
border
|
|
:columns="orderColumns"
|
|
:data="orderData"
|
|
ref="table"
|
|
sortable="custom"
|
|
@on-sort-change="orderChangeSort"
|
|
>
|
|
<!-- 订单详情格式化 -->
|
|
<template slot="orderSlot" slot-scope="scope">
|
|
<a @click="$router.push({name: 'order-detail',query: {sn: scope.row.sn}})">{{scope.row.sn}}</a>
|
|
</template>
|
|
</Table>
|
|
|
|
<Row type="flex" justify="end" class="mt_10" style="margin-top: 10px">
|
|
<Page
|
|
:current="orderSearchForm.pageNumber"
|
|
:total="orderTotal"
|
|
:page-size="orderSearchForm.pageSize"
|
|
@on-change="orderChangePage"
|
|
@on-page-size-change="orderChangePageSize"
|
|
:page-size-opts="[10, 20, 50]"
|
|
size="small"
|
|
show-total
|
|
show-elevator
|
|
show-sizer
|
|
></Page>
|
|
</Row>
|
|
</div>
|
|
</TabPane>
|
|
<TabPane label="TA的退货单" name="refundGoods">
|
|
<Row>
|
|
<Form ref="refundGoodsOrderSearchForm" :model="refundGoodsOrderSearchForm" inline :label-width="70"
|
|
class="search-form">
|
|
<Form-item label="订单编号" prop="orderSn">
|
|
<Input
|
|
type="text"
|
|
v-model="refundGoodsOrderSearchForm.orderSn"
|
|
placeholder="请输入订单编号"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Form-item label="售后单号" prop="sn">
|
|
<Input
|
|
type="text"
|
|
v-model="refundGoodsOrderSearchForm.sn"
|
|
placeholder="请输入售后单号"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Form-item label="售后状态">
|
|
<Select v-model="refundGoodsOrderSearchForm.serviceStatus" placeholder="全部" clearable
|
|
style="width: 200px">
|
|
<Option value="APPLY">申请售后</Option>
|
|
<Option value="PASS">通过售后</Option>
|
|
<Option value="REFUSE">拒绝售后</Option>
|
|
<Option value="BUYER_RETURN">买家退货,待卖家收货</Option>
|
|
<Option value="SELLER_RE_DELIVERY">商家换货/补发</Option>
|
|
<Option value="SELLER_CONFIRM">卖家确认收货</Option>
|
|
<Option value="SELLER_TERMINATION">卖家终止售后</Option>
|
|
<Option value="BUYER_CONFIRM">买家确认收货</Option>
|
|
<Option value="BUYER_CANCEL">买家取消售后</Option>
|
|
<Option value="COMPLETE">完成售后</Option>
|
|
</Select>
|
|
</Form-item>
|
|
<Form-item label="申请时间">
|
|
<DatePicker
|
|
v-model="selectDate"
|
|
type="datetimerange"
|
|
format="yyyy-MM-dd HH:mm:ss"
|
|
clearable
|
|
@on-change="selectRefundGoodsDateRange"
|
|
placeholder="选择起始时间"
|
|
style="width: 200px"
|
|
></DatePicker>
|
|
</Form-item>
|
|
<Form-item label="商家名称" prop="storeName">
|
|
<Input
|
|
type="text"
|
|
v-model="refundGoodsOrderSearchForm.storeName"
|
|
placeholder="请输入商家名称"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Form-item label="会员名称" prop="memberName">
|
|
<Input
|
|
type="text"
|
|
v-model="refundGoodsOrderSearchForm.memberName"
|
|
placeholder="请输入会员名称"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Button @click="getRefundGoodsOrderData" type="primary" icon="ios-search" class="search-btn">搜索</Button>
|
|
</Form>
|
|
</Row>
|
|
<div style="min-height: 180px">
|
|
<Table
|
|
:loading="loading"
|
|
border
|
|
:columns="refundGoodsOrderColumns"
|
|
:data="refundGoodsOrderData"
|
|
ref="table"
|
|
sortable="custom"
|
|
@on-sort-change="refundGoodsOrderChangeSort"
|
|
>
|
|
<!-- 商品栏目格式化 -->
|
|
<template slot="goodsSlot" slot-scope="scope">
|
|
<div style="margin-top: 5px;height: 80px; display: flex;">
|
|
<div style="">
|
|
<img :src="scope.row.goodsImage" style="height: 60px;margin-top: 3px">
|
|
</div>
|
|
|
|
<div style="margin-left: 13px;margin-top: 3px;">
|
|
<div class="div-zoom">
|
|
<a>{{scope.row.goodsName}}</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<!-- 订单详情格式化 -->
|
|
<template slot="orderSlot" slot-scope="scope">
|
|
<a
|
|
@click="$router.push({name: 'order-detail',query: {sn: scope.row.orderSn}})">{{scope.row.orderSn}}</a>
|
|
</template>
|
|
|
|
<!-- 售后单详情格式化 -->
|
|
<template slot="refundGoodsOrderSlot" slot-scope="scope">
|
|
<a @click="$router.push({name: 'after-order-detail',query: {sn: scope.row.sn}})">{{scope.row.sn}}</a>
|
|
</template>
|
|
</Table>
|
|
|
|
<Row type="flex" justify="end" class="mt_10" style="margin-top: 10px">
|
|
<Page
|
|
:current="refundGoodsOrderSearchForm.pageNumber"
|
|
:total="refundGoodsOrderTotal"
|
|
:page-size="refundGoodsOrderSearchForm.pageSize"
|
|
@on-change="refundGoodsOrderChangePage"
|
|
@on-page-size-change="refundGoodsOrderChangePageSize"
|
|
:page-size-opts="[10, 20, 50]"
|
|
size="small"
|
|
show-total
|
|
show-elevator
|
|
show-sizer
|
|
></Page>
|
|
</Row>
|
|
</div>
|
|
</TabPane>
|
|
<TabPane label="TA的退款单" name="refund">
|
|
<Row>
|
|
<Form ref="refundOrderSearchForm" :model="refundOrderSearchForm" inline :label-width="70"
|
|
class="search-form">
|
|
<Form-item label="订单编号" prop="orderSn">
|
|
<Input
|
|
type="text"
|
|
v-model="refundOrderSearchForm.orderSn"
|
|
placeholder="请输入订单编号"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Form-item label="售后单号" prop="sn">
|
|
<Input
|
|
type="text"
|
|
v-model="refundOrderSearchForm.sn"
|
|
placeholder="请输入售后单号"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Form-item label="售后状态">
|
|
<Select v-model="refundOrderSearchForm.serviceStatus" placeholder="全部" clearable
|
|
style="width: 200px">
|
|
<Option value="APPLY">申请售后</Option>
|
|
<Option value="PASS">通过售后</Option>
|
|
<Option value="REFUSE">拒绝售后</Option>
|
|
<Option value="BUYER_RETURN">买家退货,待卖家收货</Option>
|
|
<Option value="SELLER_RE_DELIVERY">商家换货/补发</Option>
|
|
<Option value="SELLER_CONFIRM">卖家确认收货</Option>
|
|
<Option value="SELLER_TERMINATION">卖家终止售后</Option>
|
|
<Option value="BUYER_CONFIRM">买家确认收货</Option>
|
|
<Option value="BUYER_CANCEL">买家取消售后</Option>
|
|
<Option value="COMPLETE">完成售后</Option>
|
|
</Select>
|
|
</Form-item>
|
|
<Form-item label="申请时间">
|
|
<DatePicker
|
|
v-model="selectDate"
|
|
type="datetimerange"
|
|
format="yyyy-MM-dd HH:mm:ss"
|
|
clearable
|
|
@on-change="selectRefundDateRange"
|
|
placeholder="选择起始时间"
|
|
style="width: 200px"
|
|
></DatePicker>
|
|
</Form-item>
|
|
<Form-item label="商家名称" prop="storeName">
|
|
<Input
|
|
type="text"
|
|
v-model="refundOrderSearchForm.storeName"
|
|
placeholder="请输入商家名称"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Form-item label="会员名称" prop="memberName">
|
|
<Input
|
|
type="text"
|
|
v-model="refundOrderSearchForm.memberName"
|
|
placeholder="请输入会员名称"
|
|
clearable
|
|
style="width: 200px"
|
|
/>
|
|
</Form-item>
|
|
<Button @click="getRefundOrder" type="primary" icon="ios-search" class="search-btn">搜索</Button>
|
|
</Form>
|
|
</Row>
|
|
<div style="min-height: 180px">
|
|
<Table
|
|
:loading="loading"
|
|
border
|
|
:columns="refundGoodsOrderColumns"
|
|
:data="refundOrderData"
|
|
ref="table"
|
|
sortable="custom"
|
|
@on-sort-change="refundOrderChangeSort"
|
|
>
|
|
<!-- 商品栏目格式化 -->
|
|
<template slot="goodsSlot" slot-scope="scope">
|
|
<div style="margin-top: 5px;height: 80px; display: flex;">
|
|
<div style="">
|
|
<img :src="scope.row.goodsImage" style="height: 60px;margin-top: 3px">
|
|
</div>
|
|
|
|
<div style="margin-left: 13px;margin-top: 3px;">
|
|
<div class="div-zoom">
|
|
<a>{{scope.row.goodsName}}</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<!-- 订单详情格式化 -->
|
|
<template slot="orderSlot" slot-scope="scope">
|
|
<a
|
|
@click="$router.push({name: 'order-detail',query: {sn: scope.row.orderSn}})">{{scope.row.orderSn}}</a>
|
|
</template>
|
|
|
|
<!-- 售后单详情格式化 -->
|
|
<template slot="refundGoodsOrderSlot" slot-scope="scope">
|
|
<a @click="$router.push({name: 'after-order-detail',query: {sn: scope.row.sn}})">{{scope.row.sn}}</a>
|
|
</template>
|
|
</Table>
|
|
|
|
<Row type="flex" justify="end" class="mt_10" style="margin-top: 10px">
|
|
<Page
|
|
:current="refundOrderSearchForm.pageNumber"
|
|
:total="refundOrderTotal"
|
|
:page-size="refundOrderSearchForm.pageSize"
|
|
@on-change="refundOrderChangePage"
|
|
@on-page-size-change="refundOrderChangePageSize"
|
|
:page-size-opts="[10, 20, 50]"
|
|
size="small"
|
|
show-total
|
|
show-elevator
|
|
show-sizer
|
|
></Page>
|
|
</Row>
|
|
</div>
|
|
</TabPane>
|
|
</Tabs>
|
|
</Card>
|
|
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import region from "@/views/lili-components/region";
|
|
import ossManage from "@/views/sys/oss-manage/ossManage";
|
|
import * as RegExp from '@/libs/RegExp.js';
|
|
import {getCategoryTree} from "@/api/goods";
|
|
import * as API_Store from "@/api/shops.js";
|
|
import * as API_Order from "@/api/order.js";
|
|
|
|
|
|
export default {
|
|
name: "member",
|
|
components: {
|
|
region,
|
|
ossManage,
|
|
},
|
|
data() {
|
|
return {
|
|
id: "",//店铺id
|
|
categories: [], //店铺静音范围
|
|
loading: true, // 表单加载状态
|
|
storeInfo: {},//店铺信息
|
|
checkAllGroup: [], //选中的经营分类
|
|
selectDate: null, // 申请时间
|
|
submitLoading: false, // 添加或编辑提交状态
|
|
|
|
orderColumns: [
|
|
{
|
|
title: "订单编号",
|
|
key: "sn",
|
|
minWidth: 100,
|
|
tooltip: true,
|
|
slot: "orderSlot",
|
|
},
|
|
{
|
|
title: "订单金额",
|
|
key: "flowPrice",
|
|
width: 140,
|
|
render: (h, params) => {
|
|
return h("div", this.$options.filters.unitPrice(params.row.flowPrice, '¥'));
|
|
}
|
|
},
|
|
{
|
|
title: "订单类型",
|
|
key: "orderType",
|
|
width: 100,
|
|
render: (h, params) => {
|
|
if (params.row.orderType == "NORMAL") {
|
|
return h('div', [h('span', {}, '普通订单'),]);
|
|
} else if (params.row.orderType == "VIRTUAL") {
|
|
return h('div', [h('span', {}, '虚拟订单'),]);
|
|
} else if (params.row.orderType == "GIFT") {
|
|
return h('div', [h('span', {}, '赠品订单'),]);
|
|
} else if (params.row.orderType == "PINTUAN") {
|
|
return h('div', [h('span', {}, '拼团订单'),]);
|
|
}
|
|
|
|
}
|
|
},
|
|
{
|
|
title: "来源",
|
|
key: "clientType",
|
|
width: 80,
|
|
render: (h, params) => {
|
|
if (params.row.clientType == "H5") {
|
|
return h("div",{},"移动端");
|
|
}else if(params.row.clientType == "PC") {
|
|
return h("div",{},"PC端");
|
|
}else if(params.row.clientType == "WECHAT_MP") {
|
|
return h("div",{},"小程序端");
|
|
}else if(params.row.clientType == "APP") {
|
|
return h("div",{},"移动应用端");
|
|
}
|
|
else{
|
|
return h("div",{},params.row.clientType);
|
|
}
|
|
},
|
|
},
|
|
{
|
|
title: "订单状态",
|
|
key: "orderStatus",
|
|
width: 95,
|
|
render: (h, params) => {
|
|
if (params.row.orderStatus == "UNPAID") {
|
|
return h('div', [h('span', {}, '未付款'),]);
|
|
} else if (params.row.orderStatus == "PAID") {
|
|
return h('div', [h('span', {}, '已付款'),]);
|
|
} else if (params.row.orderStatus == "UNDELIVERED") {
|
|
return h('div', [h('span', {}, '待发货'),]);
|
|
} else if (params.row.orderStatus == "DELIVERED") {
|
|
return h('div', [h('span', {}, '已发货'),]);
|
|
} else if (params.row.orderStatus == "COMPLETED") {
|
|
return h('div', [h('span', {}, '已完成'),]);
|
|
} else if (params.row.orderStatus == "TAKE") {
|
|
return h('div', [h('span', {}, '待核验'),]);
|
|
} else if (params.row.orderStatus == "CANCELLED") {
|
|
return h('div', [h('span', {}, '已取消'),]);
|
|
}
|
|
}
|
|
},
|
|
{
|
|
title: "支付状态",
|
|
key: "payStatus",
|
|
width: 95,
|
|
render: (h, params) => {
|
|
if (params.row.payStatus == "UNPAID") {
|
|
return h('div', [h('span', {}, '未付款'),]);
|
|
} else if (params.row.payStatus == "PAID") {
|
|
return h('div', [h('span', {}, '已付款'),]);
|
|
}
|
|
}
|
|
},
|
|
|
|
{
|
|
title: "售后状态",
|
|
key: "groupAfterSaleStatus",
|
|
width: 100,
|
|
render: (h, params) => {
|
|
if (params.row.groupAfterSaleStatus == "NEW") {
|
|
return h('div', [h('span', {}, '未申请'),]);
|
|
} else if (params.row.groupAfterSaleStatus == "NOT_APPLIED") {
|
|
return h('div', [h('span', {}, '未申请'),]);
|
|
} else if (params.row.groupAfterSaleStatus == "ALREADY_APPLIED") {
|
|
return h('div', [h('span', {}, '已申请'),]);
|
|
} else if (params.row.groupAfterSaleStatus == "EXPIRED") {
|
|
return h('div', [h('span', {}, '已失效'),]);
|
|
}
|
|
}
|
|
},
|
|
{
|
|
title: "投诉状态",
|
|
key: "groupComplainStatus",
|
|
width: 95,
|
|
render: (h, params) => {
|
|
if (params.row.groupComplainStatus == "NEW") {
|
|
return h('div', [h('span', {}, '未申请'),]);
|
|
} else if (params.row.groupComplainStatus == "NO_APPLY") {
|
|
return h('div', [h('span', {}, '未申请'),]);
|
|
} else if (params.row.groupComplainStatus == "APPLYING") {
|
|
return h('div', [h('span', {}, '申请中'),]);
|
|
} else if (params.row.groupComplainStatus == "COMPLETE") {
|
|
return h('div', [h('span', {}, '已完成'),]);
|
|
} else if (params.row.groupComplainStatus == "EXPIRED") {
|
|
return h('div', [h('span', {}, '已失效'),]);
|
|
} else if (params.row.groupComplainStatus == "CANCEL") {
|
|
return h('div', [h('span', {}, '取消投诉'),]);
|
|
}
|
|
}
|
|
},
|
|
{
|
|
title: "购买店铺",
|
|
key: "storeName",
|
|
width: 180,
|
|
tooltip: true
|
|
},
|
|
{
|
|
title: "下单时间",
|
|
key: "createTime",
|
|
width: 170,
|
|
},
|
|
|
|
],
|
|
orderData: [],//订单数据
|
|
orderTotal: 0,//订单总条数
|
|
//TA的订单form
|
|
orderSearchForm: {
|
|
pageNumber: 1, // 当前页数
|
|
pageSize: 10, // 页面大小
|
|
payStatus: "",
|
|
orderSn: "",
|
|
orderType: "",
|
|
},
|
|
refundGoodsOrderColumns: [
|
|
{
|
|
title: "售后服务单号",
|
|
key: "sn",
|
|
minWidth: 140,
|
|
slot: "refundGoodsOrderSlot",
|
|
|
|
},
|
|
{
|
|
title: "订单编号",
|
|
key: "orderSn",
|
|
minWidth: 120,
|
|
slot: "orderSlot",
|
|
},
|
|
{
|
|
title: "商品",
|
|
key: "goodsName",
|
|
minWidth: 300,
|
|
tooltip: true,
|
|
slot: "goodsSlot",
|
|
},
|
|
{
|
|
title: "会员名称",
|
|
key: "memberName",
|
|
width: 140,
|
|
},
|
|
{
|
|
title: "商家名称",
|
|
key: "storeName",
|
|
minWidth: 100,
|
|
tooltip: true
|
|
},
|
|
{
|
|
title: "售后金额",
|
|
key: "applyRefundPrice",
|
|
width: 110,
|
|
render: (h, params) => {
|
|
if (params.row.applyRefundPrice == null) {
|
|
return h(
|
|
"div",
|
|
this.$options.filters.unitPrice(0, "¥")
|
|
);
|
|
} else {
|
|
return h(
|
|
"div",
|
|
this.$options.filters.unitPrice(params.row.applyRefundPrice, "¥")
|
|
);
|
|
}
|
|
|
|
},
|
|
},
|
|
{
|
|
title: "售后类型",
|
|
key: "serviceType",
|
|
width: 100,
|
|
render: (h, params) => {
|
|
if (params.row.serviceType == "RETURN_MONEY") {
|
|
return h('div', [h('span', {}, '退款'),]);
|
|
} else if (params.row.serviceType == "RETURN_GOODS") {
|
|
return h('div', [h('span', {}, '退货'),]);
|
|
} else if (params.row.serviceType == "EXCHANGE_GOODS") {
|
|
return h('div', [h('span', {}, '换货'),]);
|
|
}
|
|
}
|
|
},
|
|
|
|
{
|
|
title: "售后状态",
|
|
key: "serviceStatus",
|
|
width: 110,
|
|
render: (h, params) => {
|
|
if (params.row.serviceStatus == "APPLY") {
|
|
return h('div', [h('span', {}, '申请中'),]);
|
|
} else if (params.row.serviceStatus == "PASS") {
|
|
return h('div', [h('span', {}, '通过售后'),]);
|
|
} else if (params.row.serviceStatus == "REFUSE") {
|
|
return h('div', [h('span', {}, '拒绝售后'),]);
|
|
} else if (params.row.serviceStatus == "BUYER_RETURN") {
|
|
return h('div', [h('span', {}, '买家退货,待卖家收货'),]);
|
|
} else if (params.row.serviceStatus == "SELLER_RE_DELIVERY") {
|
|
return h('div', [h('span', {}, '商家换货/补发'),]);
|
|
} else if (params.row.serviceStatus == "SELLER_CONFIRM") {
|
|
return h('div', [h('span', {}, '卖家确认收货'),]);
|
|
} else if (params.row.serviceStatus == "SELLER_TERMINATION") {
|
|
return h('div', [h('span', {}, '卖家终止售后'),]);
|
|
} else if (params.row.serviceStatus == "BUYER_CONFIRM") {
|
|
return h('div', [h('span', {}, '买家确认收货'),]);
|
|
} else if (params.row.serviceStatus == "BUYER_CANCEL") {
|
|
return h('div', [h('span', {}, '买家取消售后'),]);
|
|
} else if (params.row.serviceStatus == "COMPLETE") {
|
|
return h('div', [h('span', {}, '完成售后'),]);
|
|
} else if (params.row.serviceStatus == "WAIT_REFUND") {
|
|
return h('div', [h('span', {}, '待平台退款'),]);
|
|
}
|
|
}
|
|
},
|
|
{
|
|
title: "申请时间",
|
|
key: "createTime",
|
|
minWidth: 145,
|
|
tooltip: true
|
|
},
|
|
],
|
|
refundGoodsOrderData: [],//售后单数据
|
|
refundGoodsOrderTotal: 0,//售后单总条数
|
|
//TA的退货单form
|
|
refundGoodsOrderSearchForm: {
|
|
pageNumber: 1, // 当前页数
|
|
pageSize: 10, // 页面大小
|
|
},
|
|
//TA的退款单form
|
|
refundOrderSearchForm: {
|
|
pageNumber: 1, // 当前页数
|
|
pageSize: 10, // 页面大小
|
|
},
|
|
refundOrderData: [],//售后单数据
|
|
refundOrderTotal: 0,//售后单总条数
|
|
};
|
|
},
|
|
methods: {
|
|
init() {
|
|
//查店铺基本信息
|
|
this.getStoreInfo();
|
|
//查询店铺分类
|
|
this.getCategories();
|
|
//查询订单信息
|
|
this.getOrderData();
|
|
},
|
|
//会员信息tab改变事件
|
|
storeInfoChange(v) {
|
|
if (v == "order") {
|
|
this.getOrderData();
|
|
}
|
|
if (v == "refundGoods") {
|
|
this.getRefundGoodsOrderData();
|
|
}
|
|
if(v == "refund"){
|
|
this.getRefundOrder();
|
|
}
|
|
},
|
|
//查询会员信息
|
|
getStoreInfo() {
|
|
API_Store.getShopDetailData(this.id).then((res) => {
|
|
this.$set(this, "storeInfo", res.result);
|
|
//因switch开关需要用到true或者false 所以进行一次格式化
|
|
this.storeInfo.storeDisable = this.storeInfo.storeDisable === "OPEN" ? true : false
|
|
this.checkAllGroup = this.storeInfo.goodsManagementCategory.split(",");
|
|
});
|
|
},
|
|
//店铺状态改变事件
|
|
shopStatusChange(v) {
|
|
if (v) {
|
|
API_Store.enableBrand(this.id).then(res => {
|
|
});
|
|
} else {
|
|
API_Store.disableShop(this.id).then(res => {
|
|
});
|
|
}
|
|
},
|
|
//查询TA的订单
|
|
getOrderData() {
|
|
this.loading = true;
|
|
this.orderSearchForm.storeId = this.id
|
|
API_Order.getOrderList(this.orderSearchForm).then((res) => {
|
|
this.loading = false;
|
|
if (res.success) {
|
|
this.orderData = res.result.records;
|
|
this.orderTotal = res.result.total;
|
|
}
|
|
});
|
|
this.loading = false;
|
|
},
|
|
//查询TA的售后单
|
|
getRefundOrder() {
|
|
this.loading = true;
|
|
this.refundOrderSearchForm.storeId = this.id
|
|
this.refundOrderSearchForm.serviceType = "RETURN_MONEY"
|
|
API_Order.getAfterSaleOrderPage(this.refundOrderSearchForm).then((res) => {
|
|
this.loading = false;
|
|
if (res.success) {
|
|
this.refundOrderData = res.result.records;
|
|
this.refundOrderTotal = res.result.total;
|
|
}
|
|
});
|
|
this.loading = false;
|
|
},
|
|
//查询TA的售后单
|
|
getRefundGoodsOrderData() {
|
|
this.loading = true;
|
|
this.refundGoodsOrderSearchForm.storeId = this.id
|
|
this.refundGoodsOrderSearchForm.serviceType = "RETURN_GOODS"
|
|
API_Order.getAfterSaleOrderPage(this.refundGoodsOrderSearchForm).then((res) => {
|
|
this.loading = false;
|
|
if (res.success) {
|
|
this.refundGoodsOrderData = res.result.records;
|
|
this.refundGoodsOrderTotal = res.result.total;
|
|
}
|
|
});
|
|
this.loading = false;
|
|
},
|
|
detail(v) {
|
|
let sn = v.sn;
|
|
this.$router.push({
|
|
name: "after-order-detail",
|
|
query: {sn: sn},
|
|
});
|
|
|
|
},
|
|
//跳转到订单详情页面
|
|
orderDetail(v) {
|
|
this.$router.push({
|
|
name: "order-detail",
|
|
query: {sn: v},
|
|
});
|
|
},
|
|
//查询分类
|
|
getCategories() {
|
|
getCategoryTree().then((res) => {
|
|
if (res.success) {
|
|
this.categories = res.result;
|
|
}
|
|
});
|
|
},
|
|
|
|
|
|
//售后单页数变化
|
|
refundGoodsOrderChangePage(v) {
|
|
this.refundGoodsOrderSearchForm.pageNumber = v;
|
|
this.getRefundGoodsOrderData()
|
|
}
|
|
,
|
|
//售后单页数变化
|
|
refundGoodsOrderChangePageSize(v) {
|
|
this.refundGoodsOrderSearchForm.pageSize = v;
|
|
this.getRefundGoodsOrderData();
|
|
},
|
|
//售后单
|
|
refundGoodsOrderChangeSort(e) {
|
|
this.refundGoodsOrderSearchForm.sort = e.key;
|
|
this.refundGoodsOrderSearchForm.order = e.order;
|
|
this.getRefundGoodsOrderData();
|
|
},
|
|
|
|
//退款单页数变化
|
|
refundOrderChangePage(v) {
|
|
this.refundOrderSearchForm.pageNumber = v;
|
|
this.getRefundOrder()
|
|
}
|
|
,
|
|
//售后单页数变化
|
|
refundOrderChangePageSize(v) {
|
|
this.refundOrderSearchForm.pageSize = v;
|
|
this.getRefundOrder();
|
|
},
|
|
//售后单
|
|
refundOrderChangeSort(e) {
|
|
this.refundOrderSearchForm.sort = e.key;
|
|
this.refundOrderSearchForm.order = e.order;
|
|
this.getRefundOrder();
|
|
},
|
|
//订单记录页数变化
|
|
orderChangePage(v) {
|
|
this.orderSearchForm.pageNumber = v;
|
|
this.getOrderData()
|
|
}
|
|
,
|
|
//订单记录页数变化
|
|
orderChangePageSize(v) {
|
|
this.orderSearchForm.pageSize = v;
|
|
this.getOrderData();
|
|
},
|
|
orderChangeSort(e) {
|
|
this.orderSearchForm.sort = e.key;
|
|
this.orderSearchForm.order = e.order;
|
|
this.getOrderData();
|
|
},
|
|
selectDateRange(v) {
|
|
if (v) {
|
|
this.orderSearchForm.startDate = v[0];
|
|
this.orderSearchForm.endDate = v[1];
|
|
}
|
|
},
|
|
selectRefundGoodsDateRange(v) {
|
|
if (v) {
|
|
this.refundGoodsOrderSearchForm.startDate = v[0];
|
|
this.refundGoodsOrderSearchForm.endDate = v[1];
|
|
}
|
|
},
|
|
selectRefundDateRange(v) {
|
|
if (v) {
|
|
this.refundOrderSearchForm.startDate = v[0];
|
|
this.refundOrderSearchForm.endDate = v[1];
|
|
}
|
|
},
|
|
},
|
|
|
|
mounted() {
|
|
this.id = this.$route.query.id;
|
|
this.init();
|
|
}
|
|
,
|
|
};
|
|
</script>
|
|
<style lang="scss" scoped>
|
|
@import "shopDetail.scss";
|
|
</style>
|