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-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java |   70 +++++++++++++++++++++++++++++++++++
 1 files changed, 70 insertions(+), 0 deletions(-)

diff --git a/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java b/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java
index d646a5b..c8441cd 100644
--- a/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java
+++ b/cloud-server-activity/src/main/java/com/dsh/activity/service/impl/UserCouponServiceImpl.java
@@ -1,10 +1,23 @@
 package com.dsh.activity.service.impl;
 
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.dsh.activity.entity.UserCoupon;
+import com.dsh.activity.feignclient.course.CoursePackageClient;
+import com.dsh.activity.feignclient.course.model.CoursePackage;
 import com.dsh.activity.mapper.UserCouponMapper;
+import com.dsh.activity.model.CouponListVo;
 import com.dsh.activity.service.UserCouponService;
+import com.dsh.activity.util.GDMapGeocodingUtil;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+
+import javax.annotation.Resource;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Map;
 
 /**
  * <p>
@@ -17,4 +30,61 @@
 @Service
 public class UserCouponServiceImpl extends ServiceImpl<UserCouponMapper, UserCoupon> implements UserCouponService {
 
+    @Resource
+    private CoursePackageClient coursePackageClient;
+
+    @Autowired
+    private GDMapGeocodingUtil gdMapGeocodingUtil;
+
+
+    /**
+     * 获取购买课程可用优惠券列表
+     * @param uid
+     * @param coursePackageId
+     * @return
+     */
+    @Override
+    public List<CouponListVo> queryAvailableCouponList(Integer uid, Integer coursePackageId, Double price, String lon, String lat) throws Exception {
+        CoursePackage coursePackage = coursePackageClient.queryCoursePackageById(coursePackageId);
+        Integer storeId = coursePackage.getStoreId();
+        Map<String, String> geocode = gdMapGeocodingUtil.geocode(lon, lat);
+        String provinceCode = geocode.get("provinceCode");
+        String cityCode = geocode.get("cityCode");
+        List<Map<String, Object>> userCoupons = this.baseMapper.queryAvailableCouponList(uid, storeId, provinceCode, cityCode);
+        List<CouponListVo> listVos = new ArrayList<>();
+        for (Map<String, Object> userCoupon : userCoupons) {
+            Integer type = Integer.valueOf(userCoupon.get("type").toString());
+            CouponListVo couponListVo = new CouponListVo();
+            couponListVo.setId(Long.valueOf(userCoupon.get("id").toString()));
+            couponListVo.setName(userCoupon.get("name").toString());
+            couponListVo.setType(type);
+            couponListVo.setEffectiveTime(userCoupon.get("endTime").toString());
+            String content = userCoupon.get("content").toString();
+            if (type == 1) {//满减{"num1":1,"num2":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                Double num1 = jsonObject.getDouble("num1");
+                if(price.compareTo(num1) <= 0){
+                    continue;
+                }
+                couponListVo.setUseCondition("满" + num1 + "元可用");
+                couponListVo.setFavorable(jsonObject.getDouble("num2") + "元");
+            }
+            if (type == 2) {//代金券{"num1":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                Double num1 = jsonObject.getDouble("num1");
+                if(price.compareTo(num1) <= 0){
+                    continue;
+                }
+                couponListVo.setUseCondition("");
+                couponListVo.setFavorable(num1 + "元");
+            }
+            if (type == 3) {//体验券{"num1":1}
+                JSONObject jsonObject = JSON.parseObject(content);
+                couponListVo.setUseCondition("");
+                couponListVo.setFavorable(jsonObject.getString("num1"));
+            }
+            listVos.add(couponListVo);
+        }
+        return listVos;
+    }
 }

--
Gitblit v1.7.1