From 85384328c12fcc689e1f66f4deca77168859882d Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期五, 10 一月 2025 19:12:39 +0800 Subject: [PATCH] 修改bug --- ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java | 126 +++++++++++++++++++++++++++++++++-------- 1 files changed, 100 insertions(+), 26 deletions(-) diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java index 4a5dc06..1a01bec 100644 --- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java +++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java @@ -2,7 +2,9 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper; import com.ruoyi.account.api.feignClient.AppUserClient; import com.ruoyi.account.api.feignClient.AppUserShopClient; import com.ruoyi.account.api.model.AppUser; @@ -13,15 +15,9 @@ import com.ruoyi.common.security.utils.SecurityUtils; import com.ruoyi.order.feignClient.OrderClient; import com.ruoyi.order.vo.VerifiableShopVo; -import com.ruoyi.other.api.domain.Goods; -import com.ruoyi.other.api.domain.GoodsShop; -import com.ruoyi.other.api.domain.Shop; -import com.ruoyi.other.api.domain.ShopScore; +import com.ruoyi.other.api.domain.*; import com.ruoyi.other.mapper.ShopMapper; -import com.ruoyi.other.service.GoodsService; -import com.ruoyi.other.service.GoodsShopService; -import com.ruoyi.other.service.ShopScoreService; -import com.ruoyi.other.service.ShopService; +import com.ruoyi.other.service.*; import com.ruoyi.other.util.GeodesyUtil; import com.ruoyi.other.util.tencentMap.TencentMapUtil; import com.ruoyi.other.vo.NearbyShopVO; @@ -38,10 +34,13 @@ import io.swagger.annotations.ApiParam; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; +import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import java.math.BigDecimal; +import java.math.MathContext; +import java.math.RoundingMode; import java.time.LocalDateTime; import java.util.*; import java.util.stream.Collectors; @@ -80,6 +79,13 @@ private GoodsShopService goodsShopService; @Resource private OrderClient orderClient; + @Resource + private TechnicianSubscribeService technicianSubscribeService; + @Resource + private TechnicianService technicianService; + @Resource + private ReceiverBankChannelService receiverBankChannelService; + @@ -182,26 +188,42 @@ Shop shop = shopService.getById(id); shop.setDelFlag(1); shopService.updateById(shop); - //获取门店的员工数据 + appUserClient.clearBindShop(shop.getId()); UserShop userShop = new UserShop(); userShop.setShopId(shop.getId()); List<UserShop> data = userShopClient.getUserShop(userShop).getData(); - List<Integer> collect = data.stream().map(UserShop::getUserId).collect(Collectors.toList()).stream().map(Long::intValue).collect(Collectors.toList()); - List<SysUser> sysUserList = sysUserClient.getUserList(collect).getData(); - //删除门店下的所有员工 - sysUserClient.delShopUser(shop.getId(), 2); - //修改小程序用户类型和门店数据 - for (SysUser sysUser : sysUserList) { - String userName = sysUser.getUserName(); - //通过电话号码查询小程序用户和门店关系数据 - AppUser appUser = appUserClient.getAppUserByPhone1(userName).getData(); - //需要先判断用户是否没有关联任何门店 - List<AppUserShop> userShops = appUserShopClient.getAppUserShop(appUser.getId()).getData(); - if(userShops.size() == 1 && userShops.get(0).getShopId().equals(shop.getId())){ - appUser.setUserType(1); - appUserClient.editAppUserById(appUser); + if(data.size() > 0){ + List<Integer> collect = data.stream().map(UserShop::getUserId).collect(Collectors.toList()).stream().map(Long::intValue).collect(Collectors.toList()); + List<SysUser> sysUserList = sysUserClient.getUserList(collect).getData(); + //删除门店下的所有员工 + sysUserClient.delShopUser(shop.getId(), 2); + //修改小程序用户类型和门店数据 + for (SysUser sysUser : sysUserList) { + //通过电话号码查询小程序用户和门店关系数据 + AppUser appUser = appUserClient.getAppUserByPhone1(sysUser.getUserName()).getData(); + //需要先判断用户是否没有关联任何门店 + List<AppUserShop> userShops = appUserShopClient.getAppUserShop(appUser.getId()).getData(); + if(userShops.size() == 1 && userShops.get(0).getShopId().equals(shop.getId())){ + appUser.setUserType(1); + appUserClient.editAppUserById(appUser); + } + //删除用户门店关系表数据 + AppUserShop appUserShop = new AppUserShop(); + appUserShop.setAppUserId(appUser.getId()); + appUserShop.setShopId(shop.getId()); + appUserShopClient.delAppUserShop(appUserShop); } - + } + //取消预约的订单 + List<Technician> list = technicianService.list(new LambdaQueryWrapper<Technician>().eq(Technician::getShopId, shop.getId()).eq(Technician::getDelFlag, 0)); + if(list.size() > 0){ + for (Technician technician : list) { + technician.setDelFlag(1); + } + technicianService.updateBatchById(list); + Set<Integer> collect = list.stream().map(Technician::getId).collect(Collectors.toSet()); + technicianSubscribeService.update(new LambdaUpdateWrapper<TechnicianSubscribe>().in(TechnicianSubscribe::getTechnicianId, collect).eq(TechnicianSubscribe::getDelFlag, 0) + .eq(TechnicianSubscribe::getStatus, 0).set(TechnicianSubscribe::getStatus, 2)); } return R.ok(); } @@ -381,8 +403,10 @@ */ @GetMapping("/shopByUser") @ApiOperation(value = "查询当前店长所属门店", tags = {"小程序-个人中心"}, notes = "可绑定的门店列表") - public R<List<Shop>> shopByUser() { - R<List<AppUserShop>> r = appUserClient.getAppUserShop(SecurityUtils.getUserId()); + public R<List<Shop>> shopByUser(@RequestParam("longitude") String longitude, @RequestParam("latitude") String latitude) { + Long userid = tokenService.getLoginUserApplet().getUserid(); + AppUser appUser = appUserClient.getAppUserById(userid); + R<List<AppUserShop>> r = appUserClient.getAppUserShop(userid); if (R.isSuccess(r)){ List<AppUserShop> appUserShopList = r.getData(); if (CollectionUtils.isEmpty(appUserShopList)){ @@ -390,6 +414,32 @@ } List<Integer> shopIds = appUserShopList.stream().map(AppUserShop::getShopId).collect(Collectors.toList()); List<Shop> shopList = shopService.listByIds(shopIds); + if(null != appUser.getShopId()){ + Optional<Shop> first = shopList.stream().filter(s -> s.getId().equals(appUser.getShopId())).findFirst(); + if(first.isPresent()){ + Shop shop = first.get(); + for (Shop shop1 : shopList) { + if(shop1.getId().equals(shop.getId())){ + shopList.remove(shop1); + break; + } + } + shopList.add(0, shop); + } + } + for (Shop shop : shopList) { + Double wgs84 = GeodesyUtil.getDistance(longitude + "," + latitude, shop.getLongitude() + "," + shop.getLatitude()).get("WGS84"); + shop.setDistance(wgs84); + List<ShopScore> list = shopScoreService.list(new LambdaQueryWrapper<ShopScore>().eq(ShopScore::getShopId, shop.getId())); + double v = 5; + if(list.size() > 0){ + v = list.stream().map(ShopScore::getScore).reduce(BigDecimal.ZERO, BigDecimal::add) + .divide(new BigDecimal(list.size()), new MathContext(2, RoundingMode.HALF_EVEN)).doubleValue(); + } + shop.setScore(v); + ShopScore one = shopScoreService.getOne(new LambdaQueryWrapper<ShopScore>().eq(ShopScore::getAppUserId, userid).eq(ShopScore::getShopId, shop.getId()).last(" order by create_time desc limit 0, 1")); + shop.setMyScore(null == one ? "0" : one.getScore().toString()); + } return R.ok(shopList); } return R.ok(new ArrayList<>()); @@ -580,5 +630,29 @@ List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1)); return R.ok(list); } + + @ResponseBody + @GetMapping("/verifyAccountConfiguration") + @ApiOperation(value = "判断是否有提现账户", tags = {"门店后台-财务管理-提现明细"}) + public R verifyAccountConfiguration(){ + Long userid = tokenService.getLoginUser().getUserid(); + SysUser sysUser = sysUserClient.getSysUser(userid).getData(); + Shop shop = shopService.getById(sysUser.getObjectId()); + if(StringUtils.hasLength(shop.getReceiverAccountNoEnc())){ + return R.ok(); + } + return R.fail("请先配置收款账户"); + } + + + + @ResponseBody + @GetMapping("/getBankSerialNumber") + @ApiOperation(value = "获取行联号", tags = {"门店后台-财务管理-提现明细"}) + public R<List<ReceiverBankChannel>> getBankSerialNumber(String name){ + List<ReceiverBankChannel> list = receiverBankChannelService.list(new LambdaQueryWrapper<ReceiverBankChannel>().like(ReceiverBankChannel::getName, name)); + return R.ok(list); + } + } -- Gitblit v1.7.1