From ac6a07af9baba0e0fc8d181aae904da679ae8f5a Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期四, 06 七月 2023 10:04:07 +0800
Subject: [PATCH] 更新部分功能接口

---
 cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java |  112 ++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 108 insertions(+), 4 deletions(-)

diff --git a/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java b/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java
index cade892..356f640 100644
--- a/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java
+++ b/cloud-server-course/src/main/java/com/dsh/course/service/impl/TCoursePackageServiceImpl.java
@@ -8,10 +8,15 @@
 import com.dsh.course.entity.CoursePackagePaymentConfig;
 import com.dsh.course.entity.TCoursePackage;
 import com.dsh.course.entity.TCoursePackageDiscount;
+import com.dsh.course.entity.TCoursePackagePayment;
 import com.dsh.course.feignclient.account.AppUserClient;
 import com.dsh.course.feignclient.account.StudentClient;
 import com.dsh.course.feignclient.account.model.AppUser;
 import com.dsh.course.feignclient.account.model.Student;
+import com.dsh.course.feignclient.activity.CouponClient;
+import com.dsh.course.feignclient.activity.UserCouponClient;
+import com.dsh.course.feignclient.activity.model.Coupon;
+import com.dsh.course.feignclient.activity.model.UserCoupon;
 import com.dsh.course.feignclient.other.StoreClient;
 import com.dsh.course.feignclient.other.model.Store;
 import com.dsh.course.mapper.TCoursePackageMapper;
@@ -23,6 +28,7 @@
 import com.dsh.course.service.TCoursePackageService;
 import com.dsh.course.util.GDMapGeocodingUtil;
 import com.dsh.course.util.GeodesyUtil;
+import com.dsh.course.util.ResultUtil;
 import com.dsh.course.util.ToolUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -65,6 +71,12 @@
 
     @Resource
     private StudentClient studentClient;
+
+    @Resource
+    private UserCouponClient userCouponClient;
+
+    @Resource
+    private CouponClient couponClient;
 
 
 
@@ -273,9 +285,11 @@
         coursePackageInfo.setStoreAddress(store.getAddress());
         coursePackageInfo.setLon(store.getLon());
         coursePackageInfo.setLat(store.getLat());
-        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();
-        coursePackageInfo.setDistance(wgs84);
+        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();
+            coursePackageInfo.setDistance(wgs84);
+        }
 
         String[] split = coursePackage.getClassWeeks().split(";");
         coursePackageInfo.setWeeks(Arrays.asList(split));
@@ -290,7 +304,7 @@
             coursePackagePaymentConfigVo.setClassHours(coursePackagePaymentConfig.getClassHours());
             coursePackagePaymentConfigVo.setPayType(coursePackage.getPayType());
             coursePackagePaymentConfigVo.setPlayPaiCoin(coursePackagePaymentConfig.getPlayPaiCoin());
-            //会员显示原价和会员价(最低)。非会员显示会员价和支付价(最低)
+            //会员显示原价和支付价(会员价)。非会员显示会员价和支付价(最低)
             if(appUser.getIsVip() == 0){//非会员
                 List<TCoursePackageDiscount> list2 = coursePackageDiscountService.list(new QueryWrapper<TCoursePackageDiscount>().eq("coursePackagePaymentConfigId", coursePackagePaymentConfig.getId())
                         .eq("type", 1).eq("auditStatus", 2));
@@ -406,4 +420,94 @@
         coursePackageInfo.setStudent(studentVo);
         return coursePackageInfo;
     }
+
+
+    /**
+     * 课程包名支付
+     * @param uid
+     * @param paymentCourseVo
+     * @return
+     * @throws Exception
+     */
+    @Override
+    public ResultUtil paymentCourse(Integer uid, PaymentCourseVo paymentCourseVo) throws Exception {
+        AppUser appUser = appUserClient.queryAppUser(uid);
+        CoursePackageInfo coursePackageInfo = queryCourseInfo(uid, paymentCourseVo.getId(), null, null);
+        List<CoursePackagePaymentConfigVo> list = coursePackageInfo.getList();
+
+        String[] students = paymentCourseVo.getStudentIds().split(";");
+        for (CoursePackagePaymentConfigVo coursePackagePaymentConfigVo : list) {
+            if(paymentCourseVo.getCoursePackagePaymentConfigId().compareTo(coursePackagePaymentConfigVo.getId()) == 0){
+                Integer payType = coursePackagePaymentConfigVo.getPayType();
+                if(payType == 1 && paymentCourseVo.getPayType() == 3){//现金支付
+                    return ResultUtil.error("支付方式错误,请刷新后重试");
+                }
+                if(payType == 2 && paymentCourseVo.getPayType() != 3){//玩湃币支付
+                    return ResultUtil.error("支付方式错误,请刷新后重试");
+                }
+                Double paymentPrice = coursePackagePaymentConfigVo.getPaymentPrice();//支付价
+                paymentPrice = new BigDecimal(students.length).multiply(new BigDecimal(paymentPrice)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+                Double playPaiCoin = coursePackagePaymentConfigVo.getPlayPaiCoin().doubleValue();//支付币
+                playPaiCoin = new BigDecimal(students.length).multiply(new BigDecimal(playPaiCoin)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+                if(payType == 1 && paymentPrice.compareTo(paymentCourseVo.getPrice()) != 0){
+                    return ResultUtil.error("支付金额异常,请刷新后重试");
+                }
+                if(payType == 2 && playPaiCoin.compareTo(paymentCourseVo.getPrice()) != 0){
+                    return ResultUtil.error("支付金额异常,请刷新后重试");
+                }
+            }
+        }
+
+        Double price = paymentCourseVo.getPrice();//支付金额
+
+        //校验优惠券
+        Long couponId = paymentCourseVo.getCouponId();
+        if(null != couponId && paymentCourseVo.getPayType() != 3){
+            UserCoupon userCoupon = userCouponClient.queryUserCouponById(couponId);
+            if(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(coupon.getType() == 1){//满减
+                JSONObject jsonObject = JSON.parseObject(coupon.getContent());
+                Double num1 = jsonObject.getDouble("num1");
+                Double num2 = jsonObject.getDouble("num2");
+                if(price.compareTo(num1) <= 0){
+                    return ResultUtil.error("该优惠券无法使用");
+                }
+
+                price = new BigDecimal(price).subtract(new BigDecimal(num2)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+            }
+            if(coupon.getType() == 2){//代金券
+                JSONObject jsonObject = JSON.parseObject(coupon.getContent());
+                Double num1 = jsonObject.getDouble("num1");
+                if(price.compareTo(num1) <= 0){
+                    return ResultUtil.error("该优惠券无法使用");
+                }
+                price = new BigDecimal(price).subtract(new BigDecimal(num1)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+            }
+        }
+
+        if(paymentCourseVo.getPayType() == 1){//微信支付
+
+        }
+        if(paymentCourseVo.getPayType() == 2){//支付宝支付
+
+        }
+        if(paymentCourseVo.getPayType() == 3){//玩湃币支付
+
+        }
+        return null;
+    }
+
+
+    public ResultUtil weChatPaymentCourse(Integer uid, PaymentCourseVo paymentCourseVo){
+        TCoursePackagePayment coursePackagePayment = new TCoursePackagePayment();
+//        coursePackagePayment
+        return ResultUtil.success();
+    }
 }

--
Gitblit v1.7.1