| package com.jsh.erp.service.accountHead; | 
|   | 
| 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.*; | 
| import com.jsh.erp.datasource.mappers.AccountHeadMapper; | 
| import com.jsh.erp.datasource.mappers.AccountHeadMapperEx; | 
| import com.jsh.erp.datasource.mappers.AccountItemMapperEx; | 
| import com.jsh.erp.datasource.mappers.AccountMapper; | 
| import com.jsh.erp.exception.BusinessRunTimeException; | 
| import com.jsh.erp.exception.JshException; | 
| import com.jsh.erp.service.accountItem.AccountItemService; | 
| import com.jsh.erp.service.depotHead.DepotHeadService; | 
| import com.jsh.erp.service.log.LogService; | 
| import com.jsh.erp.service.orgaUserRel.OrgaUserRelService; | 
| import com.jsh.erp.service.supplier.SupplierService; | 
| import com.jsh.erp.service.systemConfig.SystemConfigService; | 
| import com.jsh.erp.service.user.UserService; | 
| import com.jsh.erp.utils.StringUtil; | 
| import com.jsh.erp.utils.Tools; | 
| import org.slf4j.Logger; | 
| import org.slf4j.LoggerFactory; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.transaction.annotation.Transactional; | 
| import org.springframework.web.context.request.RequestContextHolder; | 
| import org.springframework.web.context.request.ServletRequestAttributes; | 
|   | 
| import javax.annotation.Resource; | 
| import javax.servlet.http.HttpServletRequest; | 
| import java.math.BigDecimal; | 
| import java.util.ArrayList; | 
| import java.util.Date; | 
| import java.util.List; | 
|   | 
| import static com.jsh.erp.utils.Tools.getCenternTime; | 
|   | 
| @Service | 
| public class AccountHeadService { | 
|     private Logger logger = LoggerFactory.getLogger(AccountHeadService.class); | 
|     @Resource | 
|     private AccountHeadMapper accountHeadMapper; | 
|     @Resource | 
|     private AccountHeadMapperEx accountHeadMapperEx; | 
|     @Resource | 
|     private OrgaUserRelService orgaUserRelService; | 
|     @Resource | 
|     private AccountItemService accountItemService; | 
|     @Resource | 
|     private UserService userService; | 
|     @Resource | 
|     private SupplierService supplierService; | 
|     @Resource | 
|     private SystemConfigService systemConfigService; | 
|     @Resource | 
|     private LogService logService; | 
|     @Resource | 
|     private AccountItemMapperEx accountItemMapperEx; | 
|     @Resource | 
|     private AccountMapper accountMapper; | 
|   | 
|     public AccountHead getAccountHead(long id) throws Exception { | 
|         AccountHead result=null; | 
|         try{ | 
|             result=accountHeadMapper.selectByPrimaryKey(id); | 
|         }catch(Exception e){ | 
|             JshException.readFail(logger, e); | 
|         } | 
|         return result; | 
|     } | 
|   | 
|     public List<AccountHead> getAccountHeadListByIds(String ids)throws Exception { | 
|         List<Long> idList = StringUtil.strToLongList(ids); | 
|         List<AccountHead> list = new ArrayList<>(); | 
|         try{ | 
|             AccountHeadExample example = new AccountHeadExample(); | 
|             example.createCriteria().andIdIn(idList); | 
|             list = accountHeadMapper.selectByExample(example); | 
|         }catch(Exception e){ | 
|             JshException.readFail(logger, e); | 
|         } | 
|         return list; | 
|     } | 
|   | 
|     public List<AccountHead> getAccountHead() throws Exception{ | 
|         AccountHeadExample example = new AccountHeadExample(); | 
|         List<AccountHead> list=null; | 
|         try{ | 
|             list=accountHeadMapper.selectByExample(example); | 
|         }catch(Exception e){ | 
|             JshException.readFail(logger, e); | 
|         } | 
|         return list; | 
|     } | 
|   | 
|     public List<AccountHeadVo4ListEx> select(String type, String billNo, String beginTime, String endTime, | 
|                                              Long organId, Long creator, Long handsPersonId, Long accountId, String status, | 
|                                              String remark, String number, int offset, int rows) throws Exception{ | 
|         List<AccountHeadVo4ListEx> resList = new ArrayList<>(); | 
|         try{ | 
|             String [] creatorArray = getCreatorArray(); | 
|             beginTime = Tools.parseDayToTime(beginTime,BusinessConstants.DAY_FIRST_TIME); | 
|             endTime = Tools.parseDayToTime(endTime,BusinessConstants.DAY_LAST_TIME); | 
|             List<AccountHeadVo4ListEx> list = accountHeadMapperEx.selectByConditionAccountHead(type, creatorArray, billNo, | 
|                     beginTime, endTime, organId, creator, handsPersonId, accountId, status, remark, number, offset, rows); | 
|             if (null != list) { | 
|                 for (AccountHeadVo4ListEx ah : list) { | 
|                     if(ah.getChangeAmount() != null) { | 
|                         if(BusinessConstants.TYPE_MONEY_IN.equals(ah.getType())) { | 
|                             ah.setChangeAmount(ah.getChangeAmount()); | 
|                         } else if(BusinessConstants.TYPE_MONEY_OUT.equals(ah.getType())) { | 
|                             ah.setChangeAmount(BigDecimal.ZERO.subtract(ah.getChangeAmount())); | 
|                         } else { | 
|                             ah.setChangeAmount(ah.getChangeAmount().abs()); | 
|                         } | 
|                     } | 
|                     if(ah.getTotalPrice() != null) { | 
|                         if(BusinessConstants.TYPE_MONEY_IN.equals(ah.getType())) { | 
|                             ah.setTotalPrice(ah.getTotalPrice()); | 
|                         } else if(BusinessConstants.TYPE_MONEY_OUT.equals(ah.getType())) { | 
|                             ah.setTotalPrice(BigDecimal.ZERO.subtract(ah.getTotalPrice())); | 
|                         } else { | 
|                             ah.setTotalPrice(ah.getTotalPrice().abs()); | 
|                         } | 
|                     } | 
|                     if(ah.getBillTime() !=null) { | 
|                         ah.setBillTimeStr(getCenternTime(ah.getBillTime())); | 
|                     } | 
|                     resList.add(ah); | 
|                 } | 
|             } | 
|         }catch(Exception e){ | 
|             JshException.readFail(logger, e); | 
|         } | 
|         return resList; | 
|     } | 
|   | 
|     public Long countAccountHead(String type, String billNo, String beginTime, String endTime, | 
|                                  Long organId, Long creator, Long handsPersonId, Long accountId, String status, | 
|                                  String remark, String number) throws Exception{ | 
|         Long result=null; | 
|         try{ | 
|             String [] creatorArray = getCreatorArray(); | 
|             beginTime = Tools.parseDayToTime(beginTime,BusinessConstants.DAY_FIRST_TIME); | 
|             endTime = Tools.parseDayToTime(endTime,BusinessConstants.DAY_LAST_TIME); | 
|             result = accountHeadMapperEx.countsByAccountHead(type, creatorArray, billNo, | 
|                     beginTime, endTime, organId, creator, handsPersonId, accountId, status, remark, number); | 
|         }catch(Exception e){ | 
|             JshException.readFail(logger, e); | 
|         } | 
|         return result; | 
|     } | 
|   | 
|     /** | 
|      * 根据角色类型获取操作员数组 | 
|      * @return | 
|      * @throws Exception | 
|      */ | 
|     private String[] getCreatorArray() throws Exception { | 
|         String creator = ""; | 
|         User user = userService.getCurrentUser(); | 
|         String roleType = userService.getRoleTypeByUserId(user.getId()).getType(); //角色类型 | 
|         if(BusinessConstants.ROLE_TYPE_PRIVATE.equals(roleType)) { | 
|             creator = user.getId().toString(); | 
|         } else if(BusinessConstants.ROLE_TYPE_THIS_ORG.equals(roleType)) { | 
|             creator = orgaUserRelService.getUserIdListByUserId(user.getId()); | 
|         } | 
|         String [] creatorArray=null; | 
|         if(StringUtil.isNotEmpty(creator)){ | 
|             creatorArray = creator.split(","); | 
|         } | 
|         return creatorArray; | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public int insertAccountHead(JSONObject obj, HttpServletRequest request) throws Exception{ | 
|         AccountHead accountHead = JSONObject.parseObject(obj.toJSONString(), AccountHead.class); | 
|         int result=0; | 
|         try{ | 
|             User userInfo=userService.getCurrentUser(); | 
|             accountHead.setCreator(userInfo==null?null:userInfo.getId()); | 
|             result = accountHeadMapper.insertSelective(accountHead); | 
|             logService.insertLog("财务", | 
|                     new StringBuffer(BusinessConstants.LOG_OPERATION_TYPE_ADD).append(accountHead.getBillNo()).toString(), request); | 
|         }catch(Exception e){ | 
|             JshException.writeFail(logger, e); | 
|         } | 
|         return result; | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public int updateAccountHead(JSONObject obj, HttpServletRequest request)throws Exception { | 
|         AccountHead accountHead = JSONObject.parseObject(obj.toJSONString(), AccountHead.class); | 
|         int result=0; | 
|         try{ | 
|             result = accountHeadMapper.updateByPrimaryKeySelective(accountHead); | 
|             logService.insertLog("财务", | 
|                     new StringBuffer(BusinessConstants.LOG_OPERATION_TYPE_EDIT).append(accountHead.getBillNo()).toString(), request); | 
|         }catch(Exception e){ | 
|             JshException.writeFail(logger, e); | 
|         } | 
|         return result; | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public int deleteAccountHead(Long id, HttpServletRequest request)throws Exception { | 
|         return batchDeleteAccountHeadByIds(id.toString()); | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public int batchDeleteAccountHead(String ids, HttpServletRequest request)throws Exception { | 
|         return batchDeleteAccountHeadByIds(ids); | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public int batchDeleteAccountHeadByIds(String ids)throws Exception { | 
|         StringBuffer sb = new StringBuffer(); | 
|         sb.append(BusinessConstants.LOG_OPERATION_TYPE_DELETE); | 
|         User userInfo=userService.getCurrentUser(); | 
|         String [] idArray=ids.split(","); | 
|         List<AccountHead> list = getAccountHeadListByIds(ids); | 
|         for(AccountHead accountHead: list){ | 
|             if(!"0".equals(accountHead.getStatus())) { | 
|                 throw new BusinessRunTimeException(ExceptionConstants.ACCOUNT_HEAD_UN_AUDIT_DELETE_FAILED_CODE, | 
|                         String.format(ExceptionConstants.ACCOUNT_HEAD_UN_AUDIT_DELETE_FAILED_MSG)); | 
|             } | 
|         } | 
|         //删除主表 | 
|         accountItemMapperEx.batchDeleteAccountItemByHeadIds(new Date(),userInfo==null?null:userInfo.getId(),idArray); | 
|         //删除子表 | 
|         accountHeadMapperEx.batchDeleteAccountHeadByIds(new Date(),userInfo==null?null:userInfo.getId(),idArray); | 
|         //路径列表 | 
|         List<String> pathList = new ArrayList<>(); | 
|         for(AccountHead accountHead: list){ | 
|             sb.append("[").append(accountHead.getBillNo()).append("]"); | 
|             if(StringUtil.isNotEmpty(accountHead.getFileName())) { | 
|                 pathList.add(accountHead.getFileName()); | 
|             } | 
|             if("收预付款".equals(accountHead.getType())){ | 
|                 if (accountHead.getOrganId() != null) { | 
|                     //更新会员预付款 | 
|                     supplierService.updateAdvanceIn(accountHead.getOrganId()); | 
|                 } | 
|             } | 
|         } | 
|         //逻辑删除文件 | 
|         systemConfigService.deleteFileByPathList(pathList); | 
|         logService.insertLog("财务", sb.toString(), | 
|                 ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest()); | 
|         return 1; | 
|     } | 
|   | 
|     /** | 
|      * 校验单据编号是否存在 | 
|      * @param id | 
|      * @param billNo | 
|      * @return | 
|      * @throws Exception | 
|      */ | 
|     public int checkIsBillNoExist(Long id, String billNo)throws Exception { | 
|         AccountHeadExample example = new AccountHeadExample(); | 
|         example.createCriteria().andIdNotEqualTo(id).andBillNoEqualTo(billNo).andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED); | 
|         List<AccountHead> list = null; | 
|         try{ | 
|             list = accountHeadMapper.selectByExample(example); | 
|         }catch(Exception e){ | 
|             JshException.readFail(logger, e); | 
|         } | 
|         return list==null?0:list.size(); | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public int batchSetStatus(String status, String accountHeadIds)throws Exception { | 
|         int result = 0; | 
|         try{ | 
|             List<Long> ahIds = new ArrayList<>(); | 
|             List<Long> ids = StringUtil.strToLongList(accountHeadIds); | 
|             for(Long id: ids) { | 
|                 AccountHead accountHead = getAccountHead(id); | 
|                 if("0".equals(status)){ | 
|                     if("1".equals(accountHead.getStatus())) { | 
|                         ahIds.add(id); | 
|                     } | 
|                 } else if("1".equals(status)){ | 
|                     if("0".equals(accountHead.getStatus())) { | 
|                         ahIds.add(id); | 
|                     } | 
|                 } | 
|             } | 
|             if(ahIds.size()>0) { | 
|                 AccountHead accountHead = new AccountHead(); | 
|                 accountHead.setStatus(status); | 
|                 AccountHeadExample example = new AccountHeadExample(); | 
|                 example.createCriteria().andIdIn(ahIds); | 
|                 result = accountHeadMapper.updateByExampleSelective(accountHead, example); | 
|             } else { | 
|                 return 1; | 
|             } | 
|         }catch(Exception e){ | 
|             JshException.writeFail(logger, e); | 
|         } | 
|         return result; | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public void addAccountHeadAndDetail(String beanJson, String rows, HttpServletRequest request) throws Exception { | 
|         AccountHead accountHead = JSONObject.parseObject(beanJson, AccountHead.class); | 
|         //校验单号是否重复 | 
|         if(checkIsBillNoExist(0L, accountHead.getBillNo())>0) { | 
|             throw new BusinessRunTimeException(ExceptionConstants.ACCOUNT_HEAD_BILL_NO_EXIST_CODE, | 
|                     String.format(ExceptionConstants.ACCOUNT_HEAD_BILL_NO_EXIST_MSG)); | 
|         } | 
|         //校验付款账户和明细中的账户重复(转账单据) | 
|         if(BusinessConstants.TYPE_GIRO.equals(accountHead.getType())) { | 
|             JSONArray rowArr = JSONArray.parseArray(rows); | 
|             if (null != rowArr && rowArr.size()>0) { | 
|                 for (int i = 0; i < rowArr.size(); i++) { | 
|                     JSONObject object = JSONObject.parseObject(rowArr.getString(i)); | 
|                     if (object.get("accountId") != null && !object.get("accountId").equals("")) { | 
|                         Long accoutId = object.getLong("accountId"); | 
|                         String accountName = accountMapper.selectByPrimaryKey(accoutId).getName(); | 
|                         if(accoutId.equals(accountHead.getAccountId())) { | 
|                             throw new BusinessRunTimeException(ExceptionConstants.ACCOUNT_HEAD_ACCOUNT_REPEAT_CODE, | 
|                                     String.format(ExceptionConstants.ACCOUNT_HEAD_ACCOUNT_REPEAT_MSG, accountName)); | 
|                         } | 
|                     } | 
|                 } | 
|             } | 
|         } | 
|         User userInfo=userService.getCurrentUser(); | 
|         accountHead.setCreator(userInfo==null?null:userInfo.getId()); | 
|         if(StringUtil.isEmpty(accountHead.getStatus())) { | 
|             accountHead.setStatus(BusinessConstants.BILLS_STATUS_UN_AUDIT); | 
|         } | 
|         accountHeadMapper.insertSelective(accountHead); | 
|         //根据单据编号查询单据id | 
|         AccountHeadExample dhExample = new AccountHeadExample(); | 
|         dhExample.createCriteria().andBillNoEqualTo(accountHead.getBillNo()).andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED); | 
|         List<AccountHead> list = accountHeadMapper.selectByExample(dhExample); | 
|         if(list!=null) { | 
|             Long headId = list.get(0).getId(); | 
|             String type = list.get(0).getType(); | 
|             /**处理单据子表信息*/ | 
|             accountItemService.saveDetials(rows, headId, type, request); | 
|         } | 
|         if("收预付款".equals(accountHead.getType())){ | 
|             //更新会员预付款 | 
|             supplierService.updateAdvanceIn(accountHead.getOrganId()); | 
|         } | 
|         logService.insertLog("财务单据", | 
|                 new StringBuffer(BusinessConstants.LOG_OPERATION_TYPE_ADD).append(accountHead.getBillNo()).toString(), request); | 
|     } | 
|   | 
|     @Transactional(value = "transactionManager", rollbackFor = Exception.class) | 
|     public void updateAccountHeadAndDetail(String beanJson, String rows, HttpServletRequest request) throws Exception { | 
|         AccountHead accountHead = JSONObject.parseObject(beanJson, AccountHead.class); | 
|         //校验单号是否重复 | 
|         if(checkIsBillNoExist(accountHead.getId(), accountHead.getBillNo())>0) { | 
|             throw new BusinessRunTimeException(ExceptionConstants.ACCOUNT_HEAD_BILL_NO_EXIST_CODE, | 
|                     String.format(ExceptionConstants.ACCOUNT_HEAD_BILL_NO_EXIST_MSG)); | 
|         } | 
|         accountHeadMapper.updateByPrimaryKeySelective(accountHead); | 
|         //根据单据编号查询单据id | 
|         AccountHeadExample dhExample = new AccountHeadExample(); | 
|         dhExample.createCriteria().andBillNoEqualTo(accountHead.getBillNo()).andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED); | 
|         List<AccountHead> list = accountHeadMapper.selectByExample(dhExample); | 
|         if(list!=null) { | 
|             Long headId = list.get(0).getId(); | 
|             String type = list.get(0).getType(); | 
|             /**处理单据子表信息*/ | 
|             accountItemService.saveDetials(rows, headId, type, request); | 
|         } | 
|         if("收预付款".equals(accountHead.getType())){ | 
|             //更新会员预付款 | 
|             supplierService.updateAdvanceIn(accountHead.getOrganId()); | 
|         } | 
|         logService.insertLog("财务单据", | 
|                 new StringBuffer(BusinessConstants.LOG_OPERATION_TYPE_EDIT).append(accountHead.getBillNo()).toString(), request); | 
|     } | 
|   | 
|     public List<AccountHeadVo4ListEx> getDetailByNumber(String billNo)throws Exception { | 
|         List<AccountHeadVo4ListEx> resList = new ArrayList<AccountHeadVo4ListEx>(); | 
|         List<AccountHeadVo4ListEx> list = null; | 
|         try{ | 
|             list = accountHeadMapperEx.getDetailByNumber(billNo); | 
|         }catch(Exception e){ | 
|             JshException.readFail(logger, e); | 
|         } | 
|         if (null != list) { | 
|             for (AccountHeadVo4ListEx ah : list) { | 
|                 if(ah.getChangeAmount() != null) { | 
|                     if(BusinessConstants.TYPE_MONEY_IN.equals(ah.getType())) { | 
|                         ah.setChangeAmount(ah.getChangeAmount()); | 
|                     } else if(BusinessConstants.TYPE_MONEY_OUT.equals(ah.getType())) { | 
|                         ah.setChangeAmount(BigDecimal.ZERO.subtract(ah.getChangeAmount())); | 
|                     } else { | 
|                         ah.setChangeAmount(ah.getChangeAmount().abs()); | 
|                     } | 
|                 } | 
|                 if(ah.getTotalPrice() != null) { | 
|                     if(BusinessConstants.TYPE_MONEY_IN.equals(ah.getType())) { | 
|                         ah.setTotalPrice(ah.getTotalPrice()); | 
|                     } else if(BusinessConstants.TYPE_MONEY_OUT.equals(ah.getType())) { | 
|                         ah.setTotalPrice(BigDecimal.ZERO.subtract(ah.getTotalPrice())); | 
|                     } else { | 
|                         ah.setTotalPrice(ah.getTotalPrice().abs()); | 
|                     } | 
|                 } | 
|                 if(ah.getBillTime() !=null) { | 
|                     ah.setBillTimeStr(getCenternTime(ah.getBillTime())); | 
|                 } | 
|                 resList.add(ah); | 
|             } | 
|         } | 
|         return resList; | 
|     } | 
|   | 
|     public List<AccountItem> getFinancialBillNoByBillIdList(List<Long> idList) { | 
|         return accountHeadMapperEx.getFinancialBillNoByBillIdList(idList); | 
|     } | 
|   | 
|     public List<AccountHead> getFinancialBillNoByBillId(Long billId) { | 
|         return accountHeadMapperEx.getFinancialBillNoByBillId(billId); | 
|     } | 
| } |