dispatch.java 77 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210
  1. package restcontroller.webmanage.sale.dispatch;
  2. import beans.data.BatchDeleteErr;
  3. import beans.datacontrllog.DataContrlLog;
  4. import beans.dispatch.Dispatch;
  5. import beans.parameter.Parameter;
  6. import beans.remind.Remind;
  7. import beans.report.Report;
  8. import com.alibaba.fastjson.JSONArray;
  9. import com.alibaba.fastjson.JSONObject;
  10. import com.sun.codemodel.internal.JForEach;
  11. import common.Controller;
  12. import common.YosException;
  13. import common.annotation.API;
  14. import common.annotation.CACHEING;
  15. import common.annotation.CACHEING_CLEAN;
  16. import common.data.*;
  17. import org.apache.commons.lang.StringUtils;
  18. import org.apache.log4j.Logger;
  19. import restcontroller.R;
  20. import restcontroller.sale.cashbill.cashbill;
  21. import restcontroller.webmanage.executorService.Executor;
  22. import restcontroller.webmanage.sale.order.Order;
  23. import restcontroller.webmanage.sale.order.OrderItems;
  24. import sun.awt.AWTIcon32_security_icon_yellow32_png;
  25. import utility.ERPDocking;
  26. import utility.tools.WebRequest;
  27. import java.math.BigDecimal;
  28. import java.util.ArrayList;
  29. import java.util.Date;
  30. import java.util.HashMap;
  31. import static java.time.LocalDate.now;
  32. /**
  33. * 发货单
  34. */
  35. @API(title = "发货单")
  36. public class dispatch extends Controller {
  37. private static Logger logger = Logger.getLogger(dispatch.class);
  38. public dispatch(JSONObject arg0) throws YosException {
  39. super(arg0);
  40. // TODO Auto-generated constructor stub
  41. }
  42. @API(title = "查询是否存在新建的发货单", apiversion = R.ID20240123163302.v1.class)
  43. public String query() throws YosException {
  44. Long sys_enterpriseid = content.getLongValue("sys_enterpriseid");
  45. Long sa_orderid = content.getLongValue("sa_orderid");
  46. Rows rows = dbConnect.runSqlQuery("SELECT * from sa_dispatch WHERE sys_enterpriseid=" + sys_enterpriseid + " and status='新建' and sa_orderid='" + sa_orderid + "' and siteid='" + siteid + "'");
  47. return getSucReturnObject().setData(rows).toString();
  48. }
  49. @API(title = "发货单新增更新", apiversion = R.ID20221114135203.v1.class, intervaltime = 200)
  50. @CACHEING_CLEAN(apiversions = {R.ID20221114135303.v1.class, R.ID20221114135403.v1.class, R.ID20230320160203.v1.class})
  51. public String insertormodify_dispatch() throws YosException {
  52. ArrayList<String> sqlList = new ArrayList<>();
  53. // 表名
  54. String tableName = "sa_dispatch";
  55. Long sa_dispatchid = content.getLong("sa_dispatchid");
  56. Long sa_orderid = content.getLong("sa_orderid");
  57. // Long sys_enterpriseid = content.getLong("sys_enterpriseid");
  58. // Long sa_logiscompid = content.getLong("sa_logiscompid");
  59. // Long rec_contactsid = content.getLongValue("rec_contactsid");
  60. String remarks = content.getStringValue("remarks");
  61. String billdate = content.getStringValue("billdate");
  62. SQLFactory sqlFactory = new SQLFactory(this, "发货单新增");
  63. if (sa_dispatchid <= 0) {
  64. sa_dispatchid = createTableID(tableName);
  65. Rows rowsinfo = dbConnect
  66. .runSqlQuery("select contactsid from sys_enterprise_contacts where workaddress=1 and sys_enterpriseid="
  67. + content.getLong("sys_enterpriseid"));
  68. if (rowsinfo.isEmpty()) {
  69. //return getErrReturnObject().setErrMsg("该订单不存在").toString();
  70. }
  71. sqlFactory.addParameter("sa_orderid", sa_orderid);
  72. // 订货企业id
  73. sqlFactory.addParameter("sys_enterpriseid", content.getLong("sys_enterpriseid"));
  74. // 物流公司档案ID
  75. //sqlFactory.addParameter("sa_logiscompid", rowsinfo.get(0).getLong("sa_logiscompid"));
  76. // 合作企业联系人表ID(收货信息)
  77. if (!rowsinfo.isEmpty()) {
  78. sqlFactory.addParameter("rec_contactsid", rowsinfo.get(0).getLong("contactsid"));
  79. } else {
  80. sqlFactory.addParameter("rec_contactsid", 0);
  81. }
  82. //运费状态
  83. sqlFactory.addParameter("freightstatus", "");
  84. sqlFactory.addParameter("remarks", remarks);
  85. sqlFactory.addParameter("billdate", now());
  86. sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "新增", "发货单新增成功").getSQL());
  87. } else {
  88. Rows rows = dbConnect.runSqlQuery(
  89. "SELECT status,sys_enterpriseid,rec_contactsid,sa_orderid,freightstatus from sa_dispatch WHERE sa_dispatchid = "
  90. + sa_dispatchid);
  91. if (rows.isNotEmpty()) {
  92. if (rows.get(0).getString("status").equals("新建")) {
  93. //通过版本更新发货单表头数据
  94. Dispatch.updateDispatchWithVersion(this);
  95. sqlFactory = new SQLFactory(this, "发货单更新");
  96. if (sa_orderid <= 0) {
  97. sqlFactory.addParameter("sa_orderid", rows.get(0).getLong("sa_orderid"));
  98. // 订货企业id
  99. if (content.getLong("sys_enterpriseid") <= 0) {
  100. sqlFactory.addParameter("sys_enterpriseid", rows.get(0).getLong("sys_enterpriseid"));
  101. } else {
  102. sqlFactory.addParameter("sys_enterpriseid", content.getLong("sys_enterpriseid"));
  103. }
  104. // 物流公司档案ID
  105. // if (content.getLong("sa_logiscompid") <= 0) {
  106. // sqlFactory.addParameter("sa_logiscompid", rows.get(0).getLong("sa_logiscompid"));
  107. // } else {
  108. // sqlFactory.addParameter("sa_logiscompid", content.getLong("sa_logiscompid"));
  109. // }
  110. // 合作企业联系人表ID(收货信息)
  111. if (content.getLong("rec_contactsid") <= 0) {
  112. sqlFactory.addParameter("rec_contactsid", rows.get(0).getLong("rec_contactsid"));
  113. } else {
  114. sqlFactory.addParameter("rec_contactsid", content.getLong("rec_contactsid"));
  115. }
  116. } else {
  117. Rows rowsinfo = dbConnect.runSqlQuery(
  118. "select rec_contactsid,sys_enterpriseid from sa_order where sa_orderid="
  119. + sa_orderid);
  120. if (rowsinfo.isEmpty()) {
  121. return getErrReturnObject().setErrMsg("该发货单不存在").toString();
  122. }
  123. sqlFactory.addParameter("sa_orderid", sa_orderid);
  124. // 订货企业id
  125. sqlFactory.addParameter("sys_enterpriseid", rowsinfo.get(0).getLong("sys_enterpriseid"));
  126. // 物流公司档案ID
  127. //sqlFactory.addParameter("sa_logiscompid", rowsinfo.get(0).getLong("sa_logiscompid"));
  128. // 合作企业联系人表ID(收货信息)
  129. sqlFactory.addParameter("rec_contactsid", rowsinfo.get(0).getLong("rec_contactsid"));
  130. }
  131. //运费状态
  132. if (!StringUtils.isBlank(content.getStringValue("freightstatus"))) {
  133. sqlFactory.addParameter("freightstatus", content.getStringValue("freightstatus"));
  134. } else {
  135. sqlFactory.addParameter("freightstatus", rows.get(0).getString("freightstatus"));
  136. }
  137. sqlFactory.addParameter("billdate", billdate);
  138. sqlFactory.addParameter("remarks", remarks);
  139. sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "更新", "发货单更新成功").getSQL());
  140. } else {
  141. return getErrReturnObject().setErrMsg("非新建状态下无法编辑").toString();
  142. }
  143. } else {
  144. return getErrReturnObject().setErrMsg("该发货单不存在").toString();
  145. }
  146. }
  147. sqlFactory.addParameter("siteid", siteid);
  148. sqlFactory.addParameter("userid", userid);
  149. sqlFactory.addParameter("username", username);
  150. sqlFactory.addParameter("sa_dispatchid", sa_dispatchid);
  151. // 发货单号createBillCode("dispatchbillno")
  152. sqlFactory.addParameter("billno", createBillCode("dispatchbill"));
  153. sqlList.add(sqlFactory.getSQL());
  154. dbConnect.runSqlUpdate(sqlList);
  155. content.put("sa_dispatchid", sa_dispatchid);
  156. return queryDispatchMain();
  157. }
  158. @API(title = "发货单详情", apiversion = R.ID20221114135303.v1.class)
  159. @CACHEING
  160. public String queryDispatchMain() throws YosException {
  161. Long sa_dispatchid = content.getLong("sa_dispatchid");
  162. SQLFactory sqlFactory = new SQLFactory(this, "发货单详情查询");
  163. sqlFactory.addParameter("sa_dispatchid", sa_dispatchid);
  164. sqlFactory.addParameter("siteid", siteid);
  165. Rows rows = dbConnect.runSqlQuery(sqlFactory);
  166. Rows sum = dbConnect.runSqlQuery("select sum(t1.qty * t2.price) sumamount,sum(t1.qty) qty from sa_dispatch_items t1 inner join sa_orderitems t2 on t1.sa_orderitemsid = t2.sa_orderitemsid and t1.siteid = t2.siteid where t1.siteid='" + siteid + "' AND t1.sa_dispatchid=" + sa_dispatchid);
  167. Row row = rows.isNotEmpty() ? rows.get(0) : new Row();
  168. if (sum.isNotEmpty()) {
  169. row.put("sumamount", sum.get(0).getBigDecimal("sumamount"));
  170. row.put("qty", sum.get(0).getBigDecimal("qty"));
  171. }
  172. //物流
  173. // SQLFactory sqlFactory1 = new SQLFactory(this, "发货单-查询物流信息");
  174. // sqlFactory1.addParameter("siteid", siteid);
  175. // sqlFactory1.addParameter("sa_dispatchid", sa_dispatchid);
  176. // Rows logiscompRows = dbConnect.runSqlQuery(sqlFactory1);
  177. // row.put("logiscomp", logiscompRows.isNotEmpty() ? logiscompRows.get(0) : new Row());
  178. //收货
  179. SQLFactory sqlFactory2 = new SQLFactory(this, "发货单-查询收货信息");
  180. sqlFactory2.addParameter("siteid", siteid);
  181. sqlFactory2.addParameter("sa_dispatchid", sa_dispatchid);
  182. Rows recviceRows = dbConnect.runSqlQuery(sqlFactory2);
  183. row.put("recvice", recviceRows.isNotEmpty() ? recviceRows.get(0) : new Row());
  184. return getSucReturnObject().setData(row).toString();
  185. }
  186. @API(title = "查询发货单列表", apiversion = R.ID20221114135403.v1.class)
  187. public String queryDispatchList() throws YosException {
  188. StringBuffer where = new StringBuffer(" 1=1 ");
  189. if (content.containsKey("where")) {
  190. JSONObject whereObject = content.getJSONObject("where");
  191. if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
  192. where.append(" and(");
  193. where.append("t1.billno like'%").append(whereObject.getString("condition")).append("%' ");
  194. where.append("or t3.sonum like'%").append(whereObject.getString("condition")).append("%' ");
  195. where.append("or t2.enterprisename like'%").append(whereObject.getString("condition")).append("%' ");
  196. where.append("or t7.agentnum like'%").append(whereObject.getString("condition")).append("%' ");
  197. where.append("or t1.remarks like'%").append(whereObject.getString("condition")).append("%' ");
  198. where.append("or t1.recheckby like'%").append(whereObject.getString("condition")).append("%' ");
  199. where.append(")");
  200. }
  201. if (whereObject.containsKey("status") && !"".equals(whereObject.getString("status"))) {
  202. where.append(" and t1.status ='").append(whereObject.getString("status")).append("' ");
  203. }
  204. if (whereObject.containsKey("begindate") && !"".equals(whereObject.getString("begindate"))) {
  205. where.append(" and DATE_FORMAT(t1.billdate, '%Y-%m-%d') >='").append(whereObject.getString("begindate")).append("' ");
  206. }
  207. if (whereObject.containsKey("enddate") && !"".equals(whereObject.getString("enddate"))) {
  208. where.append(" and DATE_FORMAT(t1.billdate, '%Y-%m-%d') <='").append(whereObject.getString("enddate")).append("' ");
  209. }
  210. if (whereObject.containsKey("remarks") && !"".equals(whereObject.getString("remarks"))) {
  211. where.append("and t1.remarks like'%").append(whereObject.getString("remarks")).append("%' ");
  212. }
  213. if (whereObject.containsKey("agentinfo") && !"".equals(whereObject.getString("agentinfo"))) {
  214. where.append(" and(");
  215. where.append(" t2.enterprisename like'%").append(whereObject.getString("agentinfo")).append("%' ");
  216. where.append("or t7.agentnum like'%").append(whereObject.getString("agentinfo")).append("%' ");
  217. where.append(")");
  218. }
  219. if (whereObject.containsKey("param") && !"".equals(whereObject.getString("param"))) {
  220. Rows rowsDispatchid = dbConnect.runSqlQuery("select t1.sa_dispatchid from sa_dispatch_items t1 left join sa_orderitems t2 on t1.sa_orderitemsid=t2.sa_orderitemsid and t1.siteid=t2.siteid " +
  221. "left join sa_order t3 on t2.sa_orderid=t3.sa_orderid and t2.siteid=t3.siteid left join plm_item t4 on t1.itemid=t4.itemid and t1.siteid=t4.siteid where t1.siteid='" + siteid + "' and (t4.itemname like '%" + whereObject.getString("param") + "%' or t4.itemno like '%" + whereObject.getString("param") + "%' or t3.sonum='" + whereObject.getString("param") + "')");
  222. if (rowsDispatchid.toJsonArray("sa_dispatchid").isEmpty()) {
  223. where.append(" and t1.sa_dispatchid in (0)");
  224. } else {
  225. String str = rowsDispatchid.toJsonArray("sa_dispatchid").toJSONString();
  226. str = str.replace("[", "(").replace("]", ")");
  227. where.append(" and t1.sa_dispatchid in").append(str);
  228. }
  229. }
  230. if (whereObject.containsKey("sa_orderitemsid") && !"".equals(whereObject.getString("sa_orderitemsid"))) {
  231. Rows rowsDispatchid = dbConnect.runSqlQuery("select t1.sa_dispatchid from sa_dispatch_items t1 left join sa_dispatch t2 on t1.sa_dispatchid=t2.sa_dispatchid and t1.siteid=t2.siteid " +
  232. " where t2.status !='新建' and t1.siteid='" + siteid + "' and t1.sa_orderitemsid =" + whereObject.getLong("sa_orderitemsid") + "");
  233. if (rowsDispatchid.toJsonArray("sa_dispatchid").isEmpty()) {
  234. where.append(" and t1.sa_dispatchid in (0)");
  235. } else {
  236. String str = rowsDispatchid.toJsonArray("sa_dispatchid").toJSONString();
  237. str = str.replace("[", "(").replace("]", ")");
  238. where.append(" and t1.sa_dispatchid in").append(str);
  239. }
  240. }
  241. }
  242. // SQLFactory sqlFactory = new SQLFactory(this, "发货单列表查询", pageSize, pageNumber, pageSorting);
  243. // sqlFactory.addParameter("siteid", siteid);
  244. // sqlFactory.addParameter_SQL("where", where);
  245. // Rows rows = dbConnect.runSqlQuery(sqlFactory);
  246. QuerySQL querySQL = queryDispatchList(where.toString());
  247. querySQL.setPage(pageSize, pageNumber);
  248. querySQL.setOrderBy(pageSorting);
  249. Rows rows = querySQL.query();
  250. ArrayList<Long> ids = rows.toArrayList("sa_dispatchid", new ArrayList<>());
  251. //查询数量金额
  252. RowsMap dispatchAmountRowsMap = Dispatch.getDispatchAmountAndQty(this, ids);
  253. Rows reportRows = dbConnect.runSqlQuery("select sys_reportid from sys_report where (siteid is null or siteid='' or siteid='" + siteid + "') and systemappid=209");
  254. ArrayList<HashMap<Long, Integer>> viewCountList = new ArrayList<>();
  255. for (Row reportRow : reportRows) {
  256. long sys_reportid = reportRow.getLong("sys_reportid");
  257. HashMap<Long, Integer> viewCount = Report.getViewCount(this, sys_reportid, ids);
  258. viewCountList.add(viewCount);
  259. }
  260. // HashMap<Long, Integer> viewCount = Report.getViewCount(this, 82, ids);
  261. for (Row row : rows) {
  262. Long id = row.getLong("sa_dispatchid");
  263. if (dispatchAmountRowsMap.get(id.toString()).isNotEmpty()) {
  264. row.put("sumamount", dispatchAmountRowsMap.get(id.toString()).get(0).getBigDecimal("sumamount"));
  265. row.put("sumqty", dispatchAmountRowsMap.get(id.toString()).get(0).getBigDecimal("sumqty"));
  266. } else {
  267. row.put("sumamount", 0);
  268. row.put("sumqty", 0);
  269. }
  270. Integer isreport = 0;
  271. for (HashMap<Long, Integer> viewCount : viewCountList) {
  272. if (viewCount.containsKey(id)) {
  273. isreport += viewCount.get(id);
  274. }
  275. }
  276. row.put("isreport", isreport);
  277. }
  278. return getSucReturnObject().setData(rows).toString();
  279. }
  280. //查询发货单列表
  281. public QuerySQL queryDispatchList(String where) throws YosException {
  282. QuerySQL querySQL = SQLFactory.createQuerySQL(this, "sa_dispatch");
  283. querySQL.setTableAlias("t1");
  284. querySQL.addJoinTable(JOINTYPE.left, "sys_enterprise", "t2", "t1.sys_enterpriseid = t2.sys_enterpriseid AND t1.siteid = t2.siteid",
  285. "enterprisename", "abbreviation");
  286. querySQL.addQueryFields("enterprisephonenumber", "t2.phonenumber");
  287. querySQL.addJoinTable(JOINTYPE.left, "sa_order", "t3", "t1.sa_orderid = t3.sa_orderid AND t1.siteid = t3.siteid", "sonum");
  288. querySQL.addJoinTable(JOINTYPE.left, "sys_enterprise_contacts", "t5", "t1.rec_contactsid = t5.contactsid AND t1.siteid = t5.siteid",
  289. "province", "city", "county", "address");
  290. querySQL.addQueryFields("contactsphonenumber", "t5.phonenumber");
  291. querySQL.addJoinTable(JOINTYPE.left, "sa_agents", "t7", "t7.sys_enterpriseid = t1.sys_enterpriseid AND t1.siteid = t7.siteid",
  292. "agentnum");
  293. querySQL.setWhere("t1.siteid", siteid);
  294. querySQL.setWhere(where);
  295. return querySQL;
  296. }
  297. @API(title = "经销商列表查询(管理端)", apiversion = R.ID20230324125803.v1.class)
  298. public String query_agentList() throws YosException {
  299. /*
  300. * 过滤条件设置
  301. */
  302. StringBuffer where = new StringBuffer(" 1=1 ");
  303. if (content.containsKey("where")) {
  304. JSONObject whereObject = content.getJSONObject("where");
  305. if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
  306. where.append(" and(");
  307. where.append("t4.agentnum like'%").append(whereObject.getString("condition")).append("%' ");
  308. where.append("or t3.enterprisename like'%").append(whereObject.getString("condition")).append("%' ");
  309. where.append(")");
  310. }
  311. }
  312. SQLFactory sqlFactory = new SQLFactory(this, "经销商合作企业查询", pageSize, pageNumber, pageSorting);
  313. sqlFactory.addParameter("siteid", siteid);
  314. sqlFactory.addParameter_SQL("where", where);
  315. Rows rows = dbConnect.runSqlQuery(sqlFactory);
  316. // QuerySQL querySQL = SQLFactory.createQuerySQL(this, "select distinct t2.sys_enterpriseid,t1.siteid from sa_orderitems t1\n" +
  317. // "inner join sa_order t2 on t1.siteid=t2.siteid and t1.sa_orderid=t2.sa_orderid\n" +
  318. // "where t1.siteid=$siteid$ and t2.status in ('审核','提交') and undeliqty>0","sys_enterpriseid");
  319. // querySQL.setTableAlias("t1");
  320. // querySQL.addJoinTable(JOINTYPE.inner, "sys_enterprise", "t3", "t3.sys_enterpriseid = t1.sys_enterpriseid and t3.siteid = t1.siteid",
  321. // "enterprisename", "contact","address","province","city","phonenumber","county");
  322. // querySQL.addJoinTable(JOINTYPE.inner, "sa_agents", "t4", "t3.siteid = t4.siteid and t3.sys_enterpriseid = t4.sys_enterpriseid",
  323. // "agentnum");
  324. // querySQL.setWhere("t1.siteid", siteid);
  325. // querySQL.setWhere(where.toString());
  326. // querySQL.setWhere(" exists(select 1 from sa_orderitems where sa_orderid=t1.sa_orderid and undeliqty>0 )");
  327. // querySQL.addGroupBy(" t1.sys_enterpriseid,\n" +
  328. // " t3.enterprisename,\n" +
  329. // " t3.contact,\n" +
  330. // " t3.address,\n" +
  331. // " t3.province,\n" +
  332. // " t3.city,\n" +
  333. // " t3.county,\n" +
  334. // " t3.phonenumber,\n" +
  335. // " t4.agentnum");
  336. // querySQL.setOrderBy(pageSorting);
  337. // querySQL.setPage(pageSize, pageNumber);
  338. return getSucReturnObject().setData(rows).toString();
  339. }
  340. @API(title = "删除", apiversion = R.ID20221114135503.v1.class)
  341. @CACHEING_CLEAN(apiversions = {R.ID20221114135303.v1.class, R.ID20221114135403.v1.class, R.ID20230320160203.v1.class})
  342. public String delete() throws YosException {
  343. JSONArray sa_dispatchids = content.getJSONArray("sa_dispatchids");
  344. BatchDeleteErr batchDeleteErr = BatchDeleteErr.create(this, sa_dispatchids.size());
  345. for (Object o : sa_dispatchids) {
  346. long sa_dispatchid = Long.parseLong(o.toString());
  347. Rows RowsStatus = dbConnect.runSqlQuery("select sa_dispatchid,status from sa_dispatch where siteid='"
  348. + siteid + "' and sa_dispatchid='" + sa_dispatchid + "'");
  349. Rows logisticsRows = dbConnect.runSqlQuery("select * from sa_logistics_items where siteid='"
  350. + siteid + "' and sa_dispatchid='" + sa_dispatchid + "'");
  351. if (RowsStatus.isNotEmpty()) {
  352. if (!RowsStatus.get(0).getString("status").equals("新建")) {
  353. batchDeleteErr.addErr(sa_dispatchid, "非新建状态的发货单无法删除");
  354. continue;
  355. }
  356. }
  357. if (logisticsRows.isNotEmpty()) {
  358. batchDeleteErr.addErr(sa_dispatchid, "存在发货物流明细信息,无法删除");
  359. continue;
  360. }
  361. dbConnect.runSqlUpdate(
  362. "delete from sa_dispatch where siteid='" + siteid + "' and sa_dispatchid=" + sa_dispatchid);
  363. }
  364. return batchDeleteErr.getReturnObject().toString();
  365. }
  366. // @API(title = "审核", apiversion = R.ID20221114135603.v1.class)
  367. // @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, dispatch.class, dispatchItems.class,cashbill.class})
  368. // public String check() throws YosException {
  369. // Long sa_dispatchid = content.getLong("sa_dispatchid");
  370. // Long sa_orderid = 0L;
  371. // Rows rows = dbConnect.runSqlQuery("select sa_dispatchid,status,billno,sa_orderid from sa_dispatch where sa_dispatchid ='"
  372. // + sa_dispatchid + "' and siteid='" + siteid + "'");
  373. // if (rows.isEmpty()) {
  374. // return getErrReturnObject().setErrMsg("该发货单不存在")
  375. // .toString();
  376. // } else {
  377. // sa_orderid = rows.get(0).getLong("sa_orderid");
  378. // if (!rows.get(0).getString("status").equals("新建")) {
  379. // return getErrReturnObject().setErrMsg("单号为:【" + rows.get(0).getString("billno") + "】的发货单为非新建状态,无法审核")
  380. // .toString();
  381. // }
  382. // }
  383. //
  384. // ArrayList<String> sqlList = new ArrayList<>();
  385. // Rows rowsOrderDetail = dbConnect.runSqlQuery("select t1.undeliqty,t1.deliedqty,t1.qty,t1.sa_orderitemsid from sa_orderitems t1 where t1.sa_orderitemsid in (select sa_orderitemsid from sa_dispatch_items where sa_dispatchid="+ sa_dispatchid+")" );
  386. // RowsMap rowsMap = rowsOrderDetail.toRowsMap("sa_orderitemsid");
  387. // Rows rowsDispatchDetail = dbConnect.runSqlQuery("select t1.qty,t1.sa_orderitemsid,t1.rowno,t2.itemname from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where t1.sa_dispatchid=" + sa_dispatchid);
  388. // if (!rowsDispatchDetail.isEmpty()) {
  389. // for (Row row : rowsDispatchDetail) {
  390. // if (rowsMap.get(row.getString("sa_orderitemsid")).isEmpty()) {
  391. // return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细不存在对应得订单行,无法审核")
  392. // .toString();
  393. // }
  394. // if (row.getBigDecimal("qty").compareTo(rowsMap.get(row.getString("sa_orderitemsid")).get(0).getBigDecimal("undeliqty")) == 1) {
  395. // return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细的数量大于对应订单行的未发货数量,无法审核")
  396. // .toString();
  397. // }
  398. // sqlList.add("update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").subtract(row.getBigDecimal("qty")) + ",deliedqty=" + (row.getBigDecimal("qty").add(rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  399. // }
  400. // }
  401. // SQLFactory sqlFactoryupdate = new SQLFactory(this, "发货单审核");
  402. // sqlFactoryupdate.addParameter("siteid", siteid);
  403. // sqlFactoryupdate.addParameter("sa_dispatchid", sa_dispatchid);
  404. // sqlFactoryupdate.addParameter("checkby", username);
  405. // sqlList.add(sqlFactoryupdate.getSQL());
  406. // sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "审核", "发货单审核成功").getSQL());
  407. // dbConnect.runSqlUpdate(sqlList);
  408. //
  409. //
  410. // Executor.sendEml(this, "dispatchrecheck", sa_dispatchid,new ArrayList<>());
  411. // return getSucReturnObject().toString();
  412. //
  413. // }
  414. //
  415. //
  416. @API(title = "反审核", apiversion = R.ID20221114135703.v1.class)
  417. @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, dispatch.class, dispatchItems.class, cashbill.class})
  418. public String uncheck() throws YosException {
  419. Long sa_dispatchid = content.getLong("sa_dispatchid");
  420. //通过版本更新发货单表头数据
  421. Dispatch.updateDispatchWithVersion(this);
  422. Long sa_orderid = 0L;
  423. Rows rows = dbConnect.runSqlQuery("select sa_dispatchid,status,billno,sa_orderid from sa_dispatch where sa_dispatchid ='"
  424. + sa_dispatchid + "' and siteid='" + siteid + "'");
  425. if (rows.isEmpty()) {
  426. return getErrReturnObject().setErrMsg("该发货单不存在")
  427. .toString();
  428. } else {
  429. sa_orderid = rows.get(0).getLong("sa_orderid");
  430. if (!rows.get(0).getString("status").equals("审核")) {
  431. return getErrReturnObject().setErrMsg("单号为:【" + rows.get(0).getString("billno") + "】的发货单为非审核状态,无法反审核")
  432. .toString();
  433. }
  434. }
  435. ArrayList<String> sqlList = new ArrayList<>();
  436. Rows rowsOrderDetail = dbConnect.runSqlQuery("select t1.undeliqty,t1.deliedqty,t1.qty,t1.sa_orderitemsid from sa_orderitems t1 where t1.sa_orderitemsid in (select sa_orderitemsid from sa_dispatch_items where sa_dispatchid=" + sa_dispatchid + ")");
  437. RowsMap rowsMap = rowsOrderDetail.toRowsMap("sa_orderitemsid");
  438. Rows rowsDispatchDetail = dbConnect.runSqlQuery("select t1.qty,t1.sa_orderitemsid,t1.rowno,t2.itemname from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where t1.sa_dispatchid=" + sa_dispatchid);
  439. if (!rowsDispatchDetail.isEmpty()) {
  440. for (Row row : rowsDispatchDetail) {
  441. // if(rowsMap.get(row.getLong("sa_orderitemsid")).isEmpty()) {
  442. // return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细不存在对应得订单行,无法审核")
  443. // .toString();
  444. // }
  445. // if(row.getBigDecimal("qty").compareTo(rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty"))==1) {
  446. // return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细的数量大于对应订单行的未发货数量,无法审核")
  447. // .toString();
  448. // }
  449. sqlList.add("update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").add(row.getBigDecimal("qty")) + ",deliedqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty").subtract(row.getBigDecimal("qty")) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  450. }
  451. }
  452. SQLFactory sqlFactoryupdate = new SQLFactory(this, "发货单反审核");
  453. sqlFactoryupdate.addParameter("siteid", siteid);
  454. sqlFactoryupdate.addParameter("sa_dispatchid", sa_dispatchid);
  455. sqlFactoryupdate.addParameter("checkby", username);
  456. sqlList.add(sqlFactoryupdate.getSQL());
  457. sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "反审核", "发货单反审核成功").getSQL());
  458. dbConnect.runSqlUpdate(sqlList);
  459. return getSucReturnObject().toString();
  460. }
  461. @API(title = "手工关闭", apiversion = R.ID20230404134703.v1.class)
  462. @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, dispatch.class, dispatchItems.class, cashbill.class})
  463. public String unclose() throws YosException {
  464. Long sa_dispatchid = content.getLong("sa_dispatchid");
  465. Long sa_orderid = 0L;
  466. Rows rows = dbConnect.runSqlQuery("select sa_dispatchid,status,billno,sa_orderid,sys_enterpriseid from sa_dispatch where sa_dispatchid ='"
  467. + sa_dispatchid + "' and siteid='" + siteid + "'");
  468. Rows rowsdetail = dbConnect.runSqlQuery("select cast(sa_dispatch_itemsid AS CHAR) as sa_dispatch_itemsid from sa_dispatch_items where sa_dispatchid ='"
  469. + sa_dispatchid + "' and siteid='" + siteid + "'");
  470. if (rows.isEmpty()) {
  471. return getErrReturnObject().setErrMsg("该发货单不存在")
  472. .toString();
  473. } else {
  474. sa_orderid = rows.get(0).getLong("sa_orderid");
  475. if (!rows.get(0).getString("status").equals("复核")) {
  476. return getErrReturnObject().setErrMsg("单号为:【" + rows.get(0).getString("billno") + "】的发货单为非复核状态,无法手工关闭")
  477. .toString();
  478. }
  479. }
  480. if (siteid.equalsIgnoreCase("lsa")) {
  481. Rows erp_urlrows = dbConnect.runSqlQuery("SELECT erp_url from sys_site_parameter WHERE siteid='" + siteid + "'");
  482. if (erp_urlrows.isNotEmpty()) {
  483. String url = erp_urlrows.get(0).getString("erp_url");
  484. if(!StringUtils.isBlank(url)){
  485. JSONObject object = new JSONObject();
  486. object.put("classname", "getIcinvbal");
  487. object.put("method", "getIcstockbillMsg");
  488. JSONObject content = new JSONObject();
  489. content.put("sa_dispatch_itemsids", rowsdetail.toJsonArray("sa_dispatch_itemsid"));
  490. object.put("content", content);
  491. WebRequest request = new WebRequest();
  492. String result = request.doPost(object.toString(),
  493. url);
  494. JSONArray jsonArray = new JSONArray();
  495. if (isJSONArray(result)) {
  496. jsonArray = JSONArray.parseArray(result);
  497. } else {
  498. return getErrReturnObject().setErrMsg("与中间表连接异常")
  499. .toString();
  500. }
  501. if (!jsonArray.isEmpty()) {
  502. return getErrReturnObject().setErrMsg("中间表存在未同步的销售出库单,无法手工关闭")
  503. .toString();
  504. }
  505. //
  506. JSONObject object1 = new JSONObject();
  507. object1.put("classname", "getIcinvbal");
  508. object1.put("method", "canCloseSainvoiceByHand");
  509. JSONObject content1 = new JSONObject();
  510. content1.put("billno", rows.get(0).getString("billno"));
  511. object1.put("content", content1);
  512. String canCloseSainvoiceByHand = request.doPost(object1.toString(),
  513. url);
  514. if (!canCloseSainvoiceByHand.equals("true")) {
  515. return getErrReturnObject().setErrMsg("中间表状态不为1,无法手工关闭")
  516. .toString();
  517. }
  518. }
  519. }
  520. }
  521. //对接erp生成erp发货单
  522. if (Parameter.get("system.ccerp_dockswitch").equalsIgnoreCase("true") && !siteid.equalsIgnoreCase("lsa")) {
  523. ERPDocking erpDocking = new ERPDocking(siteid);
  524. if (!erpDocking.getUrl().isEmpty()) {
  525. String result = erpDocking.closeErpSainvoice(rows.get(0).getString("billno"), true, this, sa_dispatchid);
  526. if (!result.equals("true")) {
  527. return getErrReturnObject().setErrMsg(result).toString();
  528. } else {
  529. JSONArray jsonArray = erpDocking.queryErpSainvoice(rows.get(0).getString("billno"));
  530. ArrayList<String> dispatchsqlList = new ArrayList<>();
  531. if (!jsonArray.isEmpty()) {
  532. for (Object object1 : jsonArray) {
  533. JSONObject jsonObject = (JSONObject) object1;
  534. dispatchsqlList.add("update sa_dispatch_items set outwarehouseqty=" + jsonObject.getBigDecimalValue("fqty1") + " where rowno =" + jsonObject.getIntValue("frownum") + " and sa_dispatchid='" + sa_dispatchid + "' and siteid='" + siteid + "'");
  535. }
  536. }
  537. dbConnect.runSqlUpdate(dispatchsqlList);
  538. }
  539. }
  540. }
  541. ArrayList<String> sqlList = new ArrayList<>();
  542. Rows rowsOrderDetail = dbConnect.runSqlQuery("select t1.undeliqty,t1.deliedqty,t1.qty,t1.sa_orderitemsid from sa_orderitems t1 where t1.sa_orderitemsid in (select sa_orderitemsid from sa_dispatch_items where sa_dispatchid=" + sa_dispatchid + ")");
  543. RowsMap rowsMap = rowsOrderDetail.toRowsMap("sa_orderitemsid");
  544. Rows rowsDispatchDetail = dbConnect.runSqlQuery("select t1.qty,t1.outwarehouseqty,t1.sa_orderitemsid,t1.rowno,t2.itemname from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where ifnull(isclose,0)=0 and t1.sa_dispatchid=" + sa_dispatchid);
  545. Rows rowsDispatchDetailGroup = dbConnect.runSqlQuery("select sum(t1.qty) qty, sum(t1.outwarehouseqty) outwarehouseqty,t1.sa_orderitemsid,t1.siteid from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where ifnull(isclose,0)=0 and t1.sa_dispatchid=" + sa_dispatchid + " group by t1.sa_orderitemsid,t1.siteid");
  546. if (!rowsDispatchDetail.isEmpty()) {
  547. for (Row row : rowsDispatchDetailGroup) {
  548. // if(rowsMap.get(row.getLong("sa_orderitemsid")).isEmpty()) {
  549. // return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细不存在对应得订单行,无法审核")
  550. // .toString();
  551. // }
  552. // if(row.getBigDecimal("qty").compareTo(rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty"))==1) {
  553. // return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细的数量大于对应订单行的未发货数量,无法审核")
  554. // .toString();
  555. // }
  556. sqlList.add("update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").add(row.getBigDecimal("qty").subtract(row.getBigDecimal("outwarehouseqty"))) + ",deliedqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty").subtract(row.getBigDecimal("qty").subtract(row.getBigDecimal("outwarehouseqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  557. }
  558. }
  559. Rows orderRows = dbConnect.runSqlQuery("select distinct t1.sa_orderid from sa_orderitems t1 inner join sa_dispatch_items t2 on t1.siteid=t2.siteid and t1.sa_orderitemsid=t2.sa_orderitemsid where t1.siteid='" + siteid + "' and t2.sa_dispatchid=" + sa_dispatchid);
  560. for (Row row : orderRows) {
  561. //sqlList.add("update sa_order set status='审核' where sa_orderid=" + row.getLong("sa_orderid") + " and siteid='" + siteid + "'");
  562. }
  563. SQLFactory sqlFactoryupdate = new SQLFactory(this, "发货单关闭");
  564. sqlFactoryupdate.addParameter("siteid", siteid);
  565. sqlFactoryupdate.addParameter("sa_dispatchid", sa_dispatchid);
  566. sqlFactoryupdate.addParameter("closeby", username);
  567. sqlList.add(sqlFactoryupdate.getSQL());
  568. sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "手工关闭", "发货单手工关闭成功").getSQL());
  569. dbConnect.runSqlUpdate(sqlList);
  570. if (siteid.equalsIgnoreCase("lsa")) {
  571. Rows erp_urlrows = dbConnect.runSqlQuery("SELECT erp_url from sys_site_parameter WHERE siteid='" + siteid + "'");
  572. if (erp_urlrows.isNotEmpty()) {
  573. String url = erp_urlrows.get(0).getString("erp_url");
  574. if(!StringUtils.isBlank(url)){
  575. JSONObject objectfeek = new JSONObject();
  576. objectfeek.put("classname", "getIcinvbal");
  577. objectfeek.put("method", "updateSainvoiceStatus");
  578. JSONObject contentfeek = new JSONObject();
  579. contentfeek.put("billno", rows.get(0).getString("billno"));
  580. objectfeek.put("content", contentfeek);
  581. WebRequest request = new WebRequest();
  582. request.doPost(objectfeek.toString(),
  583. url);
  584. }
  585. }
  586. }
  587. sendRemind(rows.get(0).getLong("sys_enterpriseid"), sa_dispatchid);
  588. return getSucReturnObject().toString();
  589. }
  590. @API(title = "行关闭", apiversion = R.ID20230522093703.v1.class)
  591. @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, dispatch.class, dispatchItems.class, cashbill.class})
  592. public String closeRows() throws YosException {
  593. JSONArray sa_dispatch_itemsids = content.getJSONArray("sa_dispatch_itemsids");
  594. BatchDeleteErr batchDeleteErr = BatchDeleteErr.create(this, sa_dispatch_itemsids.size());
  595. String sql = "";
  596. if (sa_dispatch_itemsids.size() > 0) {
  597. sql = "select t1.sa_dispatch_itemsid,t1.sa_orderitemsid,t1.qty,t1.outwarehouseqty,t1.sa_dispatchid,t1.rowno,t3.itemno,t2.billno,t2.status,t1.isclose from sa_dispatch_items t1 left join sa_dispatch t2 on t1.sa_dispatchid=t2.sa_dispatchid and t1.siteid=t2.siteid left join plm_item t3 on t1.itemid=t3.itemid and t1.siteid=t3.siteid where t1.sa_dispatch_itemsid in" + sa_dispatch_itemsids.toJSONString() + " and t1.siteid='" + siteid + "'";
  598. sql = sql.replace("[", "(").replace("]", ")");
  599. } else {
  600. return getErrReturnObject().setErrMsg("请选择发货单行后,进行行关闭").toString();
  601. }
  602. Rows rows = dbConnect.runSqlQuery(sql);
  603. if (rows.isEmpty()) {
  604. return getErrReturnObject().setErrMsg("该发货单所选行不存在")
  605. .toString();
  606. } else {
  607. if (!rows.get(0).getString("status").equals("复核")) {
  608. return getErrReturnObject().setErrMsg("单号为:【" + rows.get(0).getString("billno") + "】的发货单为非复核状态,无法行关闭")
  609. .toString();
  610. }
  611. }
  612. ArrayList<String> sqlList = new ArrayList<>();
  613. String orderdetailSql = "select t1.undeliqty,t1.deliedqty,t1.qty,t1.sa_orderitemsid from sa_orderitems t1 where t1.sa_orderitemsid in (select sa_orderitemsid from sa_dispatch_items where sa_dispatch_itemsid in" + sa_dispatch_itemsids.toJSONString() + " )";
  614. orderdetailSql = orderdetailSql.replace("[", "(").replace("]", ")");
  615. Rows rowsOrderDetail = dbConnect.runSqlQuery(orderdetailSql);
  616. RowsMap rowsMap = rowsOrderDetail.toRowsMap("sa_orderitemsid");
  617. for (Row row : rows) {
  618. //对接erp生成erp发货单
  619. if (row.getBoolean("isclose")) {
  620. batchDeleteErr.addErr(row.getLong("sa_dispatch_itemsid"), "第" + row.getString("rowno") + "行的发货单明细已关闭,请勿重复关闭");
  621. continue;
  622. }
  623. if (Parameter.get("system.ccerp_dockswitch").equalsIgnoreCase("true")) {
  624. ERPDocking erpDocking = new ERPDocking(siteid);
  625. if (!erpDocking.getUrl().isEmpty()) {
  626. String result = erpDocking.closeErpSainvoiceRow(row.getString("billno"), this, row.getLong("rowno"), row.getString("itemno"), row.getLong("sa_dispatchid"));
  627. if (!result.equals("true")) {
  628. batchDeleteErr.addErr(row.getLong("sa_dispatch_itemsid"), result);
  629. continue;
  630. } else {
  631. sqlList.add("update sa_dispatch_items set isclose=1 where sa_dispatch_itemsid=" + row.getLong("sa_dispatch_itemsid"));
  632. sqlList.add("update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").add(row.getBigDecimal("qty").subtract(row.getBigDecimal("outwarehouseqty"))) + ",deliedqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty").subtract(row.getBigDecimal("qty").subtract(row.getBigDecimal("outwarehouseqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  633. }
  634. }
  635. }
  636. }
  637. dbConnect.runSqlUpdate(sqlList);
  638. Rows sumcountRows = dbConnect.runSqlQuery("select count(1) sumcount from sa_dispatch_items where sa_dispatchid=" + rows.get(0).getLong("sa_dispatchid") + " and siteid='" + siteid + "'");
  639. Rows closecountRows = dbConnect.runSqlQuery("select count(1) closecount from sa_dispatch_items where sa_dispatchid=" + rows.get(0).getLong("sa_dispatchid") + " and siteid='" + siteid + "' and isclose=1");
  640. if (sumcountRows.get(0).getLong("sumcount") == closecountRows.get(0).getLong("closecount")) {
  641. if (Parameter.get("system.ccerp_dockswitch").equalsIgnoreCase("true")) {
  642. ERPDocking erpDocking = new ERPDocking(siteid);
  643. if (!erpDocking.getUrl().isEmpty()) {
  644. String result = erpDocking.closeErpSainvoice(rows.get(0).getString("billno"), true, this, rows.get(0).getLong("sa_dispatchid"));
  645. if (!result.equals("true")) {
  646. return getErrReturnObject().setErrMsg(result).toString();
  647. } else {
  648. dbConnect.runSqlUpdate("update sa_dispatch set status='手工关闭',closeby='" + username + "',closedate=CURRENT_TIMESTAMP where sa_dispatchid=" + rows.get(0).getLong("sa_dispatchid"));
  649. dbConnect.runSqlUpdate(DataContrlLog.createLog(this, "sa_dispatch", rows.get(0).getLong("sa_dispatchid"), "手工关闭", "发货单手工关闭成功").getSQL());
  650. }
  651. }
  652. }
  653. }
  654. return batchDeleteErr.getReturnObject().toString();
  655. }
  656. @API(title = "自动关闭(erp调用)", apiversion = R.ID20230413110103.v1.class, accesstoken = false)
  657. @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, dispatch.class, dispatchItems.class, cashbill.class})
  658. public String autoClose() throws YosException {
  659. String finvonum = content.getString("finvonum");
  660. Rows rows = dbConnect.runSqlQuery("select * from sa_dispatch where status='复核' and siteid='CCYOSG' and billno='" + finvonum + "'");
  661. Rows rowsdetail = dbConnect.runSqlQuery("select t1.* from sa_dispatch_items t1 inner join sa_dispatch t2 on t1.sa_dispatchid=t2.sa_dispatchid and t1.siteid=t2.siteid where t2.status='复核' and t1.siteid='CCYOSG'");
  662. RowsMap rowsMap = rowsdetail.toRowsMap("sa_dispatchid");
  663. ArrayList<String> sqlList = new ArrayList<>();
  664. ERPDocking erpDocking = new ERPDocking(siteid);
  665. if (!erpDocking.getUrl().isEmpty()) {
  666. for (Row row : rows) {
  667. String sa_dispatchid = row.getString("sa_dispatchid");
  668. String billno = row.getString("billno");
  669. String result = erpDocking.closeErpSainvoice(billno, false, this, row.getLong("sa_dispatchid"));
  670. if (result.equals("true")) {
  671. sqlList.add("update sa_dispatch set status='关闭' where sa_dispatchid='" + sa_dispatchid + "' and siteid='CCYOSG'");
  672. SQLFactory sqlFactory = new SQLFactory(new DataContrlLog(), "数据操作日志新增");
  673. sqlFactory.addParameter("ownertable", "sa_dispatch");
  674. sqlFactory.addParameter("ownerid", sa_dispatchid);
  675. sqlFactory.addParameter("action", "自动关闭");
  676. sqlFactory.addParameter("remarks", "发货单自动关闭成功");
  677. sqlFactory.addParameter("actionuserid", "1");
  678. sqlFactory.addParameter("actionby", "admin");
  679. sqlFactory.addParameter("siteid", "CCYOSG");
  680. sqlList.add(sqlFactory.getSQL());
  681. } else {
  682. logger.info("发货单自动关闭错误:" + result);
  683. return getErrReturnObject().setErrMsg(result).toString();
  684. }
  685. JSONArray jsonArray = erpDocking.queryErpSainvoice(billno);
  686. if (!jsonArray.isEmpty()) {
  687. for (Object object : jsonArray) {
  688. JSONObject jsonObject = (JSONObject) object;
  689. sqlList.add("update sa_dispatch_items set outwarehouseqty=" + jsonObject.getBigDecimalValue("fqty1") + " where rowno =" + jsonObject.getIntValue("frownum") + " and sa_dispatchid='" + sa_dispatchid + "' and siteid='CCYOSG'");
  690. }
  691. }
  692. }
  693. dbConnect.runSqlUpdate(sqlList);
  694. }
  695. return getSucReturnObject().toString();
  696. }
  697. @API(title = "复核", apiversion = R.ID20221114135803.v1.class)
  698. @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, dispatch.class, dispatchItems.class, cashbill.class})
  699. public String recheck() throws YosException {
  700. Long sa_dispatchid = content.getLong("sa_dispatchid");
  701. Rows dispatchRows = dbConnect.runSqlQuery("select sa_dispatchid,status,billno,sa_orderid from sa_dispatch where sa_dispatchid ='"
  702. + sa_dispatchid + "' and siteid='" + siteid + "'");
  703. if (dispatchRows.isEmpty()) {
  704. return getErrReturnObject().setErrMsg("该发货单不存在")
  705. .toString();
  706. } else {
  707. if (!dispatchRows.get(0).getString("status").equals("新建")) {
  708. return getErrReturnObject().setErrMsg("单号为:【" + dispatchRows.get(0).getString("billno") + "】的发货单为非新建状态,无法复核")
  709. .toString();
  710. }
  711. }
  712. ArrayList<String> sqlList = new ArrayList<>();
  713. Rows rowsOrderDetail = dbConnect.runSqlQuery("select t1.undeliqty,t1.deliedqty,t1.qty,t1.sa_orderitemsid from sa_orderitems t1 where t1.sa_orderitemsid in (select sa_orderitemsid from sa_dispatch_items where sa_dispatchid=" + sa_dispatchid + ")");
  714. RowsMap rowsMap = rowsOrderDetail.toRowsMap("sa_orderitemsid");
  715. Rows rowsDispatchDetail = dbConnect.runSqlQuery("select t1.qty,t1.sa_orderitemsid,t1.rowno,t2.itemname,t2.itemno from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where t1.sa_dispatchid=" + sa_dispatchid);
  716. Rows rowsDispatchDetailGroup = dbConnect.runSqlQuery("select sum(t1.qty) qty,t1.sa_orderitemsid,t1.siteid from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where t1.sa_dispatchid=" + sa_dispatchid + " group by t1.sa_orderitemsid,t1.siteid");
  717. Rows rowsDispatchAllDetail = dbConnect.runSqlQuery("select sum(t1.outwarehouseqty) sumoutwarehouseqty,t1.sa_orderitemsid from sa_dispatch_items t1 inner join sa_dispatch t2 on t1.sa_dispatchid=t2.sa_dispatchid and t1.siteid=t2.siteid where t2.status in('复核','关闭','手工关闭') and t1.sa_orderitemsid in(select sa_orderitemsid from sa_dispatch_items where sa_dispatchid="+sa_dispatchid+") group by t1.sa_orderitemsid");
  718. RowsMap rowsDispatchAllDetailMap = rowsDispatchAllDetail.toRowsMap("sa_orderitemsid");
  719. Rows rowscurrentDispatchDetail = dbConnect.runSqlQuery("select sum(t1.qty) qty,t1.sa_orderitemsid,t1.siteid,t2.itemno from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where t1.sa_dispatchid=" + sa_dispatchid + " group by t1.sa_orderitemsid,t1.siteid,t2.itemno");
  720. Rows rowsDispatchDetailGroupByItem = dbConnect.runSqlQuery("select sum(t1.qty) qty,t2.itemno,ifnull(t1.batchno,'') batchno,0 invbalqty from sa_dispatch_items t1 inner join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where t1.sa_dispatchid=" + sa_dispatchid + " group by t2.itemno,ifnull(t1.batchno,'')");
  721. RowsMap rowsMapDispatchDetailGroupByItem = rowsDispatchDetailGroupByItem.toRowsMap("itemno");
  722. if (siteid.equalsIgnoreCase("lsa") && Parameter.get(siteid, "dispatchinstock").equals("1")) {
  723. JSONObject object = new JSONObject();
  724. object.put("classname", "getIcinvbal");
  725. object.put("method", "getMsg");
  726. JSONObject content = new JSONObject();
  727. content.put("fitemnos", rowsDispatchDetail.toJsonArray("itemno"));
  728. object.put("content", content);
  729. WebRequest request = new WebRequest();
  730. String result = request.doPost(object.toString(),
  731. "http://60.190.151.198:8089/BYESB/jaxrs/webclientrest");
  732. JSONArray jsonArray = new JSONArray();
  733. if (isJSONArray(result)) {
  734. jsonArray = JSONArray.parseArray(result);
  735. }
  736. SQLFactory sqlFactory1 = new SQLFactory(this, "商品发货数量汇总");
  737. sqlFactory1.addParameter("siteid", siteid);
  738. sqlFactory1.addParameter_in("itemno", rowsDispatchDetail.toArrayList("itemno", new ArrayList<>()));
  739. Rows sumQtyRows = dbConnect.runSqlQuery(sqlFactory1);
  740. RowsMap sumQtyRowsMap = sumQtyRows.toRowsMap("itemno");
  741. for (Object obj : jsonArray) {
  742. JSONObject jsonObject = (JSONObject) obj;
  743. if (rowsMapDispatchDetailGroupByItem.containsKey(jsonObject.getString("fitemno"))) {
  744. if (rowsMapDispatchDetailGroupByItem.get(jsonObject.getString("fitemno")).isNotEmpty()) {
  745. rowsMapDispatchDetailGroupByItem.get(jsonObject.getString("fitemno")).get(0).put("invbalqty", jsonObject.getBigDecimalValue("FQty"));
  746. } else {
  747. rowsMapDispatchDetailGroupByItem.get(jsonObject.getString("fitemno")).get(0).put("invbalqty", 0);
  748. }
  749. }
  750. }
  751. for (Row row : rowsDispatchDetailGroupByItem) {
  752. if (sumQtyRowsMap.containsKey(row.getString("itemno"))) {
  753. row.put("delinvbalqty", (row.containsKey("invbalqty") ? row.getBigDecimal("invbalqty") : BigDecimal.ZERO).subtract(sumQtyRowsMap.get(row.getString("itemno")).get(0).getBigDecimal("qty")));
  754. } else {
  755. row.put("delinvbalqty", row.containsKey("invbalqty") ? row.getBigDecimal("invbalqty") : BigDecimal.ZERO);
  756. }
  757. if (row.getBigDecimal("qty").compareTo(row.getBigDecimal("delinvbalqty")) > 0) {
  758. return getErrReturnObject().setErrMsg("发货商品" + row.getString("itemno") + ",库存不足,无法操作复核!")
  759. .toString();
  760. }
  761. }
  762. }
  763. if (!siteid.equalsIgnoreCase("lsa") && Parameter.get(siteid, "dispatchinstock").equals("1")) {
  764. ERPDocking erpDocking = new ERPDocking(siteid);
  765. if (!erpDocking.getUrl().isEmpty()) {
  766. JSONArray jsonArray = erpDocking.getErpIcinvbalRows(200000, 1, rowsDispatchDetail.toJsonArray("itemno"));
  767. Rows rowsDispatchDetailBatchno = dbConnect.runSqlQuery("select t2.itemno,t1.batchno from sa_dispatch_items t1 inner join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where ifnull(t1.batchno,'')!='' and t1.sa_dispatchid=" + sa_dispatchid);
  768. for (Row row : rowsDispatchDetailBatchno) {
  769. JSONArray jsonArray1 = new JSONArray();
  770. jsonArray1.add(row.getString("itemno"));
  771. JSONArray jsonArrayBatch = erpDocking.getErpIcinvbalBatchRowsforbatchno(20000, 1, jsonArray1, row.getString("batchno"));
  772. if (jsonArrayBatch.isEmpty()) {
  773. return getErrReturnObject().setErrMsg(row.getString("itemno") + "批号有误,请重新选择!!")
  774. .toString();
  775. } else {
  776. if (rowsMapDispatchDetailGroupByItem.containsKey(row.getString("itemno"))) {
  777. if (rowsMapDispatchDetailGroupByItem.get(row.getString("itemno")).isNotEmpty()) {
  778. for (Row row1 : rowsMapDispatchDetailGroupByItem.get(row.getString("itemno"))) {
  779. if (row1.getString("batchno").equals(row.getString("batchno"))) {
  780. row1.put("invbalqty", ((JSONObject) jsonArrayBatch.get(0)).getBigDecimalValue("fqty"));
  781. }
  782. }
  783. }
  784. }
  785. }
  786. }
  787. SQLFactory sqlFactory1 = new SQLFactory(this, "商品发货数量汇总");
  788. sqlFactory1.addParameter("siteid", siteid);
  789. sqlFactory1.addParameter_in("itemno", rowsDispatchDetail.toArrayList("itemno", new ArrayList<>()));
  790. Rows sumQtyRows = dbConnect.runSqlQuery(sqlFactory1);
  791. RowsMap sumQtyRowsMap = sumQtyRows.toRowsMap("itemno");
  792. for (Object obj : jsonArray) {
  793. JSONObject jsonObject = (JSONObject) obj;
  794. if (rowsMapDispatchDetailGroupByItem.containsKey(jsonObject.getString("fitemno"))) {
  795. if (rowsMapDispatchDetailGroupByItem.get(jsonObject.getString("fitemno")).isNotEmpty()) {
  796. for (Row row : rowsMapDispatchDetailGroupByItem.get(jsonObject.getString("fitemno"))) {
  797. if (StringUtils.isBlank(row.getString("batchno"))) {
  798. row.put("invbalqty", jsonObject.getBigDecimalValue("fqty"));
  799. }
  800. }
  801. }
  802. }
  803. }
  804. logger.info("进入前:");
  805. for (Row row : rowsDispatchDetailGroupByItem) {
  806. if (sumQtyRowsMap.containsKey(row.getString("itemno"))) {
  807. RowsMap rowsMapByBatchno = sumQtyRowsMap.get(row.getString("itemno")).toRowsMap("batchno");
  808. if (rowsMapByBatchno.containsKey(row.getString("batchno"))) {
  809. for (Row row1 : sumQtyRowsMap.get(row.getString("itemno"))) {
  810. if (row.getString("batchno").equals(row1.getString("batchno"))) {
  811. row.put("delinvbalqty", (row.containsKey("invbalqty") ? row.getBigDecimal("invbalqty") : BigDecimal.ZERO).subtract(row1.getBigDecimal("qty")));
  812. }
  813. }
  814. } else {
  815. row.put("delinvbalqty", row.containsKey("invbalqty") ? row.getBigDecimal("invbalqty") : BigDecimal.ZERO);
  816. }
  817. } else {
  818. row.put("delinvbalqty", row.containsKey("invbalqty") ? row.getBigDecimal("invbalqty") : BigDecimal.ZERO);
  819. }
  820. JSONObject response =new JSONObject();
  821. response.put("sumQtyRows",sumQtyRows);
  822. response.put("rowsDispatchDetailGroupByItem",rowsDispatchDetailGroupByItem);
  823. response.put("errcode",0);
  824. logger.info("进入后:");
  825. if (row.getBigDecimal("qty").compareTo(row.getBigDecimal("delinvbalqty")) > 0) {
  826. logger.info("response:"+response);
  827. erpDocking.saveLog(this, "sa_dispatch", sa_dispatchid, "发货单复核", "", response, dispatchRows.get(0).getString("billno"));
  828. return getErrReturnObject().setErrMsg("发货商品" + row.getString("itemno") + ",库存不足,无法操作复核!")
  829. .toString();
  830. }else{
  831. logger.info("response:"+response);
  832. erpDocking.saveLog(this, "sa_dispatch", sa_dispatchid, "发货单复核", "", response, dispatchRows.get(0).getString("billno"));
  833. }
  834. }
  835. }
  836. }
  837. if (!rowscurrentDispatchDetail.isEmpty()) {
  838. for (Row row : rowscurrentDispatchDetail) {
  839. if (row.getBigDecimal("qty").compareTo(rowsMap.get(row.getString("sa_orderitemsid")).get(0).getBigDecimal("undeliqty")) == 1) {
  840. return getErrReturnObject().setErrMsg("【" + row.getString("itemno") + "】的发货单明细的发货数量超过未发量,无法复核")
  841. .toString();
  842. }
  843. }
  844. }
  845. if (!rowsDispatchDetail.isEmpty()) {
  846. for (Row row : rowsDispatchDetail) {
  847. if (rowsMap.get(row.getString("sa_orderitemsid")).isEmpty()) {
  848. return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细不存在对应得订单行,无法复核")
  849. .toString();
  850. }
  851. if (row.getBigDecimal("qty").compareTo(BigDecimal.ZERO) != 1) {
  852. return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细的数量小于等于0,无法复核")
  853. .toString();
  854. }
  855. if (row.getBigDecimal("qty").compareTo(rowsMap.get(row.getString("sa_orderitemsid")).get(0).getBigDecimal("undeliqty")) == 1) {
  856. return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细的数量大于对应订单行的未发货数量,无法复核")
  857. .toString();
  858. }
  859. if (!rowsDispatchAllDetailMap.get(row.getString("sa_orderitemsid")).isEmpty()) {
  860. if ((row.getBigDecimal("qty").add(rowsDispatchAllDetailMap.get(row.getString("sa_orderitemsid")).get(0).getBigDecimal("sumoutwarehouseqty"))).compareTo(rowsMap.get(row.getString("sa_orderitemsid")).get(0).getBigDecimal("qty")) == 1) {
  861. return getErrReturnObject().setErrMsg("行号为:【" + row.getString("rowno") + "】的发货单明细的总出库数量大于对应订单行的数量,无法复核")
  862. .toString();
  863. }
  864. }
  865. //logger.info(new Date() +"复核测试:"+"update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").subtract(row.getBigDecimal("qty")) + ",deliedqty=" + (row.getBigDecimal("qty").add(rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  866. //sqlList.add("update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").subtract(row.getBigDecimal("qty")) + ",deliedqty=" + (row.getBigDecimal("qty").add(rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  867. }
  868. } else {
  869. return getErrReturnObject().setErrMsg("该发货单明细不存在,无法复核").toString();
  870. }
  871. Rows rows = dbConnect.runSqlQuery("select t1.*,t3.agentnum,t2.enterprisename,t4.sonum,t5.name,t5.phonenumber,t5.address from sa_dispatch t1 left join sys_enterprise t2 on t1.sys_enterpriseid=t2.sys_enterpriseid and t1.siteid=t2.siteid left join sa_agents t3 on t1.sys_enterpriseid=t3.sys_enterpriseid and t1.siteid=t3.siteid left join sa_order t4 on t1.sa_orderid=t4.sa_orderid and t1.siteid=t4.siteid left join sys_enterprise_contacts t5 on t1.rec_contactsid=t5.contactsid and t1.siteid=t5.siteid where t1.sa_dispatchid ='"
  872. + sa_dispatchid + "' and t1.siteid='" + siteid + "'");
  873. Rows rowsdetail = dbConnect.runSqlQuery("select t3.sonum,t2.rowno sorowno,t4.itemno,t1.batchno,t1.rowno,t1.qty,t2.price,t1.remarks from sa_dispatch_items t1 left join sa_orderitems t2 on t1.sa_orderitemsid=t2.sa_orderitemsid and t1.siteid=t2.siteid left join sa_order t3 on t2.sa_orderid=t3.sa_orderid and t2.siteid=t3.siteid left join plm_item t4 on t1.itemid=t4.itemid and t1.siteid=t4.siteid where t1.sa_dispatchid ='"
  874. + sa_dispatchid + "' and t1.siteid='" + siteid + "'");
  875. SQLFactory sqlFactoryupdate = new SQLFactory(this, "发货单复核");
  876. Rows orderRows = dbConnect.runSqlQuery("select distinct t1.sa_orderid from sa_orderitems t1 inner join sa_dispatch_items t2 on t1.siteid=t2.siteid and t1.sa_orderitemsid=t2.sa_orderitemsid where t1.siteid='" + siteid + "' and t2.sa_dispatchid=" + sa_dispatchid);
  877. if (orderRows.size() == 1) {
  878. sqlList.add("update sa_dispatch set sa_orderid=" + orderRows.get(0).getLong("sa_orderid") + " where siteid='" + siteid + "' and sa_dispatchid=" + sa_dispatchid);
  879. }
  880. //对接erp生成erp发货单
  881. if (Parameter.get("system.ccerp_dockswitch").equalsIgnoreCase("true")) {
  882. ERPDocking erpDocking = new ERPDocking(siteid);
  883. if (!erpDocking.getUrl().isEmpty()) {
  884. String result = erpDocking.createErpSainvoice(rows.get(0), rowsdetail, this, sa_dispatchid);
  885. if (!result.equals("true")) {
  886. System.out.println(result);
  887. return getErrReturnObject().setErrMsg(result).toString();
  888. }
  889. }
  890. }
  891. //对接erp成功后统一更新订单数量
  892. for (Row row : rowsDispatchDetailGroup) {
  893. logger.info(new Date() + "复核测试:" + "update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").subtract(row.getBigDecimal("qty")) + ",deliedqty=" + (row.getBigDecimal("qty").add(rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  894. sqlList.add("update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").subtract(row.getBigDecimal("qty")) + ",deliedqty=" + (row.getBigDecimal("qty").add(rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  895. }
  896. // //判断当前订单是否已发完货,如果发完,则生把订单变为关闭状态
  897. // //总数量
  898. // Rows totalRows = dbConnect.runSqlQuery("select count(1) count,sa_orderid from sa_orderitems where siteid='" + siteid + "' group by sa_orderid");
  899. // RowsMap totalRowsMap=totalRows.toRowsMap("sa_orderid");
  900. // //已发完数量
  901. // Rows deliRows = dbConnect.runSqlQuery("select count(1) count,sa_orderid from sa_orderitems where undeliqty=0 and siteid='" + siteid + "' group by sa_orderid");
  902. // RowsMap deliRowsMap=deliRows.toRowsMap("sa_orderid");
  903. // for (Row row:orderRows) {
  904. // if(totalRowsMap.containsKey(row.getString("sa_orderid")) && deliRowsMap.containsKey(row.getString("sa_orderid"))){
  905. // if (totalRowsMap.get(row.getString("sa_orderid")).get(0).getLong("count") ==deliRowsMap.get(row.getString("sa_orderid")).get(0).getLong("count")) {
  906. // dbConnect.runSqlUpdate("update sa_order set status='关闭' where sa_orderid=" + row.getLong("sa_orderid") + " and siteid='" + siteid + "'");
  907. // }
  908. // }
  909. // }
  910. // Executor.sendEml(this, "dispatchreccheck", sa_dispatchid,new ArrayList<>());
  911. sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "复核", "发货单复核成功").getSQL());
  912. sqlFactoryupdate.addParameter("siteid", siteid);
  913. sqlFactoryupdate.addParameter("sa_dispatchid", sa_dispatchid);
  914. sqlFactoryupdate.addParameter("recheckby", username);
  915. sqlList.add(sqlFactoryupdate.getSQL());
  916. dbConnect.runSqlUpdate(sqlList);
  917. Long sys_enterpriseid = rows.get(0).getLong("sys_enterpriseid");
  918. String message = "您的发货单" + rows.get(0).getString("billno") + "已复核,请及时查看!";
  919. sendMsg(message, sa_dispatchid, sys_enterpriseid);
  920. return getSucReturnObject().toString();
  921. }
  922. @API(title = "反复核", apiversion = R.ID20230720152503.v1.class)
  923. @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, dispatch.class, dispatchItems.class, cashbill.class})
  924. public String unrecheck() throws YosException {
  925. //通过版本更新发货单表头数据
  926. Dispatch.updateDispatchWithVersion(this);
  927. Long sa_dispatchid = content.getLong("sa_dispatchid");
  928. Rows dispatchRows = dbConnect.runSqlQuery("select sa_dispatchid,status,billno,sa_orderid,sys_enterpriseid from sa_dispatch where sa_dispatchid ='"
  929. + sa_dispatchid + "' and siteid='" + siteid + "'");
  930. if (dispatchRows.isEmpty()) {
  931. return getErrReturnObject().setErrMsg("该发货单不存在")
  932. .toString();
  933. } else {
  934. if (!dispatchRows.get(0).getString("status").equals("复核")) {
  935. return getErrReturnObject().setErrMsg("单号为:【" + dispatchRows.get(0).getString("billno") + "】的发货单为非复核状态,无法反复核")
  936. .toString();
  937. }
  938. }
  939. if (siteid.equalsIgnoreCase("lsa")) {
  940. JSONObject object = new JSONObject();
  941. object.put("classname", "getIcinvbal");
  942. object.put("method", "getSainvoiceMsg");
  943. JSONObject content = new JSONObject();
  944. content.put("billno", dispatchRows.get(0).getString("billno"));
  945. object.put("content", content);
  946. WebRequest request = new WebRequest();
  947. String result = request.doPost(object.toString(),
  948. "http://60.190.151.198:8089/BYESB/jaxrs/webclientrest");
  949. if (result.equals("true")) {
  950. return getErrReturnObject().setErrMsg("K3发货单为非删除状态,无法反复核")
  951. .toString();
  952. }
  953. }
  954. ArrayList<String> sqlList = new ArrayList<>();
  955. Rows rowsOrderDetail = dbConnect.runSqlQuery("select t1.undeliqty,t1.deliedqty,t1.qty,t1.sa_orderitemsid from sa_orderitems t1 where t1.sa_orderitemsid in (select sa_orderitemsid from sa_dispatch_items where sa_dispatchid=" + sa_dispatchid + ")");
  956. RowsMap rowsMap = rowsOrderDetail.toRowsMap("sa_orderitemsid");
  957. Rows rowsDispatchDetail = dbConnect.runSqlQuery("select t1.qty,t1.outwarehouseqty,t1.sa_orderitemsid,t1.rowno,t2.itemname from sa_dispatch_items t1 left join plm_item t2 on t1.itemid=t2.itemid and t1.siteid=t2.siteid where t1.sa_dispatchid=" + sa_dispatchid);
  958. if (!rowsDispatchDetail.isEmpty()) {
  959. for (Row row : rowsDispatchDetail) {
  960. sqlList.add("update sa_orderitems set undeliqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("undeliqty").add(row.getBigDecimal("qty").subtract(row.getBigDecimal("outwarehouseqty"))) + ",deliedqty=" + rowsMap.get(row.getLong("sa_orderitemsid")).get(0).getBigDecimal("deliedqty").subtract(row.getBigDecimal("qty").subtract(row.getBigDecimal("outwarehouseqty"))) + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
  961. }
  962. } else {
  963. return getErrReturnObject().setErrMsg("该发货单明细不存在,无法复核").toString();
  964. }
  965. SQLFactory sqlFactoryupdate = new SQLFactory(this, "发货单复核");
  966. Rows orderRows = dbConnect.runSqlQuery("select distinct t1.sa_orderid from sa_orderitems t1 inner join sa_dispatch_items t2 on t1.siteid=t2.siteid and t1.sa_orderitemsid=t2.sa_orderitemsid where t1.siteid='" + siteid + "' and t2.sa_dispatchid=" + sa_dispatchid);
  967. sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "反复核", "发货单反复核成功").getSQL());
  968. sqlFactoryupdate.addParameter("siteid", siteid);
  969. sqlFactoryupdate.addParameter("sa_dispatchid", sa_dispatchid);
  970. sqlFactoryupdate.addParameter("recheckby", username);
  971. sqlList.add(sqlFactoryupdate.getSQL());
  972. dbConnect.runSqlUpdate(sqlList);
  973. Long sys_enterpriseid = dispatchRows.get(0).getLong("sys_enterpriseid");
  974. String message = "您的发货单" + dispatchRows.get(0).getString("billno") + "已复核,请及时查看!";
  975. sendMsg(message, sa_dispatchid, sys_enterpriseid);
  976. return getSucReturnObject().toString();
  977. }
  978. @API(title = "一键生成发货单", apiversion = R.ID20230220100604.v1.class)
  979. @CACHEING_CLEAN(apiversions = {R.ID20221114135303.v1.class, R.ID20221114135403.v1.class, R.ID20230320160203.v1.class})
  980. public String generatedispatch() throws YosException {
  981. Long sa_orderid = content.getLong("sa_orderid");
  982. JSONArray sa_orderitemsids = content.getJSONArray("sa_orderitemsids");
  983. Rows orderRows = dbConnect.runSqlQuery("select freightstatus,sys_enterpriseid,rec_contactsid,status,remarks from sa_order where siteid='" + siteid + "' and sa_orderid=" + sa_orderid);
  984. if (orderRows.isEmpty()) {
  985. return getErrReturnObject().setErrMsg("订单无效").toString();
  986. }
  987. if (!orderRows.get(0).getString("status").equals("审核") && !orderRows.get(0).getString("status").equals("关闭")) {
  988. return getErrReturnObject().setErrMsg("非审核后订单无法生成发货单").toString();
  989. }
  990. ArrayList<String> sqlList = new ArrayList<>();
  991. long sa_dispatchid = createTableID("sa_dispatch");
  992. String billCode = createBillCode("dispatchbill");
  993. SQLFactory sqlFactory = new SQLFactory(this, "发货单新增");
  994. sqlFactory.addParameter("siteid", siteid);
  995. sqlFactory.addParameter("userid", userid);
  996. sqlFactory.addParameter("username", username);
  997. sqlFactory.addParameter("sa_dispatchid", sa_dispatchid);
  998. sqlFactory.addParameter("billno", billCode);
  999. sqlFactory.addParameter("sys_enterpriseid", orderRows.get(0).getLong("sys_enterpriseid"));
  1000. sqlFactory.addParameter("rec_contactsid", orderRows.get(0).getLong("rec_contactsid"));
  1001. //sqlFactory.addParameter("sa_logiscompid", orderRows.get(0).getLong("sa_logiscompid"));
  1002. sqlFactory.addParameter("sa_orderid", sa_orderid);
  1003. sqlFactory.addParameter("remarks", orderRows.get(0).getString("remarks"));
  1004. sqlFactory.addParameter("freightstatus", orderRows.get(0).getString("freightstatus"));
  1005. sqlFactory.addParameter("billdate", now());
  1006. sqlList.add(sqlFactory.getSQL());
  1007. // RowsMap orderitemsRowsMap = dbConnect.runSqlQuery("select itemid,itemno,qty,sa_orderitemsid,sa_orderid,remarks from sa_orderitems where siteid='" + siteid + "' and sa_orderid=" + sa_orderid).toRowsMap("sa_orderitemsid");
  1008. // RowsMap dispatchitemsRowsMap;
  1009. // if (dbConnect.runSqlQuery("select 1 from sys_site_parameter where siteid='" + siteid + "' and dispatch_recheck=1").isEmpty()) {
  1010. // dispatchitemsRowsMap = dbConnect.runSqlQuery("select sa_orderid,sa_orderitemsid,ifnull(sum(qty),0) qty from sa_dispatch t1 inner join sa_dispatch_items t2 on t1.siteid=t2.siteid and t1.sa_dispatchid=t2.sa_dispatchid where t1.siteid='" + siteid + "' and t1.status in ('审核','关闭') group by t1.sa_orderid,t2.sa_orderitemsid").toRowsMap("sa_orderitemsid");
  1011. // } else {
  1012. // dispatchitemsRowsMap = dbConnect.runSqlQuery("select sa_orderid,sa_orderitemsid,ifnull(sum(qty),0) qty from sa_dispatch t1 inner join sa_dispatch_items t2 on t1.siteid=t2.siteid and t1.sa_dispatchid=t2.sa_dispatchid where t1.siteid='" + siteid + "' and t1.status in ('复核','关闭') group by t1.sa_orderid,t2.sa_orderitemsid").toRowsMap("sa_orderitemsid");
  1013. // }
  1014. Rows orderitemsRows = dbConnect.runSqlQuery("select itemid,itemno,sa_orderitemsid,undeliqty,remarks,customproperties from sa_orderitems where siteid='" + siteid + "' and sa_orderitemsid in " + sa_orderitemsids.toString().replace("[", "(").replace("]", ")"));
  1015. Long rowno = 1L;
  1016. for (Row row : orderitemsRows) {
  1017. String sa_orderitemsid = row.getString("sa_orderitemsid");
  1018. BigDecimal qty = row.getBigDecimal("undeliqty");
  1019. if (qty.compareTo(new BigDecimal("0")) < 1) {
  1020. continue;
  1021. }
  1022. // if (orderitemsRowsMap.containsKey(sa_orderitemsid)) {
  1023. // Rows orderitemsRows = orderitemsRowsMap.get(sa_orderitemsid);
  1024. // qty = orderitemsRows.get(0).getBigDecimal("qty");
  1025. // if (dispatchitemsRowsMap.containsKey(sa_orderitemsid)) {
  1026. // RowsMap dispatchRowsMap = dispatchitemsRowsMap.get(sa_orderitemsid).toRowsMap("sa_orderid");
  1027. // if (dispatchRowsMap.containsKey(sa_orderid.toString())) {
  1028. // Rows orderitemRows = dispatchRowsMap.get(sa_orderid.toString());
  1029. // if (orderitemsRows.get(0).getBigDecimal("qty").compareTo(orderitemRows.get(0).getBigDecimal("qty")) < 1) {
  1030. // continue;
  1031. // } else {
  1032. // qty = qty.subtract(orderitemRows.get(0).getBigDecimal("qty"));
  1033. // }
  1034. // }
  1035. // }
  1036. sqlFactory = new SQLFactory(this, "发货单明细新增");
  1037. sqlFactory.addParameter("siteid", siteid);
  1038. sqlFactory.addParameter("sa_dispatch_itemsid", createTableID("sa_dispatch_items"));
  1039. sqlFactory.addParameter("sa_dispatchid", sa_dispatchid);
  1040. sqlFactory.addParameter("rowno", rowno);
  1041. sqlFactory.addParameter("billno", billCode);
  1042. rowno++;
  1043. sqlFactory.addParameter("sa_orderitemsid", sa_orderitemsid);
  1044. sqlFactory.addParameter("itemid", row.getLong("itemid"));
  1045. sqlFactory.addParameter("qty", qty);
  1046. sqlFactory.addParameter("batchcontrol", 0);
  1047. sqlFactory.addParameter("batchno", "");
  1048. String remarks = row.getString("customproperties");
  1049. if (!row.getString("remarks").isEmpty()) {
  1050. remarks = remarks + " 备注:" + row.getString("remarks");
  1051. }
  1052. sqlFactory.addParameter("remarks", remarks);
  1053. sqlFactory.addParameter("userid", userid);
  1054. sqlFactory.addParameter("username", username);
  1055. sqlList.add(sqlFactory.getSQL());
  1056. // }
  1057. }
  1058. sqlList.add(DataContrlLog.createLog(this, "sa_dispatch", sa_dispatchid, "一键发货", "一键发货").getSQL());
  1059. dbConnect.runSqlUpdate(sqlList);
  1060. content.put("sa_dispatchid", sa_dispatchid);
  1061. return queryDispatchMain();
  1062. }
  1063. public void sendMsg(String content, Long sa_dispatchid, Long sys_enterpriseid) throws YosException {
  1064. ArrayList<Long> userList = getEnterpriseHrs(sys_enterpriseid).toArrayList("userid", new ArrayList<>());
  1065. Remind remind = new Remind(this);
  1066. remind.setTitle("发货单消息");
  1067. remind.setContent(content);
  1068. remind.setType("应用");
  1069. remind.setObjectid(sa_dispatchid);
  1070. remind.setObjectname("sa_dispatch");
  1071. remind.setTouserid(userList);
  1072. remind.sendByDialogMsg().createSys_message();
  1073. }
  1074. @API(title = "查询erp对接记录", apiversion = R.ID20230228133403.v1.class)
  1075. @CACHEING
  1076. public String queryErpupdatelog() throws YosException {
  1077. Long sa_dispatchid = content.getLong("sa_dispatchid");
  1078. SQLFactory sqlFactory = new SQLFactory(this, "发货单erp对接记录", pageSize, pageNumber, pageSorting);
  1079. sqlFactory.addParameter("siteid", siteid);
  1080. sqlFactory.addParameter("sa_dispatchid", sa_dispatchid);
  1081. Rows rows = dbConnect.runSqlQuery(sqlFactory.getSQL());
  1082. return getSucReturnObject().setData(rows).toString();
  1083. }
  1084. private void sendRemind(Long sys_enterpriseid, Long sa_dispatchid) throws YosException {
  1085. Rows rows1 = dbConnect.runSqlQuery("select userid from sys_enterprise_hr where siteid='" + siteid + "' and sys_enterpriseid=" + sys_enterpriseid);
  1086. HashMap<String, Object> extradata = new HashMap<>();
  1087. extradata.put("extraUserList", rows1.toArrayList("userid", new ArrayList<Long>()));
  1088. Executor.sendEml(this, "dispatch_close", sa_dispatchid, siteid, extradata);
  1089. }
  1090. }