ReCalculateNoAuditExcutor.cs 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Linq;
  5. using System.Text;
  6. using JLHHJSvr.BLL;
  7. using JLHHJSvr.Com;
  8. using JLHHJSvr.Com.Model;
  9. using JLHHJSvr.Helper;
  10. using JLHHJSvr.LJException;
  11. using JLHHJSvr.Tools;
  12. using LJLib.DAL.SQL;
  13. using LJLib.Net.SPI.Server;
  14. using LJLib.SQLEX;
  15. using static JLHHJSvr.Helper.CacheHelper;
  16. namespace JLHHJSvr.Excutor
  17. {
  18. internal sealed class ReCalculateNoAuditExcutor : ExcutorBase<ReCalculateNoAuditRequest, ReCalculateNoAuditResponse>
  19. {
  20. protected override void ExcuteInternal(ReCalculateNoAuditRequest request, object state, ReCalculateNoAuditResponse rslt)
  21. {
  22. var tokendata = BllHelper.GetToken(request.token);
  23. if (tokendata == null)
  24. {
  25. rslt.ErrMsg = "会话已经中断,请重新登录";
  26. return;
  27. }
  28. if (request.list == null)
  29. {
  30. rslt.ErrMsg = "提交缺少列表参数,请检查!";
  31. return;
  32. }
  33. if (!request.list.Any())
  34. {
  35. rslt.ErrMsg = "至少提交一条需要重算的记录";
  36. return;
  37. }
  38. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  39. using (var cmd = con.CreateCommand())
  40. {
  41. con.Open();
  42. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  43. foreach (var mattress in request.list)
  44. {
  45. DbSqlHelper.SelectOne(cmd, mattress, "flag,deptid");
  46. if (mattress.flag == 1) throw new LJCommonException("存在报价单已审核,不能重算!");
  47. if (mattress.deptid <= 0) throw new LJCommonException("存在报价单部门id错误,不能重算!");
  48. var dept = helper.Cache.GetData<u_dept,DeptMapping>(mattress.deptid.Value);
  49. if (dept.pricelistid <= 0) throw new LJCommonException("存在报价单部门pricelistid错误,不能重算!");
  50. }
  51. using (cmd.Transaction = con.BeginTransaction())
  52. {
  53. try
  54. {
  55. foreach(var mattress in request.list)
  56. {
  57. var mattress_temp = helper.GetMattress(mattress.mattressid);
  58. var mxList = helper.GetMattressMxMtrl(mattress.mattressid);
  59. var mxExtra1List = helper.GetMattressMxExtra(mattress.mattressid, 1);
  60. var mxExtra2List = helper.GetMattressMxExtra(mattress.mattressid, 2);
  61. var subspecsList = helper.GetMattressSubspecs(mattress.mattressid);
  62. helper.CalCulateFormula(mattress_temp, mxList, true, true, mxExtra1List, mxExtra2List);
  63. helper.MattressCalculateCost(mattress_temp, mxList, mxExtra1List, mxExtra2List);
  64. //helper.SaveMattress(mattress_temp, mxList, mxExtra1List, mxExtra2List);
  65. mattress_temp.mxList = mxList;
  66. mattress_temp.extraList = mxExtra1List;
  67. mattress_temp.extraCostList = mxExtra2List;
  68. helper.SaveMattressPro(mattress_temp,false,true);
  69. }
  70. cmd.Transaction.Commit();
  71. }
  72. catch (Exception e)
  73. {
  74. cmd.Transaction.Rollback();
  75. rslt.ErrMsg = e.Message;
  76. }
  77. }
  78. }
  79. }
  80. }
  81. }