已退款订单
This commit is contained in:
parent
be0220e3bd
commit
47c5de6384
|
@ -198,6 +198,15 @@ export const asyncRoutes = [
|
||||||
roles: ['order_back', 'editor']
|
roles: ['order_back', 'editor']
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: 'refunded',
|
||||||
|
component: () => import('@/views/order/refunded'),
|
||||||
|
name: 'OrderBack',
|
||||||
|
meta: {
|
||||||
|
title: '已退款订单',
|
||||||
|
roles: ['order_back', 'editor']
|
||||||
|
}
|
||||||
|
},
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,992 @@
|
||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<div class="filter-container">
|
||||||
|
<el-input
|
||||||
|
v-model="listQuery.sn"
|
||||||
|
placeholder="订单号"
|
||||||
|
style="width: 200px"
|
||||||
|
class="filter-item"
|
||||||
|
/>
|
||||||
|
<el-input
|
||||||
|
v-model="listQuery.product_name"
|
||||||
|
placeholder="标题"
|
||||||
|
style="width: 200px"
|
||||||
|
class="filter-item"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-input
|
||||||
|
v-model="listQuery.mobile"
|
||||||
|
placeholder="手机号"
|
||||||
|
style="width: 200px"
|
||||||
|
class="filter-item"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-input
|
||||||
|
v-model="listQuery.zhubo"
|
||||||
|
placeholder="主播"
|
||||||
|
style="width: 100px"
|
||||||
|
class="filter-item"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-input
|
||||||
|
v-model="listQuery.admin"
|
||||||
|
placeholder="客服"
|
||||||
|
style="width: 100px"
|
||||||
|
class="filter-item"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- <el-cascader
|
||||||
|
v-model="listQuery.os_status"
|
||||||
|
placeholder="平台状态"
|
||||||
|
:options="oss"
|
||||||
|
clearable
|
||||||
|
:props="{ checkStrictly: true }"
|
||||||
|
class="filter-item"
|
||||||
|
@change="handleChange"
|
||||||
|
/> -->
|
||||||
|
|
||||||
|
<el-select
|
||||||
|
v-model="listQuery.status"
|
||||||
|
filterable
|
||||||
|
placeholder="跟进状态"
|
||||||
|
class="filter-item"
|
||||||
|
style="width: 120px"
|
||||||
|
>
|
||||||
|
<el-option key="" label="请选择" value="" />
|
||||||
|
<el-option
|
||||||
|
v-for="(v, k) in status_arr"
|
||||||
|
:key="k"
|
||||||
|
:label="v"
|
||||||
|
:value="k"
|
||||||
|
/>
|
||||||
|
</el-select>
|
||||||
|
|
||||||
|
<el-select
|
||||||
|
v-model="listQuery.timetype"
|
||||||
|
filterable
|
||||||
|
placeholder="时间"
|
||||||
|
class="filter-item"
|
||||||
|
style="width: 120px"
|
||||||
|
>
|
||||||
|
<el-option key="" label="请选择" value="" />
|
||||||
|
<el-option
|
||||||
|
v-for="(v, k) in timetype_arr"
|
||||||
|
:key="k"
|
||||||
|
:label="v"
|
||||||
|
:value="k"
|
||||||
|
/>
|
||||||
|
</el-select>
|
||||||
|
|
||||||
|
<el-date-picker
|
||||||
|
v-model="listQuery.times"
|
||||||
|
class="filter-item"
|
||||||
|
type="datetimerange"
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
:default-time="['00:00:00', '23:59:59']"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
/>
|
||||||
|
<el-select
|
||||||
|
v-model="listQuery.appointment_status"
|
||||||
|
filterable
|
||||||
|
clearable
|
||||||
|
placeholder="预约状态"
|
||||||
|
class="filter-item"
|
||||||
|
style="width: 120px"
|
||||||
|
>
|
||||||
|
<el-option key="0" label="未预约" value="0" />
|
||||||
|
<el-option key="1" label="已预约(未处理)" value="1" />
|
||||||
|
<el-option key="2" label="已预约(已处理)" value="2" />
|
||||||
|
</el-select>
|
||||||
|
|
||||||
|
<el-button
|
||||||
|
class="filter-item"
|
||||||
|
type="primary"
|
||||||
|
icon="el-icon-search"
|
||||||
|
@click="getList"
|
||||||
|
>
|
||||||
|
搜索
|
||||||
|
</el-button>
|
||||||
|
|
||||||
|
<el-button
|
||||||
|
class="filter-item"
|
||||||
|
type="primary"
|
||||||
|
icon="el-icon-search"
|
||||||
|
@click="getList(1)"
|
||||||
|
>
|
||||||
|
导出
|
||||||
|
</el-button>
|
||||||
|
|
||||||
|
<!-- <el-button
|
||||||
|
class="filter-item"
|
||||||
|
type="primary"
|
||||||
|
icon="el-icon-search"
|
||||||
|
@click="dialog2Visible = true"
|
||||||
|
>
|
||||||
|
核单
|
||||||
|
</el-button> -->
|
||||||
|
<!-- <el-button
|
||||||
|
type="primary"
|
||||||
|
:disabled="multipleSelection.length == 0"
|
||||||
|
class="filter-item"
|
||||||
|
icon="el-icon-refresh"
|
||||||
|
@click="onCirculationAll()"
|
||||||
|
>
|
||||||
|
批量流转
|
||||||
|
</el-button> -->
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<el-table
|
||||||
|
v-loading="listLoading"
|
||||||
|
:data="list"
|
||||||
|
border
|
||||||
|
fit
|
||||||
|
highlight-current-row
|
||||||
|
style="width: 100%"
|
||||||
|
:height="tableMaxHeight"
|
||||||
|
@selection-change="handleSelectionChange"
|
||||||
|
>
|
||||||
|
<el-table-column type="selection" width="55"> </el-table-column>
|
||||||
|
<el-table-column align="center" fixed label="电话" width="140">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{ scope.row.mobile }}</span>
|
||||||
|
<span style="display: block; font-size: 12px"
|
||||||
|
>{{ scope.row.mobileInfo.area }}-{{
|
||||||
|
scope.row.mobileInfo.originalIsp
|
||||||
|
}}</span
|
||||||
|
>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column
|
||||||
|
align="center"
|
||||||
|
fixed
|
||||||
|
label="平台"
|
||||||
|
width="80"
|
||||||
|
prop="os_name"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-table-column align="center" fixed label="直播" width="60">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<el-tag v-if="scope.row.is_zhibo">是</el-tag>
|
||||||
|
<el-tag v-else type="info">否</el-tag>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column
|
||||||
|
align="center"
|
||||||
|
fixed
|
||||||
|
label="客服"
|
||||||
|
width="80"
|
||||||
|
prop="admin.username"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-table-column align="center" label="订单号" width="180" prop="sn" />
|
||||||
|
|
||||||
|
<el-table-column width="138px" align="center" label="下单时间">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{
|
||||||
|
scope.row.create_at | parseTime("{y}-{m}-{d} {h}:{i}")
|
||||||
|
}}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column width="160px" align="center" label="派单时间">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{
|
||||||
|
scope.row.give_time | parseTime("{y}-{m}-{d} {h}:{i}")
|
||||||
|
}}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column align="center" label="预约状态(抖音)" width="80">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<div
|
||||||
|
style="padding: 1px 5px; border-radius: 3px"
|
||||||
|
:style="{
|
||||||
|
color: order_status[scope.row.appointment_status],
|
||||||
|
border: `1px solid ${order_status[scope.row.appointment_status]}`,
|
||||||
|
}"
|
||||||
|
type="primary"
|
||||||
|
>
|
||||||
|
{{
|
||||||
|
scope.row.appointment_status == 1
|
||||||
|
? "已预约(未处理)"
|
||||||
|
: scope.row.appointment_status == 2
|
||||||
|
? "已预约(已处理)"
|
||||||
|
: "未预约"
|
||||||
|
}}
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column align="center" label="状态" width="80">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<div
|
||||||
|
style="padding: 1px 5px; border-radius: 3px"
|
||||||
|
:style="{
|
||||||
|
color: order_status[scope.row.order_status],
|
||||||
|
border: `1px solid ${order_status[scope.row.order_status]}`,
|
||||||
|
}"
|
||||||
|
type="primary"
|
||||||
|
>
|
||||||
|
{{ scope.row.order_status_name }}
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column align="center" label="跟进状态" width="90">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<div
|
||||||
|
style="padding: 1px 5px; border-radius: 3px"
|
||||||
|
:style="{
|
||||||
|
color: follow_status[scope.row.status],
|
||||||
|
border: `1px solid ${follow_status[scope.row.status]}`,
|
||||||
|
}"
|
||||||
|
type="primary"
|
||||||
|
>
|
||||||
|
{{ scope.row.status_name }}
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column
|
||||||
|
align="center"
|
||||||
|
width="500px"
|
||||||
|
label="标题"
|
||||||
|
prop="product_name"
|
||||||
|
/>
|
||||||
|
<el-table-column
|
||||||
|
width="500px"
|
||||||
|
align="center"
|
||||||
|
label="跟进备注"
|
||||||
|
prop="remark"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-table-column
|
||||||
|
align="center"
|
||||||
|
label="联系人"
|
||||||
|
width="120"
|
||||||
|
prop="contact"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- <el-table-column align="center" label="微信" width="80">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<i v-if="scope.row.is_wechat>0" class="el-icon-circle-check"></i>
|
||||||
|
</template>
|
||||||
|
</el-table-column> -->
|
||||||
|
|
||||||
|
<el-table-column width="138px" align="center" label="出行时间">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{ scope.row.travel_date | parseTime("{y}-{m}-{d}") }}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column width="138px" align="center" label="最后跟进时间">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{
|
||||||
|
scope.row.last_follow | parseTime("{y}-{m}-{d} {h}:{i}")
|
||||||
|
}}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column align="center" label="核单" width="80">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<i v-if="scope.row.is_check == 1" class="el-icon-check" />
|
||||||
|
<i v-if="scope.row.is_check == 2" class="el-icon-close" />
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column
|
||||||
|
align="center"
|
||||||
|
width="138px"
|
||||||
|
label="分类"
|
||||||
|
prop="category_desc"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-table-column align="center" label="总金额" width="120">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{ scope.row.total_price / 100 }}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
|
||||||
|
<el-table-column
|
||||||
|
align="center"
|
||||||
|
width="80px"
|
||||||
|
label="人数"
|
||||||
|
prop="quantity"
|
||||||
|
/>
|
||||||
|
<el-table-column
|
||||||
|
align="center"
|
||||||
|
label="主播"
|
||||||
|
width="80"
|
||||||
|
prop="anchor.username"
|
||||||
|
/>
|
||||||
|
<el-table-column width="138px" align="center" label="修改时间">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{
|
||||||
|
scope.row.update_time | parseTime("{y}-{m}-{d} {h}:{i}")
|
||||||
|
}}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
|
||||||
|
<pagination
|
||||||
|
v-show="total > 0"
|
||||||
|
:total="total"
|
||||||
|
:page.sync="listQuery.page"
|
||||||
|
:limit.sync="listQuery.limit"
|
||||||
|
@pagination="setMode"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<el-dialog title="订单跟进" :visible.sync="dialogVisible">
|
||||||
|
<el-form label-width="130px" :model="item">
|
||||||
|
<el-form-item label="产品名称">
|
||||||
|
{{ item.product_name }}
|
||||||
|
</el-form-item>
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="产品状态">
|
||||||
|
{{ item.order_status_name }}
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="数量">
|
||||||
|
{{ item.quantity }}
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="联系人">
|
||||||
|
{{ item.contact }}
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="手机">
|
||||||
|
{{ item.mobile }}
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="下单时间">
|
||||||
|
{{ item.create_at | parseTime("{y}-{m}-{d} {h}:{i}") }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="人员">
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="3">大人</el-col>
|
||||||
|
<el-col :span="5"
|
||||||
|
><el-input
|
||||||
|
v-model="item.personnel.adult"
|
||||||
|
name="adult"
|
||||||
|
placeholder="大人"
|
||||||
|
/></el-col>
|
||||||
|
<el-col :span="3">老人</el-col>
|
||||||
|
<el-col :span="5"
|
||||||
|
><el-input
|
||||||
|
v-model="item.personnel.old"
|
||||||
|
name="old"
|
||||||
|
placeholder="老人"
|
||||||
|
/></el-col>
|
||||||
|
<el-col :span="3">小孩</el-col>
|
||||||
|
<el-col :span="5"
|
||||||
|
><el-input
|
||||||
|
v-model="item.personnel.child"
|
||||||
|
name="child"
|
||||||
|
placeholder="小孩"
|
||||||
|
/></el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item v-if="item.status !== 1" label="核销码">
|
||||||
|
<el-input
|
||||||
|
v-model="item.check_sn"
|
||||||
|
name="check_sn"
|
||||||
|
placeholder="请输入平台核销码"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item label="加微信" v-if="item.status !== 2">
|
||||||
|
<el-checkbox
|
||||||
|
v-model="item.is_wechat"
|
||||||
|
:true-label="1"
|
||||||
|
:false-label="0"
|
||||||
|
>已加微信</el-checkbox
|
||||||
|
>
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item required pros="travel_date" label="出游日期">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="item.travel_date"
|
||||||
|
type="date"
|
||||||
|
placeholder="选择日期时间"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item v-if="item.status !== 1" label="返回日期">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="item.travel_end"
|
||||||
|
type="date"
|
||||||
|
placeholder="选择日期时间"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
|
<el-form-item
|
||||||
|
required
|
||||||
|
pros="next_follow"
|
||||||
|
label="下次跟进时间"
|
||||||
|
v-if="item.status !== 2"
|
||||||
|
>
|
||||||
|
<el-date-picker
|
||||||
|
v-model="next_follow"
|
||||||
|
type="datetime"
|
||||||
|
placeholder="选择日期时间"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-form-item label="跟进状态">
|
||||||
|
<template v-for="(v, k) in status_arr">
|
||||||
|
<el-radio v-if="k > 0" v-model="item.status" :label="k" border>{{
|
||||||
|
v
|
||||||
|
}}</el-radio>
|
||||||
|
</template>
|
||||||
|
</el-form-item>
|
||||||
|
<!-- <el-form-item label="快捷跟进" style="width: 600px;">
|
||||||
|
<el-select v-model="value" placeholder="请选择" @change="onChange">
|
||||||
|
<el-form-item style="display: inline-flex;text-align: left;width: 770px;">
|
||||||
|
<el-option
|
||||||
|
v-for="item in options"
|
||||||
|
:key="item.value"
|
||||||
|
style="width: 250px;display: inline-flex;word-break: break-all;"
|
||||||
|
:label="item.label"
|
||||||
|
:value="item.label"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>-->
|
||||||
|
|
||||||
|
<el-form-item required pros="desc" label="跟进说明">
|
||||||
|
<el-input v-model="item.desc" type="textarea" />
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
|
||||||
|
<div slot="footer" class="dialog-footer">
|
||||||
|
<el-button type="primary" @click="onSave(item)">保 存</el-button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<el-tabs v-model="active" type="border-card">
|
||||||
|
<el-tab-pane name="follow" label="跟进记录">
|
||||||
|
<el-table :data="item.follow" style="width: 100%">
|
||||||
|
<el-table-column label="日期" width="138">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{
|
||||||
|
scope.row.create_time | parseTime("{y}-{m}-{d} {h}:{i}")
|
||||||
|
}}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="跟进人" width="110" prop="name" />
|
||||||
|
<el-table-column label="状态" width="80">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{ status_arr[scope.row.status] }}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column prop="desc" label="跟进说明" />
|
||||||
|
</el-table>
|
||||||
|
</el-tab-pane>
|
||||||
|
<el-tab-pane name="finance" label="财务记录">
|
||||||
|
<el-table :data="item.finance" style="width: 100%">
|
||||||
|
<el-table-column label="日期">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{
|
||||||
|
scope.row.create_time | parseTime("{y}-{m}-{d} {h}:{i}")
|
||||||
|
}}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="类型" width="110">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{ type_arr[scope.row.type] }}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="状态" width="120">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<span>{{ scope.row.total / 100 }}</span>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
</el-tab-pane>
|
||||||
|
</el-tabs>
|
||||||
|
</el-dialog>
|
||||||
|
|
||||||
|
<el-dialog title="纯核销" :visible.sync="dialog2Visible">
|
||||||
|
<el-form label-width="160px" :model="form">
|
||||||
|
<el-form-item label="平台">
|
||||||
|
<el-radio v-model="form.os" label="1">美团</el-radio>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="核销码">
|
||||||
|
<el-input v-model="form.check_sn" placeholder="请输入平台核销码" />
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<div slot="footer" class="dialog-footer">
|
||||||
|
<el-button type="primary" @click="onPass(form)">保 存</el-button>
|
||||||
|
</div>
|
||||||
|
</el-dialog>
|
||||||
|
|
||||||
|
<el-dialog title="申请转出订单" :visible.sync="applyVisible">
|
||||||
|
<el-form label-width="160px" :model="item3" :rules="rules" ref="ruleForm">
|
||||||
|
<el-form-item label="标题:" v-if="!isAll">
|
||||||
|
<el-input v-model="item3.product_name" disabled />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="订单号:" v-if="!isAll">
|
||||||
|
<el-input v-model="item3.sn" disabled />
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item label="流转对象:" style="width: 600px" prop="flowObj">
|
||||||
|
<el-select
|
||||||
|
v-model="item3.flowObj"
|
||||||
|
placeholder="请选择"
|
||||||
|
@change="onChange2"
|
||||||
|
>
|
||||||
|
<el-form-item
|
||||||
|
style="display: inline-flex; text-align: left; width: 770px"
|
||||||
|
>
|
||||||
|
<el-option
|
||||||
|
v-for="item in adminList"
|
||||||
|
:key="item.value"
|
||||||
|
style="
|
||||||
|
width: 250px;
|
||||||
|
display: inline-flex;
|
||||||
|
word-break: break-all;
|
||||||
|
"
|
||||||
|
:label="item.username"
|
||||||
|
:value="item.id"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<div slot="footer" class="dialog-footer">
|
||||||
|
<!-- scope.row.backs&&scope.row.backs.status==2? -->
|
||||||
|
<el-button
|
||||||
|
v-if="item3.backs && item3.backs.status == 0"
|
||||||
|
type="primary"
|
||||||
|
@click="onCancel(item3.flowObj)"
|
||||||
|
>取 消</el-button
|
||||||
|
>
|
||||||
|
<el-button
|
||||||
|
v-else
|
||||||
|
type="primary"
|
||||||
|
@click="onCirculationSave(item3.flowObj)"
|
||||||
|
>确 认</el-button
|
||||||
|
>
|
||||||
|
</div>
|
||||||
|
</el-dialog>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
// import Pagination from '@/Wangeditor/Pagination'
|
||||||
|
import Pagination from "@/components/PaginationFixed";
|
||||||
|
import { orderBack, orderbackBatch } from "@/api/order";
|
||||||
|
export default {
|
||||||
|
name: "Orderlist",
|
||||||
|
components: { Pagination },
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
active: "follow",
|
||||||
|
types: {
|
||||||
|
0: "",
|
||||||
|
1: "",
|
||||||
|
2: "",
|
||||||
|
3: "primary",
|
||||||
|
4: "success",
|
||||||
|
5: "warning",
|
||||||
|
6: "danger",
|
||||||
|
7: "info",
|
||||||
|
},
|
||||||
|
types2: { 1: "primary", 2: "success", 3: "warning" },
|
||||||
|
status_arr: ["待跟进", "跟进中", "已核销", "核销失败", "放弃跟单"],
|
||||||
|
type_arr: ["-", "收益", "支出"],
|
||||||
|
timetype_arr: {},
|
||||||
|
order_status: [
|
||||||
|
"#9e9f9c",
|
||||||
|
"#04bcd9",
|
||||||
|
"#fc9904",
|
||||||
|
"#1193f4",
|
||||||
|
"#48b14b",
|
||||||
|
"#eb1662",
|
||||||
|
"#9d1cb5",
|
||||||
|
],
|
||||||
|
follow_status: [
|
||||||
|
"#9e9f9c",
|
||||||
|
"#04bcd9",
|
||||||
|
"#fc9904",
|
||||||
|
"#1193f4",
|
||||||
|
"#48b14b",
|
||||||
|
"#eb1662",
|
||||||
|
],
|
||||||
|
options: [],
|
||||||
|
value: null,
|
||||||
|
next_follow: null,
|
||||||
|
list: [],
|
||||||
|
total: 0,
|
||||||
|
listLoading: true,
|
||||||
|
listQuery: {
|
||||||
|
page: 1,
|
||||||
|
limit: 10,
|
||||||
|
times: [],
|
||||||
|
status: null,
|
||||||
|
admin: null,
|
||||||
|
zhubo: null,
|
||||||
|
os_status: [],
|
||||||
|
appointment_status: "",
|
||||||
|
},
|
||||||
|
item: { next_follow: "", personnel: { adult: "" } },
|
||||||
|
follow: [],
|
||||||
|
|
||||||
|
dialogVisible: false,
|
||||||
|
dialog2Visible: false,
|
||||||
|
applyVisible: false,
|
||||||
|
oss: [],
|
||||||
|
isSynchronization: false,
|
||||||
|
item3: {
|
||||||
|
sn: null,
|
||||||
|
backs: null,
|
||||||
|
flowObj: "",
|
||||||
|
os: null, // 初始值,你可以根据需要设置为 1、2 或 3
|
||||||
|
},
|
||||||
|
os_arr: { 1: "美团", 2: "快手", 3: "抖音(甄选)", 5: "抖音(新国旅)" },
|
||||||
|
multipleSelection: [],
|
||||||
|
sn: [],
|
||||||
|
adminList: [],
|
||||||
|
form: {},
|
||||||
|
isAll: false,
|
||||||
|
rules: {
|
||||||
|
flowObj: [
|
||||||
|
{ required: true, message: "请选择流转对象", trigger: "change" },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
};
|
||||||
|
},
|
||||||
|
async created() {
|
||||||
|
// this.listQuery.status = this.$route.query.status || null
|
||||||
|
this.listQuery.zhubo = this.$route.query.zhubo || null;
|
||||||
|
if (this.$route.query.start && this.$route.query.end) {
|
||||||
|
this.listQuery.times = [this.$route.query.start, this.$route.query.end];
|
||||||
|
}
|
||||||
|
// console.log(typeof this.$route.params.id);
|
||||||
|
this.setQuery("status");
|
||||||
|
this.setQuery("os_status");
|
||||||
|
this.setQuery("times");
|
||||||
|
this.setQuery("appointment_status");
|
||||||
|
// await this.getList();
|
||||||
|
// if (!this.$route.query.id) {
|
||||||
|
// await this.setOneClickRepair();
|
||||||
|
// await this.getList();
|
||||||
|
// }
|
||||||
|
this.getShortcutContent();
|
||||||
|
this.getAdminList();
|
||||||
|
},
|
||||||
|
mounted() {
|
||||||
|
console.log(this.$route.query);
|
||||||
|
this.setMode();
|
||||||
|
if (this.$route.query.id) {
|
||||||
|
this.onInfo({ id: this.$route.query.id });
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
tableMaxHeight() {
|
||||||
|
return window.innerHeight - 320 + "px";
|
||||||
|
},
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
$route(to, from) {
|
||||||
|
this.onInfo({ id: this.$route.query.id });
|
||||||
|
},
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
handleSelectionChange(val) {
|
||||||
|
// console.log(val);
|
||||||
|
|
||||||
|
this.multipleSelection = val;
|
||||||
|
const data = [];
|
||||||
|
this.multipleSelection.map((item) => {
|
||||||
|
data.push(item.sn);
|
||||||
|
});
|
||||||
|
this.sn = data;
|
||||||
|
},
|
||||||
|
setQuery(key) {
|
||||||
|
if (this.$route.query.hasOwnProperty(key)) {
|
||||||
|
this.listQuery[key] = this.$route.query[key];
|
||||||
|
} else {
|
||||||
|
this.listQuery[key] = "";
|
||||||
|
}
|
||||||
|
},
|
||||||
|
async setMode() {
|
||||||
|
await this.getList();
|
||||||
|
// await this.setOneClickRepair();
|
||||||
|
// await this.getList();
|
||||||
|
},
|
||||||
|
async setOneClickRepair() {
|
||||||
|
let arr = this.list.map((res) => {
|
||||||
|
return res.id;
|
||||||
|
});
|
||||||
|
await this.onOneClickRepair({ id: arr.join() });
|
||||||
|
},
|
||||||
|
async getList($is_excel) {
|
||||||
|
this.listQuery.excel = null;
|
||||||
|
this.listQuery.is_refunded = 1;
|
||||||
|
if ($is_excel == 1) {
|
||||||
|
this.listQuery.excel = 1;
|
||||||
|
const isdate = this.listQuery.times[0] instanceof Date;
|
||||||
|
const params = {
|
||||||
|
...this.listQuery,
|
||||||
|
times: [
|
||||||
|
isdate ? this.listQuery.times[0].toISOString() : "",
|
||||||
|
isdate ? this.listQuery.times[1].toISOString() : "",
|
||||||
|
],
|
||||||
|
};
|
||||||
|
window.open("/admin/order/index?" + this.objectToQuery(params));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await this.$axios
|
||||||
|
.get("/admin/order/index", { params: this.listQuery })
|
||||||
|
.then((response) => {
|
||||||
|
this.list = response.data.data;
|
||||||
|
this.total = response.data.total;
|
||||||
|
(this.timetype_arr = response.ext.timetype),
|
||||||
|
(this.oss = response.ext.oss);
|
||||||
|
this.listLoading = false;
|
||||||
|
this.isSynchronization = true;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
objectToQuery(obj) {
|
||||||
|
return Object.keys(obj)
|
||||||
|
.map((key) => {
|
||||||
|
const value = obj[key];
|
||||||
|
if (value == undefined || value == null) return "";
|
||||||
|
return encodeURIComponent(key) + "=" + encodeURIComponent(value);
|
||||||
|
})
|
||||||
|
.join("&");
|
||||||
|
},
|
||||||
|
onInfo(item) {
|
||||||
|
this.value = null;
|
||||||
|
this.next_follow = null;
|
||||||
|
this.$set(item, "next_follow", null);
|
||||||
|
// this.item = item;
|
||||||
|
this.active = "follow";
|
||||||
|
this.$axios
|
||||||
|
.get("/admin/order/info", { params: { id: item.id } })
|
||||||
|
.then((res) => {
|
||||||
|
this.item = res.data;
|
||||||
|
this.dialogVisible = true;
|
||||||
|
})
|
||||||
|
.catch((err) => {});
|
||||||
|
},
|
||||||
|
resetForm(formName) {
|
||||||
|
this.$refs[formName].resetFields();
|
||||||
|
},
|
||||||
|
getAdminList(typeDesc = "") {
|
||||||
|
this.$axios
|
||||||
|
.get("/admin/admin/index", {
|
||||||
|
params: { limit: 100, status: 1, is_order: 1, type_desc: typeDesc },
|
||||||
|
})
|
||||||
|
.then((response) => {
|
||||||
|
this.adminList = response.data.data;
|
||||||
|
this.listLoading = false;
|
||||||
|
})
|
||||||
|
.catch((err) => {});
|
||||||
|
},
|
||||||
|
onCirculation(item) {
|
||||||
|
this.getAdminList(item.category_desc);
|
||||||
|
this.applyVisible = true;
|
||||||
|
this.isAll = false;
|
||||||
|
this.item3 = { ...item, os: Number(item.os) };
|
||||||
|
console.log(this.item3);
|
||||||
|
if (this.item3.backs && this.item3.backs.admin_id) {
|
||||||
|
this.item3.flowObj = this.item3.backs.admin_id;
|
||||||
|
} else {
|
||||||
|
this.resetForm("ruleForm");
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// 批量设置
|
||||||
|
onCirculationAll() {
|
||||||
|
this.applyVisible = true;
|
||||||
|
this.isAll = true;
|
||||||
|
},
|
||||||
|
//确定
|
||||||
|
onCirculationSave(to_admin_id) {
|
||||||
|
this.$refs.ruleForm.validate(async (valid) => {
|
||||||
|
if (valid) {
|
||||||
|
let res;
|
||||||
|
if (this.isAll) {
|
||||||
|
this.$confirm("是否批量流转订单", "提示", {
|
||||||
|
confirmButtonText: "确定",
|
||||||
|
cancelButtonText: "取消",
|
||||||
|
type: "warning",
|
||||||
|
}).then(async () => {
|
||||||
|
res = await orderbackBatch({
|
||||||
|
sn: this.sn,
|
||||||
|
to_admin_id: to_admin_id,
|
||||||
|
});
|
||||||
|
if (res.data) {
|
||||||
|
this.$message({
|
||||||
|
message: "批量流转订单成功",
|
||||||
|
type: "success",
|
||||||
|
});
|
||||||
|
this.applyVisible = false;
|
||||||
|
this.isAll = false;
|
||||||
|
this.getList();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
res = await orderBack({
|
||||||
|
sn: this.item3.sn,
|
||||||
|
os: this.item3.os,
|
||||||
|
to_admin_id: to_admin_id,
|
||||||
|
});
|
||||||
|
if (res.data) {
|
||||||
|
this.$message({
|
||||||
|
message: "流转订单成功",
|
||||||
|
type: "success",
|
||||||
|
});
|
||||||
|
this.applyVisible = false;
|
||||||
|
this.isAll = false;
|
||||||
|
this.getList();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// 取消
|
||||||
|
onCancel() {
|
||||||
|
this.$refs.ruleForm.validate((valid) => {
|
||||||
|
if (valid) {
|
||||||
|
this.$axios
|
||||||
|
.post("/admin/order/backcancel", { id: this.item3.id })
|
||||||
|
.then((res) => {
|
||||||
|
this.applyVisible = false;
|
||||||
|
this.isAll = false;
|
||||||
|
this.getList();
|
||||||
|
})
|
||||||
|
.catch((err) => {
|
||||||
|
console.log(err);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
onBack() {
|
||||||
|
this.$axios
|
||||||
|
.post("/admin/order/back", this.item)
|
||||||
|
.then((res) => {
|
||||||
|
this.dialogVisible = false;
|
||||||
|
this.item = {};
|
||||||
|
this.getList();
|
||||||
|
})
|
||||||
|
.catch((err) => {});
|
||||||
|
},
|
||||||
|
onSave(item) {
|
||||||
|
this.$axios
|
||||||
|
.post("/admin/order/save", {
|
||||||
|
id: item.id,
|
||||||
|
check_sn: item.check_sn,
|
||||||
|
is_wechat: item.is_wechat,
|
||||||
|
travel_end: item.travel_end,
|
||||||
|
travel_date: item.travel_date,
|
||||||
|
desc: item.desc,
|
||||||
|
status: item.status,
|
||||||
|
next_follow: this.next_follow,
|
||||||
|
personnel: this.item.personnel,
|
||||||
|
})
|
||||||
|
.then((res) => {
|
||||||
|
this.dialogVisible = false;
|
||||||
|
this.item = { next_follow: "", personnel: { adult: "" } };
|
||||||
|
this.$router.push({
|
||||||
|
path: "/order/index",
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.catch((err) => {});
|
||||||
|
},
|
||||||
|
onPass(form) {
|
||||||
|
this.$axios
|
||||||
|
.post("/admin/order/pass", { check_sn: form.check_sn })
|
||||||
|
.then((res) => {
|
||||||
|
this.dialog2Visible = false;
|
||||||
|
this.form = {};
|
||||||
|
})
|
||||||
|
.catch((err) => {});
|
||||||
|
},
|
||||||
|
onChange(from) {
|
||||||
|
this.$set(
|
||||||
|
this.item,
|
||||||
|
"desc",
|
||||||
|
from + (this.item.desc != undefined ? this.item.desc : "")
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onChange2(from) {
|
||||||
|
this.$set(
|
||||||
|
this.item,
|
||||||
|
"to_admin_id",
|
||||||
|
from + (this.item.admin_id != undefined ? this.item.admin_id : "")
|
||||||
|
);
|
||||||
|
},
|
||||||
|
handleChange(os) {
|
||||||
|
console.log(os);
|
||||||
|
},
|
||||||
|
getShortcutContent() {
|
||||||
|
this.listLoading = true;
|
||||||
|
this.$axios
|
||||||
|
.get("/admin/shortcutContent/list", {
|
||||||
|
params: { page: 1, limit: 50, status: 1 },
|
||||||
|
})
|
||||||
|
.then((response) => {
|
||||||
|
for (const r of response.data.data) {
|
||||||
|
this.options.push({ value: r.id, label: r.content });
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.catch(() => {});
|
||||||
|
},
|
||||||
|
onOneClickRepair(item) {
|
||||||
|
// this.$axios
|
||||||
|
// .post("/admin/order/oneClickRepair", { id: item.id })
|
||||||
|
// .then((res) => {
|
||||||
|
// this.$notify({
|
||||||
|
// title: "成功",
|
||||||
|
// message: "同步完成",
|
||||||
|
// type: "success",
|
||||||
|
// });
|
||||||
|
// // this.getList();
|
||||||
|
// })
|
||||||
|
// .catch((err) => {
|
||||||
|
// this.$notify.error({
|
||||||
|
// title: "同步失败",
|
||||||
|
// message: err,
|
||||||
|
// });
|
||||||
|
// });
|
||||||
|
},
|
||||||
|
onOneClickYyHandle(item) {
|
||||||
|
this.$axios
|
||||||
|
.post("/admin/order/changeAppointmentStatus", { id: item.id })
|
||||||
|
.then((res) => {
|
||||||
|
this.dialogVisible = false;
|
||||||
|
this.$notify({
|
||||||
|
title: "成功",
|
||||||
|
message: "已处理",
|
||||||
|
type: "success",
|
||||||
|
});
|
||||||
|
// this.getList();
|
||||||
|
})
|
||||||
|
.catch((err) => {
|
||||||
|
this.$notify.error({
|
||||||
|
title: "错误",
|
||||||
|
message: err,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.app-container {
|
||||||
|
position: relative;
|
||||||
|
padding-bottom: 60px; /* 分页条的高度 */
|
||||||
|
}
|
||||||
|
|
||||||
|
.filter-container,
|
||||||
|
.el-table {
|
||||||
|
padding-bottom: 5px; /* 分页条的高度,以避免内容重叠 */
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -38,8 +38,8 @@ module.exports = {
|
||||||
},
|
},
|
||||||
proxy: {
|
proxy: {
|
||||||
'/dev-api': { // 接口地址 以 api开头的都走下面的配置
|
'/dev-api': { // 接口地址 以 api开头的都走下面的配置
|
||||||
target: 'https://www.szjinao.cn', // 代理目标地址为后端服务器地址 127.0.0.1 192.168.1.2
|
// target: 'https://www.szjinao.cn', // 代理目标地址为后端服务器地址 127.0.0.1 192.168.1.2
|
||||||
// target: 'http://192.168.0.100:8787', // 代理目标地址为后端服务器地址 127.0.0.1 192.168.1.2
|
target: 'http://192.168.0.100:8787', // 代理目标地址为后端服务器地址 127.0.0.1 192.168.1.2
|
||||||
ws: true, // 是否支持 websocket 请求 支持
|
ws: true, // 是否支持 websocket 请求 支持
|
||||||
changeOrigin: true, // 是否启用跨域
|
changeOrigin: true, // 是否启用跨域
|
||||||
pathRewrite: {
|
pathRewrite: {
|
||||||
|
|
|
@ -26,6 +26,7 @@ class OrderController extends base
|
||||||
$timetype = $request->get('timetype');
|
$timetype = $request->get('timetype');
|
||||||
$times = $request->get('times');
|
$times = $request->get('times');
|
||||||
$os_status = $request->get('os_status');
|
$os_status = $request->get('os_status');
|
||||||
|
$isRefunded = $request->get('is_refunded', 0);
|
||||||
|
|
||||||
$where = [];
|
$where = [];
|
||||||
if(!$request->admin->is_super) {
|
if(!$request->admin->is_super) {
|
||||||
|
@ -33,6 +34,7 @@ class OrderController extends base
|
||||||
} else {
|
} else {
|
||||||
$where = [['admin_id', '>', 0]];
|
$where = [['admin_id', '>', 0]];
|
||||||
}
|
}
|
||||||
|
$where[] = ['is_refunded', '=', $isRefunded];
|
||||||
|
|
||||||
if($sn) {
|
if($sn) {
|
||||||
$where[] = ['sn','=', $sn];
|
$where[] = ['sn','=', $sn];
|
||||||
|
@ -94,7 +96,7 @@ class OrderController extends base
|
||||||
$admin_id = Admins::where('username', $admin)->value('id');
|
$admin_id = Admins::where('username', $admin)->value('id');
|
||||||
$query->where('admin_id', $admin_id);
|
$query->where('admin_id', $admin_id);
|
||||||
}
|
}
|
||||||
|
Log::info($query->getLastSql());
|
||||||
$excel = $request->get('excel');
|
$excel = $request->get('excel');
|
||||||
if($excel == 1) {
|
if($excel == 1) {
|
||||||
$orders = $query->select();
|
$orders = $query->select();
|
||||||
|
|
|
@ -24,9 +24,9 @@ class Orders extends base
|
||||||
// 0 1 2 3 4 5 6 7 8
|
// 0 1 2 3 4 5 6 7 8
|
||||||
|
|
||||||
const AllOssStatusSql = [
|
const AllOssStatusSql = [
|
||||||
1 => '((os=1 and order_status=3) or (os=2 and order_status=4) or (os in ("3", "5") and order_status=1))', //待使用
|
1 => '((os in (1,7) and order_status=3) or (os=2 and order_status=4) or (os in ("3", "5") and order_status=1))', //待使用
|
||||||
2 => '((os=1 and order_status=4) or (os=2 and order_status=5) or (os in ("3", "5") and order_status=2))', //已核销
|
2 => '((os in (1,7) and order_status=4) or (os=2 and order_status=5) or (os in ("3", "5") and order_status=2))', //已核销
|
||||||
3 => '((os=1 and order_status=5) or (os in ("3", "5") and order_status=4))' //已退款(快手暂无已退款状态)
|
3 => '((os in (1,7) and order_status=5) or (os in ("3", "5") and order_status=4))' //已退款(快手暂无已退款状态)
|
||||||
];
|
];
|
||||||
|
|
||||||
const StatusName = ['待跟进', '跟进中', '已核销', '核销失败', '放弃跟单'];
|
const StatusName = ['待跟进', '跟进中', '已核销', '核销失败', '放弃跟单'];
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1 @@
|
||||||
|
.pagination-container[data-v-28fdfbeb]{padding:32px 16px;position:fixed;bottom:0;left:0;width:100%;background:#fff;padding:40px 280px;-webkit-box-shadow:0 -2px 10px rgba(0,0,0,.1);box-shadow:0 -2px 10px rgba(0,0,0,.1);z-index:100}.pagination-container.hidden[data-v-28fdfbeb]{display:none}.app-container[data-v-79892438]{position:relative;padding-bottom:60px}.el-table[data-v-79892438],.filter-container[data-v-79892438]{padding-bottom:5px}
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -7,4 +7,22 @@ ALTER TABLE `admins`
|
||||||
ADD COLUMN `type` tinyint NOT NULL DEFAULT 0 COMMENT '类型(0-管理员,1-客服,2-主播,3-中控)' AFTER `route_type`;
|
ADD COLUMN `type` tinyint NOT NULL DEFAULT 0 COMMENT '类型(0-管理员,1-客服,2-主播,3-中控)' AFTER `route_type`;
|
||||||
|
|
||||||
ALTER TABLE `orders`
|
ALTER TABLE `orders`
|
||||||
ADD COLUMN `live_room_works` int NOT NULL DEFAULT 0 COMMENT '排班表id' AFTER `appointment_status`;
|
ADD COLUMN `live_room_works` int NOT NULL DEFAULT 0 COMMENT '排班表id' AFTER `appointment_status`;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
2024/10/13
|
||||||
|
ALTER TABLE `orders`
|
||||||
|
ADD COLUMN `is_refunded` tinyint NOT NULL DEFAULT 0 COMMENT '是否已退款(0-否,1-是)' AFTER `update_time`;
|
||||||
|
|
||||||
|
update
|
||||||
|
`orders`
|
||||||
|
set is_refunded = 1
|
||||||
|
WHERE
|
||||||
|
`os` IN ( '1', '7' ) and order_status = 5;
|
||||||
|
|
||||||
|
update
|
||||||
|
`orders`
|
||||||
|
set is_refunded = 1
|
||||||
|
WHERE
|
||||||
|
(`os` IN ( '3', '5' ) and order_status = 4)
|
Loading…
Reference in New Issue