From 560a802494341918f4685863dcdd41d888549b3f Mon Sep 17 00:00:00 2001 From: PigBaoBei <2739175034@qq.com> Date: Tue, 15 Oct 2024 15:38:53 +0800 Subject: [PATCH 1/8] =?UTF-8?q?=E5=BA=93=E5=AD=98=E5=93=81=E5=8F=96?= =?UTF-8?q?=E6=B6=88=E7=BB=B4=E6=8A=A4=E6=95=B0=E9=87=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../service/impl/DistributionReservationServiceImpl.java | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionReservationServiceImpl.java b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionReservationServiceImpl.java index 3fbf5a176..2fa39c457 100644 --- a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionReservationServiceImpl.java +++ b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionReservationServiceImpl.java @@ -3948,11 +3948,18 @@ public class DistributionReservationServiceImpl extends BaseServiceImpl Date: Tue, 15 Oct 2024 16:53:13 +0800 Subject: [PATCH 2/8] =?UTF-8?q?=E8=BD=A6=E8=BE=86=E9=A1=B5=E9=9D=A2?= =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E4=BF=9D=E9=99=A9=E4=B8=B4=E6=9C=9F=E3=80=81?= =?UTF-8?q?=E4=BF=9D=E9=99=A9=E5=88=B0=E6=9C=9F=E3=80=81=E5=B9=B4=E5=AE=A1?= =?UTF-8?q?=E4=B8=B4=E6=9C=9F=E3=80=81=E5=B9=B4=E5=AE=A1=E5=88=B0=E6=9C=9F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../basicdata/dto/BasicdataVehicleDTO.java | 6 +- .../mapper/BasicdataVehicleMapper.java | 33 ++ .../mapper/BasicdataVehicleMapper.xml | 351 ++++++++++++++++++ .../impl/BasicdataVehicleServiceImpl.java | 128 ++++--- 4 files changed, 466 insertions(+), 52 deletions(-) diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataVehicleDTO.java b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataVehicleDTO.java index b44dc7833..43637802c 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataVehicleDTO.java +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/dto/BasicdataVehicleDTO.java @@ -32,7 +32,11 @@ import lombok.EqualsAndHashCode; public class BasicdataVehicleDTO extends BasicdataVehicleEntity { private static final long serialVersionUID = 1L; - @ApiModelProperty(value = "车辆所属") private String vehicleOwners; + /** + * 页面类型 0-全部 1-保险临期 2-保险到期 3-年审临期 4-年审到期 + */ + private Integer pageType; + } diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.java b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.java index bfddef518..ee1dc329c 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.java +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.java @@ -70,4 +70,37 @@ public interface BasicdataVehicleMapper extends BaseMapper selectInsuranceDeadlineBasicdataVehiclePage(IPage page,@Param("param") BasicdataVehicleDTO basicdataVehicle); + + /** + * 保险到期 + * @param page + * @param basicdataVehicle + * @return + */ + IPage selectInsuranceExpireBasicdataVehiclePage(IPage page,@Param("param") BasicdataVehicleDTO basicdataVehicle); + + /** + * 年审临期 + * @param page + * @param basicdataVehicle + * @return + */ + IPage selectAnnualDeadlineBasicdataVehiclePage(IPage page,@Param("param") BasicdataVehicleDTO basicdataVehicle); + + /** + * 年审到期 + * @param page + * @param basicdataVehicle + * @return + */ + IPage selectAnnualExpireBasicdataVehiclePage(IPage page,@Param("param") BasicdataVehicleDTO basicdataVehicle); + } diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.xml b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.xml index 1d2a62b95..81d8c2815 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.xml +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataVehicleMapper.xml @@ -331,6 +331,357 @@ lbv.id = #{id} AND is_deleted = 0 + + + + diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataVehicleServiceImpl.java b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataVehicleServiceImpl.java index 0607d55f8..6605a31a0 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataVehicleServiceImpl.java +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/impl/BasicdataVehicleServiceImpl.java @@ -42,6 +42,7 @@ import com.logpm.basicdata.vo.BasicdataCarrierVO; import com.logpm.basicdata.vo.BasicdataVehicleVO; import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; +import org.springblade.common.exception.CustomerException; import org.springblade.common.utils.PhoneCheckUtil; import org.springblade.core.log.exception.ServiceException; import org.springblade.core.mp.base.BaseServiceImpl; @@ -51,10 +52,7 @@ import org.springblade.core.tool.utils.StringUtil; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.stream.Collectors; /** @@ -75,14 +73,42 @@ public class BasicdataVehicleServiceImpl extends BaseServiceImpl selectBasicdataVehiclePage(IPage page, BasicdataVehicleDTO basicdataVehicle) { - return page.setRecords(baseMapper.selectBasicdataVehiclePage(page, basicdataVehicle)); + if (Objects.isNull(basicdataVehicle.getPageType())) { + throw new CustomerException("pageType参数缺失!!!"); + } + switch (basicdataVehicle.getPageType()) { + case 0: + //全部 + List basicdataVehicleVOS = baseMapper.selectBasicdataVehiclePage(page, basicdataVehicle); + return page.setRecords(basicdataVehicleVOS); + case 1: + //保险临期 + IPage insuranceDeadlineBasicdataVehicleVOS = baseMapper.selectInsuranceDeadlineBasicdataVehiclePage(page, basicdataVehicle); + return insuranceDeadlineBasicdataVehicleVOS; + case 2: + //保险到期 + IPage insuranceExpireBasicdataVehicleVOS = baseMapper.selectInsuranceExpireBasicdataVehiclePage(page, basicdataVehicle); + return insuranceExpireBasicdataVehicleVOS; + case 3: + //年审临期 + IPage annualDeadlineBasicdataVehicleVOS = baseMapper.selectAnnualDeadlineBasicdataVehiclePage(page, basicdataVehicle); + return annualDeadlineBasicdataVehicleVOS; + case 4: + //年审到期 + IPage expireDeadlineBasicdataVehicleVOS = baseMapper.selectAnnualExpireBasicdataVehiclePage(page, basicdataVehicle); + return expireDeadlineBasicdataVehicleVOS; + default: + log.error("未知的车辆类型>>>>>>>>>>>>>"); + return null; + } } @Override - public List exportBasicdataVehicle(String ids) { + public List exportBasicdataVehicle(String ids) { List basicdataVehicleList = baseMapper.exportBasicdataVehicle(ids.isEmpty() ? null : Func.toLongList(ids)); // List basicdataCarrierVOS = basicdataCarrierService.selectBasicdataCarrierDictionary(); @@ -106,7 +132,7 @@ public class BasicdataVehicleServiceImpl extends BaseServiceImpl selectBasicdataVehicleDictionary(String vehicleNub) { - if(StringUtil.isBlank(vehicleNub)){ + if (StringUtil.isBlank(vehicleNub)) { vehicleNub = null; } return baseMapper.selectBasicdataDictionary(vehicleNub); @@ -116,30 +142,30 @@ public class BasicdataVehicleServiceImpl extends BaseServiceImpl().lambda().eq(BasicdataDrivermiddleEntity::getBrandId, basicdataVehicle.getId())); - if (basicdataVehicle.getVehicleOwners().isEmpty()){ + if (basicdataVehicle.getVehicleOwners().isEmpty()) { return delete; } //新增现有的数据 - // if (delete>0){ - List bindOwners = Arrays.asList(basicdataVehicle.getVehicleOwners().split(",")); - ArrayList basicdataDrivermiddleEntities = new ArrayList<>(); - bindOwners.forEach(e->{ - BasicdataDrivermiddleEntity basicdataDrivermiddleEntity = new BasicdataDrivermiddleEntity(); - basicdataDrivermiddleEntity.setBrandId(basicdataVehicle.getId()); - basicdataDrivermiddleEntity.setDriverId(Long.valueOf(e)); - basicdataDrivermiddleEntities.add(basicdataDrivermiddleEntity); - }); - - basicdataDrivermiddleService.saveBatch(basicdataDrivermiddleEntities); - // } + // if (delete>0){ + List bindOwners = Arrays.asList(basicdataVehicle.getVehicleOwners().split(",")); + ArrayList basicdataDrivermiddleEntities = new ArrayList<>(); + bindOwners.forEach(e -> { + BasicdataDrivermiddleEntity basicdataDrivermiddleEntity = new BasicdataDrivermiddleEntity(); + basicdataDrivermiddleEntity.setBrandId(basicdataVehicle.getId()); + basicdataDrivermiddleEntity.setDriverId(Long.valueOf(e)); + basicdataDrivermiddleEntities.add(basicdataDrivermiddleEntity); + }); + + basicdataDrivermiddleService.saveBatch(basicdataDrivermiddleEntities); + // } return delete; } @Override public boolean saveVehicle(BasicdataVehicleDTO basicdataVehicle) { - if (Func.isNotEmpty(basicdataVehicle.getCarrierId())){ + if (Func.isNotEmpty(basicdataVehicle.getCarrierId())) { BasicdataCarrierEntity carrierEntity = basicdataCarrierService.getById(basicdataVehicle.getCarrierId()); - if (Func.isNotEmpty(carrierEntity)){ + if (Func.isNotEmpty(carrierEntity)) { basicdataVehicle.setCarrierName(carrierEntity.getCarrierName()); } @@ -152,7 +178,7 @@ public class BasicdataVehicleServiceImpl extends BaseServiceImpl list = this.list(); List basicdataVehicleVOS = new ArrayList<>(); - if(Func.isEmpty(list)){ + if (Func.isEmpty(list)) { return null; } // 查询所有的iD @@ -168,22 +194,22 @@ public class BasicdataVehicleServiceImpl extends BaseServiceImpl basicdataDriverArteryEntities1 = basicdataDriverArteryMapper.selectList(queryWrapper1); - if (Func.isNotEmpty(list)){ - list.forEach(l->{ + if (Func.isNotEmpty(list)) { + list.forEach(l -> { BasicdataVehicleVO vehicleVO = Func.copy(l, BasicdataVehicleVO.class); List basicdataDrivermiddleEntities = groupedEntities.get(vehicleVO.getId()); - if(Func.isNotEmpty(basicdataDrivermiddleEntities)){ + if (Func.isNotEmpty(basicdataDrivermiddleEntities)) { List driverIds = basicdataDrivermiddleEntities. stream().filter(f -> Func.isNotEmpty(f.getDriverId())).map(BasicdataDrivermiddleEntity::getDriverId).collect(Collectors.toList()); - if (Func.isNotEmpty(driverIds)){ + if (Func.isNotEmpty(driverIds)) { List basicdataDriverArteryEntities = new ArrayList(); for (Long driverId : driverIds) { - basicdataDriverArteryEntities1.forEach(e->{ - if (driverId.equals(e.getId())){ + basicdataDriverArteryEntities1.forEach(e -> { + if (driverId.equals(e.getId())) { basicdataDriverArteryEntities.add(e); } }); @@ -210,56 +236,56 @@ public class BasicdataVehicleServiceImpl extends BaseServiceImpl data) { String method = "#############BasicdataVehicleServiceImpl.importDriverArtery"; - log.info("车辆模板导入信息>>>>{}",data); + log.info("车辆模板导入信息>>>>{}", data); try { - ListdrivermiddleEntities = new ArrayList<>(); + List drivermiddleEntities = new ArrayList<>(); //对导入数据进行处理 for (BasicdataVehicleImportExcel datum : data) { BasicdataDrivermiddleEntity basicdataDrivermiddleEntity = null; BasicdataVehicleEntity entity = this.getOne(Wrappers.query().lambda().eq(BasicdataVehicleEntity::getVehicleNub, datum.getVehicleNub())); - if (Func.isNotEmpty(entity)){ + if (Func.isNotEmpty(entity)) { continue; } //查询模板信息是否合法 //车牌号是否合法 - if (Func.isEmpty(datum.getVehicleNub())){ + if (Func.isEmpty(datum.getVehicleNub())) { //车牌号为空 throw new ServiceException("请填写车牌号!"); } //查看是否填写了电话号码,如果填写了电话号码进行校验号码是否有效 - if (Func.isNotEmpty(datum.getVehicleUnitPhone())){ + if (Func.isNotEmpty(datum.getVehicleUnitPhone())) { //车辆所属单位电话校验 boolean a = PhoneCheckUtil.checkPhone(datum.getVehicleUnitPhone()); - if (a){ + if (a) { throw new ServiceException("请填写正确手机号码!"); - } + } } - if (Func.isNotEmpty(datum.getVehicleOwnerPhone())){ + if (Func.isNotEmpty(datum.getVehicleOwnerPhone())) { //车辆所属人电话校验 - boolean b = PhoneCheckUtil.checkPhone(datum.getVehicleOwnerPhone()); - if (b){ + boolean b = PhoneCheckUtil.checkPhone(datum.getVehicleOwnerPhone()); + if (b) { throw new ServiceException("请填写正确手机号码!"); } - //进行关系司机绑定 + //进行关系司机绑定 //查询是否存在司机 - if (!StringUtil.isBlank(datum.getVehicleOwner())){ - BasicdataDriverArteryEntity driverArteryEntity = basicdataDriverArteryMapper.findDriverListByPhone(datum.getVehicleOwner().trim(),datum.getVehicleOwnerPhone().trim()); + if (!StringUtil.isBlank(datum.getVehicleOwner())) { + BasicdataDriverArteryEntity driverArteryEntity = basicdataDriverArteryMapper.findDriverListByPhone(datum.getVehicleOwner().trim(), datum.getVehicleOwnerPhone().trim()); if (BeanUtil.isEmpty(driverArteryEntity)) { - log.info(method+ "查询到司机信息,进行绑定!>>>:{}",driverArteryEntity.getName()); - log.info(method+ "查询到司机信息,进行绑定!>>>:{}",driverArteryEntity.getPhone()); + log.info(method + "查询到司机信息,进行绑定!>>>:{}", driverArteryEntity.getName()); + log.info(method + "查询到司机信息,进行绑定!>>>:{}", driverArteryEntity.getPhone()); //绑定用户 basicdataDrivermiddleEntity = new BasicdataDrivermiddleEntity(); basicdataDrivermiddleEntity.setDriverId(driverArteryEntity.getId()); - } + } } } - if (Func.isNotEmpty(datum.getCarrierName())){ + if (Func.isNotEmpty(datum.getCarrierName())) { //存在承运商,进行承运商的校验 //找到数据库内的承运商 List basicdataCarrierEntities = basicdataCarrierService.list(Wrappers.lambdaQuery().eq(BasicdataCarrierEntity::getCarrierName, datum.getCarrierName())); @@ -279,16 +305,16 @@ public class BasicdataVehicleServiceImpl extends BaseServiceImpl Date: Tue, 15 Oct 2024 18:12:52 +0800 Subject: [PATCH 3/8] =?UTF-8?q?feat(all):=20=E5=A2=9E=E5=8A=A0=E9=85=8D?= =?UTF-8?q?=E9=80=81=E6=98=8E=E7=BB=862.0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 1 优化配送明细报表 --- .../controller/ReportDeliveryController.java | 14 ++++ .../report/mapper/ReportDeliverMapeer.java | 3 + .../report/mapper/ReportDeliverMapper.xml | 73 +++++++++++++++++++ .../report/reader/DeliveryDetailV2Reader.java | 43 +++++++++++ .../logpm/report/service/IAsyncService.java | 2 + .../report/service/ReportDeliverService.java | 5 ++ .../report/service/impl/AsyncServiceImpl.java | 5 ++ .../impl/ReportDeliverServiceImpl.java | 27 +++++++ 8 files changed, 172 insertions(+) create mode 100644 blade-service/logpm-report/src/main/java/com/logpm/report/reader/DeliveryDetailV2Reader.java diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/controller/ReportDeliveryController.java b/blade-service/logpm-report/src/main/java/com/logpm/report/controller/ReportDeliveryController.java index 09de067aa..5f4f171f2 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/controller/ReportDeliveryController.java +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/controller/ReportDeliveryController.java @@ -90,6 +90,13 @@ public class ReportDeliveryController extends BladeController { IPage pages = reportDeliverService.detailsPage(vo, query); return R.data(pages); } + @GetMapping("/details/v2") + @ApiOperationSupport(order = 5) + @ApiOperation(value = "配送明细报表v2", notes = "配送明细报表v2") + public R> detailsPageV2(ReportDetailVO vo, DevilerDetailsQuery query) { + IPage pages = reportDeliverService.detailsPageV2(vo, query); + return R.data(pages); + } @GetMapping("/exportDetails") @ApiOperationSupport(order = 6) @@ -97,6 +104,13 @@ public class ReportDeliveryController extends BladeController { public void exportDetails(HttpServletResponse response, ReportDetailVO vo, DevilerDetailsQuery query) { reportDeliverService.exportDetails(response, vo, query); + } + @GetMapping("/exportDetails/v2") + @ApiOperationSupport(order = 6) + @ApiOperation(value = "导出配送明细报表v2", notes = "导出配送明细报表v2") + public void exportDetailsV2(HttpServletResponse response, ReportDetailVO vo, DevilerDetailsQuery query) { + reportDeliverService.exportDetailsV2(response, vo, query); + } @GetMapping("/stockOrder") diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapeer.java b/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapeer.java index bd6a6bacc..7795250d3 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapeer.java +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapeer.java @@ -70,6 +70,9 @@ public interface ReportDeliverMapeer extends BaseMapper { List getDeliveryTrainLoadSacnInvnByIds(@Param("idBatch") List idBatch); Long getDetailsPageCount(@Param("ew") Wrapper query); + Long getDetailsV2PageCount(@Param("ew") Wrapper query); List getDetailsPageExport(@Param("ew") Wrapper queryWrapper, @Param("current") Integer current, @Param("size") Integer size); + + List getDetailsPageV2(IPage page, @Param("ew") Wrapper queryWrapper); } diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapper.xml b/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapper.xml index e4d158a4a..b6f6a8d9d 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapper.xml +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/mapper/ReportDeliverMapper.xml @@ -500,6 +500,74 @@ + + + select * + from (select plan_train_number train_number, + plan_reservation_code reservation_code, + delivery_time task_time, + warehouse_name warehouse_name, + warehouse_id warehouse_id, + delivery_type type, + delivery_kind kind, + vehicle_name vehicle_name, + driver_name driver_name, + distribution_company distribution_company, + custom_name dr_consignee, + custom_phone delivery_phone, + custom_address delivery_address, + consignee_unit consignee, + consignee_person consignee_name, + consignee_mobile consignee_mobile, + waybill_number waybill_no, + order_code stock_article_id, + order_package_code order_package_code, + train_number customer_train, + case + when conditions = 1 then '订制品' + when conditions = 2 then '零担' + when conditions = 3 then '库存品' end conditions, + firsts_product firsts, + second_product decond, + third_product third_product, + materiel_code material_code, + materiel_name material_name, + begin_warehouse_name start_war, + begin_warehouse_in_time start_war_in_time, + begin_warehouse_out_time start_war_out_time, + end_warehouse_in_time warehouse_entry_time_end, + case + when sign_status = 1 then '已签收' + when sign_status = 0 then '未签收' + when sign_status = -1 then '已回库' end driver_signing, + load_time unload_time, + load_user_name un_administrators_name, + sign_time sjsigning_time, + sign_user_name lds_signee_name, + case when review_time is null then '未复核' else '已复核' end signing_status, + review_time signing_time, + sign_num sign_num, + case + when sign_type = 1 then '司机扫描签收' + when sign_type = 2 then '司机批量签收' + when sign_type = 1 then '文员批量签收' end sign_type, + case + when load_type = 2 then '按件装车' + when load_type = 3 then '按订单装车' + when load_type = 4 then '一键装车' + when load_type = 5 then '补录装车' end loading_mode, + brand_name brand, + review_user_name examine_user_name, + case + when plan_reservation_code = sign_reservation_code then '否' + when plan_reservation_code != sign_reservation_code then '是' + else '' end abnormal_signing + from logpm_quality_deliver + order by id desc + ) t ${ew.customSqlSegment} + select id, @@ -837,6 +905,11 @@ ) t +