using LogLibrary.Log;
using Masuit.Tools;
using Newtonsoft.Json;
using WIDESEA_Common;
using WIDESEA_Core;
using WIDESEA_DTO;
using WIDESEA_DTO.MOM;
using WIDESEA_IStorageBasicService;
using WIDESEA_IStoragIntegrationServices;
using WIDESEA_Model.Models;
namespace WIDESEA_StoragIntegrationServices;
public class CellStateService : ICellStateService
{
private readonly LogFactory LogFactory = new LogFactory();
private readonly IBoxingInfoService _boxingInfoService;
public CellStateService(IBoxingInfoService boxingInfoService)
{
_boxingInfoService = boxingInfoService;
}
///
/// 单电芯属性获取
///
/// 电芯数据
///
public async Task GetCellStateAsync(CellStateDto input)
{
WebResponseContent content = new WebResponseContent();
try
{
input.SessionId = Guid.NewGuid().ToString();
input.Software = "陈化机";
input.EquipmentCode = "P1K10040";
input.EmployeeNo = "T00001";
input.RequestTime = TimeZoneInfo.ConvertTimeToUtc(DateTime.Now).ToString("yyyy-MM-ddTHH:mm:ss.fffZ");
var inputJson = input.ToDictionary();
var x = await HttpsClient.PostAsync("http://ts-momapp01:12020/api/MachineIntegration/CellState", inputJson);
if (x != null)
{
ResultCellState result = JsonConvert.DeserializeObject(x);
DtBoxingInfo boxingInfo = new DtBoxingInfo()
{
IsFull = true,
PalletCode = "",
};
var details = new List();
foreach (var item in result.SerialNos)
{
DtBoxingInfoDetail detail = new DtBoxingInfoDetail()
{
SerialNumber = item.SerialNo,
OrderNo = item.BindCode,
Status = item.SerialNoStatus,
};
details.Add(detail);
}
boxingInfo.BoxingInfoDetails = details;
var abc = await _boxingInfoService.AddBoxingInfoAsync(boxingInfo);
if (abc.Status)
return content.OK("组盘成功");
else
return content.Error("组盘失败");
}
LogFactory.GetLog("单电芯属性获取").Info(true, $"\r\r--------------------------------------");
LogFactory.GetLog("单电芯属性获取").Info(true, x);
}
catch (Exception err)
{
Console.WriteLine(err.Message.ToString());
LogFactory.GetLog("单电芯属性获取").Error(true, $"\r\r--------------------------------------");
LogFactory.GetLog("单电芯属性获取").Error(true, err.StackTrace);
}
return Task.FromResult(null);
}
///
/// 整盘电芯属性获取
///
/// 电芯数据
///
public async Task GetTrayCellStatusAsync(TrayCellsStatusDto input)
{
WebResponseContent content = new WebResponseContent();
try
{
input.SessionId = Guid.NewGuid().ToString();
input.Software = "陈化机";
input.EquipmentCode = "P1K10040";
input.EmployeeNo = "T00001";
input.RequestTime = TimeZoneInfo.ConvertTimeToUtc(DateTime.Now).ToString("yyyy-MM-ddTHH:mm:ss.fffZ");
var inputJson = input.ToDictionary();
var x = await HttpsClient.PostAsync("http://ts-momapp01:12020/api/MachineIntegration/TrayCellsStatus", inputJson);
if (x != null)
{
ResultTrayCellsStatus result = JsonConvert.DeserializeObject(x);
DtBoxingInfo boxingInfo = new DtBoxingInfo()
{
IsFull = true,
PalletCode = "",
};
var details = new List();
foreach (var item in result.SerialNos)
{
DtBoxingInfoDetail detail = new DtBoxingInfoDetail()
{
SerialNumber = item.SerialNo,
OrderNo = result.BindCode,
Status = item.SerialNoStatus,
BatchNo = item.PositionNo.ToString()
};
details.Add(detail);
}
boxingInfo.BoxingInfoDetails = details;
var abc = await _boxingInfoService.AddBoxingInfoAsync(boxingInfo);
if (abc.Status)
content.OK("组盘成功", result);
else
content.Error("组盘失败");
}
LogFactory.GetLog("整盘电芯属性获取").Info(true, $"\r\r--------------------------------------");
LogFactory.GetLog("整盘电芯属性获取").Info(true, x);
}
catch (Exception err)
{
Console.WriteLine(err.Message.ToString());
LogFactory.GetLog("整盘电芯属性获取").Error(true, $"\r\r--------------------------------------");
LogFactory.GetLog("整盘电芯属性获取").Error(true, err.StackTrace);
}
return content;
}
}