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));
|
}
|
}
|