From f12b84be577b7b74544bfc63f079c330cf0c81d9 Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期三, 28 一月 2026 11:53:07 +0800
Subject: [PATCH] 安全生产--隐患排查上报
---
src/main/java/com/ruoyi/safe/service/impl/SafeHiddenFileServiceImpl.java | 20 ++
src/main/java/com/ruoyi/safe/controller/SafeHiddenController.java | 57 +++++
src/main/java/com/ruoyi/safe/pojo/SafeHidden.java | 110 +++++++++++
src/main/java/com/ruoyi/safe/controller/SafeHiddenFileController.java | 71 +++++++
src/main/java/com/ruoyi/safe/service/SafeHiddenFileService.java | 16 +
src/main/java/com/ruoyi/safe/mapper/SafeHiddenFileMapper.java | 18 +
src/main/java/com/ruoyi/safe/pojo/SafeHiddenFile.java | 57 +++++
src/main/java/com/ruoyi/safe/mapper/SafeHiddenMapper.java | 23 ++
src/main/java/com/ruoyi/safe/service/impl/SafeHiddenServiceImpl.java | 79 +++++++
src/main/java/com/ruoyi/safe/service/SafeHiddenService.java | 26 ++
src/main/resources/mapper/safe/SafeHiddenMapper.xml | 46 ++++
src/main/java/com/ruoyi/safe/pojo/SafeHazard.java | 7
src/main/java/com/ruoyi/safe/dto/SafeHiddenDto.java | 28 ++
src/main/resources/mapper/safe/SafeHiddenFileMapper.xml | 19 +
src/main/java/com/ruoyi/safe/controller/SafeCertificationFileController.java | 2
15 files changed, 578 insertions(+), 1 deletions(-)
diff --git a/src/main/java/com/ruoyi/safe/controller/SafeCertificationFileController.java b/src/main/java/com/ruoyi/safe/controller/SafeCertificationFileController.java
index 9c4a1a3..589f5b7 100644
--- a/src/main/java/com/ruoyi/safe/controller/SafeCertificationFileController.java
+++ b/src/main/java/com/ruoyi/safe/controller/SafeCertificationFileController.java
@@ -51,7 +51,7 @@
*/
@DeleteMapping("/del")
@ApiOperation("鍒犻櫎")
- public R delQualityUnqualified(@RequestBody List<Integer> ids) {
+ public R delSafeCertificationFile(@RequestBody List<Integer> ids) {
if(CollectionUtils.isEmpty(ids)){
return R.fail("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
}
diff --git a/src/main/java/com/ruoyi/safe/controller/SafeHiddenController.java b/src/main/java/com/ruoyi/safe/controller/SafeHiddenController.java
new file mode 100644
index 0000000..f8186ae
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/controller/SafeHiddenController.java
@@ -0,0 +1,57 @@
+package com.ruoyi.safe.controller;
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.web.domain.R;
+import com.ruoyi.safe.dto.SafeHiddenDto;
+import com.ruoyi.safe.pojo.SafeHazard;
+import com.ruoyi.safe.pojo.SafeHidden;
+import com.ruoyi.safe.service.SafeHazardService;
+import com.ruoyi.safe.service.SafeHiddenService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤 鍓嶇鎺у埗鍣�
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:10:54
+ */
+@RestController
+@RequestMapping("/safeHidden")
+@Api(tags = "瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤")
+public class SafeHiddenController {
+
+ @Autowired
+ private SafeHiddenService safeHiddenService;
+
+ @GetMapping("/page")
+ @ApiOperation("鍒嗛〉鏌ヨ")
+ public R page(Page page, SafeHiddenDto safeHiddenDto) {
+ return R.ok(safeHiddenService.pageSafeHidden(page, safeHiddenDto));
+ }
+
+ @ApiOperation("鏂板闅愭偅鎺掓煡")
+ @PostMapping()
+ public R add(@RequestBody SafeHidden safeHidden) {
+ return R.ok(safeHiddenService.add(safeHidden));
+ }
+
+ @ApiOperation("淇敼闅愭偅鎺掓煡(鏁存敼/楠屾敹)")
+ @PutMapping ()
+ public R update(@RequestBody SafeHidden safeHidden) {
+ return R.ok(safeHiddenService.updateById(safeHidden));
+ }
+
+ @ApiOperation("鍒犻櫎闅愭偅鎺掓煡")
+ @DeleteMapping("/{ids}")
+ public R delSafeHidden(@RequestBody List<Integer> ids) {
+ return R.ok(safeHiddenService.delSafeHidden(ids));
+ }
+
+}
diff --git a/src/main/java/com/ruoyi/safe/controller/SafeHiddenFileController.java b/src/main/java/com/ruoyi/safe/controller/SafeHiddenFileController.java
new file mode 100644
index 0000000..6d229c0
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/controller/SafeHiddenFileController.java
@@ -0,0 +1,71 @@
+package com.ruoyi.safe.controller;
+
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.framework.web.domain.R;
+import com.ruoyi.safe.pojo.SafeHiddenFile;
+import com.ruoyi.safe.service.SafeHiddenFileService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.util.CollectionUtils;
+import org.springframework.web.bind.annotation.*;
+
+import javax.annotation.Resource;
+import java.util.List;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤--闄勪欢 鍓嶇鎺у埗鍣�
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:50:05
+ */
+@RestController
+@RequestMapping("/safeHiddenFile")
+@Api(tags = "瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤--闄勪欢")
+public class SafeHiddenFileController {
+
+ @Resource
+ private SafeHiddenFileService safeHiddenFileService;
+
+
+ /**
+ * 鏂板
+ * @param safeHiddenFile
+ * @return
+ */
+ @PostMapping("/add")
+ @ApiOperation("鏂板")
+ public R add(@RequestBody SafeHiddenFile safeHiddenFile) {
+ return R.ok(safeHiddenFileService.save(safeHiddenFile));
+ }
+
+ /**
+ * 鍒犻櫎
+ * @param ids
+ * @return
+ */
+ @DeleteMapping("/del")
+ @ApiOperation("鍒犻櫎")
+ public R delSafeHiddenFile(@RequestBody List<Integer> ids) {
+ if(CollectionUtils.isEmpty(ids)){
+ return R.fail("璇烽�夋嫨鑷冲皯涓�鏉℃暟鎹�");
+ }
+ //鍒犻櫎妫�楠岄檮浠�
+ return R.ok(safeHiddenFileService.removeBatchByIds(ids));
+ }
+
+ /**
+ *鍒嗛〉鏌ヨ
+ * @param page
+ * @param safeHiddenFile
+ * @return
+ */
+ @GetMapping("/listPage")
+ @ApiOperation("鍒嗛〉鏌ヨ")
+ public R listPage(Page page, SafeHiddenFile safeHiddenFile) {
+ return R.ok(safeHiddenFileService.page(page, Wrappers.<SafeHiddenFile>lambdaQuery().eq(SafeHiddenFile::getSafeHiddenId,safeHiddenFile.getSafeHiddenId())));
+ }
+
+}
diff --git a/src/main/java/com/ruoyi/safe/dto/SafeHiddenDto.java b/src/main/java/com/ruoyi/safe/dto/SafeHiddenDto.java
new file mode 100644
index 0000000..fedb6a0
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/dto/SafeHiddenDto.java
@@ -0,0 +1,28 @@
+package com.ruoyi.safe.dto;
+
+import com.baomidou.mybatisplus.annotation.*;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.ruoyi.safe.pojo.SafeHidden;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.Getter;
+import lombok.Setter;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.io.Serializable;
+import java.time.LocalDate;
+import java.time.LocalDateTime;
+
+@Data
+public class SafeHiddenDto extends SafeHidden {
+
+ @ApiModelProperty("涓婃姤浜�")
+ private String createUserName;
+
+ @ApiModelProperty("鏁存敼璐d换浜�")
+ private String rectifyUserName;
+
+ @ApiModelProperty("楠屾敹浜�")
+ private String verifyUserName;
+}
diff --git a/src/main/java/com/ruoyi/safe/mapper/SafeHiddenFileMapper.java b/src/main/java/com/ruoyi/safe/mapper/SafeHiddenFileMapper.java
new file mode 100644
index 0000000..9b0051a
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/mapper/SafeHiddenFileMapper.java
@@ -0,0 +1,18 @@
+package com.ruoyi.safe.mapper;
+
+import com.ruoyi.safe.pojo.SafeHiddenFile;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤--闄勪欢 Mapper 鎺ュ彛
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:50:05
+ */
+@Mapper
+public interface SafeHiddenFileMapper extends BaseMapper<SafeHiddenFile> {
+
+}
diff --git a/src/main/java/com/ruoyi/safe/mapper/SafeHiddenMapper.java b/src/main/java/com/ruoyi/safe/mapper/SafeHiddenMapper.java
new file mode 100644
index 0000000..53b0384
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/mapper/SafeHiddenMapper.java
@@ -0,0 +1,23 @@
+package com.ruoyi.safe.mapper;
+
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.safe.dto.SafeHiddenDto;
+import com.ruoyi.safe.pojo.SafeHidden;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤 Mapper 鎺ュ彛
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:10:54
+ */
+@Mapper
+public interface SafeHiddenMapper extends BaseMapper<SafeHidden> {
+
+ IPage<SafeHiddenDto> pageSafeHidden(Page page, @Param("c") SafeHiddenDto safeHiddenDto);
+}
diff --git a/src/main/java/com/ruoyi/safe/pojo/SafeHazard.java b/src/main/java/com/ruoyi/safe/pojo/SafeHazard.java
index e900138..43e5c1e 100644
--- a/src/main/java/com/ruoyi/safe/pojo/SafeHazard.java
+++ b/src/main/java/com/ruoyi/safe/pojo/SafeHazard.java
@@ -8,10 +8,13 @@
import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Getter;
import lombok.Setter;
+import org.springframework.format.annotation.DateTimeFormat;
/**
* <p>
@@ -70,12 +73,16 @@
private String remark;
@TableField(fill = FieldFill.INSERT)
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime createTime;
@TableField(fill = FieldFill.INSERT)
private Integer createUser;
@TableField(fill = FieldFill.INSERT_UPDATE)
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime updateTime;
@TableField(fill = FieldFill.INSERT_UPDATE)
diff --git a/src/main/java/com/ruoyi/safe/pojo/SafeHidden.java b/src/main/java/com/ruoyi/safe/pojo/SafeHidden.java
new file mode 100644
index 0000000..ba64039
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/pojo/SafeHidden.java
@@ -0,0 +1,110 @@
+package com.ruoyi.safe.pojo;
+
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import java.io.Serializable;
+import java.time.LocalDate;
+import java.time.LocalDateTime;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Getter;
+import lombok.Setter;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import javax.validation.constraints.NotBlank;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:10:54
+ */
+@Getter
+@Setter
+@TableName("safe_hidden")
+@ApiModel(value = "SafeHidden瀵硅薄", description = "瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤")
+public class SafeHidden implements Serializable {
+
+ private static final long serialVersionUID = 1L;
+
+ @TableId(value = "id", type = IdType.AUTO)
+ private Integer id;
+
+ @ApiModelProperty("闅愭偅缂栧彿")
+ private String hiddenCode;
+
+ @ApiModelProperty("闅愭偅绫诲瀷")
+ private String type;
+
+ @ApiModelProperty("闅愭偅椋庨櫓绛夌骇")
+ private String riskLevel;
+
+ @ApiModelProperty("闅愭偅鍏蜂綋浣嶇疆")
+ private String location;
+
+ @ApiModelProperty("闅愭偅鎻忚堪")
+ private String hiddenDesc;
+
+ @ApiModelProperty("鏁存敼璐d换浜� ID")
+ @NotBlank(message = "鏁存敼璐d换浜轰笉鑳戒负绌�")
+ private Integer rectifyUserId;
+
+ @ApiModelProperty("鏁存敼浜鸿仈绯荤數璇�")
+ private String rectifyUserMobile;
+
+ @ApiModelProperty("鏁存敼瀹屾垚鏈熼檺(鏃ユ湡)")
+ @JsonFormat(pattern = "yyyy-MM-dd")
+ @DateTimeFormat(pattern = "yyyy-MM-dd")
+ @NotBlank(message = "鏁存敼瀹屾垚鏈熼檺涓嶈兘涓虹┖")
+ private LocalDate rectifyTime;
+
+ @ApiModelProperty("鏁存敼鍏蜂綋鎺柦")
+ private String rectifyMeasures;
+
+ @ApiModelProperty("瀹為檯鏁存敼瀹屾垚鏃堕棿")
+ @JsonFormat(pattern = "yyyy-MM-dd")
+ @DateTimeFormat(pattern = "yyyy-MM-dd")
+ private LocalDate rectifyActualTime;
+
+ @ApiModelProperty("楠屾敹浜� ID")
+ private Integer verifyUserId;
+
+ @ApiModelProperty("楠屾敹缁撴灉")
+ private String verifyResult;
+
+ @ApiModelProperty("楠屾敹鎰忚")
+ private String verifyRemark;
+
+ @ApiModelProperty("楠屾敹鏃堕棿")
+ @JsonFormat(pattern = "yyyy-MM-dd")
+ @DateTimeFormat(pattern = "yyyy-MM-dd")
+ private LocalDate verifyTime;
+
+ @ApiModelProperty("涓婃姤鏃堕棿")
+ @TableField(fill = FieldFill.INSERT)
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ private LocalDateTime createTime;
+
+ @ApiModelProperty("涓婃姤浜篿d")
+ @TableField(fill = FieldFill.INSERT)
+ private Integer createUser;
+
+ @TableField(fill = FieldFill.INSERT_UPDATE)
+ @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
+ private LocalDateTime updateTime;
+
+ @TableField(fill = FieldFill.INSERT_UPDATE)
+ private Integer updateUser;
+
+ @TableField(fill = FieldFill.INSERT)
+ private Integer tenantId;
+}
diff --git a/src/main/java/com/ruoyi/safe/pojo/SafeHiddenFile.java b/src/main/java/com/ruoyi/safe/pojo/SafeHiddenFile.java
new file mode 100644
index 0000000..59f67d1
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/pojo/SafeHiddenFile.java
@@ -0,0 +1,57 @@
+package com.ruoyi.safe.pojo;
+
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import java.io.Serializable;
+import java.time.LocalDateTime;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤--闄勪欢
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:50:05
+ */
+@Getter
+@Setter
+@TableName("safe_hidden_file")
+@ApiModel(value = "SafeHiddenFile瀵硅薄", description = "瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤--闄勪欢")
+public class SafeHiddenFile implements Serializable {
+
+ private static final long serialVersionUID = 1L;
+
+ @TableId(value = "id", type = IdType.AUTO)
+ private Integer id;
+
+ @ApiModelProperty("鍏宠仈闅愭偅鎺掓煡涓婃姤id")
+ private Integer safeHiddenId;
+
+ private String name;
+
+ private String url;
+
+ private Object fileSize;
+
+ @TableField(fill = FieldFill.INSERT)
+ private LocalDateTime createTime;
+
+ @TableField(fill = FieldFill.INSERT)
+ private Integer createUser;
+
+ @TableField(fill = FieldFill.INSERT_UPDATE)
+ private LocalDateTime updateTime;
+
+ @TableField(fill = FieldFill.INSERT_UPDATE)
+ private Integer updateUser;
+
+ @TableField(fill = FieldFill.INSERT)
+ private Integer tenantId;
+}
diff --git a/src/main/java/com/ruoyi/safe/service/SafeHiddenFileService.java b/src/main/java/com/ruoyi/safe/service/SafeHiddenFileService.java
new file mode 100644
index 0000000..a7daf46
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/service/SafeHiddenFileService.java
@@ -0,0 +1,16 @@
+package com.ruoyi.safe.service;
+
+import com.ruoyi.safe.pojo.SafeHiddenFile;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤--闄勪欢 鏈嶅姟绫�
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:50:05
+ */
+public interface SafeHiddenFileService extends IService<SafeHiddenFile> {
+
+}
diff --git a/src/main/java/com/ruoyi/safe/service/SafeHiddenService.java b/src/main/java/com/ruoyi/safe/service/SafeHiddenService.java
new file mode 100644
index 0000000..e240ec3
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/service/SafeHiddenService.java
@@ -0,0 +1,26 @@
+package com.ruoyi.safe.service;
+
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.safe.dto.SafeHiddenDto;
+import com.ruoyi.safe.pojo.SafeHidden;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+import java.util.List;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤 鏈嶅姟绫�
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:10:54
+ */
+public interface SafeHiddenService extends IService<SafeHidden> {
+
+ IPage<SafeHiddenDto> pageSafeHidden(Page page, SafeHiddenDto safeHiddenDto);
+
+ int add(SafeHidden safeHidden);
+
+ int delSafeHidden(List<Integer> ids);
+}
diff --git a/src/main/java/com/ruoyi/safe/service/impl/SafeHiddenFileServiceImpl.java b/src/main/java/com/ruoyi/safe/service/impl/SafeHiddenFileServiceImpl.java
new file mode 100644
index 0000000..9e21377
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/service/impl/SafeHiddenFileServiceImpl.java
@@ -0,0 +1,20 @@
+package com.ruoyi.safe.service.impl;
+
+import com.ruoyi.safe.pojo.SafeHiddenFile;
+import com.ruoyi.safe.mapper.SafeHiddenFileMapper;
+import com.ruoyi.safe.service.SafeHiddenFileService;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springframework.stereotype.Service;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤--闄勪欢 鏈嶅姟瀹炵幇绫�
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:50:05
+ */
+@Service
+public class SafeHiddenFileServiceImpl extends ServiceImpl<SafeHiddenFileMapper, SafeHiddenFile> implements SafeHiddenFileService {
+
+}
diff --git a/src/main/java/com/ruoyi/safe/service/impl/SafeHiddenServiceImpl.java b/src/main/java/com/ruoyi/safe/service/impl/SafeHiddenServiceImpl.java
new file mode 100644
index 0000000..993556e
--- /dev/null
+++ b/src/main/java/com/ruoyi/safe/service/impl/SafeHiddenServiceImpl.java
@@ -0,0 +1,79 @@
+package com.ruoyi.safe.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.project.system.domain.SysNotice;
+import com.ruoyi.project.system.mapper.SysNoticeMapper;
+import com.ruoyi.project.system.service.ISysNoticeService;
+import com.ruoyi.project.system.service.impl.SysNoticeServiceImpl;
+import com.ruoyi.safe.dto.SafeHiddenDto;
+import com.ruoyi.safe.pojo.SafeHidden;
+import com.ruoyi.safe.mapper.SafeHiddenMapper;
+import com.ruoyi.safe.service.SafeHiddenService;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.time.LocalDate;
+import java.time.format.DateTimeFormatter;
+import java.util.Arrays;
+import java.util.List;
+
+/**
+ * <p>
+ * 瀹夊叏鐢熶骇--闅愭偅鎺掓煡涓婃姤 鏈嶅姟瀹炵幇绫�
+ * </p>
+ *
+ * @author 鑺杞欢锛堟睙鑻忥級鏈夐檺鍏徃
+ * @since 2026-01-28 11:10:54
+ */
+@Service
+@Transactional(rollbackFor = Exception.class)
+public class SafeHiddenServiceImpl extends ServiceImpl<SafeHiddenMapper, SafeHidden> implements SafeHiddenService {
+
+ @Autowired
+ private SafeHiddenMapper safeHiddenMapper;
+ @Autowired
+ private ISysNoticeService sysNoticeService;
+
+
+ @Override
+ public IPage<SafeHiddenDto> pageSafeHidden(Page page, SafeHiddenDto safeHiddenDto) {
+ return safeHiddenMapper.pageSafeHidden(page, safeHiddenDto);
+ }
+
+ @Override
+ public int add(SafeHidden safeHidden) {
+ safeHiddenMapper.insert(safeHidden);
+ String datePrefix = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyyMMdd"));
+ String no = "YH" + String.format("%s%03d", datePrefix, safeHidden.getId());
+ safeHidden.setHiddenCode(no);
+ safeHiddenMapper.updateById(safeHidden);
+ //娑堟伅閫氱煡
+ sysNoticeService.simpleNoticeByUser("闅愭偅鎺掓煡涓婃姤鏁存敼",
+ "闅愭偅绫诲瀷锛�"+safeHidden.getType()+"\n"+
+ "闅愭偅椋庨櫓绛夌骇锛�"+safeHidden.getRiskLevel()+"\n"+
+ "闅愭偅鍏蜂綋浣嶇疆锛�"+safeHidden.getLocation()+"\n"+
+ "闅愭偅鎻忚堪锛�"+safeHidden.getHiddenDesc()+"\n"+
+ "鏁存敼瀹屾垚鏈熼檺(鏃ユ湡)锛�"+safeHidden.getRectifyTime(),
+ Arrays.asList(Long.valueOf(safeHidden.getRectifyUserId())),
+ "/collaborativeApproval/approvalProcess?id=" + safeHidden.getId());
+ return 0;
+ }
+
+ @Override
+ public int delSafeHidden(List<Integer> ids) {
+ List<SafeHidden> safeHiddens = safeHiddenMapper.selectBatchIds(ids);
+ for (SafeHidden safeHidden : safeHiddens) {
+ // 鍒犻櫎瀵瑰簲鐨勬秷鎭�氱煡
+ sysNoticeService.remove(new LambdaQueryWrapper<SysNotice>()
+ .eq(SysNotice::getNoticeTitle, "闅愭偅鎺掓煡涓婃姤鏁存敼")
+ .eq(SysNotice::getSenderId, safeHidden.getCreateUser())
+ .apply("CAST(notice_content AS CHAR) LIKE CONCAT('%', {0}, '%')", safeHidden.getId()));
+ }
+ safeHiddenMapper.deleteBatchIds(ids);
+ return 0;
+ }
+}
diff --git a/src/main/resources/mapper/safe/SafeHiddenFileMapper.xml b/src/main/resources/mapper/safe/SafeHiddenFileMapper.xml
new file mode 100644
index 0000000..47145c9
--- /dev/null
+++ b/src/main/resources/mapper/safe/SafeHiddenFileMapper.xml
@@ -0,0 +1,19 @@
+<?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="com.ruoyi.safe.mapper.SafeHiddenFileMapper">
+
+ <!-- 閫氱敤鏌ヨ鏄犲皠缁撴灉 -->
+ <resultMap id="BaseResultMap" type="com.ruoyi.safe.pojo.SafeHiddenFile">
+ <id column="id" property="id" />
+ <result column="safe_hidden_id" property="safeHiddenId" />
+ <result column="name" property="name" />
+ <result column="url" property="url" />
+ <result column="file_size" property="fileSize" />
+ <result column="create_time" property="createTime" />
+ <result column="create_user" property="createUser" />
+ <result column="update_time" property="updateTime" />
+ <result column="update_user" property="updateUser" />
+ <result column="tenant_id" property="tenantId" />
+ </resultMap>
+
+</mapper>
diff --git a/src/main/resources/mapper/safe/SafeHiddenMapper.xml b/src/main/resources/mapper/safe/SafeHiddenMapper.xml
new file mode 100644
index 0000000..c1af4bd
--- /dev/null
+++ b/src/main/resources/mapper/safe/SafeHiddenMapper.xml
@@ -0,0 +1,46 @@
+<?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="com.ruoyi.safe.mapper.SafeHiddenMapper">
+
+ <!-- 閫氱敤鏌ヨ鏄犲皠缁撴灉 -->
+ <resultMap id="BaseResultMap" type="com.ruoyi.safe.pojo.SafeHidden">
+ <id column="id" property="id" />
+ <result column="hidden_code" property="hiddenCode" />
+ <result column="type" property="type" />
+ <result column="risk_level" property="riskLevel" />
+ <result column="location" property="location" />
+ <result column="hidden_desc" property="hiddenDesc" />
+ <result column="rectify_user_id" property="rectifyUserId" />
+ <result column="rectify_user_mobile" property="rectifyUserMobile" />
+ <result column="rectify_time" property="rectifyTime" />
+ <result column="rectify_measures" property="rectifyMeasures" />
+ <result column="rectify_actual_time" property="rectifyActualTime" />
+ <result column="verify_user_id" property="verifyUserId" />
+ <result column="verify_result" property="verifyResult" />
+ <result column="verify_remark" property="verifyRemark" />
+ <result column="verify_time" property="verifyTime" />
+ <result column="create_time" property="createTime" />
+ <result column="create_user" property="createUser" />
+ <result column="update_time" property="updateTime" />
+ <result column="update_user" property="updateUser" />
+ <result column="tenant_id" property="tenantId" />
+ </resultMap>
+ <select id="pageSafeHidden" resultType="com.ruoyi.safe.dto.SafeHiddenDto">
+ select sh.*,
+ su1.nick_name createUserName,
+ su2.nick_name rectifyUserName,
+ su3.nick_name verifyUserName
+ from safe_hidden sh
+ left join sys_user su1 on sh.create_user = su1.user_id
+ left join sys_user su2 on sh.rectify_user_id = su2.user_id
+ left join sys_user su3 on sh.verify_user_id = su3.user_id
+ where 1=1
+ <if test="c.type != null and c.type != ''">
+ and sh.type like concat('%', #{c.type}, '%')
+ </if>
+ <if test="c.riskLevel != null and c.riskLevel != ''">
+ and sh.risk_level like concat('%', #{c.riskLevel}, '%')
+ </if>
+ </select>
+
+</mapper>
--
Gitblit v1.9.3