From 78676e7c2e4e06080a45fb6802bd32fd931cead3 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期五, 23 八月 2024 10:36:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/AppUserInfoDto.java                            |    3 
 ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/AppGoodQuery.java                           |   11 +
 ruoyi-service/ruoyi-payment/src/main/java/com/ruoyi/payment/wx/controller/WxPayController.java                     |   10 +
 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/InfoCouponDto.java                             |    7 +
 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/util/PointDetailUtil.java                              |    2 
 ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/factory/OrderFallbackFactory.java                      |    5 
 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/UserChangeDto.java                             |    1 
 ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TApplyChargingPile.java            |    1 
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/TGoodsController.java                           |   33 ++++-
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java                   |    2 
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/TGoodsService.java                                 |    3 
 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java                     |   28 +++-
 ruoyi-service/ruoyi-chargingPile/src/main/resources/template/充电桩申请记录.xlsx                                          |    0 
 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/AppUserClient.java                     |    4 
 ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/feignClient/OrderClient.java                           |    2 
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/mapper/TGoodsMapper.java                                   |    3 
 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppUser.java                                |    5 
 ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/ExchangeDto.java                            |    7 +
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/dto/TApplyChargingPileExportDto.java         |   12 +
 ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/dto/ApplyChargingQuery.java              |    2 
 ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/PointChangeDto.java                         |   11 +
 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/AppUserFallbackFactory.java                |    8 +
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TApplyChargingPileController.java |  102 +++++++++++++++--
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TShoppingOrderController.java                   |   48 ++++++++
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/TGoodsServiceImpl.java                        |    5 
 ruoyi-service/ruoyi-other/src/main/resources/mapper/other/TGoodsMapper.xml                                         |   23 ++-
 26 files changed, 298 insertions(+), 40 deletions(-)

diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/AppUserInfoDto.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/AppUserInfoDto.java
index 28613f6..3a02097 100644
--- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/AppUserInfoDto.java
+++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/AppUserInfoDto.java
@@ -5,6 +5,7 @@
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
 
+import java.math.BigDecimal;
 import java.time.LocalDateTime;
 import java.util.List;
 
@@ -12,6 +13,8 @@
 public class AppUserInfoDto {
     @ApiModelProperty("1是0否")
     private Integer isVip;
+    @ApiModelProperty("最低会员价格")
+    private BigDecimal minPrice;
     @ApiModelProperty("vip结束时间")
     private LocalDateTime vipExpireTime;
     @ApiModelProperty("当天是否签到")
diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/InfoCouponDto.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/InfoCouponDto.java
index 1af4b89..d3bff84 100644
--- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/InfoCouponDto.java
+++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/InfoCouponDto.java
@@ -1,6 +1,8 @@
 package com.ruoyi.account.api.dto;
 
+import com.baomidou.mybatisplus.annotation.IdType;
 import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
 
@@ -9,9 +11,14 @@
 
 @Data
 public class InfoCouponDto {
+
+    @ApiModelProperty(value = "主键")
+    @TableId(value = "id", type = IdType.AUTO)
+    private Long id;
     @ApiModelProperty(value = "优惠券名称")
     @TableField("name")
     private String name;
+    private Integer type;
     @ApiModelProperty(value = "优惠方式(1=满减,2=抵扣)")
     @TableField("preferential_mode")
     private Integer preferentialMode;
diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/UserChangeDto.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/UserChangeDto.java
index ab157d7..8ac5947 100644
--- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/UserChangeDto.java
+++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/dto/UserChangeDto.java
@@ -8,4 +8,5 @@
     private Long userId;
     @ApiModelProperty("1=正常,2=冻结")
     private Integer status;
+    private String remark;
 }
diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/AppUserFallbackFactory.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/AppUserFallbackFactory.java
index b811b76..20f36a2 100644
--- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/AppUserFallbackFactory.java
+++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/AppUserFallbackFactory.java
@@ -3,6 +3,7 @@
 import com.ruoyi.account.api.feignClient.AppUserClient;
 import com.ruoyi.account.api.model.TAppUser;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.dto.PointChangeDto;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.cloud.openfeign.FallbackFactory;
@@ -41,8 +42,13 @@
             }
 
             @Override
+            public R change(PointChangeDto points) {
+                return null;
+            }
+
+            @Override
             public R<TAppUser> selectByPhone(String phone) {
-                return R.fail("通过手机号查询用户失败:"+throwable.getMessage());
+                return R.fail("积分变化失败:"+throwable.getMessage());
             }
 
             @Override
diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/AppUserClient.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/AppUserClient.java
index a408ac7..ea7adc9 100644
--- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/AppUserClient.java
+++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/AppUserClient.java
@@ -4,6 +4,7 @@
 import com.ruoyi.common.core.constant.ServiceNameConstants;
 import com.ruoyi.account.api.factory.AppUserFallbackFactory;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.dto.PointChangeDto;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.cloud.openfeign.FeignClient;
 import org.springframework.web.bind.annotation.*;
@@ -42,6 +43,9 @@
     @PostMapping("/t-app-user/user/updateAppUser")
     R updateAppUser(@RequestBody TAppUser appUser);
 
+    @PostMapping("/t-app-user/user/points/change")
+    R change(@RequestBody PointChangeDto points);
+
     /**
      * 通过手机号查询用户
      * @param phone
diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppUser.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppUser.java
index 0cfdd15..2009d1c 100644
--- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppUser.java
+++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/TAppUser.java
@@ -95,6 +95,11 @@
     @TableField("city_code")
     private String cityCode;
 
+
+    @ApiModelProperty(value = "备注")
+    @TableField("remark")
+    private String remark;
+
     @ApiModelProperty(value = "状态(1=正常,2=冻结,3=注销)")
     @TableField("status")
     private Integer status;
diff --git a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/dto/ApplyChargingQuery.java b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/dto/ApplyChargingQuery.java
index 7559f8c..770669f 100644
--- a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/dto/ApplyChargingQuery.java
+++ b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/dto/ApplyChargingQuery.java
@@ -5,5 +5,5 @@
 
 @Data
 public class ApplyChargingQuery extends BasePage {
-    String name;
+    String landlordPhone;
 }
diff --git a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TApplyChargingPile.java b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TApplyChargingPile.java
index 86bd0fc..e9bd6a5 100644
--- a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TApplyChargingPile.java
+++ b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/model/TApplyChargingPile.java
@@ -56,6 +56,7 @@
     @TableField("landlord_handling")
     private Integer landlordHandling;
 
+
     @ApiModelProperty(value = "户名")
     @TableField("landlord_name")
     private String landlordName;
diff --git a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/factory/OrderFallbackFactory.java b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/factory/OrderFallbackFactory.java
index 8f689c3..e0dc45f 100644
--- a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/factory/OrderFallbackFactory.java
+++ b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/factory/OrderFallbackFactory.java
@@ -49,6 +49,11 @@
                 return R.fail("创建订单" + cause.getMessage());
             }
 
+            @Override
+            public R<Long> shopCreate(ExchangeDto exchangeDto) {
+                return R.fail("订单创建" + cause.getMessage());
+            }
+
 
             @Override
             public R<TActivityVO> activityStatistics(TActivityStatisticsQuery dto) {
diff --git a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/feignClient/OrderClient.java b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/feignClient/OrderClient.java
index 23c8fc9..6e60d80 100644
--- a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/feignClient/OrderClient.java
+++ b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/feignClient/OrderClient.java
@@ -34,6 +34,8 @@
 
     @PostMapping("/t-exchange-order/create")
     public R<Long> exchangeCreate(@RequestBody ExchangeDto exchangeDto);
+    @PostMapping("/t-shopping-order/create")
+    public R<Long> shopCreate(@RequestBody ExchangeDto exchangeDto);
 
     /**
      * 管理后台 活动费用统计
diff --git a/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/AppGoodQuery.java b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/AppGoodQuery.java
new file mode 100644
index 0000000..0a3188d
--- /dev/null
+++ b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/AppGoodQuery.java
@@ -0,0 +1,11 @@
+package com.ruoyi.common.core.dto;
+
+import com.ruoyi.common.core.web.page.BasePage;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+public class AppGoodQuery extends BasePage {
+    @ApiModelProperty("1=购买商品,2=兑换商品")
+    private Integer type;
+}
diff --git a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/dto/ExchangeDto.java b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/ExchangeDto.java
similarity index 72%
rename from ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/dto/ExchangeDto.java
rename to ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/ExchangeDto.java
index d0d3c50..29456ee 100644
--- a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/dto/ExchangeDto.java
+++ b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/ExchangeDto.java
@@ -18,6 +18,13 @@
     Integer goodType;
     @ApiModelProperty(hidden = true)
     Integer point;
+    @ApiModelProperty("购买数量")
+    Integer num;
+    @ApiModelProperty("优惠卷id")
+    Long couponId;
+
+    @ApiModelProperty("1微信2支付宝")
+    Integer payMethod;
 
 
 }
diff --git a/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/PointChangeDto.java b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/PointChangeDto.java
new file mode 100644
index 0000000..4a6d0fb
--- /dev/null
+++ b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/dto/PointChangeDto.java
@@ -0,0 +1,11 @@
+package com.ruoyi.common.core.dto;
+
+import lombok.Data;
+import org.springframework.web.bind.annotation.RequestParam;
+@Data
+public class PointChangeDto {
+    private Long userId;
+    private Integer points;
+    private String remark;
+    private Integer type;
+}
diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java
index 7cfd4cf..b74dc0c 100644
--- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java
+++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/TAppUserController.java
@@ -15,6 +15,7 @@
 import com.ruoyi.account.util.GiveVipUtil;
 import com.ruoyi.common.core.constant.Constants;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.dto.PointChangeDto;
 import com.ruoyi.common.core.enums.status.AppUserStatusEnum;
 import com.ruoyi.common.core.utils.JwtUtils;
 import com.ruoyi.common.core.utils.StringUtils;
@@ -29,13 +30,11 @@
 import com.ruoyi.order.api.feignClient.ExchangeOrderClient;
 import com.ruoyi.order.api.model.TChargingOrder;
 import com.ruoyi.order.api.model.TExchangeOrder;
+import com.ruoyi.other.api.domain.*;
 import com.ruoyi.other.api.dto.UnitListQueryDto;
-import com.ruoyi.other.api.domain.TCompany;
-import com.ruoyi.other.api.domain.TCoupon;
-import com.ruoyi.other.api.domain.TIntegralRule;
-import com.ruoyi.other.api.domain.TUserTag;
 import com.ruoyi.other.api.feignClient.IntegralRuleClient;
 import com.ruoyi.other.api.feignClient.OtherClient;
+import com.ruoyi.other.api.feignClient.VipClient;
 import com.ruoyi.system.api.model.LoginUserApplet;
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
@@ -106,6 +105,9 @@
     private TAppUserCarService carService;
     @Resource
     private IntegralRuleClient integralRuleClient;
+
+    @Resource
+    private VipClient vipClient;
 
 
 
@@ -435,6 +437,7 @@
     public R pointsDetail(@RequestBody UserChangeDto userChangeDto) {
         TAppUser appUser = appUserService.getById(userChangeDto.getUserId());
         appUser.setStatus(userChangeDto.getStatus());
+        appUser.setRemark(userChangeDto.getRemark());
         appUserService.updateById(appUser);
         return R.ok();
     }
@@ -467,6 +470,8 @@
         Long userId = tokenService.getLoginUserApplet().getUserId();
         TAppUser byId = appUserService.getById(userId);
         AppUserInfoDto appUserInfoDto = new AppUserInfoDto();
+        TVip data = vipClient.getVipInfoByType(2).getData();
+        appUserInfoDto.setMinPrice(data.getMonthlyCard());
 
         //判断会员
         if (byId.getVipEndTime()==null||byId.getVipEndTime().isBefore(LocalDateTime.now())){
@@ -500,6 +505,7 @@
             TCoupon coupon = JSON.toJavaObject(JSON.parseObject(tAppCoupon.getCouponJson()), TCoupon.class);
             InfoCouponDto infoCouponDto = new InfoCouponDto();
             BeanUtils.copyProperties(coupon,infoCouponDto);
+            infoCouponDto.setId(tAppCoupon.getId());
             couponDtos.add(infoCouponDto);
 
         }
@@ -620,7 +626,7 @@
     }
 
     @ApiOperation(value = "签到", tags = {"小程序-个人中心-签到"})
-    @PostMapping(value = "/user/sign")
+    @GetMapping(value = "/user/sign")
     public R sign() {
         LoginUserApplet loginUserApplet = tokenService.getLoginUserApplet();
         Long userId = loginUserApplet.getUserId();
@@ -664,13 +670,23 @@
                 signService.updateById(appUserSign);
             }
         }
-        pointDetailUtil.addDetail(byId.getPoints(),byId.getPoints()+points,1,userId,"每日签到","");
+        pointDetailUtil.addDetail(byId.getPoints(),byId.getPoints()+points,1,userId,"每日签到","JF");
         byId.setPoints(byId.getPoints()+points);
         appUserService.updateById(byId);
         return R.ok();
     }
 
 
+    //积分变化记录用
+    @PostMapping(value = "/user/points/change")
+    public R change(@RequestBody PointChangeDto points) {
+        TAppUser byId = appUserService.getById(points.getUserId());
+        pointDetailUtil.addDetail(byId.getPoints(),byId.getPoints()+points.getPoints(),points.getType(),points.getUserId(),points.getRemark(),"JF");
+        byId.setPoints(byId.getPoints()+points.getPoints());
+        appUserService.updateById(byId);
+        return R.ok();
+    }
+
     @ApiOperation(value = "添加编辑车辆", tags = {"小程序-个人中心-车辆"})
     @PostMapping(value = "/user/car/addOrUpdate")
     public R carAdd(@RequestBody TAppUserCar appUserCar) {
diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/util/PointDetailUtil.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/util/PointDetailUtil.java
index bb183a1..4b935ac 100644
--- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/util/PointDetailUtil.java
+++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/util/PointDetailUtil.java
@@ -15,7 +15,7 @@
     public void addDetail(Integer old,Integer now,Integer type,Long userId,String extension,String code){
 
         TAppUserIntegralChange tAppUserIntegralChange= new TAppUserIntegralChange();
-        tAppUserIntegralChange.setCode(OrderCodeUtil.getOrderCode("DH"));
+        tAppUserIntegralChange.setCode(OrderCodeUtil.getOrderCode(code));
         tAppUserIntegralChange.setAppUserId(userId);
         tAppUserIntegralChange.setChangeType(type);
         tAppUserIntegralChange.setHistoricalIntegral(old);
diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TApplyChargingPileController.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TApplyChargingPileController.java
index fc6ee66..376534d 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TApplyChargingPileController.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TApplyChargingPileController.java
@@ -5,6 +5,9 @@
 import com.alibaba.excel.ExcelWriter;
 import com.alibaba.excel.write.builder.ExcelWriterBuilder;
 import com.alibaba.excel.write.metadata.WriteSheet;
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ruoyi.chargingPile.api.dto.ApplyChargingQuery;
 import com.ruoyi.chargingPile.api.dto.ApplyChargingRemarkDto;
@@ -32,6 +35,7 @@
 import java.net.URLEncoder;
 import java.util.ArrayList;
 import java.util.List;
+import java.util.regex.Pattern;
 
 /**
  * <p>
@@ -79,7 +83,7 @@
     @PostMapping(value = "/page")
     public AjaxResult<Page<TApplyChargingPile>> page(ApplyChargingQuery applyChargingQuery) {
         Page<TApplyChargingPile> page = applyChargingPileService.lambdaQuery()
-                .like(applyChargingQuery.getName() != null && !applyChargingQuery.getName().equals(""), TApplyChargingPile::getAgentPhone, applyChargingQuery.getName())
+                .like(applyChargingQuery.getLandlordPhone() != null && !applyChargingQuery.getLandlordPhone().equals(""), TApplyChargingPile::getLandlordPhone, applyChargingQuery.getLandlordPhone())
                 .page(Page.of(applyChargingQuery.getPageCurr(), applyChargingQuery.getPageSize()));
         return AjaxResult.ok(page);
     }
@@ -87,7 +91,7 @@
 
     @ApiOperation(tags = {"后台-申请表单-申请建桩"},value = "导出")
     @PutMapping(value = "/export")
-    public R export(HttpServletResponse response) {
+    public R export(String landlordPhone,HttpServletResponse response) {
         try {
         response.setCharacterEncoding(Constants.UTF8);
         response.setContentType("application/vnd.ms-excel");
@@ -98,21 +102,87 @@
             return R.fail("excel导出失败!");
         }
         try {
-            List<TApplyChargingPile> list = applyChargingPileService.lambdaQuery().last("limit 1").list();
+            List<TApplyChargingPile> list = applyChargingPileService.lambdaQuery().like(landlordPhone != null && !landlordPhone.equals(""), TApplyChargingPile::getLandlordPhone, landlordPhone).list();
 
             List<TApplyChargingPileExportDto> exportDtos =new ArrayList<>();
             for (TApplyChargingPile tApplyChargingPile : list) {
                 TApplyChargingPileExportDto applyChargingPileExportDto = new TApplyChargingPileExportDto();
                 BeanUtils.copyProperties(tApplyChargingPile,applyChargingPileExportDto);
-                applyChargingPileExportDto.setLandlordFrontIdCard(new URL(tApplyChargingPile.getLandlordFrontIdCard()));
-                applyChargingPileExportDto.setLandlordBackIdCard(new URL(tApplyChargingPile.getLandlordBackIdCard()));
-                applyChargingPileExportDto.setAgentBackIdCard(new URL(tApplyChargingPile.getAgentBackIdCard()));
-                applyChargingPileExportDto.setAgentFrontIdCard(new URL(tApplyChargingPile.getAgentFrontIdCard()));
-                List<URL> urls = new ArrayList<>();
-                urls.add(new URL("https://img-blog.csdnimg.cn/direct/c11088e1790049a5b84a0fda21a271b1.png"));
-                urls.add(new URL("https://img-blog.csdnimg.cn/direct/c11088e1790049a5b84a0fda21a271b1.png"));
-                urls.add(new URL("https://img-blog.csdnimg.cn/direct/c11088e1790049a5b84a0fda21a271b1.png"));
-                        applyChargingPileExportDto.setUrls(urls);
+                JSONArray p1 = JSON.parseArray(tApplyChargingPile.getLandlordFrontIdCard());
+                if (!p1.isEmpty()) {
+                    applyChargingPileExportDto.setLandlordFrontIdCard(new URL((String) p1.get(0)));
+                }
+                JSONArray p2 = JSON.parseArray(tApplyChargingPile.getLandlordBackIdCard());
+                if (!p2.isEmpty()){
+                applyChargingPileExportDto.setLandlordBackIdCard(new URL((String)p2.get(0)));}
+                JSONArray p3 = JSON.parseArray(tApplyChargingPile.getAgentBackIdCard());
+                if (!p3.isEmpty())
+                applyChargingPileExportDto.setAgentBackIdCard(new URL((String)p3.get(0)));
+                JSONArray p4 = JSON.parseArray(tApplyChargingPile.getAgentFrontIdCard());
+                if (!p4.isEmpty()) {
+                    applyChargingPileExportDto.setAgentFrontIdCard(new URL((String)p4.get(0)));
+                }
+
+                if (tApplyChargingPile.getChargingPileUser()==1){
+                    JSONArray pics1 = JSON.parseArray(tApplyChargingPile.getFixedParkingPropertyRights());
+                    if (!pics1.isEmpty()) {
+                        applyChargingPileExportDto.setPics1(new URL((String)pics1.get(0)));
+                    }
+                    JSONArray pics2 = JSON.parseArray(tApplyChargingPile.getConstructionCertificate());
+                    if (!pics1.isEmpty()) {
+                        applyChargingPileExportDto.setPics2(new URL((String)pics2.get(0)));
+                    }
+                }else {
+                    JSONArray pics1 = JSON.parseArray(tApplyChargingPile.getTitleCertificate());
+                    if (!pics1.isEmpty()) {
+                        applyChargingPileExportDto.setPics1(new URL((String)pics1.get(0)));
+                    }
+                    JSONArray pics2 = JSON.parseArray(tApplyChargingPile.getBusinessLicense());
+                    if (!pics1.isEmpty()) {
+                        applyChargingPileExportDto.setPics2(new URL((String)pics2.get(0)));
+                    }
+                }
+
+                JSONArray objects1 = JSON.parseArray(tApplyChargingPile.getFurtherInformation());
+                for (int i = 0; i < objects1.size(); i++) {
+                    JSONObject jsonObject = JSON.parseObject(objects1.get(i).toString());
+                    System.err.println("==================="+jsonObject.get("url"));
+
+                    boolean isImage = isImageUrl(jsonObject);
+                    if (!isImage){
+                        continue;
+                    }
+                    System.err.println("Is image: " + isImage);
+                    if (i==0){
+                        applyChargingPileExportDto.setUrl1(new URL((String)jsonObject.get("url")));
+                    }else if (i==1){
+                        applyChargingPileExportDto.setUrl2(new URL((String)jsonObject.get("url")));
+                    }else if (i==2){
+                        applyChargingPileExportDto.setUrl3(new URL((String)jsonObject.get("url")));
+                    }else if (i==3){
+                        applyChargingPileExportDto.setUrl4(new URL((String)jsonObject.get("url")));
+                    }else if (i==4){
+                        applyChargingPileExportDto.setUrl5(new URL((String)jsonObject.get("url")));
+                    }else if (i==5){
+                        applyChargingPileExportDto.setUrl6(new URL((String)jsonObject.get("url")));
+                    }
+                }
+
+                if (tApplyChargingPile.getLandlordHandling()==1){
+                    applyChargingPileExportDto.setIs1("是");
+                }else {
+                    applyChargingPileExportDto.setIs1("否");
+                }
+                if (tApplyChargingPile.getChargingPileUser()==1){
+                    applyChargingPileExportDto.setIs2("是");
+                }else {
+                    applyChargingPileExportDto.setIs2("否");
+                }
+                if (tApplyChargingPile.getChargingPile()==1){
+                    applyChargingPileExportDto.setIs3("是");
+                }else {
+                    applyChargingPileExportDto.setIs3("否");
+                }
                 exportDtos.add(applyChargingPileExportDto);
 
             }
@@ -134,6 +204,14 @@
         return R.ok();
     }
 
+    public static boolean isImageUrl(JSONObject jsonObject) {
+        String url = jsonObject.getString("url");
+        Pattern pattern = Pattern.compile(
+                "^.*\\.(?i)(jpg|jpeg|png|gif|bmp|webp)$"
+        );
+        return pattern.matcher(url).matches();
+    }
+
     @ApiOperation(tags = {"后台-申请表单-申请建桩"},value = "详情")
     @PostMapping(value = "/detail/{id}")
     public AjaxResult<TApplyChargingPile> detail(@PathVariable Integer id) {
diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/dto/TApplyChargingPileExportDto.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/dto/TApplyChargingPileExportDto.java
index 73df50f..8b642c9 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/dto/TApplyChargingPileExportDto.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/dto/TApplyChargingPileExportDto.java
@@ -109,5 +109,15 @@
     @ApiModelProperty(value = "备注")
     @TableField("remark")
     private String remark;
-    private List<URL> urls;
+    private URL pics1;
+    private URL pics2;
+    private URL url1;
+    private URL url2;
+    private URL url3;
+    private URL url4;
+    private URL url5;
+    private URL url6;
+    private String is1;
+    private String is2;
+    private String is3;
 }
diff --git "a/ruoyi-service/ruoyi-chargingPile/src/main/resources/template/\345\205\205\347\224\265\346\241\251\347\224\263\350\257\267\350\256\260\345\275\225.xlsx" "b/ruoyi-service/ruoyi-chargingPile/src/main/resources/template/\345\205\205\347\224\265\346\241\251\347\224\263\350\257\267\350\256\260\345\275\225.xlsx"
index 1456be1..fc621e2 100644
--- "a/ruoyi-service/ruoyi-chargingPile/src/main/resources/template/\345\205\205\347\224\265\346\241\251\347\224\263\350\257\267\350\256\260\345\275\225.xlsx"
+++ "b/ruoyi-service/ruoyi-chargingPile/src/main/resources/template/\345\205\205\347\224\265\346\241\251\347\224\263\350\257\267\350\256\260\345\275\225.xlsx"
Binary files differ
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java
index 92e56a0..1e5f04f 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TExchangeOrderController.java
@@ -183,7 +183,7 @@
         tExchangeOrder.setCreateTime(LocalDateTime.now());
         tExchangeOrder.setDelFlag(false);
         exchangeOrderService.save(tExchangeOrder);
-        return R.ok();
+        return R.ok(tExchangeOrder.getId());
 
     }
     
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TShoppingOrderController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TShoppingOrderController.java
index e853464..5b448ec 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TShoppingOrderController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TShoppingOrderController.java
@@ -1,6 +1,11 @@
 package com.ruoyi.order.controller;
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
 
 
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.dto.ExchangeDto;
+import com.ruoyi.common.core.utils.OrderCodeUtil;
 import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.order.api.model.TExchangeOrder;
 import com.ruoyi.order.api.model.TShoppingOrder;
@@ -82,5 +87,48 @@
 		List<MyShoppingOrderList> list = shoppingOrderService.getNoInvoicedOrder(query);
 		return AjaxResult.success(list);
 	}
+
+//	@PostMapping("/create")
+//	public R<Long> shopCreate(@RequestBody ExchangeDto exchangeDto){
+//		TShoppingOrder shoppingOrder = new TShoppingOrder();
+//		shoppingOrder.setCode(OrderCodeUtil.getOrderCode("GW"));
+//		shoppingOrder.setAppUserId(exchangeDto.getUserId());
+//		shoppingOrder.setOrderType(exchangeDto.getGoodType());
+//		if (exchangeDto.getGoodType()==1) {
+//			shoppingOrder.setGoodsId(exchangeDto.getGoodId());
+//		}else {
+//			shoppingOrder.setCouponId(exchangeDto.getGoodId());
+//		}
+//		shoppingOrder.setPurchaseQuantity(exchangeDto.getNum());
+//		shoppingOrder.setAppUserAddressId(Long.valueOf(exchangeDto.getAddressId()));
+//		shoppingOrder.setOrderAmount(new BigDecimal("0"));
+//		shoppingOrder.setAppCouponId(0L);
+//		shoppingOrder.setCouponDiscountAmount(new BigDecimal("0"));
+//		shoppingOrder.setVipDiscount(new BigDecimal("0"));
+//		shoppingOrder.setVipDiscountAmount(new BigDecimal("0"));
+//		shoppingOrder.setPaymentAmount(new BigDecimal("0"));
+//		shoppingOrder.setPaymentStatus(0);
+//		shoppingOrder.setPaymentType(0);
+//		shoppingOrder.setSerialNumber("");
+//		shoppingOrder.setRemark("");
+//		shoppingOrder.setStatus(0);
+//		shoppingOrder.setExpressCompany("");
+//		shoppingOrder.setExpressNumber("");
+//		shoppingOrder.setConsignerId(0);
+//		shoppingOrder.setConsignerTime(LocalDateTime.now());
+//		shoppingOrder.setReceivingTime(LocalDateTime.now());
+//		shoppingOrder.setCancellationTime(LocalDateTime.now());
+//		shoppingOrder.setCancellationId(0);
+//		shoppingOrder.setRefundCode("");
+//		shoppingOrder.setRefundAmount(new BigDecimal("0"));
+//		shoppingOrder.setRefundStatus(0);
+//		shoppingOrder.setRefundSerialNumber("");
+//		shoppingOrder.setRefundTime(LocalDateTime.now());
+//		shoppingOrder.setCreateTime(LocalDateTime.now());
+//		shoppingOrder.setDelFlag(false);
+//
+//
+//
+//	}
 }
 
diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/TGoodsController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/TGoodsController.java
index 55fb297..14de43b 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/TGoodsController.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/TGoodsController.java
@@ -7,6 +7,8 @@
 import com.ruoyi.account.api.feignClient.AppUserClient;
 import com.ruoyi.account.api.model.TAppUser;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.dto.AppGoodQuery;
+import com.ruoyi.common.core.dto.PointChangeDto;
 import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.common.core.web.page.BasePage;
 import com.ruoyi.common.core.web.page.PageInfo;
@@ -100,11 +102,11 @@
 
     @ApiOperation(tags = {"小程序-兑换商城"},value = "商品列表分页查询")
     @PostMapping(value = "/app/pageList")
-    public AjaxResult<PageInfo<TGoods>> apppageList(BasePage basePage) {
-        return AjaxResult.ok(goodsService.pageList1(basePage));
+    public AjaxResult<PageInfo<TGoods>> apppageList(@RequestBody AppGoodQuery appGoodQuery) {
+        return AjaxResult.ok(goodsService.pageList1(appGoodQuery));
     }
 
-    @ApiOperation(tags = {"小程序-兑换商城"},value = "兑换商品")
+    @ApiOperation(tags = {"小程序-兑换商城"},value = "积分兑换商品")
     @PostMapping(value = "/app/shop")
     public AjaxResult<PageInfo<TGoods>> shop(@RequestBody ExchangeDto exchangeDto) {
         //检查当前用户积分是否够
@@ -135,7 +137,7 @@
         }
         exchangeDto.setPoint(point);
         //生成积分兑换成功的订单
-        orderClient.exchangeCreate(exchangeDto);
+        R<Long> longR = orderClient.exchangeCreate(exchangeDto);
         if (exchangeDto.getGoodType()==2) {
             //如果是优惠卷,赠送优惠卷给用户
             GrantCouponDto grantCouponDto = new GrantCouponDto();
@@ -146,14 +148,31 @@
             appCouponClient.grantCoupon(grantCouponDto);
         }
         //生成消耗积分的记录
-
-
-
+        PointChangeDto pointChangeDto = new PointChangeDto();
+        pointChangeDto.setUserId(userId);
+        pointChangeDto.setPoints(point);
+        pointChangeDto.setRemark(longR.getData().toString());
+        pointChangeDto.setType(6);
+        appUserClient.change(pointChangeDto);
         return AjaxResult.success();
 
 
     }
 
+//    @ApiOperation(tags = {"小程序-兑换商城"},value = "支付商品")
+//    @PostMapping(value = "/app/pay")
+//    public AjaxResult<PageInfo<TGoods>> pay(@RequestBody ExchangeDto exchangeDto) {
+//
+//        //创建订单
+//
+//        //计算价格
+//
+//        //调起支付
+//
+//
+//
+//    }
+
     
     /**
      * 根据id获取商品信息
diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/mapper/TGoodsMapper.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/mapper/TGoodsMapper.java
index 491b8ad..9d72988 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/mapper/TGoodsMapper.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/mapper/TGoodsMapper.java
@@ -1,6 +1,7 @@
 package com.ruoyi.other.mapper;
 
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.ruoyi.common.core.dto.AppGoodQuery;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.other.api.domain.TActivity;
 import com.ruoyi.other.api.domain.TGoods;
@@ -20,6 +21,6 @@
 public interface TGoodsMapper extends BaseMapper<TGoods> {
 
     List<TGoods> pageList(@Param("pageInfo")PageInfo<TGoods> pageInfo, @Param("req") GoodsDTO dto);
-    List<TGoods> pageList1(@Param("pageInfo")PageInfo<TGoods> pageInfo);
+    List<TGoods> pageList1(@Param("pageInfo")PageInfo<TGoods> pageInfo, @Param("appGoodQuery")AppGoodQuery appGoodQuery);
 
 }
diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/TGoodsService.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/TGoodsService.java
index d37be56..848e1d2 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/TGoodsService.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/TGoodsService.java
@@ -1,6 +1,7 @@
 package com.ruoyi.other.service;
 
 import com.baomidou.mybatisplus.extension.service.IService;
+import com.ruoyi.common.core.dto.AppGoodQuery;
 import com.ruoyi.common.core.web.page.BasePage;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.other.api.domain.TGoods;
@@ -17,6 +18,6 @@
 public interface TGoodsService extends IService<TGoods> {
 
     PageInfo<TGoods> pageList(GoodsDTO dto);
-    PageInfo<TGoods> pageList1(BasePage basePage);
+    PageInfo<TGoods> pageList1(AppGoodQuery appGoodQuery);
 
 }
diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/TGoodsServiceImpl.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/TGoodsServiceImpl.java
index 7372668..7a58640 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/TGoodsServiceImpl.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/TGoodsServiceImpl.java
@@ -1,5 +1,6 @@
 package com.ruoyi.other.service.impl;
 
+import com.ruoyi.common.core.dto.AppGoodQuery;
 import com.ruoyi.common.core.web.page.BasePage;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.order.api.feignClient.OrderClient;
@@ -57,14 +58,14 @@
         return pageInfo;
     }
     @Override
-    public PageInfo<TGoods> pageList1(BasePage basePage) {
+    public PageInfo<TGoods> pageList1(AppGoodQuery basePage) {
         GoodsDTO dto = new GoodsDTO();
         dto.setType(2);
         dto.setStatus(1);
         dto.setPageCurr(basePage.getPageCurr());
         dto.setPageSize(basePage.getPageSize());
         PageInfo<TGoods> pageInfo = new PageInfo<>(dto.getPageCurr(),dto.getPageSize());
-        List<TGoods> list = this.baseMapper.pageList1(pageInfo);
+        List<TGoods> list = this.baseMapper.pageList1(pageInfo,basePage);
 
         StringBuilder stringBuilder = new StringBuilder();
         for (TGoods temp : list) {
diff --git a/ruoyi-service/ruoyi-other/src/main/resources/mapper/other/TGoodsMapper.xml b/ruoyi-service/ruoyi-other/src/main/resources/mapper/other/TGoodsMapper.xml
index 4b83baa..4c7d61e 100644
--- a/ruoyi-service/ruoyi-other/src/main/resources/mapper/other/TGoodsMapper.xml
+++ b/ruoyi-service/ruoyi-other/src/main/resources/mapper/other/TGoodsMapper.xml
@@ -51,13 +51,24 @@
     </select>
 
     <select id="pageList1" resultType="com.ruoyi.other.api.domain.TGoods">
-        select * from t_goods
-        <where>
-            AND del_flag = ${@com.ruoyi.common.core.enums.DelFlagEnum@NO.getCode()}
-        </where>
+        SELECT
+            id,name,redeem_points,inventory
+        FROM
+            t_goods
+        WHERE `status` = 1 and del_flag = 0 and type = #{appGoodQuery.type}
+        UNION ALL
+        SELECT
+            id,name,redeem_points,inventory_quantity as inventory
+        FROM
+            t_coupon
+        WHERE `status`= 1 and del_flag = 0 and type = #{appGoodQuery.type}
         ORDER BY
-        CASE WHEN `inventory` = 0 THEN 0 ELSE 1 END DESC,
-        `redeem_points` ASC;
+            CASE
+
+                WHEN `inventory` = 0 THEN
+                    0 ELSE 1
+                END DESC,
+            `redeem_points` ASC;
     </select>
 
 </mapper>
diff --git a/ruoyi-service/ruoyi-payment/src/main/java/com/ruoyi/payment/wx/controller/WxPayController.java b/ruoyi-service/ruoyi-payment/src/main/java/com/ruoyi/payment/wx/controller/WxPayController.java
index adeb678..f3e7274 100644
--- a/ruoyi-service/ruoyi-payment/src/main/java/com/ruoyi/payment/wx/controller/WxPayController.java
+++ b/ruoyi-service/ruoyi-payment/src/main/java/com/ruoyi/payment/wx/controller/WxPayController.java
@@ -87,6 +87,16 @@
     public R<Map<String, Object>> payNotify(HttpServletRequest request) throws Exception {
         try {
             Map<String, Object> params = wxV3Pay.verifyNotify(request, new TypeReference<Map<String, Object>>() {});
+            String outRefundNo = (String) params.get("out_refund_no");
+            String substring = outRefundNo.substring(0, 2);
+            switch (substring){
+                //购物订单
+                case "GW":
+                    //更改订单状态
+                    //如果是优惠卷赠送优惠卷
+                    break;
+            }
+
             log.info("支付回调:{}", params);
             return R.ok(params);
         } catch (Exception e) {

--
Gitblit v1.7.1