From 5e4f1cba1d27b43aeef878ae3b4e77813a2870ff Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Mon, 19 Jul 2021 10:47:46 +0800 Subject: [PATCH] fix --- gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java | 176 +++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 160 insertions(+), 16 deletions(-) diff --git a/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java b/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java index 3f047aa..0f70a10 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java +++ b/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java @@ -1,30 +1,42 @@ package com.xzx.gc.user.controller; +import cn.hutool.core.codec.Base64; +import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.ObjectUtil; +import cn.hutool.core.util.StrUtil; import com.xzx.gc.common.constant.CommonEnum; import com.xzx.gc.common.constant.Constants; import com.xzx.gc.common.dto.log.OperationAppLog; import com.xzx.gc.common.request.BaseController; import com.xzx.gc.entity.AccountInfo; import com.xzx.gc.entity.RedPaperRule; +import com.xzx.gc.entity.UserHeadRelate; import com.xzx.gc.model.JsonResult; +import com.xzx.gc.model.admin.ExportParamModel; +import com.xzx.gc.model.admin.PromoterModel; +import com.xzx.gc.model.admin.UserModel; import com.xzx.gc.user.dto.*; import com.xzx.gc.user.mapper.AccountMapper; import com.xzx.gc.user.mapper.RedPaperRuleMapper; +import com.xzx.gc.user.mapper.UserHeadRelateMapper; import com.xzx.gc.user.service.DistribService; -import com.xzx.gc.user.vo.DistribListVo; -import com.xzx.gc.user.vo.ViewSettingVo; +import com.xzx.gc.user.vo.*; +import com.xzx.gc.util.DoubleUtil; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiResponse; import io.swagger.annotations.ApiResponses; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.MediaType; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.util.ArrayList; +import java.util.List; import java.util.Map; @RestController @@ -39,6 +51,9 @@ @Autowired private AccountMapper accountMapper; + + @Autowired + private UserHeadRelateMapper userHeadRelateMapper; /** * 查看分銷系統设置详情 @@ -77,7 +92,7 @@ return JsonResult.success("操作成功!"); } - @ApiOperation(value = "团长列表") + @ApiOperation(value = "符合条件待入选团长列表") @ApiResponses( @ApiResponse(code = 200, message = "success", response = DistribListVo.class) ) @@ -93,29 +108,158 @@ @ApiOperation(value="分銷系統管理--新增团长", notes="test: 仅0有正确返回") public JsonResult adddistrib(@RequestBody AdddistribDto model, HttpServletRequest request) { String id = model.getId(); + List<String> ids = StrUtil.split(id, ','); +// AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id); + List<AccountInfo> accountInfos = accountMapper.selectAccountInfoByIds(ids); + if (CollUtil.isNotEmpty(accountInfos)) { + for (AccountInfo accountInfo : accountInfos) { +// if(ObjectUtil.isEmpty(accountInfo)){ +// return JsonResult.failMessage("账户不存在!"); +// } + if(ObjectUtil.isEmpty(accountInfo.getIsHead()) + || accountInfo.getIsHead() == 1){ + return JsonResult.failMessage(accountInfo.getAccountName() + "账户不能重复添加!"); + } + if(ObjectUtil.isEmpty(accountInfo.getDelFlag()) + || accountInfo.getDelFlag() == 1){ + return JsonResult.failMessage(accountInfo.getAccountName() + "账户已删除!"); + } + if(ObjectUtil.isEmpty(accountInfo.getIsProhibit()) + || "1".equals(accountInfo.getIsProhibit())){ + return JsonResult.failMessage(accountInfo.getAccountName() + "账户已冻结!"); + } + //团员不能当团长 + String userId = accountInfo.getUserId(); + UserHeadRelate userHeadRelate = userHeadRelateMapper.selectMemberByUserId(userId); + if(ObjectUtil.isNotEmpty(userHeadRelate)){ + return JsonResult.failMessage(accountInfo.getAccountName() + "账户不能申请成为团长!"); + } + distribService.adddistrib(model); + OperationAppLog build = OperationAppLog.builder().appPrograme(CommonEnum.后台.getValue()).opreateName(getAdminName(request)) + .methodName(Constants.USER_MODUL_NAME).operateAction("分銷系統管理--新增团长-"+id).build(); + mqUtil.sendApp(build); + } + + return JsonResult.success("操作成功!"); + } else { + return JsonResult.failMessage("参数错误"); + } + + } + + @ApiOperation(value = "团长列表") + @ApiResponses( + @ApiResponse(code = 200, message = "success", response = DistribInfoListVo.class) + ) + @PostMapping(value = Constants.ADMIN_VIEW_PREFIX + "/distrib/distribInfoList.json") + public JsonResult<Map<String, Object>> distribInfoList(@RequestBody DistribInfoListDto distribInfoListDto) { + return JsonResult.success(distribService.distribInfoList(distribInfoListDto)); + } + + /** + * 查看团长信息详情-个人信息 + */ + @PostMapping(Constants.ADMIN_VIEW_PREFIX + "/distrib/viewDistribInfo.json") + @ApiResponses({@ApiResponse( code = 200, message = "success", response = ViewDistribInfoVo.class)}) + @ApiOperation(value="团长列表-个人信息详情", notes="test: 仅0有正确返回") + public JsonResult<ViewDistribInfoVo> viewDistribInfo(@RequestBody ViewDistribInfoDto viewDistribInfoDto) { + String id = viewDistribInfoDto.getId(); AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id); if(ObjectUtil.isEmpty(accountInfo)){ return JsonResult.failMessage("账户不存在!"); } - if(ObjectUtil.isEmpty(accountInfo.getIsHead()) - || accountInfo.getIsHead() == 1){ - return JsonResult.failMessage("账户不能重复添加!"); + ViewDistribInfoVo viewDistribInfoVo = distribService.viewDistribInfo(id); + return JsonResult.success(viewDistribInfoVo); + } + + @ApiOperation(value = "团长列表-团队信息") + @ApiResponses( + @ApiResponse(code = 200, message = "success", response = UserHeadInfoVo.class) + ) + @PostMapping(value = Constants.ADMIN_VIEW_PREFIX + "/distrib/userHeadInfoList.json") + public JsonResult<Map<String, Object>> userHeadInfoList(@RequestBody UserHeadInfoListDto userHeadInfoListDto) { + return JsonResult.success(distribService.userHeadInfoList(userHeadInfoListDto)); + } + + @ApiOperation(value = "团长列表-订单详情") + @ApiResponses( + @ApiResponse(code = 200, message = "success", response = OrderItemsVo.class) + ) + @PostMapping(value = Constants.ADMIN_VIEW_PREFIX + "/distrib/orderItemsList.json") + public JsonResult<Map<String, Object>> orderItemsList(@RequestBody UserHeadInfoListDto userHeadInfoListDto) { + return JsonResult.success(distribService.orderItemsList(userHeadInfoListDto)); + } + + /** + * 启用禁用团长 + */ + @PostMapping(Constants.ADMIN_VIEW_PREFIX + "/distrib/prohibitDistrib.json") + @ApiOperation(value="分銷系統管理--启用禁用团长", notes="test: 仅0有正确返回") + public JsonResult prohibitDistrib(@RequestBody ProhibitDistribDto model, HttpServletRequest request) { + String id = model.getId(); + AccountInfo accountInfo = accountMapper.selectByPrimaryKey(id); + if(ObjectUtil.isEmpty(accountInfo)){ + return JsonResult.failMessage("账户不存在!"); } - if(ObjectUtil.isEmpty(accountInfo.getDelFlag()) - || accountInfo.getDelFlag() == 1){ - return JsonResult.failMessage("账户已删除!"); - } - if(ObjectUtil.isEmpty(accountInfo.getIsProhibit()) - || accountInfo.getIsProhibit() == "1"){ - return JsonResult.failMessage("账户已冻结!"); - } - distribService.adddistrib(model); + distribService.prohibitDistrib(model); OperationAppLog build = OperationAppLog.builder().appPrograme(CommonEnum.后台.getValue()).opreateName(getAdminName(request)) - .methodName(Constants.USER_MODUL_NAME).operateAction("分銷系統管理--新增团长-"+id).build(); + .methodName(Constants.USER_MODUL_NAME).operateAction("分銷系統管理--启用禁用团长-"+id).build(); mqUtil.sendApp(build); return JsonResult.success("操作成功!"); } + @ApiOperation(value = "团长数据--头部") + @ApiResponses( + @ApiResponse(code = 200, message = "success", response = DistribDataInfoVo.class) + ) + @PostMapping(value = Constants.ADMIN_VIEW_PREFIX + "/distrib/distribDataInfo.json") + public JsonResult<DistribDataInfoVo> distribDataInfo(@RequestBody DistribDataInfoDto distribDataInfoDto) { + return JsonResult.success(distribService.distribDataInfo(distribDataInfoDto)); + } + + @ApiOperation(value = "团长数据--列表") + @ApiResponses( + @ApiResponse(code = 200, message = "success", response = DistribDataListVo.class) + ) + @PostMapping(value = Constants.ADMIN_VIEW_PREFIX + "/distrib/distribDataList.json") + public JsonResult<Map<String, Object>> distribDataList(@RequestBody DistribDataListDto distribDataListDto) { + return JsonResult.success(distribService.distribDataList(distribDataListDto)); + } + + @ApiOperation(value = "团长数据--列表导出",produces = MediaType.APPLICATION_OCTET_STREAM_VALUE) + @PostMapping(value = Constants.ADMIN_VIEW_PREFIX + "/distrib/distribDataExport.json") + public void distribDataExport(@RequestBody ExportDistribDataListDto distribDataListDto, HttpServletRequest request, HttpServletResponse response) { + List<List<String>> rows = new ArrayList<>(); + List<String> header=new ArrayList<>(); + //标题 + header=CollUtil.newArrayList( "团长名称", "手机号", "身份", "团员数量", "交易单数", "累计积分收益", "累计环保币收益", "累计订单重量(kg)","累计订单数量(家电)"); + rows.add(header); + Map<String, Object> stringObjectMap = distribService.distribDataExport(distribDataListDto); + List<DistribDataListVo> distribDataListVos = (List<DistribDataListVo>) stringObjectMap.get("data"); + if (CollUtil.isNotEmpty(distribDataListVos)) { + for(DistribDataListVo m : distribDataListVos){ + List<String> list = new ArrayList<>(); + list.add(m.getNickname()); + list.add(m.getPhone()); + list.add("团长"); + list.add(m.getCnt().toString()); + list.add(m.getOrderCnt()); + list.add(m.getScore()); + list.add(m.getAmount()); + list.add(m.getKg()); + list.add(m.getJdsl()); + rows.add(list); + } + } + //导出 + export(rows,response); + + OperationAppLog build = OperationAppLog.builder().appPrograme(CommonEnum.后台.getValue()).opreateName(getAdminName(request)) + .methodName(Constants.USER_MODUL_NAME).operateAction("用户导出-团长数据").build(); + mqUtil.sendApp(build); + + } + } -- Gitblit v1.9.1