using System; using System.Collections.Generic; using System.Dynamic; using System.Linq; using System.Reactive; using System.Reflection; using System.Text; using System.Threading.Tasks; using Aop.Api.Domain; using Aspose.Cells.Drawing; using JNPF.Common.Core.Manager; using JNPF.Common.Dtos.VisualDev; using JNPF.Common.Enums; using JNPF.Common.Security; using JNPF.DependencyInjection; using JNPF.DynamicApiController; using JNPF.FriendlyException; using JNPF.Logging; using JNPF.Systems.Interfaces.System; using JNPF.TaskScheduler; using JNPF.TaskScheduler.Entitys.Dto.TaskScheduler; using JNPF.TaskScheduler.Entitys.Model; using JNPF.VisualDev; using JNPF.VisualDev.Entitys; using JNPF.VisualDev.Interfaces; using Mapster; using Microsoft.AspNetCore.Identity; using Microsoft.AspNetCore.Mvc; using Microsoft.CodeAnalysis.CSharp.Syntax; using SqlSugar; using Tnb.BasicData; using Tnb.BasicData.Entities; using Tnb.EquipMgr.Entities; using Tnb.EquipMgr.Entities.Dto; using Tnb.EquipMgr.Interfaces; namespace Tnb.EquipMgr { /// /// 模具保养规则定义服务 /// [ApiDescriptionSettings(Tag = ModuleConsts.Tag, Area = ModuleConsts.Area, Order = 700)] [Route("api/[area]/[controller]/[action]")] [OverideVisualDev(ModuleId)] public class ToolMoldMaintainRuleService : IOverideVisualDevService, IToolMoldMaintainRuleService, IDynamicApiController, ITransient { private const string ModuleId = "26164864904981"; private readonly ISqlSugarClient _db; private readonly IUserManager _userManager; private readonly IDictionaryDataService _dictionaryDataService; private readonly TimeTaskService _timeTaskService; private readonly IVisualDevService _visualDevService; private readonly IRunService _runService; public OverideVisualDevFunc OverideFuncs { get; } = new OverideVisualDevFunc(); public ToolMoldMaintainRuleService(ISqlSugarRepository repository, IUserManager userManager, IDictionaryDataService dictionaryDataService, TimeTaskService timeTaskService, IVisualDevService visualDevService, IRunService runService) { _db = repository.AsSugarClient(); _userManager = userManager; _dictionaryDataService = dictionaryDataService; _timeTaskService = timeTaskService; _visualDevService = visualDevService; _runService = runService; OverideFuncs.DeleteAsync = Delete; OverideFuncs.CreateAsync = Create; } private async Task Create(VisualDevModelDataCrInput input) { int cycle = int.Parse(input.data["cycle"].ToString()!); var startTime = TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(1970, 1, 1)).AddMilliseconds(long.Parse(input.data["startandend_date"].ToString()!)); ToolMoldMaintainRule toolMoldMaintainRule = new ToolMoldMaintainRule(); toolMoldMaintainRule.id = SnowflakeIdHelper.NextId(); toolMoldMaintainRule.mode = input.data["mode"].ToString(); toolMoldMaintainRule.cycle = cycle; toolMoldMaintainRule.startandend_date = startTime.ToString("yyyy-MM-dd HH:mm:ss"); toolMoldMaintainRule.create_id = _userManager.UserId; toolMoldMaintainRule.create_time=DateTime.Now; await _db.Insertable(toolMoldMaintainRule).ExecuteCommandAsync(); if (toolMoldMaintainRule.mode == "27118635748885") { string id = toolMoldMaintainRule.id; var comtentModel = new ContentModel(); comtentModel.cron = "0 0 9 "+ startTime.Day + "/"+ toolMoldMaintainRule.cycle + " * ?"; comtentModel.interfaceId = ""; comtentModel.interfaceName = ""; comtentModel.parameter = new List(); comtentModel.parameter!.Add(new InterfaceParameter() { field = "id", value = id, defaultValue = "" }); comtentModel.localHostTaskId = "MoldMaintainTask/CreateTask"; DateTimeOffset dateTimeOffset = new DateTimeOffset(startTime); comtentModel.startTime = dateTimeOffset.ToUnixTimeMilliseconds(); comtentModel.TenantId = _userManager?.TenantId!; comtentModel.TenantDbName = _userManager?.TenantDbName!; comtentModel.ConnectionConfig = _userManager?.ConnectionConfig!; comtentModel.Token = _userManager?.ToKen!; TimeTaskCrInput timeTaskCrInput = new TimeTaskCrInput() { enCode = DateTime.Now.ToString("yyyyMMddHHmmss"), fullName = "生成模具保养任务" + id, executeType = "3", executeContent = comtentModel.ToJsonString(), description = "", sortCode = 99, enabledMark = 1, }; await _timeTaskService.DeleteByName(timeTaskCrInput.fullName); await _timeTaskService.Create(timeTaskCrInput, false); } return await Task.FromResult(true); } private async Task Delete(string id) { var ToolMoldMaintainRule = await _db.Queryable().Where(p => p.id == id).FirstAsync(); var ToolMoldMaintainRuleRelations = await _db.Queryable().Where(p => p.rule_id == id).ToListAsync(); await _timeTaskService.DeleteByName("生成模具保养任务" + id); await _db.Ado.BeginTranAsync(); await _db.Deleteable(ToolMoldMaintainRule).ExecuteCommandAsync(); await _db.Deleteable(ToolMoldMaintainRuleRelations).ExecuteCommandAsync(); await _db.Ado.CommitTranAsync(); } /// /// 根据规则Id获取匹配的模具列表 /// /// 规则Id /// [HttpGet] public async Task GetListById([FromRoute] string ruleId) { var result = new List(); var list = await _db.Queryable().Where(it => it.rule_id == ruleId).ToListAsync(); if (list?.Count > 0) { var ids = list.Select(it => it.mold_id).ToList(); result = await _db.Queryable().Where(it => ids.Contains(it.id)) .Select(it => new MaintainRuleMoldListOutput { mold_id = it.id, item_group_id = list.First().item_group_id }, true) .Mapper ( it => it.item_group_name = _db.Queryable().First(x => x.id == list.First().item_group_id).name! ) .ToListAsync(); } return result; } /// /// 获取模具选择列表 /// /// [HttpGet] public async Task GetMoldRuleSelectorList() { return await _db.Queryable().Select(it => new MoldRuleSelectorListOutput { mold_id = it.id, }, true) .Mapper(it => { var itemGroupIds = _db.Queryable().Where(x => x.mold_id == it.mold_id).Select(x => x.item_group_id).Distinct().ToList(); it.groupItems = _db.Queryable().Where(x => itemGroupIds.Contains(x.id)).Select(x => new MaintainItemGroupItem { item_group_id = x.id, name = x.name }).ToList(); }) .ToListAsync(); } /// /// 关联模具 /// /// 关联模具输入参数 /// /// [HttpPost] public async Task RelevanceMold(RelevanceMoldInput input) { if (input == null) throw new ArgumentNullException(nameof(input)); await _db.Deleteable().Where(it => it.rule_id == input.rule_id).ExecuteCommandAsync(); if (input.rowIds?.Count > 0) { List entities = new(); foreach (var item in input.rowIds) { ToolMoldMaintainRuleRelation entity = new(); entity.id = SnowflakeIdHelper.NextId(); entity.rule_id = input.rule_id; entity.mold_id = item.mold_id; entity.item_group_id = item.group_id; entities.Add(entity); } var row = await _db.Insertable(entities).ExecuteCommandAsync(); if (row < 1) throw Oops.Oh(ErrorCode.COM1000); } } /// /// 删除模具信息 /// /// /// [HttpPost] public async Task DeleteMoldRelevance(RelevanceMoldInput input) { if (input.ids?.Count > 0) { var row = await _db.Deleteable().Where(it => it.rule_id == input.rule_id && input.ids.Contains(it.mold_id)).ExecuteCommandAsync(); if (row < 1) throw Oops.Oh(ErrorCode.COM1002); } } /// /// 生成模具保养计划 /// /// [HttpPost] public async Task GenMaintainPlan(MaintainPlanCrInput input) { if (input == null) throw new ArgumentNullException("input"); try { await _db.Ado.BeginTranAsync(); var maintainRules = await _db.Queryable().Where(it => input.ruleIds.Contains(it.id)).ToListAsync(); var ruleMoldRelations = await _db.Queryable().Where(it => input.ruleIds.Contains(it.rule_id)).ToListAsync(); if (ruleMoldRelations?.Count > 0) { List maintainPlans = new(); List maintainPlanRelations = new(); foreach (var mrr in ruleMoldRelations) { var rule = await _db.Queryable().FirstAsync(it => it.id == mrr.rule_id); if (rule != null && rule.cycle.HasValue && rule.cycle.Value > 0) { ToolMoldMaintainPlan maintainPlan = new(); maintainPlan.plan_code = $"JHDM{DateTime.Now:yyyyMMddmmss}"; maintainPlan.mode = rule.mode; maintainPlan.status = DictConst.UnMaintainStatusCode; maintainPlan.plan_start_date = DateTime.Now; maintainPlan.plan_end_date = DateTime.Now.AddDays(rule.cycle.Value); maintainPlan.create_id = _userManager.UserId; maintainPlan.create_time = DateTime.Now; maintainPlans.Add(maintainPlan); ToolMoldMaintainPlanRelation maintainPlanReation = new(); maintainPlanReation.maintain_plan_id = maintainPlan.id; maintainPlanReation.mold_id = mrr.mold_id; maintainPlanRelations.Add(maintainPlanReation); } } await _db.Insertable(maintainPlans).ExecuteCommandAsync(); await _db.Insertable(maintainPlanRelations).ExecuteCommandAsync(); await _db.Ado.CommitTranAsync(); } } catch (Exception ex) { Log.Error("生成保养计划失败", ex); await _db.Ado.RollbackTranAsync(); } } } }