odf_new/server/ZR.Service/Business/OdfCheckinService.cs
zpc 7c4d7d5978 feat: ODF v1.0.2 功能更新 - 签到、干线故障、光缆管理、用户模块权限
数据库:
- 新增 odf_checkin/odf_cables/odf_cable_faults/odf_cable_fault_images/odf_user_modules 5张表
- 新增菜单权限和角色分配 SQL 脚本

后台 API (.NET/SqlSugar):
- 新增实体模型、DTO、Service、Controller (签到/光缆/故障/图片/用户模块)

前端 APP (UniApp):
- 新增 portal/checkin/trunk/cable/fault-list/fault-detail/fault-add/trunk-search/route-plan 9个页面
- 新增 permission/checkin/trunk 服务层
- 新增 navigation/watermark 工具函数

后台管理前端 (ZR.Vue):
- 新增光缆管理/干线故障管理/签到记录管理/用户模块权限 4个管理页面
- 新增对应 API 模块和表单组件
2026-03-04 14:08:48 +08:00

114 lines
3.9 KiB
C#

using Infrastructure.Attribute;
using ZR.Model;
using ZR.Model.Business;
using ZR.Model.Business.Dto;
using ZR.Model.System;
using ZR.Repository;
using ZR.Service.Business.IBusinessService;
namespace ZR.Service.Business
{
/// <summary>
/// 签到记录Service业务层处理
/// </summary>
[AppService(ServiceType = typeof(IOdfCheckinService), ServiceLifetime = LifeTime.Transient)]
public class OdfCheckinService : BaseService<OdfCheckin>, IOdfCheckinService
{
/// <summary>
/// 新增签到记录
/// </summary>
/// <param name="dto"></param>
/// <returns></returns>
public OdfCheckin AddCheckin(OdfCheckinDto dto)
{
// 校验 RoomId 存在
var room = Context.Queryable<OdfRooms>()
.Where(r => r.Id == dto.RoomId)
.First();
if (room == null)
{
throw new CustomException("机房不存在");
}
var model = new OdfCheckin
{
RoomId = dto.RoomId,
Personnel = dto.Personnel,
CheckinTime = DateTime.Parse(dto.CheckinTime),
WorkContent = dto.WorkContent,
UserId = dto.UserId,
CreatedAt = DateTime.Now
};
return Insertable(model).ExecuteReturnEntity();
}
/// <summary>
/// 分页查询签到记录(联查机房名称和提交人用户名)
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
public PagedInfo<OdfCheckinListDto> GetList(OdfCheckinQueryDto parm)
{
var predicate = QueryExp(parm);
var response = Queryable()
.Where(predicate.ToExpression())
.LeftJoin<OdfRooms>((it, r) => it.RoomId == r.Id)
.LeftJoin<SysUser>((it, r, u) => it.UserId == u.UserId)
.OrderByDescending((it, r, u) => it.CheckinTime)
.Select((it, r, u) => new OdfCheckinListDto()
{
RoomName = r.RoomName,
UserName = u.NickName
}, true)
.ToPage(parm);
return response;
}
/// <summary>
/// 导出签到记录
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
public PagedInfo<OdfCheckinListDto> ExportList(OdfCheckinQueryDto parm)
{
parm.PageNum = 1;
parm.PageSize = 100000;
var predicate = QueryExp(parm);
var response = Queryable()
.Where(predicate.ToExpression())
.LeftJoin<OdfRooms>((it, r) => it.RoomId == r.Id)
.LeftJoin<SysUser>((it, r, u) => it.UserId == u.UserId)
.OrderByDescending((it, r, u) => it.CheckinTime)
.Select((it, r, u) => new OdfCheckinListDto()
{
RoomName = r.RoomName,
UserName = u.NickName
}, true)
.ToPage(parm);
return response;
}
/// <summary>
/// 查询表达式
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
private static Expressionable<OdfCheckin> QueryExp(OdfCheckinQueryDto parm)
{
var predicate = Expressionable.Create<OdfCheckin>();
predicate = predicate.AndIF(parm.RoomId != null, it => it.RoomId == parm.RoomId);
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.Personnel), it => it.Personnel.Contains(parm.Personnel));
predicate = predicate.AndIF(parm.BeginCheckinTime != null, it => it.CheckinTime >= parm.BeginCheckinTime);
predicate = predicate.AndIF(parm.EndCheckinTime != null, it => it.CheckinTime <= parm.EndCheckinTime);
return predicate;
}
}
}