Merge branch 'bd-dev' of 47.94.45.65:angelo/web-base-admin into bd-test
This commit is contained in:
commit
a77aad953b
|
@ -300,12 +300,44 @@ export function tourismDetails(params) {
|
|||
})
|
||||
}
|
||||
|
||||
// 营销管理-直推排行数据
|
||||
export function getMemberDirectPusht(params) {
|
||||
// 营销管理-直推人数排行数据
|
||||
export function getMemberDirectPush(data) {
|
||||
return request({
|
||||
url: '/member/manager/member/get-member-direct-push',
|
||||
method: 'get',
|
||||
params
|
||||
url: '/member/manage/member-statistics/topPeople',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
// 营销管理-直推金额排行数据
|
||||
export function getMemberDirectPushAmount(data) {
|
||||
return request({
|
||||
url: '/member/manage/member-statistics/topAmount',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
|
||||
// params type setShowPeople setShowAmount
|
||||
export function getMemberDirectPushSwitchStatus(type) {
|
||||
return request({
|
||||
url: `member/manage/member-statistics/${type}`,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
|
||||
// 直推人数排行开关
|
||||
export function setMemberDirectPush(flag) {
|
||||
return request({
|
||||
url: `member/manage/member-statistics/setShowPeople/${flag}`,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
|
||||
// 直推金额排行开关
|
||||
export function setMemberDirectPushAmount(flag) {
|
||||
return request({
|
||||
url: `member/manage/member-statistics/setShowAmount/${flag}`,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
|
||||
|
|
|
@ -1928,6 +1928,7 @@ export const constantRoutes = [
|
|||
}
|
||||
]
|
||||
},
|
||||
|
||||
{
|
||||
path: 'lotteryDetails',
|
||||
name: 'LotteryDetails',
|
||||
|
@ -1941,33 +1942,6 @@ export const constantRoutes = [
|
|||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
path: 'rechargeCard',
|
||||
name: 'RechargeCard',
|
||||
component: ParentView,
|
||||
children: [
|
||||
{
|
||||
path: 'rechargeCardList',
|
||||
name: 'RechargeCardList',
|
||||
component: () => import('@/views/marketing/rechargeCard/index'),
|
||||
meta: { title: '充值提货卡' }
|
||||
},
|
||||
{
|
||||
path: 'addRechargeCard',
|
||||
name: 'addRechargeCard',
|
||||
component: () => import('@/views/marketing/rechargeCard/addRechargeCard'),
|
||||
meta: { title: '充值提货卡-添加' },
|
||||
hidden: true
|
||||
},
|
||||
{
|
||||
path: 'rechargeQc',
|
||||
name: 'rechargeQc',
|
||||
component: () => import('@/views/marketing/rechargeCard/rechargeQc'),
|
||||
meta: { title: '充值提货卡-添加' },
|
||||
hidden: true
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
path: 'lottery',
|
||||
name: 'Lottery',
|
||||
|
@ -2002,6 +1976,33 @@ export const constantRoutes = [
|
|||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
path: 'rechargeCard',
|
||||
name: 'RechargeCard',
|
||||
component: ParentView,
|
||||
children: [
|
||||
{
|
||||
path: 'rechargeCardList',
|
||||
name: 'RechargeCardList',
|
||||
component: () => import('@/views/marketing/rechargeCard/index'),
|
||||
meta: { title: '充值提货卡' }
|
||||
},
|
||||
{
|
||||
path: 'addRechargeCard',
|
||||
name: 'addRechargeCard',
|
||||
component: () => import('@/views/marketing/rechargeCard/addRechargeCard'),
|
||||
meta: { title: '充值提货卡-添加' },
|
||||
hidden: true
|
||||
},
|
||||
{
|
||||
path: 'rechargeQc',
|
||||
name: 'rechargeQc',
|
||||
component: () => import('@/views/marketing/rechargeCard/rechargeQc'),
|
||||
meta: { title: '充值提货卡-添加' },
|
||||
hidden: true
|
||||
}
|
||||
]
|
||||
},
|
||||
|
||||
{
|
||||
path: 'directUpgrade',
|
||||
|
@ -2023,6 +2024,34 @@ export const constantRoutes = [
|
|||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
path: 'directRanking',
|
||||
name: 'DirectRanking',
|
||||
component: ParentView,
|
||||
meta: { title: '直推排行数据' },
|
||||
children: [
|
||||
{
|
||||
path: 'directRankingList',
|
||||
name: 'DirectRankingList',
|
||||
component: () => import('@/views/marketing/directRanking/index'),
|
||||
meta: { title: '直推人数排行数据' }
|
||||
},
|
||||
{
|
||||
path: 'directAmountRankingList',
|
||||
name: 'DirectAmountRankingList',
|
||||
component: () => import('@/views/marketing/directRanking/amount'),
|
||||
meta: { title: '直推金额排行数据' },
|
||||
hidden: true
|
||||
},
|
||||
{
|
||||
path: 'directConfig',
|
||||
name: 'DirectConfig',
|
||||
component: () => import('@/views/marketing/directRanking/config'),
|
||||
meta: { title: '直推配置' },
|
||||
hidden: true
|
||||
}
|
||||
]
|
||||
},
|
||||
// {
|
||||
// path: 'benefitsGift',
|
||||
// name: 'BenefitsGift',
|
||||
|
@ -2122,19 +2151,6 @@ export const constantRoutes = [
|
|||
meta: { title: '旅游活动数据' }
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
path: 'directRanking',
|
||||
name: 'DirectRanking',
|
||||
component: ParentView,
|
||||
children: [
|
||||
{
|
||||
path: 'directRankingList',
|
||||
name: 'DirectRankingList',
|
||||
component: () => import('@/views/marketing/directRanking/index'),
|
||||
meta: { title: '直推排行数据' }
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
]
|
||||
|
|
|
@ -204,6 +204,9 @@ export default {
|
|||
}
|
||||
},
|
||||
methods: {
|
||||
splitDate(date) {
|
||||
return date.split(' ')[0]
|
||||
},
|
||||
getDetails() {
|
||||
api
|
||||
.recommendDetail({
|
||||
|
@ -223,13 +226,17 @@ export default {
|
|||
this.ruleForm.actEndDate = res.data.activityParam.actEndDate
|
||||
this.ruleForm.disStartDate = res.data.activityParam.disStartDate
|
||||
this.ruleForm.disEndDate = res.data.activityParam.disEndDate
|
||||
const actStartDate = this.splitDate(res.data.activityParam.actStartDate)
|
||||
const actEndDate = this.splitDate(res.data.activityParam.actEndDate)
|
||||
const disStartDate = this.splitDate(res.data.activityParam.disStartDate)
|
||||
const disEndDate = this.splitDate(res.data.activityParam.disEndDate)
|
||||
this.$set(this.ruleForm, 'ruleFormTime', [
|
||||
res.data.activityParam.actStartDate,
|
||||
res.data.activityParam.actEndDate
|
||||
actStartDate,
|
||||
actEndDate
|
||||
])
|
||||
this.$set(this.ruleForm, 'ruleFormTime1', [
|
||||
res.data.activityParam.disStartDate,
|
||||
res.data.activityParam.disEndDate
|
||||
disStartDate,
|
||||
disEndDate
|
||||
])
|
||||
const arr1 = []
|
||||
const arr2 = []
|
||||
|
@ -267,12 +274,12 @@ export default {
|
|||
)
|
||||
this.$set(this.ruleForm, 'actCover', this.addData.activityParam.actCover)
|
||||
this.$set(this.ruleForm, 'ruleFormTime', [
|
||||
this.addData.activityParam.actStartDate,
|
||||
this.addData.activityParam.actEndDate
|
||||
this.splitDate(this.addData.activityParam.actStartDate),
|
||||
this.splitDate(this.addData.activityParam.actEndDate)
|
||||
])
|
||||
this.$set(this.ruleForm, 'ruleFormTime1', [
|
||||
this.addData.activityParam.disStartDate,
|
||||
this.addData.activityParam.disEndDate
|
||||
this.splitDate(this.addData.activityParam.disStartDate),
|
||||
this.splitDate(this.addData.activityParam.disEndDate)
|
||||
])
|
||||
const arr1 = []
|
||||
const arr2 = []
|
||||
|
@ -400,7 +407,13 @@ export default {
|
|||
{},
|
||||
{
|
||||
controlType: this.controlType,
|
||||
activityParam: this.ruleForm,
|
||||
activityParam: {
|
||||
...this.ruleForm,
|
||||
actStartDate: this.ruleForm.actStartDate + ' 00:00:00',
|
||||
actEndDate: this.ruleForm.actEndDate + ' 23:59:59',
|
||||
disStartDate: this.ruleForm.disStartDate + ' 00:00:00',
|
||||
disEndDate: this.ruleForm.disEndDate + ' 23:59:59'
|
||||
},
|
||||
recommendUpgradeList:
|
||||
this.$refs.directUpdata.recommendUpgradeList,
|
||||
authorityList: this.$refs.directUpdata.form.waresAuthorityList
|
||||
|
|
|
@ -0,0 +1,288 @@
|
|||
<template>
|
||||
<div class="page">
|
||||
<topBar
|
||||
v-if="topList.length > 0"
|
||||
:top-list="topList"
|
||||
:moren="moren"
|
||||
/>
|
||||
<div class="main">
|
||||
<div class="form_all">
|
||||
<el-form ref="select" :model="select" label-width="auto">
|
||||
<el-row :gutter="10">
|
||||
<el-col :span="6">
|
||||
<el-form-item :label="'统计时间'">
|
||||
<el-date-picker
|
||||
v-model="select.selectDate"
|
||||
type="month"
|
||||
value-format="yyyy-MM"
|
||||
:placeholder="'请选择'"
|
||||
:clearable="false"
|
||||
@change="changeTime"
|
||||
/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="4">
|
||||
<el-button type="primary" @click="getDataList">
|
||||
{{ '搜索' }}</el-button>
|
||||
<el-button type="" @click="reset"> {{ '重置' }}</el-button>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
</div>
|
||||
<div class="maintop">
|
||||
<div class="mainbtn">
|
||||
<el-button
|
||||
v-hasButtons="['directRankingExport']"
|
||||
size="small"
|
||||
style="background-color: #ffad41"
|
||||
class="thebtn1"
|
||||
@click="handleExport"
|
||||
>
|
||||
{{ '导出' }}</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<div class="maintable">
|
||||
<el-table
|
||||
v-loading="loading"
|
||||
:data="tableData"
|
||||
style="width: 100%"
|
||||
:header-cell-style="{ background: '#EEEEEE' }"
|
||||
:row-class-name="tableRowClassName"
|
||||
@selection-change="handleSelectionChange"
|
||||
>
|
||||
<el-table-column type="selection" width="55" />
|
||||
|
||||
<el-table-column align="center" prop="ranking" label="排名">
|
||||
<template slot-scope="scope">
|
||||
<span :class="getRankingClass(scope.$index + 1)">{{ scope.$index + 1 }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="memberCode"
|
||||
:label="'会员编号'"
|
||||
/>
|
||||
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="memberName"
|
||||
:label="'会员姓名'"
|
||||
/>
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="numberOfAmount"
|
||||
label="直推金额(万元)"
|
||||
/>
|
||||
</el-table>
|
||||
</div>
|
||||
</div>
|
||||
<!-- <pagination
|
||||
v-show="total > 0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getDataList"
|
||||
/> -->
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import * as api from '@/api/giftGoods.js'
|
||||
import mixins from './mixins'
|
||||
export default {
|
||||
name: 'DirectRankingList',
|
||||
|
||||
mixins: [mixins],
|
||||
data() {
|
||||
return {
|
||||
select: {
|
||||
selectDate: ''
|
||||
},
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 50,
|
||||
year: '',
|
||||
month: '',
|
||||
faker: false
|
||||
},
|
||||
total: 0,
|
||||
tableData: [],
|
||||
loading: false,
|
||||
moren: 'directAmountRankingList'
|
||||
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.init()
|
||||
this.getDataList()
|
||||
},
|
||||
methods: {
|
||||
aaa(obj) {
|
||||
console.log(obj, '....obj')
|
||||
},
|
||||
init() {
|
||||
const month = new Date().getMonth() + 1
|
||||
const monthStr = month < 10 ? '0' + month : month
|
||||
this.select.selectDate = new Date().getFullYear() + '-' + monthStr
|
||||
},
|
||||
changeTime(val) {
|
||||
this.queryParams.selectDate = val
|
||||
},
|
||||
reset() {
|
||||
this.select = {}
|
||||
},
|
||||
|
||||
getDataList() {
|
||||
this.loading = true
|
||||
const [year, month] = this.select.selectDate.split('-')
|
||||
api
|
||||
.getMemberDirectPushAmount(Object.assign({}, this.queryParams, this.select, {
|
||||
year,
|
||||
month
|
||||
}))
|
||||
.then((res) => {
|
||||
this.tableData = res.data
|
||||
this.total = res.total
|
||||
this.loading = false
|
||||
})
|
||||
},
|
||||
|
||||
handleSelectionChange(val) {},
|
||||
tableRowClassName({ row, rowIndex }) {
|
||||
if (rowIndex % 2 === 1) {
|
||||
return 'warning-row'
|
||||
} else if (rowIndex % 2 === 0) {
|
||||
return 'success-row'
|
||||
}
|
||||
return ''
|
||||
},
|
||||
getRankingClass(ranking) {
|
||||
if (ranking === 1) {
|
||||
return 'first-place-cell'
|
||||
} else if (ranking === 2) {
|
||||
return 'second-place-cell'
|
||||
} else if (ranking === 3) {
|
||||
return 'third-place-cell'
|
||||
}
|
||||
return 'normal-ranking'
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped lang="scss">
|
||||
::v-deep .el-table .warning-row {
|
||||
background: #f9f9f9;
|
||||
}
|
||||
|
||||
::v-deep .el-table .success-row {
|
||||
background: #ffffff;
|
||||
}
|
||||
::v-deep .el-table thead {
|
||||
color: #000000;
|
||||
}
|
||||
::v-deep .el-select {
|
||||
width: 100%;
|
||||
}
|
||||
.uploadIcon ::v-deep .el-upload--picture-card {
|
||||
display: none !important; /* 上传按钮隐藏 */
|
||||
}
|
||||
.page {
|
||||
padding: 20px;
|
||||
background: #f9f9f9;
|
||||
font-size: 14px;
|
||||
.main {
|
||||
background: #ffffff;
|
||||
border-radius: 8px;
|
||||
box-shadow: 0px 2px 20px 0px rgba(238, 238, 238, 0.5);
|
||||
.form_all {
|
||||
padding: 0px 20px 0 20px;
|
||||
// margin-bottom: 20px;
|
||||
background: #fff;
|
||||
border-radius: 8px;
|
||||
}
|
||||
.maintop {
|
||||
display: flex;
|
||||
padding: 0px 0px;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
|
||||
background: #f8f8f8;
|
||||
.mainbtn {
|
||||
.thebtn1 {
|
||||
background: #3181e5;
|
||||
color: #ffffff;
|
||||
}
|
||||
.thebtn2 {
|
||||
background: #ffad41;
|
||||
color: #ffffff;
|
||||
}
|
||||
}
|
||||
.maintitle {
|
||||
font-size: 10px;
|
||||
font-family: MicrosoftYaHei;
|
||||
color: #999999;
|
||||
}
|
||||
}
|
||||
}
|
||||
.tem {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
img {
|
||||
width: 28px;
|
||||
height: 20px;
|
||||
margin-right: 3px;
|
||||
}
|
||||
}
|
||||
.isRed {
|
||||
color: #ed1d25;
|
||||
}
|
||||
.isGreen {
|
||||
color: #1ab62b;
|
||||
}
|
||||
.bgImg {
|
||||
width: 48px;
|
||||
height: 48px;
|
||||
}
|
||||
}
|
||||
.openClose {
|
||||
text-align: right;
|
||||
margin-right: 10px;
|
||||
color: #3181e5;
|
||||
}
|
||||
.dizhi {
|
||||
::v-deep .el-cascader {
|
||||
width: 100%;
|
||||
}
|
||||
}
|
||||
::v-deep .el-date-editor.el-input,
|
||||
.el-date-editor.el-input__inner {
|
||||
width: auto;
|
||||
}
|
||||
.lan {
|
||||
text-decoration: underline;
|
||||
color: #48b2fd;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
/* 排名字体颜色样式 */
|
||||
.first-place-cell {
|
||||
color: #FFD700;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.second-place-cell {
|
||||
color: #C0C0C0;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.third-place-cell {
|
||||
color: #CD853F;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.normal-ranking {
|
||||
color: #666666;
|
||||
}
|
||||
</style>
|
|
@ -0,0 +1,94 @@
|
|||
<template>
|
||||
<div class="page">
|
||||
<topBar
|
||||
v-if="topList.length > 0"
|
||||
:top-list="topList"
|
||||
:moren="moren"
|
||||
/>
|
||||
<el-form>
|
||||
<el-form-item label="直推人数排行榜">
|
||||
<el-switch
|
||||
:value="pushPeople"
|
||||
active-text="开启"
|
||||
inactive-text="关闭"
|
||||
active-value="true"
|
||||
inactive-value="false"
|
||||
@change="pushPeopleHandle"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="直推金额排行榜">
|
||||
<el-switch
|
||||
:value="pushAmount"
|
||||
active-text="开启"
|
||||
inactive-text="关闭"
|
||||
active-value="true"
|
||||
inactive-value="false"
|
||||
@change="pushAmountHandle"
|
||||
/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</div>
|
||||
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import mixins from './mixins'
|
||||
import {
|
||||
getMemberDirectPushSwitchStatus,
|
||||
setMemberDirectPush,
|
||||
setMemberDirectPushAmount
|
||||
} from '@/api/giftGoods'
|
||||
|
||||
export default {
|
||||
name: 'DirectRankingConfig',
|
||||
mixins: [mixins],
|
||||
data() {
|
||||
return {
|
||||
pushPeople: false,
|
||||
pushAmount: false,
|
||||
moren: 'directConfig'
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.getMemberDirectPushSwitchStatus()
|
||||
},
|
||||
methods: {
|
||||
pushPeopleHandle(val) {
|
||||
this.pushPeople = val
|
||||
this.setMemberDirectPush(val)
|
||||
},
|
||||
pushAmountHandle(val) {
|
||||
this.pushAmount = val
|
||||
this.setMemberDirectPushAmount(val)
|
||||
},
|
||||
getMemberDirectPushSwitchStatus() {
|
||||
getMemberDirectPushSwitchStatus('getShowPeople').then(res => {
|
||||
this.pushPeople = res.data
|
||||
})
|
||||
getMemberDirectPushSwitchStatus('getShowAmount').then(res => {
|
||||
this.pushAmount = res.data
|
||||
})
|
||||
},
|
||||
|
||||
setMemberDirectPush(val) {
|
||||
setMemberDirectPush(val).then(res => {
|
||||
if (res.code === 200) {
|
||||
this.pushPeople = res.data
|
||||
}
|
||||
})
|
||||
},
|
||||
setMemberDirectPushAmount(val) {
|
||||
setMemberDirectPushAmount(val).then(res => {
|
||||
if (res.code === 200) {
|
||||
this.pushAmount = res.data
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
</script>
|
||||
|
||||
<style>
|
||||
|
||||
</style>
|
|
@ -2,171 +2,139 @@
|
|||
<div class="page">
|
||||
<topBar
|
||||
v-if="topList.length > 0"
|
||||
:topList="topList"
|
||||
:top-list="topList"
|
||||
:moren="moren"
|
||||
></topBar>
|
||||
/>
|
||||
<div class="main">
|
||||
<div class="form_all">
|
||||
<el-form ref="select" :model="select" label-width="auto">
|
||||
<el-row :gutter="10">
|
||||
<el-col :span="4">
|
||||
<el-form-item :label="'会员编号'" prop="memberCode">
|
||||
<el-input
|
||||
clearable
|
||||
v-model="select.memberCode"
|
||||
:placeholder="'请输入'"
|
||||
></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item :label="'统计时间'">
|
||||
<el-date-picker
|
||||
v-model="select.payDate"
|
||||
@change="changeTime"
|
||||
v-model="select.selectDate"
|
||||
type="month"
|
||||
value-format="yyyy-MM"
|
||||
:placeholder="'请选择'"
|
||||
>
|
||||
</el-date-picker>
|
||||
:clearable="false"
|
||||
@change="changeTime"
|
||||
/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="4">
|
||||
<el-button type="primary" @click="getDataList">
|
||||
{{ '搜索' }}</el-button
|
||||
>
|
||||
{{ '搜索' }}</el-button>
|
||||
<el-button type="" @click="reset"> {{ '重置' }}</el-button>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
</div>
|
||||
<div class="maintop">
|
||||
<div class="mainbtn">
|
||||
<el-button
|
||||
size="small"
|
||||
@click="handleExport"
|
||||
v-hasButtons="['directRankingExport']"
|
||||
style="background-color: #ffad41"
|
||||
class="thebtn1"
|
||||
>
|
||||
{{ '导出' }}</el-button
|
||||
>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="maintable">
|
||||
<el-table
|
||||
:data="tableData"
|
||||
v-loading="loading"
|
||||
:data="tableData"
|
||||
style="width: 100%"
|
||||
:header-cell-style="{ background: '#EEEEEE' }"
|
||||
:row-class-name="tableRowClassName"
|
||||
@selection-change="handleSelectionChange"
|
||||
>
|
||||
<el-table-column type="selection" width="55"> </el-table-column>
|
||||
<el-table-column type="selection" width="55" />
|
||||
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="payTime"
|
||||
:label="'统计时间'"
|
||||
>
|
||||
</el-table-column>
|
||||
<el-table-column align="center" prop="ranking" label="排名">
|
||||
<template slot-scope="scope">
|
||||
<span :class="getRankingClass(scope.$index + 1)">{{ scope.$index + 1 }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="memberCode"
|
||||
:label="'会员编号'"
|
||||
>
|
||||
</el-table-column>
|
||||
/>
|
||||
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="memberName"
|
||||
:label="'会员姓名'"
|
||||
>
|
||||
</el-table-column>
|
||||
/>
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="gradeName"
|
||||
:label="'结算等级'"
|
||||
>
|
||||
</el-table-column>
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="awardsName"
|
||||
:label="'真实奖衔'"
|
||||
>
|
||||
</el-table-column>
|
||||
|
||||
<el-table-column
|
||||
align="center"
|
||||
prop="orderAchieve"
|
||||
:label="'直推业绩'"
|
||||
>
|
||||
</el-table-column>
|
||||
prop="numberOfPeople"
|
||||
label="直推人数"
|
||||
/>
|
||||
</el-table>
|
||||
</div>
|
||||
</div>
|
||||
<pagination
|
||||
<!-- <pagination
|
||||
v-show="total > 0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getDataList"
|
||||
/>
|
||||
/> -->
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import topBar from "@/components/topBar";
|
||||
import * as api from "@/api/giftGoods.js";
|
||||
<script>
|
||||
import * as api from '@/api/giftGoods.js'
|
||||
import mixins from './mixins'
|
||||
export default {
|
||||
name: "DirectRankingList",
|
||||
components: {
|
||||
topBar,
|
||||
},
|
||||
name: 'DirectRankingList',
|
||||
|
||||
mixins: [mixins],
|
||||
data() {
|
||||
return {
|
||||
creationTime: [],
|
||||
select: {},
|
||||
select: {
|
||||
selectDate: ''
|
||||
},
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 50,
|
||||
year: '',
|
||||
month: '',
|
||||
faker: false
|
||||
},
|
||||
total: 0,
|
||||
tableData: [],
|
||||
loading:false,
|
||||
moren: "directRankingList",
|
||||
topList: [
|
||||
{
|
||||
name: "直推排行数据",
|
||||
path: "directRankingList",
|
||||
},
|
||||
],
|
||||
};
|
||||
loading: false,
|
||||
moren: 'directRankingList'
|
||||
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
// 获取列表
|
||||
// this.getDataList();
|
||||
this.init()
|
||||
this.getDataList()
|
||||
},
|
||||
methods: {
|
||||
changeTime(val){
|
||||
this.queryParams.payDate = val
|
||||
aaa(obj) {
|
||||
console.log(obj, '....obj')
|
||||
},
|
||||
init() {
|
||||
const month = new Date().getMonth() + 1
|
||||
const monthStr = month < 10 ? '0' + month : month
|
||||
this.select.selectDate = new Date().getFullYear() + '-' + monthStr
|
||||
},
|
||||
changeTime(val) {
|
||||
this.queryParams.selectDate = val
|
||||
},
|
||||
reset() {
|
||||
this.select = {};
|
||||
this.creationTime = [];
|
||||
this.select = {}
|
||||
},
|
||||
|
||||
getDataList() {
|
||||
this.loading = true
|
||||
const [year, month] = this.select.selectDate.split('-')
|
||||
api
|
||||
.getMemberDirectPusht(Object.assign({}, this.queryParams, this.select))
|
||||
.getMemberDirectPush(Object.assign({}, this.queryParams, this.select, {
|
||||
year,
|
||||
month
|
||||
}))
|
||||
.then((res) => {
|
||||
this.tableData = res.data;
|
||||
this.total = res.total;
|
||||
this.tableData = res.data
|
||||
this.total = res.total
|
||||
this.loading = false
|
||||
});
|
||||
})
|
||||
},
|
||||
|
||||
handleSelectionChange(val) {},
|
||||
|
@ -175,25 +143,35 @@ export default {
|
|||
this.$confirm('是否确认导出所有数据项?', '警告', {
|
||||
confirmButtonText: '确定',
|
||||
cancelButtonText: '取消',
|
||||
type: "warning",
|
||||
type: 'warning'
|
||||
}).then((_) => {
|
||||
this.download(
|
||||
"/member/manager/member/get-member-direct-push-export",
|
||||
'/member/manager/member/get-member-direct-push-export',
|
||||
Object.assign({}, this.queryParams, this.select),
|
||||
`直推排行数据${new Date().getTime()}.xlsx`
|
||||
);
|
||||
});
|
||||
)
|
||||
})
|
||||
},
|
||||
tableRowClassName({ row, rowIndex }) {
|
||||
if (rowIndex % 2 == 1) {
|
||||
return "warning-row";
|
||||
} else if (rowIndex % 2 == 0) {
|
||||
return "success-row";
|
||||
if (rowIndex % 2 === 1) {
|
||||
return 'warning-row'
|
||||
} else if (rowIndex % 2 === 0) {
|
||||
return 'success-row'
|
||||
}
|
||||
return "";
|
||||
return ''
|
||||
},
|
||||
},
|
||||
};
|
||||
getRankingClass(ranking) {
|
||||
if (ranking === 1) {
|
||||
return 'first-place-cell'
|
||||
} else if (ranking === 2) {
|
||||
return 'second-place-cell'
|
||||
} else if (ranking === 3) {
|
||||
return 'third-place-cell'
|
||||
}
|
||||
return 'normal-ranking'
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped lang="scss">
|
||||
::v-deep .el-table .warning-row {
|
||||
|
@ -290,5 +268,24 @@ export default {
|
|||
color: #48b2fd;
|
||||
cursor: pointer;
|
||||
}
|
||||
</style>
|
||||
|
||||
/* 排名字体颜色样式 */
|
||||
.first-place-cell {
|
||||
color: #FFD700;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.second-place-cell {
|
||||
color: #C0C0C0;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.third-place-cell {
|
||||
color: #CD853F;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.normal-ranking {
|
||||
color: #666666;
|
||||
}
|
||||
</style>
|
||||
|
|
|
@ -0,0 +1,48 @@
|
|||
import topBar from '@/components/topBarRole'
|
||||
import { getRouters } from '@/api/settle'
|
||||
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
topList: [
|
||||
{
|
||||
name: '直推人数排行数据',
|
||||
path: 'directRankingList',
|
||||
url: 'DirectRankingList',
|
||||
changed: false
|
||||
},
|
||||
{
|
||||
name: '直推金额排行数据',
|
||||
path: 'directAmountRankingList',
|
||||
url: 'DirectAmountRankingList',
|
||||
changed: false
|
||||
},
|
||||
{
|
||||
name: '直推配置',
|
||||
path: 'directConfig',
|
||||
url: 'DirectConfig',
|
||||
changed: false
|
||||
}
|
||||
]
|
||||
}
|
||||
},
|
||||
components: {
|
||||
topBar
|
||||
},
|
||||
mounted() {
|
||||
this.getUserRoute()
|
||||
},
|
||||
methods: {
|
||||
getUserRoute() {
|
||||
getRouters().then((res) => {
|
||||
res.data.forEach((item) => {
|
||||
this.topList.forEach((items) => {
|
||||
if (item.routeName === items.url) {
|
||||
items.changed = true
|
||||
}
|
||||
})
|
||||
})
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue