diff --git a/njzscloud-common/njzscloud-common-sichen/src/main/java/com/njzscloud/common/sichen/support/TaskStore.java b/njzscloud-common/njzscloud-common-sichen/src/main/java/com/njzscloud/common/sichen/support/TaskStore.java index 9d5f44c..c6244c8 100644 --- a/njzscloud-common/njzscloud-common-sichen/src/main/java/com/njzscloud/common/sichen/support/TaskStore.java +++ b/njzscloud-common/njzscloud-common-sichen/src/main/java/com/njzscloud/common/sichen/support/TaskStore.java @@ -6,7 +6,8 @@ import cn.hutool.core.util.StrUtil; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.njzscloud.common.core.tuple.Tuple2; import com.njzscloud.common.core.utils.GroupUtil; -import com.njzscloud.common.sichen.*; +import com.njzscloud.common.sichen.SysTaskEntity; +import com.njzscloud.common.sichen.SysTaskService; import com.njzscloud.common.sichen.contant.ScheduleType; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; @@ -87,7 +88,7 @@ public class TaskStore implements BeanPostProcessor { if (StrUtil.isNotBlank(cron) || period > 0) { String memo_ = task.memo(); String memo = StrUtil.isBlank(memo_) ? clazz.getCanonicalName() + "#" + method.getName() : memo_; - String scheduleConf = cron != null ? cron : String.valueOf(period); + String scheduleConf = StrUtil.isNotBlank(cron) ? cron : String.valueOf(period); ScheduleType scheduleType = StrUtil.isNotBlank(cron) ? ScheduleType.Cron : ScheduleType.Fixed; tasks.add(new TaskInfo() .setId(IdUtil.getSnowflakeNextId()) diff --git a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/contant/TimeOutStatus.java b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/contant/TimeOutStatus.java new file mode 100644 index 0000000..752a212 --- /dev/null +++ b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/contant/TimeOutStatus.java @@ -0,0 +1,21 @@ +package com.njzscloud.supervisory.dispose.contant; + +import com.njzscloud.common.core.ienum.DictStr; +import lombok.Getter; +import lombok.RequiredArgsConstructor; + +/** + * 字典代码:time_out_status + * 字典名称:超时状态 + */ +@Getter +@RequiredArgsConstructor +public enum TimeOutStatus implements DictStr { + WeiChaoShi("WeiChaoShi", "未超时"), + YiChaoShi("YiChaoShi", "已超时"), + ; + + private final String val; + + private final String txt; +} diff --git a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/pojo/DisposeRecordEntity.java b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/pojo/DisposeRecordEntity.java index 6d44b07..8d47792 100644 --- a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/pojo/DisposeRecordEntity.java +++ b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/pojo/DisposeRecordEntity.java @@ -3,6 +3,7 @@ package com.njzscloud.supervisory.dispose.pojo; import com.baomidou.mybatisplus.annotation.*; import com.njzscloud.common.mp.support.handler.j.JsonTypeHandler; import com.njzscloud.supervisory.dispose.contant.GarbageCategory; +import com.njzscloud.supervisory.dispose.contant.TimeOutStatus; import lombok.Getter; import lombok.Setter; import lombok.ToString; @@ -84,6 +85,8 @@ public class DisposeRecordEntity { */ private String disposalSite; + private TimeOutStatus timeOutStatus; + private String dataSn; private String inFrontPhoto; private String inBodyPhoto; diff --git a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/service/DisposeRecordService.java b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/service/DisposeRecordService.java index 61d22af..9c32a96 100644 --- a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/service/DisposeRecordService.java +++ b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/dispose/service/DisposeRecordService.java @@ -5,7 +5,9 @@ import cn.hutool.core.date.DateUtil; import cn.hutool.core.map.MapUtil; import cn.hutool.core.util.StrUtil; import com.alibaba.excel.EasyExcel; +import com.baomidou.mybatisplus.core.metadata.OrderItem; import com.baomidou.mybatisplus.core.toolkit.Wrappers; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.IService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.njzscloud.common.core.ex.Exceptions; @@ -83,7 +85,12 @@ public class DisposeRecordService extends ServiceImpl paging(PageParam pageParam, DisposeRecordPagingParam disposeRecordPagingParam) { String keywords = disposeRecordPagingParam.getKeywords(); - return PageResult.of(this.page(pageParam.toPage(), Wrappers.lambdaQuery() + Page page = pageParam.toPage(); + page.addOrder( + new OrderItem().setColumn("time_out_status").setAsc(false), + new OrderItem().setColumn("id").setAsc(false) + ); + return PageResult.of(this.page(page, Wrappers.lambdaQuery() .and(StrUtil.isNotBlank(keywords), it -> it.like(DisposeRecordEntity::getOrigin, keywords) .or().like(DisposeRecordEntity::getClearingCompany, keywords) @@ -137,7 +144,42 @@ public class DisposeRecordService extends ServiceImplupdate() + .set("time_out_status", TimeOutStatus.YiChaoShi) + .leSql("create_time", "DATE_SUB(NOW(), INTERVAL 12 HOUR)") + .eq("time_out_status", TimeOutStatus.WeiChaoShi) + ); + log.info("超时警告任务执行结束:{}", update); + } +} diff --git a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/pojo/TempStoragePointEntity.java b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/pojo/TempStoragePointEntity.java index 3179387..084390a 100644 --- a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/pojo/TempStoragePointEntity.java +++ b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/pojo/TempStoragePointEntity.java @@ -54,6 +54,10 @@ public class TempStoragePointEntity { * 视频URL */ private String videoUrl; + /** + * 负责人 Id; sys_user.id + */ + private Long managerId; /** * 创建人 Id; sys_user.id diff --git a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/service/TempStoragePointService.java b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/service/TempStoragePointService.java index 9ac637e..ce80fe3 100644 --- a/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/service/TempStoragePointService.java +++ b/njzscloud-svr/src/main/java/com/njzscloud/supervisory/tsp/service/TempStoragePointService.java @@ -6,6 +6,8 @@ import com.baomidou.mybatisplus.extension.service.IService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.njzscloud.common.mp.support.PageParam; import com.njzscloud.common.mp.support.PageResult; +import com.njzscloud.common.security.support.UserDetail; +import com.njzscloud.common.security.util.SecurityUtil; import com.njzscloud.supervisory.tsp.contant.PointStatus; import com.njzscloud.supervisory.tsp.mapper.TempStoragePointMapper; import com.njzscloud.supervisory.tsp.pojo.TempStoragePointEntity; @@ -69,10 +71,19 @@ public class TempStoragePointService extends ServiceImpl paging(PageParam pageParam, TempStoragePointEntity tempStoragePointEntity) { + UserDetail userDetail = SecurityUtil.loginUser(); + boolean isAdmin = userDetail.getRoles().contains("admin"); + Long userId = userDetail.getUserId(); String pointName = tempStoragePointEntity.getPointName(); PointStatus status = tempStoragePointEntity.getStatus(); return PageResult.of(baseMapper.paging(pageParam.toPage(), Wrappers.query() - .like(StrUtil.isNotBlank(pointName), "point_name", pointName) + .eq(!isAdmin, "manager_id", userId) + .and(StrUtil.isNotBlank(pointName), it -> + it.like("point_name", pointName) + .or().like("street_name", pointName) + .or().like("microdistrict", pointName) + .or().like("property_management", pointName)) + .eq(status != null, "status", status) .eq("deleted", 0)) ); diff --git a/z-doc/zsy-recycling-supervision.pdma.json b/z-doc/zsy-recycling-supervision.pdma.json index 13f0b22..75cb3c4 100644 --- a/z-doc/zsy-recycling-supervision.pdma.json +++ b/z-doc/zsy-recycling-supervision.pdma.json @@ -4,7 +4,7 @@ "avatar": "", "version": "4.9.4", "createdTime": "2023-4-13 11:53:52", - "updatedTime": "2025-8-20 14:31:53", + "updatedTime": "2025-8-25 13:55:06", "dbConns": [], "profile": { "default": { @@ -9125,6 +9125,23 @@ "extProps": {}, "id": "DF246FD3-8E1E-470F-883C-E0AA51D0AF3A" }, + { + "defKey": "time_out_status", + "defName": "超时状态", + "comment": "", + "type": "VARCHAR", + "len": 32, + "scale": "", + "primaryKey": false, + "notNull": true, + "autoIncrement": false, + "defaultValue": "'WeiChaoShi'", + "hideInGraph": false, + "refDict": "", + "baseType": "AA07828C-4FCB-4EDA-9B51-53A3F264F231", + "extProps": {}, + "id": "4B715514-CEA9-411B-8598-C5D27D0EBD34" + }, { "defKey": "creator_id", "defName": "创建人 Id", @@ -9425,7 +9442,7 @@ "primaryKey": false, "notNull": true, "autoIncrement": false, - "defaultValue": "", + "defaultValue": "''", "hideInGraph": false, "refDict": "", "attr1": "", @@ -9565,7 +9582,7 @@ "primaryKey": false, "notNull": true, "autoIncrement": false, - "defaultValue": "", + "defaultValue": "''", "hideInGraph": false, "refDict": "", "attr1": "", @@ -9582,10 +9599,27 @@ "extProps": {}, "uiHint": "" }, + { + "defKey": "manager_id", + "defName": "负责人 Id", + "comment": "sys_user.id", + "type": "BIGINT", + "len": "", + "scale": "", + "primaryKey": false, + "notNull": false, + "autoIncrement": false, + "defaultValue": "", + "hideInGraph": false, + "refDict": "", + "baseType": "9B6B9E10-DB11-4409-878B-5868A19CD9B0", + "extProps": {}, + "id": "1D88A443-3429-4A8C-93D4-3BCC6C8827CD" + }, { "defKey": "creator_id", "defName": "创建人 Id", - "comment": " sys_user.id", + "comment": "sys_user.id", "type": "BIGINT", "len": "", "scale": "", @@ -9612,7 +9646,7 @@ { "defKey": "modifier_id", "defName": "修改人 Id", - "comment": " sys_user.id", + "comment": "sys_user.id", "type": "BIGINT", "len": "", "scale": "",