From 50b8582287a11014f71a29fad1b1a0f37b586498 Mon Sep 17 00:00:00 2001 From: ic_excellent Date: Sat, 18 Mar 2023 04:16:38 +0800 Subject: [PATCH] =?UTF-8?q?=E6=8A=A5=E8=A1=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/YearReviewController.java | 1 + .../schedule/InvoiceQuerySchedule.java | 3 - .../xhny_report/entity/CompanyEntity.java | 38 ++++++++++ .../xiao/xhny_report/entity/ConfigEntity.java | 39 ++++++++++ .../entity/SourceTrackingData.java | 18 +++++ .../xhny_report/entity/VendorMarkReport.java | 44 +++++++++++ .../entity/VendorMarkReportDt.java | 44 +++++++++++ .../xiao/xhny_report/mapper/VendorMapper.java | 33 +++++++++ .../schedule/GenerateReportSchedule.java | 56 ++++++++++++++ .../service/ScoreChainPattern.java | 74 +++++++++++++++++++ .../service/chain/AbstractScoreChain.java | 61 +++++++++++++++ .../service/chain/AccountPeriodChain.java | 54 ++++++++++++++ .../service/chain/ArrivalRateChain.java | 26 +++++++ .../service/chain/BadCountChain.java | 25 +++++++ .../service/chain/DeliveryCycleChain.java | 59 +++++++++++++++ .../service/chain/MoneyAmountChain.java | 25 +++++++ .../service/chain/OrderRequirementChain.java | 55 ++++++++++++++ .../service/chain/QuotationCompleteChain.java | 26 +++++++ .../service/chain/QuotationNumberChain.java | 26 +++++++ .../service/chain/QuotationTimeChain.java | 26 +++++++ .../service/chain/ReturnAndExchangeChain.java | 53 +++++++++++++ .../service/chain/SortingServiceChain.java | 52 +++++++++++++ .../service/chain/TopThirtyChain.java | 26 +++++++ .../service/store/VendorStore.java | 59 +++++++++++++++ src/test/java/bokang/xiao/NormalTest.java | 25 ++----- 25 files changed, 927 insertions(+), 21 deletions(-) create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/entity/CompanyEntity.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/entity/ConfigEntity.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/entity/SourceTrackingData.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReport.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReportDt.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/mapper/VendorMapper.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/schedule/GenerateReportSchedule.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/ScoreChainPattern.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AbstractScoreChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AccountPeriodChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ArrivalRateChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/BadCountChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/DeliveryCycleChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/MoneyAmountChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/OrderRequirementChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationCompleteChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationNumberChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationTimeChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ReturnAndExchangeChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/SortingServiceChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/chain/TopThirtyChain.java create mode 100644 src/main/java/weaver/bokang/xiao/xhny_report/service/store/VendorStore.java diff --git a/src/main/java/com/api/bokang/xiao/porsche_review/controller/YearReviewController.java b/src/main/java/com/api/bokang/xiao/porsche_review/controller/YearReviewController.java index cb7c47a..70a6a1f 100644 --- a/src/main/java/com/api/bokang/xiao/porsche_review/controller/YearReviewController.java +++ b/src/main/java/com/api/bokang/xiao/porsche_review/controller/YearReviewController.java @@ -124,6 +124,7 @@ public class YearReviewController { try{ log.info("into getWorkflowTop success params ==> "+param); User loginUser = HrmUserVarify.getUser(request, response); + loginUser.setLoginid("9"); param.put("workflowIds",workflowIds); if(!param.containsKey("limit")){ param.put("limit",3); diff --git a/src/main/java/weaver/bokang/xiao/dz_invoice/schedule/InvoiceQuerySchedule.java b/src/main/java/weaver/bokang/xiao/dz_invoice/schedule/InvoiceQuerySchedule.java index ef32907..7fb8a52 100644 --- a/src/main/java/weaver/bokang/xiao/dz_invoice/schedule/InvoiceQuerySchedule.java +++ b/src/main/java/weaver/bokang/xiao/dz_invoice/schedule/InvoiceQuerySchedule.java @@ -4,12 +4,10 @@ import aiyh.utils.Util; import aiyh.utils.annotation.ActionDesc; import aiyh.utils.annotation.PrintParamMark; import aiyh.utils.annotation.RequiredMark; -import aiyh.utils.excention.CustomerException; import aiyh.utils.httpUtil.ResponeVo; import aiyh.utils.httpUtil.util.HttpUtils; import com.alibaba.fastjson.JSON; import com.api.bokang.xiao.dz_invoice.mapper.DzInvoiceMapper; -import lombok.Data; import org.apache.log4j.Logger; import weaver.interfaces.schedule.BaseCronJob; import weaver.xiao.commons.config.entity.RequestMappingConfig; @@ -28,7 +26,6 @@ import java.util.Objects; **/ @ActionDesc(value = "定时查询发票勾选状态", author = "bokang.xiao") -@Data public class InvoiceQuerySchedule extends BaseCronJob { @RequiredMark("发票查询接口唯一标识") diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/entity/CompanyEntity.java b/src/main/java/weaver/bokang/xiao/xhny_report/entity/CompanyEntity.java new file mode 100644 index 0000000..ba8c0ba --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/entity/CompanyEntity.java @@ -0,0 +1,38 @@ +package weaver.bokang.xiao.xhny_report.entity; + +import aiyh.utils.annotation.recordset.SqlDbFieldAnn; +import lombok.Data; + +/** + * @ClassName CompanyEntity + * @Author 肖博亢 + * @Date 2023/3/17 18:10 + * @Description

+ **/ + +@Data +public class CompanyEntity { + + private Integer id; + + /** 起订要求 */ + @SqlDbFieldAnn("fs") + private String orderRequire; + + /** 退换货条件 */ + @SqlDbFieldAnn("thtk") + private Integer returnAndExchange; + + /** 配送周期 */ + @SqlDbFieldAnn("csshsx") + private Integer deliveryCycle; + + /** 账期 */ + @SqlDbFieldAnn("zqxlk") + private Integer accountPeriod; + + /** 装卸(分拣)服务 */ + @SqlDbFieldAnn("sftgfjfw") + private Integer sortingService; + +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/entity/ConfigEntity.java b/src/main/java/weaver/bokang/xiao/xhny_report/entity/ConfigEntity.java new file mode 100644 index 0000000..5338e82 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/entity/ConfigEntity.java @@ -0,0 +1,39 @@ +package weaver.bokang.xiao.xhny_report.entity; + +import aiyh.utils.annotation.recordset.SqlDbFieldAnn; +import lombok.Data; + +/** + * @ClassName ConfigEntity + * @Author 肖博亢 + * @Date 2023/3/16 10:50 + * @Description

评分明细配置

+ **/ + +@Data +public class ConfigEntity { + + /** 数据id */ + private Integer id; + + /** 分数 */ + @SqlDbFieldAnn("fs") + private Double score; + + /** 子项目 */ + @SqlDbFieldAnn("zxm") + private Integer childItem; + + /** 明细 */ + @SqlDbFieldAnn("mx") + private String detail; + + /** 权重 */ + @SqlDbFieldAnn("qz") + private String weight; + + /** 明细项 */ + @SqlDbFieldAnn("fs") + private Integer detailItem; + +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/entity/SourceTrackingData.java b/src/main/java/weaver/bokang/xiao/xhny_report/entity/SourceTrackingData.java new file mode 100644 index 0000000..b9a3d23 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/entity/SourceTrackingData.java @@ -0,0 +1,18 @@ +package weaver.bokang.xiao.xhny_report.entity; + +import lombok.Data; + +import java.util.List; + +/** + * @ClassName SourceTrackingData + * @Author 肖博亢 + * @Date 2023/3/17 15:19 + * @Description

询价数据

+ **/ + +@Data +public class SourceTrackingData { + + private List vendorList; +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReport.java b/src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReport.java new file mode 100644 index 0000000..c4eb8e6 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReport.java @@ -0,0 +1,44 @@ +package weaver.bokang.xiao.xhny_report.entity; + +import aiyh.utils.annotation.recordset.SqlDbFieldAnn; +import lombok.Data; + +import java.util.List; + +/** + * @ClassName VendorMarkReport + * @Author 肖博亢 + * @Date 2023/3/16 13:47 + * @Description

+ **/ + +@Data +public class VendorMarkReport { + + /** 数据id */ + private Integer id; + + /** 评估开始时间 */ + @SqlDbFieldAnn("pgksrq") + private String evaluationStartDate; + + /** 评估结束时间 */ + @SqlDbFieldAnn("pgjsrq") + private String evaluationEndDate; + + /** 供应商 */ + @SqlDbFieldAnn("gys") + private Integer supplier; + + /** 品类 */ + @SqlDbFieldAnn("pl") + private String category; + + /** 本期总分 */ + @SqlDbFieldAnn("bqzf") + private double totalScore; + + /** 分数明细信息 */ + private List vendorMarkReportDtList; + +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReportDt.java b/src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReportDt.java new file mode 100644 index 0000000..760cf09 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/entity/VendorMarkReportDt.java @@ -0,0 +1,44 @@ +package weaver.bokang.xiao.xhny_report.entity; + +import aiyh.utils.annotation.recordset.SqlDbFieldAnn; +import lombok.Builder; +import lombok.Data; + +/** + * @ClassName VendorMarkReportDt + * @Author 肖博亢 + * @Date 2023/3/16 13:56 + * @Description

+ **/ + +@Data +@Builder +public class VendorMarkReportDt { + + /** 数据id */ + private Integer id; + + /** 主数据id */ + private Integer mainId; + + /** 项目 */ + @SqlDbFieldAnn("xm") + private Integer project; + + /** 描述 */ + @SqlDbFieldAnn("ms") + private String desc; + + /** 权重 */ + @SqlDbFieldAnn("qz") + private String weight; + + + /** 预估得分 */ + @SqlDbFieldAnn("ygdf") + private String anticipateScore; + + /** 实际得分 */ + @SqlDbFieldAnn("sjdf") + private Double score; +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/mapper/VendorMapper.java b/src/main/java/weaver/bokang/xiao/xhny_report/mapper/VendorMapper.java new file mode 100644 index 0000000..b8e57c4 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/mapper/VendorMapper.java @@ -0,0 +1,33 @@ +package weaver.bokang.xiao.xhny_report.mapper; + +import aiyh.utils.annotation.recordset.Select; +import aiyh.utils.annotation.recordset.SqlMapper; +import weaver.bokang.xiao.xhny_report.entity.CompanyEntity; +import weaver.bokang.xiao.xhny_report.entity.ConfigEntity; + +import java.util.List; + +/** + * @ClassName VendorMapper + * @Author 肖博亢 + * @Date 2023/3/16 14:13 + * @Description

+ **/ + +@SqlMapper +public interface VendorMapper { + + /** + *

查询配置信息

+ * @return 配置列表 + */ + @Select("select * from uf_vendorMark") + List queryVendorConfig(); + + /** + * 查询供应商信息 + * @return 供应商列表信息 + */ + @Select("select * from uf_company_info") + List queryCompanyList(); +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/schedule/GenerateReportSchedule.java b/src/main/java/weaver/bokang/xiao/xhny_report/schedule/GenerateReportSchedule.java new file mode 100644 index 0000000..415f3c0 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/schedule/GenerateReportSchedule.java @@ -0,0 +1,56 @@ +package weaver.bokang.xiao.xhny_report.schedule; + +import aiyh.utils.Util; +import aiyh.utils.annotation.ActionDesc; +import aiyh.utils.annotation.PrintParamMark; +import aiyh.utils.annotation.RequiredMark; +import lombok.Data; +import org.apache.log4j.Logger; +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; +import weaver.bokang.xiao.xhny_report.service.ScoreChainPattern; +import weaver.bokang.xiao.xhny_report.service.chain.AbstractScoreChain; +import weaver.bokang.xiao.xhny_report.service.store.VendorStore; +import weaver.interfaces.schedule.BaseCronJob; + +import java.util.ArrayList; +import java.util.List; + +/** + * @ClassName GenerateReportSchedule + * @Author 肖博亢 + * @Date 2023/3/17 19:58 + * @Description

生成报表定时任务

+ **/ +@Data +@ActionDesc(value = "生成报表信息", author = "bokang.xiao") +public class GenerateReportSchedule extends BaseCronJob { + + private final Logger log = Util.getLogger(); + + @RequiredMark("报表模块id") + @PrintParamMark + private String reportModelId; + + @Override + public void execute() { + try { + //必填参数校验 + Util.verifyRequiredField(this); + //公共参数初始化 + VendorStore instance = VendorStore.getInstance(); + instance.init(); + //获取评分处理链 + AbstractScoreChain scoreChain = ScoreChainPattern.getScoreChain(); + //处理数据初始化 + List vendorMarkReportList = new ArrayList<>(); + SourceTrackingData sourceTrackingData = new SourceTrackingData(); + //进行供应商评分 + scoreChain.handle(vendorMarkReportList, sourceTrackingData); + //批量插入供应商报表数据 + //todo 批量插入供应商报表数据 + }catch (Exception e){ + log.error("定时任务执行异常 ==>"+Util.getErrString(e)); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/ScoreChainPattern.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/ScoreChainPattern.java new file mode 100644 index 0000000..0bcfd51 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/ScoreChainPattern.java @@ -0,0 +1,74 @@ +package weaver.bokang.xiao.xhny_report.service; + +import aiyh.utils.Util; +import aiyh.utils.excention.CustomerException; +import com.alibaba.fastjson.JSON; +import org.apache.log4j.Logger; +import weaver.bokang.xiao.xhny_report.entity.ConfigEntity; +import weaver.bokang.xiao.xhny_report.mapper.VendorMapper; +import weaver.bokang.xiao.xhny_report.service.chain.*; + +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.Objects; +import java.util.stream.Collectors; + +/** + * @ClassName ScoreChainPattern + * @Author 肖博亢 + * @Date 2023/3/17 16:13 + * @Description

评分链路初始化

+ **/ +public class ScoreChainPattern { + + private static final VendorMapper VENDOR_MAPPER = Util.getMapper(VendorMapper.class); + + private static final Logger logger = Util.getLogger(); + + private static final Map SCORE_CHAIN_MAP = new HashMap<>(); + + static { + SCORE_CHAIN_MAP.put(0,new OrderRequirementChain()); + SCORE_CHAIN_MAP.put(1,new ReturnAndExchangeChain()); + SCORE_CHAIN_MAP.put(2,new DeliveryCycleChain()); + SCORE_CHAIN_MAP.put(3,new AccountPeriodChain()); + SCORE_CHAIN_MAP.put(4,new QuotationNumberChain()); + SCORE_CHAIN_MAP.put(5,new MoneyAmountChain()); + SCORE_CHAIN_MAP.put(6,new TopThirtyChain()); + SCORE_CHAIN_MAP.put(7,new QuotationCompleteChain()); + SCORE_CHAIN_MAP.put(8,new QuotationTimeChain()); + SCORE_CHAIN_MAP.put(9,new ArrivalRateChain()); + SCORE_CHAIN_MAP.put(10,new BadCountChain()); + SCORE_CHAIN_MAP.put(11,new SortingServiceChain()); + } + + public static AbstractScoreChain getScoreChain(){ + List configEntities = VENDOR_MAPPER.queryVendorConfig(); + if(configEntities.isEmpty()){ + throw new CustomerException("评分配置信息不能为空"); + } + logger.info(String.format("评分配置信息: < %s >", JSON.toJSONString(configEntities))); + Map> configMap = configEntities.stream().collect(Collectors.groupingBy(ConfigEntity::getChildItem)); + AbstractScoreChain abstractScoreChain = null; + for (Map.Entry> entry : configMap.entrySet()) { + AbstractScoreChain tempChain = SCORE_CHAIN_MAP.get(entry.getKey()); + if(Objects.isNull(tempChain)){ + logger.error(String.format("无法找到与之 %d 对应的链路处理对象",entry.getKey())); + continue; + } + if(Objects.isNull(abstractScoreChain)){ + abstractScoreChain = SCORE_CHAIN_MAP.get(entry.getKey()); + abstractScoreChain.setScoreConfigList(entry.getValue()); + }else { + AbstractScoreChain nexChain = SCORE_CHAIN_MAP.get(entry.getKey()); + nexChain.setScoreConfigList(entry.getValue()); + abstractScoreChain.nextScoreChain(nexChain); + } + } + if(Objects.isNull(abstractScoreChain)){ + throw new CustomerException("链路调用对象初始化为空,请检查"); + } + return abstractScoreChain; + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AbstractScoreChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AbstractScoreChain.java new file mode 100644 index 0000000..0114371 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AbstractScoreChain.java @@ -0,0 +1,61 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.bokang.xiao.xhny_report.entity.ConfigEntity; +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; +import weaver.bokang.xiao.xhny_report.service.store.VendorStore; + +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +/** + * @ClassName AbstractScoreChain + * @Author 肖博亢 + * @Date 2023/3/17 14:59 + * @Description

评分处理抽象类

+ **/ +public abstract class AbstractScoreChain { + + /** 日志对象 */ + protected Logger logger = Util.getLogger(); + + /** 评分配置列表 */ + protected List scoreConfigList; + + /** 评分配置信息集合 */ + protected Map configEntityMap; + + /** 公共数据信息 */ + protected VendorStore vendorStore = VendorStore.getInstance(); + + /** 责任链中的下一个元素 */ + protected AbstractScoreChain nextAbstractScoreChain; + + /** + *

传入下一责任链元素

+ * @param abstractScoreChain 责任链元素 + */ + public void nextScoreChain(AbstractScoreChain abstractScoreChain){ + this.nextAbstractScoreChain = abstractScoreChain; + } + + /** + *

设置评分配置列表

+ * @param scoreConfigList 评分配置列表 + */ + public void setScoreConfigList(List scoreConfigList){ + this.scoreConfigList = scoreConfigList; + this.configEntityMap = scoreConfigList.stream().collect(Collectors.toMap(ConfigEntity::getDetailItem, item -> item)); + } + + /** + *

具体评分逻辑

+ * @param vendorMarkReportList 报表数据 + * @param sourceTrackingData 询价数据 + */ + abstract public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData); + +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AccountPeriodChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AccountPeriodChain.java new file mode 100644 index 0000000..7a4c259 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/AccountPeriodChain.java @@ -0,0 +1,54 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.*; + +import java.util.*; + +/** + * @ClassName AccountPeriodChain + * @Author 肖博亢 + * @Date 2023/3/17 15:33 + * @Description

账期评分

+ **/ +public class AccountPeriodChain extends AbstractScoreChain{ + + /** 评分对应关系 */ + private final Map mappingConfig = new HashMap<>(); + + { + mappingConfig.put(0,14); + mappingConfig.put(1,15); + mappingConfig.put(2,16); + mappingConfig.put(3,17); + } + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //具体评分逻辑 + logger.info(" AccountPeriodChain deal 账期评分处理 "); + Map companyMap = vendorStore.getCompanyMap(); + for (VendorMarkReport vendorMarkReport : vendorMarkReportList) { + Integer supplier = vendorMarkReport.getSupplier(); + CompanyEntity companyEntity = companyMap.get(supplier); + ConfigEntity configEntity = this.configEntityMap.get(mappingConfig.get(companyEntity.getAccountPeriod())); + double score = 0.00; + if(Objects.nonNull(configEntity)){ + score = configEntity.getScore(); + } + List vendorMarkReportDtList = vendorMarkReport.getVendorMarkReportDtList(); + vendorMarkReportDtList = Objects.isNull(vendorMarkReportDtList) ? new ArrayList<>() : vendorMarkReportDtList; + vendorMarkReportDtList.add( + VendorMarkReportDt.builder() + .score(score) + .project(configEntity.getChildItem()) + .weight(configEntity.getWeight()) + .desc("账期评分").build()); + double totalScore = vendorMarkReport.getTotalScore(); + vendorMarkReport.setTotalScore(totalScore + score); + } + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ArrivalRateChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ArrivalRateChain.java new file mode 100644 index 0000000..364dff3 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ArrivalRateChain.java @@ -0,0 +1,26 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; + +import java.util.List; +import java.util.Objects; + +/** + * @ClassName ArrivalRateChain + * @Author 肖博亢 + * @Date 2023/3/17 15:43 + * @Description

到货率评分

+ **/ +public class ArrivalRateChain extends AbstractScoreChain{ + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/BadCountChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/BadCountChain.java new file mode 100644 index 0000000..fb96dfc --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/BadCountChain.java @@ -0,0 +1,25 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; + +import java.util.List; +import java.util.Objects; + +/** + * @ClassName BadCountChain + * @Author 肖博亢 + * @Date 2023/3/17 15:45 + * @Description

不良品数评分

+ **/ +public class BadCountChain extends AbstractScoreChain{ + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/DeliveryCycleChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/DeliveryCycleChain.java new file mode 100644 index 0000000..f46cad8 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/DeliveryCycleChain.java @@ -0,0 +1,59 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.*; + +import java.util.*; + +/** + * @ClassName DeliveryCycleChain + * @Author 肖博亢 + * @Date 2023/3/17 15:32 + * @Description

配送周期评分

+ **/ +public class DeliveryCycleChain extends AbstractScoreChain{ + + /** 评分对应关系 */ + private final Map mappingConfig = new HashMap<>(); + + { + mappingConfig.put(0,5); + mappingConfig.put(1,6); + mappingConfig.put(2,7); + mappingConfig.put(3,8); + mappingConfig.put(4,9); + mappingConfig.put(5,10); + mappingConfig.put(6,11); + mappingConfig.put(7,12); + mappingConfig.put(8,13); + } + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //具体评分逻辑 + logger.info(" DeliveryCycleChain deal 配送周期评分处理 "); + Map companyMap = vendorStore.getCompanyMap(); + for (VendorMarkReport vendorMarkReport : vendorMarkReportList) { + Integer supplier = vendorMarkReport.getSupplier(); + CompanyEntity companyEntity = companyMap.get(supplier); + ConfigEntity configEntity = this.configEntityMap.get(mappingConfig.get(companyEntity.getDeliveryCycle())); + double score = 0.00; + if(Objects.nonNull(configEntity)){ + score = configEntity.getScore(); + } + List vendorMarkReportDtList = vendorMarkReport.getVendorMarkReportDtList(); + vendorMarkReportDtList = Objects.isNull(vendorMarkReportDtList) ? new ArrayList<>() : vendorMarkReportDtList; + vendorMarkReportDtList.add( + VendorMarkReportDt.builder() + .score(score) + .project(configEntity.getChildItem()) + .weight(configEntity.getWeight()) + .desc("配送周期评分").build()); + double totalScore = vendorMarkReport.getTotalScore(); + vendorMarkReport.setTotalScore(totalScore + score); + } + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/MoneyAmountChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/MoneyAmountChain.java new file mode 100644 index 0000000..2bec078 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/MoneyAmountChain.java @@ -0,0 +1,25 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; + +import java.util.List; +import java.util.Objects; + +/** + * @ClassName MoneyAmountChain + * @Author 肖博亢 + * @Date 2023/3/17 15:38 + * @Description

金额数评分

+ **/ +public class MoneyAmountChain extends AbstractScoreChain{ + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/OrderRequirementChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/OrderRequirementChain.java new file mode 100644 index 0000000..92ad802 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/OrderRequirementChain.java @@ -0,0 +1,55 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import org.apache.commons.lang3.StringUtils; +import weaver.bokang.xiao.xhny_report.entity.*; + + +import java.util.*; + +/** + * @ClassName OrderRequirementChain + * @Author 肖博亢 + * @Date 2023/3/17 15:27 + * @Description

起订要求评分

+ **/ +public class OrderRequirementChain extends AbstractScoreChain{ + + /** 评分对应关系 */ + private final Map mappingConfig = new HashMap<>(); + + { + mappingConfig.put(0,0); + mappingConfig.put(1,0); + } + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + logger.info(" OrderRequirementChain deal 起订要求评分处理 "); + Map companyMap = vendorStore.getCompanyMap(); + for (VendorMarkReport vendorMarkReport : vendorMarkReportList) { + Integer supplier = vendorMarkReport.getSupplier(); + CompanyEntity companyEntity = companyMap.get(supplier); + int configEntityId = StringUtils.isNotBlank(companyEntity.getOrderRequire()) ? 0 : 1; + ConfigEntity configEntity = this.configEntityMap.get(mappingConfig.get(configEntityId)); + double score = 0.00; + if(Objects.nonNull(configEntity)){ + score = configEntity.getScore(); + } + List vendorMarkReportDtList = vendorMarkReport.getVendorMarkReportDtList(); + vendorMarkReportDtList = Objects.isNull(vendorMarkReportDtList) ? new ArrayList<>() : vendorMarkReportDtList; + vendorMarkReportDtList.add( + VendorMarkReportDt.builder() + .score(score) + .project(configEntity.getChildItem()) + .weight(configEntity.getWeight()) + .desc("起订要求评分").build()); + double totalScore = vendorMarkReport.getTotalScore(); + vendorMarkReport.setTotalScore(totalScore + score); + } + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationCompleteChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationCompleteChain.java new file mode 100644 index 0000000..31cfa6e --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationCompleteChain.java @@ -0,0 +1,26 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; + +import java.util.List; +import java.util.Objects; + +/** + * @ClassName QuotationCompleteChain + * @Author 肖博亢 + * @Date 2023/3/17 15:41 + * @Description

报价完整信评分

+ **/ +public class QuotationCompleteChain extends AbstractScoreChain { + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationNumberChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationNumberChain.java new file mode 100644 index 0000000..a05486f --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationNumberChain.java @@ -0,0 +1,26 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; + +import java.util.List; +import java.util.Objects; + +/** + * @ClassName QuotationNumberChain + * @Author 肖博亢 + * @Date 2023/3/17 15:35 + * @Description

报价数评分

+ **/ +public class QuotationNumberChain extends AbstractScoreChain{ + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationTimeChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationTimeChain.java new file mode 100644 index 0000000..7ad4470 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/QuotationTimeChain.java @@ -0,0 +1,26 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; + +import java.util.List; +import java.util.Objects; + +/** + * @ClassName QuotationTimeChain + * @Author 肖博亢 + * @Date 2023/3/17 15:42 + * @Description

报价及时率评分

+ **/ +public class QuotationTimeChain extends AbstractScoreChain{ + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ReturnAndExchangeChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ReturnAndExchangeChain.java new file mode 100644 index 0000000..340f453 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/ReturnAndExchangeChain.java @@ -0,0 +1,53 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.*; + +import java.util.*; + +/** + * @ClassName ReturnAndExchangeChain + * @Author 肖博亢 + * @Date 2023/3/17 15:31 + * @Description

退换货评分

+ **/ +public class ReturnAndExchangeChain extends AbstractScoreChain{ + + /** 评分对应关系 */ + private final Map mappingConfig = new HashMap<>(); + + { + mappingConfig.put(0,2); + mappingConfig.put(1,3); + mappingConfig.put(2,4); + } + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //具体评分逻辑 + logger.info(" ReturnAndExchangeChain deal 退换货评分处理 "); + Map companyMap = vendorStore.getCompanyMap(); + for (VendorMarkReport vendorMarkReport : vendorMarkReportList) { + Integer supplier = vendorMarkReport.getSupplier(); + CompanyEntity companyEntity = companyMap.get(supplier); + ConfigEntity configEntity = this.configEntityMap.get(mappingConfig.get(companyEntity.getReturnAndExchange())); + double score = 0.00; + if(Objects.nonNull(configEntity)){ + score = configEntity.getScore(); + } + List vendorMarkReportDtList = vendorMarkReport.getVendorMarkReportDtList(); + vendorMarkReportDtList = Objects.isNull(vendorMarkReportDtList) ? new ArrayList<>() : vendorMarkReportDtList; + vendorMarkReportDtList.add( + VendorMarkReportDt.builder() + .score(score) + .project(configEntity.getChildItem()) + .weight(configEntity.getWeight()) + .desc("退换货评分").build()); + double totalScore = vendorMarkReport.getTotalScore(); + vendorMarkReport.setTotalScore(totalScore + score); + } + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/SortingServiceChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/SortingServiceChain.java new file mode 100644 index 0000000..cc754d8 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/SortingServiceChain.java @@ -0,0 +1,52 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.*; + +import java.util.*; + +/** + * @ClassName SortingServiceChain + * @Author 肖博亢 + * @Date 2023/3/17 15:46 + * @Description

分拣服务评分

+ **/ +public class SortingServiceChain extends AbstractScoreChain{ + + /** 评分对应关系 */ + private final Map mappingConfig = new HashMap<>(); + + { + mappingConfig.put(0,38); + mappingConfig.put(1,39); + } + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //具体评分逻辑 + logger.info(" SortingServiceChain deal 分拣服务评分处理 "); + Map companyMap = vendorStore.getCompanyMap(); + for (VendorMarkReport vendorMarkReport : vendorMarkReportList) { + Integer supplier = vendorMarkReport.getSupplier(); + CompanyEntity companyEntity = companyMap.get(supplier); + ConfigEntity configEntity = this.configEntityMap.get(mappingConfig.get(companyEntity.getSortingService())); + double score = 0.00; + if(Objects.nonNull(configEntity)){ + score = configEntity.getScore(); + } + List vendorMarkReportDtList = vendorMarkReport.getVendorMarkReportDtList(); + vendorMarkReportDtList = Objects.isNull(vendorMarkReportDtList) ? new ArrayList<>() : vendorMarkReportDtList; + vendorMarkReportDtList.add( + VendorMarkReportDt.builder() + .score(score) + .project(configEntity.getChildItem()) + .weight(configEntity.getWeight()) + .desc("分拣服务评分").build()); + double totalScore = vendorMarkReport.getTotalScore(); + vendorMarkReport.setTotalScore(totalScore + score); + } + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/TopThirtyChain.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/TopThirtyChain.java new file mode 100644 index 0000000..44b57f0 --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/chain/TopThirtyChain.java @@ -0,0 +1,26 @@ +package weaver.bokang.xiao.xhny_report.service.chain; + +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.entity.VendorMarkReport; + +import java.util.List; +import java.util.Objects; + +/** + * @ClassName TopThirtyChain + * @Author 肖博亢 + * @Date 2023/3/17 15:39 + * @Description

top30评分

+ **/ +public class TopThirtyChain extends AbstractScoreChain{ + + @Override + public void handle(List vendorMarkReportList, SourceTrackingData sourceTrackingData) { + //TODO 具体评分逻辑 + + //让下一个链对象评分 + if(Objects.nonNull(this.nextAbstractScoreChain)) { + this.nextAbstractScoreChain.handle(vendorMarkReportList, sourceTrackingData); + } + } +} diff --git a/src/main/java/weaver/bokang/xiao/xhny_report/service/store/VendorStore.java b/src/main/java/weaver/bokang/xiao/xhny_report/service/store/VendorStore.java new file mode 100644 index 0000000..e3e8a9c --- /dev/null +++ b/src/main/java/weaver/bokang/xiao/xhny_report/service/store/VendorStore.java @@ -0,0 +1,59 @@ +package weaver.bokang.xiao.xhny_report.service.store; + +import aiyh.utils.Util; +import lombok.Getter; +import org.apache.log4j.Logger; +import weaver.bokang.xiao.xhny_report.entity.CompanyEntity; +import weaver.bokang.xiao.xhny_report.mapper.VendorMapper; + +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.Objects; +import java.util.stream.Collectors; + +/** + * @ClassName VendorStore + * @Author 肖博亢 + * @Date 2023/3/17 18:31 + * @Description

+ **/ + +@Getter +public class VendorStore { + + /** 公司信息 */ + private List companyEntityList; + + private Map companyMap = new HashMap<>(); + + private static final Logger logger = Util.getLogger(); + + private static final VendorMapper VENDOR_MAPPER = Util.getMapper(VendorMapper.class); + + private VendorStore(){ + //this.init(); + } + + public void init(){ + try{ + this.companyEntityList = VENDOR_MAPPER.queryCompanyList(); + if(Objects.nonNull(companyEntityList) && !companyEntityList.isEmpty()){ + companyMap = companyEntityList.stream().collect(Collectors.toMap(CompanyEntity::getId, item -> item)); + } + }catch (Exception exception){ + logger.error("VendorStore 初始化异常 ==>"+Util.getErrString(exception)); + } + } + + public static VendorStore getInstance(){ + return VendorStoreHolder.VENDOR_STORE; + } + + private static class VendorStoreHolder{ + private VendorStoreHolder(){ + + } + private static final VendorStore VENDOR_STORE = new VendorStore(); + } +} diff --git a/src/test/java/bokang/xiao/NormalTest.java b/src/test/java/bokang/xiao/NormalTest.java index 5224d02..f895e02 100644 --- a/src/test/java/bokang/xiao/NormalTest.java +++ b/src/test/java/bokang/xiao/NormalTest.java @@ -1,7 +1,6 @@ package bokang.xiao; import aiyh.utils.GenerateFileUtil; -import aiyh.utils.ThreadPoolConfig; import aiyh.utils.Util; import aiyh.utils.httpUtil.ResponeVo; import aiyh.utils.httpUtil.util.HttpUtils; @@ -9,46 +8,33 @@ import basetest.BaseTest; import bokang.xiao.entity.CourseEntity; import bokang.xiao.entity.StudentEntity; import bokang.xiao.entity.TeacherEntity; -import bokang.xiao.mapper.TestMapper; import cn.afterturn.easypoi.excel.ExcelExportUtil; import cn.afterturn.easypoi.excel.entity.ExportParams; import com.api.bokang.xiao.porsche_review.mapper.ReviewMapper; -import com.api.bokang.xiao.porsche_review.service.ReviewService; import com.api.bokang.xiao.porsche_review.service.impl.ReviewServiceImpl; -import com.api.bokang.xiao.wx_report.entity.ReportEntityVO; import com.api.bokang.xiao.wx_report.mapper.ReportMapper; import com.api.bokang.xiao.wx_report.service.ReportService; import com.api.bokang.xiao.wx_report.service.impl.ReportServiceImpl; -import org.apache.commons.lang3.StringUtils; import org.apache.log4j.Logger; -import org.apache.poi.POIXMLDocument; -import org.apache.poi.hwpf.HWPFDocument; -import org.apache.poi.hwpf.usermodel.Range; import org.apache.poi.ss.usermodel.Workbook; -import org.apache.poi.xwpf.usermodel.XWPFDocument; -import org.apache.poi.xwpf.usermodel.XWPFParagraph; -import org.apache.poi.xwpf.usermodel.XWPFRun; import org.junit.Test; -import weaver.bokang.xiao.dz_invoice.action.InvoiceDeductionAction; -import weaver.bokang.xiao.dz_invoice.schedule.InvoiceQuerySchedule; +import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; +import weaver.bokang.xiao.xhny_report.service.chain.AbstractScoreChain; +import weaver.bokang.xiao.xhny_report.service.ScoreChainPattern; import weaver.general.StaticObj; import weaver.hrm.User; import weaver.interfaces.datasource.DataSource; import weaver.workflow.workflow.WorkflowVersion; -import weaver.xiao.commons.config.entity.ResponseMapping; import weaver.xiao.commons.utils.DocImageFileUtil; import java.io.*; import java.lang.reflect.Constructor; import java.lang.reflect.InvocationTargetException; -import java.nio.charset.StandardCharsets; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.util.*; -import java.util.concurrent.ExecutorService; -import java.util.stream.Collectors; /** * @ClassName NormalTest @@ -125,7 +111,10 @@ public class NormalTest extends BaseTest { @Test public void testgg() throws IOException { - System.out.println(null instanceof Collections); + //System.out.println(null instanceof Collections); + AbstractScoreChain scoreChain = ScoreChainPattern.getScoreChain(); + scoreChain.handle(new ArrayList<>(),new SourceTrackingData()); + System.out.println(scoreChain); } @Test