// POST api/osalesorder //public void Post([FromBody]string value) //{ //} public RTNMANVAL Post([FromBody] SO_HEADER value) { RTNMANVAL returnVal = null; SAPbobsCOM.Company oCompany = null; string newKey = ""; try { oCompany = Company.GetCompany(Properties.Settings.Default.StrDbServer, Properties.Settings.Default.StrDbUserName, Properties.Settings.Default.StrDbPassword, Properties.Settings.Default.StrDbName, Properties.Settings.Default.StrSapB1UserName, Properties.Settings.Default.StrSapB1Password, Properties.Settings.Default.StrSapB1LicenseServer); newKey = Logic.SAP.SAP_SO.AddData(oCompany, value); returnVal = new RTNMANVAL() { errorCode = "0", message = "Data has beed added", value = newKey }; } catch (Exception e) { returnVal = new RTNMANVAL() { errorCode = "-1", message = e.Message.ToString() }; } return(returnVal); }
// GET api/osalesorder/5 public RTNVAL Get(int id) { RTNVAL returnVal = null; SAPbobsCOM.Company oCompany = null; try { oCompany = Company.GetCompany(Properties.Settings.Default.StrDbServer, Properties.Settings.Default.StrDbUserName, Properties.Settings.Default.StrDbPassword, Properties.Settings.Default.StrDbName, Properties.Settings.Default.StrSapB1UserName, Properties.Settings.Default.StrSapB1Password, Properties.Settings.Default.StrSapB1LicenseServer); SO_HEADER model = Logic.SAP.SAP_SO.GetData(oCompany, id); int count = 0; string message = "No Data Found"; if (model.DocEntry != "") { count = 1; message = "Get Data Successfull"; } returnVal = new SOSKALARVAL() { errorCode = "0", message = message, values = model, recordCount = count }; } catch (Exception e) { returnVal = new SOSKALARVAL() { errorCode = "-1", message = e.Message.ToString() }; } return(returnVal); }
private void MapToHeaderRow(OrderHedRow row, SO_HEADER entity) { row.Company = entity.CompanyCode; row.TermsCode = entity.TermCode; row.CurrencyCode = entity.CurrencyCode; row.BaseCurrencyID = entity.CurrencyCode; row.CustNum = int.Parse(entity.Custnum); row.BTCustNum = int.Parse(entity.BTCustnum); row.ShipToCustNum = int.Parse(entity.ShiptoCustnum); row.OrderDate = entity.DeliveryDate; row.RequestDate = entity.DeliveryDate; row.NeedByDate = entity.DeliveryDate; row.ShipViaCode = "VAN"; row.TaxRegionCode = "VAT"; row.UserChar1 = entity.DocNum; var salesRepList = entity.SaleID.Split('~'); row.SalesRepCode1 = salesRepList.Length > 0 ? salesRepList[0] : null; row.SalesRepCode2 = salesRepList.Length > 1 ? salesRepList[1] : null; row.SalesRepCode3 = salesRepList.Length > 2 ? salesRepList[2] : null; row.SalesRepCode4 = salesRepList.Length > 3 ? salesRepList[3] : null; row.SalesRepCode5 = salesRepList.Length > 4 ? salesRepList[4] : null; }
public static string AddData(Company oCompany, SO_HEADER model) { Documents oObject = null; RTNMANVAL rtn = new RTNMANVAL(); int errCode; string errMessage, strResult = ""; try { oCompany.StartTransaction(); oObject = oCompany.GetBusinessObject(BoObjectTypes.oOrders); oObject.CardCode = model.CardCode; oObject.DocDate = model.PostingDate; oObject.DocDueDate = model.DocDueDate; oObject.TaxDate = model.DocDueDate; oObject.DocType = BoDocumentTypes.dDocument_Items; //oObject.DocTotal = model.TotalTransaction; oObject.UserFields.Fields.Item("U_DocumentNumberingPOS").Value = model.DocumentNumberingPOS; oObject.UserFields.Fields.Item("U_PrimaryNumberingPOS").Value = model.PrimaryNumberingPOS; oObject.SalesPersonCode = Convert.ToInt32(model.SalesPersonCode); for (int i = 0; i < model.Lines.Count; i++) { oObject.Lines.ItemCode = model.Lines[i].ItemCode; oObject.Lines.WarehouseCode = model.Lines[i].WarehouseCode; //oObject.Lines.UoMEntry = model.lines[i].UomEntry ; oObject.Lines.DiscountPercent = model.Lines[i].DiscountPercent; oObject.Lines.UnitPrice = model.Lines[i].Price; oObject.Lines.Quantity = model.Lines[i].Quantity; oObject.Lines.Add(); } int addStatus = oObject.Add(); if (addStatus == 0) { if (strResult == "") { strResult = oCompany.GetNewObjectKey(); } else { strResult = strResult + " | " + oCompany.GetNewObjectKey(); } } else { if (oCompany.InTransaction) { oCompany.EndTransaction(BoWfTransOpt.wf_RollBack); } oCompany.GetLastError(out errCode, out errMessage); throw new Exception("Error Code : " + errCode + " | Error Message : " + errMessage); } oCompany.EndTransaction(BoWfTransOpt.wf_Commit); } catch (Exception) { if (oCompany.InTransaction) { oCompany.EndTransaction(BoWfTransOpt.wf_RollBack); } ; throw; } return(strResult); }
public static SO_HEADER GetData(SAPbobsCOM.Company oCompany, int id) { Utils control = new Utils(); List <SO_DETAIL> details = new List <SO_DETAIL>(); XDocument xDoc = new XDocument(); XDocument xDocDetail = new XDocument(); string sql = "select U_PrimaryNumberingPOS, U_DocumentNumberingPOS, docentry, docnum, CardCode, " + "CardName, DocDate, DocDueDate, TaxDate, DocTotal, t0.slpcode, slpname from ordr t0 " + "join oslp t1 on t0.slpcode = t1.slpcode where docentry = " + id; Recordset rs = control._IDU_Recordset(oCompany, sql); xDoc = XDocument.Parse(rs.GetAsXML()); sql = "select t1.LineNum, ItemCode, dscription, UomEntry, UomCode, Quantity,Price, t2.WhsCode, t2.WhsName, t1.DiscPrcnt from rdr1 t1 " + "join owhs t2 on t1.WhsCode = t2.WhsCode where t1.docentry = " + id; rs = control._IDU_Recordset(oCompany, sql); xDocDetail = XDocument.Parse(rs.GetAsXML()); XElement xEle = xDoc.Element("BOM").Element("BO").Element("ordr").Element("row"); XElement xEleDetail = xDocDetail.Element("BOM").Element("BO").Element("rdr1"); foreach (var item in xEleDetail.Elements("row")) { SO_DETAIL model_detail = new SO_DETAIL() { LineNum = Convert.ToInt32(item.Element("LineNum").Value), ItemCode = item.Element("ItemCode").Value, Description = item.Element("dscription").Value, UomEntry = Convert.ToInt32(item.Element("UomEntry").Value), UomCode = item.Element("UomCode").Value, Quantity = Convert.ToDouble(item.Element("Quantity").Value), Price = Convert.ToDouble(item.Element("Price").Value), WarehouseCode = item.Element("WhsCode").Value, WarehouseName = item.Element("WhsName").Value, DiscountPercent = Convert.ToDouble(item.Element("DiscPrcnt").Value) }; details.Add(model_detail); } SO_HEADER model = new SO_HEADER() { PrimaryNumberingPOS = xEle.Element("U_PrimaryNumberingPOS").Value, DocumentNumberingPOS = xEle.Element("U_DocumentNumberingPOS").Value, DocEntry = xEle.Element("docentry").Value, DocNum = xEle.Element("docnum").Value, CardCode = xEle.Element("CardCode").Value, CardName = xEle.Element("CardName").Value, SalesPersonCode = xEle.Element("slpcode").Value, SalesPersonName = xEle.Element("slpname").Value, PostingDate = DateTime.ParseExact(xEle.Element("DocDate").Value, "yyyyMMdd", CultureInfo.InvariantCulture, DateTimeStyles.None), DocDueDate = DateTime.ParseExact(xEle.Element("DocDueDate").Value, "yyyyMMdd", CultureInfo.InvariantCulture, DateTimeStyles.None), TaxDate = DateTime.ParseExact(xEle.Element("TaxDate").Value, "yyyyMMdd", CultureInfo.InvariantCulture, DateTimeStyles.None), TotalTransaction = Convert.ToDouble(xEle.Element("DocTotal").Value), Lines = details }; return(model); }