SaveMattressExcutor.cs 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Diagnostics;
  5. using System.Linq;
  6. using System.Text;
  7. using DirectService.Tools;
  8. using JLHHJSvr.BLL;
  9. using JLHHJSvr.Com;
  10. using JLHHJSvr.Com.Model;
  11. using JLHHJSvr.Helper;
  12. using JLHHJSvr.LJException;
  13. using JLHHJSvr.Tools;
  14. using LJLib.DAL.SQL;
  15. using LJLib.Net.SPI.Server;
  16. namespace JLHHJSvr.Excutor
  17. {
  18. internal sealed class SaveMattressExcutor : ExcutorBase<SaveMattressRequest, SaveMattressResponse>
  19. {
  20. protected override void ExcuteInternal(SaveMattressRequest request, object state, SaveMattressResponse 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 = new SqlConnection(GlobalVar.ConnectionString))
  34. using (var cmd = con.CreateCommand())
  35. {
  36. con.Open();
  37. // 初始化属性
  38. AutoInit.AutoInitS(cmd, request.mattress);
  39. if(request.mattress.copy_id != null && request.mattress.copy_id > 0)
  40. {
  41. request.mattress.mattressid = 0;
  42. request.mattress.mattresscode = string.Empty;
  43. request.mattress.yw_flag = 0;
  44. request.mattress.yw_auditingrep = "";
  45. request.mattress.yw_auditingdate = null;
  46. request.mattress.js1_flag = 0;
  47. request.mattress.js1_auditingrep = "";
  48. request.mattress.js1_auditingdate = null;
  49. request.mattress.js2_flag = 0;
  50. request.mattress.js2_auditingrep = "";
  51. request.mattress.js2_auditingdate = null;
  52. request.mattress.xd_flag = 0;
  53. request.mattress.xd_auditingrep = "";
  54. request.mattress.xd_auditingdate = null;
  55. request.mattress.flag = 0;
  56. request.mattress.auditingrep = "";
  57. request.mattress.auditingdate = null;
  58. request.mattress.qr_auditingrep = "";
  59. request.mattress.qr_auditingdate = null;
  60. request.mattress.erp_mtrlid = 0;
  61. request.mattress.erp_mtrlcode = "";
  62. request.mattress.erp_piccode = "";
  63. request.mattress.erp_mtrlname = "";
  64. foreach (var mx in request.mattressMx)
  65. {
  66. mx.mattressid = 0;
  67. mx.mattressmxid = 0;
  68. }
  69. }
  70. else
  71. {
  72. #region 状态判断
  73. if (request.mattress.mattressid > 0) {
  74. var mattressInfo = new u_mattress() { mattressid = request.mattress.mattressid };
  75. if (DbSqlHelper.SelectOne(cmd, mattressInfo, "flag, xd_flag, yw_flag, mattresscode, parentid") == 1)
  76. {
  77. if (mattressInfo.xd_flag == 1)
  78. {
  79. rslt.ErrMsg = "床垫报价单【" + mattressInfo.mattresscode + "】已业务下单,不能修改";
  80. return;
  81. }
  82. }
  83. }
  84. if (request.subspecs.Count > 0)
  85. {
  86. foreach (var submx in request.subspecs)
  87. {
  88. var itemid = Convert.ToInt32(submx["mattressid"]);
  89. if (itemid == 0) continue;
  90. var mattressInfo = new u_mattress() { mattressid = itemid };
  91. if (DbSqlHelper.SelectOne(cmd, mattressInfo, "flag, xd_flag, yw_flag, mattresscode, parentid") == 1)
  92. {
  93. if (mattressInfo.xd_flag == 1)
  94. {
  95. rslt.ErrMsg = "副规格-床垫报价单【" + mattressInfo.mattresscode + "】已业务下单,不能修改";
  96. return;
  97. }
  98. }
  99. }
  100. }
  101. #endregion
  102. }
  103. foreach (var mx in request.mattressMx)
  104. {
  105. AutoInit.AutoInitS(cmd, mx);
  106. }
  107. using (cmd.Transaction = con.BeginTransaction())
  108. {
  109. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  110. var helperBednet = HelperBase.GetHelper<BedNetHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  111. try
  112. {
  113. rslt.mxmessage = new List<string>();
  114. rslt.mxmessage = toSaveMattress(cmd, request.mattress, request.mattressMx, request.extraProcesses, request.extraCosts, tokendata);
  115. rslt.mattressid = request.mattress.mattressid;
  116. rslt.mattresscode = request.mattress.mattresscode;
  117. var subspecsList = helper.GetMattressSubspecs(request.mattress.mattressid);
  118. if (subspecsList.Count > 0)
  119. {
  120. foreach (var submx in subspecsList)
  121. {
  122. // 删除副规格特殊工艺表
  123. cmd.CommandText = @"DELETE u_mattress_mx_extra WHERE mattressid = @mattressid";
  124. cmd.Parameters.Clear();
  125. cmd.Parameters.AddWithValue("@mattressid", submx.mattressid);
  126. cmd.ExecuteNonQuery();
  127. // 删除副规格明细
  128. cmd.CommandText = @"DELETE u_mattress_mx_mtrl WHERE mattressid = @mattressid";
  129. cmd.Parameters.Clear();
  130. cmd.Parameters.AddWithValue("@mattressid", submx.mattressid);
  131. cmd.ExecuteNonQuery();
  132. // 删除副规格
  133. cmd.CommandText = @"DELETE u_mattress WHERE mattressid = @mattressid";
  134. cmd.Parameters.Clear();
  135. cmd.Parameters.AddWithValue("@mattressid", submx.mattressid);
  136. cmd.ExecuteNonQuery();
  137. }
  138. }
  139. if (request.subspecs != null && request.subspecs.Count > 0)
  140. {
  141. // 排序:宽、长,从小到大
  142. var _subspecs = request.subspecs.OrderBy(o => o["mattress_width"]).ThenBy(o => o["mattress_length"]).ToList();
  143. // 副规格
  144. foreach (var submx in _subspecs)
  145. {
  146. var _mattress = ObjectHelper.DeepCopy(request.mattress);
  147. _mattress.parentid = request.mattress.mattressid;
  148. _mattress.createby = request.mattress.createby;
  149. _mattress.mattressid = 0;
  150. _mattress.mattresscode = "";
  151. _mattress.mattress_width = Convert.ToInt32(submx["mattress_width"]);
  152. _mattress.mattress_length = Convert.ToInt32(submx["mattress_length"]);
  153. _mattress.mattress_height = Convert.ToInt32(submx["mattress_height"]);
  154. _mattress.mattressrelcode = Convert.ToString(submx["mattressrelcode"]);
  155. _mattress.mattressname = Convert.ToString(submx["mattressname"]);
  156. if (submx.Value<int>("erp_mtrlid") > 0)
  157. {
  158. _mattress.erp_mtrlid = Convert.ToInt32(submx["erp_mtrlid"]);
  159. }
  160. if (!string.IsNullOrEmpty(submx.Value<string>("erp_mtrlcode")))
  161. {
  162. _mattress.erp_mtrlcode = Convert.ToString(submx["erp_mtrlcode"]);
  163. }
  164. var _mattressMx = new List<u_mattress_mx_mtrl>();
  165. if (request.mattressMx != null && request.mattressMx.Any())
  166. {
  167. var bednetIndex = 0; // 床网索引
  168. var ifSubspecsIndex = 0; // 垫层主副规格物料索引
  169. foreach (var itemMx in request.mattressMx)
  170. {
  171. var item = ObjectHelper.DeepCopy(itemMx);
  172. item.mattressid = _mattress.mattressid;
  173. item.mattressmxid = 0;
  174. item.message = "";
  175. #region 副规格床网自动匹配/新增逻辑
  176. if (item.formulatype == 99 && item.mtrlid > 0)
  177. {
  178. bednetIndex++;
  179. var oBednet = new u_bednet();
  180. var _bednet = helperBednet.GetBedNet(item.mtrlid.Value);
  181. var _bednetMx = helperBednet.GetBedNetMxList(item.mtrlid.Value);
  182. var _bednetSpring = helperBednet.GetBedNetSpringList(item.mtrlid.Value);
  183. _bednet.mattress_width = Convert.ToInt32(submx["mattress_width"]) - (request.mattress.mattress_width - _bednet.mattress_width);
  184. _bednet.mattress_length = Convert.ToInt32(submx["mattress_length"]) - (request.mattress.mattress_length - _bednet.mattress_length);
  185. var _spring_qty_width = Convert.ToInt32(submx["spring_qty_width_" + bednetIndex]);
  186. var _spring_qty_length = Convert.ToInt32(submx["spring_qty_length_" + bednetIndex]);
  187. var _bednet_fork_qty = _bednet.fork_qty;
  188. if (!string.IsNullOrEmpty(submx.Value<string>("bednet_fork_qty_" + bednetIndex)))
  189. {
  190. _bednet_fork_qty = Convert.ToInt32(submx["bednet_fork_qty_" + bednetIndex]);
  191. }
  192. if (_bednetMx.Count > 0)
  193. {
  194. cmd.CommandText = @"SELECT TOP 1 u_bednet.bednetid
  195. ,u_bednet_type.typename
  196. ,bednetcode
  197. ,mattress_width
  198. ,mattress_length
  199. ,mattress_height
  200. ,nottax_factory_cost
  201. FROM u_bednetmx
  202. INNER JOIN u_bednet on u_bednet.bednetid = u_bednetmx.bednetid
  203. INNER JOIN u_bednet_type on u_bednet_type.bednettypeid = u_bednet.bednettypeid
  204. WHERE u_bednet.bednettypeid = @bednettypeid
  205. AND u_bednet.mattress_width = @mattress_width
  206. AND u_bednet.mattress_length = @mattress_length
  207. AND u_bednet.if_doublenet = @if_doublenet
  208. AND u_bednet.if_doublespring = @if_doublespring
  209. AND u_bednet.snake_wire_diameter = @snake_wire_diameter
  210. AND u_bednet.if_rsorwa = @if_rsorwa
  211. AND u_bednet.if_sponge_drilling = @if_sponge_drilling
  212. AND u_bednet.ifsaleout = 0
  213. AND u_bednet.sponge_mtrlid = @sponge_mtrlid
  214. AND u_bednet.sponge_thickness = @sponge_thickness
  215. AND u_bednet.sponge_height = @sponge_height
  216. AND u_bednet.sponge_tc_mtrlid = @sponge_tc_mtrlid
  217. AND u_bednet.sponge_tc_thickness = @sponge_tc_thickness
  218. AND u_bednet.sponge_tc_height = @sponge_tc_height
  219. AND u_bednet.edge_mtrlid = @edge_mtrlid
  220. AND u_bednet.edge_height = @edge_height
  221. AND u_bednet.felt_mtrlid = @felt_mtrlid
  222. AND u_bednet.felt_qty = @felt_qty
  223. AND u_bednet.felt_x_mtrlid = @felt_x_mtrlid
  224. AND u_bednet.felt_x_qty = @felt_x_qty
  225. AND u_bednet.fork_qty = @fork_qty
  226. AND u_bednet.felt_dscrp = @felt_dscrp
  227. AND u_bednet.duo_qv_str = @duo_qv_str
  228. AND u_bednetmx.bednet_height = @bednet_height
  229. AND u_bednetmx.springid = @springid
  230. AND u_bednetmx.spring_qty_width = @spring_qty_width
  231. AND u_bednetmx.spring_qty_length = @spring_qty_length
  232. AND u_bednetmx.if_side_iron = @if_side_iron
  233. AND u_bednetmx.side_iron_qty = @side_iron_qty
  234. AND u_bednetmx.fabrics2_mtrlid = @fabrics2_mtrlid
  235. AND u_bednetmx.fabrics1_mtrlid = @fabrics1_mtrlid
  236. AND u_bednetmx.if_hard_around = @if_hard_around
  237. AND u_bednetmx.hard_around_springid = @hard_around_springid
  238. AND u_bednetmx.hard_around_row = @hard_around_row
  239. AND u_bednetmx.if_15strip = @if_15strip
  240. ";
  241. cmd.Parameters.Clear();
  242. cmd.Parameters.AddWithValue("@bednettypeid", _bednet.bednettypeid);
  243. cmd.Parameters.AddWithValue("@mattress_width", _bednet.mattress_width);
  244. cmd.Parameters.AddWithValue("@mattress_length", _bednet.mattress_length);
  245. cmd.Parameters.AddWithValue("@if_doublenet", _bednet.if_doublenet);
  246. cmd.Parameters.AddWithValue("@if_doublespring", _bednet.if_doublespring);
  247. cmd.Parameters.AddWithValue("@snake_wire_diameter", _bednet.snake_wire_diameter);
  248. cmd.Parameters.AddWithValue("@if_rsorwa", _bednet.if_rsorwa);
  249. cmd.Parameters.AddWithValue("@if_sponge_drilling", _bednet.if_sponge_drilling);
  250. cmd.Parameters.AddWithValue("@sponge_mtrlid", _bednet.sponge_mtrlid);
  251. cmd.Parameters.AddWithValue("@sponge_thickness", _bednet.sponge_thickness);
  252. cmd.Parameters.AddWithValue("@sponge_height", _bednet.sponge_height);
  253. cmd.Parameters.AddWithValue("@sponge_tc_mtrlid", _bednet.sponge_tc_mtrlid);
  254. cmd.Parameters.AddWithValue("@sponge_tc_thickness", _bednet.sponge_tc_thickness);
  255. cmd.Parameters.AddWithValue("@sponge_tc_height", _bednet.sponge_tc_height);
  256. cmd.Parameters.AddWithValue("@edge_mtrlid", _bednet.edge_mtrlid);
  257. cmd.Parameters.AddWithValue("@edge_height", _bednet.edge_height);
  258. cmd.Parameters.AddWithValue("@felt_mtrlid", _bednet.felt_mtrlid);
  259. cmd.Parameters.AddWithValue("@felt_qty", _bednet.felt_qty);
  260. cmd.Parameters.AddWithValue("@felt_x_mtrlid", _bednet.felt_x_mtrlid);
  261. cmd.Parameters.AddWithValue("@felt_x_qty", _bednet.felt_x_qty);
  262. cmd.Parameters.AddWithValue("@felt_dscrp", _bednet.felt_dscrp);
  263. cmd.Parameters.AddWithValue("@duo_qv_str", _bednet.duo_qv_str);
  264. cmd.Parameters.AddWithValue("@fork_qty", _bednet.iffork == 1 ? _bednet_fork_qty : 0);
  265. cmd.Parameters.AddWithValue("@bednet_height", _bednetMx[0].bednet_height);
  266. cmd.Parameters.AddWithValue("@springid", _bednetMx[0].springid);
  267. cmd.Parameters.AddWithValue("@spring_qty_width", _spring_qty_width);
  268. cmd.Parameters.AddWithValue("@spring_qty_length", _spring_qty_length);
  269. cmd.Parameters.AddWithValue("@if_side_iron", _bednetMx[0].if_side_iron);
  270. cmd.Parameters.AddWithValue("@side_iron_qty", _bednetMx[0].side_iron_qty);
  271. cmd.Parameters.AddWithValue("@fabrics2_mtrlid", _bednetMx[0].fabrics2_mtrlid);
  272. cmd.Parameters.AddWithValue("@fabrics1_mtrlid", _bednetMx[0].fabrics1_mtrlid);
  273. cmd.Parameters.AddWithValue("@if_hard_around", _bednetMx[0].if_hard_around);
  274. cmd.Parameters.AddWithValue("@hard_around_springid", _bednetMx[0].hard_around_springid);
  275. cmd.Parameters.AddWithValue("@hard_around_row", _bednetMx[0].hard_around_row);
  276. cmd.Parameters.AddWithValue("@if_15strip", _bednetMx[0].if_15strip);
  277. using (var reader = cmd.ExecuteReader())
  278. {
  279. if (reader.Read())
  280. {
  281. oBednet = new u_bednet() {
  282. bednetid = Convert.ToInt32(reader["bednetid"]),
  283. typename = Convert.ToString(reader["typename"]),
  284. bednetcode = Convert.ToString(reader["bednetcode"]),
  285. mattress_width = Convert.ToInt32(reader["mattress_width"]),
  286. mattress_length = Convert.ToInt32(reader["mattress_length"]),
  287. mattress_height = Convert.ToInt32(reader["mattress_height"]),
  288. nottax_factory_cost = Convert.ToDecimal(reader["nottax_factory_cost"])
  289. };
  290. }
  291. }
  292. }
  293. // 匹配失败,自动新建
  294. if (oBednet.bednetid == null)
  295. {
  296. oBednet = _bednet;
  297. _bednetMx[0].spring_qty_width = _spring_qty_width;
  298. _bednetMx[0].spring_qty_length = _spring_qty_length;
  299. oBednet.fork_qty = _bednet_fork_qty;
  300. oBednet.bednetid = 0;
  301. // 袋装网,多个分区时,重新分配弹簧
  302. helperBednet.GetSpringListQty(oBednet, _bednetMx[0], ref _bednetSpring);
  303. helperBednet.SaveBedNet(oBednet, _bednetMx, _bednetSpring);
  304. }
  305. var _mtrlname = oBednet.typename +
  306. " " +
  307. oBednet.bednetcode +
  308. " " +
  309. oBednet.mattress_width +
  310. "*" +
  311. oBednet.mattress_length +
  312. "*" +
  313. oBednet.mattress_height;
  314. item.mtrlid = oBednet.bednetid;
  315. item.mtrlname = _mtrlname;
  316. item.price = oBednet.nottax_factory_cost;
  317. item.qty = 1;
  318. }
  319. #endregion
  320. #region 垫层改动逻辑
  321. if (item.formulatype == 1 && item.mtrlid > 0 )
  322. {
  323. // 规格长/宽,按比例缩放
  324. if (item.mattress_width > 0)
  325. {
  326. item.mattress_width = (int)Math.Floor((decimal)item.mattress_width * (Convert.ToDecimal(submx["mattress_width"]) / (decimal)request.mattress.mattress_width));
  327. }
  328. if (item.mattress_length > 0)
  329. {
  330. item.mattress_length = (int)Math.Floor((decimal)item.mattress_length * (Convert.ToDecimal(submx["mattress_length"]) / (decimal)request.mattress.mattress_length));
  331. }
  332. // 副规格-垫层物料替换
  333. if (item.if_subspecs == 1)
  334. {
  335. ifSubspecsIndex++;
  336. item.mtrlid = Convert.ToInt32(submx["cushions_subspecs_" + ifSubspecsIndex]);
  337. }
  338. }
  339. #endregion
  340. _mattressMx.Add(item);
  341. }
  342. #region FEAT:内布套/顶部裥棉逻辑
  343. var butaoList = _mattressMx.Where(t => (t.formulatype == 101 || t.formulatype == 102 || t.formulatype == 103) && t.mtrlid > 0 && (t.mattress_width > 0 || t.mattress_length > 0));
  344. foreach(var itemMx in butaoList)
  345. {
  346. itemMx.mattress_width += _mattress.mattress_width - request.mattress.mattress_width;
  347. itemMx.mattress_length += _mattress.mattress_length - request.mattress.mattress_length;
  348. }
  349. #endregion
  350. }
  351. toSaveMattress(cmd, _mattress, _mattressMx, request.extraProcesses, request.extraCosts, tokendata);
  352. }
  353. }
  354. cmd.Transaction.Commit();
  355. }
  356. catch (Exception e)
  357. {
  358. cmd.Transaction.Rollback();
  359. rslt.ErrMsg = e.ToString();
  360. Trace.Write(e);
  361. }
  362. }
  363. }
  364. }
  365. public List<string> toSaveMattress(SqlCommand cmd, u_mattress mattress, List<u_mattress_mx_mtrl> mattressMx, List<u_mattress_mx_extra> extraProcesses, List<u_mattress_mx_extra> extraCosts, TokenData tokendata)
  366. {
  367. var helper = HelperBase.GetHelper<MattressHelper>(cmd, new HelperBase.Context() { tokendata = tokendata });
  368. List<string> message = new List<string>();
  369. helper.MattressCalculateCost(mattress, mattressMx, extraProcesses, extraCosts);
  370. var mxmessageList = mattressMx.Where(item => !string.IsNullOrEmpty(item.message)).ToList();
  371. if (mxmessageList.Any())
  372. {
  373. foreach (var mx in mxmessageList)
  374. {
  375. message.Add(mx.message);
  376. }
  377. }
  378. try
  379. {
  380. helper.SaveMattress(mattress, mattressMx, extraProcesses, extraCosts);
  381. if (mattress.copy_id != null && mattress.copy_id > 0)
  382. {
  383. helper.CopyMattressInterface(mattress.copy_id.Value, mattress.mattressid);
  384. }
  385. }
  386. catch (Exception e)
  387. {
  388. throw new LJCommonException(e.Message);
  389. }
  390. return message;
  391. }
  392. }
  393. }