From 5ba50d43ea3384a606ab16501633797297a78de3 Mon Sep 17 00:00:00 2001 From: liujie <1793218484@qq.com> Date: 星期五, 12 九月 2025 10:31:08 +0800 Subject: [PATCH] 供应商erp --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmBranchController.java | 142 ++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 132 insertions(+), 10 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmBranchController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmBranchController.java index 6788fee..7d5f0c2 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmBranchController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmBranchController.java @@ -1,24 +1,29 @@ package com.ruoyi.web.controller.api; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.ruoyi.common.annotation.Log; import com.ruoyi.common.basic.PageInfo; import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.enums.BusinessType; +import com.ruoyi.framework.web.service.TokenService; import com.ruoyi.system.dto.TCrmBranchDTO; -import com.ruoyi.system.model.TCrmBranch; -import com.ruoyi.system.model.TErpGoods; +import com.ruoyi.system.model.*; import com.ruoyi.system.query.TCrmBranchQuery; -import com.ruoyi.system.service.TCrmBranchService; +import com.ruoyi.system.service.*; import com.ruoyi.system.vo.TCrmBranchVO; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import java.util.List; +import java.util.Objects; +import java.util.stream.Collectors; /** * <p> @@ -34,9 +39,23 @@ public class TCrmBranchController { private final TCrmBranchService crmBranchService; + private final TCrmBranchAreaService crmBranchAreaService; + private final TCrmBranchSalaryService crmBranchSalaryService; + private final ISysUserService sysUserService; + private final TCrmChangePointsService crmChangePointsService; + private final TCrmPositionService crmPositionService; + private final TCrmSalespersonService crmSalespersonService; + private final TokenService tokenService; @Autowired - public TCrmBranchController(TCrmBranchService crmBranchService) { + public TCrmBranchController(TCrmBranchService crmBranchService, TCrmBranchAreaService crmBranchAreaService, TCrmBranchSalaryService crmBranchSalaryService, ISysUserService sysUserService, TCrmChangePointsService crmChangePointsService, TCrmPositionService crmPositionService, TCrmSalespersonService crmSalespersonService, TokenService tokenService) { this.crmBranchService = crmBranchService; + this.crmBranchAreaService = crmBranchAreaService; + this.crmBranchSalaryService = crmBranchSalaryService; + this.sysUserService = sysUserService; + this.crmChangePointsService = crmChangePointsService; + this.crmPositionService = crmPositionService; + this.crmSalespersonService = crmSalespersonService; + this.tokenService = tokenService; } /** @@ -54,7 +73,23 @@ @ApiOperation(value = "获取crm分公司管理列表") @PostMapping(value = "/list") public R<List<TCrmBranch>> list() { - return R.ok(crmBranchService.list(Wrappers.lambdaQuery(TCrmBranch.class).orderByDesc(TCrmBranch::getCreateTime))); + Integer roleType = tokenService.getLoginUser().getUser().getRoleType(); + Long userId = tokenService.getLoginUser().getUserId(); + LambdaQueryWrapper<TCrmBranch> wrapper = new LambdaQueryWrapper<>(); + if (roleType == 2) { + wrapper.eq(TCrmBranch::getUserId, userId); + } + if(roleType == 3){ + // 查询业务员信息 + TCrmSalesperson crmSalesperson = crmSalespersonService.getOne(Wrappers.lambdaQuery(TCrmSalesperson.class) + .eq(TCrmSalesperson::getUserId, userId) + .last("LIMIT 1")); + if(Objects.nonNull(crmSalesperson)){ + wrapper.eq(TCrmBranch::getId, crmSalesperson.getBranchId()); + } + } + wrapper.eq(TCrmBranch::getStatus,1).orderByDesc(TCrmBranch::getCreateTime); + return R.ok(crmBranchService.list(wrapper)); } /** @@ -64,7 +99,7 @@ @ApiOperation(value = "添加crm分公司管理") @PostMapping(value = "/add") public R<Boolean> add(@Validated @RequestBody TCrmBranchDTO dto) { - return crmBranchService.add(dto); + return crmBranchService.addBranch(dto); } /** @@ -73,8 +108,8 @@ @Log(title = "crm分公司管理信息-修改crm分公司管理", businessType = BusinessType.UPDATE) @ApiOperation(value = "修改crm分公司管理") @PostMapping(value = "/update") - public R<Boolean> update(@Validated @RequestBody TCrmBranch dto) { - return R.ok(crmBranchService.updateById(dto)); + public R<Boolean> update(@Validated @RequestBody TCrmBranchDTO dto) { + return crmBranchService.updateBranch(dto); } /** @@ -82,8 +117,21 @@ */ @ApiOperation(value = "查看crm分公司管理详情") @GetMapping(value = "/getDetailById") - public R<TCrmBranch> getDetailById(@RequestParam String id) { - return R.ok(crmBranchService.getById(id)); + public R<TCrmBranchVO> getDetailById(@RequestParam String id) { + TCrmBranch crmBranch = crmBranchService.getById(id); + TCrmBranchVO crmBranchVO = new TCrmBranchVO(); + BeanUtils.copyProperties(crmBranch, crmBranchVO); + // 查询区域 + List<TCrmBranchArea> crmBranchAreas = crmBranchAreaService.list(Wrappers.lambdaQuery(TCrmBranchArea.class).eq(TCrmBranchArea::getBranchId, id)); + crmBranchVO.setCrmBranchAreas(crmBranchAreas); + // 职位薪资 + List<TCrmPosition> crmPositions = crmPositionService.list(); + List<TCrmBranchSalary> crmBranchSalaries = crmBranchSalaryService.list(Wrappers.lambdaQuery(TCrmBranchSalary.class).eq(TCrmBranchSalary::getBranchId, id)); + for (TCrmBranchSalary crmBranchSalary : crmBranchSalaries) { + crmPositions.stream().filter(crmPosition -> Objects.equals(crmPosition.getId(), crmBranchSalary.getPositionId())).findFirst().ifPresent(crmPosition -> crmBranchSalary.setPositionName(crmPosition.getPositionName())); + } + crmBranchVO.setCrmBranchSalaries(crmBranchSalaries); + return R.ok(crmBranchVO); } /** @@ -93,6 +141,13 @@ @ApiOperation(value = "删除crm分公司管理") @DeleteMapping(value = "/deleteById") public R<Boolean> deleteById(@RequestParam String id) { + // 删除区域 + crmBranchAreaService.remove(Wrappers.lambdaQuery(TCrmBranchArea.class).eq(TCrmBranchArea::getBranchId, id)); + // 删除职位薪资 + crmBranchSalaryService.remove(Wrappers.lambdaQuery(TCrmBranchSalary.class).eq(TCrmBranchSalary::getBranchId, id)); + // 删除账号 + TCrmBranch crmBranch = crmBranchService.getById(id); + sysUserService.deleteUserById(crmBranch.getUserId()); return R.ok(crmBranchService.removeById(id)); } @@ -103,8 +158,75 @@ @ApiOperation(value = "批量删除crm分公司管理") @DeleteMapping(value = "/deleteByIds") public R<Boolean> deleteByIds(@RequestBody List<String> ids) { + // 删除区域 + crmBranchAreaService.remove(Wrappers.lambdaQuery(TCrmBranchArea.class).in(TCrmBranchArea::getBranchId, ids)); + // 删除职位薪资 + crmBranchSalaryService.remove(Wrappers.lambdaQuery(TCrmBranchSalary.class).in(TCrmBranchSalary::getBranchId, ids)); + // 删除账号 + List<TCrmBranch> crmBranchList = crmBranchService.list(Wrappers.lambdaQuery(TCrmBranch.class).in(TCrmBranch::getId, ids)); + List<Long> userIds = crmBranchList.stream().map(TCrmBranch::getUserId).collect(Collectors.toList()); + sysUserService.deleteUserByIds(userIds); return R.ok(crmBranchService.removeByIds(ids)); } + + /** + * 批量删除crm分公司管理 + */ + @Log(title = "crm分公司管理信息-分公司管理解冻冻结", businessType = BusinessType.UPDATE) + @ApiOperation(value = "分公司管理解冻冻结",notes = "状态 1=使用中 2=冻结") + @PutMapping(value = "/thawOrFreeze") + public R<Boolean> thawOrFreeze(@RequestParam(value = "id")String id, + @RequestParam(value = "status")Integer status) { + TCrmBranch crmBranch = crmBranchService.getById(id); + crmBranch.setStatus(status); + crmBranchService.updateById(crmBranch); + // 查询用户 + SysUser sysUser = sysUserService.selectUserById(crmBranch.getUserId()); + switch (status){ + case 1: + // 解冻 + sysUser.setStatus("0"); + sysUserService.updateUser(sysUser); + break; + case 2: + // 冻结 + sysUser.setStatus("1"); + sysUserService.updateUser(sysUser); + break; + } + return R.ok(); + } + + /** + * 批量删除crm分公司管理 + */ + @Log(title = "crm分公司管理信息-分公司管理修改积分", businessType = BusinessType.DELETE) + @ApiOperation(value = "分公司管理修改积分") + @PutMapping(value = "/changePoints") + public R<Boolean> changePoints(@RequestBody TCrmChangePoints changePoints) { + // 查询分公司信息 + TCrmBranch crmBranch = crmBranchService.getById(changePoints.getBranchSalespersonId()); + if (Objects.isNull(crmBranch)) { + return R.fail("未查询到该分公司"); + } + switch (changePoints.getChangeType()){ + case 1: + // 增加积分 + crmBranch.setUserPoints(crmBranch.getUserPoints() + changePoints.getChangeValue()); + break; + case 2: + // 减少积分 + if (crmBranch.getUserPoints() < changePoints.getChangeValue()) { + return R.fail("操作失败,剩余积分数不足"); + } + crmBranch.setUserPoints(crmBranch.getUserPoints() - changePoints.getChangeValue()); + break; + } + crmBranchService.updateById(crmBranch); + changePoints.setUserType(1); + crmChangePointsService.save(changePoints); + return R.ok(); + } } -- Gitblit v1.7.1