using LogLibrary.Log;
|
using Masuit.Tools;
|
using Newtonsoft.Json;
|
using WIDESEA_Common;
|
using WIDESEA_Core;
|
using WIDESEA_DTO;
|
using WIDESEA_IStorageBasicService;
|
using WIDESEA_IStoragIntegrationServices;
|
|
namespace WIDESEA_StoragIntegrationServices;
|
|
public class CellStateService : ICellStateService
|
{
|
private readonly LogFactory LogFactory = new LogFactory();
|
|
private readonly IBoxingInfoService _boxingInfoService;
|
|
public CellStateService(IBoxingInfoService boxingInfoService)
|
{
|
_boxingInfoService = boxingInfoService;
|
}
|
|
/// <summary>
|
/// 单电芯属性获取
|
/// </summary>
|
/// <param name="input">电芯数据</param>
|
/// <returns></returns>
|
public async Task<dynamic> GetCellStateAsync(CellStateDto input)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
input.SessionId = Guid.NewGuid().ToString();
|
input.EmployeeNo = "MITest";
|
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);
|
#region
|
//if (x != null)
|
//{
|
// ResultCellState result = JsonConvert.DeserializeObject<ResultCellState>(x);
|
// DtBoxingInfo boxingInfo = new DtBoxingInfo()
|
// {
|
// IsFull = true,
|
// PalletCode = "",
|
// };
|
// var details = new List<DtBoxingInfoDetail>();
|
// 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("组盘失败");
|
//}
|
#endregion
|
|
LogFactory.GetLog("单电芯属性获取").Info(true, $"\r\r--------------------------------------");
|
LogFactory.GetLog("单电芯属性获取").Info(true, x);
|
return x;
|
}
|
catch (Exception err)
|
{
|
Console.WriteLine(err.Message.ToString());
|
LogFactory.GetLog("单电芯属性获取").Error(true, $"\r\r--------------------------------------");
|
LogFactory.GetLog("单电芯属性获取").Error(true, $"请求参数: {JsonConvert.SerializeObject(input)}");
|
LogFactory.GetLog("单电芯属性获取").Error(true, err.Message);
|
LogFactory.GetLog("单电芯属性获取").Error(true, err.StackTrace);
|
}
|
return Task.FromResult<dynamic>(null);
|
}
|
|
/// <summary>
|
/// 整盘电芯属性获取
|
/// </summary>
|
/// <param name="input">电芯数据</param>
|
/// <returns></returns>
|
public async Task<WebResponseContent> GetTrayCellStatusAsync(TrayCellsStatusDto input)
|
{
|
WebResponseContent content = new WebResponseContent();
|
try
|
{
|
input.SessionId = Guid.NewGuid().ToString();
|
input.EmployeeNo = "MITest";
|
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对象
|
//ResultTrayCellsStatus result = JsonConvert.DeserializeObject<ResultTrayCellsStatus>(x);
|
|
//// 创建DtBoxingInfo对象
|
//DtBoxingInfo boxingInfo = new DtBoxingInfo
|
//{
|
// IsFull = true,
|
// PalletCode = result.TrayBarcode,
|
//};
|
|
//// 使用LINQ创建DtBoxingInfoDetail对象列表
|
//var details = result.SerialNos.Select(item => new DtBoxingInfoDetail
|
//{
|
// SerialNumber = item.SerialNo,
|
// OrderNo = item.PositionNo.ToString(),
|
// Status = item.SerialNoStatus,
|
// Remark = result.TrayBarcodePropertys.ToJsonString(),
|
// MaterielCode = result.BindCode,
|
//}).ToList();
|
|
//// 赋值DtBoxingInfoDetails
|
//boxingInfo.BoxingInfoDetails = details;
|
//var abc = await _boxingInfoService.AddBoxingInfoAsync(boxingInfo);
|
content.OK("组盘成功", x);
|
}
|
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, $"请求参数: {JsonConvert.SerializeObject(input)}");
|
LogFactory.GetLog("整盘电芯属性获取").Error(true, err.Message);
|
LogFactory.GetLog("整盘电芯属性获取").Error(true, err.StackTrace);
|
}
|
return content;
|
}
|
}
|