2023-10-26 09:32:37 +08:00
|
|
|
|
<template>
|
|
|
|
|
<div class="app-center">
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<!-- 支付金额、会员登录-->
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div class="center-left">
|
|
|
|
|
<div class="center-vh">
|
|
|
|
|
<div class="center-left-top">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div class="vip-bottom" v-if="isMember == false" @click="dialogVisiblevip = true">
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div>会员登录</div>
|
|
|
|
|
</div>
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div v-else style="width: 96%;margin: 0 auto;display: flex;justify-content: space-between">
|
|
|
|
|
<div
|
|
|
|
|
style="display: flex;color: white;justify-content: space-around;width: 55%;
|
|
|
|
|
height: 90%;border-radius: 10px;
|
|
|
|
|
padding-top: 10px;
|
|
|
|
|
background-color: rgb(67,119,204)">
|
|
|
|
|
<div>
|
|
|
|
|
<template>
|
|
|
|
|
<img v-if="member.avatar" class="list-avatar" :src="member.avatar">
|
|
|
|
|
<img v-else class="list-avatar" src="@/assets/images/avatar.png">
|
|
|
|
|
</template>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="text-align: center">
|
|
|
|
|
<span style="margin-bottom: 10px">{{ member.name }}</span><br/>
|
|
|
|
|
<span>{{ member.mobile }}</span>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="background-color: rgba(46,82,142,0.65);width: 50px;height: 45px;padding-top: 5px;
|
|
|
|
|
border-radius: 5px;text-align: center">
|
|
|
|
|
<el-tooltip placement="top">
|
|
|
|
|
<div slot="content">
|
|
|
|
|
<p>会员储值账户余额:{{ member.cardBalance }}</p>
|
|
|
|
|
<p>积分余额:{{ member.points }}</p>
|
|
|
|
|
</div>
|
|
|
|
|
<i class="el-icon-bank-card" style="font-size: 35px"></i>
|
|
|
|
|
</el-tooltip>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="background-color: rgba(46,82,142,0.65);width: 50px;height: 45px;padding-top: 5px;
|
|
|
|
|
border-radius: 5px;text-align: center">
|
|
|
|
|
<el-tooltip placement="top">
|
|
|
|
|
<div slot="content">
|
2023-11-16 19:00:57 +08:00
|
|
|
|
会员等级:{{ gradeName }}
|
2023-11-07 18:12:17 +08:00
|
|
|
|
</div>
|
|
|
|
|
<i class="el-icon-medal" style="font-size: 35px"></i>
|
|
|
|
|
</el-tooltip>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="vip-bottom" style="height: 40px;margin-top: 10px" @click="resetMember">
|
|
|
|
|
<div>重置会员</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div class="center-left-hj">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div class="hj-box" style="justify-content: left">油品:¥{{ oilAmount }}</div>
|
|
|
|
|
<div class="hj-box" style="border-left: 1px solid #d1d1d4; border-right: 1px solid #d1d1d4;">商品:¥{{ goodsAmount }}</div>
|
|
|
|
|
<div class="hj-box" style="justify-content: flex-end">合计: ¥{{ oilAmount + goodsAmount }}</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div class="center-left-hj">
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<div>
|
|
|
|
|
<el-popover
|
|
|
|
|
placement="bottom-start"
|
|
|
|
|
width="400"
|
|
|
|
|
trigger="click">
|
|
|
|
|
<div>
|
|
|
|
|
<el-checkbox-group v-model="checkedCities1" @change="handleCheckedCitiesChange1">
|
|
|
|
|
<el-checkbox v-for="city in cities1" :label="city" :key="city">
|
|
|
|
|
<div style="display: flex;justify-content: space-between;height: 40px;line-height: 40px;">
|
|
|
|
|
<div style="width: 200px">{{city}}</div>
|
|
|
|
|
<div style="line-height: 20px;width:150px;font-size: 12px;text-align: right">
|
|
|
|
|
<div style="color: red">-¥1.56</div>
|
|
|
|
|
<div style="color: grey">满100元每升优惠0.2元</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
</div>
|
|
|
|
|
<div slot="reference">
|
|
|
|
|
<el-checkbox :indeterminate="isIndeterminate1"
|
|
|
|
|
style="color: black;font-size: 16px"
|
|
|
|
|
v-model="checkAll1" @change="handleCheckAllChange1">
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
满减活动
|
|
|
|
|
</div>
|
|
|
|
|
</el-popover>
|
|
|
|
|
</div>
|
|
|
|
|
<div>-¥{{ fullReduction + goodsDiscount }}</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
2023-11-09 18:52:12 +08:00
|
|
|
|
<div class="center-left-hj" v-show="isMember">
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<div>
|
|
|
|
|
<el-popover
|
|
|
|
|
placement="bottom-start"
|
|
|
|
|
width="400"
|
|
|
|
|
trigger="click">
|
|
|
|
|
<div>
|
|
|
|
|
<el-checkbox-group v-model="checkedCities2" @change="handleCheckedCitiesChange2">
|
|
|
|
|
<el-checkbox v-for="(item,index) in gradeDiscount" :label="item.type" :key="index">
|
|
|
|
|
<div style="display: flex;justify-content: space-between;height: 40px;line-height: 40px;">
|
|
|
|
|
<div style="width: 200px">{{item.type}}</div>
|
|
|
|
|
<div style="line-height: 20px;width:150px;font-size: 12px;text-align: right">
|
|
|
|
|
<div style="color: red">-¥{{ oilDiscount }}</div>
|
|
|
|
|
<div v-if="item.type=='满减优惠'" style="color: grey">消费满{{ item.full }}元,立减{{ item.reduce }}元</div>
|
|
|
|
|
<div v-else style="color: grey">消费满{{ item.full }}元,每升优惠{{ item.reduce }}元</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
</div>
|
|
|
|
|
<div slot="reference">
|
|
|
|
|
<el-checkbox :indeterminate="isIndeterminate2"
|
|
|
|
|
style="color: black;font-size: 16px"
|
|
|
|
|
v-model="checkAll2" @change="handleCheckAllChange2">
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
等级优惠
|
|
|
|
|
</div>
|
|
|
|
|
</el-popover>
|
|
|
|
|
</div>
|
|
|
|
|
<div>-¥{{ oilDiscount + goodsDiscount }}</div>
|
2023-11-09 13:51:57 +08:00
|
|
|
|
</div>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<div class="center-left-hj" v-show="isMember && refuelMoney!=null">
|
|
|
|
|
<div>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<el-popover
|
|
|
|
|
placement="bottom-start"
|
|
|
|
|
width="400"
|
|
|
|
|
trigger="click">
|
|
|
|
|
<div>
|
|
|
|
|
<el-checkbox-group v-model="checkedCities3" @change="handleCheckedCitiesChange3">
|
|
|
|
|
<el-checkbox v-for="city in cities3" :label="city" :key="city">
|
|
|
|
|
<div style="display: flex;justify-content: space-between;height: 40px;line-height: 40px;">
|
|
|
|
|
<div style="width: 200px">{{city}}</div>
|
|
|
|
|
<div style="line-height: 20px;width:150px;font-size: 12px;text-align: right">
|
|
|
|
|
<div style="color: red">-¥1.56</div>
|
|
|
|
|
<div style="color: grey">满100元每升优惠0.2元</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
</div>
|
|
|
|
|
<div slot="reference">
|
|
|
|
|
<el-checkbox :indeterminate="isIndeterminate3"
|
|
|
|
|
style="color: black;font-size: 16px"
|
|
|
|
|
v-model="checkAll3" @change="handleCheckAllChange3">
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
囤油卡
|
|
|
|
|
<div style="margin: 5px 0" v-for="(item,index) in refuelMoney" :key="index">
|
|
|
|
|
({{ item.type }}卡
|
|
|
|
|
<span style="color: #00afff">{{ item.oilType }}</span>
|
|
|
|
|
余额:{{ item.refuelMoney }}L)
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-popover>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div>- {{ consumeRefuelMoney }}L</div>
|
|
|
|
|
</div>
|
2023-11-09 18:52:12 +08:00
|
|
|
|
<div class="center-left-hj" v-show="isMember">
|
2023-11-09 13:51:57 +08:00
|
|
|
|
<div>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<el-popover
|
|
|
|
|
placement="bottom-start"
|
|
|
|
|
width="400"
|
|
|
|
|
trigger="click">
|
|
|
|
|
<div>
|
|
|
|
|
<el-checkbox-group v-model="checkedCities4" @change="handleCheckedCitiesChange4">
|
|
|
|
|
<el-checkbox v-for="city in cities4" :label="city" :key="city">
|
|
|
|
|
<div style="display: flex;justify-content: space-between;height: 40px;line-height: 40px;">
|
|
|
|
|
<div style="width: 200px">{{city}}</div>
|
|
|
|
|
<div style="line-height: 20px;width:150px;font-size: 12px;text-align: right">
|
|
|
|
|
<div style="color: red">-¥1.56</div>
|
|
|
|
|
<div style="color: grey">满100元每升优惠0.2元</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
</div>
|
|
|
|
|
<div slot="reference">
|
|
|
|
|
<el-checkbox :indeterminate="isIndeterminate4"
|
|
|
|
|
style="color: black;font-size: 16px"
|
|
|
|
|
v-model="checkAll4" @change="handleCheckAllChange4">
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
储值卡
|
|
|
|
|
<span>(账户余额:{{ balance }}元)</span>
|
|
|
|
|
</div>
|
|
|
|
|
</el-popover>
|
2023-11-09 13:51:57 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div>-¥{{ consumeAmount }}</div>
|
|
|
|
|
</div>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<div class="center-left-hj" v-show="isMember">
|
|
|
|
|
<div>
|
|
|
|
|
<el-popover
|
|
|
|
|
placement="bottom-start"
|
|
|
|
|
width="400"
|
|
|
|
|
trigger="click">
|
|
|
|
|
<div>
|
|
|
|
|
<el-checkbox-group v-model="checkedCities5" @change="handleCheckedCitiesChange5">
|
|
|
|
|
<el-checkbox v-for="city in cities5" :label="city" :key="city">
|
|
|
|
|
<div style="display: flex;justify-content: space-between;height: 40px;line-height: 40px;">
|
|
|
|
|
<div style="width: 200px">{{city}}</div>
|
|
|
|
|
<div style="line-height: 20px;width:150px;font-size: 12px;text-align: right">
|
|
|
|
|
<div style="color: red">-¥1.56</div>
|
|
|
|
|
<div style="color: grey">满100元每升优惠0.2元</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
</div>
|
|
|
|
|
<div slot="reference">
|
|
|
|
|
<el-checkbox :indeterminate="isIndeterminate5"
|
|
|
|
|
style="color: black;font-size: 16px"
|
|
|
|
|
v-model="checkAll5" @change="handleCheckAllChange5">
|
|
|
|
|
</el-checkbox>
|
|
|
|
|
优惠券
|
|
|
|
|
</div>
|
|
|
|
|
</el-popover>
|
|
|
|
|
</div>
|
|
|
|
|
<div>-¥{{ couponAmount }}</div>
|
|
|
|
|
</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div class="center-left-th">
|
|
|
|
|
<div class="th-box">
|
|
|
|
|
<div>扫码支付</div>
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<div class="bule">{{ oilActualPay + goodsActualPay }}</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div class="th-box">
|
|
|
|
|
<div>找零</div>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<div class="bule">{{ seekZero }}</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div class="th-box">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div @click="dialogVisible = true">加油员</div>
|
|
|
|
|
<div style="cursor: pointer;color: crimson" @click="dialogVisible = true" >{{ staff.realName }}</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="bottom-posi">
|
|
|
|
|
<div class="center-left-wrap">
|
2023-11-03 15:59:38 +08:00
|
|
|
|
<div class="wrap-box" v-for="item in payList"
|
|
|
|
|
:key="item.dictValue"
|
|
|
|
|
:value="item.dictValue">
|
|
|
|
|
<span @click="payMethod(item.dictValue)">{{ item.dictLabel }}</span>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="center-left-bottom">
|
|
|
|
|
<div>
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<div class="bottom-price">¥{{ oilActualPay + goodsActualPay }}</div>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<div class="price-red">优惠合计:{{ oilDiscount + goodsDiscount }}元/{{consumeRefuelMoney}}L</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div class="center-left-lv" @click="settlement">立即结算</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
</div>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<!-- 油品选择-->
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div class="center-right">
|
|
|
|
|
<div class="center-top">
|
|
|
|
|
<div class="center-top-tab">
|
|
|
|
|
<el-tabs v-model="activeName" @tab-click="handleClick">
|
2023-11-03 15:59:38 +08:00
|
|
|
|
<el-tab-pane label="全部" name="1"></el-tab-pane>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
<el-tab-pane v-for="item in oilNameList" :key="item.id"
|
|
|
|
|
:label="item.oilName" :name="item.id+''"></el-tab-pane>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<!-- <el-tab-pane v-for="(item,index) in gunList" :key="index"-->
|
|
|
|
|
<!-- :label="item.oilName" :name="item.numberId+''"></el-tab-pane>-->
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</el-tabs>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="center-top-data">
|
2023-11-06 18:06:29 +08:00
|
|
|
|
<div class="center-top-of">
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div class="wrap-wrap">
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<div class="of-box" v-for="(item,index) in gunList" :key="index"
|
|
|
|
|
:style="{'background-color': colorList[index%5].color}"
|
|
|
|
|
@click="refuel(item)">
|
|
|
|
|
<!-- <div>{{ getName(oilNameList,item.oilName) }}</div>-->
|
|
|
|
|
<div>{{ item.oilNumber }}</div>
|
|
|
|
|
|
|
|
|
|
<div class="of-title" >{{item.gunName}}</div>
|
|
|
|
|
<div style="display: flex;justify-content: space-between">
|
|
|
|
|
<img src="../../../assets/images/jya.png" style="width: 18px;height: 18px;">
|
|
|
|
|
<span style="font-size: 12px">{{ item.tankName }}</span>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<!-- <div class="of-box" v-for="(item,index) in oilNumGunList" :key="index"-->
|
|
|
|
|
<!-- :style="{'background-color': colorList[index%5].color}"-->
|
|
|
|
|
<!-- @click="refuel(item.id)">-->
|
|
|
|
|
<!-- <div>{{ getName(oilNameList,item.oilName) }}</div>-->
|
|
|
|
|
|
|
|
|
|
<!-- <div class="of-title" >{{item.oilGunNum}}号枪</div>-->
|
|
|
|
|
<!-- <div>-->
|
|
|
|
|
<!-- <img src="../../../assets/images/jya.png" style="width: 18px;height: 18px;">-->
|
|
|
|
|
<!-- </div>-->
|
|
|
|
|
<!-- </div>-->
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<!-- -->
|
|
|
|
|
<div class="content-top-bottom">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div>订单笔数 <span class="bule">{{ oilTotal }}件</span> </div>
|
|
|
|
|
<div>订单金额 <span class="bule">¥{{ oilAmount }}</span> </div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="center-left-bottom">
|
2023-11-09 13:51:57 +08:00
|
|
|
|
<div class="bottom-gd" @click="resetting">重置</div>
|
|
|
|
|
<!-- <div class="bottom-qk">解锁</div>-->
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<!-- 商品选择-->
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div class="center-app">
|
|
|
|
|
<div class="center-top">
|
|
|
|
|
<div class="center-top-title">非油商品</div>
|
|
|
|
|
<div class="center-top-input">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<template>
|
2023-11-09 18:52:12 +08:00
|
|
|
|
<el-autocomplete
|
2023-11-10 18:10:23 +08:00
|
|
|
|
popper-class="my-autocomplete"
|
|
|
|
|
style="width: 94%"
|
2023-11-09 18:52:12 +08:00
|
|
|
|
v-model="goods"
|
|
|
|
|
:fetch-suggestions="querySearch"
|
2023-11-10 18:10:23 +08:00
|
|
|
|
placeholder="商品名称,商品关键词,商品条码"
|
|
|
|
|
@select="changeGoods">
|
|
|
|
|
<template slot-scope="{ item }">
|
|
|
|
|
<div style="display: flex;justify-content: space-between">
|
|
|
|
|
<span class="name">{{ item.name }}</span>
|
|
|
|
|
<span v-if="isMember" class="addr">{{ item.memberPrice }}</span>
|
|
|
|
|
<span v-else class="addr">{{ item.retailPrice }}</span>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
</el-autocomplete>
|
2023-11-09 18:52:12 +08:00
|
|
|
|
<!-- <el-select v-model="goods" filterable-->
|
|
|
|
|
<!-- style="width: 95%;font-size: 20px;"-->
|
|
|
|
|
<!-- @change="changeGoods"-->
|
|
|
|
|
<!-- @keydown.enter.native="queryGoods"-->
|
|
|
|
|
<!-- clearable-->
|
|
|
|
|
<!-- placeholder="请输入商品名称,商品关键词">-->
|
|
|
|
|
<!-- <el-option-->
|
|
|
|
|
<!-- v-for="item in goodsList"-->
|
|
|
|
|
<!-- :key="item.id"-->
|
|
|
|
|
<!-- :label="item.name"-->
|
|
|
|
|
<!-- :value="item.id">-->
|
|
|
|
|
<!-- <span style="float: left">{{ item.name }}</span>-->
|
|
|
|
|
<!-- <span style="float: right; color: #8492a6; font-size: 13px">{{ item.retailPrice }}</span>-->
|
|
|
|
|
<!-- </el-option>-->
|
|
|
|
|
<!-- </el-select>-->
|
2023-11-07 18:12:17 +08:00
|
|
|
|
</template>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div class="center-top-data">
|
|
|
|
|
<div class="data-top">
|
|
|
|
|
<div class="data-top-title">商品</div>
|
|
|
|
|
<div class="data-top-three">
|
2023-11-09 13:51:57 +08:00
|
|
|
|
<div v-if="isMember == false">单价</div>
|
|
|
|
|
<div v-else>会员价</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div>数量</div>
|
|
|
|
|
<div>操作</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div class="data-top-box" v-for="(item,index) in goodsOrder" :key="index">
|
|
|
|
|
<div class="data-top-title">{{ item.name }}</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div class="data-top-three">
|
2023-11-09 13:51:57 +08:00
|
|
|
|
<div v-if="isMember == false">{{ item.retailPrice }}</div>
|
|
|
|
|
<div v-else>{{ item.memberPrice }}</div>
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div>
|
|
|
|
|
<el-input-number v-model="item.num" size="small" controls-position="right"
|
|
|
|
|
@change="handleChange" :min="1" :max="10"></el-input-number>
|
|
|
|
|
</div>
|
|
|
|
|
<div @click="delGoods(index)"><i class="el-icon-circle-close" style="font-size: 22px"></i></div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="content-top-bottom">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div>商品数量 <span class="bule">{{ goodsTotal }}件</span> </div>
|
|
|
|
|
<div>商品总额 <span class="bule">¥{{ goodsAmount }}</span> </div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="center-left-bottom">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div class="bottom-qk" @click="empty">清空</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div style="display: flex">
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<div class="bottom-qd" @click="dialogTakeOrder = true">取单</div>
|
|
|
|
|
<div class="bottom-gd" @click="dialogRegistration = true">挂单</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<!-- 加油员姓名-->
|
|
|
|
|
<el-dialog
|
2023-11-06 18:06:29 +08:00
|
|
|
|
title="选择加油员"
|
2023-10-26 09:32:37 +08:00
|
|
|
|
:visible.sync="dialogVisible"
|
|
|
|
|
width="30%"
|
2023-11-06 18:06:29 +08:00
|
|
|
|
:close-on-click-modal="false">
|
|
|
|
|
<div class="wrap-wrap">
|
|
|
|
|
<div class="of-box" v-for="(item,index) in staffList" :key="index"
|
2023-11-07 18:12:17 +08:00
|
|
|
|
@click="chooseStaff(item)"
|
2023-11-06 18:06:29 +08:00
|
|
|
|
:style="{'background-color': item.color}">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<div class="of-title">{{ item.realName }}</div>
|
|
|
|
|
<div style="text-align: center;font-size: 17px">{{ item.mobile }}</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<span slot="footer" class="dialog-footer">
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<el-button @click="dialogVisible = false">关 闭</el-button>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
<!-- <el-button type="primary" @click="dialogVisible = false">确 定</el-button>-->
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</span>
|
|
|
|
|
</el-dialog>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<!-- 挂单-->
|
|
|
|
|
<el-dialog
|
|
|
|
|
title="挂单提示"
|
|
|
|
|
:visible.sync="dialogRegistration"
|
|
|
|
|
width="20%"
|
|
|
|
|
style="margin-top: 200px"
|
|
|
|
|
:close-on-click-modal="false">
|
|
|
|
|
<div class="wrap-wrap">
|
|
|
|
|
<p>
|
|
|
|
|
挂单只可将非油商品进行挂单,挂单成功后可在取单页面进行取单操作、挂单备注为选填
|
|
|
|
|
</p>
|
|
|
|
|
<div>
|
|
|
|
|
<el-input
|
|
|
|
|
type="textarea"
|
|
|
|
|
:rows="2"
|
|
|
|
|
style="width: 180%"
|
|
|
|
|
placeholder="请输入挂单备注(选填)"
|
|
|
|
|
v-model="registrationRemark">
|
|
|
|
|
</el-input>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<span slot="footer" class="dialog-footer">
|
|
|
|
|
<el-button @click="dialogRegistration = false">关 闭</el-button>
|
|
|
|
|
<el-button type="primary" @click="registration">确 定</el-button>
|
|
|
|
|
</span>
|
|
|
|
|
</el-dialog>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<!-- 挂单成功提示-->
|
|
|
|
|
<el-dialog
|
|
|
|
|
title="挂单成功"
|
|
|
|
|
:visible.sync="dialogSuccess"
|
|
|
|
|
width="20%"
|
|
|
|
|
style="margin-top: 200px"
|
|
|
|
|
:close-on-click-modal="false">
|
|
|
|
|
<span>商品记录挂单成功</span>
|
|
|
|
|
<span slot="footer" class="dialog-footer">
|
|
|
|
|
<!-- <el-button @click="dialogVisible = false">取 消</el-button>-->
|
|
|
|
|
<el-button type="primary" @click="dialogSuccess = false">确 定</el-button>
|
|
|
|
|
</span>
|
|
|
|
|
</el-dialog>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<!-- 取单提示-->
|
|
|
|
|
<el-dialog
|
|
|
|
|
title="取单"
|
|
|
|
|
:visible.sync="dialogTakeOrder"
|
|
|
|
|
width="50%"
|
|
|
|
|
:close-on-click-modal="false">
|
|
|
|
|
<div style="height: 500px">
|
|
|
|
|
<el-row class="tac">
|
|
|
|
|
<el-col :span="6">
|
|
|
|
|
<el-input v-model="putRemark" placeholder="挂单备注检索" style="margin-bottom: 20px;width: 80%"></el-input>
|
|
|
|
|
<el-menu
|
|
|
|
|
default-active="2"
|
|
|
|
|
v-for="(item,index) in registrationList"
|
|
|
|
|
:key="index"
|
|
|
|
|
class="el-menu-vertical-demo">
|
|
|
|
|
<el-menu-item :index="index+''" @click="getTakeGoods(item,index)">
|
|
|
|
|
<span slot="title">{{ item.menu }}</span>
|
|
|
|
|
</el-menu-item>
|
|
|
|
|
</el-menu>
|
|
|
|
|
</el-col>
|
|
|
|
|
<el-col :span="18">
|
|
|
|
|
<el-table ref="tables" :data="takeList">
|
|
|
|
|
<el-table-column label="商品名称" align="center" prop="name" />
|
|
|
|
|
<el-table-column label="零售价" align="center" prop="retailPrice"/>
|
|
|
|
|
<el-table-column label="数量" align="center" prop="num"/>
|
|
|
|
|
<el-table-column label="金额" align="center">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<span>{{ scope.row.retailPrice * scope.row.num }}</span>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
</el-table>
|
|
|
|
|
</el-col>
|
|
|
|
|
</el-row>
|
|
|
|
|
</div>
|
|
|
|
|
<span style="display: flex;justify-content: space-between">
|
|
|
|
|
<el-button class="elBut" @click="dialogTakeOrder = false" round>返 回</el-button>
|
|
|
|
|
<span>
|
|
|
|
|
<el-button class="elBut" type="danger" @click="cancel" round>作 废</el-button>
|
|
|
|
|
<el-button class="elBut" type="success" @click="pickOrder" round>取 单</el-button>
|
|
|
|
|
</span>
|
|
|
|
|
</span>
|
|
|
|
|
</el-dialog>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<!-- 立即结算-->
|
|
|
|
|
<el-dialog
|
2023-11-07 18:12:17 +08:00
|
|
|
|
title="扫码支付"
|
2023-10-26 09:32:37 +08:00
|
|
|
|
:visible.sync="dialogVisiblej"
|
|
|
|
|
width="30%"
|
2023-11-06 18:06:29 +08:00
|
|
|
|
:close-on-click-modal="false">
|
2023-11-09 18:52:12 +08:00
|
|
|
|
<div v-if="isPay == true"
|
|
|
|
|
v-loading="loading">
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<div style="text-align: center;font-size: 15px;font-weight: bold">应收金额</div>
|
|
|
|
|
<div style="text-align: center;font-size: 30px;font-weight: bold;color: red;margin: 10px 0">
|
2023-11-09 13:51:57 +08:00
|
|
|
|
¥{{ oilActualPay + goodsActualPay }}
|
2023-11-08 18:07:17 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div style="text-align: center;margin-bottom: 10px">
|
2023-11-16 19:00:57 +08:00
|
|
|
|
合计金额:{{ oilAmount + goodsAmount }}元、优惠合计{{ oilDiscount + goodsDiscount }}元
|
2023-11-08 18:07:17 +08:00
|
|
|
|
</div>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<div v-if="map.payType != 'CASH'">
|
|
|
|
|
<div>
|
|
|
|
|
<el-input v-model="authCode"
|
|
|
|
|
autofocus="autofocus"
|
|
|
|
|
@keydown.enter.native="collection"
|
|
|
|
|
placeholder="扫描或输入付款码、支持微信、支付宝、云闪付">
|
|
|
|
|
<i
|
|
|
|
|
slot="suffix">
|
|
|
|
|
<svg t="1697791915471" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1479" width="32" height="32"><path d="M149.333333 170.858667A21.546667 21.546667 0 0 1 170.858667 149.333333H384V106.666667H170.858667A64.213333 64.213333 0 0 0 106.666667 170.858667V384h42.666666V170.858667zM170.858667 874.666667A21.546667 21.546667 0 0 1 149.333333 853.141333V640H106.666667v213.141333A64.213333 64.213333 0 0 0 170.858667 917.333333H384v-42.666666H170.858667zM853.12 149.333333A21.546667 21.546667 0 0 1 874.666667 170.858667V384h42.666666V170.858667A64.213333 64.213333 0 0 0 853.141333 106.666667H640v42.666666h213.141333zM874.666667 853.141333A21.546667 21.546667 0 0 1 853.141333 874.666667H640v42.666666h213.141333A64.213333 64.213333 0 0 0 917.333333 853.141333V640h-42.666666v213.141333zM106.666667 490.666667h810.666666v42.666666H106.666667v-42.666666z" fill="#3D3D3D" p-id="1480"></path></svg>
|
|
|
|
|
</i>
|
|
|
|
|
</el-input>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="demo-image"></div>
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<div class="block" style="text-align: center">
|
|
|
|
|
<el-image
|
|
|
|
|
style="width: 200px; height: 200px"
|
|
|
|
|
fit="cover"
|
|
|
|
|
src="https://oil.wudb.cn/static/img/scan-demo.fcb8b1ab.png"></el-image>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<div v-else>
|
|
|
|
|
<div>
|
|
|
|
|
<el-input v-model="authCode"
|
|
|
|
|
autofocus="autofocus"
|
|
|
|
|
@input="changeSeekZero"
|
|
|
|
|
@keydown.enter.native="collection"
|
|
|
|
|
placeholder="请输入收款金额">
|
|
|
|
|
</el-input>
|
|
|
|
|
</div>
|
|
|
|
|
<div style="text-align: right;margin: 10px 0">
|
|
|
|
|
<span>应找零</span>
|
|
|
|
|
<span style="color: red;font-size: 18px"> ¥{{ seekZero }}</span>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<el-divider></el-divider>
|
|
|
|
|
<span slot="footer" class="dialog-footer" style="display: flex;justify-content: space-around">
|
|
|
|
|
<el-button @click="dialogVisiblej = false" class="but">取 消</el-button>
|
|
|
|
|
<el-button type="primary" class="but" @click="collection">确 定 收 款</el-button>
|
|
|
|
|
</span>
|
2023-11-03 15:59:38 +08:00
|
|
|
|
</div>
|
2023-11-09 18:52:12 +08:00
|
|
|
|
<div v-else>
|
2023-11-08 18:07:17 +08:00
|
|
|
|
<div v-if="isPaySuccess">
|
|
|
|
|
<el-result icon="success" title="收款成功">
|
|
|
|
|
<template slot="extra">
|
|
|
|
|
<el-button type="primary" @click="handClose">关 闭</el-button>
|
|
|
|
|
</template>
|
|
|
|
|
</el-result>
|
|
|
|
|
</div>
|
|
|
|
|
<div v-else>
|
|
|
|
|
<el-result icon="error" title="支付失败,请重新支付">
|
|
|
|
|
<template slot="extra">
|
|
|
|
|
<el-button type="primary" @click="handClose">关 闭</el-button>
|
|
|
|
|
</template>
|
|
|
|
|
</el-result>
|
2023-11-03 15:59:38 +08:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</el-dialog>
|
2023-11-16 19:00:57 +08:00
|
|
|
|
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<!-- 会员登录-->
|
|
|
|
|
<el-dialog
|
2023-11-06 18:06:29 +08:00
|
|
|
|
title="会员信息"
|
2023-10-26 09:32:37 +08:00
|
|
|
|
:visible.sync="dialogVisiblevip"
|
|
|
|
|
width="30%"
|
2023-11-06 18:06:29 +08:00
|
|
|
|
:close-on-click-modal="false">
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<div >
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<el-input placeholder="会员手机号、用户昵称" v-model="userNo"
|
|
|
|
|
clearable
|
|
|
|
|
@keyup.enter.native="getUser"
|
2023-11-06 18:06:29 +08:00
|
|
|
|
class="input-with-select" style="text-align: center;">
|
|
|
|
|
<el-select v-model="select1" slot="prepend" placeholder="请选择" style="width: 120px">
|
|
|
|
|
<el-option label="会员手机号" value="会员手机号"></el-option>
|
|
|
|
|
<el-option label="用户昵称" value="用户昵称"></el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
<el-button slot="append" @click="getUser">查询</el-button>
|
|
|
|
|
</el-input>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
<el-row>
|
|
|
|
|
<el-descriptions title="会员信息" :column="2">
|
|
|
|
|
<el-descriptions-item label="手机号">{{member.mobile ? member.mobile : "--"}}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="会员昵称">{{member.name ? member.name : "--"}}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="积分">{{member.points ? member.points : "--"}}</el-descriptions-item>
|
|
|
|
|
<!-- <el-descriptions-item label="加油金余额">0</el-descriptions-item>-->
|
|
|
|
|
<el-descriptions-item label="车牌号">{{member.carNo ? member.carNo : "--"}}</el-descriptions-item>
|
|
|
|
|
<el-descriptions-item label="会员备注">{{member.remark ? member.remark : "--"}}</el-descriptions-item>
|
|
|
|
|
</el-descriptions>
|
|
|
|
|
<el-descriptions title="会员等级">
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<el-descriptions-item label="等级名称">{{member.gradeId ? getGradeName(gradeList,member.gradeId) : "--"}}</el-descriptions-item>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
</el-descriptions>
|
|
|
|
|
<el-descriptions title="储值余额">
|
|
|
|
|
<template slot="extra">
|
2023-11-16 19:00:57 +08:00
|
|
|
|
<span style="color: red;margin-right: 20px">余额充值</span>
|
|
|
|
|
<span style="font-weight: bold">¥{{member.cardBalance ? member.cardBalance : "--"}}</span>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
</template>
|
|
|
|
|
<el-descriptions-item v-if="member.cardBalance!=0" label="账户余额">{{member.cardBalance ? member.cardBalance : "--"}}元</el-descriptions-item>
|
|
|
|
|
</el-descriptions>
|
|
|
|
|
</el-row>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
<span slot="footer" class="dialog-footer">
|
|
|
|
|
<el-button @click="dialogVisiblevip = false">取 消</el-button>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<el-button type="primary" :disabled="isSure" @click="chooseUser(member)">确 定</el-button>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</span>
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
2023-11-06 18:06:29 +08:00
|
|
|
|
<!-- 加油枪加油金额-->
|
|
|
|
|
<el-dialog
|
|
|
|
|
title="加油金额"
|
|
|
|
|
:close-on-click-modal="false"
|
|
|
|
|
:visible.sync="dialogVisibleamount"
|
|
|
|
|
width="30%">
|
|
|
|
|
<div class="amount">
|
|
|
|
|
<span>已选油品</span>
|
|
|
|
|
<span class="amountBlue">{{ getName(oilNameList,form.oilName) }}</span>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="amount">
|
|
|
|
|
<span>已选油枪</span>
|
2023-11-17 16:33:36 +08:00
|
|
|
|
<span class="amountBlue">{{ form.gunName }}</span>
|
2023-11-06 18:06:29 +08:00
|
|
|
|
</div>
|
|
|
|
|
<div class="amount">
|
|
|
|
|
<span>油品单价</span>
|
|
|
|
|
<span class="amountBlue">{{ form.oilPrice }}元/L</span>
|
|
|
|
|
</div>
|
|
|
|
|
<div >
|
2023-11-09 13:51:57 +08:00
|
|
|
|
<el-input v-model="amount" @input="form.amount = amount" placeholder="请输入加油金额"
|
2023-11-06 18:06:29 +08:00
|
|
|
|
style="font-weight: 700;text-align: center;font-size: 20px;">
|
|
|
|
|
<el-select v-model="select" style="width: 70px" @change="changeSelect" slot="append" placeholder="请选择">
|
|
|
|
|
<el-option label="元" value="元"></el-option>
|
|
|
|
|
<el-option label="L" value="L"></el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-input>
|
2023-11-09 13:51:57 +08:00
|
|
|
|
<!-- <el-input v-model="form.amount"></el-input>-->
|
2023-11-06 18:06:29 +08:00
|
|
|
|
</div>
|
|
|
|
|
<el-row :gutter="20">
|
|
|
|
|
<el-col :span="6" v-for="(item,index) in rise" :key="index">
|
|
|
|
|
<el-button class="grid-content bg-purple" @click="changeAmount(item.value)">{{ item.value }}</el-button>
|
|
|
|
|
</el-col>
|
|
|
|
|
</el-row>
|
|
|
|
|
<span slot="footer" class="dialog-footer" style="display: flex;justify-content: space-around">
|
|
|
|
|
<el-button @click="dialogVisibleamount = false" class="but">取 消</el-button>
|
|
|
|
|
<el-button type="primary" @click="getOilOrder" class="but">确 定</el-button>
|
|
|
|
|
</span>
|
|
|
|
|
</el-dialog>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
|
2023-11-07 18:12:17 +08:00
|
|
|
|
<!-- 模糊查询会员列表信息-->
|
|
|
|
|
<el-dialog
|
|
|
|
|
title="请选择会员"
|
|
|
|
|
:visible.sync="dialogVisibleMember"
|
|
|
|
|
:close-on-click-modal="false">
|
|
|
|
|
<div class="wrap-wrap">
|
|
|
|
|
<el-table ref="tables" :data="memberList">
|
|
|
|
|
<el-table-column label="ID" align="center" prop="id" width="80" />
|
|
|
|
|
<el-table-column label="头像" align="center" width="70">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<img v-if="scope.row.avatar" class="list-avatar" :src="scope.row.avatar">
|
|
|
|
|
<img v-else class="list-avatar" src="@/assets/images/avatar.png">
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column label="姓名" align="center" prop="name" />
|
|
|
|
|
<el-table-column label="手机号" align="center" prop="mobile"/>
|
|
|
|
|
<el-table-column label="注册时间" align="center" prop="createTime">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<span>{{ parseTime(scope.row.createTime) }}</span>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary" round
|
|
|
|
|
@click="handleChoose(scope.row)"
|
|
|
|
|
>选择</el-button>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
</el-table>
|
|
|
|
|
</div>
|
|
|
|
|
</el-dialog>
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2023-11-03 15:59:38 +08:00
|
|
|
|
import {getDicts} from "@/api/dict/data";
|
2023-11-06 18:06:29 +08:00
|
|
|
|
import {getOilNameList, getOilNumGun, getOilNumGunById, listOilNumGun} from "@/api/cashier/oilnumgun";
|
2023-11-10 18:10:23 +08:00
|
|
|
|
import {listgoods} from "@/api/cashier/ljgoods";
|
2023-11-07 18:12:17 +08:00
|
|
|
|
import {getUserVoMobile, getUserVoName} from "@/api/cashier/user";
|
|
|
|
|
import {queryStaffs, staffInfo} from "@/api/cashier/staff";
|
2023-11-08 18:07:17 +08:00
|
|
|
|
import {addLJGoods, goodsOrder, oilOrder} from "@/api/cashier/oilorder";
|
2023-11-17 16:33:36 +08:00
|
|
|
|
import {getUserGrade, listUserGrade} from "@/api/cashier/usergrade";
|
|
|
|
|
import {getOilGun} from "@/api/cashier/oilGuns";
|
2023-11-16 19:00:57 +08:00
|
|
|
|
import {listCardFavorableRecord} from "@/api/cashier/cardfavorablerecord";
|
2023-11-17 16:33:36 +08:00
|
|
|
|
import {getOilNumberById} from "@/api/cashier/oilnumber";
|
2023-10-26 09:32:37 +08:00
|
|
|
|
|
2023-11-17 16:33:36 +08:00
|
|
|
|
const cityOptions = ['上海', '北京'];
|
2023-11-03 15:59:38 +08:00
|
|
|
|
export default {
|
|
|
|
|
name: "homeindex",
|
|
|
|
|
data(){
|
|
|
|
|
return{
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 满减全选
|
|
|
|
|
checkAll1: false,
|
|
|
|
|
isIndeterminate1: true,
|
|
|
|
|
checkedCities1: ['上海'],
|
|
|
|
|
cities1: cityOptions,
|
|
|
|
|
// 等级全选
|
|
|
|
|
checkAll2: false,
|
|
|
|
|
isIndeterminate2: true,
|
|
|
|
|
checkedCities2: [],
|
|
|
|
|
cities2: cityOptions,
|
|
|
|
|
gradeDiscount: [],
|
|
|
|
|
// 囤油卡全选
|
|
|
|
|
checkAll3: false,
|
|
|
|
|
isIndeterminate3: true,
|
|
|
|
|
checkedCities3: ['上海'],
|
|
|
|
|
cities3: cityOptions,
|
|
|
|
|
// 储值卡全选
|
|
|
|
|
checkAll4: false,
|
|
|
|
|
isIndeterminate4: true,
|
|
|
|
|
checkedCities4: ['上海'],
|
|
|
|
|
cities4: cityOptions,
|
|
|
|
|
// 优惠券全选
|
|
|
|
|
checkAll5: false,
|
|
|
|
|
isIndeterminate5: true,
|
|
|
|
|
checkedCities5: ['上海'],
|
|
|
|
|
cities5: cityOptions,
|
2023-11-16 19:00:57 +08:00
|
|
|
|
// 优惠券列表
|
|
|
|
|
couponList:[],
|
|
|
|
|
// 消费升数
|
|
|
|
|
consumeRefuelMoney:0,
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 满减优惠
|
|
|
|
|
fullReduction:0,
|
2023-11-16 19:00:57 +08:00
|
|
|
|
// 囤油卡信息
|
|
|
|
|
refuelMoney:null,
|
2023-11-09 13:51:57 +08:00
|
|
|
|
// 会员消费金额(储值卡需要减少的金额)
|
|
|
|
|
consumeAmount:0,
|
|
|
|
|
// 账户余额
|
|
|
|
|
balance:0,
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 绑定金额数据
|
2023-11-16 19:00:57 +08:00
|
|
|
|
amount:0,
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 找零金额
|
|
|
|
|
seekZero:0,
|
2023-11-09 13:51:57 +08:00
|
|
|
|
// 等待中
|
2023-11-08 18:07:17 +08:00
|
|
|
|
loading:false,
|
|
|
|
|
// 油品类型
|
|
|
|
|
oilType:'',
|
|
|
|
|
// 取单列表
|
|
|
|
|
takeList:[],
|
|
|
|
|
// 挂单备注检索
|
|
|
|
|
putRemark:"",
|
|
|
|
|
// 挂单备注
|
|
|
|
|
registrationRemark:"",
|
|
|
|
|
// 挂单列表
|
|
|
|
|
registrationList:[],
|
2023-11-06 18:06:29 +08:00
|
|
|
|
// 油品订单
|
|
|
|
|
oilOrder:[],
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 油品金额
|
|
|
|
|
oilAmount:0,
|
2023-11-06 18:06:29 +08:00
|
|
|
|
// 油品订单数
|
|
|
|
|
oilTotal:0,
|
2023-11-08 18:07:17 +08:00
|
|
|
|
// 油品实付金额
|
|
|
|
|
oilActualPay:0,
|
|
|
|
|
// 油品优惠金额
|
|
|
|
|
oilDiscount:0,
|
|
|
|
|
// 商品优惠金额
|
|
|
|
|
goodsDiscount:0,
|
|
|
|
|
// 商品实付金额
|
|
|
|
|
goodsActualPay:0,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 商品订单
|
|
|
|
|
goodsOrder:[],
|
|
|
|
|
// 商品金额
|
|
|
|
|
goodsAmount:0,
|
|
|
|
|
// 商品订单数
|
|
|
|
|
goodsTotal:0,
|
2023-11-06 18:06:29 +08:00
|
|
|
|
// 加油金额
|
|
|
|
|
rise:[
|
|
|
|
|
{value:"¥100"},
|
|
|
|
|
{value:"¥150"},
|
|
|
|
|
{value:"¥200"},
|
|
|
|
|
{value:"¥300"},
|
|
|
|
|
],
|
|
|
|
|
// 会员信息
|
|
|
|
|
member:{},
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 会员列表信息
|
|
|
|
|
memberList:[],
|
2023-11-06 18:06:29 +08:00
|
|
|
|
select1:'会员手机号',
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 查询会员信息参数
|
2023-11-06 18:06:29 +08:00
|
|
|
|
userNo:"",
|
|
|
|
|
// 查询的商品信息
|
|
|
|
|
goods:"",
|
|
|
|
|
select:"元",
|
2023-11-16 19:00:57 +08:00
|
|
|
|
form:{ amount : 0 },
|
2023-11-06 18:06:29 +08:00
|
|
|
|
oilNumGunList:[],
|
2023-11-03 15:59:38 +08:00
|
|
|
|
authCode:'',
|
|
|
|
|
// 油号列表
|
|
|
|
|
oilNumList:[],
|
2023-11-06 18:06:29 +08:00
|
|
|
|
// 商品列表
|
|
|
|
|
goodsList:[],
|
2023-11-03 15:59:38 +08:00
|
|
|
|
// 油枪列表
|
|
|
|
|
oilGunList:[],
|
|
|
|
|
// 支付方式列表
|
|
|
|
|
payList:[],
|
|
|
|
|
dialogVisible: false,
|
|
|
|
|
dialogVisiblej: false,
|
|
|
|
|
dialogVisiblevip:false,
|
2023-11-06 18:06:29 +08:00
|
|
|
|
dialogVisibleamount:false,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
dialogVisibleMember:false,
|
2023-11-08 18:07:17 +08:00
|
|
|
|
dialogRegistration:false,
|
|
|
|
|
dialogSuccess:false,
|
|
|
|
|
dialogTakeOrder:false,
|
2023-11-06 18:06:29 +08:00
|
|
|
|
activeName: '1',
|
2023-11-03 15:59:38 +08:00
|
|
|
|
tabarr:[
|
|
|
|
|
{name:'收银台',icon:'el-icon-s-platform'},
|
|
|
|
|
{name:'充值',icon: 'el-icon-s-finance'},
|
|
|
|
|
{name:'订单',icon: 'el-icon-s-order'},
|
|
|
|
|
{name:'会员',icon: 'el-icon-s-custom'},
|
|
|
|
|
{name:'核销',icon: 'el-icon-s-check'},
|
|
|
|
|
{name:'挂账',icon:'el-icon-s-claim'},
|
|
|
|
|
{name:'积分',icon:'el-icon-s-data'},
|
|
|
|
|
{name:'交班',icon: 'el-icon-s-flag'},
|
|
|
|
|
],
|
|
|
|
|
leftindex:0,
|
2023-11-09 18:52:12 +08:00
|
|
|
|
oilList:[],
|
2023-11-03 15:59:38 +08:00
|
|
|
|
colorList:[
|
|
|
|
|
{color:'#e5f0ff'},
|
|
|
|
|
{color:'#fff2e5'},
|
|
|
|
|
{color:'#e5edf1'},
|
|
|
|
|
{color:'#ecfae5'},
|
|
|
|
|
{color:'#fafafa'}
|
|
|
|
|
],
|
2023-11-07 18:12:17 +08:00
|
|
|
|
restaurants:'',
|
2023-11-03 15:59:38 +08:00
|
|
|
|
num: 1,
|
2023-11-16 19:00:57 +08:00
|
|
|
|
// 油号名称
|
2023-11-06 18:06:29 +08:00
|
|
|
|
oilNameList:'',
|
2023-11-16 19:00:57 +08:00
|
|
|
|
// 员工列表
|
2023-11-06 18:06:29 +08:00
|
|
|
|
staffList:[],
|
2023-11-07 18:12:17 +08:00
|
|
|
|
isMember: false,
|
|
|
|
|
// 员工信息
|
|
|
|
|
staff:"",
|
|
|
|
|
map:{
|
2023-11-08 18:07:17 +08:00
|
|
|
|
allAmount:0,
|
|
|
|
|
// 用户支付条码信息
|
|
|
|
|
authCode:'',
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 油品订单
|
|
|
|
|
oilOrder:"",
|
|
|
|
|
// 商品订单
|
|
|
|
|
goodsOrder:"",
|
|
|
|
|
// 支付方式
|
2023-11-17 16:33:36 +08:00
|
|
|
|
payType:"CASH",
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 油品订单金额
|
2023-11-08 18:07:17 +08:00
|
|
|
|
oilAmount:0,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 商品订单金额
|
2023-11-08 18:07:17 +08:00
|
|
|
|
goodsAmount:0,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 油品实付金额
|
2023-11-08 18:07:17 +08:00
|
|
|
|
oilActualPay:0,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 商品实付金额
|
2023-11-08 18:07:17 +08:00
|
|
|
|
goodsActualPay:0,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 付款用户
|
|
|
|
|
payUser:"",
|
|
|
|
|
// 油品优惠金额
|
2023-11-08 18:07:17 +08:00
|
|
|
|
oilDiscount:0,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 商品优惠金额
|
2023-11-08 18:07:17 +08:00
|
|
|
|
goodsDiscount:0,
|
|
|
|
|
// 员工id
|
|
|
|
|
staffId:"",
|
|
|
|
|
// 优惠券id
|
|
|
|
|
couponId:"",
|
|
|
|
|
// 会员id
|
|
|
|
|
userId:"",
|
|
|
|
|
// 提成金额
|
|
|
|
|
commissionAmount:0,
|
|
|
|
|
// 使用积分数量
|
|
|
|
|
usePoint:0,
|
|
|
|
|
// 积分金额
|
|
|
|
|
pointAmount:0,
|
|
|
|
|
// 终端
|
|
|
|
|
terminal:"PC",
|
|
|
|
|
// 商品数量
|
|
|
|
|
goodsNum:0,
|
2023-11-09 13:51:57 +08:00
|
|
|
|
// 会员消费金额(储值卡需要减少的金额)
|
|
|
|
|
consumeAmount:0,
|
2023-11-16 19:00:57 +08:00
|
|
|
|
// 消费后的升数json
|
|
|
|
|
refuelMoney:"",
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 找零金额
|
|
|
|
|
seekZero:0,
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 会员等级名称
|
2023-11-07 18:12:17 +08:00
|
|
|
|
gradeName:"",
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 会员等级列表
|
|
|
|
|
gradeList:"",
|
2023-11-08 18:07:17 +08:00
|
|
|
|
menu:1,
|
|
|
|
|
index:0,
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 是否支付
|
2023-11-08 18:07:17 +08:00
|
|
|
|
isPay:true,
|
|
|
|
|
isPaySuccess:false,
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 订单号
|
2023-11-09 13:51:57 +08:00
|
|
|
|
orderNo:'',
|
2023-11-09 18:52:12 +08:00
|
|
|
|
timer: null,
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 是否一直查询
|
2023-11-09 18:52:12 +08:00
|
|
|
|
isQuery:true,
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 油枪列表
|
2023-11-16 19:00:57 +08:00
|
|
|
|
gunList:[],
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 是否可以点会员确定按钮
|
|
|
|
|
isSure:true,
|
|
|
|
|
// 优惠券消费金额
|
|
|
|
|
couponAmount:0,
|
2023-11-03 15:59:38 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
this.getPayList();
|
2023-11-06 18:06:29 +08:00
|
|
|
|
this.getOilName();
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.getGoods();
|
|
|
|
|
this.getStaffList();
|
|
|
|
|
this.getStaff();
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.getList();
|
|
|
|
|
this.getCouponList();
|
2023-11-09 18:52:12 +08:00
|
|
|
|
},
|
2023-11-03 15:59:38 +08:00
|
|
|
|
methods:{
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 计算找零金额
|
|
|
|
|
changeSeekZero(){
|
|
|
|
|
this.seekZero = this.authCode - this.oilActualPay - this.goodsActualPay
|
|
|
|
|
},
|
|
|
|
|
// 获取会员等级id
|
|
|
|
|
getGradeName(list,id){
|
|
|
|
|
let name = "";
|
|
|
|
|
list.forEach(item => {
|
|
|
|
|
if (item.id == id){
|
|
|
|
|
name = item.name
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
this.gradeName = name;
|
|
|
|
|
return name;
|
|
|
|
|
},
|
|
|
|
|
// 选择优惠信息
|
|
|
|
|
handleCheckAllChange1(val) {
|
|
|
|
|
this.checkedCities1 = val ? cityOptions : [];
|
|
|
|
|
this.isIndeterminate1 = false;
|
|
|
|
|
},
|
|
|
|
|
handleCheckedCitiesChange1(value) {
|
|
|
|
|
let checkedCount = value.length;
|
|
|
|
|
this.checkAll1 = checkedCount === this.cities1.length;
|
|
|
|
|
this.isIndeterminate1 = checkedCount > 0 && checkedCount < this.cities1.length;
|
|
|
|
|
},
|
|
|
|
|
handleCheckAllChange2(val) {
|
|
|
|
|
let list = []
|
|
|
|
|
this.gradeDiscount.forEach(item => {
|
|
|
|
|
list.push(item.type)
|
|
|
|
|
})
|
|
|
|
|
this.checkedCities2 = val ? list : [];
|
|
|
|
|
this.isIndeterminate2 = false;
|
|
|
|
|
},
|
|
|
|
|
handleCheckedCitiesChange2(value) {
|
|
|
|
|
let checkedCount = value.length;
|
|
|
|
|
this.checkAll2 = checkedCount === this.gradeDiscount.length;
|
|
|
|
|
this.isIndeterminate2 = checkedCount > 0 && checkedCount < this.gradeDiscount.length;
|
|
|
|
|
},
|
|
|
|
|
handleCheckAllChange3(val) {
|
|
|
|
|
this.checkedCities3 = val ? cityOptions : [];
|
|
|
|
|
this.isIndeterminate3 = false;
|
|
|
|
|
},
|
|
|
|
|
handleCheckedCitiesChange3(value) {
|
|
|
|
|
let checkedCount = value.length;
|
|
|
|
|
this.checkAll3 = checkedCount === this.cities3.length;
|
|
|
|
|
this.isIndeterminate3 = checkedCount > 0 && checkedCount < this.cities3.length;
|
|
|
|
|
},
|
|
|
|
|
handleCheckAllChange4(val) {
|
|
|
|
|
this.checkedCities4 = val ? cityOptions : [];
|
|
|
|
|
this.isIndeterminate4 = false;
|
|
|
|
|
},
|
|
|
|
|
handleCheckedCitiesChange4(value) {
|
|
|
|
|
let checkedCount = value.length;
|
|
|
|
|
this.checkAll4 = checkedCount === this.cities4.length;
|
|
|
|
|
this.isIndeterminate4 = checkedCount > 0 && checkedCount < this.cities4.length;
|
|
|
|
|
},
|
|
|
|
|
handleCheckAllChange5(val) {
|
|
|
|
|
this.checkedCities5 = val ? cityOptions : [];
|
|
|
|
|
this.isIndeterminate5 = false;
|
|
|
|
|
},
|
|
|
|
|
handleCheckedCitiesChange5(value) {
|
|
|
|
|
let checkedCount = value.length;
|
|
|
|
|
this.checkAll5 = checkedCount === this.cities5.length;
|
|
|
|
|
this.isIndeterminate5 = checkedCount > 0 && checkedCount < this.cities5.length;
|
|
|
|
|
},
|
2023-11-16 19:00:57 +08:00
|
|
|
|
// 模糊查询商品信息
|
2023-11-09 18:52:12 +08:00
|
|
|
|
querySearch(queryString, cb) {
|
|
|
|
|
let _this = this;
|
2023-11-10 18:10:23 +08:00
|
|
|
|
let results = _this.goodsList;
|
|
|
|
|
if (queryString != ""){
|
|
|
|
|
results = [];
|
|
|
|
|
_this.goodsList.forEach(item => {
|
|
|
|
|
if(item.name.includes(queryString)){
|
|
|
|
|
results.push(item)
|
|
|
|
|
}
|
|
|
|
|
if(item.goodsNo.includes(queryString)){
|
|
|
|
|
results.push(item)
|
|
|
|
|
}
|
2023-11-09 18:52:12 +08:00
|
|
|
|
})
|
|
|
|
|
}
|
2023-11-10 18:10:23 +08:00
|
|
|
|
cb(results);
|
2023-11-09 18:52:12 +08:00
|
|
|
|
},
|
2023-11-08 18:07:17 +08:00
|
|
|
|
// 取单
|
|
|
|
|
pickOrder(){
|
|
|
|
|
let list = this.takeList
|
|
|
|
|
this.goodsOrder = list;
|
|
|
|
|
let num = 0;
|
|
|
|
|
let amount = 0;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
let _this = this;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
list.forEach(item => {
|
|
|
|
|
num += item.num;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
if (_this.isMember){
|
|
|
|
|
amount += item.memberPrice;
|
|
|
|
|
}else {
|
|
|
|
|
amount += item.retailPrice;
|
|
|
|
|
}
|
2023-11-08 18:07:17 +08:00
|
|
|
|
})
|
|
|
|
|
this.goodsTotal = num;
|
|
|
|
|
this.goodsAmount = amount;
|
2023-11-10 18:10:23 +08:00
|
|
|
|
this.goodsActualPay = this.goodsAmount - this.goodsDiscount;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.dialogTakeOrder = false;
|
|
|
|
|
},
|
|
|
|
|
// 作废
|
|
|
|
|
cancel(){
|
|
|
|
|
this.registrationList.splice(this.index,1);
|
|
|
|
|
this.takeList = [];
|
|
|
|
|
},
|
|
|
|
|
// 取单列表
|
|
|
|
|
getTakeGoods(data,index){
|
|
|
|
|
this.takeList = data.children;
|
|
|
|
|
this.index = index;
|
|
|
|
|
},
|
|
|
|
|
// 挂单
|
|
|
|
|
registration(){
|
|
|
|
|
this.dialogRegistration = false;
|
|
|
|
|
this.registrationList.push({menu:this.menu,children:this.goodsOrder})
|
|
|
|
|
this.menu++;
|
|
|
|
|
this.goodsOrder = [];
|
|
|
|
|
this.goodsTotal = 0;
|
|
|
|
|
this.goodsAmount = 0;
|
2023-11-10 18:10:23 +08:00
|
|
|
|
this.goodsActualPay = this.goodsAmount - this.goodsDiscount;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.getTakeGoods(this.registrationList[0]);
|
|
|
|
|
this.dialogSuccess = true;
|
|
|
|
|
},
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 重置会员
|
|
|
|
|
resetMember(){
|
|
|
|
|
this.member = {};
|
|
|
|
|
this.isMember = false;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.map.payUser == "";
|
|
|
|
|
this.balance = 0;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.oilDiscount = 0;
|
|
|
|
|
this.goodsDiscount = 0;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.userNo = "";
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.oilActualPay = this.oilAmount - this.oilDiscount - this.couponAmount
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.goodsActualPay = this.goodsAmount - this.goodsDiscount
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.isSure = true;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.handleChange();
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
|
|
|
|
// 获取会员等级信息
|
|
|
|
|
getGrade(id){
|
2023-11-16 19:00:57 +08:00
|
|
|
|
let _this = this;
|
|
|
|
|
this.oilDiscount = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.gradeDiscount = [];
|
2023-11-07 18:12:17 +08:00
|
|
|
|
getUserGrade(id).then( response => {
|
2023-11-16 19:00:57 +08:00
|
|
|
|
let gasolineDiscount = 0;
|
|
|
|
|
let dieselDiscount = 0;
|
|
|
|
|
let naturalGasDiscount = 0;
|
|
|
|
|
_this.oilOrder.forEach(item => {
|
|
|
|
|
if (item.oilType == "汽油"){
|
|
|
|
|
let gasolineRule = JSON.parse(response.data.gasolineRule);
|
|
|
|
|
if (response.data.preferential == '自定义优惠' && response.data.status == 'qy'){
|
|
|
|
|
if (response.data.gasolineDiscount=="满减优惠"){
|
|
|
|
|
let oilDiscount = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
let discount = {type:"满减优惠",full:0,reduce:0}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
for (let i = 1; i <= gasolineRule.length; i++){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 将满减条件加入等级优惠列表
|
|
|
|
|
discount.full = gasolineRule[i-1].gasolineRule1
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (gasolineRule.length>1){
|
|
|
|
|
if (item.amount >= gasolineRule[gasolineRule.length-1].gasolineRule1){
|
|
|
|
|
oilDiscount = (item.amount/gasolineRule[gasolineRule.length-1].gasolineRule1 *
|
|
|
|
|
gasolineRule[gasolineRule.length-1].gasolineRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = gasolineRule[i-1].gasolineRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (item.amount >= gasolineRule[i-1].gasolineRule1 && item.amount < gasolineRule[i].gasolineRule1){
|
|
|
|
|
oilDiscount = (item.amount/gasolineRule[i-1].gasolineRule1 * gasolineRule[i-1].gasolineRule2).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = gasolineRule[i-1].gasolineRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}else {
|
|
|
|
|
if (item.amount >= gasolineRule[i-1].gasolineRule1){
|
|
|
|
|
oilDiscount = (item.amount/gasolineRule[i-1].gasolineRule1 * gasolineRule[i-1].gasolineRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = gasolineRule[i-1].gasolineRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-17 16:33:36 +08:00
|
|
|
|
if (discount.reduce!=0){
|
|
|
|
|
_this.gradeDiscount.push(discount)
|
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
gasolineDiscount += +oilDiscount
|
|
|
|
|
}else if (response.data.gasolineDiscount=="每升优惠"){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
let discount = {type:"每升优惠",full:0,reduce:0}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
let oilDiscount = 0;
|
|
|
|
|
for (let i = 1; i <= gasolineRule.length; i++){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 将满减条件加入等级优惠列表
|
|
|
|
|
discount.full = gasolineRule[i-1].gasolineRule1
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (gasolineRule.length>1){
|
|
|
|
|
if (item.amount >= gasolineRule[gasolineRule.length-1].gasolineRule1){
|
|
|
|
|
oilDiscount = (item.liters * gasolineRule[gasolineRule.length-1].gasolineRule3).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = gasolineRule[i-1].gasolineRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (item.amount >= gasolineRule[i-1].gasolineRule1 && item.amount < gasolineRule[i].gasolineRule1){
|
|
|
|
|
oilDiscount = (item.liters * gasolineRule[i-1].gasolineRule3).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = gasolineRule[i-1].gasolineRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}else {
|
|
|
|
|
if (item.amount >= gasolineRule[i-1].gasolineRule1){
|
|
|
|
|
oilDiscount = (item.liters * gasolineRule[i-1].gasolineRule3).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = gasolineRule[i-1].gasolineRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-17 16:33:36 +08:00
|
|
|
|
if (discount.reduce!=0){
|
|
|
|
|
_this.gradeDiscount.push(discount)
|
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
gasolineDiscount += +oilDiscount
|
|
|
|
|
}else {
|
|
|
|
|
gasolineDiscount = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (item.oilType == "柴油"){
|
|
|
|
|
let dieselRule = JSON.parse(response.data.dieselRule);
|
|
|
|
|
if (response.data.preferential == '自定义优惠' && response.data.status == 'qy'){
|
|
|
|
|
if (response.data.dieselDiscount=="满减优惠"){
|
|
|
|
|
let oilDiscount = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
let discount = {type:"满减优惠",full:0,reduce:0}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
for (let i = 1; i <= dieselRule.length; i++){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 将满减条件加入等级优惠列表
|
|
|
|
|
discount.full = dieselRule[i-1].dieselRule1
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (dieselRule.length>1){
|
|
|
|
|
if (item.amount >= dieselRule[dieselRule.length-1].dieselRule1){
|
|
|
|
|
oilDiscount = (item.amount/dieselRule[dieselRule.length-1].dieselRule1 *
|
|
|
|
|
dieselRule[dieselRule.length-1].dieselRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = dieselRule[i-1].dieselRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (item.amount >= dieselRule[i-1].dieselRule1 && item.amount < dieselRule[i].dieselRule1){
|
|
|
|
|
oilDiscount = (item.amount/dieselRule[i-1].dieselRule1 * dieselRule[i-1].dieselRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = dieselRule[i-1].dieselRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}else {
|
|
|
|
|
if (item.amount >= dieselRule[i-1].dieselRule1){
|
|
|
|
|
oilDiscount = (item.amount/dieselRule[i-1].dieselRule1 * dieselRule[i-1].dieselRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = dieselRule[i-1].dieselRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-17 16:33:36 +08:00
|
|
|
|
if (discount.reduce!=0){
|
|
|
|
|
_this.gradeDiscount.push(discount)
|
|
|
|
|
_this.checkedCities2 = ['满减优惠']
|
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
dieselDiscount += +oilDiscount
|
|
|
|
|
}else if (response.data.dieselDiscount=="每升优惠"){
|
|
|
|
|
let oilDiscount = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
let discount = {type:"每升优惠",full:0,reduce:0}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
for (let i = 1; i <= dieselRule.length; i++){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 将满减条件加入等级优惠列表
|
|
|
|
|
discount.full = dieselRule[i-1].dieselRule1
|
|
|
|
|
_this.gradeDiscount.push(discount)
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (dieselRule.length>1){
|
|
|
|
|
if (item.amount >= dieselRule[dieselRule.length-1].dieselRule1){
|
|
|
|
|
oilDiscount = (item.liters * dieselRule[gasolineRule.length-1].dieselRule3).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = dieselRule[i-1].dieselRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (item.amount >= dieselRule[i-1].dieselRule1 && item.amount < dieselRule[i].dieselRule1){
|
|
|
|
|
oilDiscount = (item.liters * dieselRule[i-1].dieselRule3).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = dieselRule[i-1].dieselRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}else {
|
|
|
|
|
if (item.amount >= dieselRule[i-1].dieselRule1){
|
|
|
|
|
oilDiscount = (item.liters * dieselRule[i-1].dieselRule3).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = dieselRule[i-1].dieselRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-17 16:33:36 +08:00
|
|
|
|
if (discount.reduce!=0){
|
|
|
|
|
_this.gradeDiscount.push(discount)
|
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
dieselDiscount += +oilDiscount
|
|
|
|
|
}else {
|
|
|
|
|
dieselDiscount = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (item.oilType == "天然气"){
|
|
|
|
|
let naturalGasRule = JSON.parse(response.data.naturalGasRule);
|
|
|
|
|
if (response.data.preferential == '自定义优惠' && response.data.status == 'qy'){
|
|
|
|
|
if (response.data.naturalGasDiscount=="满减优惠"){
|
|
|
|
|
let oilDiscount = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
let discount = {type:"满减优惠",full:0,reduce:0}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
for (let i = 1; i <= naturalGasRule.length; i++){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 将满减条件加入等级优惠列表
|
|
|
|
|
discount.full = naturalGasRule[i-1].naturalGasRule1
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (naturalGasRule.length>1){
|
|
|
|
|
if (item.amount >= naturalGasRule[naturalGasRule.length-1].naturalGasRule1){
|
|
|
|
|
oilDiscount = (item.amount/naturalGasRule[naturalGasRule.length-1].naturalGasRule1 *
|
|
|
|
|
naturalGasRule[naturalGasRule.length-1].naturalGasRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = naturalGasRule[i-1].naturalGasRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (item.amount >= naturalGasRule[i-1].naturalGasRule1 && item.amount < naturalGasRule[i].naturalGasRule1){
|
|
|
|
|
oilDiscount = (item.amount/naturalGasRule[i-1].naturalGasRule1 * naturalGasRule[i-1].naturalGasRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = naturalGasRule[i-1].naturalGasRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}else {
|
|
|
|
|
if (item.amount >= naturalGasRule[i-1].naturalGasRule1){
|
|
|
|
|
oilDiscount = (item.amount/naturalGasRule[i-1].naturalGasRule1 * naturalGasRule[i-1].naturalGasRule2).toFixed(2);
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = naturalGasRule[i-1].naturalGasRule2
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-17 16:33:36 +08:00
|
|
|
|
if (discount.reduce!=0){
|
|
|
|
|
_this.gradeDiscount.push(discount)
|
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
naturalGasDiscount += +oilDiscount
|
|
|
|
|
}else if (response.data.naturalGasDiscount=="每单位优惠"){
|
|
|
|
|
let oilDiscount = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
let discount = {type:"每单位优惠",full:0,reduce:0}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
for (let i = 1; i <= naturalGasRule.length; i++){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 将满减条件加入等级优惠列表
|
|
|
|
|
discount.full = naturalGasRule[i-1].naturalGasRule1
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (naturalGasRule.length>1){
|
|
|
|
|
if (item.amount >= naturalGasRule[naturalGasRule.length-1].naturalGasRule1){
|
|
|
|
|
oilDiscount = (item.liters * naturalGasRule[gasolineRule.length-1].naturalGasRule3).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = naturalGasRule[i-1].naturalGasRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (item.amount >= naturalGasRule[i-1].naturalGasRule1 && item.amount < naturalGasRule[i].naturalGasRule1){
|
|
|
|
|
oilDiscount = (item.liters * naturalGasRule[i-1].naturalGasRule3).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = naturalGasRule[i-1].naturalGasRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}else {
|
|
|
|
|
if (item.amount >= naturalGasRule[i-1].naturalGasRule1){
|
|
|
|
|
oilDiscount = (item.liters * naturalGasRule[i-1].naturalGasRule3).toFixed(2)
|
2023-11-17 16:33:36 +08:00
|
|
|
|
discount.reduce = naturalGasRule[i-1].naturalGasRule3
|
2023-11-16 19:00:57 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-11-17 16:33:36 +08:00
|
|
|
|
if (discount.reduce!=0){
|
|
|
|
|
_this.gradeDiscount.push(discount)
|
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
naturalGasDiscount += +oilDiscount
|
|
|
|
|
}else {
|
|
|
|
|
naturalGasDiscount = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
let oilActualPay = _this.oilActualPay;
|
|
|
|
|
_this.oilDiscount = gasolineDiscount + dieselDiscount + naturalGasDiscount
|
|
|
|
|
_this.oilActualPay = oilActualPay - _this.oilDiscount;
|
|
|
|
|
// 储值卡余额
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 如果总金额为0 则表示没有使用囤油卡
|
|
|
|
|
if (oilActualPay == 0){
|
|
|
|
|
oilActualPay = _this.oilAmount - _this.oilDiscount;
|
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (_this.balance>=(_this.oilAmount - _this.oilDiscount)){
|
|
|
|
|
_this.consumeAmount = _this.oilAmount - _this.oilDiscount;
|
|
|
|
|
_this.oilActualPay = 0;
|
|
|
|
|
}else {
|
|
|
|
|
_this.consumeAmount = _this.balance;
|
|
|
|
|
_this.oilActualPay = oilActualPay - _this.oilDiscount - _this.balance;
|
|
|
|
|
}
|
2023-11-07 18:12:17 +08:00
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
// 选择会员
|
2023-11-16 19:00:57 +08:00
|
|
|
|
chooseUser(data){
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.dialogVisiblevip = false
|
|
|
|
|
this.isMember = true;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.map.payUser = data.mobile;
|
|
|
|
|
this.map.userId = data.id;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.balance = this.member.cardBalance;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.getGrade(data.gradeId)
|
|
|
|
|
this.changeRefuelMoney();
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.handleChange();
|
2023-11-17 17:26:12 +08:00
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
// 调用优惠参数接口
|
|
|
|
|
preferential(){
|
|
|
|
|
|
2023-11-16 19:00:57 +08:00
|
|
|
|
},
|
|
|
|
|
// 查询该会员是否可使用优惠券
|
|
|
|
|
queryCoupon(list,id){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// let result = false;
|
|
|
|
|
// list.forEach(item => {
|
|
|
|
|
// if (item.mtUserId==id){
|
|
|
|
|
// let startTime = item.startTime;
|
|
|
|
|
// let endTime = item.endTime;
|
|
|
|
|
// let date = new Date();
|
|
|
|
|
// let sysDate = `${date.getFullYear()}-${date.getMonth() - 1}-${date.getDate()}`
|
|
|
|
|
// }
|
|
|
|
|
// })
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
|
|
|
|
// 选择会员信息
|
|
|
|
|
handleChoose(data){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.isSure = false;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.member = data;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.refuelMoney = JSON.parse(data.refuelMoney)
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.dialogVisibleMember = false;
|
|
|
|
|
},
|
|
|
|
|
// 清空商品订单列表
|
|
|
|
|
empty(){
|
|
|
|
|
this.goodsOrder = [];
|
|
|
|
|
this.goodsTotal = 0;
|
|
|
|
|
this.goodsAmount = 0;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.goodsActualPay = 0;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.goodsDiscount = 0;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
|
|
|
|
// 获取当前账户信息
|
|
|
|
|
getStaff(){
|
|
|
|
|
staffInfo().then( response => {
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.staff = response.data;
|
|
|
|
|
this.map.staffId = this.staff.id;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
// 选择员工信息
|
|
|
|
|
chooseStaff(data){
|
|
|
|
|
this.staff = data;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.map.staffId = this.staff.id;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
|
|
|
|
// 删除商品列表信息
|
|
|
|
|
delGoods(index){
|
|
|
|
|
this.goodsOrder.splice(index,1)
|
|
|
|
|
},
|
|
|
|
|
// 添加商品列表信息
|
|
|
|
|
changeGoods(val){
|
|
|
|
|
let result = true;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
let goods = this.goodsOrder;
|
|
|
|
|
let _this = this;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
if (this.goodsOrder.length>0){
|
|
|
|
|
let amount = 0;
|
|
|
|
|
for (let i = 0; i<goods.length; i++){
|
2023-11-09 13:51:57 +08:00
|
|
|
|
if (_this.isMember){
|
|
|
|
|
amount += goods[i].memberPrice * goods[i].num
|
|
|
|
|
}else {
|
|
|
|
|
amount += goods[i].retailPrice * goods[i].num
|
|
|
|
|
}
|
2023-11-10 18:10:23 +08:00
|
|
|
|
if (goods[i].id == val.id){
|
2023-11-07 18:12:17 +08:00
|
|
|
|
goods[i].num = goods[i].num + 1;
|
|
|
|
|
this.goodsTotal += 1;
|
|
|
|
|
result = false;
|
|
|
|
|
break;
|
|
|
|
|
}else {
|
|
|
|
|
result = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
this.goodsAmount = amount;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.goodsActualPay = this.goodsAmount - this.goodsDiscount;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
}else {
|
|
|
|
|
result = true;
|
|
|
|
|
}
|
|
|
|
|
if (result){
|
2023-11-10 18:10:23 +08:00
|
|
|
|
val.num = 1;
|
|
|
|
|
if (_this.isMember){
|
|
|
|
|
this.goodsAmount += val.memberPrice
|
|
|
|
|
}else {
|
|
|
|
|
this.goodsAmount += val.retailPrice
|
|
|
|
|
}
|
|
|
|
|
this.goodsActualPay = this.goodsAmount - this.goodsDiscount;
|
|
|
|
|
this.goodsOrder.push(val);
|
|
|
|
|
this.goodsTotal += 1;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
}
|
|
|
|
|
this.goods = ""
|
|
|
|
|
},
|
|
|
|
|
// 立即结算
|
|
|
|
|
settlement(){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.authCode = ""
|
|
|
|
|
this.seekZero = 0;
|
2023-11-09 18:52:12 +08:00
|
|
|
|
this.isPay = true
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.dialogVisiblej = true
|
|
|
|
|
},
|
|
|
|
|
// 新增订单(重置)
|
|
|
|
|
resetting(){
|
|
|
|
|
this.oilOrder = [];
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.oilActualPay = 0;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.oilTotal = 0;
|
|
|
|
|
this.oilAmount = 0;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.oilDiscount = 0;
|
|
|
|
|
this.consumeAmount = 0;
|
|
|
|
|
this.consumeRefuelMoney = 0;
|
|
|
|
|
this.refuelMoney = JSON.parse(this.member.refuelMoney)
|
|
|
|
|
this.amount = 0;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
|
|
|
|
// 获取员工列表
|
2023-11-06 18:06:29 +08:00
|
|
|
|
getStaffList(){
|
|
|
|
|
queryStaffs().then( response => {
|
|
|
|
|
this.staffList = response.data
|
|
|
|
|
})
|
|
|
|
|
},
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 油品订单信息
|
2023-11-06 18:06:29 +08:00
|
|
|
|
getOilOrder(){
|
|
|
|
|
this.dialogVisibleamount = false
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.form.oilType = this.oilType;
|
|
|
|
|
// 计算油的升数
|
|
|
|
|
if (this.select == "元"){
|
|
|
|
|
this.form.liters = (this.form.amount/this.form.oilPrice).toFixed(2)
|
|
|
|
|
}else {
|
|
|
|
|
this.form.liters = this.form.amount
|
|
|
|
|
this.form.amount = this.form.oilPrice * this.form.amount
|
|
|
|
|
}
|
|
|
|
|
// 获取油号信息
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// let name1 = this.getName(this.oilNameList,this.form.oilName);
|
|
|
|
|
// this.form.oilType = name1;
|
2023-11-06 18:06:29 +08:00
|
|
|
|
this.oilOrder.push(this.form)
|
2023-11-16 19:00:57 +08:00
|
|
|
|
|
2023-11-07 18:12:17 +08:00
|
|
|
|
if (this.select == "元"){
|
|
|
|
|
this.oilAmount = +this.form.amount + this.oilAmount;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
if (this.balance!=0){
|
|
|
|
|
if (this.balance>=(this.oilAmount - this.oilDiscount)){
|
|
|
|
|
this.consumeAmount = this.oilAmount - this.oilDiscount;
|
2023-11-09 13:59:06 +08:00
|
|
|
|
this.oilActualPay = 0;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
}else {
|
|
|
|
|
this.consumeAmount = this.balance;
|
|
|
|
|
this.oilActualPay = this.oilAmount - this.oilDiscount - this.balance;
|
|
|
|
|
}
|
|
|
|
|
}else {
|
|
|
|
|
this.oilActualPay = this.oilAmount - this.oilDiscount;
|
|
|
|
|
}
|
2023-11-07 18:12:17 +08:00
|
|
|
|
}else {
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.oilAmount = this.form.amount + this.oilAmount;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.oilActualPay = this.oilAmount - this.oilDiscount;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
}
|
2023-11-16 19:00:57 +08:00
|
|
|
|
|
2023-11-06 18:06:29 +08:00
|
|
|
|
this.oilTotal += 1;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.select = "元";
|
2023-11-16 19:00:57 +08:00
|
|
|
|
if (this.isMember){
|
|
|
|
|
this.getGrade(this.member.gradeId)
|
|
|
|
|
this.changeRefuelMoney();
|
|
|
|
|
}
|
|
|
|
|
},
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 囤油卡变化后总金额的变化
|
2023-11-16 19:00:57 +08:00
|
|
|
|
changeRefuelMoney(){
|
|
|
|
|
let _this = this;
|
|
|
|
|
_this.consumeRefuelMoney = 0;
|
|
|
|
|
_this.oilActualPay = 0;
|
|
|
|
|
_this.oilOrder.forEach(item => {
|
|
|
|
|
let conRefMon = 0;
|
|
|
|
|
let oilActualPay = 0;
|
|
|
|
|
if (_this.refuelMoney!=null){
|
|
|
|
|
let result = false;
|
|
|
|
|
for (let i = 0;i < _this.refuelMoney.length;i++){
|
|
|
|
|
// 囤油卡升数变化
|
|
|
|
|
if (_this.refuelMoney[i].oilType==item.oilType){
|
|
|
|
|
if ((_this.refuelMoney[i].refuelMoney-item.liters)>=0){
|
|
|
|
|
conRefMon = item.liters
|
|
|
|
|
oilActualPay = 0;
|
|
|
|
|
}else {
|
|
|
|
|
conRefMon = _this.refuelMoney[i].refuelMoney
|
|
|
|
|
oilActualPay = item.amount - (_this.refuelMoney[i].refuelMoney * item.oilPrice).toFixed(2)
|
|
|
|
|
}
|
|
|
|
|
result = true;
|
|
|
|
|
}else {
|
|
|
|
|
if (result==false){
|
|
|
|
|
oilActualPay = item.amount
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
_this.consumeRefuelMoney += +conRefMon
|
|
|
|
|
_this.oilActualPay += +oilActualPay
|
|
|
|
|
})
|
2023-11-06 18:06:29 +08:00
|
|
|
|
},
|
|
|
|
|
// 选择“元”或“L”
|
|
|
|
|
changeSelect(){
|
|
|
|
|
if(this.select == "元"){
|
|
|
|
|
this.rise = [
|
|
|
|
|
{value:"¥100"},
|
|
|
|
|
{value:"¥150"},
|
|
|
|
|
{value:"¥200"},
|
|
|
|
|
{value:"¥300"},
|
|
|
|
|
];
|
|
|
|
|
}else {
|
|
|
|
|
this.rise = [
|
|
|
|
|
{value:"100L"},
|
|
|
|
|
{value:"150L"},
|
|
|
|
|
{value:"200L"},
|
|
|
|
|
{value:"300L"},
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// 改变加油金额
|
|
|
|
|
changeAmount(amount){
|
|
|
|
|
if (this.select == "元"){
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.amount = amount.slice(1)
|
2023-11-10 18:10:23 +08:00
|
|
|
|
this.form.amount = this.amount
|
2023-11-06 18:06:29 +08:00
|
|
|
|
}else {
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.amount = amount.slice(0,3)
|
2023-11-10 18:10:23 +08:00
|
|
|
|
this.form.amount = this.amount
|
2023-11-06 18:06:29 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// 获取油号名称
|
|
|
|
|
getName(oilNameList,id){
|
|
|
|
|
let name = ""
|
2023-11-08 18:07:17 +08:00
|
|
|
|
let _this = this;
|
2023-11-06 18:06:29 +08:00
|
|
|
|
if(oilNameList!=null && oilNameList!=""){
|
|
|
|
|
oilNameList.forEach(item => {
|
|
|
|
|
if (item.id == id){
|
2023-11-08 18:07:17 +08:00
|
|
|
|
name = item.oilName;
|
|
|
|
|
_this.oilType = item.oilType;
|
2023-11-06 18:06:29 +08:00
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
return name;
|
|
|
|
|
},
|
|
|
|
|
// 获取油号信息
|
|
|
|
|
getOilName(){
|
|
|
|
|
getOilNameList().then( response => {
|
|
|
|
|
this.oilNameList = response.data;
|
|
|
|
|
})
|
|
|
|
|
},
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 根据手机号查询会员信息
|
2023-11-06 18:06:29 +08:00
|
|
|
|
getUser(){
|
2023-11-07 18:12:17 +08:00
|
|
|
|
if(this.select1=="会员手机号"){
|
|
|
|
|
getUserVoMobile({mobile:this.userNo}).then( response => {
|
2023-11-09 13:51:57 +08:00
|
|
|
|
if (response.data!=null){
|
|
|
|
|
this.member = response.data
|
|
|
|
|
}else {
|
|
|
|
|
this.$modal.msgError("会员信息不存在")
|
|
|
|
|
}
|
2023-11-07 18:12:17 +08:00
|
|
|
|
})
|
|
|
|
|
}else {
|
|
|
|
|
getUserVoName({name:this.userNo}).then( response => {
|
|
|
|
|
this.memberList = response.data
|
|
|
|
|
})
|
|
|
|
|
this.dialogVisibleMember = true;
|
2023-11-06 18:06:29 +08:00
|
|
|
|
}
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
|
|
|
|
// 查询所有商品信息
|
|
|
|
|
getGoods(){
|
|
|
|
|
listgoods().then( response => {
|
|
|
|
|
this.goodsList = response.data
|
2023-11-06 18:06:29 +08:00
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
// 加油金额
|
2023-11-17 16:33:36 +08:00
|
|
|
|
refuel(data){
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.select = "元";
|
2023-11-10 18:10:23 +08:00
|
|
|
|
this.amount = 0
|
2023-11-06 18:06:29 +08:00
|
|
|
|
this.dialogVisibleamount = true;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
getOilNumberById(data.numberId).then( response => {
|
2023-11-06 18:06:29 +08:00
|
|
|
|
this.form = response.data;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.gunList.forEach(item => {
|
|
|
|
|
if (item.id==data.id){
|
|
|
|
|
this.form.gunName = item.gunName
|
|
|
|
|
}
|
|
|
|
|
})
|
2023-11-06 18:06:29 +08:00
|
|
|
|
})
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// getOilNumGunById(id).then( response => {
|
|
|
|
|
// this.form = response.data;
|
|
|
|
|
// })
|
2023-11-06 18:06:29 +08:00
|
|
|
|
},
|
2023-11-03 15:59:38 +08:00
|
|
|
|
// 确定收款
|
|
|
|
|
collection(){
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// JSON.parse()
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.map.seekZero = this.seekZero;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.map.oilAmount = this.oilAmount;
|
|
|
|
|
this.map.goodsAmount = this.goodsAmount;
|
|
|
|
|
this.map.oilActualPay = this.oilActualPay;
|
|
|
|
|
this.map.goodsActualPay = this.goodsActualPay;
|
|
|
|
|
this.map.oilDiscount = this.oilDiscount;
|
|
|
|
|
this.map.goodsDiscount = this.goodsDiscount;
|
|
|
|
|
this.map.goodsNum = this.goodsTotal;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.map.oilOrder = JSON.stringify(this.oilOrder);
|
|
|
|
|
this.map.goodsOrder = JSON.stringify(this.goodsOrder);
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.map.authCode = this.authCode;
|
2023-11-09 18:52:12 +08:00
|
|
|
|
this.map.allAmount = this.oilActualPay + this.goodsActualPay;
|
2023-11-13 16:51:57 +08:00
|
|
|
|
this.map.consumeAmount = this.consumeAmount;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
this.updateRefuelMoney();
|
|
|
|
|
this.map.refuelMoney = JSON.stringify(this.refuelMoney)
|
2023-11-08 18:07:17 +08:00
|
|
|
|
|
|
|
|
|
let _this = this;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
addLJGoods(_this.map).then( response => {
|
|
|
|
|
if (response.data.oilOrder!=null){
|
2023-11-09 18:52:12 +08:00
|
|
|
|
_this.orderNo = response.data.oilOrder.orderNo;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
if (response.data.oilOrder.orderStatus == "paid"){
|
|
|
|
|
_this.isPaySuccess = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (response.data.goodsOrder!=null){
|
|
|
|
|
if (response.data.goodsOrder.status == "paid"){
|
|
|
|
|
_this.isPaySuccess = true;
|
|
|
|
|
}
|
2023-11-08 18:07:17 +08:00
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
this.loading = true;
|
2023-11-09 18:52:12 +08:00
|
|
|
|
_this.queryPayStatus();
|
|
|
|
|
let timer = setInterval(function () {
|
|
|
|
|
if (_this.isQuery == false) {
|
|
|
|
|
_this.loading = false;
|
|
|
|
|
_this.isPay = false;
|
|
|
|
|
clearInterval(_this.timer);
|
|
|
|
|
}
|
|
|
|
|
},500)
|
2023-11-08 18:07:17 +08:00
|
|
|
|
setTimeout(function (){
|
2023-11-09 18:52:12 +08:00
|
|
|
|
clearInterval(timer);
|
|
|
|
|
},30000)
|
|
|
|
|
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.authCode = "";
|
2023-11-09 13:51:57 +08:00
|
|
|
|
if (_this.isPaySuccess == true){
|
|
|
|
|
_this.oilAmount = 0;
|
|
|
|
|
_this.oilActualPay = 0;
|
|
|
|
|
_this.oilDiscount = 0;
|
|
|
|
|
_this.goodsAmount = 0;
|
|
|
|
|
_this.goodsActualPay = 0;
|
|
|
|
|
_this.goodsDiscount = 0;
|
|
|
|
|
_this.consumeAmount = 0;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
_this.consumeRefuelMoney = 0;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
_this.oilTotal = 0;
|
|
|
|
|
_this.goodsTotal = 0;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
_this.isMember = false;
|
2023-11-13 16:51:57 +08:00
|
|
|
|
};
|
|
|
|
|
this.map = {
|
|
|
|
|
allAmount:0,
|
|
|
|
|
// 用户支付条码信息
|
|
|
|
|
authCode:'',
|
|
|
|
|
// 油品订单
|
|
|
|
|
oilOrder:"",
|
|
|
|
|
// 商品订单
|
|
|
|
|
goodsOrder:"",
|
|
|
|
|
// 支付方式
|
|
|
|
|
payType:"WECHAT",
|
|
|
|
|
// 油品订单金额
|
|
|
|
|
oilAmount:0,
|
|
|
|
|
// 商品订单金额
|
|
|
|
|
goodsAmount:0,
|
|
|
|
|
// 油品实付金额
|
|
|
|
|
oilActualPay:0,
|
|
|
|
|
// 商品实付金额
|
|
|
|
|
goodsActualPay:0,
|
|
|
|
|
// 付款用户
|
|
|
|
|
payUser:"",
|
|
|
|
|
// 油品优惠金额
|
|
|
|
|
oilDiscount:0,
|
|
|
|
|
// 商品优惠金额
|
|
|
|
|
goodsDiscount:0,
|
|
|
|
|
// 优惠券id
|
|
|
|
|
couponId:"",
|
|
|
|
|
// 提成金额
|
|
|
|
|
commissionAmount:0,
|
|
|
|
|
// 使用积分数量
|
|
|
|
|
usePoint:0,
|
|
|
|
|
// 积分金额
|
|
|
|
|
pointAmount:0,
|
|
|
|
|
// 终端
|
|
|
|
|
terminal:"PC",
|
|
|
|
|
// 商品数量
|
|
|
|
|
goodsNum:0,
|
|
|
|
|
// 会员消费金额(储值卡需要减少的金额)
|
|
|
|
|
consumeAmount:0,
|
|
|
|
|
};
|
2023-11-08 18:07:17 +08:00
|
|
|
|
},
|
2023-11-16 19:00:57 +08:00
|
|
|
|
updateRefuelMoney(){
|
|
|
|
|
let _this = this;
|
|
|
|
|
_this.oilOrder.forEach(item => {
|
|
|
|
|
if (_this.refuelMoney!=null){
|
|
|
|
|
_this.refuelMoney.forEach(i => {
|
|
|
|
|
if (i.oilType==item.oilType){
|
|
|
|
|
if ((i.refuelMoney-item.liters)>=0){
|
|
|
|
|
let refuelMoney = i.refuelMoney;
|
|
|
|
|
i.refuelMoney = refuelMoney-item.liters
|
|
|
|
|
}else {
|
|
|
|
|
i.refuelMoney = 0
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
2023-11-09 18:52:12 +08:00
|
|
|
|
// 查询订单支付状态
|
|
|
|
|
queryPayStatus(){
|
|
|
|
|
let _this = this;
|
|
|
|
|
_this.timer = setInterval(function (){
|
|
|
|
|
oilOrder({orderNo:_this.orderNo}).then( response => {
|
|
|
|
|
if (response.data!=null){
|
|
|
|
|
if (response.data.orderStatus == "unpaid"){
|
|
|
|
|
_this.isQuery = true;
|
|
|
|
|
}
|
|
|
|
|
if (response.data.orderStatus == "paid"){
|
|
|
|
|
_this.isPaySuccess = true;
|
|
|
|
|
_this.isQuery = false;
|
|
|
|
|
}
|
|
|
|
|
if (response.data.orderStatus == "payFail"){
|
|
|
|
|
_this.isPaySuccess = false;
|
|
|
|
|
_this.isQuery = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
goodsOrder({orderNo:_this.orderNo}).then( response => {
|
|
|
|
|
if (response.data!=null){
|
|
|
|
|
if (response.data.status == "unpaid"){
|
|
|
|
|
_this.isQuery = true;
|
|
|
|
|
}
|
|
|
|
|
if (response.data.status == "paid"){
|
|
|
|
|
_this.isPaySuccess = true;
|
|
|
|
|
_this.isQuery = false;
|
|
|
|
|
}
|
|
|
|
|
if (response.data.status == "payFail"){
|
|
|
|
|
_this.isPaySuccess = false;
|
|
|
|
|
_this.isQuery = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},500)
|
|
|
|
|
},
|
2023-11-08 18:07:17 +08:00
|
|
|
|
handClose(){
|
2023-11-09 18:52:12 +08:00
|
|
|
|
if(this.isPaySuccess){
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.oilAmount = 0;
|
|
|
|
|
this.oilActualPay = 0;
|
|
|
|
|
this.oilDiscount = 0;
|
|
|
|
|
this.goodsAmount = 0;
|
|
|
|
|
this.goodsActualPay = 0;
|
|
|
|
|
this.goodsDiscount = 0;
|
|
|
|
|
this.consumeAmount = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.consumeRefuelMoney = 0;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.oilTotal = 0;
|
|
|
|
|
this.goodsTotal = 0;
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.isMember = false;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
}
|
2023-11-09 18:52:12 +08:00
|
|
|
|
this.isPay = true;
|
2023-11-08 18:07:17 +08:00
|
|
|
|
this.dialogVisiblej = false
|
|
|
|
|
this.isPaySuccess = false;
|
2023-11-03 15:59:38 +08:00
|
|
|
|
},
|
2023-11-07 18:12:17 +08:00
|
|
|
|
// 支付方式
|
2023-11-03 15:59:38 +08:00
|
|
|
|
payMethod(payType){
|
2023-11-07 18:12:17 +08:00
|
|
|
|
this.map.payType = payType;
|
2023-11-03 15:59:38 +08:00
|
|
|
|
},
|
|
|
|
|
// 获取支付方式
|
|
|
|
|
getPayList(){
|
|
|
|
|
getDicts("payment_type").then( response => {
|
|
|
|
|
this.payList = response.data;
|
|
|
|
|
})
|
|
|
|
|
// 获取油号列表信息
|
|
|
|
|
listOilNumGun().then( response => {
|
|
|
|
|
this.oilNumList = response.data
|
|
|
|
|
})
|
2023-11-06 18:06:29 +08:00
|
|
|
|
// 获取油号油枪对应信息
|
|
|
|
|
getOilNumGun({oilNum : "全部"}).then( response => {
|
|
|
|
|
this.oilNumGunList = response.data
|
|
|
|
|
})
|
2023-11-03 15:59:38 +08:00
|
|
|
|
},
|
|
|
|
|
handleClose(done) {
|
|
|
|
|
this.$confirm('确认关闭?')
|
|
|
|
|
.then(_ => {
|
|
|
|
|
done();
|
|
|
|
|
})
|
|
|
|
|
.catch(_ => {});
|
|
|
|
|
},
|
|
|
|
|
handleChange(value) {
|
2023-11-07 18:12:17 +08:00
|
|
|
|
let goods = this.goodsOrder;
|
|
|
|
|
let num = 0;
|
|
|
|
|
let amount = 0;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
let _this = this;
|
2023-11-07 18:12:17 +08:00
|
|
|
|
goods.forEach(item => {
|
|
|
|
|
num += item.num
|
2023-11-09 13:51:57 +08:00
|
|
|
|
if (_this.isMember){
|
|
|
|
|
amount += item.memberPrice*item.num;
|
|
|
|
|
}else {
|
|
|
|
|
amount += item.retailPrice*item.num;
|
|
|
|
|
}
|
2023-11-07 18:12:17 +08:00
|
|
|
|
})
|
|
|
|
|
this.goodsTotal = num;
|
|
|
|
|
this.goodsAmount = amount;
|
2023-11-09 13:51:57 +08:00
|
|
|
|
this.goodsActualPay = this.goodsAmount - this.goodsDiscount;
|
2023-11-03 15:59:38 +08:00
|
|
|
|
},
|
|
|
|
|
handleClick(tab, event) {
|
2023-11-06 18:06:29 +08:00
|
|
|
|
let oilNum = ""
|
|
|
|
|
this.oilNumList.forEach(item => {
|
|
|
|
|
if (item.oilName == tab.name){
|
|
|
|
|
oilNum = item.numberId
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
if (tab.label == "全部"){
|
2023-11-17 16:33:36 +08:00
|
|
|
|
oilNum = ""
|
2023-11-06 18:06:29 +08:00
|
|
|
|
}
|
2023-11-17 16:33:36 +08:00
|
|
|
|
this.getList(oilNum)
|
|
|
|
|
// getOilNumGun({oilNum : oilNum}).then( response => {
|
|
|
|
|
// this.oilNumGunList = response.data
|
|
|
|
|
// })
|
2023-11-03 15:59:38 +08:00
|
|
|
|
},
|
|
|
|
|
gocomponents(index){
|
|
|
|
|
this.leftindex = index
|
|
|
|
|
},
|
2023-11-16 19:00:57 +08:00
|
|
|
|
// 获取优惠券列表信息
|
|
|
|
|
getCouponList(){
|
|
|
|
|
listCardFavorableRecord().then(response => {
|
|
|
|
|
this.couponList = response.data.records
|
|
|
|
|
})
|
2023-11-17 16:33:36 +08:00
|
|
|
|
let map = {
|
|
|
|
|
page:1,
|
|
|
|
|
pageSize:20,
|
|
|
|
|
}
|
|
|
|
|
listUserGrade(map).then(response => {
|
|
|
|
|
this.gradeList = response.data.records
|
|
|
|
|
})
|
2023-11-16 19:00:57 +08:00
|
|
|
|
},
|
2023-11-17 16:33:36 +08:00
|
|
|
|
// 获取油枪列表信息
|
|
|
|
|
getList(numberId){
|
|
|
|
|
getOilGun({numberId:numberId}).then(response => {
|
|
|
|
|
this.gunList = response.data.records;
|
2023-11-16 19:00:57 +08:00
|
|
|
|
})
|
|
|
|
|
},
|
2023-11-07 18:12:17 +08:00
|
|
|
|
},
|
2023-11-03 15:59:38 +08:00
|
|
|
|
|
|
|
|
|
}
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style scoped lang="scss">
|
2023-11-06 18:06:29 +08:00
|
|
|
|
.but{
|
|
|
|
|
width: 150px;
|
|
|
|
|
height: 50px;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
font-size: 20px;
|
|
|
|
|
}
|
|
|
|
|
.amountBlue{
|
|
|
|
|
color: #00afff;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
}
|
|
|
|
|
.amount{
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
width: 100%;
|
|
|
|
|
padding: 0 10px;
|
|
|
|
|
margin: 10px auto;
|
|
|
|
|
height: 50px;
|
|
|
|
|
line-height: 50px;
|
|
|
|
|
background-color: #f6f6f6;
|
|
|
|
|
border-radius: 5px;
|
|
|
|
|
}
|
2023-10-26 09:32:37 +08:00
|
|
|
|
.app-center{
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
}
|
|
|
|
|
.center-left{
|
|
|
|
|
width: 33%;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
height: 98vh;
|
|
|
|
|
position: relative;
|
|
|
|
|
}
|
|
|
|
|
.bottom-posi{
|
|
|
|
|
width: 100%;
|
|
|
|
|
position: absolute;
|
|
|
|
|
bottom: 0px;
|
|
|
|
|
}
|
|
|
|
|
.center-app{
|
|
|
|
|
width: 33%;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
/*background: white;*/
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.center-right{
|
|
|
|
|
width: 33%;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
margin: 0px 10px;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.center-top{
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 86vh;
|
|
|
|
|
background: white;
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
position: relative;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.center-top-title{
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px 0px;
|
|
|
|
|
padding-bottom: 15px;
|
|
|
|
|
border-bottom: 1px solid #ececec;
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
}
|
|
|
|
|
.center-top-tab{
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 15px 0px;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.center-top-input{
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 60px;
|
|
|
|
|
background: #f8f8f8;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
input{
|
|
|
|
|
width: 90%;
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
border: none;
|
|
|
|
|
outline: none;
|
|
|
|
|
background-color:transparent;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.center-top-data{
|
|
|
|
|
width: 100%;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
margin-top: 10px;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*background-color: #f8f8f8;*/
|
|
|
|
|
}
|
|
|
|
|
.center-top-of{
|
|
|
|
|
width: 100%;
|
|
|
|
|
/*background-color: #99a9bf;*/
|
|
|
|
|
height: 70vh;
|
|
|
|
|
overflow: auto;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.wrap-wrap{
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
}
|
|
|
|
|
.of-box{
|
|
|
|
|
width: 31%;
|
|
|
|
|
margin-right: 10px;
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
background-color: #b4d5ff;
|
|
|
|
|
height: 110px;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
color: #3e4f60;
|
|
|
|
|
}
|
|
|
|
|
.of-title{
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
font-size: 22px;
|
|
|
|
|
text-align: center;
|
|
|
|
|
margin: 13px;
|
|
|
|
|
}
|
|
|
|
|
.data-top{
|
|
|
|
|
width: 100%;
|
|
|
|
|
background-color: #ededed;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 15px 10px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
}
|
|
|
|
|
.data-top-box{
|
|
|
|
|
width: 100%;
|
|
|
|
|
/*background-color: #ededed;*/
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 15px 10px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.data-top-three{
|
|
|
|
|
width: 55%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.data-top-title{
|
|
|
|
|
width: 45%;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
}
|
|
|
|
|
.content-top-bottom{
|
|
|
|
|
position: absolute;
|
|
|
|
|
bottom:-16px;
|
|
|
|
|
width: 98%;
|
|
|
|
|
border-top: 1px solid #ececec;
|
|
|
|
|
height: 40px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
transform: translate(-50%,-50%);
|
|
|
|
|
left: 50%;
|
|
|
|
|
color: #2c3e50;
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 15px ;
|
|
|
|
|
background-color: white;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.center-left-top{
|
|
|
|
|
width: 100%;
|
|
|
|
|
background: #5393ff;
|
|
|
|
|
height: 70px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
}
|
|
|
|
|
.center-vh{
|
|
|
|
|
/*height: 68vh;*/
|
|
|
|
|
}
|
|
|
|
|
.center-left-hj{
|
|
|
|
|
background: white;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 15px;
|
|
|
|
|
margin-bottom: 2px;
|
|
|
|
|
}
|
|
|
|
|
.center-left-th{
|
|
|
|
|
background: white;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 15px;
|
|
|
|
|
margin: 10px auto;
|
|
|
|
|
}
|
|
|
|
|
.center-left-wrap{
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
/*margin-top: 280px;*/
|
|
|
|
|
}
|
|
|
|
|
.wrap-box{
|
|
|
|
|
width: 31%;
|
|
|
|
|
background: #ffffff;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
height: 80px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
.wrap-box :hover{
|
|
|
|
|
/*background: #00afff !important;*/
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
height: 80px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
border: 1px solid #00afff;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
/*color: white;*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.center-left-bottom{
|
|
|
|
|
width: 100%;
|
|
|
|
|
background-color: white;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
}
|
|
|
|
|
.bottom-qk{
|
|
|
|
|
border: 1px solid #99a9bf;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 14px 20px;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
color: #99a9bf;
|
|
|
|
|
margin: 15px 0px ;
|
|
|
|
|
}
|
|
|
|
|
.bottom-qd{
|
|
|
|
|
border: 1px solid #13ce66;
|
|
|
|
|
background: #13ce66;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 14px 20px;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
|
|
|
|
|
margin: 15px 10px ;
|
|
|
|
|
}
|
|
|
|
|
.bottom-gd{
|
|
|
|
|
border: 1px solid #5393ff;
|
|
|
|
|
background: #5393ff;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 14px 20px;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
|
|
|
|
|
margin: 15px 10px ;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottom-price{
|
|
|
|
|
font-size: 26px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
}
|
|
|
|
|
.price-red{
|
|
|
|
|
color: red;
|
|
|
|
|
}
|
|
|
|
|
.center-left-lv{
|
|
|
|
|
width: 60%;
|
|
|
|
|
height: 80px;
|
|
|
|
|
background-color: #13ce66;
|
|
|
|
|
color: white;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
font-size: 22px;
|
|
|
|
|
}
|
|
|
|
|
.th-box{
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
border-bottom: 1px solid #f6f8f9;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 10px 0px;
|
|
|
|
|
}
|
|
|
|
|
.hj-box{
|
|
|
|
|
width: 33%;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
}
|
|
|
|
|
.bule{
|
|
|
|
|
font-weight: 700;
|
|
|
|
|
color: #5393ff !important;
|
|
|
|
|
}
|
|
|
|
|
.vip-bottom{
|
|
|
|
|
border: 1px solid #ffffff;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
padding: 5px 15px;
|
|
|
|
|
border-radius: 50px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
color: white;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
}
|
2023-11-06 18:06:29 +08:00
|
|
|
|
.el-row {
|
|
|
|
|
margin-top: 20px;
|
|
|
|
|
margin-bottom: 20px;
|
|
|
|
|
&:last-child {
|
|
|
|
|
margin-bottom: 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.el-col {
|
|
|
|
|
border-radius: 2px;
|
|
|
|
|
text-align: center;
|
|
|
|
|
font-size: 20px;
|
|
|
|
|
height: 50px;
|
|
|
|
|
line-height: 50px;
|
|
|
|
|
}
|
|
|
|
|
.bg-purple-dark {
|
|
|
|
|
background: #eeeeee;
|
|
|
|
|
}
|
|
|
|
|
.bg-purple {
|
|
|
|
|
background: #d3dce6;
|
|
|
|
|
}
|
|
|
|
|
.bg-purple-light {
|
|
|
|
|
background: #e5e9f2;
|
|
|
|
|
}
|
|
|
|
|
.grid-content {
|
|
|
|
|
height: 50px;
|
|
|
|
|
font-size: 20px;
|
|
|
|
|
width: 120px;
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
min-height: 36px;
|
|
|
|
|
}
|
|
|
|
|
.row-bg {
|
|
|
|
|
padding: 10px 0;
|
|
|
|
|
background-color: #eeeeee;
|
|
|
|
|
}
|
2023-11-08 18:07:17 +08:00
|
|
|
|
.elBut{
|
|
|
|
|
width: 85px;
|
|
|
|
|
height: 50px;
|
|
|
|
|
font-size: 18px;
|
|
|
|
|
}
|
2023-11-10 18:10:23 +08:00
|
|
|
|
.addr{
|
|
|
|
|
color: grey;
|
|
|
|
|
font-size: 12px;
|
|
|
|
|
}
|
2023-10-26 09:32:37 +08:00
|
|
|
|
</style>
|