PlanServiceImpl.java 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516
  1. package com.ruoyi.demo.service.impl;
  2. import cn.hutool.core.lang.Dict;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.github.pagehelper.PageHelper;
  5. import com.github.pagehelper.PageInfo;
  6. import com.ruoyi.demo.entity.*;
  7. import com.ruoyi.demo.entity.bo.CallBackBean;
  8. import com.ruoyi.demo.entity.bo.PlanAddBo;
  9. import com.ruoyi.demo.entity.bo.PlanBo;
  10. import com.ruoyi.demo.entity.bo.PlanItemAddBo;
  11. import com.ruoyi.demo.entity.vo.*;
  12. import com.ruoyi.demo.mapper.*;
  13. import com.ruoyi.demo.service.PlanService;
  14. import com.ruoyi.demo.utils.OnStateUtil;
  15. import com.ruoyi.demo.utils.SendCallBackUtil;
  16. import com.ruoyi.demo.utils.SignUtil;
  17. import com.ruoyi.demo.utils.StateUtil;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.stereotype.Service;
  20. import org.springframework.transaction.annotation.Transactional;
  21. import java.time.LocalDateTime;
  22. import java.time.ZoneId;
  23. import java.util.ArrayList;
  24. import java.util.List;
  25. import java.util.Map;
  26. @Service
  27. @Transactional
  28. public class PlanServiceImpl implements PlanService {
  29. @Autowired
  30. PlanMapper planMapper;
  31. @Autowired
  32. PlanItemMapper planItemMapper;
  33. @Autowired
  34. PlanAuditMapper planAuditMapper;
  35. @Autowired
  36. AppMapper appMapper;
  37. @Autowired
  38. CommercialMapper commercialMapper;
  39. @Autowired
  40. SystemSetterMapper systemSetterMapper;
  41. @Autowired
  42. StoreMapper storeMapper;
  43. @Autowired
  44. PlanPushStatisticsMapper planPushStatisticsMapper;
  45. @Autowired
  46. AddrCategoryMapper addrCategoryMapper;
  47. @Autowired
  48. EquipmentMapper equipmentMapper;
  49. @Autowired
  50. GoodsMapper goodsMapper;
  51. @Autowired
  52. StatisticsMapper statisticsMapper;
  53. @Autowired
  54. ExposureMapper exposureMapper;
  55. // @Autowired
  56. // SysUserMapper sysUserMapper;
  57. @Override
  58. public String getSign(PlanAddBo bo) {
  59. QueryWrapper<App> appQueryWrapper = new QueryWrapper<>();
  60. appQueryWrapper.eq("appkey",bo.getAppkey());
  61. appQueryWrapper.eq("state",1);
  62. appQueryWrapper.eq("deleted","0");
  63. App app = appMapper.selectOne(appQueryWrapper);
  64. if (app == null)
  65. return "error";
  66. Map<String,Object> params = Dict.create()
  67. .set("appkey",bo.getAppkey())
  68. .set("goodsId",bo.getGoodsId())
  69. .set("goodsImg",bo.getGoodsImg())
  70. .set("goodsIntroduce",bo.getGoodsIntroduce())
  71. .set("goodsLogo",bo.getGoodsLogo())
  72. .set("goodsName",bo.getGoodsName())
  73. .set("goodsClassify",bo.getGoodsClassify())
  74. .set("goodsPrice",bo.getGoodsPrice())
  75. .set("items",bo.getItems())
  76. .set("planEndTime",bo.getPlanEndTime())
  77. .set("planStartTime",bo.getPlanStartTime())
  78. .set("sign",null)
  79. .set("vendorId",bo.getVendorId())
  80. .set("vendorName",bo.getVendorName());
  81. return SignUtil.sign(params,app.getAppSecret());
  82. }
  83. @Override
  84. public int addPlan(PlanAddBo bo) {
  85. QueryWrapper<App> appQueryWrapper = new QueryWrapper<>();
  86. appQueryWrapper.eq("appkey",bo.getAppkey());
  87. appQueryWrapper.eq("state",1);
  88. appQueryWrapper.eq("deleted","0");
  89. App app = appMapper.selectOne(appQueryWrapper);
  90. if (app == null)
  91. return -1;
  92. Map<String,Object> params = Dict.create()
  93. .set("appkey",bo.getAppkey())
  94. .set("goodsId",bo.getGoodsId())
  95. .set("goodsImg",bo.getGoodsImg())
  96. .set("goodsIntroduce",bo.getGoodsIntroduce())
  97. .set("goodsLogo",bo.getGoodsLogo())
  98. .set("goodsName",bo.getGoodsName())
  99. .set("goodsClassify",bo.getGoodsClassify())
  100. .set("goodsPrice",bo.getGoodsPrice())
  101. .set("items",bo.getItems())
  102. .set("planEndTime",bo.getPlanEndTime())
  103. .set("planStartTime",bo.getPlanStartTime())
  104. .set("sign",bo.getSign())
  105. .set("vendorId",bo.getVendorId())
  106. .set("vendorName",bo.getVendorName());
  107. if (!SignUtil.verify(params,app.getAppSecret()))
  108. return -3;
  109. // 插入广告计划
  110. Plan plan = new Plan(app,bo);
  111. planMapper.insert(plan);
  112. // 插入广告计划明细
  113. for (PlanItemAddBo itemAddBo : bo.getItems()) {
  114. PlanItem item = new PlanItem(plan.getPlanId(), itemAddBo);
  115. planItemMapper.insert(item);
  116. }
  117. // 插入商品信息
  118. QueryWrapper<Goods> goodsQueryWrapper = new QueryWrapper<>();
  119. goodsQueryWrapper.eq("appkey",bo.getAppkey());
  120. goodsQueryWrapper.eq("goods_id",bo.getGoodsId());
  121. goodsQueryWrapper.eq("vendor_id",bo.getVendorId());
  122. Goods query = goodsMapper.selectOne(goodsQueryWrapper);
  123. if (query == null){
  124. Goods goods = new Goods(plan);
  125. goodsMapper.insert(goods);
  126. }
  127. return 1;
  128. }
  129. @Override
  130. public int deletePlan(String id) {
  131. QueryWrapper<PlanItem> itemQueryWrapper = new QueryWrapper<>();
  132. itemQueryWrapper.eq("plan_id",id);
  133. planItemMapper.delete(itemQueryWrapper);
  134. QueryWrapper<Plan> queryWrapper = new QueryWrapper<>();
  135. queryWrapper.eq("plan_id",id);
  136. return planMapper.delete(queryWrapper);
  137. }
  138. @Override
  139. public int deletePlans(List<String> ids) {
  140. int i = 0;
  141. for (String id : ids){
  142. QueryWrapper<Plan> queryWrapper = new QueryWrapper<>();
  143. queryWrapper.eq("plan_id",id);
  144. i += planMapper.delete(queryWrapper);
  145. }
  146. return i;
  147. }
  148. @Override
  149. public int checkPlan(PlanBo bo,Long userId,String userName) {
  150. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  151. planQueryWrapper.eq("plan_id",bo.getPlanId());
  152. planQueryWrapper.eq("deleted","0");
  153. Plan plan = planMapper.selectOne(planQueryWrapper);
  154. if (plan == null)
  155. return -1;
  156. // 没有该app或者该app已经被禁用,则不允许审核
  157. QueryWrapper<App> appQueryWrapper = new QueryWrapper<>();
  158. appQueryWrapper.eq("appkey",plan.getAppkey());
  159. appQueryWrapper.eq("state",1);
  160. appQueryWrapper.eq("deleted","0");
  161. App app = appMapper.selectOne(appQueryWrapper);
  162. if (app == null)
  163. return -1;
  164. plan.setState(bo.getState());
  165. int i = planMapper.updateById(plan);
  166. if (i == 0)
  167. return 0;
  168. // SysUser sysUser = sysUserMapper.selectById(userId);
  169. PlanAudit audit = new PlanAudit(bo,userId.toString(),userName);
  170. int insert = planAuditMapper.insert(audit);
  171. if (insert == 1){
  172. CallBackBean callBackBean = new CallBackBean();
  173. callBackBean.setAuditPerson(userName);
  174. if (bo.getState() == 1)
  175. callBackBean.setAuditComment("审核通过");
  176. else callBackBean.setAuditComment("审核不通过");
  177. callBackBean.setAuditTime(LocalDateTime.now(ZoneId.of("Asia/Shanghai")));
  178. SendCallBackUtil.sendCallBack(app.getCallBack(),callBackBean);
  179. }
  180. return insert;
  181. }
  182. @Override
  183. public PageInfo<List<PlanListVo>> getPlanList(PlanBo bo) {
  184. PageHelper.startPage(bo.getPageNum(), bo.getPageSize(),true);
  185. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  186. if (bo.getText() != null)
  187. planQueryWrapper.and(planQueryWrapper1 -> {
  188. planQueryWrapper1.like("plan_id",bo.getText())
  189. .or()
  190. .like("plan_name",bo.getText())
  191. .or()
  192. .like("principal_name",bo.getText())
  193. .or()
  194. .like("principal_telephone",bo.getText());
  195. });
  196. if (bo.getStartTime() != null)
  197. planQueryWrapper.apply("plan_create_time >= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getStartTime());
  198. if (bo.getEndTime() != null)
  199. planQueryWrapper.apply("plan_create_time <= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getEndTime());
  200. planQueryWrapper.eq("state", StateUtil.APPROVED);
  201. planQueryWrapper.eq("deleted","0");
  202. List<Plan> plans = planMapper.selectList(planQueryWrapper);
  203. List<PlanListVo> vos = new ArrayList<>();
  204. for (Plan plan : plans){
  205. vos.add(new PlanListVo(plan));
  206. }
  207. return new PageInfo(vos);
  208. }
  209. @Override
  210. public PlanDetailVo getPlanDetail(String planId) {
  211. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  212. planQueryWrapper.eq("plan_id",planId);
  213. planQueryWrapper.eq("deleted","0");
  214. Plan plan = planMapper.selectOne(planQueryWrapper);
  215. if (plan == null)
  216. return null;
  217. QueryWrapper<PlanItem> itemQueryWrapper = new QueryWrapper<>();
  218. itemQueryWrapper.eq("plan_id",planId);
  219. List<PlanItem> items = planItemMapper.selectList(itemQueryWrapper);
  220. List<PlanItemVo> itemVos = new ArrayList<>();
  221. if (items != null)
  222. for (PlanItem item : items){
  223. itemVos.add(new PlanItemVo(item));
  224. }
  225. PlanDetailVo vo = new PlanDetailVo(plan, itemVos);
  226. return vo;
  227. }
  228. @Override
  229. public List<PlanPushVo> getPlanPush(String equipmentId) {
  230. // 根据设备id查询可投放的广告计划
  231. // 再根据每个广告计划id,查询其商品信息
  232. List<PlanPushVo> pushVos = new ArrayList<>();
  233. QueryWrapper<PlanItem> itemQueryWrapper = new QueryWrapper<>();
  234. itemQueryWrapper.eq("equipment_id",equipmentId);
  235. itemQueryWrapper.eq("deleted","0");
  236. List<PlanItem> items = planItemMapper.selectList(itemQueryWrapper);
  237. for (PlanItem item : items){
  238. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  239. planQueryWrapper.apply("plan_start_time <= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",LocalDateTime.now(ZoneId.of("Asia/Shanghai")));
  240. planQueryWrapper.apply("plan_end_time > STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",LocalDateTime.now(ZoneId.of("Asia/Shanghai")));
  241. planQueryWrapper.eq("plan_id",item.getPlanId());
  242. planQueryWrapper.eq("state",StateUtil.APPROVED);
  243. planQueryWrapper.eq("deleted","0");
  244. Plan plan = planMapper.selectOne(planQueryWrapper);
  245. if (plan != null)
  246. pushVos.add(new PlanPushVo(item,plan));
  247. }
  248. return pushVos;
  249. }
  250. @Override
  251. public List<PlanPushVo> getPlanPushByCode(String equipmentCode) {
  252. List<PlanPushVo> pushVos = new ArrayList<>();
  253. QueryWrapper<PlanItem> itemQueryWrapper = new QueryWrapper<>();
  254. itemQueryWrapper.eq("equipment_code",equipmentCode);
  255. itemQueryWrapper.eq("deleted","0");
  256. List<PlanItem> items = planItemMapper.selectList(itemQueryWrapper);
  257. for (PlanItem item : items){
  258. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  259. planQueryWrapper.eq("plan_id",item.getPlanId());
  260. planQueryWrapper.apply("plan_start_time <= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",LocalDateTime.now(ZoneId.of("Asia/Shanghai")));
  261. planQueryWrapper.apply("plan_end_time > STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",LocalDateTime.now(ZoneId.of("Asia/Shanghai")));
  262. planQueryWrapper.eq("state",StateUtil.APPROVED);
  263. planQueryWrapper.eq("on_state", OnStateUtil.UP);
  264. planQueryWrapper.eq("deleted","0");
  265. Plan plan = planMapper.selectOne(planQueryWrapper);
  266. if (plan != null)
  267. pushVos.add(new PlanPushVo(item,plan));
  268. }
  269. return pushVos;
  270. }
  271. @Override
  272. public int planUpDown(String planId) {
  273. QueryWrapper<Plan> queryWrapper = new QueryWrapper<>();
  274. queryWrapper.eq("plan_id",planId);
  275. queryWrapper.eq("deleted","0");
  276. Plan plan = planMapper.selectOne(queryWrapper);
  277. if (plan == null)
  278. return -1;
  279. plan.setOnState(plan.getOnState()+1);
  280. if (plan.getOnState() >= 2)
  281. plan.setOnState(0);
  282. return planMapper.updateById(plan);
  283. }
  284. @Override
  285. public PageInfo<List<PlanManageListVo>> getPlanManageList(PlanBo bo) {
  286. PageHelper.startPage(bo.getPageNum(),bo.getPageSize(),true);
  287. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  288. planQueryWrapper.eq("state",bo.getState());
  289. if (bo.getText() != null)
  290. planQueryWrapper.and(planQueryWrapper1 -> {
  291. planQueryWrapper1.like("plan_id",bo.getText())
  292. .or()
  293. .like("app_name",bo.getText())
  294. .or()
  295. .like("commercial_name",bo.getText());
  296. });
  297. if (bo.getStartTime() != null)
  298. planQueryWrapper.apply("plan_start_time >= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getStartTime());
  299. if (bo.getEndTime() != null)
  300. planQueryWrapper.apply("plan_end_time <= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getEndTime());
  301. planQueryWrapper.eq("deleted","0");
  302. List<Plan> plans = planMapper.selectList(planQueryWrapper);
  303. List<PlanManageListVo> vos = new ArrayList<>();
  304. for (Plan plan : plans){
  305. PlanManageListVo vo = new PlanManageListVo(plan);
  306. Integer count = planItemMapper.selectEquipmentCountByPlanId(plan.getPlanId());
  307. vo.setEquipmentCount(count);
  308. vos.add(vo);
  309. }
  310. return new PageInfo(vos);
  311. }
  312. @Override
  313. public PlanManageDetailVo getPlanManageDetail(String planId) {
  314. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  315. planQueryWrapper.eq("plan_id",planId);
  316. planQueryWrapper.eq("deleted","0");
  317. Plan plan = planMapper.selectOne(planQueryWrapper);
  318. if (plan == null)
  319. return null;
  320. QueryWrapper<PlanItem> itemQueryWrapper = new QueryWrapper<>();
  321. itemQueryWrapper.eq("plan_id",planId);
  322. itemQueryWrapper.eq("deleted","0");
  323. List<PlanItem> items = planItemMapper.selectList(itemQueryWrapper);
  324. List<PlanManageItemVo> itemVos = new ArrayList<>();
  325. for (PlanItem item : items){
  326. PlanManageItemVo itemVo = new PlanManageItemVo(item);
  327. if (item.getStoreId() != null){
  328. Store store = storeMapper.selectById(item.getStoreId());
  329. if (store != null)
  330. itemVo.setStoreName(store.getStoreName());
  331. }
  332. itemVos.add(itemVo);
  333. }
  334. PlanManageDetailVo vo = new PlanManageDetailVo(plan, itemVos);
  335. return vo;
  336. }
  337. @Override
  338. public PageInfo<List<PlanPushListVo>> getPlanPushList(PlanBo bo) {
  339. PageHelper.startPage(bo.getPageNum(),bo.getPageSize(),true);
  340. QueryWrapper<Plan> planQueryWrapper = new QueryWrapper<>();
  341. planQueryWrapper.eq("appkey",bo.getAppkey());
  342. // planQueryWrapper.eq("commercial_id",bo.getCommercialId());
  343. if (bo.getText() != null)
  344. planQueryWrapper.and(planQueryWrapper1 -> {
  345. planQueryWrapper1.like("plan_id",bo.getText())
  346. .or()
  347. .like("plan_name",bo.getText())
  348. .or()
  349. .like("principal_name",bo.getText())
  350. .or()
  351. .like("principal_telephone",bo.getText());
  352. });
  353. if (bo.getStartTime() != null)
  354. planQueryWrapper.apply("plan_start_time >= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getStartTime());
  355. if (bo.getEndTime() != null)
  356. planQueryWrapper.apply("plan_end_time <= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getEndTime());
  357. planQueryWrapper.eq("deleted","0");
  358. List<Plan> plans = planMapper.selectList(planQueryWrapper);
  359. List<PlanPushListVo> vos = new ArrayList<>();
  360. for (Plan plan : plans){
  361. PlanPushListVo vo = new PlanPushListVo(plan);
  362. Integer count = planItemMapper.selectEquipmentCountByPlanId(plan.getPlanId());
  363. vo.setEquipmentCount(count);
  364. vos.add(vo);
  365. }
  366. return new PageInfo(vos);
  367. }
  368. @Override
  369. public PageInfo<List<PlanPushStatisticsListVo>> getPlanPushStatisticsList(PlanBo bo) {
  370. PageHelper.startPage(bo.getPageNum(),bo.getPageSize(),true);
  371. QueryWrapper<PlanPushStatistics> statisticsQueryWrapper = new QueryWrapper<>();
  372. if (bo.getText() != null)
  373. statisticsQueryWrapper.and(planPushStatisticsQueryWrapper -> {
  374. planPushStatisticsQueryWrapper.like("plan_id",bo.getText())
  375. .or()
  376. .like("equipment_id",bo.getText())
  377. .or()
  378. .like("equipment_code",bo.getText())
  379. .or()
  380. .like("equipment_name",bo.getText());
  381. });
  382. if (bo.getStartTime() != null)
  383. statisticsQueryWrapper.apply("laster_time >= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getStartTime());
  384. if (bo.getEndTime() != null)
  385. statisticsQueryWrapper.apply("laster_time <= STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')",bo.getEndTime());
  386. List<PlanPushStatistics> list = planPushStatisticsMapper.selectList(statisticsQueryWrapper);
  387. List<PlanPushStatisticsListVo> vos = new ArrayList<>();
  388. for (PlanPushStatistics statistics : list){
  389. vos.add(new PlanPushStatisticsListVo(statistics));
  390. }
  391. return new PageInfo(vos);
  392. }
  393. @Override
  394. public void planPushStatisticsStart() {
  395. // 清除当前月的统计记录
  396. QueryWrapper<PlanPushStatistics> planPushStatisticsQueryWrapper = new QueryWrapper<>();
  397. planPushStatisticsQueryWrapper.apply("DATE_FORMAT(laster_time,'%Y-%m') = STR_TO_DATE({0},'%Y-%m')",LocalDateTime.now(ZoneId.of("Asia/Shanghai")));
  398. planPushStatisticsMapper.delete(planPushStatisticsQueryWrapper);
  399. // 获取所有设备,遍历
  400. for (Equipment equipment : equipmentMapper.selectList(null)) {
  401. // 先查询设备下所有plan_item,再根据item_id统计查询曝光记录表获取曝光次数
  402. List<String> ids = planItemMapper.getItemIdsByCode(equipment.getEquipmentCode());
  403. Integer carousalCount = exposureMapper.selectTotalCountByItemIds(ids);
  404. // 统计查询统计信息表获取累计扫码量、累计交易数、累计用户数、累计收入
  405. Integer scanCount = statisticsMapper.selectScanByEquipmentCode(equipment.getEquipmentCode());
  406. Integer tradeCount = statisticsMapper.selectDealCountByEquipmentCode(equipment.getEquipmentCode());
  407. List<String> users = statisticsMapper.selectUserIdsByEquipmentCode(equipment.getEquipmentCode());
  408. Float totalPrice = statisticsMapper.selectTotalPriceByEquipmentCode(equipment.getEquipmentCode());
  409. // 插入记录
  410. PlanPushStatistics planPushStatistics = new PlanPushStatistics();
  411. planPushStatistics.setEquipmentId(equipment.getEquipmentId());
  412. planPushStatistics.setEquipmentName(equipment.getEquipmentName());
  413. planPushStatistics.setEquipmentCode(equipment.getEquipmentCode());
  414. planPushStatistics.setCarouselCount(carousalCount);
  415. planPushStatistics.setScanCodeCount(scanCount);
  416. planPushStatistics.setTradeCount(tradeCount);
  417. if (users == null)
  418. planPushStatistics.setTotalUserCount(0);
  419. else
  420. planPushStatistics.setTotalUserCount(users.size());
  421. if (totalPrice == null)
  422. planPushStatistics.setTotalPrice(Float.valueOf(0));
  423. else
  424. planPushStatistics.setTotalPrice(totalPrice);
  425. planPushStatistics.setLasterTime(LocalDateTime.now(ZoneId.of("Asia/Shanghai")));
  426. planPushStatisticsMapper.insert(planPushStatistics);
  427. }
  428. }
  429. @Override
  430. public PlanHomeVo getPlanTotal() {
  431. PlanHomeVo vo = new PlanHomeVo();
  432. vo.setTotal(planMapper.selectPlanTotal());
  433. return vo;
  434. }
  435. @Override
  436. public List<AddrCategory> getAddrCategory() {
  437. return addrCategoryMapper.selectList(null);
  438. }
  439. @Override
  440. public List<AddrCategory> getAddrCategoryLevel(String code,String level) {
  441. if ("province".equals(level)){
  442. QueryWrapper<AddrCategory> queryWrapper = new QueryWrapper<>();
  443. queryWrapper.eq("city","");
  444. return addrCategoryMapper.selectList(queryWrapper);
  445. }else if("city".equals(level)){
  446. QueryWrapper<AddrCategory> queryWrapper = new QueryWrapper<>();
  447. queryWrapper.likeRight("addr_code",code.substring(0,2));
  448. queryWrapper.and(categoryQueryWrapper -> {
  449. categoryQueryWrapper.eq("district", "").and(addrCategoryQueryWrapper -> {
  450. addrCategoryQueryWrapper.ne("city", "");
  451. });
  452. });
  453. return addrCategoryMapper.selectList(queryWrapper);
  454. }else if("zone".equals(level)){
  455. QueryWrapper<AddrCategory> queryWrapper = new QueryWrapper<>();
  456. queryWrapper.likeRight("addr_code",code.substring(0,4));
  457. queryWrapper.and(categoryQueryWrapper -> {
  458. categoryQueryWrapper.ne("district", "");
  459. });
  460. return addrCategoryMapper.selectList(queryWrapper);
  461. }
  462. return null;
  463. }
  464. @Override
  465. public PageInfo<List<Equipment>> getEquipments(PlanBo bo) {
  466. PageHelper.startPage(bo.getPageNum(),bo.getPageSize(),true);
  467. QueryWrapper<Equipment> equipmentQueryWrapper = new QueryWrapper<>();
  468. equipmentQueryWrapper.eq("state",1);
  469. if (bo.getText() != null)
  470. equipmentQueryWrapper.and(equipmentQueryWrapper1 -> {
  471. equipmentQueryWrapper1.like("equipment_id",bo.getText())
  472. .or()
  473. .like("equipment_code",bo.getText())
  474. .or()
  475. .like("equipment_name",bo.getText());
  476. });
  477. if (bo.getAddrCodes() != null){
  478. for (String addrCode : bo.getAddrCodes()){
  479. String province = String.valueOf(addrCode.charAt(0))+String.valueOf(addrCode.charAt(1));
  480. String city = String.valueOf(addrCode.charAt(2))+String.valueOf(addrCode.charAt(3));
  481. String district = String.valueOf(addrCode.charAt(4))+String.valueOf(addrCode.charAt(5));
  482. if (district.equals("00")){
  483. if (city.equals("00"))
  484. equipmentQueryWrapper.or().likeRight("addr_code",province);
  485. else
  486. equipmentQueryWrapper.or().likeRight("addr_code",province+city);
  487. }else
  488. equipmentQueryWrapper.or().likeRight("addr_code",province+city+district);
  489. }
  490. }
  491. return new PageInfo(equipmentMapper.selectList(equipmentQueryWrapper));
  492. }
  493. }