临时收纳点照片上传

master
lzq 2025-08-25 17:18:53 +08:00
parent a6e5c55109
commit 7f200a5758
8 changed files with 155 additions and 11 deletions

View File

@ -6,7 +6,8 @@ import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.njzscloud.common.core.tuple.Tuple2; import com.njzscloud.common.core.tuple.Tuple2;
import com.njzscloud.common.core.utils.GroupUtil; 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 com.njzscloud.common.sichen.contant.ScheduleType;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
@ -87,7 +88,7 @@ public class TaskStore implements BeanPostProcessor {
if (StrUtil.isNotBlank(cron) || period > 0) { if (StrUtil.isNotBlank(cron) || period > 0) {
String memo_ = task.memo(); String memo_ = task.memo();
String memo = StrUtil.isBlank(memo_) ? clazz.getCanonicalName() + "#" + method.getName() : 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; ScheduleType scheduleType = StrUtil.isNotBlank(cron) ? ScheduleType.Cron : ScheduleType.Fixed;
tasks.add(new TaskInfo() tasks.add(new TaskInfo()
.setId(IdUtil.getSnowflakeNextId()) .setId(IdUtil.getSnowflakeNextId())

View File

@ -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;
}

View File

@ -3,6 +3,7 @@ package com.njzscloud.supervisory.dispose.pojo;
import com.baomidou.mybatisplus.annotation.*; import com.baomidou.mybatisplus.annotation.*;
import com.njzscloud.common.mp.support.handler.j.JsonTypeHandler; import com.njzscloud.common.mp.support.handler.j.JsonTypeHandler;
import com.njzscloud.supervisory.dispose.contant.GarbageCategory; import com.njzscloud.supervisory.dispose.contant.GarbageCategory;
import com.njzscloud.supervisory.dispose.contant.TimeOutStatus;
import lombok.Getter; import lombok.Getter;
import lombok.Setter; import lombok.Setter;
import lombok.ToString; import lombok.ToString;
@ -84,6 +85,8 @@ public class DisposeRecordEntity {
*/ */
private String disposalSite; private String disposalSite;
private TimeOutStatus timeOutStatus;
private String dataSn; private String dataSn;
private String inFrontPhoto; private String inFrontPhoto;
private String inBodyPhoto; private String inBodyPhoto;

View File

@ -5,7 +5,9 @@ import cn.hutool.core.date.DateUtil;
import cn.hutool.core.map.MapUtil; import cn.hutool.core.map.MapUtil;
import cn.hutool.core.util.StrUtil; import cn.hutool.core.util.StrUtil;
import com.alibaba.excel.EasyExcel; import com.alibaba.excel.EasyExcel;
import com.baomidou.mybatisplus.core.metadata.OrderItem;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; 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.IService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.njzscloud.common.core.ex.Exceptions; import com.njzscloud.common.core.ex.Exceptions;
@ -83,7 +85,12 @@ public class DisposeRecordService extends ServiceImpl<DisposeRecordMapper, Dispo
*/ */
public PageResult<DisposeRecordEntity> paging(PageParam pageParam, DisposeRecordPagingParam disposeRecordPagingParam) { public PageResult<DisposeRecordEntity> paging(PageParam pageParam, DisposeRecordPagingParam disposeRecordPagingParam) {
String keywords = disposeRecordPagingParam.getKeywords(); String keywords = disposeRecordPagingParam.getKeywords();
return PageResult.of(this.page(pageParam.toPage(), Wrappers.<DisposeRecordEntity>lambdaQuery() Page<DisposeRecordEntity> 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.<DisposeRecordEntity>lambdaQuery()
.and(StrUtil.isNotBlank(keywords), it -> .and(StrUtil.isNotBlank(keywords), it ->
it.like(DisposeRecordEntity::getOrigin, keywords) it.like(DisposeRecordEntity::getOrigin, keywords)
.or().like(DisposeRecordEntity::getClearingCompany, keywords) .or().like(DisposeRecordEntity::getClearingCompany, keywords)
@ -137,7 +144,42 @@ public class DisposeRecordService extends ServiceImpl<DisposeRecordMapper, Dispo
} }
public void report(Integer action, DisposeRecordReportParam disposeRecordReportParam) { public void report(Integer action, DisposeRecordReportParam disposeRecordReportParam) {
if (action == 1) { switch (action) {
case 1: {
DisposeRecordEntity disposeRecordEntity = this.getOne(Wrappers.lambdaQuery(DisposeRecordEntity.class)
.eq(DisposeRecordEntity::getDataSn, disposeRecordReportParam.getTreatmentOrderNo())
);
if (disposeRecordEntity == null) {
this.save(resolveData(disposeRecordReportParam));
break;
}
}
case 2: {
DisposeRecordEntity disposeRecordEntity = this.getOne(Wrappers.lambdaQuery(DisposeRecordEntity.class)
.eq(DisposeRecordEntity::getDataSn, disposeRecordReportParam.getTreatmentOrderNo())
);
if (disposeRecordEntity != null) {
this.updateById(resolveData(disposeRecordReportParam).setId(disposeRecordEntity.getId()));
} else {
throw Exceptions.clierr("更新失败,数据不存在");
}
break;
}
case 3: {
DisposeRecordEntity disposeRecordEntity = this.getOne(Wrappers.lambdaQuery(DisposeRecordEntity.class)
.eq(DisposeRecordEntity::getDataSn, disposeRecordReportParam.getTreatmentOrderNo())
);
if (disposeRecordEntity != null) {
this.removeById(disposeRecordEntity.getId());
} else {
throw Exceptions.clierr("删除失败,数据不存在");
}
break;
}
default:
throw Exceptions.clierr("操作类型错误");
}
/* if (action == 1) {
DisposeRecordEntity disposeRecordEntity = this.getOne(Wrappers.lambdaQuery(DisposeRecordEntity.class) DisposeRecordEntity disposeRecordEntity = this.getOne(Wrappers.lambdaQuery(DisposeRecordEntity.class)
.eq(DisposeRecordEntity::getDataSn, disposeRecordReportParam.getTreatmentOrderNo()) .eq(DisposeRecordEntity::getDataSn, disposeRecordReportParam.getTreatmentOrderNo())
); );
@ -164,7 +206,7 @@ public class DisposeRecordService extends ServiceImpl<DisposeRecordMapper, Dispo
} else { } else {
throw Exceptions.clierr("删除失败,数据不存在"); throw Exceptions.clierr("删除失败,数据不存在");
} }
} } */
} }
private DisposeRecordEntity resolveData(DisposeRecordReportParam disposeRecordReportParam) { private DisposeRecordEntity resolveData(DisposeRecordReportParam disposeRecordReportParam) {

View File

@ -0,0 +1,28 @@
package com.njzscloud.supervisory.dispose.service;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.njzscloud.common.sichen.support.Task;
import com.njzscloud.supervisory.dispose.contant.TimeOutStatus;
import com.njzscloud.supervisory.dispose.pojo.DisposeRecordEntity;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
@Slf4j
@Component
@RequiredArgsConstructor
public class TaskService {
private final DisposeRecordService disposeRecordService;
@Task(period = 60)
public void earlyWarning() {
log.info("超时警告任务执行开始");
boolean update = disposeRecordService.update(Wrappers.<DisposeRecordEntity>update()
.set("time_out_status", TimeOutStatus.YiChaoShi)
.leSql("create_time", "DATE_SUB(NOW(), INTERVAL 12 HOUR)")
.eq("time_out_status", TimeOutStatus.WeiChaoShi)
);
log.info("超时警告任务执行结束:{}", update);
}
}

View File

@ -54,6 +54,10 @@ public class TempStoragePointEntity {
* URL * URL
*/ */
private String videoUrl; private String videoUrl;
/**
* Id; sys_user.id
*/
private Long managerId;
/** /**
* Id; sys_user.id * Id; sys_user.id

View File

@ -6,6 +6,8 @@ import com.baomidou.mybatisplus.extension.service.IService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.njzscloud.common.mp.support.PageParam; import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult; 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.contant.PointStatus;
import com.njzscloud.supervisory.tsp.mapper.TempStoragePointMapper; import com.njzscloud.supervisory.tsp.mapper.TempStoragePointMapper;
import com.njzscloud.supervisory.tsp.pojo.TempStoragePointEntity; import com.njzscloud.supervisory.tsp.pojo.TempStoragePointEntity;
@ -69,10 +71,19 @@ public class TempStoragePointService extends ServiceImpl<TempStoragePointMapper,
* @return PageResult&lt;TempStoragePointEntity&gt; * @return PageResult&lt;TempStoragePointEntity&gt;
*/ */
public PageResult<TempStoragePointEntity> paging(PageParam pageParam, TempStoragePointEntity tempStoragePointEntity) { public PageResult<TempStoragePointEntity> paging(PageParam pageParam, TempStoragePointEntity tempStoragePointEntity) {
UserDetail userDetail = SecurityUtil.loginUser();
boolean isAdmin = userDetail.getRoles().contains("admin");
Long userId = userDetail.getUserId();
String pointName = tempStoragePointEntity.getPointName(); String pointName = tempStoragePointEntity.getPointName();
PointStatus status = tempStoragePointEntity.getStatus(); PointStatus status = tempStoragePointEntity.getStatus();
return PageResult.of(baseMapper.paging(pageParam.toPage(), Wrappers.<TempStoragePointEntity>query() return PageResult.of(baseMapper.paging(pageParam.toPage(), Wrappers.<TempStoragePointEntity>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(status != null, "status", status)
.eq("deleted", 0)) .eq("deleted", 0))
); );

View File

@ -4,7 +4,7 @@
"avatar": "", "avatar": "",
"version": "4.9.4", "version": "4.9.4",
"createdTime": "2023-4-13 11:53:52", "createdTime": "2023-4-13 11:53:52",
"updatedTime": "2025-8-20 14:31:53", "updatedTime": "2025-8-25 13:55:06",
"dbConns": [], "dbConns": [],
"profile": { "profile": {
"default": { "default": {
@ -9125,6 +9125,23 @@
"extProps": {}, "extProps": {},
"id": "DF246FD3-8E1E-470F-883C-E0AA51D0AF3A" "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", "defKey": "creator_id",
"defName": "创建人 Id", "defName": "创建人 Id",
@ -9425,7 +9442,7 @@
"primaryKey": false, "primaryKey": false,
"notNull": true, "notNull": true,
"autoIncrement": false, "autoIncrement": false,
"defaultValue": "", "defaultValue": "''",
"hideInGraph": false, "hideInGraph": false,
"refDict": "", "refDict": "",
"attr1": "", "attr1": "",
@ -9565,7 +9582,7 @@
"primaryKey": false, "primaryKey": false,
"notNull": true, "notNull": true,
"autoIncrement": false, "autoIncrement": false,
"defaultValue": "", "defaultValue": "''",
"hideInGraph": false, "hideInGraph": false,
"refDict": "", "refDict": "",
"attr1": "", "attr1": "",
@ -9582,10 +9599,27 @@
"extProps": {}, "extProps": {},
"uiHint": "" "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", "defKey": "creator_id",
"defName": "创建人 Id", "defName": "创建人 Id",
"comment": " sys_user.id", "comment": "sys_user.id",
"type": "BIGINT", "type": "BIGINT",
"len": "", "len": "",
"scale": "", "scale": "",
@ -9612,7 +9646,7 @@
{ {
"defKey": "modifier_id", "defKey": "modifier_id",
"defName": "修改人 Id", "defName": "修改人 Id",
"comment": " sys_user.id", "comment": "sys_user.id",
"type": "BIGINT", "type": "BIGINT",
"len": "", "len": "",
"scale": "", "scale": "",