123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907 |
- package com.xy.service;
- import cn.hutool.core.bean.BeanUtil;
- import cn.hutool.core.collection.CollUtil;
- import cn.hutool.core.date.DatePattern;
- import cn.hutool.core.date.DateUtil;
- import cn.hutool.core.text.StrBuilder;
- import cn.hutool.core.util.BooleanUtil;
- import cn.hutool.core.util.NumberUtil;
- import cn.hutool.core.util.StrUtil;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
- import com.baomidou.mybatisplus.core.metadata.IPage;
- import com.baomidou.mybatisplus.core.toolkit.Wrappers;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.xy.collections.list.JArrayList;
- import com.xy.collections.list.JList;
- import com.xy.config.DeviceThreadPoolConfig;
- import com.xy.consts.DictConsts;
- import com.xy.dto.*;
- import com.xy.entity.*;
- import com.xy.enums.FileExportType;
- import com.xy.error.CommRuntimeException;
- import com.xy.mapper.DeviceInfoMapper;
- import com.xy.mapper.entity.DeviceInfoQueryPage;
- import com.xy.util.ExcelUtils;
- import com.xy.util.FileUtils;
- import com.xy.utils.*;
- import com.xy.utils.enums.DictEnum;
- import com.xy.utils.enums.DictSonEnum;
- import io.swagger.annotations.Api;
- import io.swagger.annotations.ApiOperation;
- import jodd.introspector.MapperFunction;
- import lombok.RequiredArgsConstructor;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Transactional;
- import org.springframework.validation.annotation.Validated;
- import org.springframework.web.bind.annotation.PostMapping;
- import org.springframework.web.bind.annotation.RequestBody;
- import javax.servlet.http.HttpServletResponse;
- import javax.validation.Valid;
- import java.io.IOException;
- import java.math.BigDecimal;
- import java.time.LocalDateTime;
- import java.util.*;
- import java.util.stream.Collectors;
- import static com.xy.utils.PlusBeans.*;
- /**
- * <p>
- * 设备-信息 服务实现类
- * </p>
- *
- * @author lijin
- * @since 2022-12-23
- */
- @Service
- @RequiredArgsConstructor
- @Api(tags = "设备-信息")
- public class DeviceInfoServiceImpl extends ServiceImpl<DeviceInfoMapper, DeviceInfo> implements DeviceInfoService {
- private final DeviceSysinfoServiceImpl deviceSysinfoService;
- private final DeviceStatusServiceImpl deviceStatusService;
- private final DeviceRegisterServiceImpl deviceRegisterService;
- private final DeviceErrorsRecordServiceImpl deviceErrorsRecordService;
- private final DeviceDataServiceImpl deviceDataService;
- private final DeviceTempRecordsServiceImpl deviceTempRecordsService;
- private final DeviceNetRecordServiceImpl deviceNetRecordService;
- private final GoodsDeviceService goodsDeviceService;
- private final FileExportService fileExportService;
- private final RedisService<String> redisService;
- private final String keyPrefix = "device:history:";
- private final FileUtils fileUtils;
- @Override
- @ApiOperation("对象查询")
- public R<DeviceInfoDto.Vo> obj(DeviceInfoDto.Obj obj) {
- //设备信息
- LambdaQueryWrapper<DeviceInfo> lambdaQueryWrapper = new MybatisPlusQuery().eqWrapper(obj, DeviceInfo.class).build();
- List<DeviceInfo> list = list(lambdaQueryWrapper);
- if (!Emptys.check(list)) {
- return R.ok();
- }
- DeviceInfoDto.Vo deviceInfo = copy(DeviceInfoDto.Vo.class, list.get(0));
- int num = 0;
- if (obj.getIsSysinfo()) {
- num++;
- }
- if (obj.getIsStatus()) {
- num++;
- }
- if (obj.getIsRegister()) {
- num++;
- }
- if (num > 0) {
- ThreadPoolUtils.Execute execute = ThreadPoolUtils.excPoll(DeviceThreadPoolConfig.DEVICE_COMMON_POLL, num);
- if (obj.getIsSysinfo()) {
- execute.execute(() -> {
- //系统信息
- DeviceSysinfoDto.Vo deviceSysinfo = deviceSysinfoService.get(new DeviceSysinfoDto.Vo().setDeviceId(deviceInfo.getDeviceId())).getData();
- deviceInfo.setDeviceSysinfo(deviceSysinfo);
- });
- }
- if (obj.getIsStatus()) {
- execute.execute(() -> {
- //状态信息
- DeviceStatusDto.Vo deviceStatus = deviceStatusService.obj(new DeviceStatusDto.Vo().setDeviceId(deviceInfo.getDeviceId())).getData();
- deviceInfo.setDeviceStatus(deviceStatus);
- });
- }
- if (obj.getIsRegister()) {
- execute.execute(() -> {
- //注册信息
- DeviceRegisterDto.Vo deviceRegister = deviceRegisterService.obj(new DeviceRegisterDto.Vo().setDeviceId(deviceInfo.getDeviceId())).getData();
- deviceInfo.setDeviceRegister(deviceRegister);
- });
- }
- execute.end();
- }
- return R.ok(deviceInfo);
- }
- @Override
- @ApiOperation("设备访问历史添加")
- public R history(DeviceInfoDto.Obj obj) {
- //获取字典
- SysDictRedis sysDictRedis = SysDictUtils.get(DictEnum.DATA_CLEAR_SIZE.getKey(), "device_history_twig");
- Integer value = Integer.valueOf(sysDictRedis.getValue());
- //获取redis
- String key = keyPrefix + AuthorizeUtils.getLoginId(Long.class);
- List<String> list = redisService.getList(key);
- list.add(0, String.valueOf(obj.getDeviceId()));
- //去重
- List<String> redisList = new ArrayList<>();
- JList<String> comparing = new JArrayList<>(list).comparing();
- if (comparing.size() > value) {
- for (int i = 0; i < value; i++) {
- redisList.add(comparing.get(i));
- }
- } else {
- redisList = comparing;
- }
- redisService.removeList(key);
- redisService.setList(key, redisList);
- return R.ok();
- }
- @Override
- @ApiOperation("开门检测")
- public R checkOpenDoor(DeviceInfoDto.Obj obj) {
- DeviceInfoDto.Vo deviceInfo = obj(new DeviceInfoDto.Obj()
- .setDeviceId(obj.getDeviceId())
- .setIsStatus(true)
- ).getData();
- if (deviceInfo == null) {
- return R.fail("设备不存在");
- }
- DeviceStatusDto.Vo deviceStatus = deviceInfo.getDeviceStatus();
- check(deviceInfo.getFreezeStatus(), 2, "设备已冻结");
- SysDictRedis sysDictRedis = SysDictUtils.get(DictEnum.DEVICE_FAULT_LEVEL_PAY_THRESHOLD.getKey(), DictSonEnum.DEVICE_FAULT_LEVEL_PAY_THRESHOLD_NOT_PAY.getKey());
- if (deviceInfo.getFaultLevel() >= Integer.valueOf(sysDictRedis.getValue())) {
- return R.fail("设备故障");
- }
- check(deviceStatus.getNetState(), 2, "设备已离线");
- check(obj.getDoor() != null && obj.getDoor() == 1 ? deviceStatus.getDoorStateR() : deviceStatus.getDoorStateL(), 2, "设备正在使用中,请稍后");
- check(obj.getDoor() != null && obj.getDoor() == 1 ? deviceStatus.getDeviceStateR() : deviceStatus.getDeviceStateL(), 2, "设备已锁机");
- return R.ok();
- }
- @PostMapping("historyList")
- @ApiOperation("设备访问历史查询")
- public R<List<DeviceInfoDto.Vo>> historyList() {
- //获取redis
- String key = keyPrefix + AuthorizeUtils.getLoginId(Long.class);
- List<String> deviceIds = redisService.getList(key);
- if (!Emptys.check(deviceIds)) {
- return R.ok();
- }
- //查询数据库
- List<DeviceInfo> list = list(new LambdaQueryWrapper<DeviceInfo>().in(DeviceInfo::getDeviceId, deviceIds));
- return R.ok(copy(DeviceInfoDto.Vo.class, list));
- }
- @ApiOperation("修改")
- @PostMapping("update")
- public R update(@RequestBody @Validated DeviceInfoDto.Update update) {
- DeviceInfo deviceInfo = copy(DeviceInfo.class, update);
- updateById(deviceInfo);
- return R.ok();
- }
- @Override
- @ApiOperation("更新商户线路")
- public R updateLine(@RequestBody @Validated DeviceInfoDto.UpdateLine updateLine) {
- LambdaUpdateWrapper<DeviceInfo> luw = new LambdaUpdateWrapper<DeviceInfo>().eq(DeviceInfo::getMercId, updateLine.getMercId());
- //绑定线路,更换线路
- if (DeviceInfoDto.UPDATE.equals(updateLine.getType())) {
- DeviceInfo deviceInfo = new DeviceInfo();
- deviceInfo.setPlaceLineId(updateLine.getPlaceLineId());
- luw.in(DeviceInfo::getDeviceId, updateLine.getDeviceIds());
- baseMapper.update(deviceInfo, luw);
- }
- //删除线路
- if (DeviceInfoDto.DEL.equals(updateLine.getType())) {
- luw.eq(DeviceInfo::getPlaceLineId, updateLine.getWherePlaceLineId());
- luw.set(DeviceInfo::getPlaceLineId, null);
- baseMapper.update(null, luw);
- }
- //解绑线路 设置线路ID为null
- if (DeviceInfoDto.CLEAR.equals(updateLine.getType())) {
- luw.in(DeviceInfo::getDeviceId, updateLine.getDeviceIds());
- luw.set(DeviceInfo::getPlaceLineId, null);
- baseMapper.update(null, luw);
- }
- return R.ok();
- }
- @Override
- @ApiOperation("更新商户点位")
- public R updatePlace(@RequestBody @Validated DeviceInfoDto.UpdatePlace updatePlace) {
- LambdaUpdateWrapper<DeviceInfo> luw = new LambdaUpdateWrapper<DeviceInfo>().eq(DeviceInfo::getMercId, updatePlace.getMercId());
- //绑定点位,更换点位
- if (DeviceInfoDto.UPDATE.equals(updatePlace.getType())) {
- DeviceInfo deviceInfo = new DeviceInfo();
- deviceInfo.setPlaceId(updatePlace.getPlaceId());
- luw.in(DeviceInfo::getDeviceId, updatePlace.getDeviceIds());
- baseMapper.update(deviceInfo, luw);
- }
- //删除点位
- if (DeviceInfoDto.DEL.equals(updatePlace.getType())) {
- luw.eq(DeviceInfo::getPlaceId, updatePlace.getWherePlaceId());
- luw.set(DeviceInfo::getPlaceId, null);
- baseMapper.update(null, luw);
- }
- //解绑点位 设置点位ID为null
- if (DeviceInfoDto.CLEAR.equals(updatePlace.getType())) {
- luw.in(DeviceInfo::getDeviceId, updatePlace.getDeviceIds());
- luw.set(DeviceInfo::getPlaceId, null);
- baseMapper.update(null, luw);
- }
- return R.ok();
- }
- @PostMapping("page")
- @ApiOperation("分页查询")
- public R<PageBean<DeviceInfoDto.Vo2>> page(@RequestBody DeviceInfoDto.Page page) {
- return R.ok(queryPage(page));
- }
- @ApiOperation("导出设备列表")
- @PostMapping("exportDevices")
- public void exportDevices(HttpServletResponse response, @RequestBody @Valid DeviceInfoDto.Page page) throws IOException {
- PageBean<DeviceInfoDto.Vo2> pageBean = queryPage(page);
- List<DeviceInfoDto.Vo2> records = pageBean.getRecords();
- List<DeviceInfoDto.DeviceExcelVO> deviceExcelVOS = BeanUtil.copyToList(records, DeviceInfoDto.DeviceExcelVO.class);
- // 输出
- ExcelUtils.write(response, "设备列表.xls", "设备列表", DeviceInfoDto.DeviceExcelVO.class, deviceExcelVOS);
- }
- @ApiOperation("导出设备(异步)")
- @PostMapping("exportDevices/async")
- public void exportDevicesAsync(@RequestBody @Validated DeviceInfoDto.Page page) {
- PageBean<DeviceInfoDto.Vo2> pageBean = queryPage(page);
- List<DeviceInfoDto.Vo2> records = pageBean.getRecords();
- List<DeviceInfoDto.DeviceExcelVO> deviceExcelVOS = BeanUtil.copyToList(records, DeviceInfoDto.DeviceExcelVO.class);
- //异步导出参数封装
- ExcelDTO<DeviceInfoDto.DeviceExcelVO> excelDTO = new ExcelDTO<>();
- excelDTO.setData(deviceExcelVOS);
- excelDTO.setHead(DeviceInfoDto.DeviceExcelVO.class);
- excelDTO.setSheetName(FileExportType.DEVICE_INFO.getDescription());
- excelDTO.setFileExportType(FileExportType.DEVICE_INFO);
- //执行导出
- fileExportService.exportExcelAsync(excelDTO);
- }
- @PostMapping("nearbyPage")
- @ApiOperation("附近设备分页查询")
- public R<PageBean<DeviceInfoDto.Vo2>> nearbyPage(@RequestBody DeviceInfoDto.Page page) {
- if (!Emptys.check(page.getLon()) || !Emptys.check(page.getLat())) {
- throw new CommRuntimeException("经纬度不能为空");
- }
- return R.ok(queryPage(page));
- }
- @ApiOperation(value = "商户设备授权", hidden = true)
- @Override
- @Transactional(rollbackFor = Exception.class)
- public R<Boolean> mercDeviceAuth(DeviceInfoDto.MercDeviceAuthDto auth) {
- Long mercId = auth.getMercId();
- String mercCode = auth.getMercCode();
- Long algorithmId = auth.getAlgorithmId();
- String mercName = auth.getMercName();
- //商户最终设备列表
- List<Long> deviceIds = auth.getDeviceIds();
- List<DeviceInfo> devices = getDevicesByMercId(mercId);
- //取消商户设备授权
- if (CollUtil.isEmpty(deviceIds)) {
- if (CollUtil.isEmpty(devices)) {
- return R.ok(Boolean.TRUE);
- }
- }
- //更新商户设备授权
- List<DeviceInfo> deviceInfos = this.listByIds(deviceIds);
- for (DeviceInfo deviceInfo : deviceInfos) {
- int refMercId = deviceInfo.getMercId().intValue();
- // 只有解绑后,才能给顶级商户授权
- if (refMercId != -1 && refMercId != mercId.intValue()) {
- StrBuilder sb = StrBuilder.create();
- String errMsg = sb.append("设备[")
- .append(deviceInfo.getDeviceId())
- .append("]")
- .append("已被商户[")
- .append(deviceInfo.getMercName())
- .append("]绑定,请先进行解绑!")
- .toString();
- //已关联别商户
- return R.fail(errMsg, Boolean.FALSE);
- }
- //绑定关系
- deviceInfo.setMercId(mercId).setMercCode(mercCode).setAlgorithmId(algorithmId).setMercName(mercName);
- }
- saveOrUpdateBatch(deviceInfos);
- // //原来存在的设备关系,不在最终设备列表中的移除
- // if (CollUtil.isNotEmpty(devices)) {
- // List<Long> oldIds = new ArrayList<>();
- // List<Long> removeIds = new ArrayList<>();
- // devices.forEach(device -> oldIds.add(device.getDeviceId()));
- // oldIds.forEach(deviceId -> {
- // //不在最终设备列表中的待移除
- // if (!deviceIds.contains(deviceId)) {
- // removeIds.add(deviceId);
- // }
- // });
- // if (CollUtil.isNotEmpty(removeIds)) {
- // List<DeviceInfo> removeList = this.listByIds(removeIds);
- // removeMerRefDevices(removeList, parentId);
- // }
- // }
- return R.ok(Boolean.TRUE);
- }
- /**
- * 解绑机器 回收
- *
- * @param dto
- * @return
- */
- @Override
- public R<Boolean> unBindMercDevice(DeviceInfoDto.MercDeviceUnBindDto dto) {
- List<DeviceInfo> deviceInfos = this.listByIds(dto.getDeviceIds());
- return R.ok(removeMerRefDevicesToTopMerc(deviceInfos));
- }
- /**
- * 回收机器
- *
- * @param deviceInfos
- * @return
- */
- private Boolean removeMerRefDevicesToTopMerc(List<DeviceInfo> deviceInfos) {
- if (CollUtil.isNotEmpty(deviceInfos)) {
- deviceInfos.forEach(deviceInfo -> {
- //回收
- deviceInfo.setMercId(-1L);
- deviceInfo.setMercDeviceCode(StrUtil.EMPTY);
- deviceInfo.setMercName(StrUtil.EMPTY);
- deviceInfo.setMercCode(StrUtil.EMPTY);
- });
- //批量更新
- return updateBatchById(deviceInfos);
- }
- return Boolean.FALSE;
- }
- /**
- * 批量移除商户设备绑定关系
- *
- * @param deviceInfos
- * @return
- */
- private Boolean removeMerRefDevices(List<DeviceInfo> deviceInfos, Long parentId) {
- if (CollUtil.isNotEmpty(deviceInfos) && parentId != null) {
- deviceInfos.forEach(deviceInfo -> {
- //非顶级兴元商户,解绑后,机器归父商户
- if (parentId != 1) {
- deviceInfo.setMercId(parentId);
- }
- //一级商户,解绑后,直接释放
- if (parentId == 0) {
- //兴元等级 0 释放关系
- deviceInfo.setMercId(-1L);
- }
- deviceInfo.setMercName(StrUtil.EMPTY);
- deviceInfo.setMercCode(StrUtil.EMPTY);
- });
- //批量更新
- return updateBatchById(deviceInfos);
- }
- return Boolean.FALSE;
- }
- @ApiOperation("集合查询")
- @Override
- public R<List<DeviceInfoDto.Vo>> list(DeviceInfoDto.ListDto dto) {
- List<DeviceInfo> list = list(new LambdaQueryWrapper<DeviceInfo>().in(CollUtil.isNotEmpty(dto.getDeviceIds()), DeviceInfo::getDeviceId, dto.getDeviceIds()));
- return R.ok(copy(DeviceInfoDto.Vo.class, list));
- }
- @Override
- @ApiOperation("通用集合查询")
- public R<List<DeviceInfoDto.Vo>> listCommon(DeviceInfoDto.ListCommon dto) {
- String deviceSearch = dto.getDeviceSearch();
- QueryWrapper<DeviceInfo> queryWrapper = new MybatisPlusQuery().eqWrapper(dto.getVo(), DeviceInfo.class).buildQW();
- List<Long> placeLineIds = dto.getPlaceLineIds();
- List<Long> deviceIds = dto.getDeviceIds();
- List<String> columnList = dto.getColumnList();
- if (CollUtil.isNotEmpty(placeLineIds)) {
- queryWrapper.in(LambdaUtils.getUnderlineCaseName(DeviceInfo::getPlaceLineId), placeLineIds);
- }
- if (StrUtil.isNotEmpty(deviceSearch)) {
- queryWrapper.and(wrapper -> wrapper.likeRight(LambdaUtils.getUnderlineCaseName(DeviceInfo::getDeviceName), deviceSearch).or()
- .eq(LambdaUtils.getUnderlineCaseName(DeviceInfo::getMercDeviceCode), deviceSearch));
- }
- if (CollUtil.isNotEmpty(columnList)) {
- queryWrapper.select(columnList.stream().toArray(String[]::new));
- }
- if (CollUtil.isNotEmpty(deviceIds)) {
- queryWrapper.eq(LambdaUtils.getUnderlineCaseName(DeviceInfo::getDeviceId), deviceIds);
- }
- return R.ok(copy(DeviceInfoDto.Vo.class, list(queryWrapper)));
- }
- @Override
- @ApiOperation("商户设备算法列表")
- public R<List<Long>> mercAlgorithmIdList(DeviceInfoDto.MercAlgorithmIdListDto dto) {
- String algorithmIdStr = LambdaUtils.getProperty(DeviceInfo::getAlgorithmId);
- String mercStr = StringTools.humpToLine(LambdaUtils.getProperty(DeviceInfo::getMercId));
- QueryWrapper<DeviceInfo> lqw = new QueryWrapper<DeviceInfo>()
- .isNotNull(StringTools.humpToLine(algorithmIdStr))
- .eq(mercStr, dto.getMercId())
- .select(String.format("DISTINCT (%s) as %s", StringTools.humpToLine(algorithmIdStr), algorithmIdStr));
- List<Long> list = listObjs(lqw, (MapperFunction<Object, Long>) o -> (Long) o);
- return R.ok(list);
- }
- @Override
- @ApiOperation("小程序-商户设备首页统计")
- public R<DeviceInfoDto.MercHomeStatisticalVO> mercHomeStatistical(DeviceInfoDto.MercHomeQueryDTO dto) {
- Long mercId = dto.getMercId();
- //初始化数据
- DeviceInfoDto.MercHomeStatisticalVO mercHomeStatisticalVO = new DeviceInfoDto.MercHomeStatisticalVO()
- .setClosedNum(0).setOfflineNum(0)
- .setOnlineNum(0).setOperatingNum(0).setNeedToFillNum(0);
- //获取商户机器
- List<DeviceInfo> mercDevices = getDevicesByMercId(mercId);
- if (CollUtil.isEmpty(mercDevices)) {
- return R.ok(mercHomeStatisticalVO);
- }
- List<Long> deviceIds = mercDevices.stream().map(DeviceInfo::getDeviceId).collect(Collectors.toList());
- //在线、离线
- List<DeviceStatus> deviceStatuses = deviceStatusService.listByIds(deviceIds);
- //分组统计
- Map<Integer, Long> countNetstateMap = deviceStatuses.stream().collect(Collectors
- .groupingBy(DeviceStatus::getNetState, Collectors.counting()));
- Integer onlineDictValue = SysDictUtils.getValue(DictEnum.DEVICE_ONLINE_STATUS.getKey(), DictSonEnum.DEVICE_ONLINE_STATUS_CONNECTED.getKey(), Integer.class);
- Integer offlineDictValue = SysDictUtils.getValue(DictEnum.DEVICE_ONLINE_STATUS.getKey(), DictSonEnum.DEVICE_ONLINE_STATUS_DISCONNECT.getKey(), Integer.class);
- int onlineNum = countNetstateMap.get(onlineDictValue) == null ? 0 : countNetstateMap.get(onlineDictValue).intValue();
- int offlineNum = countNetstateMap.get(offlineDictValue) == null ? 0 : countNetstateMap.get(offlineDictValue).intValue();
- mercHomeStatisticalVO.setOnlineNum(onlineNum);
- mercHomeStatisticalVO.setOfflineNum(offlineNum);
- //运营、停业
- Map<Integer, Long> countBusyStateMap = mercDevices.stream().collect(Collectors
- .groupingBy(DeviceInfo::getBusyState, Collectors.counting()));
- Integer busyState1 = SysDictUtils.getValue(DictEnum.DEVICE_BUSY_STATUS.getKey(), DictSonEnum.DEVICE_BUSY_STATUS1.getKey(), Integer.class);
- Integer busyState2 = SysDictUtils.getValue(DictEnum.DEVICE_BUSY_STATUS.getKey(), DictSonEnum.DEVICE_BUSY_STATUS2.getKey(), Integer.class);
- int operatingNum = countBusyStateMap.get(busyState1) == null ? 0 : countBusyStateMap.get(busyState1).intValue();
- int closedNum = countBusyStateMap.get(busyState2) == null ? 0 : countBusyStateMap.get(busyState2).intValue();
- mercHomeStatisticalVO.setOperatingNum(operatingNum);
- mercHomeStatisticalVO.setClosedNum(closedNum);
- //待补货
- //TODO: 此逻辑需要确认
- return R.ok(mercHomeStatisticalVO);
- }
- @Override
- @ApiOperation("小程序-商户设备首页列表")
- public R<List<DeviceInfoDto.MercHomeListVO>> mercHomeList(DeviceInfoDto.MercHomeQueryDTO dto) {
- Long mercId = dto.getMercId();
- String deviceName = dto.getDeviceName();
- Long deviceId = dto.getDeviceId();
- List<DeviceInfoDto.MercHomeCountVO> list = this.baseMapper.merHomeCountList(dto);
- if (CollUtil.isEmpty(list)) {
- return R.ok(Collections.emptyList());
- }
- List<DeviceInfoDto.MercHomeListVO> dataList = new ArrayList<>(list.size());
- LambdaQueryWrapper<DeviceInfo> lqw = new LambdaQueryWrapper<>();
- lqw.eq(mercId != null, DeviceInfo::getMercId, mercId);
- lqw.eq(deviceId != null, DeviceInfo::getDeviceId, deviceId);
- lqw.like(StrUtil.isNotEmpty(deviceName), DeviceInfo::getDeviceName, deviceName);
- List<DeviceInfo> deviceInfoList = this.list(lqw);
- //未分配线路的设置默认值
- deviceInfoList.stream().filter(s -> s.getPlaceLineId() == null).forEach(s -> s.setPlaceLineId(-1L));
- //根据线路id分组
- Map<Long, List<DeviceInfo>> deviceMap = deviceInfoList.stream().collect(Collectors.groupingBy(DeviceInfo::getPlaceLineId));
- list.forEach(v -> {
- DeviceInfoDto.MercHomeListVO vo = new DeviceInfoDto.MercHomeListVO();
- Long placeLineId = v.getPlaceLineId();
- vo.setDeviceNum(v.getDeviceNum());
- vo.setPlaceLineId(v.getPlaceLineId());
- //线路下的设备列表
- List<DeviceInfoDto.MercHomeDeviceVo> deviceInfos = Beans.copy(DeviceInfoDto.MercHomeDeviceVo.class, deviceMap.get(placeLineId));
- //设备销售统计
- String type = SysDictUtils.getValue(DictEnum.DEVICE_DATA_TYPE.getKey(), DictSonEnum.DEVICE_DATA_TYPE_DAY.getKey(), String.class);
- String todayDate = DateUtil.format(new Date(), DatePattern.PURE_DATE_PATTERN);
- List<Long> deviceIds = deviceInfos.stream().map(DeviceInfoDto.MercHomeDeviceVo::getDeviceId).collect(Collectors.toList());
- //统计条件:当天
- DeviceDataDto.ListDTO deviceDataListDTO = new DeviceDataDto.ListDTO()
- .setDeviceIds(deviceIds).setType(type).setDateValue(Integer.valueOf(todayDate)).setMercId(mercId);
- List<DeviceDataDto.Vo> deviceDataList = deviceDataService.list(deviceDataListDTO);
- Map<Long, DeviceDataDto.Vo> dataMap = new HashMap<>();
- if (CollUtil.isNotEmpty(deviceDataList)) {
- dataMap = deviceDataList.stream().collect(Collectors.toMap(DeviceDataDto.Vo::getDeviceId, d -> d));
- }
- //设备状态查询
- List<DeviceStatusDto.Vo> deviceStatusList = deviceStatusService.list(new DeviceStatusDto.SelectList().setDeviceIds(deviceIds)).getData();
- Map<Long, DeviceStatusDto.Vo> datdeviceStatusMap = new HashMap<>();
- if (CollUtil.isNotEmpty(deviceStatusList)) {
- datdeviceStatusMap = deviceStatusList.stream().collect(Collectors.toMap(DeviceStatusDto.Vo::getDeviceId, d -> d));
- }
- Map<Long, DeviceDataDto.Vo> finalDataMap = dataMap;
- Map<Long, DeviceStatusDto.Vo> finalDatdeviceStatusMap = datdeviceStatusMap;
- deviceInfos.forEach(device -> {
- Long dId = device.getDeviceId();
- //设备类型 反显
- SysDictRedis dictDeviceType = SysDictUtils.get(DictConsts.DEVICE_TYPE, String.valueOf(device.getDeviceType()));
- device.setDeviceTypeName(dictDeviceType.getMsg());
- //运营状态 反显
- SysDictRedis dictBusyState = SysDictUtils.get(DictConsts.DEVICE_BUSY_STATUS, String.valueOf(device.getBusyState()));
- device.setBusyStateName(dictBusyState.getMsg());
- DeviceDataDto.Vo deviceData = finalDataMap.get(dId);
- //今日销售、库存情况 反显
- device.setDayOrderNum(deviceData != null ? deviceData.getSalesCount() : 0);
- device.setDaySalesPrice(deviceData != null ? deviceData.getSalesMoney() : 0);
- DeviceStatusDto.Vo deviceStatus = finalDatdeviceStatusMap.get(deviceId);
- device.setOnSaleNum(deviceStatus != null ? deviceStatus.getStock() : 0);
- device.setFillNum(deviceStatus != null ? deviceStatus.getAfterFillStock() : 0);
- });
- vo.setDeviceInfos(deviceInfos);
- dataList.add(vo);
- });
- return R.ok(dataList);
- }
- /**
- * 获取商户设备列表
- *
- * @param mercId
- * @return
- */
- private List<DeviceInfo> getDevicesByMercId(Long mercId) {
- return list(Wrappers.<DeviceInfo>lambdaQuery().eq(DeviceInfo::getMercId, mercId));
- }
- @ApiOperation("小程序商户设备搜索")
- @Override
- public R<PageBean<DeviceInfoDto.MerHomeSearchVO>> mercDeviceSearchPage(@RequestBody DeviceInfoDto.Page page) {
- PageBean<DeviceInfoDto.MerHomeSearchVO> pageData = new PageBean<>();
- //小程序独有查询字段 缺货状态:stockStatus ,是否查故障设备:fault
- Boolean fault = page.getFault();
- Long mercId = page.getMercId();
- if (BooleanUtil.isTrue(fault)) {
- //查询故障设备
- List<DeviceErrorsRecord> deviceErrorsRecords = deviceErrorsRecordService.list(Wrappers.<DeviceErrorsRecord>lambdaQuery()
- .eq(mercId != null, DeviceErrorsRecord::getMercId, page.getMercId()));
- List<Long> deviceIdList = deviceErrorsRecords.stream().map(DeviceErrorsRecord::getDeviceId).collect(Collectors.toList());
- if (CollUtil.isEmpty(deviceIdList)) {
- return R.ok(new PageBean<>());
- }
- page.setDeviceIdList(deviceIdList);
- }
- PageBean<DeviceInfoDto.Vo2> pageBean = queryPage(page);
- List<DeviceInfoDto.Vo2> records = pageBean.getRecords();
- if (CollUtil.isEmpty(records)) {
- return R.ok(pageData);
- }
- List<DeviceInfoDto.MerHomeSearchVO> merHomeSearchRecords = new ArrayList<>();
- List<Long> deviceIds = records.stream().map(DeviceInfoDto.Vo2::getDeviceId).collect(Collectors.toList());
- String type = SysDictUtils.getValue(DictEnum.DEVICE_DATA_TYPE.getKey(), DictSonEnum.DEVICE_DATA_TYPE_DAY.getKey(), String.class);
- String todayDate = DateUtil.format(new Date(), DatePattern.PURE_DATE_PATTERN);
- //查询当天
- DeviceDataDto.ListDTO dto = new DeviceDataDto.ListDTO()
- .setDeviceIds(deviceIds).setType(type).setDateValue(Integer.valueOf(todayDate)).setMercId(mercId);
- BeanUtil.copyProperties(pageBean, pageData);
- List<DeviceDataDto.Vo> deviceDataList = deviceDataService.list(dto);
- if (CollUtil.isNotEmpty(deviceDataList)) {
- //统计数据反显
- Map<Long, DeviceDataDto.Vo> dataMap = deviceDataList.stream().collect(Collectors.toMap(DeviceDataDto.Vo::getDeviceId, d -> d));
- records.forEach(v -> {
- DeviceInfoDto.MerHomeSearchVO merHomeSearchVO = new DeviceInfoDto.MerHomeSearchVO();
- Long deviceId = v.getDeviceId();
- DeviceDataDto.Vo vo = dataMap.get(deviceId);
- //今日订单数
- v.setDayOrderNum(vo != null ? vo.getSalesCount() : 0);
- v.setDaySalesPrice(vo != null ? vo.getSalesMoney() : 0);
- DeviceSysinfoDto.Vo deviceSysinfo = v.getDeviceSysinfo();
- DeviceStatusDto.Vo deviceStatus = v.getDeviceStatus();
- BeanUtil.copyProperties(vo, merHomeSearchVO);
- merHomeSearchVO.setAppUpmVersion(deviceSysinfo.getAppUpmVersion());
- merHomeSearchVO.setTempValue(deviceStatus.getTempValue());
- merHomeSearchVO.setNetDbm(deviceStatus.getNetDbm());
- merHomeSearchRecords.add(merHomeSearchVO);
- });
- pageData.setRecords(merHomeSearchRecords);
- }
- return R.ok(pageData);
- }
- @ApiOperation("小程序商户设备详情-数据统计")
- @Override
- public R<DeviceInfoDto.DeviceDataCountVO> dataCount(@RequestBody DeviceInfoDto.DeviceDataCountDTO dto) {
- // 统计类型(1=经营数据,2=经营图表,3=温度图表,4=信号图表,5=商品管理)
- Integer type = dto.getType();
- switch (type) {
- case 1:
- //经营数据
- return R.ok(dataCount1(dto));
- case 2:
- //经营图表
- return R.ok(dataCount2(dto));
- case 3:
- //温度图表
- return R.ok(dataCount3(dto));
- case 4:
- //信号图表
- return R.ok(dataCount4(dto));
- case 5:
- //商品管理
- return R.ok(dataCount5(dto));
- default:
- break;
- }
- return R.ok();
- }
- /**
- * 经营数据
- *
- * @param dto
- * @return
- */
- private DeviceInfoDto.DeviceDataCountVO dataCount1(DeviceInfoDto.DeviceDataCountDTO dto) {
- Long deviceId = dto.getDeviceId();
- Long mercId = dto.getMercId();
- DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
- //当天
- DeviceDataDto.Vo dayData = deviceDataService.getByDay(deviceId, mercId, DateUtil.format(new Date(), DatePattern.PURE_DATE_PATTERN));
- //当月
- DeviceDataDto.Vo monthData = deviceDataService.getByMonth(deviceId, mercId, DateUtil.format(new Date(), DatePattern.SIMPLE_MONTH_PATTERN));
- vo.setDayBusinessData(copy(DeviceInfoDto.BusinessData.class, dayData));
- vo.setMonthBusinessData(copy(DeviceInfoDto.BusinessData.class, monthData));
- return vo;
- }
- /**
- * 经营图表
- *
- * @param dto
- * @return
- */
- private DeviceInfoDto.DeviceDataCountVO dataCount2(DeviceInfoDto.DeviceDataCountDTO dto) {
- Long deviceId = dto.getDeviceId();
- //近一个月 (销售额,订单数,退款金额,退款数)
- DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
- DeviceInfoDto.BusinessChart businessChart = new DeviceInfoDto.BusinessChart();
- List<String> categories = DataTime.dayListByLastDay(30);
- List<Integer> dateList = new ArrayList<>(30);
- businessChart.setCategories(categories);
- categories.forEach(d -> {
- dateList.add(Integer.valueOf(d.replaceAll(StrUtil.DASHED, StrUtil.EMPTY)));
- });
- Integer startDay = dateList.get(0);
- Integer endDay = dateList.get(categories.size() - 1);
- List<DeviceDataDto.Vo> listByDay = deviceDataService.getListByDay(deviceId, startDay, endDay);
- if (CollUtil.isEmpty(listByDay)) {
- return vo;
- }
- //每天的数据
- Map<Integer, DeviceDataDto.Vo> dataDayMap = listByDay.stream().collect(Collectors.toMap(DeviceDataDto.Vo::getDateValue, i -> i));
- List<DeviceInfoDto.MyChartSeries> series = new ArrayList<>();
- String[] names = {"销售额", "订单数", "退款金额", "退款数"};
- for (int i = 0; i < names.length; i++) {
- DeviceInfoDto.MyChartSeries myChartSeries = new DeviceInfoDto.MyChartSeries();
- //某个类型每天的数据
- List<Integer> data = new ArrayList<>();
- if (i == 0) {
- //销售额
- dateList.forEach(d -> {
- //每日数据填充
- DeviceDataDto.Vo deviceData = dataDayMap.get(d);
- data.add(deviceData == null ? 0 : deviceData.getSalesMoney());
- });
- } else if (i == 1) {
- //订单数
- dateList.forEach(d -> {
- //每日数据填充
- DeviceDataDto.Vo deviceData = dataDayMap.get(d);
- data.add(deviceData == null ? 0 : deviceData.getSalesCount());
- });
- } else if (i == 2) {
- //退款金额
- dateList.forEach(d -> {
- //每日数据填充
- DeviceDataDto.Vo deviceData = dataDayMap.get(d);
- data.add(deviceData == null ? 0 : deviceData.getRefundMoney());
- });
- } else if (i == 3) {
- //退款数
- dateList.forEach(d -> {
- //每日数据填充
- DeviceDataDto.Vo deviceData = dataDayMap.get(d);
- data.add(deviceData == null ? 0 : deviceData.getRefundCount());
- });
- }
- myChartSeries.setName(names[i]);
- myChartSeries.setData(data);
- series.add(myChartSeries);
- }
- businessChart.setSeries(series);
- vo.setBusinessChart(businessChart);
- return vo;
- }
- /**
- * 温度图表
- *
- * @param dto
- * @return
- */
- private DeviceInfoDto.DeviceDataCountVO dataCount3(DeviceInfoDto.DeviceDataCountDTO dto) {
- DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
- Long deviceId = dto.getDeviceId();
- String choosDate = dto.getChoosDate();
- if (StrUtil.isEmpty(choosDate)) {
- choosDate = DateUtil.formatDate(new Date());
- }
- String startTime = choosDate + " 00:00:00";
- String endTime = choosDate + " 23:59:59";
- //查询选定日期的温度数据
- List<DeviceTempRecords> deviceTempRecords = deviceTempRecordsService.list(Wrappers.<DeviceTempRecords>lambdaQuery()
- .eq(DeviceTempRecords::getDeviceId, deviceId).between(DeviceTempRecords::getCreateTime, startTime, endTime)
- .orderBy(true, true, DeviceTempRecords::getCreateTime));
- if (CollUtil.isEmpty(deviceTempRecords)) {
- return vo;
- }
- DeviceInfoDto.TemperatureChart temperatureChart = new DeviceInfoDto.TemperatureChart();
- List<String> categories = new ArrayList<>();
- String name = "温度";
- List<DeviceInfoDto.MyChartSeries2> series = new ArrayList<>();
- List<BigDecimal> data = new ArrayList<>();
- deviceTempRecords.forEach(d -> {
- String tempValue = d.getTempValue();
- LocalDateTime createTime = d.getCreateTime();
- String time = DateUtil.format(createTime, "HH:mm:ss");
- categories.add(time);
- data.add(NumberUtil.toBigDecimal(tempValue));
- });
- DeviceInfoDto.MyChartSeries2 myChartSeries = new DeviceInfoDto.MyChartSeries2();
- myChartSeries.setName(name);
- myChartSeries.setData(data);
- series.add(myChartSeries);
- temperatureChart.setSeries(series);
- temperatureChart.setCategories(categories);
- vo.setTemperatureChart(temperatureChart);
- return vo;
- }
- /**
- * 信号图表
- *
- * @param dto
- * @return
- */
- private DeviceInfoDto.DeviceDataCountVO dataCount4(DeviceInfoDto.DeviceDataCountDTO dto) {
- DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
- Long deviceId = dto.getDeviceId();
- String choosDate = dto.getChoosDate();
- if (StrUtil.isEmpty(choosDate)) {
- choosDate = DateUtil.formatDate(new Date());
- }
- String startTime = choosDate + " 00:00:00";
- String endTime = choosDate + " 23:59:59";
- //查询选定日期的温度数据
- List<DeviceNetRecord> deviceNetRecords = deviceNetRecordService.list(Wrappers.<DeviceNetRecord>lambdaQuery()
- .eq(DeviceNetRecord::getDeviceId, deviceId).between(DeviceNetRecord::getCreateTime, startTime, endTime)
- .orderBy(true, true, DeviceNetRecord::getCreateTime));
- if (CollUtil.isEmpty(deviceNetRecords)) {
- return vo;
- }
- DeviceInfoDto.SignalChart signalChart = new DeviceInfoDto.SignalChart();
- List<String> categories = new ArrayList<>();
- String name = "信号";
- List<DeviceInfoDto.MyChartSeries> series = new ArrayList<>();
- List<Integer> data = new ArrayList<>();
- deviceNetRecords.forEach(d -> {
- Integer value = d.getSimDbm();
- LocalDateTime createTime = d.getCreateTime();
- String time = DateUtil.format(createTime, "HH:mm:ss");
- categories.add(time);
- data.add(value);
- });
- DeviceInfoDto.MyChartSeries myChartSeries = new DeviceInfoDto.MyChartSeries();
- myChartSeries.setName(name);
- myChartSeries.setData(data);
- series.add(myChartSeries);
- signalChart.setSeries(series);
- signalChart.setCategories(categories);
- vo.setSignalChart(signalChart);
- return vo;
- }
- /**
- * 商品管理
- *
- * @param dto
- * @return
- */
- private DeviceInfoDto.DeviceDataCountVO dataCount5(DeviceInfoDto.DeviceDataCountDTO dto) {
- Long deviceId = dto.getDeviceId();
- DeviceInfoDto.DeviceDataCountVO vo = new DeviceInfoDto.DeviceDataCountVO();
- DeviceStatus deviceStatus = deviceStatusService.getById(dto.getDeviceId());
- DeviceInfoDto.GoodsData goodsData = copy(DeviceInfoDto.GoodsData.class, deviceStatus);
- //在售商品种类
- //根据设备ID查商品id
- GoodsDeviceDto.SelectList selectList = new GoodsDeviceDto.SelectList();
- selectList.setDeviceId(deviceId);
- R<List<GoodsDeviceDto.Vo>> r = R.feignCheck(goodsDeviceService.list(selectList));
- List<GoodsDeviceDto.Vo> goodsDeviceList = r.getData();
- goodsData.setCategoryNum(CollUtil.isNotEmpty(goodsDeviceList) ? goodsDeviceList.size() : 0);
- vo.setGoodsData(goodsData);
- return vo;
- }
- private PageBean<DeviceInfoDto.Vo2> queryPage(DeviceInfoDto.Page page) {
- IPage<DeviceInfoQueryPage> iPage = baseMapper.queryPage(toIPage(page.getPage()), page);
- return toPageBean(DeviceInfoDto.Vo2.class, iPage);
- }
- private <T> void check(T value, T value2, String msg) {
- if (value.toString().equals(value2.toString())) {
- throw new CommRuntimeException(msg);
- }
- }
- }
|