package com.jsh.erp.controller; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.jsh.erp.constants.BusinessConstants; import com.jsh.erp.constants.ExceptionConstants; import com.jsh.erp.datasource.entities.DepotHead; import com.jsh.erp.datasource.entities.DepotHeadVo4Body; import com.jsh.erp.datasource.entities.Supplier; import com.jsh.erp.datasource.vo.DepotHeadVo4InDetail; import com.jsh.erp.datasource.vo.DepotHeadVo4InOutMCount; import com.jsh.erp.datasource.vo.DepotHeadVo4List; import com.jsh.erp.datasource.vo.DepotHeadVo4StatementAccount; import com.jsh.erp.exception.BusinessParamCheckingException; import com.jsh.erp.service.accountHead.AccountHeadService; import com.jsh.erp.service.depot.DepotService; import com.jsh.erp.service.depotHead.DepotHeadService; import com.jsh.erp.service.log.LogService; import com.jsh.erp.service.redis.RedisService; import com.jsh.erp.service.supplier.SupplierService; import com.jsh.erp.utils.*; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import java.math.BigDecimal; import java.sql.Date; import java.text.DecimalFormat; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import static com.jsh.erp.utils.ResponseJsonUtil.returnJson; import static com.jsh.erp.utils.Tools.getNow3; /** * @author ji-sheng-hua 752*718*920 */ @RestController @RequestMapping(value = "/depotHead") @Api(tags = {"单据管理"}) public class DepotHeadController { private Logger logger = LoggerFactory.getLogger(DepotHeadController.class); @Resource private DepotHeadService depotHeadService; @Resource private DepotService depotService; @Resource private RedisService redisService; /** * 批量设置状态-审核或者反审核 * @param jsonObject * @param request * @return */ @PostMapping(value = "/batchSetStatus") @ApiOperation(value = "批量设置状态-审核或者反审核") public String batchSetStatus(@RequestBody JSONObject jsonObject, HttpServletRequest request) throws Exception{ Map objectMap = new HashMap<>(); String status = jsonObject.getString("status"); String ids = jsonObject.getString("ids"); int res = depotHeadService.batchSetStatus(status, ids); if(res > 0) { return returnJson(objectMap, ErpInfo.OK.name, ErpInfo.OK.code); } else { return returnJson(objectMap, ErpInfo.ERROR.name, ErpInfo.ERROR.code); } } /** * 入库出库明细接口 * @param currentPage * @param pageSize * @param oId * @param number * @param materialParam * @param depotId * @param beginTime * @param endTime * @param type * @param request * @return */ @GetMapping(value = "/findInDetail") @ApiOperation(value = "入库出库明细接口") public BaseResponseInfo findInDetail(@RequestParam("currentPage") Integer currentPage, @RequestParam("pageSize") Integer pageSize, @RequestParam(value = "organId", required = false) Integer oId, @RequestParam("number") String number, @RequestParam("materialParam") String materialParam, @RequestParam(value = "depotId", required = false) Long depotId, @RequestParam("beginTime") String beginTime, @RequestParam("endTime") String endTime, @RequestParam(value = "roleType", required = false) String roleType, @RequestParam("type") String type, @RequestParam(value = "subType",required = false) String subType, @RequestParam("remark") String remark, HttpServletRequest request)throws Exception { BaseResponseInfo res = new BaseResponseInfo(); Map map = new HashMap(); try { List depotList = new ArrayList<>(); if(depotId != null) { depotList.add(depotId); } else { //未选择仓库时默认为当前用户有权限的仓库 JSONArray depotArr = depotService.findDepotByCurrentUser(); for(Object obj: depotArr) { JSONObject object = JSONObject.parseObject(obj.toString()); depotList.add(object.getLong("id")); } } List resList = new ArrayList(); String [] creatorArray = depotHeadService.getCreatorArray(roleType); String [] organArray = depotHeadService.getOrganArray(subType, ""); beginTime = Tools.parseDayToTime(beginTime, BusinessConstants.DAY_FIRST_TIME); endTime = Tools.parseDayToTime(endTime,BusinessConstants.DAY_LAST_TIME); List list = depotHeadService.findByAll(beginTime, endTime, type, creatorArray, organArray, materialParam, depotList, oId, number, remark, (currentPage-1)*pageSize, pageSize); int total = depotHeadService.findByAllCount(beginTime, endTime, type, creatorArray, organArray, materialParam, depotList, oId, number, remark); map.put("total", total); //存放数据json数组 if (null != list) { for (DepotHeadVo4InDetail dhd : list) { resList.add(dhd); } } map.put("rows", resList); res.code = 200; res.data = map; } catch(Exception e){ e.printStackTrace(); res.code = 500; res.data = "获取数据失败"; } return res; } /** * 入库出库统计接口 * @param currentPage * @param pageSize * @param oId * @param materialParam * @param depotId * @param beginTime * @param endTime * @param type * @param request * @return */ @GetMapping(value = "/findInOutMaterialCount") @ApiOperation(value = "入库出库统计接口") public BaseResponseInfo findInOutMaterialCount(@RequestParam("currentPage") Integer currentPage, @RequestParam("pageSize") Integer pageSize, @RequestParam(value = "organId", required = false) Integer oId, @RequestParam("materialParam") String materialParam, @RequestParam(value = "depotId", required = false) Long depotId, @RequestParam("beginTime") String beginTime, @RequestParam("endTime") String endTime, @RequestParam("type") String type, @RequestParam(value = "roleType", required = false) String roleType, HttpServletRequest request)throws Exception { BaseResponseInfo res = new BaseResponseInfo(); Map map = new HashMap(); try { List depotList = new ArrayList<>(); if(depotId != null) { depotList.add(depotId); } else { //未选择仓库时默认为当前用户有权限的仓库 JSONArray depotArr = depotService.findDepotByCurrentUser(); for(Object obj: depotArr) { JSONObject object = JSONObject.parseObject(obj.toString()); depotList.add(object.getLong("id")); } } beginTime = Tools.parseDayToTime(beginTime,BusinessConstants.DAY_FIRST_TIME); endTime = Tools.parseDayToTime(endTime,BusinessConstants.DAY_LAST_TIME); List list = depotHeadService.findInOutMaterialCount(beginTime, endTime, type, StringUtil.toNull(materialParam), depotList, oId, roleType, (currentPage-1)*pageSize, pageSize); int total = depotHeadService.findInOutMaterialCountTotal(beginTime, endTime, type, StringUtil.toNull(materialParam), depotList, oId, roleType); map.put("total", total); map.put("rows", list); res.code = 200; res.data = map; } catch(Exception e){ e.printStackTrace(); res.code = 500; res.data = "获取数据失败"; } return res; } /** * 调拨明细统计 * @param currentPage * @param pageSize * @param number * @param materialParam * @param depotIdF 调出仓库 * @param depotId 调入仓库 * @param beginTime * @param endTime * @param subType * @param request * @return */ @GetMapping(value = "/findAllocationDetail") @ApiOperation(value = "调拨明细统计") public BaseResponseInfo findallocationDetail(@RequestParam("currentPage") Integer currentPage, @RequestParam("pageSize") Integer pageSize, @RequestParam("number") String number, @RequestParam("materialParam") String materialParam, @RequestParam(value = "depotId", required = false) Long depotId, @RequestParam(value = "depotIdF", required = false) Long depotIdF, @RequestParam("beginTime") String beginTime, @RequestParam("endTime") String endTime, @RequestParam("subType") String subType, @RequestParam(value = "roleType", required = false) String roleType, @RequestParam("remark") String remark, HttpServletRequest request)throws Exception { BaseResponseInfo res = new BaseResponseInfo(); Map map = new HashMap(); try { List depotList = new ArrayList<>(); List depotFList = new ArrayList<>(); if(depotId != null) { depotList.add(depotId); } else { //未选择仓库时默认为当前用户有权限的仓库 JSONArray depotArr = depotService.findDepotByCurrentUser(); for(Object obj: depotArr) { JSONObject object = JSONObject.parseObject(obj.toString()); depotList.add(object.getLong("id")); } } if(depotIdF != null) { depotFList.add(depotIdF); } else { //未选择仓库时默认为当前用户有权限的仓库 JSONArray depotArr = depotService.findDepotByCurrentUser(); for(Object obj: depotArr) { JSONObject object = JSONObject.parseObject(obj.toString()); depotFList.add(object.getLong("id")); } } String [] creatorArray = depotHeadService.getCreatorArray(roleType); beginTime = Tools.parseDayToTime(beginTime, BusinessConstants.DAY_FIRST_TIME); endTime = Tools.parseDayToTime(endTime,BusinessConstants.DAY_LAST_TIME); List list = depotHeadService.findAllocationDetail(beginTime, endTime, subType, number, creatorArray, materialParam, depotList, depotFList, remark, (currentPage-1)*pageSize, pageSize); int total = depotHeadService.findAllocationDetailCount(beginTime, endTime, subType, number, creatorArray, materialParam, depotList, depotFList, remark); map.put("rows", list); map.put("total", total); res.code = 200; res.data = map; } catch(Exception e){ e.printStackTrace(); res.code = 500; res.data = "获取数据失败"; } return res; } /** * 对账单接口 * @param currentPage * @param pageSize * @param beginTime * @param endTime * @param organId * @param supplierType * @param request * @return */ @GetMapping(value = "/getStatementAccount") @ApiOperation(value = "对账单接口") public BaseResponseInfo getStatementAccount(@RequestParam("currentPage") Integer currentPage, @RequestParam("pageSize") Integer pageSize, @RequestParam("beginTime") String beginTime, @RequestParam("endTime") String endTime, @RequestParam(value = "organId", required = false) Integer organId, @RequestParam("supplierType") String supplierType, HttpServletRequest request) throws Exception{ BaseResponseInfo res = new BaseResponseInfo(); Map map = new HashMap(); try { String type = ""; String subType = ""; if (("供应商").equals(supplierType)) { type = "入库"; subType = "采购"; } else if (("客户").equals(supplierType)) { type = "出库"; subType = "销售"; } String [] organArray = depotHeadService.getOrganArray(subType, ""); beginTime = Tools.parseDayToTime(beginTime,BusinessConstants.DAY_FIRST_TIME); endTime = Tools.parseDayToTime(endTime,BusinessConstants.DAY_LAST_TIME); List list = depotHeadService.getStatementAccount(beginTime, endTime, organId, organArray, supplierType, type, subType, (currentPage-1)*pageSize, pageSize); int total = depotHeadService.getStatementAccountCount(beginTime, endTime, organId, organArray, supplierType, type, subType); for(DepotHeadVo4StatementAccount item: list) { BigDecimal preNeed = item.getBeginNeed().add(item.getPreDebtMoney()).subtract(item.getPreBackMoney()); item.setPreNeed(preNeed); BigDecimal allNeedGet = preNeed.add(item.getDebtMoney()).subtract(item.getBackMoney()); item.setAllNeed(allNeedGet); } map.put("rows", list); map.put("total", total); List totalPayList = depotHeadService.getStatementAccountTotalPay(beginTime, endTime, organId, organArray, supplierType, type, subType); if(totalPayList.size()>0) { DepotHeadVo4StatementAccount totalPayItem = totalPayList.get(0); BigDecimal firstMoney = BigDecimal.ZERO; BigDecimal lastMoney = BigDecimal.ZERO; if(totalPayItem!=null) { firstMoney = totalPayItem.getBeginNeed().add(totalPayItem.getPreDebtMoney()).subtract(totalPayItem.getPreBackMoney()); lastMoney = firstMoney.add(totalPayItem.getDebtMoney()).subtract(totalPayItem.getBackMoney()); } map.put("firstMoney", firstMoney); //期初 map.put("lastMoney", lastMoney); //期末 } res.code = 200; res.data = map; } catch(Exception e){ e.printStackTrace(); res.code = 500; res.data = "获取数据失败"; } return res; } /** * 根据编号查询单据信息 * @param number * @param request * @return */ @GetMapping(value = "/getDetailByNumber") @ApiOperation(value = "根据编号查询单据信息") public BaseResponseInfo getDetailByNumber(@RequestParam("number") String number, HttpServletRequest request)throws Exception { BaseResponseInfo res = new BaseResponseInfo(); DepotHeadVo4List dhl = new DepotHeadVo4List(); try { List list = depotHeadService.getDetailByNumber(number); if(list.size() == 1) { dhl = list.get(0); } res.code = 200; res.data = dhl; } catch(Exception e){ e.printStackTrace(); res.code = 500; res.data = "获取数据失败"; } return res; } /** * 新增单据主表及单据子表信息 * @param body * @param request * @return * @throws Exception */ @PostMapping(value = "/addDepotHeadAndDetail") @ApiOperation(value = "新增单据主表及单据子表信息") public Object addDepotHeadAndDetail(@RequestBody DepotHeadVo4Body body, HttpServletRequest request) throws Exception{ JSONObject result = ExceptionConstants.standardSuccess(); String beanJson = body.getInfo(); String rows = body.getRows(); depotHeadService.addDepotHeadAndDetail(beanJson, rows, request); return result; } /** * 更新单据主表及单据子表信息 * @param body * @param request * @return * @throws Exception */ @PutMapping(value = "/updateDepotHeadAndDetail") @ApiOperation(value = "更新单据主表及单据子表信息") public Object updateDepotHeadAndDetail(@RequestBody DepotHeadVo4Body body, HttpServletRequest request) throws Exception{ JSONObject result = ExceptionConstants.standardSuccess(); String beanJson = body.getInfo(); String rows = body.getRows(); depotHeadService.updateDepotHeadAndDetail(beanJson,rows,request); return result; } /** * 统计今日采购额、昨日采购额、本月采购额、今年采购额|销售额|零售额 * @param request * @return */ @GetMapping(value = "/getBuyAndSaleStatistics") @ApiOperation(value = "统计今日采购额、昨日采购额、本月采购额、今年采购额|销售额|零售额") public BaseResponseInfo getBuyAndSaleStatistics(@RequestParam(value = "roleType", required = false) String roleType, HttpServletRequest request) { BaseResponseInfo res = new BaseResponseInfo(); try { String today = Tools.getNow() + BusinessConstants.DAY_FIRST_TIME; String monthFirstDay = Tools.firstDayOfMonth(Tools.getCurrentMonth()) + BusinessConstants.DAY_FIRST_TIME; String yesterdayBegin = Tools.getYesterday() + BusinessConstants.DAY_FIRST_TIME; String yesterdayEnd = Tools.getYesterday() + BusinessConstants.DAY_LAST_TIME; String yearBegin = Tools.getYearBegin() + BusinessConstants.DAY_FIRST_TIME; String yearEnd = Tools.getYearEnd() + BusinessConstants.DAY_LAST_TIME; Map map = depotHeadService.getBuyAndSaleStatistics(today, monthFirstDay, yesterdayBegin, yesterdayEnd, yearBegin, yearEnd, roleType); res.code = 200; res.data = map; } catch(Exception e){ e.printStackTrace(); res.code = 500; res.data = "获取数据失败"; } return res; } /** * 根据当前用户获取操作员数组,用于控制当前用户的数据权限,限制可以看到的单据范围 * 注意:该接口提供给部分插件使用,勿删 * @param request * @return */ @GetMapping(value = "/getCreatorByCurrentUser") @ApiOperation(value = "根据当前用户获取操作员数组") public BaseResponseInfo getCreatorByRoleType(HttpServletRequest request) { BaseResponseInfo res = new BaseResponseInfo(); Map map = new HashMap(); try { String creator = ""; String roleType = redisService.getObjectFromSessionByKey(request,"roleType").toString(); if(StringUtil.isNotEmpty(roleType)) { creator = depotHeadService.getCreatorByRoleType(roleType); } res.code = 200; res.data = creator; } catch (Exception e) { e.printStackTrace(); res.code = 500; res.data = "获取数据失败"; } return res; } /** * 查询存在欠款的单据 * @param search * @param request * @return * @throws Exception */ @GetMapping(value = "/debtList") @ApiOperation(value = "查询存在欠款的单据") public String debtList(@RequestParam(value = Constants.SEARCH, required = false) String search, HttpServletRequest request)throws Exception { Map objectMap = new HashMap<>(); String organIdStr = StringUtil.getInfo(search, "organId"); Long organId = Long.parseLong(organIdStr); String materialParam = StringUtil.getInfo(search, "materialParam"); String number = StringUtil.getInfo(search, "number"); String beginTime = StringUtil.getInfo(search, "beginTime"); String endTime = StringUtil.getInfo(search, "endTime"); String type = StringUtil.getInfo(search, "type"); String subType = StringUtil.getInfo(search, "subType"); String roleType = StringUtil.getInfo(search, "roleType"); String status = StringUtil.getInfo(search, "status"); List list = depotHeadService.debtList(organId, materialParam, number, beginTime, endTime, type, subType, roleType, status); if (list != null) { objectMap.put("rows", list); return returnJson(objectMap, ErpInfo.OK.name, ErpInfo.OK.code); } else { objectMap.put("rows", new ArrayList<>()); return returnJson(objectMap, "查找不到数据", ErpInfo.OK.code); } } }