From 0d15a761181fded7a6512e4146e5156725fde1f7 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@63.com> Date: 星期六, 19 十一月 2022 09:00:00 +0800 Subject: [PATCH] # --- src/main/java/com/zy/crm/manager/service/impl/PlanServiceImpl.java | 55 ++++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 52 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/zy/crm/manager/service/impl/PlanServiceImpl.java b/src/main/java/com/zy/crm/manager/service/impl/PlanServiceImpl.java index d9cae79..b374ea7 100644 --- a/src/main/java/com/zy/crm/manager/service/impl/PlanServiceImpl.java +++ b/src/main/java/com/zy/crm/manager/service/impl/PlanServiceImpl.java @@ -1,12 +1,61 @@ package com.zy.crm.manager.service.impl; -import com.zy.crm.manager.mapper.PlanMapper; -import com.zy.crm.manager.entity.Plan; -import com.zy.crm.manager.service.PlanService; +import com.baomidou.mybatisplus.plugins.Page; import com.baomidou.mybatisplus.service.impl.ServiceImpl; +import com.core.common.Cools; +import com.zy.crm.manager.entity.Plan; +import com.zy.crm.manager.mapper.PlanMapper; +import com.zy.crm.manager.service.PlanService; import org.springframework.stereotype.Service; @Service("planService") public class PlanServiceImpl extends ServiceImpl<PlanMapper, Plan> implements PlanService { + @Override + public Plan selectByUuid(Long hostId, String uuid) { + return this.baseMapper.selectByUuid(hostId, uuid); + } + + @Override + public String getUuid(Long hostId) { + String uuid = null; + int times = 0; + while (Cools.isEmpty(uuid)) { + if (times > 100) { break; } + String nextUuid = getNextUuid(hostId); + if (selectByUuid(hostId, nextUuid) == null) { + uuid = nextUuid; + } + times ++; + } + return uuid; + } + + @Override + public Page<Plan> getPage(Page<Plan> page, Long hostId, String deptId, Long userId, String condition) { + return page.setRecords(baseMapper.listByPage(page, hostId, deptId, userId, condition)); + } + + private String getNextUuid(Long hostId) { + Plan plan = this.baseMapper.selectPlanByNewestUuid(hostId); + if (plan == null) { + return "0001"; + } + return zerofill(String.valueOf(Integer.parseInt(plan.getUuid()) + 1), 4); + } + + public static String zerofill(String msg, Integer count){ + if (msg.length() == count){ + return msg; + } else if (msg.length() > count){ + return msg.substring(0, 16); + } else { + StringBuilder msgBuilder = new StringBuilder(msg); + for (int i = 0; i<count-msg.length(); i++){ + msgBuilder.insert(0,"0"); + } + return msgBuilder.toString(); + } + } + } -- Gitblit v1.9.1