소스 검색

Merge remote-tracking branch 'origin/master'

xiari 1 년 전
부모
커밋
a6289050f0
27개의 변경된 파일1608개의 추가작업 그리고 88개의 파일을 삭제
  1. 61 0
      ruoyi-api/ruoyi-api-hotel/src/main/java/org/dromara/hotel/api/domain/bo/RemoteLockPowerBo.java
  2. 29 0
      ruoyi-api/ruoyi-api-hotel/src/main/java/org/dromara/hotel/api/service/RemoteLockPowerService.java
  3. 9 0
      ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/mapper/PtRoomMapper.java
  4. 8 1
      ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/service/IPtRoomService.java
  5. 12 8
      ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/service/impl/PtAreaServiceImpl.java
  6. 79 65
      ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/service/impl/PtRoomServiceImpl.java
  7. 56 0
      ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/business/lock/LockBusiness.java
  8. 11 13
      ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/controller/lock/LockController.java
  9. 23 1
      ruoyi-modules/ruoyi-backstage/src/main/resources/mapper/basics/room/PtRoomMapper.xml
  10. 106 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/controller/KfLockPowerController.java
  11. 106 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/controller/KfProvideCardHisController.java
  12. 67 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/KfLockPower.java
  13. 94 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/KfProvideCardHis.java
  14. 61 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/bo/KfLockPowerBo.java
  15. 98 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/bo/KfProvideCardHisBo.java
  16. 19 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/convert/RemoteLockPowerBoConvert.java
  17. 74 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/vo/KfLockPowerVo.java
  18. 106 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/vo/KfProvideCardHisVo.java
  19. 62 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/dubbo/RemoteLockPowerServiceImpl.java
  20. 15 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/mapper/KfLockPowerMapper.java
  21. 15 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/mapper/KfProvideCardHisMapper.java
  22. 69 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/IKfLockPowerService.java
  23. 69 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/IKfProvideCardHisService.java
  24. 150 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/impl/KfLockPowerServiceImpl.java
  25. 158 0
      ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/impl/KfProvideCardHisServiceImpl.java
  26. 23 0
      ruoyi-modules/ruoyi-hotel/src/main/resources/mapper/hotel/basics/KfLockPowerMapper.xml
  27. 28 0
      ruoyi-modules/ruoyi-hotel/src/main/resources/mapper/hotel/basics/KfProvideCardHisMapper.xml

+ 61 - 0
ruoyi-api/ruoyi-api-hotel/src/main/java/org/dromara/hotel/api/domain/bo/RemoteLockPowerBo.java

@@ -0,0 +1,61 @@
+package org.dromara.hotel.api.domain.bo;
+
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.NotNull;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import org.dromara.common.core.validate.AddGroup;
+import org.dromara.common.core.validate.EditGroup;
+
+import java.io.Serial;
+import java.io.Serializable;
+
+/**
+ * 门锁电量业务对象 t_kf_lock_power
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Data
+@EqualsAndHashCode(callSuper = false)
+public class RemoteLockPowerBo implements Serializable {
+
+    @Serial
+    private static final long serialVersionUID = -1978833636227478318L;
+    /**
+     * 主键
+     */
+    private Long id;
+
+    /**
+     * 房间编号
+     */
+    private String roomCode;
+
+    /**
+     * 房间名称
+     */
+    private String roomName;
+
+    /**
+     * 电量
+     */
+    private double power;
+
+    /**
+     * 维修人ID
+     */
+    private Long repairUserId;
+
+    /**
+     * 维修人姓名
+     */
+    private String repairUserName;
+
+    /**
+     * 维修状态
+     */
+    private String repairStatus;
+
+
+}

+ 29 - 0
ruoyi-api/ruoyi-api-hotel/src/main/java/org/dromara/hotel/api/service/RemoteLockPowerService.java

@@ -0,0 +1,29 @@
+package org.dromara.hotel.api.service;
+
+import org.dromara.common.core.domain.R;
+import org.dromara.common.core.domain.model.ErrorInfo;
+import org.dromara.hotel.api.domain.bo.RemoteLockPowerBo;
+import org.dromara.hotel.api.domain.bo.RemoteTeamBo;
+import org.dromara.hotel.api.domain.vo.RemoteTeamVo;
+
+import java.util.Date;
+import java.util.List;
+
+/**
+ * @ClassName RemoteLockPowerService
+ * @Description 酒店系统门锁电量远程服务接口
+ * @Author luoyibo
+ * @Date 2024-11-12 12:40
+ * @Version 1.0
+ * @since jdk17
+ */
+public interface RemoteLockPowerService {
+
+    /**
+     * 增加门锁电量信息
+     * @param remoteBo 门锁电量业务对象
+     * @return 操作结果
+     */
+    R<ErrorInfo> insertLockPowerByBo(RemoteLockPowerBo remoteBo);
+}
+

+ 9 - 0
ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/mapper/PtRoomMapper.java

@@ -1,7 +1,12 @@
 package org.dromara.backstage.basics.mapper;
 
+import org.apache.ibatis.annotations.Param;
+import com.baomidou.mybatisplus.core.conditions.Wrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Constants;
 import org.apache.ibatis.annotations.Param;
 import org.dromara.backstage.basics.domain.PtRoom;
+import org.dromara.backstage.basics.domain.bo.PtRoomBo;
 import org.dromara.backstage.basics.domain.vo.PtRoomVo;
 import org.dromara.common.mybatis.core.mapper.BaseMapperPlus;
 
@@ -14,5 +19,9 @@ import java.util.List;
  * @date 2024-08-09
  */
 public interface PtRoomMapper extends BaseMapperPlus<PtRoom, PtRoomVo> {
+
+    /** 查询房间与门锁信息*/
+    List<PtRoomVo> selectRoomLockList(@Param(Constants.WRAPPER) Wrapper<PtRoom> ew);
     List<PtRoomVo> selectHotelRoomList(@Param("areaIds") List<Long> areaIds);
+    List<PtRoomVo> selectHotelRoomList();
 }

+ 8 - 1
ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/service/IPtRoomService.java

@@ -110,9 +110,16 @@ public interface IPtRoomService {
     Boolean updateGuestRoomStatus(String roomCode, String tenantId, String roomStatus);
 
     /**
-     * 查询酒店下的所有客房
+     * 查询指定区域的所有客房
      * @param hotelId 客房区域id
      * @return 客房集合
      */
     List<PtRoomVo> queryHotelRoomList(Long hotelId);
+
+    /**
+     * 查询所有的客房数据
+     * @return 客房集合
+     */
+    List<PtRoomVo>queryHotelRoomList();
+
 }

+ 12 - 8
ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/service/impl/PtAreaServiceImpl.java

@@ -4,12 +4,12 @@ import cn.hutool.core.bean.BeanUtil;
 import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.collection.ListUtil;
 import cn.hutool.core.map.MapUtil;
+import cn.hutool.core.util.ObjectUtil;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import org.apache.dubbo.config.annotation.DubboReference;
 import org.dromara.backstage.basics.domain.PtRoom;
 import org.dromara.backstage.basics.domain.PtRoomType;
-import org.dromara.backstage.basics.domain.bo.PtRoomTypeBo;
-import org.dromara.backstage.basics.domain.bo.QueryFloorDataBo;
-import org.dromara.backstage.basics.domain.bo.QueryFloorRoomBo;
+import org.dromara.backstage.basics.domain.bo.*;
 import org.dromara.backstage.basics.domain.vo.*;
 import org.dromara.backstage.basics.mapper.PtRoomMapper;
 import org.dromara.backstage.basics.mapper.PtRoomTypeMapper;
@@ -26,7 +26,6 @@ import lombok.RequiredArgsConstructor;
 import org.dromara.hotel.api.domain.vo.RemoteOrderVo;
 import org.dromara.hotel.api.service.RemoteOrderService;
 import org.springframework.stereotype.Service;
-import org.dromara.backstage.basics.domain.bo.PtAreaBo;
 import org.dromara.backstage.basics.domain.PtArea;
 import org.dromara.backstage.basics.mapper.PtAreaMapper;
 import org.dromara.backstage.basics.service.IPtAreaService;
@@ -496,7 +495,8 @@ public class PtAreaServiceImpl implements IPtAreaService {
         if(StringUtils.isEmpty(param.getMultiParams())){
 //        1.基础平台的房间数据:根据楼层、房型、房间状态、房间号 查询房间数据
             // 1.1.先查询所有房间数据
-            List<PtRoomVo> guestRooms = ptRoomMapper.selectVoList(Wrappers.lambdaQuery(PtRoom.class)
+//            List<PtRoomVo> guestRooms = ptRoomMapper.selectVoList(Wrappers.lambdaQuery(PtRoom.class)
+            List<PtRoomVo> guestRooms = ptRoomMapper.selectRoomLockList(Wrappers.lambdaQuery(PtRoom.class)
                 // 客房
                 .eq(PtRoom::getRoomType, FJLXEnum.KF.code())
                 //楼层
@@ -525,8 +525,11 @@ public class PtAreaServiceImpl implements IPtAreaService {
         }else{
             String multiParams = param.getMultiParams();
             // 先根据房间号查询房间数据 房间号
-            PtRoom ptRoom = ptRoomMapper.selectOne(Wrappers.lambdaQuery(PtRoom.class).eq(PtRoom::getRoomCode, multiParams));
-            if(ptRoom != null){
+//            PtRoom ptRoom = ptRoomMapper.selectOne(Wrappers.lambdaQuery(PtRoom.class).eq(PtRoom::getRoomCode, multiParams));
+            List<PtRoomVo> guestRooms = ptRoomMapper.selectRoomLockList(new QueryWrapper<>(PtRoom.class).eq("r.room_code", multiParams));
+//            if(ptRoom != null){
+            if(ObjectUtil.isNotEmpty(guestRooms)){
+                PtRoom ptRoom = MapstructUtils.convert(guestRooms.get(0), PtRoom.class);
                 // 有数据
                 PtRoomTypeBo ptRoomTypeBo = new PtRoomTypeBo();
                 ptRoomTypeBo.setRoomTypeId(ptRoom.getGuestRoomType());
@@ -541,7 +544,8 @@ public class PtAreaServiceImpl implements IPtAreaService {
             }else{
                 // 没有数据
                 // 查询这个楼层下的所有房间
-                List<PtRoomVo> allRooms = ptRoomMapper.selectVoList(Wrappers.lambdaQuery(PtRoom.class)
+//                List<PtRoomVo> allRooms = ptRoomMapper.selectVoList(Wrappers.lambdaQuery(PtRoom.class)
+                List<PtRoomVo> allRooms = ptRoomMapper.selectRoomLockList(Wrappers.lambdaQuery(PtRoom.class)
                     // 客房
                     .eq(PtRoom::getRoomType, FJLXEnum.KF.code())
                     // 楼层

+ 79 - 65
ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/basics/service/impl/PtRoomServiceImpl.java

@@ -2,31 +2,31 @@ package org.dromara.backstage.basics.service.impl;
 
 import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.map.MapUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import lombok.RequiredArgsConstructor;
+import org.dromara.backstage.basics.domain.PtRoom;
 import org.dromara.backstage.basics.domain.PtRoomType;
 import org.dromara.backstage.basics.domain.bo.PtRoomBatchSetBo;
+import org.dromara.backstage.basics.domain.bo.PtRoomBo;
 import org.dromara.backstage.basics.domain.bo.QueryRoomBo;
 import org.dromara.backstage.basics.domain.vo.PtAreaVo;
+import org.dromara.backstage.basics.domain.vo.PtRoomVo;
+import org.dromara.backstage.basics.mapper.PtRoomMapper;
 import org.dromara.backstage.basics.mapper.PtRoomTypeMapper;
+import org.dromara.backstage.basics.service.IPtRoomService;
 import org.dromara.common.core.constant.CacheNames;
 import org.dromara.common.core.enums.FJLXEnum;
 import org.dromara.common.core.enums.HotelRoomStatusEnum;
 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 lombok.RequiredArgsConstructor;
+import org.dromara.common.mybatis.core.page.TableDataInfo;
 import org.springframework.cache.annotation.CacheEvict;
 import org.springframework.cache.annotation.Cacheable;
 import org.springframework.stereotype.Service;
-import org.dromara.backstage.basics.domain.bo.PtRoomBo;
-import org.dromara.backstage.basics.domain.vo.PtRoomVo;
-import org.dromara.backstage.basics.domain.PtRoom;
-import org.dromara.backstage.basics.mapper.PtRoomMapper;
-import org.dromara.backstage.basics.service.IPtRoomService;
 import org.springframework.transaction.annotation.Transactional;
 
 import java.util.*;
@@ -48,8 +48,6 @@ public class PtRoomServiceImpl implements IPtRoomService {
 
     private final PtRoomTypeMapper roomTypeMapper;
 
-//    public static final String ROOM_KF = "10";
-
     /**
      * 查询房间定义
      *
@@ -58,10 +56,10 @@ public class PtRoomServiceImpl implements IPtRoomService {
      */
     @Override
     @Cacheable(cacheNames = CacheNames.PT_ROOM, key = "#roomId")
-    public PtRoomVo queryById(Long roomId){
+    public PtRoomVo queryById(Long roomId) {
         PtRoomVo ptRoomVo = baseMapper.selectVoById(roomId);
         PtAreaVo ptAreaVo = areaService.queryById(ptRoomVo.getAreaId());
-        if(ptAreaVo != null){
+        if (ptAreaVo != null) {
             ptRoomVo.setAreaName(ptAreaVo.getAreaName());
         }
         return ptRoomVo;
@@ -77,12 +75,12 @@ public class PtRoomServiceImpl implements IPtRoomService {
     @Override
     public TableDataInfo<PtRoomVo> queryPageList(PtRoomBo bo, PageQuery pageQuery) {
         LambdaQueryWrapper<PtRoom> lqw = buildQueryWrapper2(bo);
-        if(bo.getAreaId()!=null){
+        if (bo.getAreaId() != null) {
             List<PtAreaVo> ptAreaVos = areaService.queryListLD(bo.getAreaId());
-            if(CollectionUtil.isNotEmpty(ptAreaVos)){
+            if (CollectionUtil.isNotEmpty(ptAreaVos)) {
                 List<Long> areaIds = ptAreaVos.stream().map(PtAreaVo::getAreaId).toList();
                 lqw.in(PtRoom::getAreaId, areaIds);
-            }else{
+            } else {
                 //没有楼层 就不用查询了
                 return TableDataInfo.build(new Page<>());
             }
@@ -98,15 +96,15 @@ public class PtRoomServiceImpl implements IPtRoomService {
     @Override
     public TableDataInfo<PtRoomVo> queryPageListByAreaIds(QueryRoomBo bo, PageQuery pageQuery) {
         LambdaQueryWrapper<PtRoom> lqw = new LambdaQueryWrapper<>();
-        lqw.eq(StringUtils.isNotBlank(bo.getRoomType()),PtRoom::getRoomType, bo.getRoomType());
-        lqw.eq(StringUtils.isNotBlank(bo.getStatus()),PtRoom::getStatus, bo.getStatus());
-        lqw.in(CollectionUtil.isNotEmpty(bo.getFloorIds()),PtRoom::getAreaId, bo.getFloorIds())
+        lqw.eq(StringUtils.isNotBlank(bo.getRoomType()), PtRoom::getRoomType, bo.getRoomType());
+        lqw.eq(StringUtils.isNotBlank(bo.getStatus()), PtRoom::getStatus, bo.getStatus());
+        lqw.in(CollectionUtil.isNotEmpty(bo.getFloorIds()), PtRoom::getAreaId, bo.getFloorIds())
             .and(StringUtils.isNotBlank(bo.getRoomCode()),
                 e -> e.eq(PtRoom::getRoomCode, bo.getRoomCode()).or().eq(PtRoom::getRoomName, bo.getRoomCode()));
         lqw.orderByDesc(PtRoom::getCreateTime);
         Page<PtRoomVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
         List<PtRoomVo> records = result.getRecords();
-        if(CollectionUtil.isNotEmpty(records)){
+        if (CollectionUtil.isNotEmpty(records)) {
             List<PtRoomType> ptRoomTypes = roomTypeMapper.selectBatchIds(records.stream().map(PtRoomVo::getGuestRoomType).collect(Collectors.toList()));
             Map<Long, PtRoomType> ptRoomTypeMap = ptRoomTypes.stream().collect(Collectors.toMap(PtRoomType::getRoomTypeId, e -> e));
             records.forEach(x -> {
@@ -125,7 +123,7 @@ public class PtRoomServiceImpl implements IPtRoomService {
         List<PtRoomVo> rs = new ArrayList<>();
         //先查询楼层,在查询楼层下面的房间
         List<PtAreaVo> ptAreaVos = areaService.queryListLD(areaId);
-        if(CollectionUtil.isNotEmpty(ptAreaVos)){
+        if (CollectionUtil.isNotEmpty(ptAreaVos)) {
             LambdaQueryWrapper<PtRoom> lqw = Wrappers.lambdaQuery();
             List<Long> areaIds = ptAreaVos.stream().map(PtAreaVo::getAreaId).toList();
             lqw.in(PtRoom::getAreaId, areaIds);
@@ -143,12 +141,12 @@ public class PtRoomServiceImpl implements IPtRoomService {
     @Override
     public List<PtRoomVo> queryList(PtRoomBo bo) {
         LambdaQueryWrapper<PtRoom> lqw = buildQueryWrapper2(bo);
-        if(bo.getAreaId()!=null){
+        if (bo.getAreaId() != null) {
             List<PtAreaVo> ptAreaVos = areaService.queryListLD(bo.getAreaId());
-            if(CollectionUtil.isNotEmpty(ptAreaVos)){
+            if (CollectionUtil.isNotEmpty(ptAreaVos)) {
                 List<Long> areaIds = ptAreaVos.stream().map(PtAreaVo::getAreaId).toList();
                 lqw.in(PtRoom::getAreaId, areaIds);
-            }else{
+            } else {
                 lqw.eq(PtRoom::getAreaId, bo.getAreaId());
             }
 
@@ -173,6 +171,7 @@ public class PtRoomServiceImpl implements IPtRoomService {
 
     /**
      * 仅用于选择房间
+     *
      * @param bo 房间定义
      * @return
      */
@@ -180,29 +179,29 @@ public class PtRoomServiceImpl implements IPtRoomService {
     public Map<Long, List<PtAreaVo>> queryRoom2AreaList(PtRoomBo bo) {
         LambdaQueryWrapper<PtRoom> lqw = buildQueryWrapper(bo);
         List<PtRoomVo> ptRoomVos = baseMapper.selectVoList(lqw);
-        if(CollectionUtil.isNotEmpty(ptRoomVos)){
-           List<PtAreaVo> rs = new ArrayList<>();
-           ptRoomVos.forEach(ptRoomVo -> {
-               PtAreaVo ptAreaVo = new PtAreaVo();
-               ptAreaVo.setParentId(ptRoomVo.getAreaId());
-               ptAreaVo.setAreaName(ptRoomVo.getRoomName());
-               ptAreaVo.setAreaId(ptRoomVo.getRoomId());
-               ptAreaVo.setAreaCode(ptRoomVo.getRoomCode());
-               ptAreaVo.setAreaType("room");
-               rs.add(ptAreaVo);
-           });
-           //分组
+        if (CollectionUtil.isNotEmpty(ptRoomVos)) {
+            List<PtAreaVo> rs = new ArrayList<>();
+            ptRoomVos.forEach(ptRoomVo -> {
+                PtAreaVo ptAreaVo = new PtAreaVo();
+                ptAreaVo.setParentId(ptRoomVo.getAreaId());
+                ptAreaVo.setAreaName(ptRoomVo.getRoomName());
+                ptAreaVo.setAreaId(ptRoomVo.getRoomId());
+                ptAreaVo.setAreaCode(ptRoomVo.getRoomCode());
+                ptAreaVo.setAreaType("room");
+                rs.add(ptAreaVo);
+            });
+            //分组
             return rs.stream().collect(Collectors.groupingBy(PtAreaVo::getParentId));
         }
         return MapUtil.empty();
     }
 
     private void setAreaName(List<PtRoomVo> ptRoomVos) {
-        if(CollectionUtil.isNotEmpty(ptRoomVos)){
+        if (CollectionUtil.isNotEmpty(ptRoomVos)) {
             Map<Long, PtAreaVo> areaMap = areaService.queryMapByIds(ptRoomVos.stream().map(PtRoomVo::getAreaId).toList());
             ptRoomVos.forEach(ptRoomVo -> {
                 PtAreaVo ptAreaVo = areaMap.get(ptRoomVo.getAreaId());
-                if(ptAreaVo != null){
+                if (ptAreaVo != null) {
                     ptRoomVo.setAreaName(ptAreaVo.getAreaName());
                 }
             });
@@ -234,7 +233,7 @@ public class PtRoomServiceImpl implements IPtRoomService {
      */
     @Override
     public Boolean insertByBo(PtRoomBo bo) {
-        if(!FJLXEnum.KF.code().equals(bo.getRoomType())){
+        if (!FJLXEnum.KF.code().equals(bo.getRoomType())) {
             bo.setGuestRoomType(null);
         }
         PtRoom add = MapstructUtils.convert(bo, PtRoom.class);
@@ -249,13 +248,13 @@ public class PtRoomServiceImpl implements IPtRoomService {
     @Override
     public Boolean batchSet(PtRoomBatchSetBo bo) {
         LambdaUpdateWrapper<PtRoom> lambdaUpdate = Wrappers.lambdaUpdate();
-        lambdaUpdate.set(StringUtils.isNotBlank(bo.getRoomType()),PtRoom::getRoomType, bo.getRoomType())
-            .set(StringUtils.isBlank(bo.getRoomType()),PtRoom::getRoomType, null)
-            .set(FJLXEnum.KF.code().equals(bo.getRoomType()),PtRoom::getGuestRoomType, bo.getGuestRoomType())
-            .set(!FJLXEnum.KF.code().equals(bo.getRoomType()),PtRoom::getGuestRoomType, null)
+        lambdaUpdate.set(StringUtils.isNotBlank(bo.getRoomType()), PtRoom::getRoomType, bo.getRoomType())
+            .set(StringUtils.isBlank(bo.getRoomType()), PtRoom::getRoomType, null)
+            .set(FJLXEnum.KF.code().equals(bo.getRoomType()), PtRoom::getGuestRoomType, bo.getGuestRoomType())
+            .set(!FJLXEnum.KF.code().equals(bo.getRoomType()), PtRoom::getGuestRoomType, null)
             .in(PtRoom::getRoomId, bo.getRoomIds());
         int update = baseMapper.update(lambdaUpdate);
-        return update>0;
+        return update > 0;
     }
 
 
@@ -269,13 +268,13 @@ public class PtRoomServiceImpl implements IPtRoomService {
     @Transactional
     @CacheEvict(cacheNames = CacheNames.PT_ROOM, key = "#bo.roomId")
     public Boolean updateByBo(PtRoomBo bo) {
-        if(!FJLXEnum.KF.code().equals(bo.getRoomType())){
+        if (!FJLXEnum.KF.code().equals(bo.getRoomType())) {
             bo.setGuestRoomType(null);
         }
         PtRoom update = MapstructUtils.convert(bo, PtRoom.class);
         validEntityBeforeSave(update);
         int rs = baseMapper.updateById(update);
-        if(bo.getGuestRoomType() == null){
+        if (bo.getGuestRoomType() == null) {
             baseMapper.update(null, Wrappers.lambdaUpdate(PtRoom.class).set(PtRoom::getGuestRoomType, null)
                 .eq(PtRoom::getRoomId, bo.getRoomId()));
         }
@@ -284,12 +283,13 @@ public class PtRoomServiceImpl implements IPtRoomService {
 
     /**
      * 根据条件查询区域下的房间
-     * @param areaId 区域
+     *
+     * @param areaId   区域
      * @param roomName
      * @param roomCode
      * @return
      */
-    public List<PtRoomVo> queryByNameOrCode(Long areaId, String roomName, String roomCode){
+    public List<PtRoomVo> queryByNameOrCode(Long areaId, String roomName, String roomCode) {
         return baseMapper.selectVoList(Wrappers.<PtRoom>lambdaQuery()
             .eq(PtRoom::getAreaId, areaId)
             .and(
@@ -299,7 +299,7 @@ public class PtRoomServiceImpl implements IPtRoomService {
 
     @Override
     public Long count(Collection<Long> ids) {
-        if(CollectionUtil.isNotEmpty(ids)){
+        if (CollectionUtil.isNotEmpty(ids)) {
             return baseMapper.selectCount(Wrappers.<PtRoom>lambdaQuery().in(PtRoom::getRoomId, ids));
         }
         return 0L;
@@ -324,11 +324,11 @@ public class PtRoomServiceImpl implements IPtRoomService {
         Map<String, Long> mapList = list.stream().collect(Collectors.groupingBy(PtRoomVo::getStatus, Collectors.counting()));
 
         HotelRoomStatusEnum[] values = HotelRoomStatusEnum.values();
-        if (mapList.isEmpty()){
+        if (mapList.isEmpty()) {
             for (HotelRoomStatusEnum value : values) {
                 map.put(value.code(), 0L);
             }
-        }else{
+        } else {
             for (HotelRoomStatusEnum value : values) {
                 map.put(value.code(), mapList.getOrDefault(value.code(), 0L));
             }
@@ -341,19 +341,19 @@ public class PtRoomServiceImpl implements IPtRoomService {
     /**
      * 保存前的数据校验
      */
-    private void validEntityBeforeSave(PtRoom entity){
+    private void validEntityBeforeSave(PtRoom entity) {
         //做一些数据校验,如唯一约束
         //同一个楼栋 不能有相同的名称和门牌号
-        if(StringUtils.isNotBlank(entity.getRoomName())){
+        if (StringUtils.isNotBlank(entity.getRoomName())) {
             Long aLong = baseMapper.selectCount(Wrappers.<PtRoom>lambdaQuery()
 //                .eq(PtRoom::getAreaId, entity.getAreaId())
-                .and(
-                    queryWrapper -> queryWrapper.eq(PtRoom::getRoomName, entity.getRoomName()).or().eq(PtRoom::getRoomCode, entity.getRoomCode())
-                )
-                .ne(entity.getRoomId() != null, PtRoom::getRoomId, entity.getRoomId())
+                    .and(
+                        queryWrapper -> queryWrapper.eq(PtRoom::getRoomName, entity.getRoomName()).or().eq(PtRoom::getRoomCode, entity.getRoomCode())
+                    )
+                    .ne(entity.getRoomId() != null, PtRoom::getRoomId, entity.getRoomId())
             );
-            if(aLong != null && aLong>0){
-               throw new RuntimeException("房间名称或者房间编号重复");
+            if (aLong != null && aLong > 0) {
+                throw new RuntimeException("房间名称或者房间编号重复");
             }
         }
     }
@@ -368,11 +368,12 @@ public class PtRoomServiceImpl implements IPtRoomService {
     @Override
     @CacheEvict(cacheNames = CacheNames.PT_ROOM)
     public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
-        if(isValid){
+        if (isValid) {
             //做一些业务上的校验,判断是否需要校验
         }
         return baseMapper.deleteByIds(ids) > 0;
     }
+
     /**
      * 更新客房的状态
      *
@@ -384,14 +385,16 @@ public class PtRoomServiceImpl implements IPtRoomService {
     @Override
     public Boolean updateGuestRoomStatus(String roomCode, String tenantId, String roomStatus) {
         LambdaUpdateWrapper<PtRoom> luw = new LambdaUpdateWrapper<>();
-        luw.set(PtRoom::getStatus,roomStatus);
+        luw.set(PtRoom::getStatus, roomStatus);
         luw.eq(PtRoom::getRoomCode, roomCode);
         luw.eq(PtRoom::getTenantId, tenantId);
 
-        return baseMapper.update(null,luw)>0;
+        return baseMapper.update(null, luw) > 0;
     }
+
     /**
      * 查询酒店下的所有客房
+     *
      * @param hotelId 客房区域id
      * @return 客房集合
      */
@@ -400,11 +403,22 @@ public class PtRoomServiceImpl implements IPtRoomService {
         List<PtRoomVo> rs = new ArrayList<>();
         //先查询楼层,在查询楼层下面的房间
         List<PtAreaVo> ptAreaVos = areaService.queryListLD(hotelId);
-        if(CollectionUtil.isNotEmpty(ptAreaVos)){
+        if (CollectionUtil.isNotEmpty(ptAreaVos)) {
             LambdaQueryWrapper<PtRoom> lqw = Wrappers.lambdaQuery();
-            List<Long> areaIds = ptAreaVos.stream().map(PtAreaVo::getAreaId).toList();;
+            List<Long> areaIds = ptAreaVos.stream().map(PtAreaVo::getAreaId).toList();
             rs = baseMapper.selectHotelRoomList(areaIds);
         }
         return rs;
     }
+
+    /**
+     * 查询所有的客房数据
+     *
+     * @return 客房集合
+     */
+    @Override
+    public List<PtRoomVo> queryHotelRoomList() {
+        return baseMapper.selectHotelRoomList();
+    }
+
 }

+ 56 - 0
ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/business/lock/LockBusiness.java

@@ -1,5 +1,6 @@
 package org.dromara.backstage.business.lock;
 
+import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.RandomUtil;
@@ -7,6 +8,7 @@ import cn.hutool.json.JSONObject;
 import cn.hutool.json.JSONUtil;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.dubbo.config.annotation.DubboReference;
 import org.dromara.backstage.basics.domain.vo.PtRoomVo;
 import org.dromara.backstage.basics.service.IPtRoomService;
 import org.dromara.backstage.domain.bo.lock.RoomCardBo;
@@ -14,6 +16,8 @@ import org.dromara.backstage.util.LockUtils;
 import org.dromara.common.core.constant.DefaultConstants;
 import org.dromara.common.core.constant.LockConstants;
 import org.dromara.common.core.domain.R;
+import org.dromara.hotel.api.domain.bo.RemoteLockPowerBo;
+import org.dromara.hotel.api.service.RemoteLockPowerService;
 import org.springframework.stereotype.Service;
 
 import java.util.HashMap;
@@ -35,6 +39,9 @@ public class LockBusiness {
     private final LockUtils lockUtils;
     private final IPtRoomService roomService;
 
+    @DubboReference
+    private final RemoteLockPowerService remoteLockPowerService;
+
     /**
      * 获取门锁发卡数据
      *
@@ -72,6 +79,7 @@ public class LockBusiness {
 
     /**
      * 远程开门
+     *
      * @param lockId 门锁Id
      * @return 开门结果
      */
@@ -88,6 +96,54 @@ public class LockBusiness {
         return R.fail("远程开门失败", "远程开门失败");
     }
 
+    /**
+     * 查询指定门锁的电量
+     *
+     * @param lockId 门锁Id
+     * @return 门锁电量
+     */
+    public R<String> queryLockBattery(String lockId) {
+        Map<String, Object> formMap = new HashMap<>();
+        formMap.put("DEVICE_ID", lockId);
+        String result = lockUtils.sendPost(formMap, "queryDeviceStatus");
+        String flag = JSONUtil.parseObj(result).getStr("result");
+        if (ObjectUtil.equals(flag, "0")) {
+            JSONObject data = JSONUtil.parseObj(result).getJSONObject("data");
+            String battery = JSONUtil.parseObj(data).getStr("battery");
+            return R.ok(battery, battery);
+        }
+        return R.fail("获取门锁电量失败", "获取门锁电量失败");
+    }
+
+    public Boolean syncLockPower(Long areaId) {
+        List<PtRoomVo> roomVos = roomService.queryHotelRoomList(areaId);
+        insertLockPower(roomVos);
+        return true;
+    }
+
+    public Boolean syncLockPower() {
+        List<PtRoomVo> roomVos = roomService.queryHotelRoomList();
+        insertLockPower(roomVos);
+        return true;
+    }
+
+    private void insertLockPower(List<PtRoomVo> roomVos) {
+        if (CollectionUtil.isNotEmpty(roomVos)) {
+            roomVos.forEach(p -> {
+                String lockId = p.getLockId();
+                R<String> result = this.queryLockBattery(lockId);
+                if (R.isSuccess(result)) {
+                    RemoteLockPowerBo remoteLockPowerBo = new RemoteLockPowerBo();
+                    remoteLockPowerBo.setRoomCode(p.getRoomCode());
+                    remoteLockPowerBo.setRoomName(p.getRoomName());
+                    remoteLockPowerBo.setPower(Double.parseDouble(result.getData()));
+
+                    remoteLockPowerService.insertLockPowerByBo(remoteLockPowerBo);
+                }
+            });
+        }
+    }
+
     private Map<String, Object> setGuestCardParam(RoomCardBo bo) {
         Map<String, Object> formMap = new HashMap<>();
         formMap.put("cardSenderLockId", LockConstants.YY_CARD_SENDER_ID);

+ 11 - 13
ruoyi-modules/ruoyi-backstage/src/main/java/org/dromara/backstage/controller/lock/LockController.java

@@ -4,16 +4,12 @@ import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.dromara.backstage.business.lock.LockBusiness;
 import org.dromara.backstage.domain.bo.lock.RoomCardBo;
-import org.dromara.backstage.util.LockUtils;
 import org.dromara.common.core.api.ResponseResult;
 import org.dromara.common.core.api.ReturnResult;
 import org.dromara.common.core.domain.R;
 import org.dromara.common.core.enums.ResultCodeEnum;
 import org.springframework.web.bind.annotation.*;
 
-import java.util.HashMap;
-import java.util.Map;
-
 /**
  * name: lockController
  * package: org.dromara.backstage.controller.lock
@@ -30,21 +26,22 @@ import java.util.Map;
 @ResponseResult
 @Slf4j
 public class LockController {
-    private final LockUtils lockUtils;
     private final LockBusiness lockBusiness;
 
     /**
-     * 查询门锁状态
+     * 查询门锁电量
      *
      * @param lockId 门锁Id
      * @return 状态
      */
-    @GetMapping(value = "/device/status", produces = "application/json; charset=utf-8")
-    ReturnResult queryDeviceStatus(@RequestParam("lockId") String lockId) {
-        Map<String, Object> formMap = new HashMap<>();
-        formMap.put("DEVICE_ID", lockId);
-        String result = lockUtils.sendPost(formMap, "queryDeviceStatus");
-        return ReturnResult.success(result);
+    @GetMapping(value = "/device/battery", produces = "application/json; charset=utf-8")
+    ReturnResult queryDeviceBattery(@RequestParam("lockId") String lockId) {
+        Boolean result = lockBusiness.syncLockPower(115L);
+        if(result) {
+            return ReturnResult.success();
+        } else {
+            return ReturnResult.failure(ResultCodeEnum.INTERFACE_OUTER_INVOKE_ERROR);
+        }
     }
 
     /**
@@ -54,12 +51,13 @@ public class LockController {
      * @return 发卡数据
      */
     @GetMapping(value = "/card/data")
-    ReturnResult getRoomCardData(@RequestBody RoomCardBo bo) {
+    ReturnResult getRoomCardData( RoomCardBo bo) {
         return ReturnResult.success(lockBusiness.getWriteCardData(bo));
     }
 
     /**
      * 远程开门
+     *
      * @param lockId 门锁Id
      * @return 开门结果
      */

+ 23 - 1
ruoyi-modules/ruoyi-backstage/src/main/resources/mapper/basics/room/PtRoomMapper.xml

@@ -11,6 +11,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
             <result property="roomCode"    column="room_code"    />
             <result property="roomName"    column="room_name"    />
             <result property="roomType"    column="room_type"    />
+            <result property="guestRoomType"    column="guest_room_type"    />
             <result property="codeOne"    column="code_one"    />
             <result property="remark"    column="remark"    />
             <result property="delFlag"    column="del_flag"    />
@@ -21,11 +22,32 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
             <result property="updateTime"    column="update_time"    />
     </resultMap>
 
+    <select id="selectRoomLockList" resultType="org.dromara.backstage.basics.domain.vo.PtRoomVo">
+        SELECT
+            r.room_id,
+            r.area_id,
+            r.room_code,
+            r.room_name,
+            r.room_type,
+            r.guest_room_type,
+            r.code_one,
+            r.status,
+            r.has_network,
+            r.remark,
+            l.lock_id,
+            l.lock_password
+        FROM t_pt_room r LEFT JOIN t_kf_room_lock_r l ON r.room_id = l.room_id
+        <where>
+            ${ew.sqlSegment}
+        </where>
+    </select>
+
     <select id="selectHotelRoomList" resultType="org.dromara.backstage.basics.domain.vo.PtRoomVo">
         SELECT tpr.*,tkrlr.lock_id,tkrlr.lock_password FROM t_pt_room tpr
          INNER JOIN t_kf_room_lock_r tkrlr on tkrlr.room_id=tpr.room_id
+         where tpr.del_flag='0'
         <if test="areaIds != null and areaIds.size() > 0">
-            where tpr.area_id in
+            and tpr.area_id in
             <foreach collection="areaIds" item="item" open="(" separator="," close=")">
                 #{item}
             </foreach>

+ 106 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/controller/KfLockPowerController.java

@@ -0,0 +1,106 @@
+package org.dromara.hotel.controller;
+
+import java.util.List;
+
+import lombok.RequiredArgsConstructor;
+import jakarta.servlet.http.HttpServletResponse;
+import jakarta.validation.constraints.*;
+import cn.dev33.satoken.annotation.SaCheckPermission;
+import org.springframework.web.bind.annotation.*;
+import org.springframework.validation.annotation.Validated;
+import org.dromara.common.idempotent.annotation.RepeatSubmit;
+import org.dromara.common.log.annotation.Log;
+import org.dromara.common.web.core.BaseController;
+import org.dromara.common.mybatis.core.page.PageQuery;
+import org.dromara.common.core.domain.R;
+import org.dromara.common.core.validate.AddGroup;
+import org.dromara.common.core.validate.EditGroup;
+import org.dromara.common.log.enums.BusinessType;
+import org.dromara.common.excel.utils.ExcelUtil;
+import org.dromara.hotel.domain.vo.KfLockPowerVo;
+import org.dromara.hotel.domain.bo.KfLockPowerBo;
+import org.dromara.hotel.service.IKfLockPowerService;
+import org.dromara.common.mybatis.core.page.TableDataInfo;
+
+/**
+ * 门锁电量
+ * 前端访问路由地址为:/basics/kfLockPower
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Validated
+@RequiredArgsConstructor
+@RestController
+@RequestMapping("/basics/kfLockPower")
+public class KfLockPowerController extends BaseController {
+
+    private final IKfLockPowerService kfLockPowerService;
+
+    /**
+     * 查询门锁电量列表
+     */
+    @SaCheckPermission("basics:kfLockPower:list")
+    @GetMapping("/list")
+    public TableDataInfo<KfLockPowerVo> list(KfLockPowerBo bo, PageQuery pageQuery) {
+        return kfLockPowerService.queryPageList(bo, pageQuery);
+    }
+
+    /**
+     * 导出门锁电量列表
+     */
+    @SaCheckPermission("basics:kfLockPower:export")
+    @Log(title = "门锁电量", businessType = BusinessType.EXPORT)
+    @PostMapping("/export")
+    public void export(KfLockPowerBo bo, HttpServletResponse response) {
+        List<KfLockPowerVo> list = kfLockPowerService.queryList(bo);
+        ExcelUtil.exportExcel(list, "门锁电量", KfLockPowerVo.class, response);
+    }
+
+    /**
+     * 获取门锁电量详细信息
+     *
+     * @param id 主键
+     */
+    @SaCheckPermission("basics:kfLockPower:query")
+    @GetMapping("/{id}")
+    public R<KfLockPowerVo> getInfo(@NotNull(message = "主键不能为空")
+                                     @PathVariable Long id) {
+        return R.ok(kfLockPowerService.queryById(id));
+    }
+
+    /**
+     * 新增门锁电量
+     */
+    @SaCheckPermission("basics:kfLockPower:add")
+    @Log(title = "门锁电量", businessType = BusinessType.INSERT)
+    @RepeatSubmit()
+    @PostMapping()
+    public R<Void> add(@Validated(AddGroup.class) @RequestBody KfLockPowerBo bo) {
+        return toAjax(kfLockPowerService.insertByBo(bo));
+    }
+
+    /**
+     * 修改门锁电量
+     */
+    @SaCheckPermission("basics:kfLockPower:edit")
+    @Log(title = "门锁电量", businessType = BusinessType.UPDATE)
+    @RepeatSubmit()
+    @PutMapping()
+    public R<Void> edit(@Validated(EditGroup.class) @RequestBody KfLockPowerBo bo) {
+        return toAjax(kfLockPowerService.updateByBo(bo));
+    }
+
+    /**
+     * 删除门锁电量
+     *
+     * @param ids 主键串
+     */
+    @SaCheckPermission("basics:kfLockPower:remove")
+    @Log(title = "门锁电量", businessType = BusinessType.DELETE)
+    @DeleteMapping("/{ids}")
+    public R<Void> remove(@NotEmpty(message = "主键不能为空")
+                          @PathVariable Long[] ids) {
+        return toAjax(kfLockPowerService.deleteWithValidByIds(List.of(ids), true));
+    }
+}

+ 106 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/controller/KfProvideCardHisController.java

@@ -0,0 +1,106 @@
+package org.dromara.hotel.controller;
+
+import java.util.List;
+
+import lombok.RequiredArgsConstructor;
+import jakarta.servlet.http.HttpServletResponse;
+import jakarta.validation.constraints.*;
+import cn.dev33.satoken.annotation.SaCheckPermission;
+import org.springframework.web.bind.annotation.*;
+import org.springframework.validation.annotation.Validated;
+import org.dromara.common.idempotent.annotation.RepeatSubmit;
+import org.dromara.common.log.annotation.Log;
+import org.dromara.common.web.core.BaseController;
+import org.dromara.common.mybatis.core.page.PageQuery;
+import org.dromara.common.core.domain.R;
+import org.dromara.common.core.validate.AddGroup;
+import org.dromara.common.core.validate.EditGroup;
+import org.dromara.common.log.enums.BusinessType;
+import org.dromara.common.excel.utils.ExcelUtil;
+import org.dromara.hotel.domain.vo.KfProvideCardHisVo;
+import org.dromara.hotel.domain.bo.KfProvideCardHisBo;
+import org.dromara.hotel.service.IKfProvideCardHisService;
+import org.dromara.common.mybatis.core.page.TableDataInfo;
+
+/**
+ * 发卡记录
+ * 前端访问路由地址为:/basics/kfCardData
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Validated
+@RequiredArgsConstructor
+@RestController
+@RequestMapping("/basics/kfCardData")
+public class KfProvideCardHisController extends BaseController {
+
+    private final IKfProvideCardHisService kfProvideCardHisService;
+
+    /**
+     * 查询发卡记录列表
+     */
+    @SaCheckPermission("basics:kfCardData:list")
+    @GetMapping("/list")
+    public TableDataInfo<KfProvideCardHisVo> list(KfProvideCardHisBo bo, PageQuery pageQuery) {
+        return kfProvideCardHisService.queryPageList(bo, pageQuery);
+    }
+
+    /**
+     * 导出发卡记录列表
+     */
+    @SaCheckPermission("basics:kfCardData:export")
+    @Log(title = "发卡记录", businessType = BusinessType.EXPORT)
+    @PostMapping("/export")
+    public void export(KfProvideCardHisBo bo, HttpServletResponse response) {
+        List<KfProvideCardHisVo> list = kfProvideCardHisService.queryList(bo);
+        ExcelUtil.exportExcel(list, "发卡记录", KfProvideCardHisVo.class, response);
+    }
+
+    /**
+     * 获取发卡记录详细信息
+     *
+     * @param id 主键
+     */
+    @SaCheckPermission("basics:kfCardData:query")
+    @GetMapping("/{id}")
+    public R<KfProvideCardHisVo> getInfo(@NotNull(message = "主键不能为空")
+                                     @PathVariable Long id) {
+        return R.ok(kfProvideCardHisService.queryById(id));
+    }
+
+    /**
+     * 新增发卡记录
+     */
+    @SaCheckPermission("basics:kfCardData:add")
+    @Log(title = "发卡记录", businessType = BusinessType.INSERT)
+    @RepeatSubmit()
+    @PostMapping()
+    public R<Void> add(@Validated(AddGroup.class) @RequestBody KfProvideCardHisBo bo) {
+        return toAjax(kfProvideCardHisService.insertByBo(bo));
+    }
+
+    /**
+     * 修改发卡记录
+     */
+    @SaCheckPermission("basics:kfCardData:edit")
+    @Log(title = "发卡记录", businessType = BusinessType.UPDATE)
+    @RepeatSubmit()
+    @PutMapping()
+    public R<Void> edit(@Validated(EditGroup.class) @RequestBody KfProvideCardHisBo bo) {
+        return toAjax(kfProvideCardHisService.updateByBo(bo));
+    }
+
+    /**
+     * 删除发卡记录
+     *
+     * @param ids 主键串
+     */
+    @SaCheckPermission("basics:kfCardData:remove")
+    @Log(title = "发卡记录", businessType = BusinessType.DELETE)
+    @DeleteMapping("/{ids}")
+    public R<Void> remove(@NotEmpty(message = "主键不能为空")
+                          @PathVariable Long[] ids) {
+        return toAjax(kfProvideCardHisService.deleteWithValidByIds(List.of(ids), true));
+    }
+}

+ 67 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/KfLockPower.java

@@ -0,0 +1,67 @@
+package org.dromara.hotel.domain;
+
+import org.dromara.common.tenant.core.TenantEntity;
+import com.baomidou.mybatisplus.annotation.*;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+
+import java.io.Serial;
+
+/**
+ * 门锁电量对象 t_kf_lock_power
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@TableName("t_kf_lock_power")
+public class KfLockPower extends TenantEntity {
+
+    @Serial
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键
+     */
+    @TableId(value = "id")
+    private Long id;
+
+    /**
+     * 房间编号
+     */
+    private String roomCode;
+
+    /**
+     * 房间名称
+     */
+    private String roomName;
+
+    /**
+     * 电量
+     */
+    private double power;
+
+    /**
+     * 维修人ID
+     */
+    private Long repairUserId;
+
+    /**
+     * 维修人姓名
+     */
+    private String repairUserName;
+
+    /**
+     * 维修状态
+     */
+    private String repairStatus;
+
+    /**
+     * 删除标志
+     */
+    @TableLogic
+    private String delFlag;
+
+
+}

+ 94 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/KfProvideCardHis.java

@@ -0,0 +1,94 @@
+package org.dromara.hotel.domain;
+
+import org.dromara.common.tenant.core.TenantEntity;
+import com.baomidou.mybatisplus.annotation.*;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import java.util.Date;
+import com.fasterxml.jackson.annotation.JsonFormat;
+
+import java.io.Serial;
+
+/**
+ * 发卡记录对象 t_kf_provide_card_his
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@TableName("t_kf_provide_card_his")
+public class KfProvideCardHis extends TenantEntity {
+
+    @Serial
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键
+     */
+    @TableId(value = "id")
+    private Long id;
+
+    /**
+     * 卡片ID
+     */
+    private Long cardId;
+
+    /**
+     * 物理卡号
+     */
+    private String factoryId;
+
+    /**
+     * 卡片类别
+     */
+    private String cardType;
+
+    /**
+     * 房间编号
+     */
+    private String roomCode;
+
+    /**
+     * 持卡人ID
+     */
+    private Long masterId;
+
+    /**
+     * 持卡人
+     */
+    private String masterName;
+
+    /**
+     * 生效时间
+     */
+    private Date startTime;
+
+    /**
+     * 失效时间
+     */
+    private Date endTime;
+
+    /**
+     * 回收时间
+     */
+    private Date cecycleTime;
+
+    /**
+     * 卡片状态(1:正常;0:回收)
+     */
+    private String catdStatus;
+
+    /**
+     * 备注(记录房卡权限范围)
+     */
+    private String remark;
+
+    /**
+     * 删除标志
+     */
+    @TableLogic
+    private String delFlag;
+
+
+}

+ 61 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/bo/KfLockPowerBo.java

@@ -0,0 +1,61 @@
+package org.dromara.hotel.domain.bo;
+
+import org.dromara.hotel.domain.KfLockPower;
+import org.dromara.common.mybatis.core.domain.BaseEntity;
+import org.dromara.common.core.validate.AddGroup;
+import org.dromara.common.core.validate.EditGroup;
+import io.github.linpeilie.annotations.AutoMapper;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import jakarta.validation.constraints.*;
+
+/**
+ * 门锁电量业务对象 t_kf_lock_power
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@AutoMapper(target = KfLockPower.class, reverseConvertGenerate = false)
+public class KfLockPowerBo extends BaseEntity {
+    /**
+     * 主键
+     */
+    private Long id;
+
+    /**
+     * 房间编号
+     */
+    @NotBlank(message = "房间编号不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String roomCode;
+
+    /**
+     * 房间名称
+     */
+    @NotBlank(message = "房间名称不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String roomName;
+
+    /**
+     * 电量
+     */
+    @NotNull(message = "电量不能为空", groups = { AddGroup.class, EditGroup.class })
+    private Long power;
+
+    /**
+     * 维修人ID
+     */
+    private Long repairUserId;
+
+    /**
+     * 维修人姓名
+     */
+    private String repairUserName;
+
+    /**
+     * 维修状态
+     */
+    private String repairStatus;
+
+
+}

+ 98 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/bo/KfProvideCardHisBo.java

@@ -0,0 +1,98 @@
+package org.dromara.hotel.domain.bo;
+
+import org.dromara.hotel.domain.KfProvideCardHis;
+import org.dromara.common.mybatis.core.domain.BaseEntity;
+import org.dromara.common.core.validate.AddGroup;
+import org.dromara.common.core.validate.EditGroup;
+import io.github.linpeilie.annotations.AutoMapper;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import jakarta.validation.constraints.*;
+import java.util.Date;
+import com.fasterxml.jackson.annotation.JsonFormat;
+
+/**
+ * 发卡记录业务对象 t_kf_provide_card_his
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Data
+@EqualsAndHashCode(callSuper = true)
+@AutoMapper(target = KfProvideCardHis.class, reverseConvertGenerate = false)
+public class KfProvideCardHisBo extends BaseEntity {
+
+    /**
+     * 主键
+     */
+    @NotNull(message = "主键不能为空", groups = { EditGroup.class })
+    private Long id;
+
+    /**
+     * 卡片ID
+     */
+    @NotNull(message = "卡片ID不能为空", groups = { AddGroup.class, EditGroup.class })
+    private Long cardId;
+
+    /**
+     * 物理卡号
+     */
+    @NotBlank(message = "物理卡号不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String factoryId;
+
+    /**
+     * 卡片类别
+     */
+    @NotBlank(message = "卡片类别不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String cardType;
+
+    /**
+     * 房间编号
+     */
+    @NotBlank(message = "房间编号不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String roomCode;
+
+    /**
+     * 持卡人ID
+     */
+    @NotNull(message = "持卡人ID不能为空", groups = { AddGroup.class, EditGroup.class })
+    private Long masterId;
+
+    /**
+     * 持卡人
+     */
+    @NotBlank(message = "持卡人不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String masterName;
+
+    /**
+     * 生效时间
+     */
+    @NotNull(message = "生效时间不能为空", groups = { AddGroup.class, EditGroup.class })
+    private Date startTime;
+
+    /**
+     * 失效时间
+     */
+    @NotNull(message = "失效时间不能为空", groups = { AddGroup.class, EditGroup.class })
+    private Date endTime;
+
+    /**
+     * 回收时间
+     */
+    @NotNull(message = "回收时间不能为空", groups = { AddGroup.class, EditGroup.class })
+    private Date cecycleTime;
+
+    /**
+     * 卡片状态(1:正常;0:回收)
+     */
+    @NotBlank(message = "卡片状态(1:正常;0:回收)不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String catdStatus;
+
+    /**
+     * 备注(记录房卡权限范围)
+     */
+    @NotBlank(message = "备注(记录房卡权限范围)不能为空", groups = { AddGroup.class, EditGroup.class })
+    private String remark;
+
+
+}

+ 19 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/convert/RemoteLockPowerBoConvert.java

@@ -0,0 +1,19 @@
+package org.dromara.hotel.domain.convert;
+
+import io.github.linpeilie.BaseMapper;
+import org.dromara.hotel.api.domain.bo.RemoteLockPowerBo;
+import org.dromara.hotel.api.domain.bo.RemoteTeamBo;
+import org.dromara.hotel.domain.bo.KfLockPowerBo;
+import org.dromara.hotel.domain.bo.KfTeamBo;
+import org.mapstruct.Mapper;
+import org.mapstruct.MappingConstants;
+import org.mapstruct.ReportingPolicy;
+
+/**
+ * 客房团客信息转换器
+ * @author zhujie
+ */
+@Mapper(componentModel = MappingConstants.ComponentModel.SPRING, unmappedTargetPolicy = ReportingPolicy.IGNORE)
+public interface RemoteLockPowerBoConvert extends BaseMapper<RemoteLockPowerBo, KfLockPowerBo> {
+
+}

+ 74 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/vo/KfLockPowerVo.java

@@ -0,0 +1,74 @@
+package org.dromara.hotel.domain.vo;
+
+import org.dromara.hotel.domain.KfLockPower;
+import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
+import com.alibaba.excel.annotation.ExcelProperty;
+import org.dromara.common.excel.annotation.ExcelDictFormat;
+import org.dromara.common.excel.convert.ExcelDictConvert;
+import io.github.linpeilie.annotations.AutoMapper;
+import lombok.Data;
+
+import java.io.Serial;
+import java.io.Serializable;
+import java.util.Date;
+
+
+
+/**
+ * 门锁电量视图对象 t_kf_lock_power
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Data
+@ExcelIgnoreUnannotated
+@AutoMapper(target = KfLockPower.class)
+public class KfLockPowerVo implements Serializable {
+
+    @Serial
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键
+     */
+    @ExcelProperty(value = "主键")
+    private Long id;
+
+    /**
+     * 房间编号
+     */
+    @ExcelProperty(value = "房间编号")
+    private String roomCode;
+
+    /**
+     * 房间名称
+     */
+    @ExcelProperty(value = "房间名称")
+    private String roomName;
+
+    /**
+     * 电量
+     */
+    @ExcelProperty(value = "电量")
+    private Long power;
+
+    /**
+     * 维修人ID
+     */
+    @ExcelProperty(value = "维修人ID")
+    private Long repairUserId;
+
+    /**
+     * 维修人姓名
+     */
+    @ExcelProperty(value = "维修人姓名")
+    private String repairUserName;
+
+    /**
+     * 维修状态
+     */
+    @ExcelProperty(value = "维修状态")
+    private String repairStatus;
+
+
+}

+ 106 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/domain/vo/KfProvideCardHisVo.java

@@ -0,0 +1,106 @@
+package org.dromara.hotel.domain.vo;
+
+import java.util.Date;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import org.dromara.hotel.domain.KfProvideCardHis;
+import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
+import com.alibaba.excel.annotation.ExcelProperty;
+import org.dromara.common.excel.annotation.ExcelDictFormat;
+import org.dromara.common.excel.convert.ExcelDictConvert;
+import io.github.linpeilie.annotations.AutoMapper;
+import lombok.Data;
+
+import java.io.Serial;
+import java.io.Serializable;
+import java.util.Date;
+
+
+
+/**
+ * 发卡记录视图对象 t_kf_provide_card_his
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@Data
+@ExcelIgnoreUnannotated
+@AutoMapper(target = KfProvideCardHis.class)
+public class KfProvideCardHisVo implements Serializable {
+
+    @Serial
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键
+     */
+    @ExcelProperty(value = "主键")
+    private Long id;
+
+    /**
+     * 卡片ID
+     */
+    @ExcelProperty(value = "卡片ID")
+    private Long cardId;
+
+    /**
+     * 物理卡号
+     */
+    @ExcelProperty(value = "物理卡号")
+    private String factoryId;
+
+    /**
+     * 卡片类别
+     */
+    @ExcelProperty(value = "卡片类别")
+    private String cardType;
+
+    /**
+     * 房间编号
+     */
+    @ExcelProperty(value = "房间编号")
+    private String roomCode;
+
+    /**
+     * 持卡人ID
+     */
+    @ExcelProperty(value = "持卡人ID")
+    private Long masterId;
+
+    /**
+     * 持卡人
+     */
+    @ExcelProperty(value = "持卡人")
+    private String masterName;
+
+    /**
+     * 生效时间
+     */
+    @ExcelProperty(value = "生效时间")
+    private Date startTime;
+
+    /**
+     * 失效时间
+     */
+    @ExcelProperty(value = "失效时间")
+    private Date endTime;
+
+    /**
+     * 回收时间
+     */
+    @ExcelProperty(value = "回收时间")
+    private Date cecycleTime;
+
+    /**
+     * 卡片状态(1:正常;0:回收)
+     */
+    @ExcelProperty(value = "卡片状态(1:正常;0:回收)")
+    private String catdStatus;
+
+    /**
+     * 备注(记录房卡权限范围)
+     */
+    @ExcelProperty(value = "备注(记录房卡权限范围)")
+    private String remark;
+
+
+}

+ 62 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/dubbo/RemoteLockPowerServiceImpl.java

@@ -0,0 +1,62 @@
+package org.dromara.hotel.dubbo;
+
+import cn.hutool.core.util.ObjectUtil;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.dubbo.config.annotation.DubboService;
+import org.dromara.common.core.domain.R;
+import org.dromara.common.core.domain.model.ErrorInfo;
+import org.dromara.common.core.utils.MapstructUtils;
+import org.dromara.common.json.utils.JsonUtils;
+import org.dromara.hotel.api.domain.bo.RemoteLockPowerBo;
+import org.dromara.hotel.api.domain.bo.RemoteTeamBo;
+import org.dromara.hotel.api.domain.vo.RemoteTeamVo;
+import org.dromara.hotel.api.service.RemoteLockPowerService;
+import org.dromara.hotel.api.service.RemoteTeamService;
+import org.dromara.hotel.domain.bo.KfLockPowerBo;
+import org.dromara.hotel.domain.bo.KfTeamBo;
+import org.dromara.hotel.domain.vo.KfTeamVo;
+import org.dromara.hotel.service.IKfLockPowerService;
+import org.dromara.hotel.service.IKfTeamService;
+import org.springframework.stereotype.Service;
+
+import java.util.Date;
+import java.util.List;
+
+/**
+ * @ClassName RemoteLockPowerServiceImpl
+ * @Description 酒店门锁电量远程服务实现
+ * @Author luoyibo
+ * @Date 2024-11-14 20:31
+ * @Version 1.0
+ * @since jdk17
+ */
+
+@Slf4j
+@Service
+@DubboService
+@RequiredArgsConstructor
+public class RemoteLockPowerServiceImpl implements RemoteLockPowerService {
+    private final IKfLockPowerService lockPowerService;
+    /**
+     * 增加门锁电量信息
+     * @param remoteBo 门锁电量业务对象
+     * @return 操作结果
+     */
+    @Override
+    public R<ErrorInfo> insertLockPowerByBo(RemoteLockPowerBo remoteBo) {
+        try {
+            KfLockPowerBo bo = MapstructUtils.convert(remoteBo, KfLockPowerBo.class);
+            if (bo != null) {
+                boolean flag = lockPowerService.insertByBo(bo);
+                if (flag) {
+                    return R.ok("增加门锁电量成功");
+                }
+            }
+            return R.fail("增加门锁电量失败");
+        } catch (Exception e) {
+            log.error("增加门锁电量失败-{}-{}", JsonUtils.toJsonString(remoteBo), e.getMessage());
+            return R.fail("增加门锁电量失败");
+        }
+    }
+}

+ 15 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/mapper/KfLockPowerMapper.java

@@ -0,0 +1,15 @@
+package org.dromara.hotel.mapper;
+
+import org.dromara.hotel.domain.KfLockPower;
+import org.dromara.hotel.domain.vo.KfLockPowerVo;
+import org.dromara.common.mybatis.core.mapper.BaseMapperPlus;
+
+/**
+ * 门锁电量Mapper接口
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+public interface KfLockPowerMapper extends BaseMapperPlus<KfLockPower, KfLockPowerVo> {
+
+}

+ 15 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/mapper/KfProvideCardHisMapper.java

@@ -0,0 +1,15 @@
+package org.dromara.hotel.mapper;
+
+import org.dromara.hotel.domain.KfProvideCardHis;
+import org.dromara.hotel.domain.vo.KfProvideCardHisVo;
+import org.dromara.common.mybatis.core.mapper.BaseMapperPlus;
+
+/**
+ * 发卡记录Mapper接口
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+public interface KfProvideCardHisMapper extends BaseMapperPlus<KfProvideCardHis, KfProvideCardHisVo> {
+
+}

+ 69 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/IKfLockPowerService.java

@@ -0,0 +1,69 @@
+package org.dromara.hotel.service;
+
+import org.dromara.hotel.domain.KfLockPower;
+import org.dromara.hotel.domain.vo.KfLockPowerVo;
+import org.dromara.hotel.domain.bo.KfLockPowerBo;
+import org.dromara.common.mybatis.core.page.TableDataInfo;
+import org.dromara.common.mybatis.core.page.PageQuery;
+
+import java.util.Collection;
+import java.util.List;
+
+/**
+ * 门锁电量Service接口
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+public interface IKfLockPowerService {
+
+    /**
+     * 查询门锁电量
+     *
+     * @param id 主键
+     * @return 门锁电量
+     */
+    KfLockPowerVo queryById(Long id);
+
+    /**
+     * 分页查询门锁电量列表
+     *
+     * @param bo        查询条件
+     * @param pageQuery 分页参数
+     * @return 门锁电量分页列表
+     */
+    TableDataInfo<KfLockPowerVo> queryPageList(KfLockPowerBo bo, PageQuery pageQuery);
+
+    /**
+     * 查询符合条件的门锁电量列表
+     *
+     * @param bo 查询条件
+     * @return 门锁电量列表
+     */
+    List<KfLockPowerVo> queryList(KfLockPowerBo bo);
+
+    /**
+     * 新增门锁电量
+     *
+     * @param bo 门锁电量
+     * @return 是否新增成功
+     */
+    Boolean insertByBo(KfLockPowerBo bo);
+
+    /**
+     * 修改门锁电量
+     *
+     * @param bo 门锁电量
+     * @return 是否修改成功
+     */
+    Boolean updateByBo(KfLockPowerBo bo);
+
+    /**
+     * 校验并批量删除门锁电量信息
+     *
+     * @param ids     待删除的主键集合
+     * @param isValid 是否进行有效性校验
+     * @return 是否删除成功
+     */
+    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
+}

+ 69 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/IKfProvideCardHisService.java

@@ -0,0 +1,69 @@
+package org.dromara.hotel.service;
+
+import org.dromara.hotel.domain.KfProvideCardHis;
+import org.dromara.hotel.domain.vo.KfProvideCardHisVo;
+import org.dromara.hotel.domain.bo.KfProvideCardHisBo;
+import org.dromara.common.mybatis.core.page.TableDataInfo;
+import org.dromara.common.mybatis.core.page.PageQuery;
+
+import java.util.Collection;
+import java.util.List;
+
+/**
+ * 发卡记录Service接口
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+public interface IKfProvideCardHisService {
+
+    /**
+     * 查询发卡记录
+     *
+     * @param id 主键
+     * @return 发卡记录
+     */
+    KfProvideCardHisVo queryById(Long id);
+
+    /**
+     * 分页查询发卡记录列表
+     *
+     * @param bo        查询条件
+     * @param pageQuery 分页参数
+     * @return 发卡记录分页列表
+     */
+    TableDataInfo<KfProvideCardHisVo> queryPageList(KfProvideCardHisBo bo, PageQuery pageQuery);
+
+    /**
+     * 查询符合条件的发卡记录列表
+     *
+     * @param bo 查询条件
+     * @return 发卡记录列表
+     */
+    List<KfProvideCardHisVo> queryList(KfProvideCardHisBo bo);
+
+    /**
+     * 新增发卡记录
+     *
+     * @param bo 发卡记录
+     * @return 是否新增成功
+     */
+    Boolean insertByBo(KfProvideCardHisBo bo);
+
+    /**
+     * 修改发卡记录
+     *
+     * @param bo 发卡记录
+     * @return 是否修改成功
+     */
+    Boolean updateByBo(KfProvideCardHisBo bo);
+
+    /**
+     * 校验并批量删除发卡记录信息
+     *
+     * @param ids     待删除的主键集合
+     * @param isValid 是否进行有效性校验
+     * @return 是否删除成功
+     */
+    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
+}

+ 150 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/impl/KfLockPowerServiceImpl.java

@@ -0,0 +1,150 @@
+package org.dromara.hotel.service.impl;
+
+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.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import lombok.RequiredArgsConstructor;
+import org.springframework.stereotype.Service;
+import org.dromara.hotel.domain.bo.KfLockPowerBo;
+import org.dromara.hotel.domain.vo.KfLockPowerVo;
+import org.dromara.hotel.domain.KfLockPower;
+import org.dromara.hotel.mapper.KfLockPowerMapper;
+import org.dromara.hotel.service.IKfLockPowerService;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Collection;
+
+/**
+ * 门锁电量Service业务层处理
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@RequiredArgsConstructor
+@Service
+public class KfLockPowerServiceImpl implements IKfLockPowerService {
+
+    private final KfLockPowerMapper baseMapper;
+
+    /**
+     * 查询门锁电量
+     *
+     * @param id 主键
+     * @return 门锁电量
+     */
+    @Override
+    public KfLockPowerVo queryById(Long id){
+        return baseMapper.selectVoById(id);
+    }
+
+    /**
+     * 分页查询门锁电量列表
+     *
+     * @param bo        查询条件
+     * @param pageQuery 分页参数
+     * @return 门锁电量分页列表
+     */
+    @Override
+    public TableDataInfo<KfLockPowerVo> queryPageList(KfLockPowerBo bo, PageQuery pageQuery) {
+        LambdaQueryWrapper<KfLockPower> lqw = buildQueryWrapper(bo);
+        Page<KfLockPowerVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
+        return TableDataInfo.build(result);
+    }
+
+    /**
+     * 查询符合条件的门锁电量列表
+     *
+     * @param bo 查询条件
+     * @return 门锁电量列表
+     */
+    @Override
+    public List<KfLockPowerVo> queryList(KfLockPowerBo bo) {
+        LambdaQueryWrapper<KfLockPower> lqw = buildQueryWrapper(bo);
+        return baseMapper.selectVoList(lqw);
+    }
+
+    private LambdaQueryWrapper<KfLockPower> buildQueryWrapper(KfLockPowerBo bo) {
+        Map<String, Object> params = bo.getParams();
+        LambdaQueryWrapper<KfLockPower> lqw = Wrappers.lambdaQuery();
+        lqw.eq(StringUtils.isNotBlank(bo.getRoomCode()), KfLockPower::getRoomCode, bo.getRoomCode());
+        lqw.like(StringUtils.isNotBlank(bo.getRoomName()), KfLockPower::getRoomName, bo.getRoomName());
+        lqw.eq(bo.getPower() != null, KfLockPower::getPower, bo.getPower());
+        lqw.eq(bo.getRepairUserId() != null, KfLockPower::getRepairUserId, bo.getRepairUserId());
+        lqw.like(StringUtils.isNotBlank(bo.getRepairUserName()), KfLockPower::getRepairUserName, bo.getRepairUserName());
+        lqw.eq(StringUtils.isNotBlank(bo.getRepairStatus()), KfLockPower::getRepairStatus, bo.getRepairStatus());
+        return lqw;
+    }
+
+    private QueryWrapper<KfLockPower> buildQueryWrapper(KfLockPowerBo bo,String tableAlias) {
+        QueryWrapper<KfLockPower> lqw = new QueryWrapper<>();
+        String columnPrefix = "";
+        if(StringUtils.isNotBlank(tableAlias)){
+            columnPrefix = tableAlias + ".";
+        }
+        lqw.eq(StringUtils.isNotBlank(bo.getRoomCode()), columnPrefix+"room_code", bo.getRoomCode());
+        lqw.like(StringUtils.isNotBlank(bo.getRoomName()), columnPrefix+"room_name", bo.getRoomName());
+        lqw.eq(bo.getPower() != null, columnPrefix+"power", bo.getPower());
+        lqw.eq(bo.getRepairUserId() != null, columnPrefix+"repair_user_id", bo.getRepairUserId());
+        lqw.like(StringUtils.isNotBlank(bo.getRepairUserName()), columnPrefix+"repair_user_name", bo.getRepairUserName());
+        lqw.eq(StringUtils.isNotBlank(bo.getRepairStatus()), columnPrefix+"repair_status", bo.getRepairStatus());
+        return lqw;
+    }
+
+    /**
+     * 新增门锁电量
+     *
+     * @param bo 门锁电量
+     * @return 是否新增成功
+     */
+    @Override
+    public Boolean insertByBo(KfLockPowerBo bo) {
+        KfLockPower add = MapstructUtils.convert(bo, KfLockPower.class);
+        validEntityBeforeSave(add);
+        boolean flag = baseMapper.insert(add) > 0;
+        if (flag) {
+            bo.setId(add.getId());
+        }
+        return flag;
+    }
+
+    /**
+     * 修改门锁电量
+     *
+     * @param bo 门锁电量
+     * @return 是否修改成功
+     */
+    @Override
+    public Boolean updateByBo(KfLockPowerBo bo) {
+        KfLockPower update = MapstructUtils.convert(bo, KfLockPower.class);
+        validEntityBeforeSave(update);
+        return baseMapper.updateById(update) > 0;
+    }
+
+    /**
+     * 保存前的数据校验
+     */
+    private void validEntityBeforeSave(KfLockPower entity){
+        //TODO 做一些数据校验,如唯一约束
+    }
+
+    /**
+     * 校验并批量删除门锁电量信息
+     *
+     * @param ids     待删除的主键集合
+     * @param isValid 是否进行有效性校验
+     * @return 是否删除成功
+     */
+    @Override
+    public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
+        if(isValid){
+            //TODO 做一些业务上的校验,判断是否需要校验
+        }
+        return baseMapper.deleteByIds(ids) > 0;
+    }
+}

+ 158 - 0
ruoyi-modules/ruoyi-hotel/src/main/java/org/dromara/hotel/service/impl/KfProvideCardHisServiceImpl.java

@@ -0,0 +1,158 @@
+package org.dromara.hotel.service.impl;
+
+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.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import lombok.RequiredArgsConstructor;
+import org.springframework.stereotype.Service;
+import org.dromara.hotel.domain.bo.KfProvideCardHisBo;
+import org.dromara.hotel.domain.vo.KfProvideCardHisVo;
+import org.dromara.hotel.domain.KfProvideCardHis;
+import org.dromara.hotel.mapper.KfProvideCardHisMapper;
+import org.dromara.hotel.service.IKfProvideCardHisService;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Collection;
+
+/**
+ * 发卡记录Service业务层处理
+ *
+ * @author LionLi
+ * @date 2024-12-03
+ */
+@RequiredArgsConstructor
+@Service
+public class KfProvideCardHisServiceImpl implements IKfProvideCardHisService {
+
+    private final KfProvideCardHisMapper baseMapper;
+
+    /**
+     * 查询发卡记录
+     *
+     * @param id 主键
+     * @return 发卡记录
+     */
+    @Override
+    public KfProvideCardHisVo queryById(Long id){
+        return baseMapper.selectVoById(id);
+    }
+
+    /**
+     * 分页查询发卡记录列表
+     *
+     * @param bo        查询条件
+     * @param pageQuery 分页参数
+     * @return 发卡记录分页列表
+     */
+    @Override
+    public TableDataInfo<KfProvideCardHisVo> queryPageList(KfProvideCardHisBo bo, PageQuery pageQuery) {
+        LambdaQueryWrapper<KfProvideCardHis> lqw = buildQueryWrapper(bo);
+        Page<KfProvideCardHisVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
+        return TableDataInfo.build(result);
+    }
+
+    /**
+     * 查询符合条件的发卡记录列表
+     *
+     * @param bo 查询条件
+     * @return 发卡记录列表
+     */
+    @Override
+    public List<KfProvideCardHisVo> queryList(KfProvideCardHisBo bo) {
+        LambdaQueryWrapper<KfProvideCardHis> lqw = buildQueryWrapper(bo);
+        return baseMapper.selectVoList(lqw);
+    }
+
+    private LambdaQueryWrapper<KfProvideCardHis> buildQueryWrapper(KfProvideCardHisBo bo) {
+        Map<String, Object> params = bo.getParams();
+        LambdaQueryWrapper<KfProvideCardHis> lqw = Wrappers.lambdaQuery();
+        lqw.eq(bo.getCardId() != null, KfProvideCardHis::getCardId, bo.getCardId());
+        lqw.eq(StringUtils.isNotBlank(bo.getFactoryId()), KfProvideCardHis::getFactoryId, bo.getFactoryId());
+        lqw.eq(StringUtils.isNotBlank(bo.getCardType()), KfProvideCardHis::getCardType, bo.getCardType());
+        lqw.eq(StringUtils.isNotBlank(bo.getRoomCode()), KfProvideCardHis::getRoomCode, bo.getRoomCode());
+        lqw.eq(bo.getMasterId() != null, KfProvideCardHis::getMasterId, bo.getMasterId());
+        lqw.like(StringUtils.isNotBlank(bo.getMasterName()), KfProvideCardHis::getMasterName, bo.getMasterName());
+        lqw.eq(bo.getStartTime() != null, KfProvideCardHis::getStartTime, bo.getStartTime());
+        lqw.eq(bo.getEndTime() != null, KfProvideCardHis::getEndTime, bo.getEndTime());
+        lqw.eq(bo.getCecycleTime() != null, KfProvideCardHis::getCecycleTime, bo.getCecycleTime());
+        lqw.eq(StringUtils.isNotBlank(bo.getCatdStatus()), KfProvideCardHis::getCatdStatus, bo.getCatdStatus());
+        return lqw;
+    }
+
+    private QueryWrapper<KfProvideCardHis> buildQueryWrapper(KfProvideCardHisBo bo,String tableAlias) {
+        QueryWrapper<KfProvideCardHis> lqw = new QueryWrapper<>();
+        String columnPrefix = "";
+        if(StringUtils.isNotBlank(tableAlias)){
+            columnPrefix = tableAlias + ".";
+        }
+        lqw.eq(bo.getCardId() != null, columnPrefix+"card_id", bo.getCardId());
+        lqw.eq(StringUtils.isNotBlank(bo.getFactoryId()), columnPrefix+"factory_id", bo.getFactoryId());
+        lqw.eq(StringUtils.isNotBlank(bo.getCardType()), columnPrefix+"card_type", bo.getCardType());
+        lqw.eq(StringUtils.isNotBlank(bo.getRoomCode()), columnPrefix+"room_code", bo.getRoomCode());
+        lqw.eq(bo.getMasterId() != null, columnPrefix+"master_id", bo.getMasterId());
+        lqw.like(StringUtils.isNotBlank(bo.getMasterName()), columnPrefix+"master_name", bo.getMasterName());
+        lqw.eq(bo.getStartTime() != null, columnPrefix+"start_time", bo.getStartTime());
+        lqw.eq(bo.getEndTime() != null, columnPrefix+"end_time", bo.getEndTime());
+        lqw.eq(bo.getCecycleTime() != null, columnPrefix+"cecycle_time", bo.getCecycleTime());
+        lqw.eq(StringUtils.isNotBlank(bo.getCatdStatus()), columnPrefix+"catd_status", bo.getCatdStatus());
+        return lqw;
+    }
+
+    /**
+     * 新增发卡记录
+     *
+     * @param bo 发卡记录
+     * @return 是否新增成功
+     */
+    @Override
+    public Boolean insertByBo(KfProvideCardHisBo bo) {
+        KfProvideCardHis add = MapstructUtils.convert(bo, KfProvideCardHis.class);
+        validEntityBeforeSave(add);
+        boolean flag = baseMapper.insert(add) > 0;
+        if (flag) {
+            bo.setId(add.getId());
+        }
+        return flag;
+    }
+
+    /**
+     * 修改发卡记录
+     *
+     * @param bo 发卡记录
+     * @return 是否修改成功
+     */
+    @Override
+    public Boolean updateByBo(KfProvideCardHisBo bo) {
+        KfProvideCardHis update = MapstructUtils.convert(bo, KfProvideCardHis.class);
+        validEntityBeforeSave(update);
+        return baseMapper.updateById(update) > 0;
+    }
+
+    /**
+     * 保存前的数据校验
+     */
+    private void validEntityBeforeSave(KfProvideCardHis entity){
+        //TODO 做一些数据校验,如唯一约束
+    }
+
+    /**
+     * 校验并批量删除发卡记录信息
+     *
+     * @param ids     待删除的主键集合
+     * @param isValid 是否进行有效性校验
+     * @return 是否删除成功
+     */
+    @Override
+    public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
+        if(isValid){
+            //TODO 做一些业务上的校验,判断是否需要校验
+        }
+        return baseMapper.deleteByIds(ids) > 0;
+    }
+}

+ 23 - 0
ruoyi-modules/ruoyi-hotel/src/main/resources/mapper/hotel/basics/KfLockPowerMapper.xml

@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8" ?>
+<!DOCTYPE mapper
+PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
+"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="org.dromara.hotel.mapper.KfLockPowerMapper">
+
+    <resultMap type="org.dromara.hotel.domain.KfLockPower" id="KfLockPowerResult">
+            <result property="id"    column="id"    />
+            <result property="roomCode"    column="room_code"    />
+            <result property="roomName"    column="room_name"    />
+            <result property="power"    column="power"    />
+            <result property="repairUserId"    column="repair_user_id"    />
+            <result property="repairUserName"    column="repair_user_name"    />
+            <result property="repairStatus"    column="repair_status"    />
+            <result property="createBy"    column="create_by"    />
+            <result property="createTime"    column="create_time"    />
+            <result property="updateBy"    column="update_by"    />
+            <result property="updateTime"    column="update_time"    />
+            <result property="createDept"    column="create_dept"    />
+            <result property="tenantId"    column="tenant_id"    />
+            <result property="delFlag"    column="del_flag"    />
+    </resultMap>
+</mapper>

+ 28 - 0
ruoyi-modules/ruoyi-hotel/src/main/resources/mapper/hotel/basics/KfProvideCardHisMapper.xml

@@ -0,0 +1,28 @@
+<?xml version="1.0" encoding="UTF-8" ?>
+<!DOCTYPE mapper
+PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
+"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="org.dromara.hotel.mapper.KfProvideCardHisMapper">
+
+    <resultMap type="org.dromara.hotel.domain.KfProvideCardHis" id="KfProvideCardHisResult">
+            <result property="id"    column="id"    />
+            <result property="cardId"    column="card_id"    />
+            <result property="factoryId"    column="factory_id"    />
+            <result property="cardType"    column="card_type"    />
+            <result property="roomCode"    column="room_code"    />
+            <result property="masterId"    column="master_id"    />
+            <result property="masterName"    column="master_name"    />
+            <result property="startTime"    column="start_time"    />
+            <result property="endTime"    column="end_time"    />
+            <result property="cecycleTime"    column="cecycle_time"    />
+            <result property="catdStatus"    column="catd_status"    />
+            <result property="remark"    column="remark"    />
+            <result property="createBy"    column="create_by"    />
+            <result property="createTime"    column="create_time"    />
+            <result property="updateBy"    column="update_by"    />
+            <result property="updateTime"    column="update_time"    />
+            <result property="createDept"    column="create_dept"    />
+            <result property="tenantId"    column="tenant_id"    />
+            <result property="delFlag"    column="del_flag"    />
+    </resultMap>
+</mapper>