From 6a8d2bd39cf88e13c546adbfafb5990a9b0c5f4e Mon Sep 17 00:00:00 2001
From: zhibing.pu <393733352@qq.com>
Date: 星期一, 24 六月 2024 15:14:42 +0800
Subject: [PATCH] 优化
---
cloud-server-other/src/main/java/com/dsh/other/service/impl/SiteServiceImpl.java | 409 ++++++++++++++++++++++++++++++++++-----------------------
1 files changed, 242 insertions(+), 167 deletions(-)
diff --git a/cloud-server-other/src/main/java/com/dsh/other/service/impl/SiteServiceImpl.java b/cloud-server-other/src/main/java/com/dsh/other/service/impl/SiteServiceImpl.java
index 8021355..767ab40 100644
--- a/cloud-server-other/src/main/java/com/dsh/other/service/impl/SiteServiceImpl.java
+++ b/cloud-server-other/src/main/java/com/dsh/other/service/impl/SiteServiceImpl.java
@@ -29,6 +29,7 @@
import javax.annotation.Resource;
import java.math.BigDecimal;
import java.math.RoundingMode;
+import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.time.LocalTime;
import java.util.*;
@@ -69,22 +70,26 @@
@Autowired
private TBackRecordService backRecordService;
+ @Autowired
+ private ISiteBookingService iSiteBookingService;
-
+ @Autowired
+ private ISiteService siteService;
/**
* 获取场地列表
+ *
* @param querySiteList
* @return
* @throws Exception
*/
@Override
public List<QuerySiteListVo> querySiteList(QuerySiteList querySiteList) throws Exception {
- querySiteList.setPageNum((querySiteList.getPageNum() - 1) *querySiteList.getPageSize());
+ querySiteList.setPageNum((querySiteList.getPageNum() - 1) * querySiteList.getPageSize());
List<QuerySiteListVo> querySiteListVos = this.baseMapper.querySiteList(querySiteList);
for (QuerySiteListVo querySiteListVo : querySiteListVos) {
- if(ToolUtil.isEmpty(querySiteList.getLon())){
+ if (ToolUtil.isEmpty(querySiteList.getLon())) {
querySiteListVo.setDistance(0D);
continue;
}
@@ -98,6 +103,7 @@
/**
* 获取场地详情
+ *
* @param id
* @return
* @throws Exception
@@ -124,7 +130,7 @@
querySiteInfoVo.setCashPriceOne(site.getCashPriceOne());
- if(site.getPlayPaiCoinOne()!=null){
+ if (site.getPlayPaiCoinOne() != null) {
querySiteInfoVo.setPlayPaiCoinOne(site.getPlayPaiCoinOne().intValue());
}
@@ -144,7 +150,7 @@
}
querySiteInfoVo.setHalfName(halfName);
querySiteInfoVo.setNextName(nextName);
- if(ToolUtil.isNotEmpty(lon) && ToolUtil.isNotEmpty(lat)){
+ if (ToolUtil.isNotEmpty(lon) && ToolUtil.isNotEmpty(lat)) {
Map<String, Double> distance = GeodesyUtil.getDistance(lon + "," + lat, store.getLon() + "," + store.getLat());
double wgs84 = new BigDecimal(distance.get("WGS84")).divide(new BigDecimal(1000)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
querySiteInfoVo.setDistance(wgs84);
@@ -157,35 +163,28 @@
-
- @Autowired
- private ISiteBookingService iSiteBookingService;
- @Autowired
- private ISiteService siteService;
/**
* 获取场地预约日期数据
+ *
* @param id
* @param day
* @return
* @throws Exception
*/
@Override
- public List<QuerySiteTimes> querySiteTimes(Integer id, String day,String halfName,String siteName) throws Exception {
+ public List<QuerySiteTimes> querySiteTimes(Integer id, String day, String halfName, String siteName) throws Exception {
- System.out.println("=======date======"+day);
-
+ System.out.println("=======date======" + day);
List<String> strings = new ArrayList<>();
-// List<SiteBooking> siteBookings = siteClient.listBooks(id);
- List<SiteBooking> siteBookings = iSiteBookingService.list(new QueryWrapper<SiteBooking>().eq("siteId", id).eq("nextName",siteName).like("times",day));
+ List<SiteBooking> siteBookings = iSiteBookingService.list(new QueryWrapper<SiteBooking>().eq("siteId", id).ne("status", 5).eq("nextName", siteName).like("times", day));
-
- if (siteName==null|| siteName.equals("")){
- siteBookings = iSiteBookingService.list(new QueryWrapper<SiteBooking>().eq("siteId", id).like("times",day));
+ if (siteName == null || siteName.equals("")) {
+ siteBookings = iSiteBookingService.list(new QueryWrapper<SiteBooking>().eq("siteId", id).ne("status", 5).like("times", day));
}
- System.out.println("=======siteBookings======"+siteBookings);
+ System.out.println("=======siteBookings======" + siteBookings);
for (SiteBooking siteBooking : siteBookings) {
@@ -196,15 +195,15 @@
String convertedValue = s.substring(11);
strings.add(convertedValue);
}
- }else {
- if (halfName==null){
+ } else {
+ if (halfName == null) {
for (String s : split) {
String convertedValue = s.substring(11);
strings.add(convertedValue);
}
}
- if (siteBooking.getHalfName().equals(halfName)){
+ if (siteBooking.getHalfName().equals(halfName)) {
for (String s : split) {
String convertedValue = s.substring(11);
strings.add(convertedValue);
@@ -213,24 +212,24 @@
}
}
}
- System.out.println("======strings======="+strings);
+ System.out.println("======strings=======" + strings);
List<QuerySiteTimes> timeRanges = new ArrayList<>();
- Site site = siteService.getById(id);
- System.out.println("================"+site);
+ Site site = siteService.getById(id);
+ System.out.println("================" + site);
String appointmentStartTime = site.getAppointmentStartTime();
String appointmentEndTime = site.getAppointmentEndTime();
String currentTime = appointmentStartTime;
while (currentTime.compareTo(appointmentEndTime) < 0) {
- String nextTime=null;
- if("智慧场地".equals(site.getTypeName())){
- nextTime=getNextTimeOne(currentTime);
- }else {
- nextTime= getNextTime(currentTime);
+ String nextTime = null;
+ if ("智慧场地".equals(site.getTypeName())) {
+ nextTime = getNextTimeOne(currentTime);
+ } else {
+ nextTime = getNextTime(currentTime);
}
@@ -245,21 +244,28 @@
// if (hasExceeded){
// orderDto.setSelectable(0);
// }
- if (strings.contains(timeRange)){
+ if (strings.contains(timeRange)) {
orderDto.setSelectable(0);
- }else {
+ } else {
- String stime = day+" "+currentTime;
- String etime = day+" "+nextTime;
+ String stime = day + " " + currentTime;
+ String etime = day + " " + nextTime;
orderDto.setSelectable(1);
// 查出lock
List<SiteLock> list = siteLockService.list(new LambdaQueryWrapper<SiteLock>().eq(SiteLock::getSiteId, id));
for (SiteLock siteLock : list) {
boolean stringDateBetween = DateComparisonExample.isStringDateBetween(stime + " - " + etime, siteLock.getStartTime(), siteLock.getEndTime());
- if(stringDateBetween){
+ if (stringDateBetween) {
orderDto.setSelectable(0);
}
+ if (DateComparisonExample.isStringWithinTimeRange(stime, siteLock.getStartTime(), siteLock.getEndTime())) {
+ orderDto.setSelectable(0);
+ }
+ if (DateComparisonExample.isStringWithinTimeRange(etime, siteLock.getStartTime(), siteLock.getEndTime())) {
+ orderDto.setSelectable(0);
+ }
+
}
@@ -269,10 +275,9 @@
timeRanges.add(orderDto);
currentTime = nextTime;
}
- System.out.println("-------------"+timeRanges);
+ System.out.println("-------------" + timeRanges);
return timeRanges;
-
}
@@ -293,6 +298,7 @@
return String.format("%02d:%02d", hour, minute);
}
+
public static String getNextTimeOne(String currentTime) {
String[] parts = currentTime.split(":");
@@ -302,11 +308,11 @@
if (minute == 45) {
hour++;
minute = 0;
- } else if (minute == 0){
+ } else if (minute == 0) {
minute = 15;
- }else if (minute == 15){
+ } else if (minute == 15) {
minute = 30;
- }else if (minute == 30){
+ } else if (minute == 30) {
minute = 45;
}
@@ -317,22 +323,22 @@
/**
* 预约场地
+ *
* @param reservationSite
* @return
* @throws Exception
*/
@Override
public ResultUtil reservationSite(Integer uid, ReservationSite reservationSite) throws Exception {
-
Site site = this.getById(reservationSite.getId());
AppUser appUser = appUserClient.queryAppUser(uid);
String[] split = reservationSite.getTimes().split(";");
for (String s : split) {
String day = s.split(" ")[0];
String time = s.split(" ")[1];
- List<QuerySiteTimes> querySiteTimes = querySiteTimes(reservationSite.getId(), day,reservationSite.getHalfName(),reservationSite.getNextName());
+ List<QuerySiteTimes> querySiteTimes = querySiteTimes(reservationSite.getId(), day, reservationSite.getHalfName(), reservationSite.getNextName());
for (QuerySiteTimes querySiteTime : querySiteTimes) {
- if(querySiteTime.getTime().equals(time) && querySiteTime.getSelectable() == 0){
+ if (querySiteTime.getTime().equals(time) && querySiteTime.getSelectable() == 0) {
return ResultUtil.error("【" + s + "】" +
"时间段已被使用");
}
@@ -341,69 +347,63 @@
String s_time = split[0];
String e_time = split[split.length - 1];
- s_time = s_time.substring(0,s_time.lastIndexOf("-"));
+ s_time = s_time.substring(0, s_time.lastIndexOf("-"));
String[] s1 = e_time.split(" ");
e_time = s1[0] + " " + s1[1].split("-")[1];
SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
Double payMoney = 0D;
- if(reservationSite.getPayType() == 3){
- if(reservationSite.getIsHalf()==2){
- payMoney = new BigDecimal(site.getPlayPaiCoin()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue() ;
- }else {
- payMoney = new BigDecimal(site.getPlayPaiCoinOne()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue() /2;
+ if (reservationSite.getPayType() == 3) {
+ if (reservationSite.getIsHalf() == 2) {
+ payMoney = new BigDecimal(site.getPlayPaiCoin()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ } else {
+ payMoney = new BigDecimal(site.getPlayPaiCoinOne()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
}
- if(appUser.getPlayPaiCoins().compareTo(payMoney.intValue()) < 0){
-
- return new ResultUtil(3,"玩湃币不足");
+ if (appUser.getPlayPaiCoins().compareTo(payMoney.intValue()) < 0) {
+ return new ResultUtil(3, "玩湃币不足");
}
- }else{
- if(reservationSite.getIsHalf()==2){
- payMoney = new BigDecimal(site.getCashPrice()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue() ;
- }else {
- payMoney = new BigDecimal(site.getCashPrice()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue() / 2;
-
+ } else {
+ if (reservationSite.getIsHalf() == 2) {
+ payMoney = new BigDecimal(site.getCashPrice()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ } else {
+ payMoney = new BigDecimal(site.getCashPriceOne()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
}
}
//校验优惠券
Long couponId = reservationSite.getCouponId();
- if (couponId!=null && couponId != 0){
-
- if(null != couponId && reservationSite.getPayType() != 3){
- UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(reservationSite.getCouponId(),uid));
-
-
- if(userCoupon!=null && userCoupon.getStatus() == 2){
- return ResultUtil.error("优惠券已被核销");
- }
- Coupon coupon = couponClient.queryCouponById(userCoupon.getCouponId());
- long time = coupon.getEndTime().getTime();
- if(System.currentTimeMillis() >= time){
- return ResultUtil.error("优惠券已过期");
- }
- if(userCoupon!=null && coupon.getType() == 1){//满减
-// {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
- JSONObject jsonObject = JSON.parseObject(coupon.getContent());
- Double num1 = jsonObject.getDouble("conditionalAmount");
- Double num2 = jsonObject.getDouble("deductionAmount");
- if(payMoney.compareTo(num1) <= 0){
- return ResultUtil.error("该优惠券无法使用");
+ if (couponId != null && couponId != 0) {
+ if (null != couponId && reservationSite.getPayType() != 3) {
+ UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(reservationSite.getCouponId(), uid));
+ if (userCoupon != null && userCoupon.getStatus() == 2) {
+ return ResultUtil.error("优惠券已被核销");
}
-
- payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num2)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
- }
- if(userCoupon!=null && coupon.getType() == 2){//代金券
- JSONObject jsonObject = JSON.parseObject(coupon.getContent());
- Double num1 = jsonObject.getDouble("conditionalAmount");
- if(payMoney.compareTo(num1) <= 0){
- return ResultUtil.error("该优惠券无法使用");
+ Coupon coupon = couponClient.queryCouponById(userCoupon.getCouponId());
+ long time = coupon.getEndTime().getTime();
+ if (System.currentTimeMillis() >= time) {
+ return ResultUtil.error("优惠券已过期");
}
- payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num1)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ if (userCoupon != null && coupon.getType() == 1) {//满减
+ JSONObject jsonObject = JSON.parseObject(coupon.getContent());
+ Double num1 = jsonObject.getDouble("conditionalAmount");
+ Double num2 = jsonObject.getDouble("deductionAmount");
+ if (payMoney.compareTo(num1) < 0) {
+ return ResultUtil.error("该优惠券无法使用");
+ }
+
+ payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num2)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ }
+ if (userCoupon != null && coupon.getType() == 2) {//代金券
+ JSONObject jsonObject = JSON.parseObject(coupon.getContent());
+ Double num1 = jsonObject.getDouble("conditionalAmount");
+ if (payMoney.compareTo(num1) <= 0) {
+ return ResultUtil.error("该优惠券无法使用");
+ }
+ payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num1)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ }
+ userCoupon.setStatus(2);
+ userCouponClient.updateUserCoupon(userCoupon);
}
- userCoupon.setStatus(2);
- userCouponClient.updateUserCoupon(userCoupon);
- }
}
@@ -428,27 +428,23 @@
siteBooking.setState(1);
siteBooking.setInsertTime(new Date());
- // 2.0
siteBooking.setNextName(reservationSite.getNextName());
siteBooking.setIsHalf(reservationSite.getIsHalf());
siteBooking.setHalfName(reservationSite.getHalfName());
siteBookingService.save(siteBooking);
-
-
- if(reservationSite.getPayType() == 1){//微信支付
+ if (reservationSite.getPayType() == 1) {//微信支付
ResultUtil resultUtil = weChatPaymentSite(payMoney, siteBooking);
-
return resultUtil;
}
- if(reservationSite.getPayType() == 2){//支付宝支付
+ if (reservationSite.getPayType() == 2) {//支付宝支付
return aliPaymentSite(payMoney, siteBooking);
}
- if(reservationSite.getPayType() == 3){//玩湃币支付
- if(reservationSite.getIsHalf()==2){
+ if (reservationSite.getPayType() == 3) {//玩湃币支付
+ if (reservationSite.getIsHalf() == 2) {
return playPaiCoinPaymentSite(appUser, Double.valueOf(site.getPlayPaiCoin()), siteBooking);
- }else {
+ } else {
return playPaiCoinPaymentSite(appUser, site.getPlayPaiCoinOne(), siteBooking);
}
}
@@ -458,31 +454,33 @@
/**
* 课程微信支付
+ *
* @param paymentPrice
* @return
* @throws Exception
*/
- public ResultUtil weChatPaymentSite(Double paymentPrice, SiteBooking siteBooking) throws Exception{
+ public ResultUtil weChatPaymentSite(Double paymentPrice, SiteBooking siteBooking) throws Exception {
String code = siteBooking.getOrderNo();
Integer id = siteBooking.getId();
- ResultUtil weixinpay = payMoneyUtil.weixinpay("预约场地", id.toString(), code, paymentPrice.toString(), "/base/site/weChatPaymentSiteCallback", "APP", "");
- if(weixinpay.getCode() == 200){
+ ResultUtil weixinpay = payMoneyUtil.weixinpay("预约场地", id.toString(), code, paymentPrice.toString(),
+ "/base/site/weChatPaymentSiteCallback", "APP", "");
+ if (weixinpay.getCode() == 200) {
new Thread(new Runnable() {
@Override
public void run() {
try {
int num = 1;
int wait = 0;
- while (num <= 10){
+ while (num <= 10) {
int min = 5000;
wait += (min * num);
Thread.sleep(wait);
SiteBooking siteBooking = siteBookingService.getById(id);
- if(siteBooking.getStatus() != 0){
+ if (siteBooking.getStatus() != 0) {
break;
}
ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(siteBooking.getOrderNo(), "");
- if(resultUtil.getCode() == 200 && siteBooking.getStatus() == 0){
+ if (resultUtil.getCode() == 200 && siteBooking.getStatus() == 0) {
/**
* SUCCESS—支付成功,
* REFUND—转入退款,
@@ -495,22 +493,22 @@
Map<String, String> data1 = resultUtil.getData();
String s = data1.get("trade_state");
String transaction_id = data1.get("transaction_id");
- if("REFUND".equals(s) || "NOTPAY".equals(s) || "CLOSED".equals(s) || "REVOKED".equals(s) || "PAYERROR".equals(s) || num == 10){
+ if ("REFUND".equals(s) || "CLOSED".equals(s) || "REVOKED".equals(s) || "PAYERROR".equals(s) || num == 10) {
break;
}
- if("SUCCESS".equals(s)){
+ if ("SUCCESS".equals(s)) {
siteBooking.setPayTime(new Date());
siteBooking.setStatus(1);
siteBooking.setPayOrderNo(transaction_id);
siteBookingService.updateById(siteBooking);
break;
}
- if("USERPAYING".equals(s)){
+ if ("USERPAYING".equals(s) || "NOTPAY".equals(s)) {
num++;
}
}
}
- }catch (Exception e){
+ } catch (Exception e) {
e.printStackTrace();
}
}
@@ -519,35 +517,50 @@
return weixinpay;
}
-
+ private String smid = "2088330203191220";//平台支付宝商户号
/**
* 课程支付宝支付
+ *
* @param paymentPrice
* @return
* @throws Exception
*/
- public ResultUtil aliPaymentSite(Double paymentPrice, SiteBooking siteBooking) throws Exception{
+ public ResultUtil aliPaymentSite(Double paymentPrice, SiteBooking siteBooking) throws Exception {
String code = siteBooking.getOrderNo();
Integer id = siteBooking.getId();
- ResultUtil alipay = payMoneyUtil.alipay("预约场地", "预约场地", id.toString(), code, paymentPrice.toString(), "/base/site/aliPaymentSiteCallback");
- System.out.println("预约场地----"+alipay.getCode());
- if(alipay.getCode() == 200){
+ // 判断预约的门店 属于哪个运营商
+ Integer storeId = siteBooking.getStoreId();
+ Store byId = storeService.getById(storeId);
+ Integer operatorId = byId.getOperatorId();
+ String smid1 = "";
+ if (operatorId == null ){
+ // 平台的门店
+ smid1 = smid;
+ }else if (operatorId == 0){
+ smid1 = smid;
+ }else{
+ smid1 = siteService.getSMIDByOperatorId(operatorId);
+
+ }
+ ResultUtil alipay = payMoneyUtil.alipay(smid1,"预约场地", "预约场地", id.toString(), code, paymentPrice.toString(), "/base/site/aliPaymentSiteCallback");
+ System.out.println("预约场地----" + alipay.getCode());
+ if (alipay.getCode() == 200) {
new Thread(new Runnable() {
@Override
public void run() {
try {
int num = 1;
int wait = 0;
- while (num <= 10){
+ while (num <= 10) {
int min = 5000;
wait += (min * num);
Thread.sleep(wait);
SiteBooking siteBooking = siteBookingService.getById(id);
- if(siteBooking.getStatus() != 0){
+ if (siteBooking.getStatus() != 0) {
break;
}
AlipayTradeQueryResponse resultUtil = payMoneyUtil.queryALIOrder(code);
- if(resultUtil.getCode().equals("10000") && siteBooking.getStatus() == 0){
+ if (resultUtil.getCode().equals("10000") && siteBooking.getStatus() == 0) {
/**
* WAIT_BUYER_PAY(交易创建,等待买家付款)、
* TRADE_CLOSED(未付款交易超时关闭,或支付完成后全额退款)、
@@ -558,24 +571,38 @@
// String s = data1.get("tradeStatus");
String tradeNo = resultUtil.getTradeNo();
String s = resultUtil.getTradeStatus();
- System.out.println("ssssss"+s);
- if("TRADE_CLOSED".equals(s) || "TRADE_FINISHED".equals(s) || num == 10){
+ System.out.println("ssssss" + s);
+ if ("TRADE_CLOSED".equals(s) || "TRADE_FINISHED".equals(s) || num == 10) {
break;
}
- if("TRADE_SUCCESS".equals(s)){
+ if ("TRADE_SUCCESS".equals(s)) {
siteBooking.setPayTime(new Date());
siteBooking.setStatus(1);
siteBooking.setPayOrderNo(tradeNo);
siteBookingService.updateById(siteBooking);
System.err.println("======完成支付");
+ // 判断预约的门店 属于哪个运营商
+ Integer storeId = siteBooking.getStoreId();
+ Store byId = storeService.getById(storeId);
+ Integer operatorId = byId.getOperatorId();
+ String smid1 = "";
+ if (operatorId == null ){
+ // 平台的门店
+ }else if (operatorId == 0){
+ smid1 = smid;
+ }else{
+ smid1 = siteService.getSMIDByOperatorId(operatorId);
+
+ }
+ payMoneyUtil.confirm(smid1,code,tradeNo,paymentPrice.toString());
break;
}
- if("WAIT_BUYER_PAY".equals(s)){
+ if ("WAIT_BUYER_PAY".equals(s)) {
num++;
}
}
}
- }catch (Exception e){
+ } catch (Exception e) {
e.printStackTrace();
}
}
@@ -587,12 +614,13 @@
/**
* 玩湃币支付
+ *
* @param appUser
* @param paymentPrice
* @return
* @throws Exception
*/
- public ResultUtil playPaiCoinPaymentSite(AppUser appUser, Double paymentPrice, SiteBooking siteBooking) throws Exception{
+ public ResultUtil playPaiCoinPaymentSite(AppUser appUser, Double paymentPrice, SiteBooking siteBooking) throws Exception {
Integer playPaiCoins = appUser.getPlayPaiCoins();
appUser.setPlayPaiCoins(playPaiCoins - paymentPrice.intValue());
appUserClient.updateAppUser(appUser);
@@ -600,13 +628,14 @@
siteBooking.setStatus(1);
siteBookingService.updateById(siteBooking);
HashMap<String, String> map = new HashMap<>();
- map.put("siteBooking",siteBooking.getId().toString());
+ map.put("siteBooking", siteBooking.getId().toString());
return ResultUtil.success(map);
}
/**
* 获取我的场地预约
+ *
* @param uid
* @param status
* @param pageNo
@@ -622,8 +651,14 @@
SiteBooking siteBooking = siteBookingService.getById(queryMySiteVo.getId());
Site site = this.getById(siteBooking.getSiteId());
String[] split = siteBooking.getTimes().split(";");
- if(site!=null){
- queryMySiteVo.setPlayPaiCoin(site.getPlayPaiCoin() * split.length);
+ if (site != null) {
+ if (queryMySiteVo.getIsHalf() == 1) {
+ queryMySiteVo.setPlayPaiCoin((int) (site.getPlayPaiCoinOne() * split.length));
+
+ } else {
+ queryMySiteVo.setPlayPaiCoin(site.getPlayPaiCoin() * split.length);
+
+ }
}
}
return queryMySiteVos;
@@ -632,6 +667,7 @@
/**
* 取消我的预约场地
+ *
* @param id
* @return
* @throws Exception
@@ -642,22 +678,34 @@
SimpleDateFormat format = new SimpleDateFormat("yyyyMMdd");
Date startTime = siteBooking.getStartTime();
- if(format.format(new Date()).equals(format.format(startTime))){
+ if (format.format(new Date()).equals(format.format(startTime)) && siteBooking.getStatus() != 0) {
return ResultUtil.error("预约当天,不能取消");
}
- if(siteBooking.getStatus() == 0){
- return ResultUtil.error("请先进行支付");
+
+ if (siteBooking.getStatus() == 0) {
+ siteBooking.setStatus(5);
+ siteBookingService.updateById(siteBooking);
+ AppUser appUser = appUserClient.queryAppUser(siteBooking.getAppUserId());
+
+ if (null != siteBooking.getUserCouponId() && siteBooking.getUserCouponId() != 0) {
+ UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(), appUser.getId()));
+ userCoupon.setStatus(1);
+ userCouponClient.updateUserCoupon(userCoupon);
+ }
+
+ return ResultUtil.success();
}
- if(siteBooking.getStatus() != 1 && siteBooking.getStatus() != 2){
+ if (siteBooking.getStatus() != 1 && siteBooking.getStatus() != 2) {
return ResultUtil.error("不能进行取消操作");
}
- if(siteBooking.getPayType() == 1){//微信支付
- Map<String, String> map = payMoneyUtil.wxRefund(siteBooking.getPayOrderNo(), siteBooking.getOrderNo(), siteBooking.getPayMoney().toString(), siteBooking.getPayMoney().toString(), "/base/site/cancelMySiteCallback");
- if(null == map){
+ if (siteBooking.getPayType() == 1) {//微信支付
+ Map<String, String> map = payMoneyUtil.wxRefund(siteBooking.getPayOrderNo(), siteBooking.getOrderNo(), siteBooking.getPayMoney().toString(),
+ siteBooking.getPayMoney().toString(), "/base/site/cancelMySiteCallback");
+ if (null == map) {
return ResultUtil.error("取消退款异常");
}
- String result_code = map.get("result_code");
- if(!"SUCCESS".equals(result_code)){
+ String return_code = map.get("return_code");
+ if (!"SUCCESS".equals(return_code)) {
return ResultUtil.error(map.get("return_msg"));
}
siteBooking.setCancelUserId(uid);
@@ -670,13 +718,13 @@
backRecordService.save(tBackRecord);
}
- if(siteBooking.getPayType() == 2){//支付宝
+ if (siteBooking.getPayType() == 2) {//支付宝
Map<String, String> map = payMoneyUtil.aliRefund(siteBooking.getPayOrderNo(), siteBooking.getPayMoney().toString());
- if(null == map){
+ if (null == map) {
return ResultUtil.error("取消退款异常");
}
String code = map.get("code");
- if(!"10000".equals(code)){
+ if (!"10000".equals(code)) {
return ResultUtil.error(map.get("return_msg"));
}
String trade_no = map.get("trade_no");
@@ -685,8 +733,8 @@
siteBooking.setCancelTime(new Date());
siteBooking.setRefundOrderNo(trade_no);
siteBookingService.updateById(siteBooking);
- if(null != siteBooking.getUserCouponId()){
- UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(),siteBooking.getAppUserId()));
+ if (null != siteBooking.getUserCouponId() && siteBooking.getUserCouponId() != 0) {
+ UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(), siteBooking.getAppUserId()));
userCoupon.setStatus(1);
userCouponClient.updateUserCoupon(userCoupon);
}
@@ -699,7 +747,7 @@
backRecordService.save(tBackRecord);
}
- if(siteBooking.getPayType() == 3){//玩湃币
+ if (siteBooking.getPayType() == 3) {//玩湃币
AppUser appUser = appUserClient.queryAppUser(siteBooking.getAppUserId());
appUser.setPlayPaiCoins(appUser.getPlayPaiCoins() + siteBooking.getPayMoney().intValue());
appUserClient.updateAppUser(appUser);
@@ -708,8 +756,8 @@
siteBooking.setCancelUserId(uid);
siteBooking.setCancelTime(new Date());
siteBookingService.updateById(siteBooking);
- if(null != siteBooking.getUserCouponId()){
- UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(),appUser.getId()));
+ if (null != siteBooking.getUserCouponId() && siteBooking.getUserCouponId() != 0) {
+ UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(), appUser.getId()));
userCoupon.setStatus(1);
userCouponClient.updateUserCoupon(userCoupon);
}
@@ -721,6 +769,7 @@
/**
* 继续支付我预约的场地
+ *
* @param id
* @param payType
* @return
@@ -729,39 +778,45 @@
@Override
public ResultUtil continuePaymentMySite(Integer uid, Integer id, Integer payType) throws Exception {
SiteBooking siteBooking = siteBookingService.getById(id);
- if(siteBooking.getStatus() != 0){
+ if (siteBooking.getStatus() != 0) {
return ResultUtil.error("不能继续支付");
}
Site site = this.getById(siteBooking.getSiteId());
AppUser appUser = appUserClient.queryAppUser(uid);
String[] split = siteBooking.getTimes().split(";");
Double payMoney = 0D;
- if(payType == 3){
- payMoney = new BigDecimal(site.getPlayPaiCoin()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
- if(appUser.getPlayPaiCoins().compareTo(payMoney.intValue()) < 0){
+ if (payType == 3) {
+// payMoney = new BigDecimal(site.getPlayPaiCoin()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ if (appUser.getPlayPaiCoins().compareTo(payMoney.intValue()) < 0) {
return ResultUtil.error("玩湃币不足");
}
- }else{
- if(siteBooking.getIsHalf()==2){
+
+ if (siteBooking.getIsHalf() == 2) {
+ payMoney = new BigDecimal(site.getPlayPaiCoin()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ } else {
+ payMoney = new BigDecimal(site.getPlayPaiCoinOne()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ }
+ } else {
+ if (siteBooking.getIsHalf() == 2) {
payMoney = new BigDecimal(site.getCashPrice()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
- }else {
+ } else {
payMoney = new BigDecimal(site.getCashPriceOne()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
}
}
//校验优惠券
Long couponId = siteBooking.getUserCouponId();
- if(null != couponId && payType != 3){
- UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(),appUser.getId()));
+ if (null != couponId && payType != 3) {
+ UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(), appUser.getId()));
Coupon coupon = couponClient.queryCouponById(userCoupon.getCouponId());
- if(coupon.getType() == 1){//满减
+ if (coupon.getType() == 1) {//满减
// {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
JSONObject jsonObject = JSON.parseObject(coupon.getContent());
Double num1 = jsonObject.getDouble("conditionalAmount");
Double num2 = jsonObject.getDouble("deductionAmount");
payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num2)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
}
- if(coupon.getType() == 2){//代金券
+ if (coupon.getType() == 2) {//代金券
JSONObject jsonObject = JSON.parseObject(coupon.getContent());
Double num1 = jsonObject.getDouble("conditionalAmount");
payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num1)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
@@ -769,8 +824,8 @@
userCoupon.setStatus(2);
userCouponClient.updateUserCoupon(userCoupon);
}
- if(null != couponId && payType == 3){
- UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(),appUser.getId()));
+ if (null != couponId && payType == 3) {
+ UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(), appUser.getId()));
userCoupon.setStatus(1);
userCouponClient.updateUserCoupon(userCoupon);
}
@@ -779,17 +834,17 @@
siteBooking.setOrderNo(sdf.format(new Date()) + UUIDUtil.getNumberRandom(3));
siteBooking.setPayType(payType);
siteBooking.setPayMoney(payMoney);
- if(payType == 3){
+ if (payType == 3) {
siteBooking.setUserCouponId(null);
}
siteBookingService.updateById(siteBooking);
- if(payType == 1){//微信支付
+ if (payType == 1) {//微信支付
return weChatPaymentSite(payMoney, siteBooking);
}
- if(payType == 2){//支付宝支付
+ if (payType == 2) {//支付宝支付
return aliPaymentSite(payMoney, siteBooking);
}
- if(payType == 3){//玩湃币支付
+ if (payType == 3) {//玩湃币支付
return playPaiCoinPaymentSite(appUser, payMoney, siteBooking);
}
return ResultUtil.success();
@@ -798,6 +853,7 @@
/**
* 获取继续支付金额
+ *
* @param id
* @return
* @throws Exception
@@ -805,29 +861,43 @@
@Override
public ResultUtil<Map<String, Double>> queryContinuePaymentMySitePrice(Integer id) throws Exception {
SiteBooking siteBooking = siteBookingService.getById(id);
- if(siteBooking.getStatus() != 0){
+ if (siteBooking.getStatus() != 0) {
return ResultUtil.error("不能继续支付");
}
Site site = this.getById(siteBooking.getSiteId());
String[] split = siteBooking.getTimes().split(";");
Map<String, Double> map = new HashMap<>();
Double payMoney = new BigDecimal(site.getPlayPaiCoin()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+
+
+ if (siteBooking.getIsHalf() == 2) {
+ payMoney = new BigDecimal(site.getPlayPaiCoin()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ } else {
+ payMoney = new BigDecimal(site.getPlayPaiCoinOne()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ }
+
map.put("playPaiCoin", payMoney);
payMoney = new BigDecimal(site.getCashPrice()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ if (siteBooking.getIsHalf() == 2) {
+ payMoney = new BigDecimal(site.getCashPrice()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ } else {
+ payMoney = new BigDecimal(site.getCashPriceOne()).multiply(new BigDecimal(split.length)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+ }
+
//校验优惠券
Long couponId = siteBooking.getUserCouponId();
- if(null != couponId){
- UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(),siteBooking.getAppUserId()));
+ if (null != couponId && couponId != 0) {
+ UserCoupon userCoupon = userCouponClient.queryUserCouponById(new QueryUserCouponByIdAndUserId(siteBooking.getUserCouponId(), siteBooking.getAppUserId()));
Coupon coupon = couponClient.queryCouponById(userCoupon.getCouponId());
- if(coupon.getType() == 1){//满减
+ if (coupon.getType() == 1) {//满减
// {"conditionalAmount":50,"deductionAmount":10,"experienceName":""}
JSONObject jsonObject = JSON.parseObject(coupon.getContent());
Double num1 = jsonObject.getDouble("conditionalAmount");
Double num2 = jsonObject.getDouble("deductionAmount");
payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num2)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
}
- if(coupon.getType() == 2){//代金券
+ if (coupon.getType() == 2) {//代金券
JSONObject jsonObject = JSON.parseObject(coupon.getContent());
Double num1 = jsonObject.getDouble("conditionalAmount");
payMoney = new BigDecimal(payMoney).subtract(new BigDecimal(num1)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
@@ -842,7 +912,12 @@
List<Integer> siteIds = vo.getSiteIds();
Integer type = vo.getType();
- return siteMapper.changeState(siteIds,type);
+ return siteMapper.changeState(siteIds, type);
}
+
+ @Override
+ public String getSMIDByOperatorId(Integer id) {
+ return siteMapper.getSMIDByOperatorId(id);
+ }
}
--
Gitblit v1.7.1