feat(ems): 添加告警、能耗记录和能源费率模块- 新增告警实体类 EmsAlert 及相关业务对象、控制器、映射器和服务实现

- 新增能耗记录实体类 EmsEnergyConsumption 及相关业务对象、控制器、映射器和服务实现
- 新增能源费率实体类 EmsEnergyRate 及相关业务对象、控制器、映射器和服务实现
- 实现各模块的基础 CRUD 功能,包括分页查询、导出 Excel 等操作
- 配置 MyBatis 映射文件及逻辑删除支持
This commit is contained in:
2025-09-28 09:54:42 +08:00
parent 32059525f0
commit 16776ffdc8
51 changed files with 3058 additions and 1 deletions

View File

@@ -0,0 +1,99 @@
package com.klp.ems.controller;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.ems.domain.vo.EmsAlertVo;
import com.klp.ems.domain.bo.EmsAlertBo;
import com.klp.ems.service.IEmsAlertService;
import com.klp.common.core.page.TableDataInfo;
/**
* 告警
*
* @author klp
* @date 2025-09-28
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/ems/alert")
public class EmsAlertController extends BaseController {
private final IEmsAlertService iEmsAlertService;
/**
* 查询告警列表
*/
@GetMapping("/list")
public TableDataInfo<EmsAlertVo> list(EmsAlertBo bo, PageQuery pageQuery) {
return iEmsAlertService.queryPageList(bo, pageQuery);
}
/**
* 导出告警列表
*/
@Log(title = "告警", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(EmsAlertBo bo, HttpServletResponse response) {
List<EmsAlertVo> list = iEmsAlertService.queryList(bo);
ExcelUtil.exportExcel(list, "告警", EmsAlertVo.class, response);
}
/**
* 获取告警详细信息
*
* @param alertId 主键
*/
@GetMapping("/{alertId}")
public R<EmsAlertVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long alertId) {
return R.ok(iEmsAlertService.queryById(alertId));
}
/**
* 新增告警
*/
@Log(title = "告警", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody EmsAlertBo bo) {
return toAjax(iEmsAlertService.insertByBo(bo));
}
/**
* 修改告警
*/
@Log(title = "告警", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody EmsAlertBo bo) {
return toAjax(iEmsAlertService.updateByBo(bo));
}
/**
* 删除告警
*
* @param alertIds 主键串
*/
@Log(title = "告警", businessType = BusinessType.DELETE)
@DeleteMapping("/{alertIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] alertIds) {
return toAjax(iEmsAlertService.deleteWithValidByIds(Arrays.asList(alertIds), true));
}
}

View File

@@ -0,0 +1,99 @@
package com.klp.ems.controller;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.ems.domain.vo.EmsEnergyConsumptionVo;
import com.klp.ems.domain.bo.EmsEnergyConsumptionBo;
import com.klp.ems.service.IEmsEnergyConsumptionService;
import com.klp.common.core.page.TableDataInfo;
/**
* 能耗记录
*
* @author Joshi
* @date 2025-09-28
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/ems/energyConsumption")
public class EmsEnergyConsumptionController extends BaseController {
private final IEmsEnergyConsumptionService iEmsEnergyConsumptionService;
/**
* 查询能耗记录列表
*/
@GetMapping("/list")
public TableDataInfo<EmsEnergyConsumptionVo> list(EmsEnergyConsumptionBo bo, PageQuery pageQuery) {
return iEmsEnergyConsumptionService.queryPageList(bo, pageQuery);
}
/**
* 导出能耗记录列表
*/
@Log(title = "能耗记录", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(EmsEnergyConsumptionBo bo, HttpServletResponse response) {
List<EmsEnergyConsumptionVo> list = iEmsEnergyConsumptionService.queryList(bo);
ExcelUtil.exportExcel(list, "能耗记录", EmsEnergyConsumptionVo.class, response);
}
/**
* 获取能耗记录详细信息
*
* @param energyConsumptionId 主键
*/
@GetMapping("/{energyConsumptionId}")
public R<EmsEnergyConsumptionVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long energyConsumptionId) {
return R.ok(iEmsEnergyConsumptionService.queryById(energyConsumptionId));
}
/**
* 新增能耗记录
*/
@Log(title = "能耗记录", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody EmsEnergyConsumptionBo bo) {
return toAjax(iEmsEnergyConsumptionService.insertByBo(bo));
}
/**
* 修改能耗记录
*/
@Log(title = "能耗记录", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody EmsEnergyConsumptionBo bo) {
return toAjax(iEmsEnergyConsumptionService.updateByBo(bo));
}
/**
* 删除能耗记录
*
* @param energyConsumptionIds 主键串
*/
@Log(title = "能耗记录", businessType = BusinessType.DELETE)
@DeleteMapping("/{energyConsumptionIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] energyConsumptionIds) {
return toAjax(iEmsEnergyConsumptionService.deleteWithValidByIds(Arrays.asList(energyConsumptionIds), true));
}
}

View File

@@ -0,0 +1,99 @@
package com.klp.ems.controller;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.ems.domain.vo.EmsEnergyRateVo;
import com.klp.ems.domain.bo.EmsEnergyRateBo;
import com.klp.ems.service.IEmsEnergyRateService;
import com.klp.common.core.page.TableDataInfo;
/**
* 能源费率currency 为 INT0=CNY,1=USD,2=EUR
*
* @author Joshi
* @date 2025-09-28
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/ems/energyRate")
public class EmsEnergyRateController extends BaseController {
private final IEmsEnergyRateService iEmsEnergyRateService;
/**
* 查询能源费率currency 为 INT0=CNY,1=USD,2=EUR列表
*/
@GetMapping("/list")
public TableDataInfo<EmsEnergyRateVo> list(EmsEnergyRateBo bo, PageQuery pageQuery) {
return iEmsEnergyRateService.queryPageList(bo, pageQuery);
}
/**
* 导出能源费率currency 为 INT0=CNY,1=USD,2=EUR列表
*/
@Log(title = "能源费率currency 为 INT0=CNY,1=USD,2=EUR", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(EmsEnergyRateBo bo, HttpServletResponse response) {
List<EmsEnergyRateVo> list = iEmsEnergyRateService.queryList(bo);
ExcelUtil.exportExcel(list, "能源费率currency 为 INT0=CNY,1=USD,2=EUR", EmsEnergyRateVo.class, response);
}
/**
* 获取能源费率currency 为 INT0=CNY,1=USD,2=EUR详细信息
*
* @param energyRateId 主键
*/
@GetMapping("/{energyRateId}")
public R<EmsEnergyRateVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long energyRateId) {
return R.ok(iEmsEnergyRateService.queryById(energyRateId));
}
/**
* 新增能源费率currency 为 INT0=CNY,1=USD,2=EUR
*/
@Log(title = "能源费率currency 为 INT0=CNY,1=USD,2=EUR", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody EmsEnergyRateBo bo) {
return toAjax(iEmsEnergyRateService.insertByBo(bo));
}
/**
* 修改能源费率currency 为 INT0=CNY,1=USD,2=EUR
*/
@Log(title = "能源费率currency 为 INT0=CNY,1=USD,2=EUR", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody EmsEnergyRateBo bo) {
return toAjax(iEmsEnergyRateService.updateByBo(bo));
}
/**
* 删除能源费率currency 为 INT0=CNY,1=USD,2=EUR
*
* @param energyRateIds 主键串
*/
@Log(title = "能源费率currency 为 INT0=CNY,1=USD,2=EUR", businessType = BusinessType.DELETE)
@DeleteMapping("/{energyRateIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] energyRateIds) {
return toAjax(iEmsEnergyRateService.deleteWithValidByIds(Arrays.asList(energyRateIds), true));
}
}

View File

@@ -0,0 +1,99 @@
package com.klp.ems.controller;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.ems.domain.vo.EmsEnergyTypeVo;
import com.klp.ems.domain.bo.EmsEnergyTypeBo;
import com.klp.ems.service.IEmsEnergyTypeService;
import com.klp.common.core.page.TableDataInfo;
/**
* 能源类型(阈值已移除)
*
* @author Joshi
* @date 2025-09-28
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/mes/energyType")
public class EmsEnergyTypeController extends BaseController {
private final IEmsEnergyTypeService iEmsEnergyTypeService;
/**
* 查询能源类型(阈值已移除)列表
*/
@GetMapping("/list")
public TableDataInfo<EmsEnergyTypeVo> list(EmsEnergyTypeBo bo, PageQuery pageQuery) {
return iEmsEnergyTypeService.queryPageList(bo, pageQuery);
}
/**
* 导出能源类型(阈值已移除)列表
*/
@Log(title = "能源类型(阈值已移除)", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(EmsEnergyTypeBo bo, HttpServletResponse response) {
List<EmsEnergyTypeVo> list = iEmsEnergyTypeService.queryList(bo);
ExcelUtil.exportExcel(list, "能源类型(阈值已移除)", EmsEnergyTypeVo.class, response);
}
/**
* 获取能源类型(阈值已移除)详细信息
*
* @param energyTypeId 主键
*/
@GetMapping("/{energyTypeId}")
public R<EmsEnergyTypeVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long energyTypeId) {
return R.ok(iEmsEnergyTypeService.queryById(energyTypeId));
}
/**
* 新增能源类型(阈值已移除)
*/
@Log(title = "能源类型(阈值已移除)", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody EmsEnergyTypeBo bo) {
return toAjax(iEmsEnergyTypeService.insertByBo(bo));
}
/**
* 修改能源类型(阈值已移除)
*/
@Log(title = "能源类型(阈值已移除)", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody EmsEnergyTypeBo bo) {
return toAjax(iEmsEnergyTypeService.updateByBo(bo));
}
/**
* 删除能源类型(阈值已移除)
*
* @param energyTypeIds 主键串
*/
@Log(title = "能源类型(阈值已移除)", businessType = BusinessType.DELETE)
@DeleteMapping("/{energyTypeIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] energyTypeIds) {
return toAjax(iEmsEnergyTypeService.deleteWithValidByIds(Arrays.asList(energyTypeIds), true));
}
}

View File

@@ -0,0 +1,99 @@
package com.klp.ems.controller;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.ems.domain.vo.EmsLocationVo;
import com.klp.ems.domain.bo.EmsLocationBo;
import com.klp.ems.service.IEmsLocationService;
import com.klp.common.core.page.TableDataInfo;
/**
* 位置
*
* @author Joshi
* @date 2025-09-28
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/mes/location")
public class EmsLocationController extends BaseController {
private final IEmsLocationService iEmsLocationService;
/**
* 查询位置列表
*/
@GetMapping("/list")
public TableDataInfo<EmsLocationVo> list(EmsLocationBo bo, PageQuery pageQuery) {
return iEmsLocationService.queryPageList(bo, pageQuery);
}
/**
* 导出位置列表
*/
@Log(title = "位置", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(EmsLocationBo bo, HttpServletResponse response) {
List<EmsLocationVo> list = iEmsLocationService.queryList(bo);
ExcelUtil.exportExcel(list, "位置", EmsLocationVo.class, response);
}
/**
* 获取位置详细信息
*
* @param locationId 主键
*/
@GetMapping("/{locationId}")
public R<EmsLocationVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long locationId) {
return R.ok(iEmsLocationService.queryById(locationId));
}
/**
* 新增位置
*/
@Log(title = "位置", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody EmsLocationBo bo) {
return toAjax(iEmsLocationService.insertByBo(bo));
}
/**
* 修改位置
*/
@Log(title = "位置", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody EmsLocationBo bo) {
return toAjax(iEmsLocationService.updateByBo(bo));
}
/**
* 删除位置
*
* @param locationIds 主键串
*/
@Log(title = "位置", businessType = BusinessType.DELETE)
@DeleteMapping("/{locationIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] locationIds) {
return toAjax(iEmsLocationService.deleteWithValidByIds(Arrays.asList(locationIds), true));
}
}

View File

@@ -0,0 +1,99 @@
package com.klp.ems.controller;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.ems.domain.vo.EmsMeterVo;
import com.klp.ems.domain.bo.EmsMeterBo;
import com.klp.ems.service.IEmsMeterService;
import com.klp.common.core.page.TableDataInfo;
/**
* 计量设备(阈值移至此处)
*
* @author Joshi
* @date 2025-09-28
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/mes/meter")
public class EmsMeterController extends BaseController {
private final IEmsMeterService iEmsMeterService;
/**
* 查询计量设备(阈值移至此处)列表
*/
@GetMapping("/list")
public TableDataInfo<EmsMeterVo> list(EmsMeterBo bo, PageQuery pageQuery) {
return iEmsMeterService.queryPageList(bo, pageQuery);
}
/**
* 导出计量设备(阈值移至此处)列表
*/
@Log(title = "计量设备(阈值移至此处)", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(EmsMeterBo bo, HttpServletResponse response) {
List<EmsMeterVo> list = iEmsMeterService.queryList(bo);
ExcelUtil.exportExcel(list, "计量设备(阈值移至此处)", EmsMeterVo.class, response);
}
/**
* 获取计量设备(阈值移至此处)详细信息
*
* @param meterId 主键
*/
@GetMapping("/{meterId}")
public R<EmsMeterVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long meterId) {
return R.ok(iEmsMeterService.queryById(meterId));
}
/**
* 新增计量设备(阈值移至此处)
*/
@Log(title = "计量设备(阈值移至此处)", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody EmsMeterBo bo) {
return toAjax(iEmsMeterService.insertByBo(bo));
}
/**
* 修改计量设备(阈值移至此处)
*/
@Log(title = "计量设备(阈值移至此处)", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody EmsMeterBo bo) {
return toAjax(iEmsMeterService.updateByBo(bo));
}
/**
* 删除计量设备(阈值移至此处)
*
* @param meterIds 主键串
*/
@Log(title = "计量设备(阈值移至此处)", businessType = BusinessType.DELETE)
@DeleteMapping("/{meterIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] meterIds) {
return toAjax(iEmsMeterService.deleteWithValidByIds(Arrays.asList(meterIds), true));
}
}