123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554 |
- package restcontroller.webmanage.sale.order;
- import beans.accountbalance.Accountbalance;
- import beans.accountbalance.CashbillEntity;
- import beans.brand.Brand;
- import beans.customscheme.CustomScheme;
- import beans.datacontrllog.DataContrlLog;
- import beans.enterprise.Enterprise;
- import beans.itemprice.ItemPrice;
- import beans.parameter.Parameter;
- import beans.uploaderpdata.UploadDataToERP;
- import com.alibaba.fastjson.JSONArray;
- import com.alibaba.fastjson.JSONObject;
- import common.Controller;
- import common.DataFunction;
- import common.YosException;
- import common.annotation.API;
- import common.annotation.CACHEING;
- import common.annotation.CACHEING_CLEAN;
- import common.data.*;
- import io.reactivex.internal.observers.ForEachWhileObserver;
- import org.apache.commons.lang.StringUtils;
- import restcontroller.R;
- import restcontroller.webmanage.sale.aftersalesmag.twriteoffbill_orderchange;
- import restcontroller.webmanage.sale.rebate.Rebate;
- import restcontroller.webmanage.sale.toolbill.ToolBill;
- import utility.ERPDocking;
- import utility.tools.WebRequest;
- import java.io.IOException;
- import java.math.BigDecimal;
- import java.util.ArrayList;
- import java.util.HashMap;
- import static beans.order.Order.*;
- /**
- * 销售订单商品明细表
- */
- public class OrderItems extends Controller {
- /**
- * 构造函数
- *
- * @param content
- */
- public OrderItems(JSONObject content) throws YosException {
- super(content);
- }
- @API(title = "新增或更新", apiversion = R.ID20221109093602.v1.class, intervaltime = 200)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, ToolBill.class})
- public String insertOrUpdate() throws YosException {
- Long sa_orderid = content.getLong("sa_orderid");
- Long sys_enterpriseid = content.getLong("sys_enterpriseid");
- JSONArray items = content.getJSONArray("items");
- //辅助类
- OrderItemsHelper orderItemsHelper = new OrderItemsHelper(this);
- ArrayList<String> sqlList = new ArrayList<>();
- Rows orderRows = getOrderRows(this, sa_orderid);
- if (orderRows.isEmpty()) {
- return getErrReturnObject().setErrMsg("数据不存在,无法添加").toString();
- } else {
- if (!orderRows.get(0).getString("status").equals("新建") && !orderRows.get(0).getString("status").equals("预提交")) {
- return getErrReturnObject().setErrMsg("非新建或预提交状态无法操作").toString();
- }
- }
- //通过版本更新订单表头数据
- beans.order.Order.updateOrderWithVersion(this);
- String type = orderRows.get(0).getString("type");
- Long sa_promotionid = orderRows.get(0).getLong("sa_promotionid");
- //查询活动
- Rows promotionitems = dbConnect.runSqlQuery("select * from sa_promotion_items where siteid='" + siteid + "' and sa_promotionid=" + sa_promotionid);
- //批量查询商品信息
- RowsMap itemRowsMap = orderItemsHelper.getItemRowsMap(items);
- BigDecimal sumqty = BigDecimal.ZERO;
- for (Object obj : items) {
- JSONObject item = (JSONObject) obj;
- Long itemid = item.getLong("itemid");
- Long sa_orderitemsid = item.getLong("sa_orderitemsid");
- BigDecimal qty = item.getBigDecimalValue("qty");
- sumqty = sumqty.add(qty);
- //商品信息
- Row itemRow = getItemRow(itemid);
- long width = itemRow.getLong("width");
- long length = itemRow.getLong("length");
- if (item.containsKey("width")) {
- width = Long.parseLong(item.getString("width"));
- }
- if (item.containsKey("length")) {
- length = Long.parseLong(item.getString("length"));
- }
- if (sa_promotionid > 0 && dbConnect.runSqlQuery("SELECT 1 from sa_promotion_items WHERE islimit=1 and groupqty <= saledqty and itemid=" + itemid + " and siteid='" + siteid + "' and sa_promotionid='" + sa_promotionid + "'").isNotEmpty()) {
- return getErrReturnObject().setErrMsg("商品【" + itemRow.getString("itemno") + "】已售罄,不能添加。").toString();
- }
- BigDecimal price1 = new BigDecimal(0);
- // SQLFactory sqlFactory = new SQLFactory(this, "订单商品明细_新增");
- Boolean isInsert = true;
- JSONArray customproperties = new JSONArray();
- String spec = "";
- if (sa_orderitemsid <= 0) {
- //获取定制属性
- customproperties = orderItemsHelper.getCustomProperties(itemRowsMap, item);
- if (itemRow.getString("iscustomsize").equals("1") && customproperties.isEmpty()) {
- return getErrReturnObject().setErrMsg(itemRow.getString("itemno") + "的定制信息为空,无法添加").toString();
- }
- spec = orderItemsHelper.getCustomSpec(itemRowsMap, item);
- Rows rows = dbConnect.runSqlQuery("SELECT sa_orderitemsid,price from sa_orderitems WHERE siteid='" + siteid + "' and itemid=" + itemid + " and sa_orderid=" + sa_orderid + " and sa_promotion_itemsid=" + item.getLongValue("sa_promotion_itemsid"));
- if (rows.isEmpty()) {
- sa_orderitemsid = createTableID("sa_orderitems");
- } else {
- //System.out.println(beans.order.Order.getDefaultIsRepeatValue(siteid, type));
- if (beans.order.Order.getDefaultIsRepeatValue(siteid, type)) {
- sa_orderitemsid = createTableID("sa_orderitems");
- isInsert = true;
- } else {
- price1 = rows.get(0).getBigDecimal("price");
- sa_orderitemsid = rows.get(0).getLong("sa_orderitemsid");
- isInsert = false;
- }
- }
- } else {
- Rows rows = dbConnect.runSqlQuery("SELECT sa_orderitemsid,price from sa_orderitems WHERE siteid='" + siteid + "' and sa_orderitemsid=" + sa_orderitemsid);
- if (rows.isNotEmpty()) {
- price1 = rows.get(0).getBigDecimal("price");
- }
- isInsert = false;
- }
- if (!isInsert) {
- if (dbConnect.runSqlQuery("SELECT 1 from sa_orderitems WHERE itemid=" + itemid + " and sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'").isEmpty()) {
- continue;
- }
- }
- //是否符合商品起订量和增量判断
- orderItemsHelper.compareQty(type, itemRowsMap, item, itemRow, promotionitems);
- BigDecimal defaultprice;
- BigDecimal price;
- BigDecimal saleprice;
- //价格
- ItemPrice itemPrice = ItemPrice.getItemPrice(this, sys_enterpriseid, itemid);
- if (!item.containsKey("defaultprice")) {
- defaultprice = orderItemsHelper.getDefaultprice(itemPrice);
- price = orderItemsHelper.getPrice(orderRows.get(0), itemPrice, item, itemRowsMap,siteid);
- saleprice = orderItemsHelper.getSalePrice(orderRows.get(0), itemPrice,item,itemRowsMap);
- } else {
- defaultprice = item.getBigDecimalValue("defaultprice");
- price = item.getBigDecimalValue("price");
- saleprice = orderItemsHelper.getSalePrice(orderRows.get(0), itemPrice,item,itemRowsMap);
- if (price.compareTo(price1) != 0) {
- sqlList.add(DataContrlLog.createLog(this, "sa_order", sa_orderid, "订单商品【" + itemRow.getString("itemname") + "】由单价:" + price1 + "修改为单价:" + price, "订单修改单价").getSQL());
- }
- }
- if (price.compareTo(BigDecimal.ZERO) < 0) {
- return getErrReturnObject().setErrMsg("价格不可小于0").toString();
- }
- if (isInsert) {
- sqlList.add(orderItemsHelper.getInsertSQL(customproperties, sa_orderitemsid, item, itemRow, type, defaultprice, price, saleprice, itemPrice.getMarketprice(), spec, promotionitems, width, length).getSQL());
- } else {
- sqlList.add(orderItemsHelper.getUpdateSQL(sa_orderitemsid, item, itemRow, type, defaultprice, price, saleprice, width, length).getSQL());
- }
- }
- if (type.equals("促销订单")) {
- Rows promotionRows = dbConnect.runSqlQuery("select * from sa_promotion where siteid='" + siteid + "' and sa_promotionid=" + sa_promotionid);
- if (!promotionRows.isEmpty()) {
- if (promotionRows.get(0).getString("type").equals("打包促销")) {
- BigDecimal orderaddqty = promotionRows.get(0).getBigDecimal("orderaddqty");
- BigDecimal orderminqty = promotionRows.get(0).getBigDecimal("orderminqty");
- if (((sumqty.subtract(orderminqty)).remainder(orderaddqty)).compareTo(BigDecimal.ZERO) != 0 || sumqty.compareTo(orderminqty) < 0) {
- return getErrReturnObject().setErrMsg("不符合促销活动订购数量规则,修改不成功").toString();
- }
- }
- }
- }
- dbConnect.runSqlUpdate(sqlList);
- //重新排序
- updateRowNo(sa_orderid);
- //居间费设置
- updateRebateFee(sa_orderid);
- //调整价格(返利金)
- if (orderRows.get(0).getBoolean("rebate_used")) {
- setRebateAmount(this, sa_orderid, getMaxUsedRebateAmount(this, sa_orderid));
- adjustLastRebateAmount(this, sa_orderid);
- }
- //更新订单扣款信息
- updateAccountclassinfos(sa_orderid);
- //查询商品费用方案方法
- orderItemsHelper.executeDataFunction(sa_orderid);
- //生成摘要
- SQLFactory sqlFactory = new SQLFactory(this, "查询定制费用统计");
- sqlFactory.addParameter("sa_orderid", sa_orderid);
- Rows rows = dbConnect.runSqlQuery(sqlFactory);
- if (rows.isNotEmpty()) {
- String remarks = StringUtils.join(rows.toArray("remarks"), ";");
- dbConnect.runSqlUpdate("UPDATE sa_order set abstract ='" + remarks + "' WHERE sa_orderid='" + sa_orderid + "'");
- } else {
- dbConnect.runSqlUpdate("UPDATE sa_order set abstract ='' WHERE sa_orderid='" + sa_orderid + "'");
- }
- if (systemclient.equalsIgnoreCase("wechatsaletool")) {
- rows = dbConnect.runSqlQuery("SELECT sa_orderitemsid,sa_orderitems_v,itemid from sa_orderitems WHERE sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'");
- return getSucReturnObject().setData(rows).toString();
- }
- return getSucReturnObject().toString();
- }
- @API(title = "查询订单重复商品", apiversion = R.ID2024020201095102.v1.class)
- public String get() throws YosException {
- Long sa_orderid = content.getLongValue("sa_orderid");
- JSONArray items = content.getJSONArray("items");
- OrderItemsHelper orderItemsHelper = new OrderItemsHelper(this);
- //批量查询商品信息
- RowsMap itemRowsMap = orderItemsHelper.getItemRowsMap(items);
- Rows rows = new Rows();
- for (Object obj : items) {
- JSONObject item = (JSONObject) obj;
- Long itemid = item.getLongValue("itemid");
- JSONArray customproperties = new JSONArray();
- customproperties = orderItemsHelper.getCustomProperties(itemRowsMap, item);
- String custompropertie = customproperties.toJSONString().replace("[", "").replace("]", "").replace("\"", "");
- Rows temprows = dbConnect.runSqlQuery("SELECT itemname from sa_orderitems WHERE sa_orderid=" + sa_orderid + " and siteid='" + siteid + "' and itemid=" + itemid + " and ifnull(customproperties,'')='" + custompropertie + "'");
- rows.addAll(temprows);
- }
- Rows orderRows = beans.order.Order.getOrderRows(this, sa_orderid);
- String type = orderRows.get(0).getString("type");
- Row resRow = new Row();
- resRow.put("items", rows);
- resRow.put("isrepeat", beans.order.Order.getDefaultIsRepeatValue(siteid, type));
- return getSucReturnObject().setData(resRow).toString();
- }
- /**
- * 更新订单扣款信息
- */
- public String updateAccountclassinfos(Long sa_orderid) throws YosException {
- Rows orderRows = getOrderRows(this, sa_orderid);
- if (orderRows.isEmpty()) {
- return "订单不存在";
- }
- String type = "";
- Rows promotionrows = dbConnect.runSqlQuery("select * from sa_promotion where siteid='" + siteid + "' and sa_promotionid=" + orderRows.get(0).getLong("sa_promotionid"));
- Rows promotionenterpriserows = dbConnect.runSqlQuery("select * from sa_promotion_auth where siteid='" + siteid + "'and sys_enterpriseid=" + orderRows.get(0).getLong("pay_enterpriseid") + " and sa_promotionid=" + orderRows.get(0).getLong("sa_promotionid"));
- if (promotionrows.isNotEmpty()) {
- type = promotionrows.get(0).getString("type");
- }
- JSONArray jsonArray = new JSONArray();
- BigDecimal orderamount = getAmount(this, sa_orderid);
- //System.out.println(orderamount);
- Rows accountclassrows = dbConnect.runSqlQuery("select t1.*,ifnull(t2.balance,0) balance,ifnull(t2.creditquota,0) creditquota from sa_accountclass t1 left join sa_accountbalance t2 on t1.sa_accountclassid=t2.sa_accountclassid and t1.siteid=t2.siteid and t2.sys_enterpriseid=" + orderRows.get(0).getLong("pay_enterpriseid") + " where isused=1 and t1.siteid='" + siteid + "' and t1.sa_accountclassid=" + orderRows.get(0).getLong("sa_accountclassid"));
- if (accountclassrows.isEmpty()) {
- return "未找到扣款账户";
- }
- JSONObject jsonObject = new JSONObject();
- if (type.equals("返利促销")) {
- BigDecimal associationamount = promotionrows.get(0).getBigDecimal("associationamount");
- long associationaccountclassid = promotionrows.get(0).getLong("associationaccountclassid");
- Rows associationaccountclassrows = dbConnect.runSqlQuery("select t1.*,ifnull(t2.balance,0) balance,ifnull(t2.creditquota,0) creditquota from sa_accountclass t1 left join sa_accountbalance t2 on t1.sa_accountclassid=t2.sa_accountclassid and t1.siteid=t2.siteid and t2.sys_enterpriseid=" + orderRows.get(0).getLong("pay_enterpriseid") + " where isused=1 and t1.siteid='" + siteid + "' and t1.sa_accountclassid=" + associationaccountclassid);
- if (promotionenterpriserows.isNotEmpty()) {
- if (promotionenterpriserows.get(0).getBoolean("islimit")) {
- BigDecimal limitamount = promotionenterpriserows.get(0).getBigDecimal("limitamount");
- BigDecimal saledamount = promotionenterpriserows.get(0).getBigDecimal("saledamount");
- if (orderamount.compareTo(limitamount.subtract(saledamount)) <= 0) {
- //全部优先账户扣款
- jsonObject.put("amount", orderamount);
- jsonObject.put("sa_accountclassid", accountclassrows.get(0).getLong("sa_accountclassid"));
- jsonObject.put("accountname", accountclassrows.get(0).getString("accountname"));
- jsonObject.put("balance", accountclassrows.get(0).getBigDecimal("balance"));
- jsonObject.put("creditquota", accountclassrows.get(0).getBigDecimal("creditquota"));
- jsonArray.add(jsonObject);
- } else if (orderamount.compareTo(limitamount.subtract(saledamount)) > 0) {
- //全部优先账户扣款
- jsonObject.put("amount", limitamount.subtract(saledamount));
- jsonObject.put("sa_accountclassid", accountclassrows.get(0).getLong("sa_accountclassid"));
- jsonObject.put("accountname", accountclassrows.get(0).getString("accountname"));
- jsonObject.put("balance", accountclassrows.get(0).getBigDecimal("balance"));
- jsonObject.put("creditquota", accountclassrows.get(0).getBigDecimal("creditquota"));
- jsonArray.add(jsonObject);
- JSONObject associationjsonObject = new JSONObject();
- associationjsonObject.put("amount", orderamount.subtract((limitamount.subtract(saledamount))));
- associationjsonObject.put("sa_accountclassid", associationaccountclassrows.get(0).getLong("sa_accountclassid"));
- associationjsonObject.put("accountname", associationaccountclassrows.get(0).getString("accountname"));
- associationjsonObject.put("balance", associationaccountclassrows.get(0).getBigDecimal("balance"));
- associationjsonObject.put("creditquota", associationaccountclassrows.get(0).getBigDecimal("creditquota"));
- jsonArray.add(associationjsonObject);
- } else {
- return "未知错误,请联系管理员";
- }
- }
- } else {
- //全部优先账户扣款
- jsonObject.put("amount", orderamount);
- jsonObject.put("sa_accountclassid", accountclassrows.get(0).getLong("sa_accountclassid"));
- jsonObject.put("accountname", accountclassrows.get(0).getString("accountname"));
- jsonObject.put("balance", accountclassrows.get(0).getBigDecimal("balance"));
- jsonObject.put("creditquota", accountclassrows.get(0).getBigDecimal("creditquota"));
- jsonArray.add(jsonObject);
- }
- } else {
- //全部优先账户扣款
- jsonObject.put("amount", orderamount);
- jsonObject.put("sa_accountclassid", accountclassrows.get(0).getLong("sa_accountclassid"));
- jsonObject.put("accountname", accountclassrows.get(0).getString("accountname"));
- jsonObject.put("balance", accountclassrows.get(0).getBigDecimal("balance"));
- jsonObject.put("creditquota", accountclassrows.get(0).getBigDecimal("creditquota"));
- jsonArray.add(jsonObject);
- }
- //System.out.println(jsonArray.toJSONString());
- dbConnect.runSqlUpdate("update sa_order set sa_accountclassinfos='" + jsonArray + "' where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'");
- return "true";
- }
- /**
- * 更新居间费信息
- */
- public void updateRebateFee(Long sa_orderid) throws YosException {
- Rows orderRows = getOrderRows(this, sa_orderid);
- if (orderRows.isEmpty()) {
- return;
- }
- Long sa_projectid = orderRows.get(0).getLong("sa_projectid");
- Rows contractRows = dbConnect.runSqlQuery("SELECT * from sa_contract WHERE sa_projectid = " + sa_projectid + " and type='居间' and status='审核'");
- if (contractRows.isEmpty()) {
- return;
- }
- Long sa_contractid = contractRows.get(0).getLong("sa_contractid");
- Rows partiesRows = dbConnect.runSqlQuery("SELECT sys_enterpriseid from sa_project_parties WHERE type ='居间服务商' and sa_projectid = " + sa_projectid + " and siteid ='" + siteid + "'");
- if (partiesRows.isEmpty()) {
- return;
- }
- Long sys_enterpriseid_temp = partiesRows.get(0).getLong("sys_enterpriseid");
- content.put("sys_enterpriseid", sys_enterpriseid_temp);
- content.put("ownertable", "sa_order");
- content.put("ownerid", sa_orderid);
- content.put("billdate", "");
- content.put("remarks", "");
- content.put("sa_contractid", sa_contractid);
- content.put("settlementmode", "线上");
- content.put("sa_rebatesettlementid", 0);
- new Rebate(content).insertOrUpdate();
- }
- @API(title = "详情", apiversion = R.ID20221110134302.v1.class)
- @CACHEING
- public String selectDetail() throws YosException {
- Long sa_orderitemsid = content.getLong("sa_orderitemsid");
- SQLFactory sqlFactory = new SQLFactory(this, "订单商品明细_详情");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter_in("sa_orderitemsid", sa_orderitemsid);
- String sql = sqlFactory.getSQL();
- Rows rows = dbConnect.runSqlQuery(sql);
- Row row = rows.isNotEmpty() ? rows.get(0) : new Row();
- return getSucReturnObject().setData(row).toString();
- }
- @API(title = "删除", apiversion = R.ID20221109093702.v1.class)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, ToolBill.class})
- public String delete() throws YosException {
- Long sa_orderid = content.getLong("sa_orderid");
- Rows orderRows = getOrderRows(this, sa_orderid);
- if (orderRows.isEmpty()) {
- return getErrReturnObject().setErrMsg("数据不存在,无法添加").toString();
- } else {
- if (!orderRows.get(0).getString("status").equals("新建")) {
- return getErrReturnObject().setErrMsg("非新建状态无法删除").toString();
- }
- }
- //通过版本更新订单表头数据
- beans.order.Order.updateOrderWithVersion(this);
- JSONArray sa_orderitemsids = content.getJSONArray("sa_orderitemsids");
- String packagetypemxsql ="select t1.sa_orderitemsid from sa_orderitems t1 inner join sa_promotion_items t2 on t1.sa_promotion_itemsid=t2.sa_promotion_itemsid and t1.siteid=t2.siteid where t1.siteid='"+siteid+"' and t1.sa_orderid in(select sa_orderid from sa_orderitems where sa_orderitemsid in"+sa_orderitemsids.toJSONString()+") and t2.packagetypemx in(select distinct t2.packagetypemx from sa_orderitems t1 inner join sa_promotion_items t2 on t1.sa_promotion_itemsid=t2.sa_promotion_itemsid and t1.siteid=t2.siteid where t1.siteid='"+siteid+"' and t1.sa_orderitemsid in"+sa_orderitemsids.toJSONString()+" and ifnull(t2.packagetypemx,'')!='')";
- packagetypemxsql = packagetypemxsql.replace("[", "(").replace("]", ")");
- Rows packagetypemxrows = dbConnect.runSqlQuery(packagetypemxsql);
- sa_orderitemsids.addAll(packagetypemxrows.toJsonArray("sa_orderitemsid"));
- SQLFactory sqlFactory = new SQLFactory(this, "订单商品明细_删除");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter("sa_orderid", sa_orderid);
- sqlFactory.addParameter_in("sa_orderitemsid", sa_orderitemsids.toArray());
- String sql = sqlFactory.getSQL();
- dbConnect.runSqlUpdate(sql);
- // DeleteSQL deleteSQL = SQLFactory.createDeleteSQL(this, "sa_order_cost");
- // deleteSQL.setSiteid(siteid);
- // deleteSQL.setWhere("sa_orderitemsid", sa_orderitemsids.toArray());
- // deleteSQL.delete();
- //重新排序
- updateRowNo(sa_orderid);
- //居间费设置
- updateRebateFee(sa_orderid);
- //调整价格(返利金)
- if (orderRows.get(0).getBoolean("rebate_used")) {
- setRebateAmount(this, sa_orderid, getMaxUsedRebateAmount(this, sa_orderid));
- adjustLastRebateAmount(this, sa_orderid);
- }
- // else {
- // dbConnect.runSqlUpdate("UPDATE sa_orderitems SET amount=amount-rebateamount,price=amount/qty WHERE sa_orderid='" + sa_orderid + "' and siteid='" + siteid + "' and qty!=0");
- // dbConnect.runSqlUpdate("UPDATE sa_orderitems SET amount=0 WHERE sa_orderid='" + sa_orderid + "' and siteid='" + siteid + "' and qty=0");
- // }
- updateAccountclassinfos(sa_orderid);
- new OrderItemsHelper(this).executeDataFunction(sa_orderid);
- //生成摘要
- sqlFactory = new SQLFactory(this, "查询定制费用统计");
- sqlFactory.addParameter("sa_orderid", sa_orderid);
- Rows rows = dbConnect.runSqlQuery(sqlFactory);
- if (rows.isNotEmpty()) {
- String remarks = StringUtils.join(rows.toArray("remarks"), ";");
- dbConnect.runSqlUpdate("UPDATE sa_order set abstract ='" + remarks + "' WHERE sa_orderid='" + sa_orderid + "'");
- } else {
- dbConnect.runSqlUpdate("UPDATE sa_order set abstract ='' WHERE sa_orderid='" + sa_orderid + "'");
- }
- return getSucReturnObject().toString();
- }
- @API(title = "商品行冻结", apiversion = R.ID20230508093003.v1.class)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, ToolBill.class})
- public String freeze() throws YosException {
- Long sa_orderid = content.getLong("sa_orderid");
- //通过版本更新订单表头数据
- beans.order.Order.updateOrderWithVersion(this);
- JSONArray sa_orderitemsids = content.getJSONArray("sa_orderitemsids");
- boolean isfreeze = content.getBooleanValue("isfreeze");
- Rows orderRows = dbConnect.runSqlQuery("select * from sa_order where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'");
- if (!orderRows.isEmpty()) {
- if (!orderRows.get(0).getString("status").equals("审核")) {
- if (isfreeze) {
- return getErrReturnObject().setErrMsg("非审核状态无法进行冻结").toString();
- } else {
- return getErrReturnObject().setErrMsg("非审核状态无法进行反冻结").toString();
- }
- }
- } else {
- return getErrReturnObject().setErrMsg("该订单不存在").toString();
- }
- SQLFactory sqlFactory;
- if (isfreeze) {
- sqlFactory = new SQLFactory(this, "订单商品明细_冻结");
- } else {
- sqlFactory = new SQLFactory(this, "订单商品明细_反冻结");
- }
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter_in("sa_orderitemsid", sa_orderitemsids.toArray());
- String sql = sqlFactory.getSQL();
- //System.out.println(sql);
- dbConnect.runSqlUpdate(sql);
- return getSucReturnObject().toString();
- }
- @API(title = "商品行折扣变更", apiversion = R.ID20230508101703.v1.class)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, ToolBill.class})
- public String updateOrderItemsDiscountrate() throws YosException {
- Long sa_orderid = content.getLong("sa_orderid");
- BigDecimal discountrate = content.getBigDecimal("discountrate");
- JSONArray itemids = content.getJSONArray("itemids");
- Rows orderRows = dbConnect.runSqlQuery("select * from sa_order where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'");
- if (!orderRows.isEmpty()) {
- if (!orderRows.get(0).getString("status").equals("新建") && !orderRows.get(0).getString("status").equals("预提交")) {
- return getErrReturnObject().setErrMsg("非新建或预提交状态无法进行商品行折扣变更").toString();
- }
- } else {
- return getErrReturnObject().setErrMsg("该订单不存在").toString();
- }
- if (!(discountrate.compareTo(BigDecimal.ZERO) > 0 && discountrate.compareTo(new BigDecimal(1)) <= 0)) {
- return getErrReturnObject().setErrMsg("折扣必须在0-1之间").toString();
- }
- //通过版本更新订单表头数据
- beans.order.Order.updateOrderWithVersion(this);
- String sql;
- if (itemids.size() == 0) {
- sql = "select * from sa_orderitems where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'";
- } else {
- sql = "select * from sa_orderitems where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "' and itemid in " + itemids.toJSONString();
- sql = sql.replace("[", "(").replace("]", ")");
- }
- Rows orderItemsRows = dbConnect.runSqlQuery(sql);
- ArrayList<String> sqlList = new ArrayList<>();
- if (!orderItemsRows.isEmpty()) {
- for (Row row : orderItemsRows) {
- BigDecimal price = row.getBigDecimal("price").multiply(discountrate);
- BigDecimal amount = row.getBigDecimal("amount").multiply(discountrate);
- sqlList.add("update sa_orderitems set price=" + price + ",amount=" + amount + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
- }
- }
- sqlList.add(DataContrlLog.createLog(this, "sa_order", sa_orderid, "订单整单折扣变更【" + discountrate + "】", "整单折扣").getSQL());
- dbConnect.runSqlUpdate(sqlList);
- updateAccountclassinfos(sa_orderid);
- return getSucReturnObject().toString();
- }
- @API(title = "商品行价格刷新(变为原价)", apiversion = R.ID20230518151803.v1.class)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class, ToolBill.class})
- public String updateOrderItemsPrice() throws YosException {
- Long sa_orderid = content.getLong("sa_orderid");
- JSONArray itemids = content.getJSONArray("itemids");
- Rows orderRows = dbConnect.runSqlQuery("select * from sa_order where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'");
- if (!orderRows.isEmpty()) {
- if (!orderRows.get(0).getString("status").equals("新建") && !orderRows.get(0).getString("status").equals("预提交")) {
- return getErrReturnObject().setErrMsg("非新建或预提交状态无法进行商品行价格刷新").toString();
- }
- } else {
- return getErrReturnObject().setErrMsg("该订单不存在").toString();
- }
- //通过版本更新订单表头数据
- beans.order.Order.updateOrderWithVersion(this);
- String sql;
- if (itemids.size() == 0) {
- sql = "select * from sa_orderitems where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'";
- } else {
- sql = "select * from sa_orderitems where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "' and itemid in " + itemids.toJSONString();
- sql = sql.replace("[", "(").replace("]", ")");
- }
- Rows orderItemsRows = dbConnect.runSqlQuery(sql);
- ArrayList<String> sqlList = new ArrayList<>();
- if (!orderItemsRows.isEmpty()) {
- for (Row row : orderItemsRows) {
- //价格
- ItemPrice itemPrice = ItemPrice.getItemPrice(this, orderRows.get(0).getLong("sys_enterpriseid"), row.getLong("itemid"));
- BigDecimal price = itemPrice.getPrice();
- BigDecimal amount = row.getBigDecimal("qty").multiply(price);
- sqlList.add("update sa_orderitems set price=" + price + ",amount=" + amount + " where sa_orderitemsid=" + row.getLong("sa_orderitemsid"));
- }
- }
- sqlList.add(DataContrlLog.createLog(this, "sa_order", sa_orderid, "订单商品行价格刷新(恢复原价)", "订单商品行价格刷新").getSQL());
- dbConnect.runSqlUpdate(sqlList);
- updateAccountclassinfos(sa_orderid);
- return getSucReturnObject().toString();
- }
- @API(title = "关闭", apiversion = R.ID20221109093802.v1.class)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class})
- public String close() throws YosException {
- Long sa_orderid = content.getLong("sa_orderid");
- //通过版本更新订单表头数据
- beans.order.Order.updateOrderWithVersion(this);
- JSONArray sa_orderitemsids = content.getJSONArray("sa_orderitemsids");
- SQLFactory sqlFactory = new SQLFactory(this, "订单商品明细_行关闭");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter("userid", userid);
- sqlFactory.addParameter("username", username);
- sqlFactory.addParameter("closereason", content.getStringValue("closereason"));
- sqlFactory.addParameter_in("sa_orderitemsid", sa_orderitemsids.toArray());
- dbConnect.runSqlUpdate(sqlFactory);
- //重新排序
- updateRowNo(sa_orderid);
- return getSucReturnObject().toString();
- }
- @API(title = "查询列表", apiversion = R.ID20221109093902.v1.class)
- public String selectList() throws YosException, IOException {
- StringBuffer where = new StringBuffer(" 1=1 ");
- if (content.containsKey("where")) {
- JSONObject whereObject = content.getJSONObject("where");
- if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
- where.append(" and(");
- where.append("t1.itemno like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.itemname like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.model like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t3.spec like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.remarks like'%").append(whereObject.getString("condition")).append("%' ");
- where.append(")");
- }
- if (whereObject.containsKey("packagetypemx") && !"".equals(whereObject.getString("packagetypemx"))) {
- where.append(" and(");
- where.append("t4.packagetypemx ='").append(whereObject.getString("packagetypemx")).append("' ");
- where.append(")");
- }
- }
- Long sa_orderid = content.getLong("sa_orderid");
- Rows orderRows = getOrderRows(this, sa_orderid);
- if (orderRows.isNotEmpty()) {
- sys_enterpriseid = orderRows.get(0).getLong("sys_enterpriseid");
- }
- Long sa_promotionid = orderRows.get(0).getLong("sa_promotionid");
- // boolean isExport = content.getBooleanValue("isExport");
- // SQLFactory sqlFactory = new SQLFactory(this, "订单商品明细_列表", pageSize, pageNumber, pageSorting);
- // if (isExport) {
- // sqlFactory = new SQLFactory(this, "订单商品明细_列表");
- // }
- // sqlFactory.addParameter("siteid", siteid);
- // sqlFactory.addParameter("sa_orderid", sa_orderid);
- // sqlFactory.addParameter_SQL("where", where);
- // Rows rows = dbConnect.runSqlQuery(sqlFactory);
- QuerySQL querySQL = SQLFactory.createQuerySQL(this, "sa_orderitems");
- querySQL.addJoinTable(JOINTYPE.left, "st_invbal_sale", "t2", "t2.siteid = t1.siteid AND t2.itemid = t1.itemid");
- querySQL.addJoinTable(JOINTYPE.left, "plm_item", "t3", "t3.itemid = t1.itemid and t3.siteid = t1.siteid",
- "orderminqty_auxunit", "orderaddqty_auxunit", "spec", "iscustomsize", "widthschemeid", "lengthschemeid", "standards", "k3outcode");
- // querySQL.addJoinTable(JOINTYPE.left, "plm_itemextend", "t4", "t4.itemid = t1.itemid and t4.siteid = t1.siteid",
- // "erpitemno", "erpitemname", "material", "prodline", "device", "specalnote");
- querySQL.addJoinTable(JOINTYPE.left, "sa_promotion_items", "t4",
- "t4.sa_promotion_itemsid = t1.sa_promotion_itemsid and t4.siteid = t1.siteid and t4.sa_promotionid=" + sa_promotionid,"packagetypemx","saledqty","groupqty");
- querySQL.addQueryFields("candispatchqty", "ifnull(t2.candispatchqty, 0)");
- querySQL.addQueryFields("cansaleqty", "ifnull(t2.cansaleqty, 0)");
- querySQL.addQueryFields("totalaty", "ifnull(t2.qty, 0)");
- querySQL.addQueryFields("stockstatus", "(SELECT (CASE WHEN t2.cansaleqty>=t3.stockstatus1 THEN '充足' WHEN t2.cansaleqty<=t3.stockstatus2 THEN '缺货' ELSE '紧缺' END))");
- querySQL.addQueryFields("packageqty", "ifnull(t3.packageqty, 0)");
- querySQL.addQueryFields("delivery", "ifnull(t3.delivery, 0)");
- querySQL.addQueryFields("orderaddqty", "SELECT (CASE WHEN t4.sa_promotionid>0 THEN t4.orderaddqty ELSE t3.orderaddqty END)");
- querySQL.addQueryFields("orderminqty", "SELECT (CASE WHEN t4.sa_promotionid>0 THEN t4.orderminqty ELSE t3.orderminqty END)");
- querySQL.setWhere(where.toString()).setTableAlias("t1");
- querySQL.setWhere("t1.siteid", siteid);
- querySQL.setWhere("t1.sa_orderid", sa_orderid);
- querySQL.setPage(pageSize, pageNumber).setOrderBy(pageSorting);
- Rows rows = querySQL.query();
- ArrayList<Long> ids = rows.toArrayList("itemid", new ArrayList<>());
- ArrayList<Long> itemnos = rows.toArrayList("itemno", new ArrayList<>());
- RowsMap rowsMap = rows.toRowsMap("itemno");
- SQLFactory sqlFactory1 = new SQLFactory(this, "商品发货数量汇总");
- sqlFactory1.addParameter("siteid", siteid);
- sqlFactory1.addParameter_in("itemnos", itemnos);
- Rows sumQtyRows = dbConnect.runSqlQuery(sqlFactory1);
- RowsMap sumQtyRowsMap = sumQtyRows.toRowsMap("itemno");
- SQLFactory sqlFactory2 = new SQLFactory(this, "商品未发货数量汇总");
- sqlFactory2.addParameter("siteid", siteid);
- sqlFactory2.addParameter_in("itemnos", itemnos);
- Rows sumUnQtyRows = dbConnect.runSqlQuery(sqlFactory2);
- RowsMap sumUnQtyRowsMap = sumUnQtyRows.toRowsMap("itemno");
- SQLFactory sqlFactory3 = new SQLFactory(this, "商品原价汇总");
- sqlFactory3.addParameter("siteid", siteid);
- sqlFactory3.addParameter("sys_enterpriseid", sys_enterpriseid);
- sqlFactory3.addParameter_in("itemnos", itemnos);
- Rows itempriceRows = dbConnect.runSqlQuery(sqlFactory3);
- RowsMap itempriceRowsMap = itempriceRows.toRowsMap("itemno");
- JSONArray jsonArray = new JSONArray();
- if(content.getLongValue("onlyquery")==0){
- if (siteid.equalsIgnoreCase("lsa")) {
- JSONObject object = new JSONObject();
- object.put("classname", "getIcinvbal");
- object.put("method", "getMsg");
- JSONObject content = new JSONObject();
- content.put("fitemnos", rows.toJsonArray("itemno"));
- object.put("content", content);
- WebRequest request = new WebRequest();
- String result = request.doPost(object.toString(),
- "http://60.190.151.198:8089/BYESB/jaxrs/webclientrest");
- if (isJSONArray(result)) {
- jsonArray = JSONArray.parseArray(result);
- }
- for (Object obj : jsonArray) {
- JSONObject jsonObject = (JSONObject) obj;
- if (rowsMap.containsKey(jsonObject.getString("fitemno"))) {
- if (rowsMap.get(jsonObject.getString("fitemno")).isNotEmpty()) {
- rowsMap.get(jsonObject.getString("fitemno")).get(0).put("invbalqty", jsonObject.getBigDecimalValue("FQty"));
- }
- }
- }
- } else {
- ERPDocking erpDocking = new ERPDocking(siteid);
- if (rows.toJsonArray("itemno").size() != 0) {
- if (Parameter.get("system.ccerp_dockswitch").equalsIgnoreCase("true")) {
- jsonArray = erpDocking.getErpIcinvbalRows(1000, 1, rows.toJsonArray("itemno"));
- }
- }
- if (!jsonArray.isEmpty()) {
- for (Object object : jsonArray) {
- JSONObject jsonObject = (JSONObject) object;
- if (rowsMap.containsKey(jsonObject.getString("fitemno"))) {
- if (rowsMap.get(jsonObject.getString("fitemno")).isNotEmpty()) {
- for (Row row : rowsMap.get(jsonObject.getString("fitemno"))
- ) {
- row.put("invbalqty", jsonObject.getBigDecimalValue("fqty"));
- }
- }
- }
- }
- }
- }
- }
- //查询附件
- RowsMap attinfoRowsMap = getAttachmentUrl("plm_item", ids);
- for (Row row : rows) {
- if (itempriceRowsMap.get(row.getString("itemno")).isNotEmpty()) {
- row.put("originalprice", itempriceRowsMap.get(row.getString("itemno")).get(0).getBigDecimal("price"));
- } else {
- row.put("originalprice", BigDecimal.ZERO);
- }
- if (sumQtyRowsMap.get(row.getString("itemno")).isNotEmpty()) {
- row.put("unsoldqty", sumQtyRowsMap.get(row.getString("itemno")).get(0).getBigDecimal("qty"));
- } else {
- row.put("unsoldqty", BigDecimal.ZERO);
- }
- if (sumUnQtyRowsMap.get(row.getString("itemno")).isNotEmpty()) {
- row.put("undeliqtysum", sumUnQtyRowsMap.get(row.getString("itemno")).get(0).getBigDecimal("undeliqty"));
- } else {
- row.put("undeliqtysum", BigDecimal.ZERO);
- }
- if (!row.containsKey("invbalqty")) {
- row.put("invbalqty", BigDecimal.ZERO);
- }
- row.put("attinfos", attinfoRowsMap.getOrDefault(row.getString("itemid"), new Rows()));
- row.put("contractprice", 0);
- //处理日期字段空的情况
- row.putIfAbsent("needdate", "");
- row.putIfAbsent("deliverydate", "");
- }
- // if (isExport) {
- // //去除不需要导出项
- // String[] removeFieldList = {"sa_orderitemsid", "itemid", "sa_orderid", "candispatchqty", "cansaleqty",
- // "totalaty", "orderminqty_auxunit", "orderminqty", "orderaddqty_auxunit", "orderaddqty",
- // "spec", "delivery", "erpitemno", "erpitemname", "material", "standards", "stockstatus"};
- // for (String key : removeFieldList) {
- // rows.getFieldList().remove(key);
- // }
- //
- // Rows uploadRows = uploadExcelToObs("order", "订单商品明细_列表", rows, getTitleMap());
- // return getSucReturnObject().setData(uploadRows).toString();
- // }
- return getSucReturnObject().setData(rows).toString();
- }
- @API(title = "查询订单所有明细列表", apiversion = R.ID20230508111703.v1.class)
- public String selectAllList() throws YosException, IOException {
- StringBuffer where = new StringBuffer(" 1=1 ");
- if (sys_enterpriseid > 0) {
- where.append(" and t5.sys_enterpriseid ='").append(sys_enterpriseid).append("' ");
- }
- if (content.containsKey("where")) {
- JSONObject whereObject = content.getJSONObject("where");
- if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
- where.append(" and(");
- where.append(" t5.sonum like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.itemno like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.itemname like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t6.agentnum like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t7.enterprisename like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.remarks like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t5.remarks like'%").append(whereObject.getString("condition")).append("%' ");
- where.append(")");
- }
- if (whereObject.containsKey("iteminfo") && !"".equals(whereObject.getString("iteminfo"))) {
- where.append(" and(");
- where.append("t1.itemno like'%").append(whereObject.getString("iteminfo")).append("%' ");
- where.append("or t1.itemname like'%").append(whereObject.getString("iteminfo")).append("%' ");
- where.append(")");
- }
- if (whereObject.containsKey("agentinfo") && !"".equals(whereObject.getString("agentinfo"))) {
- where.append(" and(");
- where.append("t6.agentnum like'%").append(whereObject.getString("agentinfo")).append("%' ");
- where.append("or t7.enterprisename like'%").append(whereObject.getString("agentinfo")).append("%' ");
- where.append(")");
- }
- if (whereObject.containsKey("begindate") && !"".equals(whereObject.getString("begindate"))) {
- where.append(" and DATE_FORMAT(t5.billdate, '%Y-%m-%d') >='").append(whereObject.getString("begindate")).append("' ");
- }
- if (whereObject.containsKey("enddate") && !"".equals(whereObject.getString("enddate"))) {
- where.append(" and DATE_FORMAT(t5.billdate, '%Y-%m-%d') <='").append(whereObject.getString("enddate")).append("' ");
- }
- if (whereObject.containsKey("begindate1") && !"".equals(whereObject.getString("begindate1"))) {
- where.append(" and DATE_FORMAT(t5.submitdate, '%Y-%m-%d') >='").append(whereObject.getString("begindate1")).append("' ");
- }
- if (whereObject.containsKey("enddate1") && !"".equals(whereObject.getString("enddate1"))) {
- where.append(" and DATE_FORMAT(t5.submitdate, '%Y-%m-%d') <='").append(whereObject.getString("enddate1")).append("' ");
- }
- if (whereObject.containsKey("begindate2") && !"".equals(whereObject.getString("begindate2"))) {
- where.append(" and DATE_FORMAT(t5.checkdate, '%Y-%m-%d') >='").append(whereObject.getString("begindate2")).append("' ");
- }
- if (whereObject.containsKey("enddate2") && !"".equals(whereObject.getString("enddate2"))) {
- where.append(" and DATE_FORMAT(t5.checkdate, '%Y-%m-%d') <='").append(whereObject.getString("enddate2")).append("' ");
- }
- if (whereObject.containsKey("status") && !"".equals(whereObject.getString("status"))) {
- where.append(" and t5.status ='").append(whereObject.getString("status")).append("' ");
- }
- if (whereObject.containsKey("isfreeze") && !"".equals(whereObject.getString("isfreeze"))) {
- where.append(" and t1.isfreeze ='").append(whereObject.getString("isfreeze")).append("' ");
- }
- if (whereObject.containsKey("typemx") && !"".equals(whereObject.getString("typemx"))) {
- where.append(" and t5.typemx ='").append(whereObject.getString("typemx")).append("' ");
- }
- if (whereObject.containsKey("isuncheckout") && !"".equals(whereObject.getString("isuncheckout"))) {
- String begindate = "";
- String enddate = "";
- if (whereObject.containsKey("datetype") && !"".equals(whereObject.getString("datetype"))) {
- String datetype = whereObject.getStringValue("datetype");
- switch (datetype) {
- case "7":
- begindate = getDate_Str(-7);
- enddate = getDate_Str();
- break;
- case "30":
- begindate = getDate_Str(-30);
- enddate = getDate_Str();
- break;
- case "90":
- begindate = getDate_Str(-90);
- enddate = getDate_Str();
- break;
- default:
- break;
- }
- }
- if (!begindate.equals("")) {
- where.append(" and DATE_FORMAT(t5.submitdate, '%Y-%m-%d') >='").append(begindate).append("' ");
- }
- if (!enddate.equals("")) {
- where.append(" and DATE_FORMAT(t5.submitdate, '%Y-%m-%d') <='").append(enddate).append("' ");
- }
- String isuncheckout = whereObject.getStringValue("isuncheckout");
- if (isuncheckout.equals("1")) {
- where.append(" and t1.sa_orderitemsid in (select t1.sa_orderitemsid from sa_orderitems t1 inner join (select t2.sa_orderitemsid,t2.siteid,sum(outwarehouseqty) sumoutwarehouseqty from sa_dispatch_items t2 inner join sa_dispatch t3 on t2.sa_dispatchid=t3.sa_dispatchid and t2.siteid=t3.siteid GROUP BY sa_orderitemsid,siteid) t2 on t1.sa_orderitemsid=t2.sa_orderitemsid and t1.siteid=t2.siteid where t1.qty>ifnull(t2.sumoutwarehouseqty,0) or t1.undeliqty>0)");
- } else {
- where.append(" and t1.sa_orderitemsid not in (select t1.sa_orderitemsid from sa_orderitems t1 inner join (select t2.sa_orderitemsid,t2.siteid,sum(outwarehouseqty) sumoutwarehouseqty from sa_dispatch_items t2 inner join sa_dispatch t3 on t2.sa_dispatchid=t3.sa_dispatchid and t2.siteid=t3.siteid GROUP BY sa_orderitemsid,siteid) t2 on t1.sa_orderitemsid=t2.sa_orderitemsid and t1.siteid=t2.siteid where t1.qty>ifnull(t2.sumoutwarehouseqty,0) or t1.undeliqty>0)");
- }
- }
- if (whereObject.containsKey("iscancel") && !"".equals(whereObject.getString("iscancel"))) {
- String iscancel = whereObject.getStringValue("iscancel");
- if (iscancel.equals("1")) {
- where.append(" and t5.status ='手工关闭' and not exists(select 1 from st_stockbill_items s1 inner join st_stockbill s2 on s1.st_stockbillid=s2.st_stockbillid and s1.siteid=s2.siteid where s2.status='审核' and s2.rb=1 and s1.sa_orderitemsid=t1.sa_orderitemsid)");
- }
- }
- if (whereObject.containsKey("convenient") && !"".equals(whereObject.getString("convenient"))) {
- String convenient = whereObject.getStringValue("convenient");
- if (convenient.equals("待确认")) {
- where.append(" and t5.status ='预提交' ");
- } else if (convenient.equals("待审核")) {
- where.append(" and t5.status ='提交' ");
- } else if (convenient.equals("待发货")) {
- where.append(" and t5.status in ('审核') and not exists(select 1 from st_stockbill_items s1 inner join st_stockbill s2 on s1.st_stockbillid=s2.st_stockbillid and s1.siteid=s2.siteid where s2.status='审核' and s2.rb=1 and s1.sa_orderitemsid=t1.sa_orderitemsid)");
- } else if (convenient.equals("已发货")) {
- where.append(" and exists(select 1 from st_stockbill_items s1 inner join st_stockbill s2 on s1.st_stockbillid=s2.st_stockbillid and s1.siteid=s2.siteid where s2.status='审核' and s2.rb=1 and s1.sa_orderitemsid=t1.sa_orderitemsid)");
- } else if (convenient.equals("已取消")) {
- where.append(" and t5.status ='手工关闭' and exists(select 1 from (\n" +
- "select s1.sa_orderitemsid,s1.siteid,sum(s1.qty) qty from st_stockbill_items s1 inner join st_stockbill s2 on s1.st_stockbillid=s2.st_stockbillid and s1.siteid=s2.siteid where s2.status='审核' and s2.rb=1 group by s1.sa_orderitemsid,s1.siteid) s right join sa_orderitems s1 on s.sa_orderitemsid=s1.sa_orderitemsid and s.siteid=s1.siteid where s1.qty>ifnull(s.qty,0) and s1.sa_orderitemsid=t1.sa_orderitemsid)");
- }
- }
- }
- boolean isExport = content.getBooleanValue("isExport");
- // SQLFactory sqlFactory = new SQLFactory(this, "订单商品明细_所有列表", pageSize, pageNumber, pageSorting);
- // if (isExport) {
- // sqlFactory = new SQLFactory(this, "订单商品明细_所有列表");
- // }
- // sqlFactory.addParameter("siteid", siteid);
- // sqlFactory.addParameter_SQL("where", where);
- // Rows rows = dbConnect.runSqlQuery(sqlFactory);
- QuerySQL querySQL = queryAllListManage(where.toString());
- querySQL.setOrderBy(pageSorting);
- querySQL.setPage(pageSize, pageNumber);
- Rows rows = querySQL.query();
- ArrayList<Long> ids = rows.toArrayList("itemid", new ArrayList<>());
- RowsMap rowsMap = rows.toRowsMap("itemno");
- ArrayList<Long> sa_orderitemsid = rows.toArrayList("sa_orderitemsid", new ArrayList<>());
- QuerySQL t11 = SQLFactory.createQuerySQL(this, "sa_dispatch_items",
- "sa_orderitemsid", "siteid");
- t11.addQueryFields("outwarehouseqty", "sum(outwarehouseqty)");
- t11.setSiteid(siteid);
- t11.setWhere("sa_orderitemsid",sa_orderitemsid);
- t11.addGroupBy("sa_orderitemsid,siteid");
- RowsMap outwarehouseqtyRowsMap=t11.query().toRowsMap("sa_orderitemsid");
- SQLFactory sqlFactory1 = new SQLFactory(this, "订单明细出库数量汇总");
- sqlFactory1.addParameter("siteid", siteid);
- sqlFactory1.addParameter_in("sa_orderitemsids", rows.toArrayList("sa_orderitemsid", new ArrayList<>()));
- Rows sumQtyRows = dbConnect.runSqlQuery(sqlFactory1);
- RowsMap sumQtyRowsMap = sumQtyRows.toRowsMap("sa_orderitemsid");
- ERPDocking erpDocking = new ERPDocking(siteid);
- JSONArray jsonArray = new JSONArray();
- if (rows.toJsonArray("itemno").size() != 0) {
- if (Parameter.get("system.ccerp_dockswitch").equalsIgnoreCase("true")) {
- jsonArray = erpDocking.getErpIcinvbalRows(200000, 1, rows.toJsonArray("itemno"));
- }
- }
- if (!jsonArray.isEmpty()) {
- for (Object object : jsonArray) {
- JSONObject jsonObject = (JSONObject) object;
- if (rowsMap.containsKey(jsonObject.getString("fitemno"))) {
- if (rowsMap.get(jsonObject.getString("fitemno")).isNotEmpty()) {
- for (Row row : rowsMap.get(jsonObject.getString("fitemno"))
- ) {
- row.put("invbalqty", jsonObject.getBigDecimalValue("fqty"));
- }
- }
- }
- }
- }
- //查询附件
- RowsMap attinfoRowsMap = getAttachmentUrl("plm_item", ids);
- for (Row row : rows) {
- if (sumQtyRowsMap.get(row.getString("sa_orderitemsid")).isNotEmpty()) {
- row.put("unsoldqty", row.getBigDecimal("qty").subtract(sumQtyRowsMap.get(row.getString("sa_orderitemsid")).get(0).getBigDecimal("sumqty")));
- } else {
- row.put("unsoldqty", row.getBigDecimal("qty"));
- }
- if (!row.containsKey("invbalqty")) {
- row.put("invbalqty", BigDecimal.ZERO);
- }
- row.put("attinfos", attinfoRowsMap.getOrDefault(row.getString("itemid"), new Rows()));
- row.put("contractprice", 0);
- if(outwarehouseqtyRowsMap.get(row.getString("sa_orderitemsid")).isNotEmpty()) {
- row.put("outwarehouseqty", outwarehouseqtyRowsMap.get(row.getString("sa_orderitemsid")).get(0).getBigDecimal("outwarehouseqty"));
- }else{
- row.put("outwarehouseqty",0);
- }
- }
- // if (isExport) {
- // //去除不需要导出项
- // rows.getFieldList().remove("sa_orderitemsid");
- // rows.getFieldList().remove("itemid");
- // rows.getFieldList().remove("batchcontrol");
- // rows.getFieldList().remove("model");
- // rows.getFieldList().remove("conversionrate");
- // rows.getFieldList().remove("marketprice");
- // rows.getFieldList().remove("defaultprice");
- // rows.getFieldList().remove("defaultamount");
- // rows.getFieldList().remove("auxqty");
- // rows.getFieldList().remove("needdate");
- // rows.getFieldList().remove("deliedqty");
- // rows.getFieldList().remove("rebateamount");
- // rows.getFieldList().remove("invoiceamount");
- // rows.getFieldList().remove("writeoffamount");
- // rows.getFieldList().remove("auxunit");
- // rows.getFieldList().remove("sa_orderid");
- // rows.getFieldList().remove("deliverydate");
- // rows.getFieldList().remove("returnqty");
- // rows.getFieldList().remove("stockno");
- // rows.getFieldList().remove("position");
- // rows.getFieldList().remove("batchno");
- // rows.getFieldList().remove("isfreeze");
- // rows.getFieldList().remove("candispatchqty");
- // rows.getFieldList().remove("cansaleqty");
- // rows.getFieldList().remove("totalaty");
- // rows.getFieldList().remove("orderminqty_auxunit");
- // rows.getFieldList().remove("orderminqty");
- // rows.getFieldList().remove("orderaddqty_auxunit");
- // rows.getFieldList().remove("orderaddqty");
- // rows.getFieldList().remove("spec");
- // rows.getFieldList().remove("packageqty");
- // rows.getFieldList().remove("delivery");
- // rows.getFieldList().remove("erpitemno");
- // rows.getFieldList().remove("erpitemname");
- // rows.getFieldList().remove("prodline");
- // rows.getFieldList().remove("material");
- // rows.getFieldList().remove("device");
- // rows.getFieldList().remove("specalnote");
- // rows.getFieldList().remove("standards");
- // rows.getFieldList().remove("agentnum");
- // rows.getFieldList().remove("enterprisename");
- // rows.getFieldList().remove("agentnum");
- // rows.getFieldList().remove("stockstatus");
- // rows.getFieldList().remove("submitdate");
- // rows.getFieldList().remove("checkdate");
- // Rows rowsrolename = dbConnect.runSqlQuery("select * from sys_userrole t1 inner join sys_role t2 on t1.roleid=t2.roleid and t1.siteid=t2.siteid where t2.rolename='经销商员工' and t1.userid=" + userid);
- // if (!rowsrolename.isEmpty()) {
- // rows.getFieldList().remove("price");
- // rows.getFieldList().remove("amount");
- // }
- //
- // Rows uploadRows = uploadExcelToObs("orderdetail", "订单明细列表", rows, getTitleMapAgent());
- // return getSucReturnObject().setData(uploadRows).toString();
- // }
- return getSucReturnObject().setData(rows).toString();
- }
- //查询订单列表(管理端)
- public QuerySQL queryAllListManage(String where) throws YosException {
- QuerySQL querySQL = SQLFactory.createQuerySQL(this, "sa_orderitems",
- "sa_orderitemsid", "itemid", "rowno", "itemno", "itemname", "unit", "qty", "undeliqty", "saleprice", "defaultprice", "price", "amount", "remarks", "customproperties", "batchcontrol", "model",
- "conversionrate", "marketprice", "defaultprice", "defaultamount", "auxqty", "needdate", "deliedqty", "rebateamount", "invoiceamount", "writeoffamount", "auxunit", "sa_orderid",
- "deliverydate", "returnqty", "stockno", "position", "batchno", "isfreeze", "decorationrebateflag");
- querySQL.setTableAlias("t1");
- querySQL.addJoinTable(JOINTYPE.left, "plm_item", "t3", "t3.itemid = t1.itemid and t3.siteid = t1.siteid",
- "orderminqty_auxunit", "orderminqty", "orderaddqty_auxunit", "orderaddqty", "spec", "standards", "packageqty", "delivery", "k3outcode");
- querySQL.addJoinTable(JOINTYPE.left, "sa_order", "t5", "t5.sa_orderid = t1.sa_orderid and t5.siteid = t1.siteid",
- "sonum", "type", "typemx", "status", "billdate", "submitdate", "checkdate", "tradefield", "closedate");
- querySQL.addJoinTable(JOINTYPE.left, "sa_agents", "t6", "t6.sys_enterpriseid = t5.sys_enterpriseid and t6.siteid = t5.siteid",
- "agentnum");
- querySQL.addJoinTable(JOINTYPE.left, "sys_enterprise", "t7", "t7.sys_enterpriseid = t5.sys_enterpriseid and t7.siteid = t5.siteid",
- "enterprisename");
- querySQL.addJoinTable(JOINTYPE.left, "plm_itemclass", "t8", "t8.itemclassid = t3.marketingcategory and t8.siteid = t3.siteid",
- "itemclassname");
- querySQL.addJoinTable(JOINTYPE.left, "sys_enterprise_tradefield", "t9", "t9.sys_enterpriseid = t5.sys_enterpriseid and t9.tradefield=t5.tradefield and t9.siteid = t5.siteid",
- "sys_enterprise_tradefieldid");
- querySQL.addJoinTable(JOINTYPE.left, "sa_salearea", "t10", "t10.sa_saleareaid = t9.sa_saleareaid and t10.siteid = t9.siteid",
- "areaname");
- // querySQL.addJoinTable(JOINTYPE.left, t11, "t11", "t11.sa_orderitemsid = t1.sa_orderitemsid and t11.siteid = t1.siteid");
- querySQL.addJoinTable(JOINTYPE.left, "sa_accountclass", "t12", "t12.sa_accountclassid=t5.sa_accountclassid and t12.siteid=t5.siteid");
- querySQL.addJoinTable(JOINTYPE.left, "sa_promotion", "t13", "t13.sa_promotionid=t5.sa_promotionid and t13.siteid=t5.siteid","promnum","promname");
- querySQL.addQueryFields("accountnames", "if(ifnull(replace(replace(replace(JSON_EXTRACT (t5.sa_accountclassinfos, '$**.accountname' ),'[',''),']',''),'\\\"',''),'')='',t12.accountname,replace(replace(replace(JSON_EXTRACT (t5.sa_accountclassinfos, '$**.accountname' ),'[',''),']',''),'\\\"',''))");
- querySQL.addQueryFields("orderremarks", "t5.remarks");
- // querySQL.addQueryFields("outwarehouseqty", "ifnull(t11.outwarehouseqty,0)");
- //querySQL.addQueryFields("accountclassinfos", "REPLACE(SUBSTRING(JSON_EXTRACT(t5.sa_accountclassinfos, '$[*].accountname'), 2, CHAR_LENGTH(JSON_EXTRACT(t5.sa_accountclassinfos, '$[*].accountname'))-2),'\"','')");
- querySQL.setWhere("t1.siteid", siteid);
- querySQL.setWhere(where);
- querySQL.setWhere("t5.status !='新建'");
- return querySQL;
- }
- //返回导出的标题
- public HashMap<String, String> getTitleMap() {
- HashMap<String, String> titleMap = new HashMap<>();
- titleMap.put("rowno", "行号");
- titleMap.put("batchcontrol", "是否批次管理");
- titleMap.put("itemno", "产品编号");
- titleMap.put("itemname", "产品名称");
- titleMap.put("model", "型号");
- titleMap.put("conversionrate", "换算率(辅助数量=主单位数量/换算率)");
- titleMap.put("price", "单价,折后价(元)");
- titleMap.put("amount", "金额,折后金额(元)");
- titleMap.put("marketprice", "牌价、市场价(元)");
- titleMap.put("defaultprice", "折前价(元)");
- titleMap.put("defaultamount", "折前金额(元)");
- titleMap.put("qty", "订购数量");
- titleMap.put("auxqty", "辅助单位数量");
- titleMap.put("needdate", "需求日期");
- titleMap.put("deliedqty", "已交货量(主单位)");
- titleMap.put("rebateamount", "返利分摊金额");
- titleMap.put("undeliqty", "未交货量(主单位)");
- titleMap.put("invoiceamount", "已开票金额");
- titleMap.put("writeoffamount", "已核销金额");
- titleMap.put("unit", "计量单位名称");
- titleMap.put("auxunit", "辅助计量单位名称");
- titleMap.put("deliverydate", "交货日期");
- titleMap.put("returnqty", "退货数量");
- titleMap.put("remarks", "备注");
- titleMap.put("submitdate", "提交时间");
- titleMap.put("checkdate", "审核时间");
- return titleMap;
- }
- //返回导出的标题
- public HashMap<String, String> getTitleMapAgent() throws YosException {
- HashMap<String, String> titleMap = new HashMap<>();
- titleMap.put("rowno", "行号");
- titleMap.put("sonum", "订单号");
- titleMap.put("status", "订单状态");
- titleMap.put("type", "订单类型");
- titleMap.put("billdate", "单据日期");
- titleMap.put("tradefield", "领域");
- titleMap.put("itemno", "产品编码");
- titleMap.put("itemname", "品名");
- titleMap.put("unit", "单位");
- titleMap.put("qty", "数量");
- titleMap.put("undeliqty", "未发货数量");
- Rows rowsrolename = dbConnect.runSqlQuery("select * from sys_userrole t1 inner join sys_role t2 on t1.roleid=t2.roleid and t1.siteid=t2.siteid where t2.rolename='经销商员工' and t1.userid=" + userid);
- if (rowsrolename.isEmpty()) {
- titleMap.put("price", "单价");
- titleMap.put("amount", "金额");
- }
- titleMap.put("remarks", "订单行备注");
- return titleMap;
- }
- @API(title = "查询可添加商品列表", apiversion = R.ID20221109153502.v1.class)
- @CACHEING
- public String selectItemList() throws YosException {
- StringBuffer where = new StringBuffer(" 1=1 ");
- if (content.containsKey("where")) {
- JSONObject whereObject = content.getJSONObject("where");
- if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
- where.append(" and(");
- where.append("t1.itemno like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.itemname like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.model like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.spec like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t1.standards like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t3.material like'%").append(whereObject.getString("condition")).append("%' ");
- where.append("or t3.erpitemno like'%").append(whereObject.getString("condition")).append("%' ");
- where.append(")");
- }
- if (whereObject.containsKey("isonsale") && !"".equals(whereObject.getString("isonsale"))) {
- where.append(" and t1.isonsale ='").append(whereObject.getString("isonsale")).append("' ");
- }
- }
- Long sa_orderid = content.getLong("sa_orderid");
- Long sys_enterpriseid1 = sys_enterpriseid;
- Rows orderRows = getOrderRows(this, sa_orderid);
- Long sa_brandid = 0L;
- String tradefield = "";
- String type = "";
- String typemx = "";
- Long sys_enterpriseid = 0L;
- JSONArray sa_accountclassinfos = new JSONArray();
- if (orderRows.isNotEmpty()) {
- sa_brandid = orderRows.get(0).getLong("sa_brandid");
- tradefield = orderRows.get(0).getString("tradefield");
- type = orderRows.get(0).getString("type");
- typemx = orderRows.get(0).getString("typemx");
- sys_enterpriseid = orderRows.get(0).getLong("sys_enterpriseid");
- sa_accountclassinfos = orderRows.get(0).getJSONArray("sa_accountclassinfos");
- }
- boolean iswuliao = false;
- for (Object sa_accountclassinfo : sa_accountclassinfos) {
- JSONObject jsonObject = (JSONObject) sa_accountclassinfo;
- if (jsonObject.getString("accountname").equals("物料账户")) {
- iswuliao = true;
- }
- }
- SQLFactory sqlFactory = new SQLFactory(this, "查询可添加商品列表", pageSize, pageNumber, pageSorting);
- switch (type) {
- // case "总部订单":
- // sqlFactory = new SQLFactory(this, "查询可添加商品列表_总部订单", pageSize, pageNumber, pageSorting);
- // break;
- case "特殊订单":
- if (typemx.equals("电商") || typemx.equals("工程")) {
- sqlFactory = new SQLFactory(this, "查询可添加商品列表_总部订单", pageSize, pageNumber, pageSorting);
- } else {
- sqlFactory = new SQLFactory(this, "查询可添加商品列表_特殊订单", pageSize, pageNumber, pageSorting);
- }
- sqlFactory.addParameter("tradefield", tradefield);
- if (sys_enterpriseid1 > 0) {
- where.append(" and t1.isonsale ='1' ");
- }
- break;
- default:
- StringBuffer where2 = new StringBuffer(" 1=1 ");
- Row enterpriseRow = Enterprise.getEnterprise(this, sys_enterpriseid);
- boolean saleclassauth = enterpriseRow.getBoolean("saleclassauth");
- //需要经营授权
- if (saleclassauth) {
- where2.append(" and t1.itemclassid in (SELECT itemclassid from sys_enterprise_saleclass WHERE sys_enterpriseid = " + sys_enterpriseid + " and siteid = '" + siteid + "')");
- }
- sqlFactory.addParameter("sa_brandid", sa_brandid);
- sqlFactory.addParameter("tradefield", tradefield);
- sqlFactory.addParameter_SQL("where2", where2);
- break;
- }
- if (iswuliao) {
- where.append(" and t1.iswuliao ='1' ");
- }
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter_SQL("where", where);
- String sql = sqlFactory.getSQL(false);
- Rows rows = dbConnect.runSqlQuery(sql);
- ArrayList<Long> ids = rows.toArrayList("itemid", new ArrayList<>());
- //查询附件
- RowsMap attinfoRowsMap = getAttachmentUrl("plm_item", ids);
- //商品领域
- RowsMap tradefieldRowsMap = beans.Item.Item.getTradefieldRowsMap(this, ids);
- //品牌
- RowsMap brandRowsMap = Brand.getBrandRowsMap(this, ids);
- //价格
- HashMap<Long, ItemPrice> itemPriceRowsMap = ItemPrice.getItemPrice(this, sys_enterpriseid, ids);
- //定制信息
- CustomScheme customScheme = new CustomScheme(this);
- for (Row row : rows) {
- row.put("attinfos", attinfoRowsMap.getOrDefault(row.getString("itemid"), new Rows()));
- row.put("tradefield", tradefieldRowsMap.getOrDefault(row.getString("itemid"), new Rows()));
- row.put("brand", brandRowsMap.getOrDefault(row.getString("itemid"), new Rows()));
- if (itemPriceRowsMap.containsKey(row.getLong("itemid"))) {
- BigDecimal price;
- if(siteid.equalsIgnoreCase("ccyosg")){
- if( itemPriceRowsMap.get(row.getLong("itemid")).getQinminPrice().compareTo(BigDecimal.ZERO)>0){
- if( itemPriceRowsMap.get(row.getLong("itemid")).getQinminPrice().compareTo( itemPriceRowsMap.get(row.getLong("itemid")).getGraderateprice())<=0){
- price = itemPriceRowsMap.get(row.getLong("itemid")).getQinminPrice();
- }else{
- price = itemPriceRowsMap.get(row.getLong("itemid")).getGraderateprice();
- }
- }else{
- price = itemPriceRowsMap.get(row.getLong("itemid")).getGraderateprice();
- }
- }else{
- price = itemPriceRowsMap.get(row.getLong("itemid")).getGraderateprice();
- }
- row.put("price", price);
- row.put("price1", itemPriceRowsMap.get(row.getLong("itemid")).getGraderateprice());
- } else {
- row.put("price", 0);
- row.put("price1", 0);
- }
- row = customScheme.setScheme(row, "width");
- row = customScheme.setScheme(row, "length");
- row = customScheme.setScheme(row, "material");
- row = customScheme.setScheme(row, "color");
- row = customScheme.setScheme(row, "cheek");
- if (row.getLong("width") == 0) {
- row.replace("width", null);
- }
- if (row.getLong("length") == 0) {
- row.replace("length", null);
- }
- }
- return getSucReturnObject().setData(rows).toString();
- }
- @API(title = "判断订单中是否存在某个套餐", apiversion = R.ID2024062715055803.v1.class)
- @CACHEING
- public String jundgePackagetypemx() throws YosException {
- String packagetypemx =content.getString("packagetypemx");
- long sa_orderid=content.getLong("sa_orderid");
- Rows rows =dbConnect.runSqlQuery("select t1.sa_orderitemsid from sa_orderitems t1 inner join sa_promotion_items t2 on t1.sa_promotion_itemsid=t2.sa_promotion_itemsid and t1.siteid=t2.siteid where t1.siteid='"+siteid+"' and t1.sa_orderid="+sa_orderid+" and t2.packagetypemx="+packagetypemx);
- if(rows.isNotEmpty()){
- return getSucReturnObject().setData(true).toString();
- }else {
- return getSucReturnObject().setData(false).toString();
- }
- }
- //获取非工具数据
- public String getOrderItemsList(Long sa_orderid, String tradefield, Long sys_enterpriseid, Long sa_brandid) throws YosException {
- StringBuffer where = new StringBuffer(" 1=1 ");
- Row enterpriseRow = Enterprise.getEnterprise(this, sys_enterpriseid);
- boolean saleclassauth = enterpriseRow.getBoolean("saleclassauth");
- //需要经营授权
- if (saleclassauth) {
- where.append(" and itemclassid in (SELECT itemclassid from sys_enterprise_saleclass WHERE sys_enterpriseid = " + sys_enterpriseid + " and siteid = '" + siteid + "')");
- }
- SQLFactory sqlFactory = new SQLFactory(this, "商品范围");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter("sa_orderid", sa_orderid);
- sqlFactory.addParameter_in("tradefield", tradefield);
- sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
- sqlFactory.addParameter("sa_brandid", sa_brandid);
- sqlFactory.addParameter_SQL("where", where);
- return sqlFactory.getSQL(false);
- }
- // //获取特殊数据
- // public String getOrderItemsListSpec(Long sa_orderid, String tradefield, Long sys_enterpriseid) throws YosException {
- // SQLFactory sqlFactory = new SQLFactory(this, "商品范围_特殊");
- // sqlFactory.addParameter("siteid", siteid);
- // sqlFactory.addParameter("sa_orderid", sa_orderid);
- // sqlFactory.addParameter_in("tradefield", tradefield);
- // sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
- // return sqlFactory.getSQL(false);
- // }
- @API(title = "订单商品变更", apiversion = R.ID20221110145302.v1.class)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class})
- public String changeItem() throws YosException {
- boolean isjiean = content.getBooleanValue("isjiean");
- Long sa_orderid = content.getLong("sa_orderid");
- //通过版本更新订单表头数据
- beans.order.Order.updateOrderWithVersion(this);
- String type = content.getString("type");
- Long sa_orderitems_changeid = createTableID("sa_orderitems_change");
- JSONArray itemifnos = content.getJSONArray("itemifnos");
- BigDecimal oldValue = new BigDecimal(0);
- Rows Rowstatus = dbConnect.runSqlQuery(
- "select * from sa_order where sa_orderid=" + sa_orderid + " and siteid='" + siteid + "'");
- if (Rowstatus.isEmpty()) {
- return "订单不存在";
- } else {
- if (!Rowstatus.get(0).getString("status").equals("审核")) {
- return getErrReturnObject().setErrMsg("非审核状态的订单无法进行商品变更").toString();
- }
- }
- ArrayList<String> sqlList = new ArrayList<>();
- // 订单商品变更
- SQLFactory sqlFactory = new SQLFactory(this, "订单商品变更_新增");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter("userid", userid);
- sqlFactory.addParameter("username", username);
- sqlFactory.addParameter("sa_orderitems_changeid", sa_orderitems_changeid);
- sqlFactory.addParameter("sa_orderid", sa_orderid);
- sqlFactory.addParameter("remarks", content.getStringValue("remarks"));
- sqlList.add(sqlFactory.getSQL());
- HashMap<Long, Row> orderdetailmap = new HashMap<>();
- HashMap<Long, BigDecimal> orderdetailchangeamount = new HashMap<>();
- Rows rowsOrder = dbConnect.runSqlQuery("select * from sa_order t1 where t1.sa_orderid=" + sa_orderid);
- BigDecimal ce = new BigDecimal(0);
- for (Object obj : itemifnos) {
- JSONObject jsonObject = (JSONObject) obj;
- Rows rows = dbConnect.runSqlQuery(
- "SELECT sa_orderitemsid,qty,deliedqty,undeliqty,writeoffamount,price from sa_orderitems WHERE sa_orderitemsid="
- + jsonObject.getLongValue("sa_orderitemsid"));
- if (rows.isNotEmpty()) {
- oldValue = rows.get(0).getBigDecimal("qty");
- } else {
- return getErrReturnObject().setErrMsg("订单行不存在").toString();
- }
- if (type.equals("数量")) {
- // 更新数量
- BigDecimal newqty = jsonObject.getBigDecimal("newvalue");
- BigDecimal oldqty = rows.get(0).getBigDecimal("qty");
- BigDecimal oldundeliqty = rows.get(0).getBigDecimal("undeliqty");
- BigDecimal addqty = newqty.subtract(oldqty);// 新增的数量
- if (newqty.compareTo(oldqty) >= 0) {
- return getErrReturnObject().setErrMsg("修改数量必须小于原订单数量" + oldqty).toString();
- }
- if (newqty.compareTo(oldqty.subtract(oldundeliqty)) < 0) {
- return getErrReturnObject().setErrMsg("修改数量必须大于等于已发货数量" + oldqty.subtract(oldundeliqty)).toString();
- }
- if (newqty.compareTo(BigDecimal.ZERO) < 0) {
- return getErrReturnObject().setErrMsg("修改数量不可小于0").toString();
- }
- sqlFactory = new SQLFactory(this, "订单商品明细变更_更新");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter("sa_orderitemsid", jsonObject.getLongValue("sa_orderitemsid"));
- sqlFactory.addParameter("qty", jsonObject.getStringValue("newvalue"));
- // sqlFactory.addParameter("undeliqty", oldundeliqty.add(addqty));
- ce = ce.add(addqty.multiply(rows.get(0).getBigDecimal("price")));
- sqlList.add(sqlFactory.getSQL());
- /**
- * * 核销对冲计算
- */
- {
- /**
- * * 核销对冲计算
- */
- BigDecimal writeoffamount = rows.get(0).getBigDecimal("writeoffamount");// 订单行已核销金额
- //System.out.println(newqty.multiply(rows.get(0).getBigDecimal("price")));
- //System.out.println(writeoffamount);
- if (writeoffamount.compareTo(BigDecimal.ZERO) > 0
- && (newqty.multiply(rows.get(0).getBigDecimal("price"))).compareTo(writeoffamount) < 0) {
- // 如果已核销金额大于0 且调整后折后金额小于已核销金额,则需要将差价进行回冲
- orderdetailmap.put(rows.get(0).getLong("sa_orderitemsid"), rows.get(0));
- //System.out.println(writeoffamount.subtract(newqty.multiply(rows.get(0).getBigDecimal("price"))));
- //System.out.println("sa_orderitemsid:"+rows.get(0).getLong("sa_orderitemsid"));
- orderdetailchangeamount.put(rows.get(0).getLong("sa_orderitemsid"),
- writeoffamount.subtract(newqty.multiply(rows.get(0).getBigDecimal("price"))));
- }
- }
- }
- // 订单商品变更明细
- sqlFactory = new SQLFactory(this, "订单商品变更明细_新增");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter("sa_orderitems_changemxid", createTableID("sa_orderitems_changemx"));
- sqlFactory.addParameter("itemid", jsonObject.getLongValue("itemid"));
- sqlFactory.addParameter("sa_orderitemsid", jsonObject.getLongValue("sa_orderitemsid"));
- sqlFactory.addParameter("sa_orderitems_changeid", sa_orderitems_changeid);
- sqlFactory.addParameter("type", type);
- sqlFactory.addParameter("oldvalue", oldValue);
- sqlFactory.addParameter("newvalue", jsonObject.getStringValue("newvalue"));
- sqlList.add(sqlFactory.getSQL());
- // content.put("sa_orderitemsid", sa_orderitemsid);
- }
- Long sa_cashbillid = 0L;
- if (ce.compareTo(BigDecimal.ZERO) != 0) {
- CashbillEntity cashbillEntity = new CashbillEntity();
- cashbillEntity.setAmount(ce);
- cashbillEntity.setOwnerid(sa_orderid);
- cashbillEntity.setOwnertable("sa_order");
- cashbillEntity
- .setRemarks("订单变更:" + rowsOrder.get(0).getString("sonum") + "订单变更单id:" + sa_orderitems_changeid);
- JSONObject cashbillPay = Accountbalance.createCashbillPay(this, rowsOrder.get(0).getLong("sys_enterpriseid"),
- rowsOrder.get(0).getLong("sa_accountclassid"), cashbillEntity, true);
- sqlList.addAll(cashbillPay.getJSONArray("sqlList").toJavaList(String.class));
- sa_cashbillid = cashbillPay.getLong("sa_cashbillid");
- }
- /**
- * * 核销对冲
- */
- if (!orderdetailmap.isEmpty()) {
- //System.out.println("测试");
- sqlList.addAll(
- new twriteoffbill_orderchange(rowsOrder.get(0), orderdetailmap, orderdetailchangeamount).hedging());
- }
- for (String string : sqlList) {
- //System.out.println(string);
- }
- dbConnect.runSqlUpdate(sqlList);
- // 居间费设置
- updateRebateFee(sa_orderid);
- if (!isjiean) {
- if (Parameter.get("system.erp_dockswitch").equalsIgnoreCase("true")) {
- UploadDataToERP uploadDataToERP = new UploadDataToERP(this, sa_orderitems_changeid, "订单变更");
- boolean issuccess = uploadDataToERP.upload();
- if (!issuccess) {
- return getErrReturnObject().setErrMsg("上传ERP失败,请检查!").toString();
- }
- }
- }
- if (ce.compareTo(BigDecimal.ZERO) != 0) {
- Accountbalance.remindSend(this, rowsOrder.get(0).getLong("sys_enterpriseid"), sa_cashbillid);
- }
- return getSucReturnObject().toString();
- }
- @API(title = "订单商品变更(手动推erp)", apiversion = R.ID20230306161703.v1.class)
- @CACHEING_CLEAN(apiClass = {Order.class, OrderItems.class, restcontroller.sale.order.Order.class})
- public String changeItem1() throws YosException {
- if (Parameter.get("system.erp_dockswitch").equalsIgnoreCase("true")) {
- UploadDataToERP uploadDataToERP = new UploadDataToERP(this, content.getLong("sa_orderitems_changeid"), "订单变更");
- boolean issuccess = uploadDataToERP.upload();
- if (!issuccess) {
- return getErrReturnObject().setErrMsg("上传ERP失败,请检查!").toString();
- } else {
- return getSucReturnObject().toString();
- }
- } else {
- return getErrReturnObject().setErrMsg("erp对接开关未开!").toString();
- }
- }
- /**
- * 获取当前订单的最大行号
- *
- * @param sa_orderid
- * @return
- * @throws YosException
- */
- public Long getRowNo(Long sa_orderid) throws YosException {
- Rows rows = dbConnect.runSqlQuery("SELECT COUNT(0) count from sa_orderitems WHERE sa_orderid = " + sa_orderid + " AND siteid = '" + siteid + "'");
- return rows.get(0).getLong("count") + 1;
- }
- /**
- * 查询商品信息
- *
- * @param itemid
- * @return
- * @throws YosException
- */
- public Row getItemRow(Long itemid) throws YosException {
- SQLFactory sqlFactory = new SQLFactory(this, "查询商品信息");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter("itemid", itemid);
- Rows rows = dbConnect.runSqlQuery(sqlFactory.getSQL(false));
- return rows.isNotEmpty() ? rows.get(0) : new Row();
- }
- /**
- * 重新对商品行排序
- *
- * @param sa_orderid
- * @throws YosException
- */
- public void updateRowNo(Long sa_orderid) throws YosException {
- String sql = "SELECT sa_orderitemsid from sa_orderitems WHERE sa_orderid= " + sa_orderid + " and siteid = '" + siteid + "' ORDER BY createdate ";
- ArrayList<Long> sa_orderitemsids = dbConnect.runSqlQuery(sql).toArrayList("sa_orderitemsid", new ArrayList<>(),false);
- if (sa_orderitemsids.size() > 0) {
- int rowno = 1;
- StringBuffer where = new StringBuffer("");
- for (Long id : sa_orderitemsids) {
- where.append(" WHEN " + id + " THEN " + rowno);
- rowno++;
- }
- SQLFactory sqlFactory = new SQLFactory(this, "更新行号");
- sqlFactory.addParameter("siteid", siteid);
- sqlFactory.addParameter_SQL("where", where);
- sqlFactory.addParameter_in("sa_orderitemsid", sa_orderitemsids);
- sql = sqlFactory.getSQL(false);
- dbConnect.runSqlUpdate(sql);
- }
- }
- }
|