DeviceInfoServiceImpl.java 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974
  1. package com.xy.service;
  2. import cn.hutool.core.bean.BeanUtil;
  3. import cn.hutool.core.collection.CollUtil;
  4. import cn.hutool.core.date.DatePattern;
  5. import cn.hutool.core.date.DateUtil;
  6. import cn.hutool.core.text.StrBuilder;
  7. import cn.hutool.core.util.BooleanUtil;
  8. import cn.hutool.core.util.NumberUtil;
  9. import cn.hutool.core.util.StrUtil;
  10. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  11. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  12. import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
  13. import com.baomidou.mybatisplus.core.metadata.IPage;
  14. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  15. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  16. import com.xy.collections.list.JArrayList;
  17. import com.xy.collections.list.JList;
  18. import com.xy.config.DeviceThreadPoolConfig;
  19. import com.xy.consts.DictConsts;
  20. import com.xy.dto.*;
  21. import com.xy.entity.*;
  22. import com.xy.enums.FileExportType;
  23. import com.xy.error.CommRuntimeException;
  24. import com.xy.mapper.DeviceInfoMapper;
  25. import com.xy.mapper.entity.DeviceInfoQueryPage;
  26. import com.xy.util.ExcelUtils;
  27. import com.xy.util.FileUtils;
  28. import com.xy.utils.*;
  29. import com.xy.utils.enums.DeviceActiveStateEnum;
  30. import com.xy.utils.enums.DeviceNetSateType;
  31. import com.xy.utils.enums.DictEnum;
  32. import com.xy.utils.enums.DictSonEnum;
  33. import io.swagger.annotations.Api;
  34. import io.swagger.annotations.ApiOperation;
  35. import jodd.introspector.MapperFunction;
  36. import lombok.RequiredArgsConstructor;
  37. import org.springframework.stereotype.Service;
  38. import org.springframework.transaction.annotation.Transactional;
  39. import org.springframework.validation.annotation.Validated;
  40. import org.springframework.web.bind.annotation.PostMapping;
  41. import org.springframework.web.bind.annotation.RequestBody;
  42. import javax.servlet.http.HttpServletResponse;
  43. import javax.validation.Valid;
  44. import java.io.IOException;
  45. import java.math.BigDecimal;
  46. import java.time.LocalDateTime;
  47. import java.util.*;
  48. import java.util.stream.Collectors;
  49. import static com.xy.utils.PlusBeans.*;
  50. /**
  51. * <p>
  52. * 设备-信息 服务实现类
  53. * </p>
  54. *
  55. * @author lijin
  56. * @since 2022-12-23
  57. */
  58. @Service
  59. @RequiredArgsConstructor
  60. @Api(tags = "设备-信息")
  61. public class DeviceInfoServiceImpl extends ServiceImpl<DeviceInfoMapper, DeviceInfo> implements DeviceInfoService {
  62. private final DeviceSysinfoServiceImpl deviceSysinfoService;
  63. private final DeviceStatusServiceImpl deviceStatusService;
  64. private final DeviceRegisterServiceImpl deviceRegisterService;
  65. private final DeviceErrorsRecordServiceImpl deviceErrorsRecordService;
  66. private final DeviceDataServiceImpl deviceDataService;
  67. private final DeviceTempRecordsServiceImpl deviceTempRecordsService;
  68. private final DeviceNetRecordServiceImpl deviceNetRecordService;
  69. private final GoodsDeviceService goodsDeviceService;
  70. private final FileExportService fileExportService;
  71. private final RedisService<String> redisService;
  72. private final String keyPrefix = "device:history:";
  73. private final FileUtils fileUtils;
  74. @Override
  75. @ApiOperation("对象查询")
  76. public R<DeviceInfoDto.Vo> obj(DeviceInfoDto.Obj obj) {
  77. //设备信息
  78. LambdaQueryWrapper<DeviceInfo> lambdaQueryWrapper = new MybatisPlusQuery().eqWrapper(obj, DeviceInfo.class).build();
  79. List<DeviceInfo> list = list(lambdaQueryWrapper);
  80. if (!Emptys.check(list)) {
  81. return R.ok();
  82. }
  83. DeviceInfoDto.Vo deviceInfo = copy(DeviceInfoDto.Vo.class, list.get(0));
  84. int num = 0;
  85. if (obj.getIsSysinfo()) {
  86. num++;
  87. }
  88. if (obj.getIsStatus()) {
  89. num++;
  90. }
  91. if (obj.getIsRegister()) {
  92. num++;
  93. }
  94. if (num > 0) {
  95. ThreadPoolUtils.Execute execute = ThreadPoolUtils.excPoll(DeviceThreadPoolConfig.DEVICE_COMMON_POLL, num);
  96. if (obj.getIsSysinfo()) {
  97. execute.execute(() -> {
  98. //系统信息
  99. DeviceSysinfoDto.Vo deviceSysinfo = deviceSysinfoService.get(new DeviceSysinfoDto.Vo().setDeviceId(deviceInfo.getDeviceId())).getData();
  100. deviceInfo.setDeviceSysinfo(deviceSysinfo);
  101. });
  102. }
  103. if (obj.getIsStatus()) {
  104. execute.execute(() -> {
  105. //状态信息
  106. DeviceStatusDto.Vo deviceStatus = deviceStatusService.obj(new DeviceStatusDto.Vo().setDeviceId(deviceInfo.getDeviceId())).getData();
  107. deviceInfo.setDeviceStatus(deviceStatus);
  108. });
  109. }
  110. if (obj.getIsRegister()) {
  111. execute.execute(() -> {
  112. //注册信息
  113. DeviceRegisterDto.Vo deviceRegister = deviceRegisterService.obj(new DeviceRegisterDto.Vo().setDeviceId(deviceInfo.getDeviceId())).getData();
  114. deviceInfo.setDeviceRegister(deviceRegister);
  115. });
  116. }
  117. execute.end();
  118. }
  119. return R.ok(deviceInfo);
  120. }
  121. @ApiOperation("反显设备名称")
  122. @Override
  123. public R<Map<Long, String>> getDeviceNameList(DeviceInfoDto.DeviceIdDto dto) {
  124. LambdaQueryWrapper<DeviceInfo> lqw = new LambdaQueryWrapper<DeviceInfo>()
  125. .in(DeviceInfo::getDeviceId, dto.getDeviceId())
  126. .select(DeviceInfo::getDeviceId, DeviceInfo::getDeviceName);
  127. List<DeviceInfo> deviceInfoList = list(lqw);
  128. return R.ok(deviceInfoList.stream().collect(Collectors.toMap(DeviceInfo::getDeviceId, i -> Optional.ofNullable(i.getDeviceName()).orElse(""))));
  129. }
  130. @Override
  131. @ApiOperation("设备访问历史添加")
  132. public R history(DeviceInfoDto.Obj obj) {
  133. //获取字典
  134. SysDictRedis sysDictRedis = SysDictUtils.get(DictEnum.DATA_CLEAR_SIZE.getKey(), "device_history_twig");
  135. Integer value = Integer.valueOf(sysDictRedis.getValue());
  136. //获取redis
  137. String key = keyPrefix + AuthorizeUtils.getLoginId(Long.class);
  138. List<String> list = redisService.getList(key);
  139. list.add(0, String.valueOf(obj.getDeviceId()));
  140. //去重
  141. List<String> redisList = new ArrayList<>();
  142. JList<String> comparing = new JArrayList<>(list).comparing();
  143. if (comparing.size() > value) {
  144. for (int i = 0; i < value; i++) {
  145. redisList.add(comparing.get(i));
  146. }
  147. } else {
  148. redisList = comparing;
  149. }
  150. redisService.removeList(key);
  151. redisService.setList(key, redisList);
  152. return R.ok();
  153. }
  154. @Override
  155. @ApiOperation("开门检测")
  156. public R<DeviceInfoDto.Vo> checkOpenDoor(DeviceInfoDto.Obj obj) {
  157. DeviceInfoDto.Vo deviceInfo = obj(new DeviceInfoDto.Obj()
  158. .setDeviceId(obj.getDeviceId())
  159. .setIsStatus(true)
  160. ).getData();
  161. if (deviceInfo == null) {
  162. return R.fail("设备不存在");
  163. }
  164. DeviceStatusDto.Vo deviceStatus = deviceInfo.getDeviceStatus();
  165. check(deviceInfo.getFreezeStatus(), 2, "设备已冻结");
  166. SysDictRedis sysDictRedis = SysDictUtils.get(DictEnum.DEVICE_FAULT_LEVEL_PAY_THRESHOLD.getKey(), DictSonEnum.DEVICE_FAULT_LEVEL_PAY_THRESHOLD_NOT_PAY.getKey());
  167. if (deviceInfo.getFaultLevel() >= Integer.valueOf(sysDictRedis.getValue())) {
  168. return R.fail("设备故障");
  169. }
  170. check(deviceStatus.getNetState(), 2, "设备已离线");
  171. check(obj.getDoor() != null && obj.getDoor() == 1 ? deviceStatus.getDoorStateR() : deviceStatus.getDoorStateL(), 1, "设备正在使用中,请稍后");
  172. check(obj.getDoor() != null && obj.getDoor() == 1 ? deviceStatus.getLockStateR() : deviceStatus.getLockStateL(), 2, "设备已锁机");
  173. return R.ok(deviceInfo);
  174. }
  175. @PostMapping("historyList")
  176. @ApiOperation("设备访问历史查询")
  177. public R<List<DeviceInfoDto.Vo>> historyList() {
  178. //获取redis
  179. String key = keyPrefix + AuthorizeUtils.getLoginId(Long.class);
  180. List<String> deviceIds = redisService.getList(key);
  181. if (!Emptys.check(deviceIds)) {
  182. return R.ok();
  183. }
  184. //查询数据库
  185. List<DeviceInfo> list = list(new LambdaQueryWrapper<DeviceInfo>().in(DeviceInfo::getDeviceId, deviceIds));
  186. return R.ok(copy(DeviceInfoDto.Vo.class, list));
  187. }
  188. @ApiOperation("修改")
  189. @PostMapping("update")
  190. public R update(@RequestBody @Validated DeviceInfoDto.Update update) {
  191. DeviceInfo deviceInfo = copy(DeviceInfo.class, update);
  192. updateById(deviceInfo);
  193. return R.ok();
  194. }
  195. @ApiOperation("批量修改")
  196. @PostMapping("updateBatch")
  197. public R updateBatch(@RequestBody List<DeviceInfoDto.Update> updates) {
  198. List<DeviceInfo> deviceInfos = new ArrayList<>(updates.size());
  199. updates.forEach(update -> deviceInfos.add(copy(DeviceInfo.class, update)));
  200. updateBatchById(deviceInfos);
  201. return R.ok();
  202. }
  203. @Override
  204. @ApiOperation("更新商户线路")
  205. public R updateLine(@RequestBody @Validated DeviceInfoDto.UpdateLine updateLine) {
  206. LambdaUpdateWrapper<DeviceInfo> luw = new LambdaUpdateWrapper<DeviceInfo>().eq(DeviceInfo::getMercId, updateLine.getMercId());
  207. //绑定线路,更换线路
  208. if (DeviceInfoDto.UPDATE.equals(updateLine.getType())) {
  209. DeviceInfo deviceInfo = new DeviceInfo();
  210. deviceInfo.setPlaceLineId(updateLine.getPlaceLineId());
  211. luw.in(DeviceInfo::getDeviceId, updateLine.getDeviceIds());
  212. baseMapper.update(deviceInfo, luw);
  213. }
  214. //删除线路
  215. if (DeviceInfoDto.DEL.equals(updateLine.getType())) {
  216. luw.eq(DeviceInfo::getPlaceLineId, updateLine.getWherePlaceLineId());
  217. luw.set(DeviceInfo::getPlaceLineId, null);
  218. baseMapper.update(null, luw);
  219. }
  220. //解绑线路 设置线路ID为null
  221. if (DeviceInfoDto.CLEAR.equals(updateLine.getType())) {
  222. luw.in(DeviceInfo::getDeviceId, updateLine.getDeviceIds());
  223. luw.set(DeviceInfo::getPlaceLineId, null);
  224. baseMapper.update(null, luw);
  225. }
  226. return R.ok();
  227. }
  228. @Override
  229. @ApiOperation("更新商户点位")
  230. public R updatePlace(@RequestBody @Validated DeviceInfoDto.UpdatePlace updatePlace) {
  231. LambdaUpdateWrapper<DeviceInfo> luw = new LambdaUpdateWrapper<DeviceInfo>().eq(DeviceInfo::getMercId, updatePlace.getMercId());
  232. //绑定点位,更换点位
  233. if (DeviceInfoDto.UPDATE.equals(updatePlace.getType())) {
  234. DeviceInfo deviceInfo = new DeviceInfo();
  235. deviceInfo.setPlaceId(updatePlace.getPlaceId());
  236. luw.in(DeviceInfo::getDeviceId, updatePlace.getDeviceIds());
  237. baseMapper.update(deviceInfo, luw);
  238. }
  239. //删除点位
  240. if (DeviceInfoDto.DEL.equals(updatePlace.getType())) {
  241. luw.eq(DeviceInfo::getPlaceId, updatePlace.getWherePlaceId());
  242. luw.set(DeviceInfo::getPlaceId, null);
  243. baseMapper.update(null, luw);
  244. }
  245. //解绑点位 设置点位ID为null
  246. if (DeviceInfoDto.CLEAR.equals(updatePlace.getType())) {
  247. luw.in(DeviceInfo::getDeviceId, updatePlace.getDeviceIds());
  248. luw.set(DeviceInfo::getPlaceId, null);
  249. baseMapper.update(null, luw);
  250. }
  251. return R.ok();
  252. }
  253. @PostMapping("page")
  254. @ApiOperation("分页查询")
  255. public R<PageBean<DeviceInfoDto.Vo2>> page(@RequestBody DeviceInfoDto.Page page) {
  256. return R.ok(queryPage(page));
  257. }
  258. @ApiOperation("导出设备列表")
  259. @PostMapping("exportDevices")
  260. public void exportDevices(HttpServletResponse response, @RequestBody @Valid DeviceInfoDto.Page page) throws IOException {
  261. PageBean<DeviceInfoDto.Vo2> pageBean = queryPage(page);
  262. List<DeviceInfoDto.Vo2> records = pageBean.getRecords();
  263. List<DeviceInfoDto.DeviceExcelVO> deviceExcelVOS = BeanUtil.copyToList(records, DeviceInfoDto.DeviceExcelVO.class);
  264. // 输出
  265. ExcelUtils.write(response, "设备列表.xls", "设备列表", DeviceInfoDto.DeviceExcelVO.class, deviceExcelVOS);
  266. }
  267. @ApiOperation("导出设备(异步)")
  268. @PostMapping("exportDevices/async")
  269. public void exportDevicesAsync(@RequestBody @Validated DeviceInfoDto.Page page) {
  270. PageBean<DeviceInfoDto.Vo2> pageBean = queryPage(page);
  271. List<DeviceInfoDto.Vo2> records = pageBean.getRecords();
  272. List<DeviceInfoDto.DeviceExcelVO> deviceExcelVOS = BeanUtil.copyToList(records, DeviceInfoDto.DeviceExcelVO.class);
  273. //异步导出参数封装
  274. ExcelDTO<DeviceInfoDto.DeviceExcelVO> excelDTO = new ExcelDTO<>();
  275. excelDTO.setData(deviceExcelVOS);
  276. excelDTO.setHead(DeviceInfoDto.DeviceExcelVO.class);
  277. excelDTO.setSheetName(FileExportType.DEVICE_INFO.getDescription());
  278. excelDTO.setFileExportType(FileExportType.DEVICE_INFO);
  279. //执行导出
  280. fileExportService.exportExcelAsync(excelDTO);
  281. }
  282. @PostMapping("nearbyPage")
  283. @ApiOperation("附近设备分页查询")
  284. public R<PageBean<DeviceInfoDto.Vo2>> nearbyPage(@RequestBody DeviceInfoDto.Page page) {
  285. if (!Emptys.check(page.getLon()) || !Emptys.check(page.getLat())) {
  286. throw new CommRuntimeException("经纬度不能为空");
  287. }
  288. return R.ok(queryPage(page));
  289. }
  290. @ApiOperation(value = "商户设备授权", hidden = true)
  291. @Override
  292. @Transactional(rollbackFor = Exception.class)
  293. public R<Boolean> mercDeviceAuth(DeviceInfoDto.MercDeviceAuthDto auth) {
  294. Long mercId = auth.getMercId();
  295. String mercCode = auth.getMercCode();
  296. Long algorithmId = auth.getAlgorithmId();
  297. String mercName = auth.getMercName();
  298. //商户最终设备列表
  299. List<Long> deviceIds = auth.getDeviceIds();
  300. List<DeviceInfo> devices = getDevicesByMercId(mercId);
  301. //取消商户设备授权
  302. if (CollUtil.isEmpty(deviceIds)) {
  303. if (CollUtil.isEmpty(devices)) {
  304. return R.ok(Boolean.TRUE);
  305. }
  306. }
  307. //更新商户设备授权
  308. List<DeviceInfo> deviceInfos = this.listByIds(deviceIds);
  309. for (DeviceInfo deviceInfo : deviceInfos) {
  310. int refMercId = deviceInfo.getMercId().intValue();
  311. // 只有解绑后,才能给顶级商户授权
  312. if (refMercId != -1 && refMercId != mercId.intValue()) {
  313. StrBuilder sb = StrBuilder.create();
  314. String errMsg = sb.append("设备[")
  315. .append(deviceInfo.getDeviceId())
  316. .append("]")
  317. .append("已被商户[")
  318. .append(deviceInfo.getMercName())
  319. .append("]绑定,请先进行解绑!")
  320. .toString();
  321. //已关联别商户
  322. return R.fail(errMsg, Boolean.FALSE);
  323. }
  324. //绑定关系
  325. deviceInfo.setMercId(mercId).setMercCode(mercCode).setAlgorithmId(algorithmId).setMercName(mercName);
  326. }
  327. saveOrUpdateBatch(deviceInfos);
  328. // //原来存在的设备关系,不在最终设备列表中的移除
  329. // if (CollUtil.isNotEmpty(devices)) {
  330. // List<Long> oldIds = new ArrayList<>();
  331. // List<Long> removeIds = new ArrayList<>();
  332. // devices.forEach(device -> oldIds.add(device.getDeviceId()));
  333. // oldIds.forEach(deviceId -> {
  334. // //不在最终设备列表中的待移除
  335. // if (!deviceIds.contains(deviceId)) {
  336. // removeIds.add(deviceId);
  337. // }
  338. // });
  339. // if (CollUtil.isNotEmpty(removeIds)) {
  340. // List<DeviceInfo> removeList = this.listByIds(removeIds);
  341. // removeMerRefDevices(removeList, parentId);
  342. // }
  343. // }
  344. return R.ok(Boolean.TRUE);
  345. }
  346. /**
  347. * 解绑机器 回收
  348. *
  349. * @param dto
  350. * @return
  351. */
  352. @Override
  353. public R<Boolean> unBindMercDevice(DeviceInfoDto.MercDeviceUnBindDto dto) {
  354. List<DeviceInfo> deviceInfos = this.listByIds(dto.getDeviceIds());
  355. return R.ok(removeMerRefDevicesToTopMerc(deviceInfos));
  356. }
  357. /**
  358. * 回收机器
  359. *
  360. * @param deviceInfos
  361. * @return
  362. */
  363. private Boolean removeMerRefDevicesToTopMerc(List<DeviceInfo> deviceInfos) {
  364. if (CollUtil.isNotEmpty(deviceInfos)) {
  365. deviceInfos.forEach(deviceInfo -> {
  366. //回收
  367. deviceInfo.setMercId(-1L);
  368. deviceInfo.setMercDeviceCode(StrUtil.EMPTY);
  369. deviceInfo.setMercName(StrUtil.EMPTY);
  370. deviceInfo.setMercCode(StrUtil.EMPTY);
  371. });
  372. //批量更新
  373. return updateBatchById(deviceInfos);
  374. }
  375. return Boolean.FALSE;
  376. }
  377. /**
  378. * 批量移除商户设备绑定关系
  379. *
  380. * @param deviceInfos
  381. * @return
  382. */
  383. private Boolean removeMerRefDevices(List<DeviceInfo> deviceInfos, Long parentId) {
  384. if (CollUtil.isNotEmpty(deviceInfos) && parentId != null) {
  385. deviceInfos.forEach(deviceInfo -> {
  386. //非顶级兴元商户,解绑后,机器归父商户
  387. if (parentId != 1) {
  388. deviceInfo.setMercId(parentId);
  389. }
  390. //一级商户,解绑后,直接释放
  391. if (parentId == 0) {
  392. //兴元等级 0 释放关系
  393. deviceInfo.setMercId(-1L);
  394. }
  395. deviceInfo.setMercName(StrUtil.EMPTY);
  396. deviceInfo.setMercCode(StrUtil.EMPTY);
  397. });
  398. //批量更新
  399. return updateBatchById(deviceInfos);
  400. }
  401. return Boolean.FALSE;
  402. }
  403. @ApiOperation("集合查询")
  404. @Override
  405. public R<List<DeviceInfoDto.Vo>> list(DeviceInfoDto.ListDto dto) {
  406. List<DeviceInfo> list = list(new LambdaQueryWrapper<DeviceInfo>().in(CollUtil.isNotEmpty(dto.getDeviceIds()), DeviceInfo::getDeviceId, dto.getDeviceIds()));
  407. return R.ok(copy(DeviceInfoDto.Vo.class, list));
  408. }
  409. @Override
  410. @ApiOperation("通用集合查询")
  411. public R<List<DeviceInfoDto.Vo>> listCommon(DeviceInfoDto.ListCommon dto) {
  412. String deviceSearch = dto.getDeviceSearch();
  413. DeviceInfoDto.Vo vo = dto.getVo();
  414. QueryWrapper<DeviceInfo> queryWrapper = new MybatisPlusQuery().eqWrapper(vo == null ? new DeviceInfoDto.Vo() : vo, DeviceInfo.class).buildQW();
  415. List<Long> placeLineIds = dto.getPlaceLineIds();
  416. List<Long> deviceIds = dto.getDeviceIds();
  417. List<String> columnList = dto.getColumnList();
  418. if (CollUtil.isNotEmpty(placeLineIds)) {
  419. queryWrapper.in(LambdaUtils.getUnderlineCaseName(DeviceInfo::getPlaceLineId), placeLineIds);
  420. }
  421. if (StrUtil.isNotEmpty(deviceSearch)) {
  422. queryWrapper.and(wrapper -> wrapper.likeRight(LambdaUtils.getUnderlineCaseName(DeviceInfo::getDeviceName), deviceSearch).or()
  423. .eq(LambdaUtils.getUnderlineCaseName(DeviceInfo::getMercDeviceCode), deviceSearch));
  424. }
  425. if (CollUtil.isNotEmpty(columnList)) {
  426. queryWrapper.select(columnList.stream().toArray(String[]::new));
  427. }
  428. if (CollUtil.isNotEmpty(deviceIds)) {
  429. queryWrapper.in(LambdaUtils.getUnderlineCaseName(DeviceInfo::getDeviceId), deviceIds);
  430. }
  431. return R.ok(copy(DeviceInfoDto.Vo.class, list(queryWrapper)));
  432. }
  433. @Override
  434. @ApiOperation("商户设备算法列表")
  435. public R<List<Long>> mercAlgorithmIdList(DeviceInfoDto.MercAlgorithmIdListDto dto) {
  436. String algorithmIdStr = LambdaUtils.getProperty(DeviceInfo::getAlgorithmId);
  437. String mercStr = StringTools.humpToLine(LambdaUtils.getProperty(DeviceInfo::getMercId));
  438. QueryWrapper<DeviceInfo> lqw = new QueryWrapper<DeviceInfo>()
  439. .isNotNull(StringTools.humpToLine(algorithmIdStr))
  440. .eq(mercStr, dto.getMercId())
  441. .select(String.format("DISTINCT (%s) as %s", StringTools.humpToLine(algorithmIdStr), algorithmIdStr));
  442. List<Long> list = listObjs(lqw, (MapperFunction<Object, Long>) o -> (Long) o);
  443. return R.ok(list);
  444. }
  445. @Override
  446. @ApiOperation("小程序-商户设备首页统计")
  447. public R<DeviceInfoDto.MercHomeStatisticalVO> mercHomeStatistical(DeviceInfoDto.MercHomeQueryDTO dto) {
  448. Long mercId = dto.getMercId();
  449. //初始化数据
  450. DeviceInfoDto.MercHomeStatisticalVO mercHomeStatisticalVO = new DeviceInfoDto.MercHomeStatisticalVO()
  451. .setClosedNum(0).setOfflineNum(0)
  452. .setOnlineNum(0).setOperatingNum(0).setNeedToFillNum(0);
  453. //获取商户机器
  454. List<DeviceInfo> mercDevices = getDevicesByMercId(mercId);
  455. if (CollUtil.isEmpty(mercDevices)) {
  456. return R.ok(mercHomeStatisticalVO);
  457. }
  458. List<Long> deviceIds = mercDevices.stream().map(DeviceInfo::getDeviceId).collect(Collectors.toList());
  459. //在线、离线
  460. List<DeviceStatus> deviceStatuses = deviceStatusService.listByIds(deviceIds);
  461. //分组统计
  462. Map<Integer, Long> countNetstateMap = deviceStatuses.stream().collect(Collectors
  463. .groupingBy(DeviceStatus::getNetState, Collectors.counting()));
  464. Integer onlineDictValue = SysDictUtils.getValue(DictEnum.DEVICE_ONLINE_STATUS.getKey(), DictSonEnum.DEVICE_ONLINE_STATUS_CONNECTED.getKey(), Integer.class);
  465. Integer offlineDictValue = SysDictUtils.getValue(DictEnum.DEVICE_ONLINE_STATUS.getKey(), DictSonEnum.DEVICE_ONLINE_STATUS_DISCONNECT.getKey(), Integer.class);
  466. int onlineNum = countNetstateMap.get(onlineDictValue) == null ? 0 : countNetstateMap.get(onlineDictValue).intValue();
  467. int offlineNum = countNetstateMap.get(offlineDictValue) == null ? 0 : countNetstateMap.get(offlineDictValue).intValue();
  468. mercHomeStatisticalVO.setOnlineNum(onlineNum);
  469. mercHomeStatisticalVO.setOfflineNum(offlineNum);
  470. //运营、停业
  471. Map<Integer, Long> countBusyStateMap = mercDevices.stream().collect(Collectors
  472. .groupingBy(DeviceInfo::getBusyState, Collectors.counting()));
  473. Integer busyState1 = SysDictUtils.getValue(DictEnum.DEVICE_BUSY_STATUS.getKey(), DictSonEnum.DEVICE_BUSY_STATUS1.getKey(), Integer.class);
  474. Integer busyState2 = SysDictUtils.getValue(DictEnum.DEVICE_BUSY_STATUS.getKey(), DictSonEnum.DEVICE_BUSY_STATUS2.getKey(), Integer.class);
  475. int operatingNum = countBusyStateMap.get(busyState1) == null ? 0 : countBusyStateMap.get(busyState1).intValue();
  476. int closedNum = countBusyStateMap.get(busyState2) == null ? 0 : countBusyStateMap.get(busyState2).intValue();
  477. mercHomeStatisticalVO.setOperatingNum(operatingNum);
  478. mercHomeStatisticalVO.setClosedNum(closedNum);
  479. //待补货
  480. //TODO: 此逻辑需要确认
  481. return R.ok(mercHomeStatisticalVO);
  482. }
  483. @Override
  484. @ApiOperation("小程序-商户设备首页列表")
  485. public R<List<DeviceInfoDto.MercHomeListVO>> mercHomeList(DeviceInfoDto.MercHomeQueryDTO dto) {
  486. Long mercId = dto.getMercId();
  487. String deviceName = dto.getDeviceName();
  488. Long deviceId = dto.getDeviceId();
  489. List<DeviceInfoDto.MercHomeCountVO> list = this.baseMapper.merHomeCountList(dto);
  490. if (CollUtil.isEmpty(list)) {
  491. return R.ok(Collections.emptyList());
  492. }
  493. List<DeviceInfoDto.MercHomeListVO> dataList = new ArrayList<>(list.size());
  494. LambdaQueryWrapper<DeviceInfo> lqw = new LambdaQueryWrapper<>();
  495. lqw.eq(DeviceInfo::getActiveState, DeviceActiveStateEnum.TRUE.getCode());
  496. lqw.eq(mercId != null, DeviceInfo::getMercId, mercId);
  497. lqw.eq(deviceId != null, DeviceInfo::getDeviceId, deviceId);
  498. lqw.like(StrUtil.isNotEmpty(deviceName), DeviceInfo::getDeviceName, deviceName);
  499. List<DeviceInfo> deviceInfoList = this.list(lqw);
  500. //未分配线路的设置默认值
  501. deviceInfoList.stream().filter(s -> s.getPlaceLineId() == null).forEach(s -> s.setPlaceLineId(-1L));
  502. //根据线路id分组
  503. Map<Long, List<DeviceInfo>> deviceMap = deviceInfoList.stream().collect(Collectors.groupingBy(DeviceInfo::getPlaceLineId));
  504. list.forEach(v -> {
  505. DeviceInfoDto.MercHomeListVO vo = new DeviceInfoDto.MercHomeListVO();
  506. Long placeLineId = v.getPlaceLineId();
  507. vo.setDeviceNum(v.getDeviceNum());
  508. vo.setPlaceLineId(v.getPlaceLineId());
  509. //线路下的设备列表
  510. List<DeviceInfoDto.MercHomeDeviceVo> deviceInfos = Beans.copy(DeviceInfoDto.MercHomeDeviceVo.class, deviceMap.get(placeLineId));
  511. //设备销售统计
  512. String todayDate = DateUtil.format(new Date(), DatePattern.PURE_DATE_PATTERN);
  513. List<Long> deviceIds = deviceInfos.stream().map(DeviceInfoDto.MercHomeDeviceVo::getDeviceId).collect(Collectors.toList());
  514. //统计条件:当天
  515. DeviceDataDto.ListDTO deviceDataListDTO = new DeviceDataDto.ListDTO()
  516. .setDeviceIds(deviceIds).setType(DictSonEnum.DEVICE_DATA_TYPE_DAY.getKey()).setDateValue(Integer.valueOf(todayDate)).setMercId(mercId);
  517. List<DeviceDataDto.Vo> deviceDataList = deviceDataService.list(deviceDataListDTO);
  518. Map<Long, DeviceDataDto.Vo> dataMap = new HashMap<>();
  519. if (CollUtil.isNotEmpty(deviceDataList)) {
  520. dataMap = deviceDataList.stream().collect(Collectors.toMap(DeviceDataDto.Vo::getDeviceId, d -> d));
  521. }
  522. //设备状态查询
  523. List<DeviceStatusDto.Vo> deviceStatusList = deviceStatusService.list(new DeviceStatusDto.SelectList().setDeviceIds(deviceIds)).getData();
  524. Map<Long, DeviceStatusDto.Vo> datdeviceStatusMap = new HashMap<>();
  525. if (CollUtil.isNotEmpty(deviceStatusList)) {
  526. datdeviceStatusMap = deviceStatusList.stream().collect(Collectors.toMap(DeviceStatusDto.Vo::getDeviceId, d -> d));
  527. }
  528. for (DeviceInfoDto.MercHomeDeviceVo device : deviceInfos) {
  529. Long dId = device.getDeviceId();
  530. //设备类型 反显
  531. SysDictRedis dictDeviceType = SysDictUtils.get(DictConsts.DEVICE_TYPE, String.valueOf(device.getDeviceType()));
  532. device.setDeviceTypeName(dictDeviceType.getMsg());
  533. //运营状态 反显
  534. SysDictRedis dictBusyState = SysDictUtils.get(DictConsts.DEVICE_BUSY_STATUS, String.valueOf(device.getBusyState()));
  535. device.setBusyStateName(dictBusyState.getMsg());
  536. DeviceDataDto.Vo deviceData = dataMap.get(dId);
  537. //今日销售、库存情况 反显
  538. device.setDayOrderNum(deviceData != null ? deviceData.getSalesCount() : 0);
  539. device.setDaySalesPrice(deviceData != null ? deviceData.getSalesMoney() : 0);
  540. DeviceStatusDto.Vo deviceStatus = datdeviceStatusMap.get(device.getDeviceId());
  541. Integer stock = Emptys.check(deviceStatus.getStock()) ? deviceStatus.getStock() : 0;
  542. device.setOnSaleNum(stock);
  543. Integer afterFillStock = Emptys.check(deviceStatus.getAfterFillStock()) ? deviceStatus.getAfterFillStock() : 0;
  544. device.setFillNum(afterFillStock);
  545. //联网状态
  546. Integer netState = deviceStatus == null ? DeviceNetSateType.DISCONNECT.getCode() : deviceStatus.getNetState();
  547. device.setNetState(netState);
  548. if (netState == null) {
  549. device.setNetStateName(StrUtil.EMPTY);
  550. } else {
  551. device.setNetStateName(DeviceNetSateType.getEnumByCode(deviceStatus.getNetState()).getDescription());
  552. }
  553. }
  554. vo.setDeviceInfos(deviceInfos);
  555. dataList.add(vo);
  556. });
  557. return R.ok(dataList);
  558. }
  559. /**
  560. * 获取商户设备列表
  561. *
  562. * @param mercId
  563. * @return
  564. */
  565. private List<DeviceInfo> getDevicesByMercId(Long mercId) {
  566. return list(Wrappers.<DeviceInfo>lambdaQuery().eq(DeviceInfo::getMercId, mercId));
  567. }
  568. /**
  569. * 小程序商户设备搜索
  570. *
  571. * @param page
  572. * @return
  573. */
  574. @Override
  575. public R<PageBean<DeviceInfoDto.MerHomeSearchVO>> mercDeviceSearchPage(@RequestBody DeviceInfoDto.Page page) {
  576. PageBean<DeviceInfoDto.MerHomeSearchVO> pageData = new PageBean<>();
  577. //小程序独有查询字段 缺货状态:stockStatus ,是否查故障设备:fault
  578. Boolean fault = page.getFault();
  579. Long mercId = page.getMercId();
  580. if (BooleanUtil.isTrue(fault)) {
  581. //查询故障设备
  582. List<DeviceErrorsRecord> deviceErrorsRecords = deviceErrorsRecordService.list(Wrappers.<DeviceErrorsRecord>lambdaQuery()
  583. .eq(mercId != null, DeviceErrorsRecord::getMercId, page.getMercId()));
  584. List<Long> deviceIdList = deviceErrorsRecords.stream().map(DeviceErrorsRecord::getDeviceId).collect(Collectors.toList());
  585. if (CollUtil.isEmpty(deviceIdList)) {
  586. return R.ok(new PageBean<>());
  587. }
  588. page.setDeviceIdList(deviceIdList);
  589. }
  590. PageBean<DeviceInfoDto.Vo2> pageBean = queryPage(page);
  591. List<DeviceInfoDto.Vo2> records = pageBean.getRecords();
  592. if (CollUtil.isEmpty(records)) {
  593. return R.ok(pageData);
  594. }
  595. List<DeviceInfoDto.MerHomeSearchVO> merHomeSearchRecords = new ArrayList<>();
  596. List<Long> deviceIds = records.stream().map(DeviceInfoDto.Vo2::getDeviceId).collect(Collectors.toList());
  597. String type = SysDictUtils.getValue(DictEnum.DEVICE_DATA_TYPE.getKey(), DictSonEnum.DEVICE_DATA_TYPE_DAY.getKey(), String.class);
  598. String todayDate = DateUtil.format(new Date(), DatePattern.PURE_DATE_PATTERN);
  599. //查询当天
  600. DeviceDataDto.ListDTO dto = new DeviceDataDto.ListDTO()
  601. .setDeviceIds(deviceIds).setType(type).setDateValue(Integer.valueOf(todayDate)).setMercId(mercId);
  602. BeanUtil.copyProperties(pageBean, pageData);
  603. List<DeviceDataDto.Vo> deviceDataList = deviceDataService.list(dto);
  604. if (CollUtil.isNotEmpty(deviceDataList)) {
  605. //统计数据反显
  606. Map<Long, DeviceDataDto.Vo> dataMap = deviceDataList.stream().collect(Collectors.toMap(DeviceDataDto.Vo::getDeviceId, d -> d));
  607. records.forEach(v -> {
  608. DeviceInfoDto.MerHomeSearchVO merHomeSearchVO = new DeviceInfoDto.MerHomeSearchVO();
  609. Long deviceId = v.getDeviceId();
  610. DeviceDataDto.Vo vo = dataMap.get(deviceId);
  611. //今日订单数
  612. v.setDayOrderNum(vo != null ? vo.getSalesCount() : 0);
  613. v.setDaySalesPrice(vo != null ? vo.getSalesMoney() : 0);
  614. DeviceSysinfoDto.Vo deviceSysinfo = v.getDeviceSysinfo();
  615. DeviceStatusDto.Vo deviceStatus = v.getDeviceStatus();
  616. BeanUtil.copyProperties(vo, merHomeSearchVO);
  617. merHomeSearchVO.setAppUpmVersion(deviceSysinfo.getAppUpmVersion());
  618. merHomeSearchVO.setTempValue(deviceStatus.getTempValue());
  619. merHomeSearchVO.setNetDbm(deviceStatus.getNetDbm());
  620. merHomeSearchRecords.add(merHomeSearchVO);
  621. });
  622. pageData.setRecords(merHomeSearchRecords);
  623. }
  624. return R.ok(pageData);
  625. }
  626. /**
  627. * 小程序商户设备详情-数据统计
  628. *
  629. * @param dto
  630. * @return
  631. */
  632. @Override
  633. public R<DeviceInfoDto.DeviceDataCountVO> dataCount(@RequestBody DeviceInfoDto.DeviceDataCountDTO dto) {
  634. // 统计类型(1=经营数据,2=经营图表,3=温度图表,4=信号图表,5=商品管理)
  635. Integer type = dto.getType();
  636. switch (type) {
  637. case 1:
  638. //经营数据
  639. return R.ok(dataCount1(dto));
  640. case 2:
  641. //经营图表
  642. return R.ok(dataCount2(dto));
  643. case 3:
  644. //温度图表
  645. return R.ok(dataCount3(dto));
  646. case 4:
  647. //信号图表
  648. return R.ok(dataCount4(dto));
  649. case 5:
  650. //商品管理
  651. return R.ok(dataCount5(dto));
  652. default:
  653. break;
  654. }
  655. return R.ok();
  656. }
  657. /**
  658. * 经营数据
  659. *
  660. * @param dto
  661. * @return
  662. */
  663. private DeviceInfoDto.DeviceDataCountVO dataCount1(DeviceInfoDto.DeviceDataCountDTO dto) {
  664. Long deviceId = dto.getDeviceId();
  665. Long mercId = dto.getMercId();
  666. DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
  667. //当天
  668. DeviceDataDto.Vo dayData = deviceDataService.getByDay(deviceId, mercId, DateUtil.format(new Date(), DatePattern.PURE_DATE_PATTERN));
  669. //当月
  670. DeviceDataDto.Vo monthData = deviceDataService.getByMonth(deviceId, mercId, DateUtil.format(new Date(), DatePattern.SIMPLE_MONTH_PATTERN));
  671. vo.setDayBusinessData(copy(DeviceInfoDto.BusinessData.class, dayData));
  672. vo.setMonthBusinessData(copy(DeviceInfoDto.BusinessData.class, monthData));
  673. return vo;
  674. }
  675. /**
  676. * 经营图表
  677. *
  678. * @param dto
  679. * @return
  680. */
  681. private DeviceInfoDto.DeviceDataCountVO dataCount2(DeviceInfoDto.DeviceDataCountDTO dto) {
  682. Long deviceId = dto.getDeviceId();
  683. //近一个月 (销售额,订单数,退款金额,退款数)
  684. DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
  685. DeviceInfoDto.BusinessChart businessChart = new DeviceInfoDto.BusinessChart();
  686. List<String> categories = DataTime.dayListByLastDay(30);
  687. List<Integer> dateList = new ArrayList<>(30);
  688. businessChart.setCategories(categories);
  689. categories.forEach(d -> {
  690. dateList.add(Integer.valueOf(d.replaceAll(StrUtil.DASHED, StrUtil.EMPTY)));
  691. });
  692. Integer startDay = dateList.get(0);
  693. Integer endDay = dateList.get(categories.size() - 1);
  694. List<DeviceDataDto.Vo> listByDay = deviceDataService.getListByDay(deviceId, startDay, endDay);
  695. if (CollUtil.isEmpty(listByDay)) {
  696. return vo;
  697. }
  698. //每天的数据
  699. Map<Integer, DeviceDataDto.Vo> dataDayMap = listByDay.stream().collect(Collectors.toMap(DeviceDataDto.Vo::getDateValue, i -> i));
  700. List<DeviceInfoDto.MyChartSeries3> series = new ArrayList<>();
  701. String[] names = {"销售额", "订单数", "退款金额", "退款数"};
  702. for (int i = 0; i < names.length; i++) {
  703. DeviceInfoDto.MyChartSeries3 myChartSeries = new DeviceInfoDto.MyChartSeries3();
  704. //某个类型每天的数据
  705. List<String> data = new ArrayList<>();
  706. if (i == 0) {
  707. //销售额
  708. dateList.forEach(d -> {
  709. //每日数据填充
  710. DeviceDataDto.Vo deviceData = dataDayMap.get(d);
  711. if (deviceData == null) {
  712. data.add(String.valueOf(BigDecimal.ZERO));
  713. } else {
  714. Integer salesMoney = deviceData.getSalesMoney() == null ? 0 : deviceData.getSalesMoney();
  715. BigDecimal day = BigDecimal.valueOf(salesMoney).divide(BigDecimal.valueOf(100));
  716. data.add(String.valueOf(day));
  717. }
  718. });
  719. } else if (i == 1) {
  720. //订单数
  721. dateList.forEach(d -> {
  722. //每日数据填充
  723. DeviceDataDto.Vo deviceData = dataDayMap.get(d);
  724. String value = "0";
  725. if (deviceData == null) {
  726. data.add(value);
  727. } else {
  728. data.add(deviceData == null ? value : String.valueOf(deviceData.getSalesCount()));
  729. }
  730. });
  731. } else if (i == 2) {
  732. //退款金额
  733. dateList.forEach(d -> {
  734. //每日数据填充
  735. DeviceDataDto.Vo deviceData = dataDayMap.get(d);
  736. if (deviceData == null) {
  737. data.add(String.valueOf(BigDecimal.ZERO));
  738. } else {
  739. Integer refundMoney = deviceData.getRefundMoney() == null ? 0 : deviceData.getRefundMoney();
  740. BigDecimal day = BigDecimal.valueOf(refundMoney).divide(BigDecimal.valueOf(100));
  741. data.add(String.valueOf(day));
  742. }
  743. });
  744. } else if (i == 3) {
  745. //退款数
  746. dateList.forEach(d -> {
  747. //每日数据填充
  748. DeviceDataDto.Vo deviceData = dataDayMap.get(d);
  749. if (deviceData == null) {
  750. data.add("0");
  751. } else {
  752. data.add(deviceData == null ? "0" : String.valueOf(deviceData.getRefundCount()));
  753. }
  754. });
  755. }
  756. myChartSeries.setName(names[i]);
  757. myChartSeries.setData(data);
  758. series.add(myChartSeries);
  759. }
  760. businessChart.setSeries(series);
  761. vo.setBusinessChart(businessChart);
  762. return vo;
  763. }
  764. /**
  765. * 温度图表
  766. *
  767. * @param dto
  768. * @return
  769. */
  770. private DeviceInfoDto.DeviceDataCountVO dataCount3(DeviceInfoDto.DeviceDataCountDTO dto) {
  771. DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
  772. Long deviceId = dto.getDeviceId();
  773. String choosDate = dto.getChoosDate();
  774. if (StrUtil.isEmpty(choosDate)) {
  775. choosDate = DateUtil.formatDate(new Date());
  776. }
  777. String startTime = choosDate + " 00:00:00";
  778. String endTime = choosDate + " 23:59:59";
  779. //查询选定日期的温度数据
  780. List<DeviceTempRecords> deviceTempRecords = deviceTempRecordsService.list(Wrappers.<DeviceTempRecords>lambdaQuery()
  781. .eq(DeviceTempRecords::getDeviceId, deviceId).between(DeviceTempRecords::getCreateTime, startTime, endTime)
  782. .orderBy(true, true, DeviceTempRecords::getCreateTime));
  783. if (CollUtil.isEmpty(deviceTempRecords)) {
  784. return vo;
  785. }
  786. DeviceInfoDto.TemperatureChart temperatureChart = new DeviceInfoDto.TemperatureChart();
  787. List<String> categories = new ArrayList<>();
  788. String name = "温度";
  789. List<DeviceInfoDto.MyChartSeries2> series = new ArrayList<>();
  790. List<BigDecimal> data = new ArrayList<>();
  791. deviceTempRecords.forEach(d -> {
  792. String tempValue = d.getTempValue();
  793. LocalDateTime createTime = d.getCreateTime();
  794. String time = DateUtil.format(createTime, "HH:mm:ss");
  795. categories.add(time);
  796. data.add(NumberUtil.toBigDecimal(tempValue));
  797. });
  798. DeviceInfoDto.MyChartSeries2 myChartSeries = new DeviceInfoDto.MyChartSeries2();
  799. myChartSeries.setName(name);
  800. myChartSeries.setData(data);
  801. series.add(myChartSeries);
  802. temperatureChart.setSeries(series);
  803. temperatureChart.setCategories(categories);
  804. vo.setTemperatureChart(temperatureChart);
  805. return vo;
  806. }
  807. /**
  808. * 信号图表
  809. *
  810. * @param dto
  811. * @return
  812. */
  813. private DeviceInfoDto.DeviceDataCountVO dataCount4(DeviceInfoDto.DeviceDataCountDTO dto) {
  814. DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
  815. Long deviceId = dto.getDeviceId();
  816. String choosDate = dto.getChoosDate();
  817. if (StrUtil.isEmpty(choosDate)) {
  818. choosDate = DateUtil.formatDate(new Date());
  819. }
  820. String startTime = choosDate + " 00:00:00";
  821. String endTime = choosDate + " 23:59:59";
  822. //查询选定日期的温度数据
  823. List<DeviceNetRecord> deviceNetRecords = deviceNetRecordService.list(Wrappers.<DeviceNetRecord>lambdaQuery()
  824. .eq(DeviceNetRecord::getDeviceId, deviceId).between(DeviceNetRecord::getCreateTime, startTime, endTime)
  825. .orderBy(true, true, DeviceNetRecord::getCreateTime));
  826. if (CollUtil.isEmpty(deviceNetRecords)) {
  827. return vo;
  828. }
  829. DeviceInfoDto.SignalChart signalChart = new DeviceInfoDto.SignalChart();
  830. List<String> categories = new ArrayList<>();
  831. String name = "信号";
  832. List<DeviceInfoDto.MyChartSeries> series = new ArrayList<>();
  833. List<Integer> data = new ArrayList<>();
  834. deviceNetRecords.forEach(d -> {
  835. Integer value = d.getSimDbm();
  836. LocalDateTime createTime = d.getCreateTime();
  837. String time = DateUtil.format(createTime, "HH:mm:ss");
  838. categories.add(time);
  839. data.add(value);
  840. });
  841. DeviceInfoDto.MyChartSeries myChartSeries = new DeviceInfoDto.MyChartSeries();
  842. myChartSeries.setName(name);
  843. myChartSeries.setData(data);
  844. series.add(myChartSeries);
  845. signalChart.setSeries(series);
  846. signalChart.setCategories(categories);
  847. vo.setSignalChart(signalChart);
  848. return vo;
  849. }
  850. /**
  851. * 商品管理
  852. *
  853. * @param dto
  854. * @return
  855. */
  856. private DeviceInfoDto.DeviceDataCountVO dataCount5(DeviceInfoDto.DeviceDataCountDTO dto) {
  857. Long deviceId = dto.getDeviceId();
  858. DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
  859. DeviceStatus deviceStatus = deviceStatusService.getById(dto.getDeviceId());
  860. DeviceInfoDto.GoodsData goodsData = copy(DeviceInfoDto.GoodsData.class, deviceStatus);
  861. //在售商品种类
  862. //根据设备ID查商品id
  863. GoodsDeviceDto.SelectList selectList = new GoodsDeviceDto.SelectList();
  864. selectList.setDeviceIds(CollUtil.newArrayList(deviceId));
  865. R<List<GoodsDeviceDto.Vo>> r = R.feignCheck(goodsDeviceService.list(selectList));
  866. List<GoodsDeviceDto.Vo> goodsDeviceList = r.getData();
  867. goodsData.setCategoryNum(CollUtil.isNotEmpty(goodsDeviceList) ? goodsDeviceList.size() : 0);
  868. vo.setGoodsData(goodsData);
  869. return vo;
  870. }
  871. public PageBean<DeviceInfoDto.Vo2> queryPage(DeviceInfoDto.Page page) {
  872. IPage<DeviceInfoQueryPage> iPage = baseMapper.queryPage(toIPage(page.getPage()), page);
  873. return toPageBean(DeviceInfoDto.Vo2.class, iPage);
  874. }
  875. private <T> void check(T value, T value2, String msg) {
  876. if (value.toString().equals(value2.toString())) {
  877. throw new CommRuntimeException(msg);
  878. }
  879. }
  880. }