From 34926dd5e73208dc933c791dc6093942b20ce6e1 Mon Sep 17 00:00:00 2001 From: zhoukeda <1315948824@qq.com> Date: Fri, 12 May 2023 17:25:34 +0800 Subject: [PATCH] =?UTF-8?q?=E5=8A=A0=E8=AE=BE=E5=A4=87=E7=9B=B8=E5=85=B3?= =?UTF-8?q?=E5=AE=9E=E4=BD=93=E7=B1=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Consts/SpotInsRecordExecutionStatus.cs | 23 +++ .../Entity/EqpEquipType.cs | 100 ++++++++++ .../Entity/EqpSpotInsRecordD.cs | 134 +++++++++++++ .../Entity/EqpSpotInsRecordH.cs | 135 +++++++++++++ .../Entity/EqpSpotInsTemEquipH.cs | 177 ++++++++++++++++++ .../IEquSpotInsTemEquipService.cs | 19 ++ .../Tnb.EquipMgr/EquSpotInsTemEquipService.cs | 70 +++++++ 7 files changed, 658 insertions(+) create mode 100644 EquipMgr/Tnb.EquipMgr.Entities/Consts/SpotInsRecordExecutionStatus.cs create mode 100644 EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpEquipType.cs create mode 100644 EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordD.cs create mode 100644 EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordH.cs create mode 100644 EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsTemEquipH.cs create mode 100644 EquipMgr/Tnb.EquipMgr.Interfaces/IEquSpotInsTemEquipService.cs create mode 100644 EquipMgr/Tnb.EquipMgr/EquSpotInsTemEquipService.cs diff --git a/EquipMgr/Tnb.EquipMgr.Entities/Consts/SpotInsRecordExecutionStatus.cs b/EquipMgr/Tnb.EquipMgr.Entities/Consts/SpotInsRecordExecutionStatus.cs new file mode 100644 index 00000000..f847477a --- /dev/null +++ b/EquipMgr/Tnb.EquipMgr.Entities/Consts/SpotInsRecordExecutionStatus.cs @@ -0,0 +1,23 @@ +namespace Tnb.EquipMgr +{ + /// + /// 点巡检记录执行状态 + /// + public static class SpotInsRecordExecutionStatus + { + /// + /// 待执行 + /// + public const string TOBEEXECUTED = "1"; + + /// + /// 待复核 + /// + public const string TOBECHECK = "1"; + + /// + /// 已完成 + /// + public const string COMPLETED = "1"; + } +} \ No newline at end of file diff --git a/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpEquipType.cs b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpEquipType.cs new file mode 100644 index 00000000..adc81cbb --- /dev/null +++ b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpEquipType.cs @@ -0,0 +1,100 @@ +using SqlSugar; +using Tnb.Common.Contracts; + +namespace Tnb.EquipMgr.Entities +{ + /// + ///设备类型 + /// + [SugarTable("eqp_equip_type")] + public partial class EqpEquipType : BaseEntity + { + public EqpEquipType() + { + } + + /// + /// Desc:修改时间 + /// Default: + /// Nullable:True + /// + public DateTime? modify_time { get; set; } + + /// + /// Desc:名称 + /// Default: + /// Nullable:False + /// + public string name { get; set; } + + /// + /// Desc:编码 + /// Default: + /// Nullable:False + /// + public string code { get; set; } + + /// + /// Desc:创建时间 + /// Default: + /// Nullable:True + /// + public DateTime? create_time { get; set; } + + /// + /// Desc:是否是特种设备0否1是 + /// Default: + /// Nullable:False + /// + public int is_special_equipment { get; set; } + + /// + /// Desc:排序 + /// Default: + /// Nullable:False + /// + public int ordinal { get; set; } + + /// + /// Desc:状态0 禁用 1 启用 + /// Default: + /// Nullable:False + /// + public int status { get; set; } + + /// + /// Desc:是否是实验设备0否1是 + /// Default: + /// Nullable:False + /// + public int is_lab { get; set; } + + /// + /// Desc:创建用户 + /// Default:NULL::character varying + /// Nullable:True + /// + public string create_id { get; set; } + + /// + /// Desc:修改用户 + /// Default:NULL::character varying + /// Nullable:True + /// + public string modify_id { get; set; } + + /// + /// Desc:备注 + /// Default:NULL::character varying + /// Nullable:True + /// + public string remark { get; set; } + + /// + /// Desc:所属组织 + /// Default:NULL::character varying + /// Nullable:True + /// + public string org_id { get; set; } + } +} \ No newline at end of file diff --git a/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordD.cs b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordD.cs new file mode 100644 index 00000000..7ac2a892 --- /dev/null +++ b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordD.cs @@ -0,0 +1,134 @@ +using SqlSugar; +using Tnb.Common.Contracts; + +namespace Tnb.EquipMgr.Entities; + +/// +///点巡检执行记录子表 +/// +[SugarTable("eqp_spot_ins_record_d")] +public partial class EqpSpotInsRecordD : BaseEntity +{ + public EqpSpotInsRecordD() + { + } + + /// + /// Desc:点巡检执行记录id + /// Default: + /// Nullable:False + /// + public string spot_ins_record_id { get; set; } + + /// + /// Desc:点巡检项id + /// Default: + /// Nullable:False + /// + public string spot_ins_item_id { get; set; } + + /// + /// Desc:判断类型 + /// Default: + /// Nullable:False + /// + public string judge_type { get; set; } + + /// + /// Desc:上限值 + /// Default: + /// Nullable:True + /// + public decimal? high_value { get; set; } + + /// + /// Desc:是否包含上限值 + /// Default: + /// Nullable:True + /// + public int? high_value_is_include { get; set; } + + /// + /// Desc:下限值 + /// Default: + /// Nullable:True + /// + public decimal? low_value { get; set; } + + /// + /// Desc:是否包含下限值 + /// Default: + /// Nullable:True + /// + public int? low_value_is_include { get; set; } + + /// + /// Desc:标准值 + /// Default: + /// Nullable:True + /// + public double? standard_value { get; set; } + + /// + /// Desc:单位id + /// Default: + /// Nullable:False + /// + public string unit_id { get; set; } + + /// + /// Desc:结果 1 通过 2 不通过 + /// Default: + /// Nullable:True + /// + public int? result { get; set; } + + /// + /// Desc:实际测量值 + /// Default: + /// Nullable:True + /// + public double? real_value { get; set; } + + /// + /// Desc:排序 + /// Default: + /// Nullable:False + /// + public long ordinal { get; set; } + + /// + /// Desc:编码 + /// Default:NULL::character varying + /// Nullable:True + /// + public string code { get; set; } + + /// + /// Desc:名称 + /// Default:NULL::character varying + /// Nullable:True + /// + public string name { get; set; } + + /// + /// Desc:判断内容 + /// Default:NULL::character varying + /// Nullable:True + /// + public string judge_content { get; set; } + + /// + /// Desc:点巡检方法 + /// Default:NULL::character varying + /// Nullable:True + /// + public string inspection_method { get; set; } + + /// + /// Desc:备注 + /// Default:NULL::character varying + /// Nullable:True + /// + public string remark { get; set; } +} \ No newline at end of file diff --git a/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordH.cs b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordH.cs new file mode 100644 index 00000000..94a35273 --- /dev/null +++ b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsRecordH.cs @@ -0,0 +1,135 @@ +using SqlSugar; +using Tnb.Common.Contracts; + +namespace Tnb.EquipMgr.Entities +{ + /// + ///点巡检执行记录表 + /// + [SugarTable("eqp_spot_ins_record_h")] + public partial class EqpSpotInsRecordH : BaseEntity + { + public EqpSpotInsRecordH() + { + } + + /// + /// Desc:创建时间 + /// Default: + /// Nullable:True + /// + public DateTime? create_time { get; set; } + + /// + /// Desc:修改时间 + /// Default: + /// Nullable:True + /// + public DateTime? modify_time { get; set; } + + /// + /// Desc:设备id + /// Default: + /// Nullable:False + /// + public string equip_id { get; set; } + + /// + /// Desc:点巡检设备模板id + /// Default: + /// Nullable:False + /// + public string spot_ins_tem_equip_id { get; set; } + + /// + /// Desc:结果1 合格2不合格 + /// Default: + /// Nullable:True + /// + public int? result { get; set; } + + /// + /// Desc:执行时间 + /// Default: + /// Nullable:True + /// + public DateTime? spot_record_date_time { get; set; } + + /// + /// Desc:不合格推送 + /// Default: + /// Nullable:True + /// + public int? is_send { get; set; } + + /// + /// Desc:推送时间 + /// Default: + /// Nullable:True + /// + public DateTime? send_date_time { get; set; } + + /// + /// Desc:滞后推送时间 + /// Default: + /// Nullable:True + /// + public DateTime? after_send_date_time { get; set; } + + /// + /// Desc:是否滞后推送 + /// Default: + /// Nullable:True + /// + public int? is_after_send { get; set; } + + /// + /// Desc:创建用户 + /// Default:NULL::character varying + /// Nullable:True + /// + public string create_id { get; set; } + + /// + /// Desc:修改用户 + /// Default:NULL::character varying + /// Nullable:True + /// + public string modify_id { get; set; } + + /// + /// Desc:点巡检结果备注 + /// Default:NULL::character varying + /// Nullable:True + /// + public string result_remark { get; set; } + + /// + /// Desc:状态 1待执行 2 待复核 3 已完成 + /// Default:NULL::character varying + /// Nullable:True + /// + public string status { get; set; } + + /// + /// Desc:执行人id + /// Default:NULL::character varying + /// Nullable:True + /// + public string spot_record_user_id { get; set; } + + /// + /// Desc:设备类型id + /// Default:NULL::character varying + /// Nullable:True + /// + public string equip_type_id { get; set; } + + /// + /// Desc:推送人id + /// Default:NULL::character varying + /// Nullable:True + /// + public string send_id { get; set; } + } +} \ No newline at end of file diff --git a/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsTemEquipH.cs b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsTemEquipH.cs new file mode 100644 index 00000000..e0d39d81 --- /dev/null +++ b/EquipMgr/Tnb.EquipMgr.Entities/Entity/EqpSpotInsTemEquipH.cs @@ -0,0 +1,177 @@ +using SqlSugar; +using Tnb.Common.Contracts; + +namespace Tnb.EquipMgr.Entities +{ + /// + ///点巡检设备模板表 + /// + [SugarTable("eqp_spot_ins_tem_equip_h")] + public partial class EqpSpotInsTemEquipH : BaseEntity + { + public EqpSpotInsTemEquipH() + { + } + + /// + /// Desc:创建时间 + /// Default: + /// Nullable:True + /// + public DateTime? create_time { get; set; } + + /// + /// Desc:修改时间 + /// Default: + /// Nullable:True + /// + public DateTime? modify_time { get; set; } + + /// + /// Desc:编码 + /// Default: + /// Nullable:False + /// + public string code { get; set; } + + /// + /// Desc:名称 + /// Default: + /// Nullable:False + /// + public string name { get; set; } + + /// + /// Desc:周期 + /// Default: + /// Nullable:False + /// + public decimal plan_cycle { get; set; } + + /// + /// Desc:周期方式 1 单次 2 循环 + /// Default: + /// Nullable:False + /// + public string plan_cycle_unit { get; set; } + + /// + /// Desc:计划执行通知提前量 + /// Default: + /// Nullable:True + /// + public int? plan_run_notice { get; set; } + + /// + /// Desc:创建用户 + /// Default:NULL::character varying + /// Nullable:True + /// + public string create_id { get; set; } + + /// + /// Desc:修改用户 + /// Default:NULL::character varying + /// Nullable:True + /// + public string modify_id { get; set; } + + /// + /// Desc:执行滞后推送时间 + /// Default: + /// Nullable:True + /// + public int? plan_delay { get; set; } + + /// + /// Desc:启用时间 + /// Default: + /// Nullable:False + /// + public DateTime start_time { get; set; } + + /// + /// Desc:是否启用 + /// Default: + /// Nullable:False + /// + public string is_start { get; set; } + + /// + /// Desc:是否复核 + /// Default: + /// Nullable:False + /// + public string is_repeat { get; set; } + + /// + /// Desc:不合格推送 0 不推送 1 推送 + /// Default: + /// Nullable:True + /// + public int? is_send { get; set; } + + /// + /// Desc:点巡检模板id + /// Default:NULL::character varying + /// Nullable:True + /// + public string spot_ins_tem_id { get; set; } + + /// + /// Desc:TODO + /// Default:NULL::character varying + /// Nullable:True + /// + public string equip_id { get; set; } + + /// + /// Desc:TODO + /// Default:NULL::character varying + /// Nullable:True + /// + public string remark { get; set; } + + /// + /// Desc:计划执行通知提前量单位 1 小时 2 天 3 周 + /// Default:NULL::character varying + /// Nullable:True + /// + public string plan_run_notice_unit { get; set; } + + /// + /// Desc:执行滞后推送时间单位 1 小时 2 天 3 周 + /// Default:NULL::character varying + /// Nullable:True + /// + public string plan_delay_unit { get; set; } + + /// + /// Desc:复核岗位id + /// Default:NULL::character varying + /// Nullable:True + /// + public string repeat_post_info_user_id { get; set; } + + /// + /// Desc:责任岗位id + /// Default:NULL::character varying + /// Nullable:True + /// + public string send_post_info_user_id { get; set; } + + /// + /// Desc:推送人id + /// Default:NULL::character varying + /// Nullable:True + /// + public string send_post_id { get; set; } + + /// + /// Desc:所属组织 + /// Default:NULL::character varying + /// Nullable:True + /// + public string org_id { get; set; } + } +} \ No newline at end of file diff --git a/EquipMgr/Tnb.EquipMgr.Interfaces/IEquSpotInsTemEquipService.cs b/EquipMgr/Tnb.EquipMgr.Interfaces/IEquSpotInsTemEquipService.cs new file mode 100644 index 00000000..48b4b400 --- /dev/null +++ b/EquipMgr/Tnb.EquipMgr.Interfaces/IEquSpotInsTemEquipService.cs @@ -0,0 +1,19 @@ +namespace Tnb.EquipMgr.Interfaces +{ + public interface IEquSpotInsTemEquipService + { + // /// + // /// 获取数 + // /// + // /// + // /// + // public Task GetTree(); + + /// + /// 停止计划 + /// + /// + /// + public Task Stop(Dictionary parameters); + } +} \ No newline at end of file diff --git a/EquipMgr/Tnb.EquipMgr/EquSpotInsTemEquipService.cs b/EquipMgr/Tnb.EquipMgr/EquSpotInsTemEquipService.cs new file mode 100644 index 00000000..f866e77c --- /dev/null +++ b/EquipMgr/Tnb.EquipMgr/EquSpotInsTemEquipService.cs @@ -0,0 +1,70 @@ +using JNPF.Common.Enums; +using JNPF.Common.Security; +using JNPF.DependencyInjection; +using JNPF.DynamicApiController; +using JNPF.FriendlyException; +using Microsoft.AspNetCore.Mvc; +using SqlSugar; +using Tnb.EquipMgr.Interfaces; +using Tnb.EquipMgr.Entities; + +namespace Tnb.EquipMgr +{ + /// + /// 设备管理 + /// + [ApiDescriptionSettings(Tag = ModuleConsts.Tag, Area = ModuleConsts.Area, Order = 700)] + [Route("api/[area]/[controller]/[action]")] + public class EquSpotInsTemEquipService : IEquSpotInsTemEquipService, IDynamicApiController, ITransient + { + private readonly ISqlSugarRepository _repository; + + public EquSpotInsTemEquipService(ISqlSugarRepository repository) + { + _repository = repository; + } + + // public async Task GetTree() + // { + // List eqpEquipments = + // var data = _repository.AsSugarClient().Queryable() + // .Where(x => x.status == 1) + // .Select((x) => new TreeModel + // { + // id = x.id, + // parentId = "-1", + // hasChildren = SqlFunc.Subqueryable().Where(y=>y.eqp_type_id==x.id).Any(), + // isLeaf = false, + // num = SqlFunc.Subqueryable().Where(y=>y.eqp_type_id==x.id).Count(), + // children = SqlFunc.Subqueryable().Where(y=>y.eqp_type_id==x.id).Select(y=>new TreeModel() + // { + // + // }).ToList(model => ), + // }); + // return new { list = 1 }; + // } + + public async Task Stop(Dictionary parameters) + { + string id = parameters["id"]; + DbResult result = await _repository.AsSugarClient().Ado.UseTranAsync(async () => + { + await _repository.UpdateAsync(x => new EqpSpotInsTemEquipH() + { + is_start = "0" + }, x => x.id == id); + List ids = await _repository.AsSugarClient().Queryable() + .Where(x => x.spot_ins_tem_equip_id == id && x.status == SpotInsRecordExecutionStatus.TOBEEXECUTED) + .Select(x => x.id).ToListAsync(); + await _repository.AsSugarClient().Deleteable() + .Where(x => x.spot_ins_tem_equip_id == id && x.status == SpotInsRecordExecutionStatus.TOBEEXECUTED).ExecuteCommandAsync(); + + await _repository.AsSugarClient().Deleteable() + .Where(x => ids.Contains(x.spot_ins_record_id)).ExecuteCommandAsync(); + + }); + + if(!result.IsSuccess) throw Oops.Oh(ErrorCode.COM1008); + } + } +} \ No newline at end of file