|
@@ -3,13 +3,19 @@ package com.fjhx.purchase.service.impl;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
+import com.fjhx.utils.DateUtil;
|
|
|
+import com.fjhx.utils.ListUtil;
|
|
|
import com.fjhx.utils.WrapperUtil;
|
|
|
import com.fjhx.entity.purchase.PurchaseContract;
|
|
|
import com.fjhx.purchase.mapper.PurchaseContractMapper;
|
|
|
import com.fjhx.purchase.service.PurchaseContractService;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
+import org.springblade.core.tool.utils.ObjectUtil;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
+import java.text.ParseException;
|
|
|
+import java.util.Arrays;
|
|
|
+import java.util.HashMap;
|
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
|
|
|
@@ -56,4 +62,69 @@ public class PurchaseContractServiceImpl extends ServiceImpl<PurchaseContractMap
|
|
|
public List<Map<String,Object>> historyPayList() {
|
|
|
return baseMapper.historyPayList();
|
|
|
}
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 历史付款列表
|
|
|
+ * @param condition
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public List<PurchaseContract> getPayList(Map<String, Object> condition) throws ParseException {
|
|
|
+ List<PurchaseContract> list = baseMapper.getPayList(condition);
|
|
|
+ Map<String,Object> map = new HashMap<>();
|
|
|
+ //初始化map集合
|
|
|
+ map.put("subscribeCheck",true);
|
|
|
+ map.put("inoutBillCheck",false);
|
|
|
+ map.put("quantityCheck",false);
|
|
|
+ map.put("ContractCheck",false);
|
|
|
+ map.put("invoiceCheck",false);
|
|
|
+ map.put("payDate",null);
|
|
|
+ for(PurchaseContract p:list){
|
|
|
+ //处理是否入库判定
|
|
|
+ if(ObjectUtil.isNotEmpty(p.getPurContractState())&&p.getPurContractState()==3){
|
|
|
+ map.put("inoutBillCheck",true);
|
|
|
+ }
|
|
|
+ //处理是否质检判定
|
|
|
+ if(ObjectUtil.isNotEmpty(p.getQuantityStatus())){
|
|
|
+ map.put("quantityCheck",ListUtil.checkList(Arrays.asList(p.getQuantityStatus()),"1"));
|
|
|
+ }
|
|
|
+ //处理合同判定
|
|
|
+ if(ObjectUtil.isNotEmpty(p.getContractStatus())&&
|
|
|
+ p.getContractStatus().contains("3")){
|
|
|
+ map.put("ContractCheck",true);
|
|
|
+ }
|
|
|
+ //处理发票判定
|
|
|
+ if(ObjectUtil.isNotEmpty(p.getContractAmount())
|
|
|
+ &&p.getContractAmount().compareTo(p.getApplyPayAmount())>-1){
|
|
|
+ map.put("invoiceCheck",true);
|
|
|
+ }
|
|
|
+ //处理付款期限
|
|
|
+ if(ObjectUtil.isNotEmpty(p.getCompleteStockTime())){
|
|
|
+ String date = DateUtil.dateMinusMonth(p.getCompleteStockTime(),p.getAccountDate());
|
|
|
+ map.put("payDate",DateUtil.differenceDate(date));
|
|
|
+ }
|
|
|
+ p.setCheck(map);
|
|
|
+ }
|
|
|
+ return list;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 历史付款列表--条数
|
|
|
+ * @param condition
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public Integer getPayListCount(Map<String, Object> condition) {
|
|
|
+ return baseMapper.getPayListCount(condition);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 统计供应商总付款金额
|
|
|
+ * @param condition
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public Map<String, Object> getPayGroupBySu(Map<String, Object> condition) {
|
|
|
+ return baseMapper.getPayGroupBySu(condition);
|
|
|
+ }
|
|
|
}
|