From f7e3925846166283517af0575dee3fcaf79f25fd Mon Sep 17 00:00:00 2001 From: liujie <1793218484@qq.com> Date: 星期四, 09 十月 2025 19:01:36 +0800 Subject: [PATCH] 患者诊疗 --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TErpProcurementController.java | 132 ++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 127 insertions(+), 5 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TErpProcurementController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TErpProcurementController.java index 1cf9c4e..1028728 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TErpProcurementController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TErpProcurementController.java @@ -27,6 +27,8 @@ import javax.validation.Valid; import java.math.BigDecimal; +import java.math.RoundingMode; +import java.time.LocalDateTime; import java.util.ArrayList; import java.util.List; import java.util.Map; @@ -54,12 +56,20 @@ private final TErpClinicWarehousingService erpClinicWarehousingService; private final TErpClinicWarehousingBatchService erpClinicWarehousingBatchService; private final TCrmSupplierService crmSupplierService; + private final TErpMaintenanceReminderService erpMaintenanceReminderService; + private final TSysOtherConfigService sysOtherConfigService; + private final TCrmClinicPointsService crmClinicPointsService; + private final TCrmChangePointsService crmChangePointsService; + private final TCrmBranchService crmBranchService; + private final TCrmSalespersonService crmSalespersonService; + private final TErpProcurementCommissionService erpProcurementCommissionService; + @Autowired - public TErpProcurementController(TErpProcurementService erpProcurementService, TokenService tokenService,TCrmClinicService crmClinicService,TErpProcurementGoodsService erpProcurementGoodsService - , TErpGoodsService erpGoodsService,TErpClinicWarehousingService erpClinicWarehousingService,TErpClinicWarehousingBatchService erpClinicWarehousingBatchService, - TCrmSupplierService crmSupplierService) { + public TErpProcurementController(TErpProcurementService erpProcurementService, TokenService tokenService, TCrmClinicService crmClinicService, TErpProcurementGoodsService erpProcurementGoodsService + , TErpGoodsService erpGoodsService, TErpClinicWarehousingService erpClinicWarehousingService, TErpClinicWarehousingBatchService erpClinicWarehousingBatchService, + TCrmSupplierService crmSupplierService, TErpMaintenanceReminderService erpMaintenanceReminderService, TSysOtherConfigService sysOtherConfigService, TCrmClinicPointsService crmClinicPointsService, TCrmChangePointsService crmChangePointsService, TCrmBranchService crmBranchService, TCrmSalespersonService crmSalespersonService, TErpProcurementCommissionService erpProcurementCommissionService) { this.erpProcurementService = erpProcurementService; this.tokenService = tokenService; this.crmClinicService = crmClinicService; @@ -68,6 +78,14 @@ this.erpClinicWarehousingService = erpClinicWarehousingService; this.erpClinicWarehousingBatchService = erpClinicWarehousingBatchService; this.crmSupplierService = crmSupplierService; + this.erpMaintenanceReminderService = erpMaintenanceReminderService; + this.sysOtherConfigService = sysOtherConfigService; + this.crmClinicPointsService = crmClinicPointsService; + this.crmChangePointsService = crmChangePointsService; + this.crmBranchService = crmBranchService; + this.crmSalespersonService = crmSalespersonService; + this.erpProcurementCommissionService = erpProcurementCommissionService; + } @@ -165,7 +183,7 @@ clinicSupplierId = crmClinic.getId(); } ArrayList<DetailProcurementNextVO> detailProcurementNextVOS = new ArrayList<>(); - List<TErpProcurement> list1 = erpProcurementService.list(new LambdaQueryWrapper<TErpProcurement>().eq(TErpProcurement::getStatus, 1).orderByDesc(BaseModel::getCreateTime)); + List<TErpProcurement> list1 = erpProcurementService.list(new LambdaQueryWrapper<TErpProcurement>().eq(TErpProcurement::getStatus, 1).orderByDesc(TErpProcurement::getCreateTime)); if(list1.isEmpty()){ return R.ok(detailProcurementNextVOS); } @@ -195,9 +213,10 @@ SysUser user = tokenService.getLoginUser().getUser(); Integer roleType = user.getRoleType(); String clinicSupplierId=null; + TCrmClinic crmClinic = null; if(roleType == 5){ // 诊所 - TCrmClinic crmClinic = crmClinicService.getOne(Wrappers.lambdaQuery(TCrmClinic.class) + crmClinic = crmClinicService.getOne(Wrappers.lambdaQuery(TCrmClinic.class) .eq(TCrmClinic::getUserId, user.getUserId()) .last("LIMIT 1")); clinicSupplierId = crmClinic.getId(); @@ -248,7 +267,109 @@ tErpClinicWarehousingGoods.setSalesAmount(tErpProcurementGoods.getSalesAmount()); erpClinicWarehousingBatchService.save(tErpClinicWarehousingGoods); + + if(erpGoods.getMaintenanceInterval()!=null){ + TErpMaintenanceReminder tErpMaintenanceReminder = new TErpMaintenanceReminder(); + tErpMaintenanceReminder.setClinicSupplierId(clinicSupplierId); + tErpMaintenanceReminder.setMaintenanceType(2); + tErpMaintenanceReminder.setWarehousingBatchId(tErpClinicWarehousingGoods.getId()); + Integer day = Integer.valueOf(erpGoods.getMaintenanceInterval()); + // 当前时间+day天 + LocalDateTime time1 = LocalDateTime.now().plusDays(day); + tErpMaintenanceReminder.setMaintenanceTime(time1); + erpMaintenanceReminderService.save(tErpMaintenanceReminder); + } + + } + + BigDecimal payMoney = erpProcurement.getPayMoney(); + // 诊所添加积分 分公司添加积分 业务员添加积分 分公司添加分佣记录 业务员添加分佣记录 + TSysOtherConfig sysOtherConfig= sysOtherConfigService.getById(1); + if(sysOtherConfig!=null && sysOtherConfig.getPointsExpiration()!=null){ + Integer pointsExpiration = sysOtherConfig.getPointsExpiration(); + if(sysOtherConfig.getExpireUnit().equals(2)){ + pointsExpiration = pointsExpiration * 31; + } + if(sysOtherConfig.getExpireUnit().equals(3)){ + pointsExpiration = pointsExpiration * 365; + } + Double procurementConditions = sysOtherConfig.getProcurementConditions(); + + // 积分数 + int points = payMoney.divide(BigDecimal.valueOf(procurementConditions), 2, RoundingMode.HALF_DOWN).intValue(); + TCrmClinicPoints tCrmClinicPoints = new TCrmClinicPoints(); + tCrmClinicPoints.setClinicId(erpProcurement.getClinicId()); + tCrmClinicPoints.setPoints(points); + tCrmClinicPoints.setExpireTime(LocalDateTime.now().plusDays(pointsExpiration)); + crmClinicPointsService.save(tCrmClinicPoints); + + TCrmChangePoints tCrmChangePoints = new TCrmChangePoints(); + tCrmChangePoints.setProcurementId(erpProcurement.getId()); + tCrmChangePoints.setBranchSalespersonId(erpProcurement.getClinicId()); + tCrmChangePoints.setUserType(3); + tCrmChangePoints.setChangeType(1); + tCrmChangePoints.setChangeReason(1); + tCrmChangePoints.setChangeValue(points); + crmChangePointsService.save(tCrmChangePoints); + + } + + String branchId = crmClinic.getBranchId(); + TCrmBranch branch = crmBranchService.getById(branchId); + if(branch!=null){ + + // 积分数 + int points = payMoney.divide(branch.getPointsCommission(), 2, RoundingMode.HALF_DOWN).intValue(); + + TCrmChangePoints tCrmChangePoints = new TCrmChangePoints(); + tCrmChangePoints.setProcurementId(erpProcurement.getId()); + tCrmChangePoints.setBranchSalespersonId(branchId); + tCrmChangePoints.setUserType(1); + tCrmChangePoints.setChangeType(1); + tCrmChangePoints.setChangeReason(1); + tCrmChangePoints.setChangeValue(points); + crmChangePointsService.save(tCrmChangePoints); + + + // 分佣 + BigDecimal commission = branch.getMoneyCommission().divide(BigDecimal.valueOf(100), 4, RoundingMode.HALF_DOWN).multiply(payMoney).setScale(2, RoundingMode.HALF_UP); + TErpProcurementCommission tErpProcurementCommission = new TErpProcurementCommission(); + tErpProcurementCommission.setProcurementId(erpProcurement.getId()); + tErpProcurementCommission.setCommissionType(1); + tErpProcurementCommission.setBranchSalespersonId(branchId); + tErpProcurementCommission.setMoney(commission.doubleValue()); + erpProcurementCommissionService.save(tErpProcurementCommission); + + } + + String salespersonId = crmClinic.getSalespersonId(); + TCrmSalesperson salesperson = crmSalespersonService.getById(salespersonId); + if(salesperson!=null){ + // 积分数 + int points = payMoney.divide(salesperson.getPointsCommission(), 2, RoundingMode.HALF_DOWN).intValue(); + TCrmChangePoints tCrmChangePoints = new TCrmChangePoints(); + tCrmChangePoints.setProcurementId(erpProcurement.getId()); + tCrmChangePoints.setBranchSalespersonId(salespersonId); + tCrmChangePoints.setUserType(2); + tCrmChangePoints.setChangeType(1); + tCrmChangePoints.setChangeReason(1); + tCrmChangePoints.setChangeValue(points); + crmChangePointsService.save(tCrmChangePoints); + + + + // 分佣 + BigDecimal commission = salesperson.getMoneyCommission().divide(BigDecimal.valueOf(100), 4, RoundingMode.HALF_DOWN).multiply(payMoney).setScale(2, RoundingMode.HALF_UP); + TErpProcurementCommission tErpProcurementCommission = new TErpProcurementCommission(); + tErpProcurementCommission.setProcurementId(erpProcurement.getId()); + tErpProcurementCommission.setCommissionType(2); + tErpProcurementCommission.setBranchSalespersonId(salespersonId); + tErpProcurementCommission.setMoney(commission.doubleValue()); + erpProcurementCommissionService.save(tErpProcurementCommission); + } + + return R.ok(); } @@ -259,5 +380,6 @@ + } -- Gitblit v1.7.1