|
|
|
@@ -1,29 +1,31 @@
|
|
|
|
|
package org.dromara.property.service.impl;
|
|
|
|
|
|
|
|
|
|
import cn.hutool.core.util.ObjectUtil;
|
|
|
|
|
import org.dromara.common.core.utils.MapstructUtils;
|
|
|
|
|
import org.dromara.common.core.utils.StringUtils;
|
|
|
|
|
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
|
|
|
|
import org.dromara.common.mybatis.core.page.PageQuery;
|
|
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
|
|
import lombok.RequiredArgsConstructor;
|
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
import org.dromara.property.domain.AttendanceAreaDevice;
|
|
|
|
|
import org.dromara.property.mapper.AttendanceAreaDeviceMapper;
|
|
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
import org.dromara.property.domain.bo.AttendanceAreaBo;
|
|
|
|
|
import org.dromara.property.domain.vo.AttendanceAreaVo;
|
|
|
|
|
import org.apache.dubbo.config.annotation.DubboReference;
|
|
|
|
|
import org.dromara.common.core.utils.MapstructUtils;
|
|
|
|
|
import org.dromara.common.core.utils.StringUtils;
|
|
|
|
|
import org.dromara.common.mybatis.core.page.PageQuery;
|
|
|
|
|
import org.dromara.common.mybatis.core.page.TableDataInfo;
|
|
|
|
|
import org.dromara.property.domain.AttendanceArea;
|
|
|
|
|
import org.dromara.property.domain.AttendanceAreaDevice;
|
|
|
|
|
import org.dromara.property.domain.bo.AttendanceAreaBo;
|
|
|
|
|
import org.dromara.property.domain.vo.AttendanceAreaDeviceVo;
|
|
|
|
|
import org.dromara.property.domain.vo.AttendanceAreaVo;
|
|
|
|
|
import org.dromara.property.mapper.AttendanceAreaDeviceMapper;
|
|
|
|
|
import org.dromara.property.mapper.AttendanceAreaMapper;
|
|
|
|
|
import org.dromara.property.service.IAttendanceAreaService;
|
|
|
|
|
import org.dromara.sis.api.RemoteDeviceService;
|
|
|
|
|
import org.dromara.sis.api.domain.RemoteSisDeviceManage;
|
|
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
|
import java.util.Collection;
|
|
|
|
|
import java.util.List;
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
import java.util.Collection;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 区域区域管理Service业务层处理
|
|
|
|
@@ -40,6 +42,10 @@ public class AttendanceAreaServiceImpl implements IAttendanceAreaService {
|
|
|
|
|
|
|
|
|
|
private final AttendanceAreaDeviceMapper areaDeviceMapper;
|
|
|
|
|
|
|
|
|
|
// private TdDeviceTypeServiceImpl deviceTypeService;
|
|
|
|
|
|
|
|
|
|
@DubboReference
|
|
|
|
|
private RemoteDeviceService remoteDeviceService;
|
|
|
|
|
/**
|
|
|
|
|
* 查询区域区域管理
|
|
|
|
|
*
|
|
|
|
@@ -47,7 +53,7 @@ public class AttendanceAreaServiceImpl implements IAttendanceAreaService {
|
|
|
|
|
* @return 区域区域管理
|
|
|
|
|
*/
|
|
|
|
|
@Override
|
|
|
|
|
public AttendanceAreaVo queryById(Long id){
|
|
|
|
|
public AttendanceAreaVo queryById(Long id) {
|
|
|
|
|
return baseMapper.selectVoById(id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@@ -64,11 +70,17 @@ public class AttendanceAreaServiceImpl implements IAttendanceAreaService {
|
|
|
|
|
Page<AttendanceAreaVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
|
|
|
|
|
|
|
|
|
Page<AttendanceAreaVo> attendanceAreaVoPage = result.setRecords(result.getRecords().stream().map(vo -> {
|
|
|
|
|
//获取areaId
|
|
|
|
|
Long areaId = vo.getId();
|
|
|
|
|
//根据areaId查询中间表数据
|
|
|
|
|
List<AttendanceAreaDevice> attendanceAreaDeviceList = areaDeviceMapper.selectList(Wrappers.<AttendanceAreaDevice>lambdaQuery().eq(AttendanceAreaDevice::getAreaId, areaId));
|
|
|
|
|
vo.setAreaDevice(attendanceAreaDeviceList);
|
|
|
|
|
//获取areaId
|
|
|
|
|
Long areaId = vo.getId();
|
|
|
|
|
//根据areaId查询中间表数据
|
|
|
|
|
List<AttendanceAreaDeviceVo> attendanceAreaDeviceList =areaDeviceMapper.selectVoList(Wrappers.<AttendanceAreaDevice>lambdaQuery().eq(AttendanceAreaDevice::getAreaId, areaId));
|
|
|
|
|
// List<AttendanceAreaDeviceVo> attendanceAreaDeviceList = areaDeviceMapper.selectList(Wrappers.<AttendanceAreaDevice>lambdaQuery().eq(AttendanceAreaDevice::getAreaId, areaId));
|
|
|
|
|
attendanceAreaDeviceList.forEach(item -> {
|
|
|
|
|
//根据deviceManageId查询设备数据
|
|
|
|
|
RemoteSisDeviceManage remoteSisDeviceManage = remoteDeviceService.queryDeviceById(item.getDeviceManageId());
|
|
|
|
|
item.setRemoteSisDeviceManage(remoteSisDeviceManage);
|
|
|
|
|
});
|
|
|
|
|
vo.setAreaDevice(attendanceAreaDeviceList);
|
|
|
|
|
return vo;
|
|
|
|
|
}
|
|
|
|
|
).toList());
|
|
|
|
@@ -163,7 +175,7 @@ public class AttendanceAreaServiceImpl implements IAttendanceAreaService {
|
|
|
|
|
/**
|
|
|
|
|
* 保存前的数据校验
|
|
|
|
|
*/
|
|
|
|
|
private void validEntityBeforeSave(AttendanceArea entity){
|
|
|
|
|
private void validEntityBeforeSave(AttendanceArea entity) {
|
|
|
|
|
//TODO 做一些数据校验,如唯一约束
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@@ -177,7 +189,7 @@ public class AttendanceAreaServiceImpl implements IAttendanceAreaService {
|
|
|
|
|
@Transactional(rollbackFor = Exception.class)
|
|
|
|
|
@Override
|
|
|
|
|
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
|
|
|
|
if(isValid){
|
|
|
|
|
if (isValid) {
|
|
|
|
|
//TODO 做一些业务上的校验,判断是否需要校验
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|