From c8596d7a94a983143f859a4a29097925a438c4a5 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期三, 15 一月 2025 14:43:08 +0800 Subject: [PATCH] 修改bug --- ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java | 168 ++++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 138 insertions(+), 30 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 2bc41bf..dd8c7e6 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 @@ -45,6 +45,8 @@ import java.util.*; import java.util.stream.Collectors; +import static javax.swing.UIManager.get; + /** * <p> * 前端控制器 @@ -114,14 +116,20 @@ shop.setCustomOrderNumber(0); shop.setAppUserId(appUser.getId()); String city = TencentMapUtil.inverseGeographicalAnalysis(shop.getLongitude(), shop.getLatitude(), false); + if(!StringUtils.hasLength(city)){ + city = "510100"; + } shop.setProvinceCode(city.substring(0, 2) + "0000"); shop.setCityCode(city.substring(0, 4) + "00"); shop.setDistrictCode(city); shopService.save(shop); + Integer shopId = shop.getId(); + AppUserShop appUserShop = new AppUserShop(); appUserShop.setAppUserId(appUser.getId()); - appUserShop.setShopId(shop.getId()); + appUserShop.setShopId(shopId); + appUserShop.setRoleType(1); R<Void> r = appUserClient.addAppUserShop(appUserShop); if (R.isError(r)){ throw new RuntimeException("添加失败"); @@ -132,20 +140,23 @@ throw new RuntimeException("添加失败"); } //添加门店后台账号和门店关系数据 - SysUser sysUser = sysUserClient.queryUserByUserName(phone).getData(); + SysUser sysUser = sysUserClient.queryUserByUserNameAndRoleType(phone, 2).getData(); if(null != sysUser){ + sysUser.setAppUserId(appUser.getId()); + sysUserClient.updateUser(sysUser); + UserShop userShop = new UserShop(); userShop.setUserId(sysUser.getUserId()); - userShop.setShopId(shop.getId()); + userShop.setShopId(shopId); userShop.setRoleType(1); - userShop.setNickName(sysUser.getNickName()); List<UserShop> data = userShopClient.getUserShop(userShop).getData(); if(null == data || data.size() == 0){ userShop = new UserShop(); userShop.setUserId(sysUser.getUserId()); - userShop.setShopId(shop.getId()); + userShop.setShopId(shopId); userShop.setRoleType(1); userShop.setRoleId(2L); + userShop.setNickName(sysUser.getNickName()); userShop.setCreateTime(LocalDateTime.now()); userShopClient.saveUserShop(userShop); } @@ -160,7 +171,7 @@ user.setStatus("0"); user.setDelFlag("0"); user.setRoleType(2); - user.setObjectId(shop.getId()); + user.setObjectId(shopId); user.setAppUserId(appUser.getId()); user.setPassword(phone.substring(5)); user.setCreateTime(new Date()); @@ -168,14 +179,23 @@ UserShop userShop = new UserShop(); userShop.setUserId(userId); - userShop.setShopId(shop.getId()); + userShop.setShopId(shopId); userShop.setRoleType(1); - userShop.setRoleId(2L); - userShopClient.saveUserShop(userShop); + List<UserShop> data = userShopClient.getUserShop(userShop).getData(); + if(null == data || data.size() == 0){ + userShop = new UserShop(); + userShop.setUserId(userId); + userShop.setShopId(shopId); + userShop.setRoleType(1); + userShop.setRoleId(2L); + userShop.setNickName(user.getNickName()); + userShop.setCreateTime(LocalDateTime.now()); + userShopClient.saveUserShop(userShop); + } } // 更换下级会员绑定门店 - R<List<AppUser>> lowerShopR = appUserClient.setLowerUserShop(appUser.getId(), shop.getId()); + R<List<AppUser>> lowerShopR = appUserClient.setLowerUserShop(appUser.getId(), shopId); if (R.isError(lowerShopR)){ throw new RuntimeException("更换下级会员绑定门店失败"); } @@ -204,16 +224,26 @@ Shop shop = shopService.getById(id); shop.setDelFlag(1); shopService.updateById(shop); + // 查询有没有门店绑定这个被删除的门店 + List<Shop> shops = shopService.lambdaQuery().eq(Shop::getPid, shop.getId()).list(); + for (Shop shop1 : shops) { + LambdaUpdateWrapper<Shop> set = new LambdaUpdateWrapper<Shop>().set(Shop::getPid, null) + .eq(Shop::getId,shop1.getId()); + shopService.update(set); + } + //清除用户绑定当前门店 appUserClient.clearBindShop(shop.getId()); + //查询门店绑定的平台账号 UserShop userShop = new UserShop(); userShop.setShopId(shop.getId()); List<UserShop> data = userShopClient.getUserShop(userShop).getData(); if(data.size() > 0){ + //删除门店后台账号和关系数据 + sysUserClient.delShopUser(shop.getId(), 2); + + //修改小程序用户类型和门店数据 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(); @@ -223,10 +253,10 @@ appUser.setUserType(1); appUserClient.editAppUserById(appUser); } - //删除用户门店关系表数据 + //删除用户门店关系数据 AppUserShop appUserShop = new AppUserShop(); - appUserShop.setAppUserId(appUser.getId()); appUserShop.setShopId(shop.getId()); + appUserShop.setAppUserId(appUser.getId()); appUserShopClient.delAppUserShop(appUserShop); } } @@ -237,6 +267,14 @@ technician.setDelFlag(1); } technicianService.updateBatchById(list); + //删除技师和门店关系数据 + //删除用户门店关系数据 + AppUserShop appUserShop = new AppUserShop(); + appUserShop.setShopId(shop.getId()); + appUserShop.setRoleType(3); + appUserShopClient.delAppUserShop(appUserShop); + + //取消门店预约技师数据 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)); @@ -251,13 +289,16 @@ if (!shopService.cheUserByPhone(phone)) { return R.fail("该手机号未注册"); } - if (shop.getPid()!=null){ + if (shop.getPid() != null && shop.getPid() != 0){ Shop shopP = shopService.getById(shop.getPid()); if (shopP.getPid()!=null&&shopP.getPid()!=0&& shopP.getPid().equals(shop.getId())){ return R.fail("门店之间不能互相作为上级门店"); } } String city = TencentMapUtil.inverseGeographicalAnalysis(shop.getLongitude(), shop.getLatitude(), false); + if(!StringUtils.hasLength(city)){ + city = "510100"; + } shop.setProvinceCode(city.substring(0, 2) + "0000"); shop.setCityCode(city.substring(0, 4) + "00"); shop.setDistrictCode(city); @@ -267,40 +308,63 @@ AppUser appUser = appUserClient.getAppUserById(old_shop.getAppUserId()); //需要先判断用户是否没有关联任何门店 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()); + appUserShop.setRoleType(1); appUserShopClient.delAppUserShop(appUserShop); + //删除后台用户和店铺关系数据 + UserShop userShop = new UserShop(); + userShop.setShopId(shop.getId()); + userShop.setRoleType(1); + List<UserShop> data = userShopClient.getUserShop(userShop).getData(); + if(null != data && data.size() > 0){ + UserShop userShop1 = data.get(0); + userShopClient.delUserShop(userShop1); + //如果当前后台账户关联的店铺是最后一个,删除后台账户 + userShop = new UserShop(); + userShop.setUserId(userShop1.getUserId()); + data = userShopClient.getUserShop(userShop).getData(); + if(data.size() == 0){ + sysUserClient.delSysUserById(userShop1.getUserId()); + } + } //添加新管理员 appUser = appUserClient.getAppUserByPhone1(phone).getData(); appUserShop = new AppUserShop(); appUserShop.setAppUserId(appUser.getId()); appUserShop.setShopId(shop.getId()); + appUserShop.setRoleType(1); appUserClient.addAppUserShop(appUserShop); - + appUser.setUserType(2); + appUserClient.editAppUserById(appUser); + //修改管理员 shop.setAppUserId(appUser.getId()); shopService.updateById(shop); - + //添加门店后台账号和门店关系数据 SysUser sysUser = sysUserClient.queryUserByUserName(phone).getData(); if(null != sysUser){ - UserShop userShop = new UserShop(); - userShop.setUserId(sysUser.getUserId()); + userShop = new UserShop(); userShop.setShopId(shop.getId()); - userShop.setRoleType(1); - List<UserShop> data = userShopClient.getUserShop(userShop).getData(); + userShop.setUserId(sysUser.getUserId()); + data = userShopClient.getUserShop(userShop).getData(); if(null == data || data.size() == 0){ userShop = new UserShop(); userShop.setUserId(sysUser.getUserId()); userShop.setShopId(shop.getId()); userShop.setRoleType(1); userShop.setRoleId(2L); + userShop.setNickName(sysUser.getNickName()); + userShop.setCreateTime(LocalDateTime.now()); userShopClient.saveUserShop(userShop); } }else{ @@ -319,13 +383,21 @@ user.setPassword(phone.substring(5)); user.setCreateTime(new Date()); Long userId = sysUserClient.saveShopUser(user).getData(); - - UserShop userShop = new UserShop(); - userShop.setUserId(userId); + + userShop = new UserShop(); userShop.setShopId(shop.getId()); - userShop.setRoleType(1); - userShop.setRoleId(2L); - userShopClient.saveUserShop(userShop); + userShop.setUserId(userId); + data = userShopClient.getUserShop(userShop).getData(); + if(null == data || data.size() == 0){ + userShop = new UserShop(); + userShop.setUserId(userId); + userShop.setShopId(shop.getId()); + userShop.setRoleType(1); + userShop.setRoleId(2L); + userShop.setNickName(appUser.getName()); + userShop.setCreateTime(LocalDateTime.now()); + userShopClient.saveUserShop(userShop); + } } return R.ok(); } @@ -340,6 +412,21 @@ } shop.setStatus(status); shopService.updateById(shop); + //处理员工等数据 + UserShop userSh = new UserShop(); + userSh.setShopId(id); + List<UserShop> data = userShopClient.getUserShop(userSh).getData(); + for (UserShop datum : data) { + UserShop userShop = new UserShop(); + userShop.setUserId(datum.getUserId()); + List<UserShop> data1 = userShopClient.getUserShop(userShop).getData(); + long count = data1.stream().filter(s -> !s.getShopId().equals(id)).count(); + if(0 == count){ + SysUser sysUser = sysUserClient.getSysUser(datum.getUserId()).getData(); + sysUser.setStatus(status == 1 ? "0" : "1"); + sysUserClient.updateUser(sysUser); + } + } return R.ok(); } @@ -435,7 +522,12 @@ return R.ok(new ArrayList<>()); } List<Integer> shopIds = appUserShopList.stream().map(AppUserShop::getShopId).collect(Collectors.toList()); - List<Shop> shopList = shopService.list(new LambdaQueryWrapper<Shop>().in(Shop::getId, shopIds).eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1)); + List<Shop> shopList = shopService.list(new LambdaQueryWrapper<Shop>().in(Shop::getId, shopIds).eq(Shop::getDelFlag, 0)); + long count = shopList.stream().filter(s -> s.getStatus() == 1).count(); + if(shopList.size() > 0 && count == 0){ + return R.fail("操作失败,当前门店已冻结"); + } + shopList = shopList.stream().filter(s -> s.getStatus() == 1).collect(Collectors.toList()); if(null != appUser.getShopId()){ Optional<Shop> first = shopList.stream().filter(s -> s.getId().equals(appUser.getShopId())).findFirst(); if(first.isPresent()){ @@ -651,7 +743,7 @@ @PostMapping("/saveWithdrawalAccount") @ApiOperation(value = "保存提现账户", tags = {"门店后台-财务统计-提现明细"}) - public R saveWithdrawalAccount(SaveWithdrawalAccount saveWithdrawalAccount) { + public R saveWithdrawalAccount(@RequestBody SaveWithdrawalAccount saveWithdrawalAccount) { shopService.saveWithdrawalAccount(saveWithdrawalAccount); return R.ok(); } @@ -691,5 +783,21 @@ return R.ok(list); } + + @GetMapping("/getShopStatistics") + public R<Map<String, BigDecimal> > getShopStatistics(){ + List<Shop> shopList = shopService.list(); + BigDecimal serverGiveawayMoney = BigDecimal.ZERO; + BigDecimal lowerLevelGiveawayMoney = BigDecimal.ZERO; + for (Shop shop : shopList) { + serverGiveawayMoney = serverGiveawayMoney.add(shop.getServerGiveawayMoney()); + lowerLevelGiveawayMoney = lowerLevelGiveawayMoney.add(shop.getLowerLevelGiveawayMoney()); + } + Map<String, BigDecimal> map = new HashMap<>(); + map.put("serverGiveawayMoney", serverGiveawayMoney); + map.put("lowerLevelGiveawayMoney", lowerLevelGiveawayMoney); + return R.ok(map); + } + } -- Gitblit v1.7.1