GetComputeMattressExcutor.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Linq;
  5. using System.Text;
  6. using DirectService.Tools;
  7. using JLHHJSvr.BLL;
  8. using JLHHJSvr.Com;
  9. using JLHHJSvr.Com.Model;
  10. using JLHHJSvr.Helper;
  11. using JLHHJSvr.LJException;
  12. using JLHHJSvr.Tools;
  13. using LJLib.DAL.SQL;
  14. using LJLib.Net.SPI.Server;
  15. using LJLib.SQLEX;
  16. namespace JLHHJSvr.Excutor
  17. {
  18. internal sealed class GetComputeMattressExcutor : ExcutorBase<GetComputeMattressRequest, GetComputeMattressResponse>
  19. {
  20. protected override void ExcuteInternal(GetComputeMattressRequest request, object state, GetComputeMattressResponse rslt)
  21. {
  22. var tokendata = BllHelper.GetToken(request.token);
  23. if (tokendata == null)
  24. {
  25. rslt.ErrMsg = "会话已经中断,请重新登录";
  26. return;
  27. }
  28. if (request.mattress == null)
  29. {
  30. rslt.ErrMsg = "缺少主表信息";
  31. return;
  32. }
  33. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  34. using (var cmd = con.CreateCommand())
  35. {
  36. con.Open();
  37. // 初始化属性
  38. AutoInit.AutoInitS(cmd, request.mattress);
  39. //foreach (var mx in request.mattressMx)
  40. //{
  41. // AutoInit.AutoInitS(cmd, mx);
  42. //}
  43. using (cmd.Transaction = con.BeginTransaction())
  44. {
  45. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  46. var helperOld = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  47. var mattressMx = helper.GetMattressMxMtrl(request.mattress.mattressid);
  48. if (request.mattress.copy_id != null && request.mattress.copy_id > 0)
  49. {
  50. request.mattress.mattressid = 0;
  51. request.mattress.mattresscode = string.Empty;
  52. foreach (var mx in mattressMx)
  53. {
  54. mx.mattressid = 0;
  55. mx.mattressmxid = 0;
  56. }
  57. }
  58. if (request.mattress.dannum_type.Value == 0)
  59. {
  60. request.mattress.dannum_type = 2; // 默认标准
  61. }
  62. try
  63. {
  64. var differArr = new List<u_mattress_computed>();
  65. for (var i = 1; i < 5; i++)
  66. {
  67. var differItem = new u_mattress_computed();
  68. differItem.type = i;
  69. var _mattress = ObjectHelper.DeepCopy(request.mattress);
  70. if (request.mattress.dannum_type.Value == i)
  71. {
  72. helper.CalCulateFormula(_mattress, mattressMx, false);
  73. rslt.replace = helper.Replacements;
  74. rslt.formulas = helper.FormulaReplacements;
  75. rslt.formulas_bednet = helper.BendetFormulasReplace;
  76. }
  77. else
  78. {
  79. _mattress.dannum_type = i;
  80. helper.CalCulateFormula(_mattress, mattressMx, false);
  81. }
  82. differItem.replace = helper.Replacements;
  83. differItem.replace_bednet = helper.BendetReplace;
  84. if (request.check_original == 1)
  85. {
  86. _mattress.dannum_type = i;
  87. helperOld.CalCulateFormula(_mattress, mattressMx, false, false);
  88. differItem.replace_origin = helperOld.Replacements;
  89. rslt.formulas_origin = helperOld.FormulaReplacements;
  90. }
  91. differArr.Add(differItem);
  92. }
  93. rslt.differ = differArr;
  94. //helper.CalCulateFormula(request.mattress, request.mattressMx, false);
  95. //rslt.replace = helper.Replacements;
  96. //rslt.formulas = helper.FormulaReplacements;
  97. }
  98. catch (Exception e)
  99. {
  100. rslt.message = e.Message;
  101. }
  102. }
  103. }
  104. }
  105. }
  106. }