| package com.doumee.cloud.admin; | 
|   | 
| import cn.emay.sdk.util.StringUtil; | 
| import com.doumee.api.BaseController; | 
| import com.doumee.config.annotation.CloudRequiredPermission; | 
| import com.doumee.core.annotation.excel.ExcelExporter; | 
| import com.doumee.core.annotation.pr.PreventRepeat; | 
| import com.doumee.core.model.ApiResponse; | 
| import com.doumee.core.model.PageWrap; | 
| import com.doumee.core.model.PageData; | 
| import com.doumee.core.utils.Constants; | 
| import com.doumee.dao.business.model.YwOutinbound; | 
| import com.doumee.dao.business.model.YwOutinboundRecord; | 
| import com.doumee.dao.business.vo.YwOutinboundExcelInVO; | 
| import com.doumee.dao.business.vo.YwOutinboundExcelOutVO; | 
| import com.doumee.service.business.YwOutinboundService; | 
| 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.web.bind.annotation.*; | 
| import javax.servlet.http.HttpServletResponse; | 
|   | 
| import java.util.ArrayList; | 
| import java.util.List; | 
|   | 
| /** | 
|  * @author 江蹄蹄 | 
|  * @date 2025/01/06 11:05 | 
|  */ | 
| @Api(tags = "运维出入库信息表") | 
| @RestController | 
| @RequestMapping(Constants.CLOUD_SERVICE_URL_INDEX+"/business/ywOutinbound") | 
| public class YwOutinboundController extends BaseController { | 
|   | 
|     @Autowired | 
|     private YwOutinboundService ywOutinboundService; | 
|   | 
|     @PreventRepeat | 
|     @ApiOperation("新建") | 
|     @PostMapping("/create") | 
|     @CloudRequiredPermission("business:ywoutinbound:create") | 
|     public ApiResponse create(@RequestBody YwOutinbound ywOutinbound,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|         ywOutinbound.setLoginUserInfo(this.getLoginUser(token)); | 
|         return ApiResponse.success(ywOutinboundService.create(ywOutinbound)); | 
|     } | 
|   | 
|     @ApiOperation("根据ID删除") | 
|     @GetMapping("/delete/{id}") | 
|     @CloudRequiredPermission("business:ywoutinbound:delete") | 
|     public ApiResponse deleteById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|         ywOutinboundService.deleteById(id); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("批量删除") | 
|     @GetMapping("/delete/batch") | 
|     @CloudRequiredPermission("business:ywoutinbound:delete") | 
|     public ApiResponse deleteByIdInBatch(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|         String [] idArray = ids.split(","); | 
|         List<Integer> idList = new ArrayList<>(); | 
|         for (String id : idArray) { | 
|             idList.add(Integer.valueOf(id)); | 
|         } | 
|         ywOutinboundService.deleteByIdInBatch(idList); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("根据ID修改") | 
|     @PostMapping("/updateById") | 
|     @CloudRequiredPermission("business:ywoutinbound:update") | 
|     public ApiResponse updateById(@RequestBody YwOutinbound ywOutinbound,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|         ywOutinbound.setLoginUserInfo(this.getLoginUser(token)); | 
|         ywOutinboundService.updateById(ywOutinbound); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("分页查询") | 
|     @PostMapping("/page") | 
|     @CloudRequiredPermission("business:ywoutinbound:query") | 
|     public ApiResponse<PageData<YwOutinbound>> findPage (@RequestBody PageWrap<YwOutinbound> pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|         return ApiResponse.success(ywOutinboundService.findPage(pageWrap)); | 
|     } | 
|   | 
|     @ApiOperation("导出Excel") | 
|     @PostMapping("/exportExcel") | 
|     @CloudRequiredPermission("business:ywoutinbound:exportExcel") | 
|     public void exportExcel (@RequestBody PageWrap<YwOutinbound> pageWrap, HttpServletResponse response,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|         List<YwOutinbound> ywOutinboundList = ywOutinboundService.findPage(pageWrap).getRecords(); | 
|         Integer inOut = pageWrap.getModel().getInOut(); | 
|         if(Constants.equalsInteger(inOut,Constants.ZERO)){ | 
|             List<YwOutinboundExcelInVO> inList = new ArrayList<>(); | 
|             for (YwOutinbound ywOutinbound:ywOutinboundList) { | 
|                 YwOutinboundExcelInVO inVO = new YwOutinboundExcelInVO(); | 
|                 BeanUtils.copyProperties(ywOutinbound,inVO); | 
|                 List<YwOutinboundRecord> ywOutinboundRecordList = ywOutinbound.getRecordList(); | 
|                 StringBuffer stringBuffer = new StringBuffer(); | 
|                 for (YwOutinboundRecord ywOutinboundRecord:ywOutinboundRecordList) { | 
|                     stringBuffer.append(ywOutinboundRecord.getMaterialName()+"["+ywOutinboundRecord.getMaterialCode()+"]*"+ywOutinboundRecord.getStock()+ywOutinboundRecord.getMaterialUnitName()+";"); | 
|                 } | 
|                 inVO.setOutMaterialNum(stringBuffer.toString()); | 
|                 inList.add(inVO); | 
|             } | 
|             ExcelExporter.build(YwOutinboundExcelInVO.class).export(inList, "入库信息表", response); | 
|         }else{ | 
|             List<YwOutinboundExcelOutVO> outList = new ArrayList<>(); | 
|             for (YwOutinbound ywOutinbound:ywOutinboundList) { | 
|                 YwOutinboundExcelOutVO ywOutinboundExcelOutVO = new YwOutinboundExcelOutVO(); | 
|                 BeanUtils.copyProperties(ywOutinbound,ywOutinboundExcelOutVO); | 
|                 List<YwOutinboundRecord> ywOutinboundRecordList = ywOutinbound.getRecordList(); | 
|                 StringBuffer stringBuffer = new StringBuffer(); | 
|                 for (YwOutinboundRecord ywOutinboundRecord:ywOutinboundRecordList) { | 
|                     stringBuffer.append(ywOutinboundRecord.getMaterialName()+"["+ywOutinboundRecord.getMaterialCode()+"]*"+ywOutinboundRecord.getStock()+ywOutinboundRecord.getMaterialUnitName()+";"); | 
|                 } | 
|                 ywOutinboundExcelOutVO.setOutMaterialNum(stringBuffer.toString()); | 
|                 outList.add(ywOutinboundExcelOutVO); | 
|             } | 
|             ExcelExporter.build(YwOutinboundExcelOutVO.class).export(outList, "出库信息表", response); | 
|         } | 
|     } | 
|   | 
|     @ApiOperation("根据ID查询") | 
|     @GetMapping("/{id}") | 
|     @CloudRequiredPermission("business:ywoutinbound:query") | 
|     public ApiResponse findById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) { | 
|         return ApiResponse.success(ywOutinboundService.getDetail(id)); | 
|     } | 
| } |