From 7ea8d1c6da749da69516f47593ae47546a0d3d4c Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期一, 16 十二月 2024 11:36:46 +0800
Subject: [PATCH] 微信登陆

---
 manage/src/main/java/com/jilongda/manage/controller/TWarehousingController.java |   90 ++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 88 insertions(+), 2 deletions(-)

diff --git a/manage/src/main/java/com/jilongda/manage/controller/TWarehousingController.java b/manage/src/main/java/com/jilongda/manage/controller/TWarehousingController.java
index dfd4ff4..5ab8ca9 100644
--- a/manage/src/main/java/com/jilongda/manage/controller/TWarehousingController.java
+++ b/manage/src/main/java/com/jilongda/manage/controller/TWarehousingController.java
@@ -1,9 +1,30 @@
 package com.jilongda.manage.controller;
 
 
-import org.springframework.web.bind.annotation.RequestMapping;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.jilongda.common.basic.ApiResult;
+import com.jilongda.common.basic.PageInfo;
+import com.jilongda.common.constants.WarehousingConstant;
+import com.jilongda.common.enums.WarehousingTypeEnum;
+import com.jilongda.common.security.JwtTokenUtils;
+import com.jilongda.common.utils.CodeGenerateUtils;
+import com.jilongda.manage.dto.TWarehousingDTO;
+import com.jilongda.manage.model.TFrameWarehousingDetail;
+import com.jilongda.manage.model.TWarehousing;
+import com.jilongda.manage.query.TWarehousingDetailQuery;
+import com.jilongda.manage.service.TFrameWarehousingDetailService;
+import com.jilongda.manage.service.TWarehousingService;
+import com.jilongda.manage.vo.TFrameWarehousingDetailVO;
+import com.jilongda.manage.vo.TWarehousingVO;
+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 org.springframework.web.bind.annotation.RestController;
+import java.time.LocalDateTime;
+import java.util.List;
 
 /**
  * <p>
@@ -13,9 +34,74 @@
  * @author 无关风月
  * @since 2024-12-09
  */
+@Api(tags = "镜架/镜片出库入库")
 @RestController
 @RequestMapping("/t-warehousing")
 public class TWarehousingController {
 
+    @Autowired
+    private TWarehousingService warehousingService;
+    @Autowired
+    private TFrameWarehousingDetailService frameWarehousingDetailService;
+
+    /**
+     * 出入库单列表
+     */
+    @ApiOperation(value = "镜架出入库单列表")
+    @PostMapping(value = "/inventoryReceiptList")
+    public ApiResult<PageInfo<TWarehousingVO>> inventoryReceiptList(@RequestBody TWarehousingDetailQuery query) {
+        return ApiResult.success(warehousingService.inventoryReceiptList(query));
+    }
+
+    /**
+     * 库存明细记录列表
+     */
+    @ApiOperation(value = "镜架库存明细记录列表")
+    @PostMapping(value = "/detailList")
+    public ApiResult<PageInfo<TFrameWarehousingDetailVO>> detailList(@RequestBody TWarehousingDetailQuery query) {
+        PageInfo<TFrameWarehousingDetailVO> frameWarehousingDetailVOPageInfo = warehousingService.detailList(query);
+        return ApiResult.success(frameWarehousingDetailVOPageInfo);
+    }
+
+    /**
+     * 添加镜架出库,入库,作废,退货
+     */
+    @ApiOperation(value = "添加镜架出库,入库,作废,退货")
+    @PostMapping(value = "/outBound")
+    public ApiResult<String> outBound(@Validated @RequestBody TWarehousingDTO dto) {
+        // 获取当前用户
+        String username = JwtTokenUtils.getUsername();
+        dto.setCreateBy(username);
+        dto.setCreateTime(LocalDateTime.now());
+        dto.setType(WarehousingTypeEnum.FRAME.getCode());
+        warehousingService.save(dto);
+
+        // 添加明细
+        List<TFrameWarehousingDetail> frameWarehousingDetails = dto.getFrameWarehousingDetails();
+        frameWarehousingDetails.forEach(detail -> {
+            detail.setWarehousingId(dto.getId());
+            detail.setCode(WarehousingConstant.OUT_BOUND+CodeGenerateUtils.generateVolumeSn());
+        });
+        frameWarehousingDetailService.saveBatch(frameWarehousingDetails);
+        return ApiResult.success();
+    }
+
+    /**
+     * 查询详情
+     */
+    @ApiOperation(value = "镜架查询详情")
+    @GetMapping(value = "/getDetailById")
+    public ApiResult<TWarehousingVO> getDetailById(@RequestParam Integer id) {
+        TWarehousing warehousing = warehousingService.getById(id);
+        TWarehousingVO vo = new TWarehousingVO();
+        BeanUtils.copyProperties(warehousing, vo);
+        List<TFrameWarehousingDetail> list = frameWarehousingDetailService.list(Wrappers.lambdaQuery(TFrameWarehousingDetail.class)
+                .eq(TFrameWarehousingDetail::getWarehousingId, id));
+        vo.setFrameWarehousingDetails(list);
+        // 统计数量
+        vo.setTotalNum(list.stream().mapToInt(TFrameWarehousingDetail::getTotal).sum());
+        return ApiResult.success(vo);
+    }
+
 }
 

--
Gitblit v1.7.1