BillRuleServiceImpl.java 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. package jnpf.base.service.impl;
  2. import cn.hutool.core.util.IdUtil;
  3. import cn.hutool.core.util.ObjectUtil;
  4. import jnpf.base.model.billrule.BillRulePagination;
  5. import jnpf.base.service.SuperServiceImpl;
  6. import com.baomidou.dynamic.datasource.annotation.DSTransactional;
  7. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  8. import com.baomidou.mybatisplus.core.metadata.IPage;
  9. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  10. import jnpf.base.ActionResult;
  11. import jnpf.base.Pagination;
  12. import jnpf.base.entity.BillRuleEntity;
  13. import jnpf.base.mapper.BillRuleMapper;
  14. import jnpf.base.service.BillRuleService;
  15. import jnpf.constant.MsgCode;
  16. import jnpf.exception.DataException;
  17. import jnpf.util.*;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.stereotype.Service;
  20. import org.springframework.transaction.annotation.Transactional;
  21. import java.util.*;
  22. /**
  23. * 单据规则
  24. *
  25. * @author JNPF开发平台组
  26. * @version V3.1.0
  27. * @copyright 引迈信息技术有限公司
  28. * @date 2019年9月27日 上午9:18
  29. */
  30. @Service
  31. public class BillRuleServiceImpl extends SuperServiceImpl<BillRuleMapper, BillRuleEntity> implements BillRuleService {
  32. @Autowired
  33. private RedisUtil redisUtil;
  34. @Override
  35. public List<BillRuleEntity> getList(BillRulePagination pagination) {
  36. // 定义变量判断是否需要使用修改时间倒序
  37. boolean flag = false;
  38. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  39. if (!StringUtil.isEmpty(pagination.getKeyword())) {
  40. flag = true;
  41. queryWrapper.lambda().and(
  42. t -> t.like(BillRuleEntity::getFullName, pagination.getKeyword())
  43. .or().like(BillRuleEntity::getEnCode, pagination.getKeyword())
  44. );
  45. }
  46. if (!StringUtil.isEmpty(pagination.getCategoryId())) {
  47. flag = true;
  48. queryWrapper.lambda().and(
  49. t -> t.like(BillRuleEntity::getCategory, pagination.getCategoryId())
  50. );
  51. }
  52. if (pagination.getEnabledMark() != null) {
  53. flag = true;
  54. queryWrapper.lambda().eq(BillRuleEntity::getEnabledMark, pagination.getEnabledMark());
  55. }
  56. // 排序
  57. queryWrapper.lambda().orderByAsc(BillRuleEntity::getSortCode).orderByDesc(BillRuleEntity::getCreatorTime);
  58. if (flag) {
  59. queryWrapper.lambda().orderByDesc(BillRuleEntity::getLastModifyTime);
  60. }
  61. Page<BillRuleEntity> page = new Page<>(pagination.getCurrentPage(), pagination.getPageSize());
  62. IPage<BillRuleEntity> userPage = this.page(page, queryWrapper);
  63. return pagination.setData(userPage.getRecords(), page.getTotal());
  64. }
  65. @Override
  66. public List<BillRuleEntity> getList() {
  67. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  68. queryWrapper.lambda().eq(BillRuleEntity::getEnabledMark, 1);
  69. // 排序
  70. queryWrapper.lambda().orderByAsc(BillRuleEntity::getSortCode).orderByDesc(BillRuleEntity::getCreatorTime);
  71. return this.list(queryWrapper);
  72. }
  73. @Override
  74. public BillRuleEntity getInfo(String id) {
  75. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  76. queryWrapper.lambda().eq(BillRuleEntity::getId, id);
  77. return this.getOne(queryWrapper);
  78. }
  79. @Override
  80. public boolean isExistByFullName(String fullName, String id) {
  81. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  82. queryWrapper.lambda().eq(BillRuleEntity::getFullName, fullName);
  83. if (!StringUtil.isEmpty(id)) {
  84. queryWrapper.lambda().ne(BillRuleEntity::getId, id);
  85. }
  86. return this.count(queryWrapper) > 0 ? true : false;
  87. }
  88. @Override
  89. public boolean isExistByEnCode(String enCode, String id) {
  90. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  91. queryWrapper.lambda().eq(BillRuleEntity::getEnCode, enCode);
  92. if (!StringUtil.isEmpty(id)) {
  93. queryWrapper.lambda().ne(BillRuleEntity::getId, id);
  94. }
  95. return this.count(queryWrapper) > 0 ? true : false;
  96. }
  97. @Override
  98. @DSTransactional
  99. public String getNumber(String enCode) throws DataException {
  100. StringBuilder strNumber = new StringBuilder();
  101. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  102. queryWrapper.lambda().eq(BillRuleEntity::getEnCode, enCode);
  103. BillRuleEntity entity = this.getOne(queryWrapper);
  104. if (entity != null) {
  105. Integer startNumber = StringUtil.isEmpty(entity.getStartNumber()) ? 0 : Integer.parseInt(entity.getStartNumber());
  106. //拼接单据编码
  107. strNumber.append(StringUtil.isNotEmpty(entity.getPrefix()) ? entity.getPrefix() : "");
  108. if (ObjectUtil.equal(entity.getType(), 2)) {
  109. // 随机数编号
  110. if (ObjectUtil.equal(entity.getRandomType(), 1)) {
  111. strNumber.append(cn.hutool.core.util.RandomUtil.randomNumbers(entity.getRandomDigit()));
  112. } else {
  113. strNumber.append(cn.hutool.core.util.RandomUtil.randomStringUpper(entity.getRandomDigit()));
  114. }
  115. } else if (ObjectUtil.equal(entity.getType(), 3)) {
  116. // UUID
  117. strNumber.append(IdUtil.randomUUID().toUpperCase());
  118. } else {
  119. // 时间格式
  120. String dateFor = entity.getDateFormat();
  121. String dateForValue = "no";
  122. switch (dateFor) {
  123. case "YYYY":
  124. dateForValue = "yyyy";
  125. break;
  126. case "YYYYMM":
  127. dateForValue = "yyyyMM";
  128. break;
  129. case "YYYYMMDD":
  130. dateForValue = "yyyyMMdd";
  131. break;
  132. case "YYYYMMDDHH":
  133. dateForValue = "yyyyMMddHH";
  134. break;
  135. case "YYYYMMDDHHmm":
  136. dateForValue = "yyyyMMddHHmm";
  137. break;
  138. case "YYYYMMDDHHmmss":
  139. dateForValue = "yyyyMMddHHmmss";
  140. break;
  141. case "YYYYMMDDHHmmssSSS":
  142. dateForValue = "yyyyMMddHHmmssSSS";
  143. break;
  144. }
  145. //处理隔天流水号归0
  146. if (entity.getOutputNumber() != null) {
  147. String serialDate = "";
  148. entity.setThisNumber(entity.getThisNumber() + 1);
  149. if (!"no".equals(dateForValue)) {
  150. String thisDate = DateUtil.dateNow(dateForValue);
  151. int suffixLength = entity.getSuffix() != null ? entity.getSuffix().length() : 0;
  152. try{
  153. serialDate= entity.getOutputNumber().substring((entity.getOutputNumber().length() - dateForValue.length() - entity.getDigit() - suffixLength), (entity.getOutputNumber().length() - entity.getDigit() - suffixLength));
  154. }catch (Exception e){
  155. }
  156. if (!serialDate.equals(thisDate)) {
  157. entity.setThisNumber(0);
  158. }
  159. }
  160. } else {
  161. entity.setThisNumber(0);
  162. }
  163. if (!"no".equals(dateForValue)) {
  164. strNumber.append(DateUtil.dateNow(dateForValue));
  165. }
  166. strNumber.append(PadUtil.padRight(String.valueOf(startNumber + entity.getThisNumber()), entity.getDigit(), '0'));
  167. }
  168. strNumber.append(StringUtil.isNotEmpty(entity.getSuffix()) ? entity.getSuffix() : "");
  169. //更新流水号
  170. entity.setOutputNumber(strNumber.toString());
  171. this.updateById(entity);
  172. } else {
  173. throw new DataException("单据规则不存在");
  174. }
  175. return strNumber.toString();
  176. }
  177. @Override
  178. public void create(BillRuleEntity entity) {
  179. entity.setId(RandomUtil.uuId());
  180. entity.setCreatorUserId(UserProvider.getUser().getUserId());
  181. this.save(entity);
  182. }
  183. @Override
  184. public boolean update(String id, BillRuleEntity entity) {
  185. entity.setId(id);
  186. entity.setLastModifyTime(new Date());
  187. entity.setLastModifyUserId(UserProvider.getUser().getUserId());
  188. return this.updateById(entity);
  189. }
  190. @Override
  191. public void delete(BillRuleEntity entity) {
  192. this.removeById(entity.getId());
  193. }
  194. @Override
  195. @DSTransactional
  196. public boolean first(String id) {
  197. boolean isOk = false;
  198. //获取要上移的那条数据的信息
  199. BillRuleEntity upEntity = this.getById(id);
  200. Long upSortCode = upEntity.getSortCode() == null ? 0 : upEntity.getSortCode();
  201. //查询上几条记录
  202. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  203. queryWrapper.lambda()
  204. .lt(BillRuleEntity::getSortCode, upSortCode)
  205. .orderByDesc(BillRuleEntity::getSortCode);
  206. List<BillRuleEntity> downEntity = this.list(queryWrapper);
  207. if (downEntity.size() > 0) {
  208. //交换两条记录的sort值
  209. Long temp = upEntity.getSortCode();
  210. upEntity.setSortCode(downEntity.get(0).getSortCode());
  211. downEntity.get(0).setSortCode(temp);
  212. this.updateById(downEntity.get(0));
  213. this.updateById(upEntity);
  214. isOk = true;
  215. }
  216. return isOk;
  217. }
  218. @Override
  219. @DSTransactional
  220. public boolean next(String id) {
  221. boolean isOk = false;
  222. //获取要下移的那条数据的信息
  223. BillRuleEntity downEntity = this.getById(id);
  224. Long upSortCode = downEntity.getSortCode() == null ? 0 : downEntity.getSortCode();
  225. //查询下几条记录
  226. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  227. queryWrapper.lambda()
  228. .gt(BillRuleEntity::getSortCode, upSortCode)
  229. .orderByAsc(BillRuleEntity::getSortCode);
  230. List<BillRuleEntity> upEntity = this.list(queryWrapper);
  231. if (upEntity.size() > 0) {
  232. //交换两条记录的sort值
  233. Long temp = downEntity.getSortCode();
  234. downEntity.setSortCode(upEntity.get(0).getSortCode());
  235. upEntity.get(0).setSortCode(temp);
  236. this.updateById(upEntity.get(0));
  237. this.updateById(downEntity);
  238. isOk = true;
  239. }
  240. return isOk;
  241. }
  242. @Override
  243. public String getBillNumber(String enCode, boolean isCache) throws DataException {
  244. String strNumber;
  245. String tenantId = !StringUtil.isEmpty(UserProvider.getUser().getTenantId()) ? UserProvider.getUser().getTenantId() : "";
  246. if (isCache) {
  247. String cacheKey = tenantId + UserProvider.getUser().getUserId() + enCode;
  248. if (!redisUtil.exists(cacheKey)) {
  249. strNumber = this.getNumber(enCode);
  250. redisUtil.insert(cacheKey, strNumber);
  251. } else {
  252. strNumber = String.valueOf(redisUtil.getString(cacheKey));
  253. }
  254. } else {
  255. strNumber = this.getNumber(enCode);
  256. }
  257. return strNumber;
  258. }
  259. @Override
  260. public void useBillNumber(String enCode) {
  261. String cacheKey = UserProvider.getUser().getTenantId() + UserProvider.getUser().getUserId() + enCode;
  262. redisUtil.remove(cacheKey);
  263. }
  264. @Override
  265. @Transactional
  266. public ActionResult ImportData(BillRuleEntity entity, Integer type) throws DataException {
  267. if (entity != null) {
  268. StringJoiner stringJoiner = new StringJoiner("、");
  269. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  270. queryWrapper.lambda().eq(BillRuleEntity::getId, entity.getId());
  271. if (this.count(queryWrapper) > 0) {
  272. if (Objects.equals(type, 0)) {
  273. stringJoiner.add("ID");
  274. } else {
  275. entity.setId(RandomUtil.uuId());
  276. }
  277. }
  278. queryWrapper = new QueryWrapper<>();
  279. queryWrapper.lambda().eq(BillRuleEntity::getEnCode, entity.getEnCode());
  280. if (this.count(queryWrapper) > 0) {
  281. stringJoiner.add("编码");
  282. }
  283. queryWrapper = new QueryWrapper<>();
  284. queryWrapper.lambda().eq(BillRuleEntity::getFullName, entity.getFullName());
  285. if (this.count(queryWrapper) > 0) {
  286. stringJoiner.add("名称");
  287. }
  288. if (stringJoiner.length() > 0 && ObjectUtil.equal(type, 1)) {
  289. String copyNum = UUID.randomUUID().toString().substring(0, 5);
  290. entity.setFullName(entity.getFullName() + ".副本" + copyNum);
  291. entity.setEnCode(entity.getEnCode() + copyNum);
  292. } else if (ObjectUtil.equal(type, 0) && stringJoiner.length() > 0) {
  293. return ActionResult.fail(stringJoiner.toString() + "重复");
  294. }
  295. entity.setCreatorTime(new Date());
  296. entity.setCreatorUserId(UserProvider.getLoginUserId());
  297. entity.setLastModifyTime(null);
  298. entity.setLastModifyUserId(null);
  299. try {
  300. this.setIgnoreLogicDelete().removeById(entity);
  301. entity.setEnabledMark(0);
  302. entity.setThisNumber(null);
  303. entity.setOutputNumber(null);
  304. this.setIgnoreLogicDelete().saveOrUpdate(entity);
  305. } catch (Exception e) {
  306. throw new DataException(MsgCode.IMP003.get());
  307. }finally {
  308. this.clearIgnoreLogicDelete();
  309. }
  310. return ActionResult.success(MsgCode.IMP001.get());
  311. }
  312. return ActionResult.fail(MsgCode.IMP004.get());
  313. }
  314. @Override
  315. public List<BillRuleEntity> getListByCategory(String id,Pagination pagination) {
  316. // 定义变量判断是否需要使用修改时间倒序
  317. boolean flag = false;
  318. QueryWrapper<BillRuleEntity> queryWrapper = new QueryWrapper<>();
  319. if (!StringUtil.isEmpty(pagination.getKeyword())) {
  320. flag = true;
  321. queryWrapper.lambda().and(
  322. t -> t.like(BillRuleEntity::getFullName, pagination.getKeyword())
  323. .or().like(BillRuleEntity::getEnCode, pagination.getKeyword())
  324. );
  325. }
  326. if (!StringUtil.isEmpty(id)) {
  327. flag = true;
  328. queryWrapper.lambda().eq(BillRuleEntity::getCategory, id);
  329. }
  330. queryWrapper.lambda().eq(BillRuleEntity::getEnabledMark, 1);
  331. // 排序
  332. queryWrapper.lambda().orderByAsc(BillRuleEntity::getSortCode).orderByDesc(BillRuleEntity::getCreatorTime);
  333. if (flag) {
  334. queryWrapper.lambda().orderByDesc(BillRuleEntity::getLastModifyTime);
  335. }
  336. Page<BillRuleEntity> page = new Page<>(pagination.getCurrentPage(), pagination.getPageSize());
  337. IPage<BillRuleEntity> userPage = this.page(page, queryWrapper);
  338. return pagination.setData(userPage.getRecords(), page.getTotal());
  339. }
  340. }