From 4955cdc73d9beb5733aa2c0a578c14798394fa61 Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期二, 23 九月 2025 18:06:45 +0800 Subject: [PATCH] AI对接 --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmWarehouseController.java | 178 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 176 insertions(+), 2 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmWarehouseController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmWarehouseController.java index 92e4453..377f98a 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmWarehouseController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCrmWarehouseController.java @@ -1,8 +1,33 @@ package com.ruoyi.web.controller.api; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RestController; +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.TCrmWarehouseDTO; +import com.ruoyi.system.model.TCrmSupplier; +import com.ruoyi.system.model.TCrmSupplierToWarehouse; +import com.ruoyi.system.model.TCrmWarehouse; +import com.ruoyi.system.query.TCrmWarehouseQuery; +import com.ruoyi.system.service.ISysUserService; +import com.ruoyi.system.service.TCrmSupplierService; +import com.ruoyi.system.service.TCrmSupplierToWarehouseService; +import com.ruoyi.system.service.TCrmWarehouseService; +import com.ruoyi.system.vo.TCrmWarehouseVO; +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.util.CollectionUtils; +import org.springframework.validation.annotation.Validated; +import org.springframework.web.bind.annotation.*; + +import java.util.List; +import java.util.stream.Collectors; /** * <p> @@ -12,9 +37,158 @@ * @author xiaochen * @since 2025-08-20 */ +@Api(tags = "crm仓库管理") @RestController @RequestMapping("/t-crm-warehouse") public class TCrmWarehouseController { + private final TCrmWarehouseService crmWarehouseService; + private final ISysUserService sysUserService; + private final TokenService tokenService; + private final TCrmSupplierToWarehouseService crmSupplierToWarehouseService; + private final TCrmSupplierService crmSupplierService; + @Autowired + public TCrmWarehouseController(TCrmWarehouseService crmWarehouseService, ISysUserService sysUserService, TokenService tokenService, TCrmSupplierToWarehouseService crmSupplierToWarehouseService, TCrmSupplierService crmSupplierService) { + this.crmWarehouseService = crmWarehouseService; + this.sysUserService = sysUserService; + this.tokenService = tokenService; + this.crmSupplierToWarehouseService = crmSupplierToWarehouseService; + this.crmSupplierService = crmSupplierService; + } + + /** + * 获取crm仓库管理管理列表 + */ + @ApiOperation(value = "获取crm仓库管理分页列表") + @PostMapping(value = "/pageList") + public R<PageInfo<TCrmWarehouseVO>> pageList(@RequestBody TCrmWarehouseQuery query) { + return R.ok(crmWarehouseService.pageList(query)); + } + + /** + * 获取crm仓库管理管理列表 + */ + @ApiOperation(value = "获取crm仓库管理列表") + @PostMapping(value = "/list") + public R<List<TCrmWarehouse>> list() { + return R.ok(crmWarehouseService.list(Wrappers.lambdaQuery(TCrmWarehouse.class) + .eq(TCrmWarehouse::getStatus,1) + .orderByDesc(TCrmWarehouse::getCreateTime))); + } + + /** + * 获取crm仓库管理管理列表 + */ + @ApiOperation(value = "获取crm供应商下的仓库管理列表") + @PostMapping(value = "/listBySupplierId") + public R<List<TCrmWarehouse>> listBySupplierId() { + Integer roleType = tokenService.getLoginUser().getUser().getRoleType(); + Long userId = tokenService.getLoginUser().getUserId(); + if(roleType == 4){ + TCrmSupplier crmSupplier = crmSupplierService.getOne(Wrappers.lambdaQuery(TCrmSupplier.class) + .eq(TCrmSupplier::getUserId, userId) + .last("LIMIT 1")); + List<TCrmSupplierToWarehouse> list = crmSupplierToWarehouseService.list(Wrappers.lambdaQuery(TCrmSupplierToWarehouse.class) + .eq(TCrmSupplierToWarehouse::getSupplierId, crmSupplier.getId())); + if(CollectionUtils.isEmpty(list)){ + return R.ok(); + } + List<String> warehouseIds = list.stream().map(TCrmSupplierToWarehouse::getWarehouseId).collect(Collectors.toList()); + List<TCrmWarehouse> crmWarehouseList = crmWarehouseService.list(Wrappers.lambdaQuery(TCrmWarehouse.class) + .eq(TCrmWarehouse::getStatus, 1) + .in(TCrmWarehouse::getId, warehouseIds) + .orderByDesc(TCrmWarehouse::getCreateTime)); + return R.ok(crmWarehouseList); + } + return R.ok(); + } + + /** + * 添加crm仓库管理管理 + */ + @Log(title = "crm仓库管理信息-新增crm仓库管理", businessType = BusinessType.INSERT) + @ApiOperation(value = "添加crm仓库管理") + @PostMapping(value = "/add") + public R<Boolean> add(@Validated @RequestBody TCrmWarehouseDTO dto) { + return crmWarehouseService.addWarehouse(dto); + } + + /** + * 修改crm仓库管理 + */ + @Log(title = "crm仓库管理信息-修改crm仓库管理", businessType = BusinessType.UPDATE) + @ApiOperation(value = "修改crm仓库管理") + @PostMapping(value = "/update") + public R<Boolean> update(@Validated @RequestBody TCrmWarehouseDTO dto) { + return crmWarehouseService.updateWarehouse(dto); + } + + /** + * 查看crm仓库管理详情 + */ + @ApiOperation(value = "查看crm仓库管理详情") + @GetMapping(value = "/getDetailById") + public R<TCrmWarehouseVO> getDetailById(@RequestParam String id) { + TCrmWarehouse crmSupplier = crmWarehouseService.getById(id); + TCrmWarehouseVO crmSupplierVO = new TCrmWarehouseVO(); + BeanUtils.copyProperties(crmSupplier, crmSupplierVO); + return R.ok(crmSupplierVO); + } + + /** + * 删除crm仓库管理 + */ + @Log(title = "crm仓库管理信息-删除crm仓库管理", businessType = BusinessType.DELETE) + @ApiOperation(value = "删除crm仓库管理") + @DeleteMapping(value = "/deleteById") + public R<Boolean> deleteById(@RequestParam String id) { + // 删除账号 + TCrmWarehouse crmWarehouse = crmWarehouseService.getById(id); + sysUserService.deleteUserById(crmWarehouse.getUserId()); + return R.ok(crmWarehouseService.removeById(id)); + } + + /** + * 批量删除crm仓库管理 + */ + @Log(title = "crm仓库管理信息-删除crm仓库管理", businessType = BusinessType.DELETE) + @ApiOperation(value = "批量删除crm仓库管理") + @DeleteMapping(value = "/deleteByIds") + public R<Boolean> deleteByIds(@RequestBody List<String> ids) { + // 删除账号 + List<TCrmWarehouse> crmWarehouseList = crmWarehouseService.list(Wrappers.lambdaQuery(TCrmWarehouse.class).in(TCrmWarehouse::getId, ids)); + List<Long> userIds = crmWarehouseList.stream().map(TCrmWarehouse::getUserId).collect(Collectors.toList()); + sysUserService.deleteUserByIds(userIds); + return R.ok(crmWarehouseService.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) { + TCrmWarehouse crmWarehouse = crmWarehouseService.getById(id); + crmWarehouse.setStatus(status); + crmWarehouseService.updateById(crmWarehouse); + // 查询用户 + SysUser sysUser = sysUserService.selectUserById(crmWarehouse.getUserId()); + switch (status){ + case 1: + // 解冻 + sysUser.setStatus("0"); + sysUserService.updateUser(sysUser); + break; + case 2: + // 冻结 + sysUser.setStatus("1"); + sysUserService.updateUser(sysUser); + break; + } + return R.ok(); + } + } -- Gitblit v1.7.1