From 34922eb239109534679d35a75661d6e2a5603347 Mon Sep 17 00:00:00 2001
From: wankeda <Administrator@DESKTOP-HAU3ST3>
Date: 星期六, 27 十二月 2025 10:16:36 +0800
Subject: [PATCH] 成品库流程
---
WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs | 93 ++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 93 insertions(+), 0 deletions(-)
diff --git a/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs b/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs
index 85385df..3be55df 100644
--- a/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs
+++ b/WMS/WIDESEA_WMSServer/WIDESEA_Core/Helper/CodeAnalysisHelper.cs
@@ -112,6 +112,99 @@
}
/// <summary>
+ /// 瑙f瀽缂栫爜鎴愬璞¢泦
+ /// </summary>
+ /// <typeparam name="T">娉涘瀷</typeparam>
+ /// <param name="analysisCode">瑙勫垯缂栧彿</param>
+ /// <param name="code">闇�瑙f瀽鐨勫瓧绗︿覆</param>
+ /// <returns></returns>
+ public static T CodeAnalysisCP<T>(AnalysisCodeEnum analysisCode, string code)
+ {
+ Type type = typeof(T);
+ object? obj = Activator.CreateInstance(type);
+ if (obj == null)
+ throw new Exception("瀹炰緥鍖栧璞¢敊璇�");
+ T result = (T)obj;
+ try
+ {
+ AnalysisRuleAttribute? analysisRule = type.GetCustomAttribute<AnalysisRuleAttribute>();
+ if (analysisRule != null)
+ {
+ SqlSugarClient sugarClient = new SqlSugarClient(new ConnectionConfig
+ {
+ ConfigId = MainDb.CurrentDbConnId,
+ ConnectionString = DBContext.GetMainConnectionDb().Connection,
+ IsAutoCloseConnection = true,
+ DbType = MainDb.DbType,
+ });
+
+ dynamic ruleConfig = sugarClient.Queryable(MainDb.AnalysisRuleConfig, "x").Where(MainDb.AnalysisCode, "=", analysisCode.ToString()).First();
+ if (ruleConfig != null)
+ {
+ string format = ruleConfig.Format;
+ string splitStr = ruleConfig.SplitStr;
+ List<string> items = format.Split(splitStr).ToList();
+ List<string> codes = code.Split(splitStr).ToList();
+ if (items.Count == codes.Count)
+ {
+ PropertyInfo[] propertyInfos = type.GetProperties();
+ if (AnalysisRuleEnum.Split == analysisRule.AnalysisRule)
+ {
+ for (int i = 0; i < propertyInfos.Length; i++)
+ {
+ PropertyInfo propertyInfo = propertyInfos[i];
+ AnalysisItemRuleAttribute? analysisItemRule = propertyInfo.GetCustomAttribute<AnalysisItemRuleAttribute>();
+ if (analysisItemRule != null)
+ {
+ if (analysisItemRule.AnalysisFormaType == AnalysisFormatTypeEnum.BD)
+ {
+ propertyInfo.SetValue(result, code.ChangeType(propertyInfo.PropertyType));
+ }
+ else
+ {
+ int index = items.IndexOf($"[{analysisItemRule.AnalysisFormaType}]");
+ if (index != -1)
+ {
+ propertyInfo.SetValue(result, codes[index]);
+ }
+ else
+ {
+ string? codeItem = items.FirstOrDefault(x => x.Contains($"[{analysisItemRule.AnalysisFormaType}]"));
+ if (!string.IsNullOrEmpty(codeItem))
+ {
+ index = items.IndexOf(codeItem);
+ if (index != -1)
+ {
+ string value = codes[index];
+ string replaceStr = codeItem.Replace($"[{analysisItemRule.AnalysisFormaType}]", "");
+
+ propertyInfo.SetValue(result, value.Replace(replaceStr, "").ChangeType(propertyInfo.PropertyType));
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+ catch (Exception ex)
+ {
+ throw new Exception($"瑙f瀽閿欒,{ex.Message}");
+ }
+
+ (bool, string, object?) validateResult = ModelValidate.ValidateModelData(result, type);
+ if (!validateResult.Item1)
+ {
+ throw new Exception($"瑙f瀽閿欒,{validateResult.Item2}");
+ }
+
+ return result;
+ }
+
+ /// <summary>
/// 瑙f瀽缂栫爜鎴愬璞¢泦鍚�
/// </summary>
/// <typeparam name="T">娉涘瀷</typeparam>
--
Gitblit v1.9.3