/// <summary> /// Method to make charges /// </summary> /// <param name="stockCode">Stock code</param> /// <param name="stockType">Stock type</param> /// <returns>Charges</returns> private Charges GetCharges(string stockCode, char stockType) { var dateStart = DateTime.Now; Performancelog.Debug($"Start,StockManager,GetCharges,{string.Empty},{DateTime.Now:hh.mm.ss.ffffff}"); var cg = new Charges(); if (stockType == 'G') { return(null); } var allTaxes = _taxService.GetAllTaxes(); // Load Charges var charges = _stockService.GetAssociateCharges(stockCode); foreach (var charge in charges) { var taxes = _stockService.GetTax(charge.AsCode); var cs = new Charge_Taxes(); foreach (var tax in taxes) { var taxMast = allTaxes.FirstOrDefault(t => t.TaxName == tax.Tax_Name && t.Active.HasValue && t.Active.Value); if (taxMast != null) { cs.Add(Convert.ToString(tax.Tax_Name), Convert.ToString(tax.Tax_Code), Convert.ToSingle(tax.Tax_Rate), Convert.ToBoolean(tax.Tax_Included), ""); } } cg.Add(Convert.ToString(charge.AsCode), Convert.ToString(charge.Description), Convert.ToSingle(charge.Price), cs, ""); } var returnValue = cg; Performancelog.Debug($"End,StockManager,GetCharges,{DateTime.Now.Subtract(dateStart).TotalMilliseconds},{DateTime.Now:hh.mm.ss.ffffff}"); return(returnValue); }
/// <summary> /// Method to save vendor payout /// </summary> /// <param name="po">Payout</param> /// <param name="tillNumber">Till number</param> /// <param name="userCode">User code</param> /// <param name="registerNumber">Register number</param> /// <param name="taxes">Taxes</param> /// <param name="openDrawer">Open cash drawer</param> /// <param name="error">Error message</param> /// <returns>Report</returns> public Report SaveVendorPayout(Payout po, int tillNumber, string userCode, byte registerNumber, List <Tax> taxes, out bool openDrawer, out ErrorMessage error) { openDrawer = false; var sale = _saleManager.GetCurrentSale(po.Sale_Num, tillNumber, 0, userCode, out error); var offSet = _policyManager.LoadStoreInfo().OffSet; if (!string.IsNullOrEmpty(error.MessageStyle.Message)) { return(null); } if (!_policyManager.DO_PAYOUTS || (sale != null && sale.Sale_Lines.Count > 0)) { MessageType temp_VbStyle8 = (int)MessageType.Exclamation + MessageType.OkOnly; error.MessageStyle = _resourceManager.CreateMessage(offSet, 38, 54, null, temp_VbStyle8); return(null); } if (po.Gross > (decimal)214748.3647) { error = new ErrorMessage { MessageStyle = new MessageStyle { Message = "Maximum payout amount is 214748.3647" } }; return(null); } var salePo = new Sale(); var tendPo = new Tenders(); var curr = Convert.ToString(_policyManager.BASECURR); if (string.IsNullOrEmpty(curr)) { MessageType temp_VbStyle = (int)MessageType.OkOnly + MessageType.Critical; error.MessageStyle = _resourceManager.CreateMessage(offSet, 23, 94, null, temp_VbStyle); return(null); } var poTaxes = _taxService.GetAllTaxes(); float sumTaxes = 0; foreach (var tax in taxes) { if (poTaxes.Any(p => p.TaxName == tax.Code)) { po.Payout_Taxes.Add(tax.Code, "", tax.Amount, true, tax.Code); salePo.Sale_Totals.Sale_Taxes.Add(tax.Code, "I", 0, 0, 0, tax.Amount, po.Gross, 0, 0, ""); sumTaxes = (float)(sumTaxes + Conversion.Val(tax.Amount)); } else { MessageType temp_VbStyle8 = (int)MessageType.Exclamation + MessageType.OkOnly; error.MessageStyle = new MessageStyle { Message = "Invalid tax entered", MessageType = temp_VbStyle8 }; return(null); } } if (!string.IsNullOrEmpty(po.Vendor.Code)) { po.Vendor = _stockService.GetVendorByCode(po.Vendor.Code); if (po.Vendor.Code == null) { MessageType temp_VbStyle2 = (int)MessageType.Critical + MessageType.OkOnly; error.MessageStyle = new MessageStyle { Message = "Invalid vendor code", MessageType = temp_VbStyle2 }; return(null); } } // Nicoolette changed next line on Nov 13,2007 to allow negative payouts, based on Mr. Gas requirement if (po.Gross == 0) { // If PO.Gross <= 0 Then //You must specify the Payout Amount, vbCritical + vbOKOnly MessageType temp_VbStyle2 = (int)MessageType.Critical + MessageType.OkOnly; error.MessageStyle = _resourceManager.CreateMessage(offSet, 23, 91, null, temp_VbStyle2); return(null); } if (_policyManager.PO_REASON) { po.Return_Reason = _reasonService.GetReturnReason(po.Return_Reason.Reason, (char)ReasonType.Payouts); if (po.Return_Reason == null) { MessageType temp_VbStyle2 = (int)MessageType.Critical + MessageType.OkOnly; error.MessageStyle = _resourceManager.CreateMessage(offSet, 23, 92, null, temp_VbStyle2); return(null); } salePo.Return_Reason = po.Return_Reason; } var till = _tillService.GetTill(tillNumber); till.Cash = till.Cash - po.Gross; _tillService.UpdateTill(till); if (_policyManager.OPEN_DRAWER == "Every Sale") { openDrawer = true; } tendPo.Add(curr, "Cash", 1, true, true, false, 1, curr, false, 0, 0, 0.01, true, Convert.ToDouble((object)-po.Gross), 1, true, false, "", ""); _tenderManager.Set_Amount_Entered(ref tendPo, ref salePo, tendPo[1], -po.Gross, -1); // payout if (_policyManager.PENNY_ADJ && po.Gross != 0) { salePo.Sale_Totals.Penny_Adj = modGlobalFunctions.Calculate_Penny_Adj(po.Gross); } else { salePo.Sale_Totals.Penny_Adj = 0; } po.Penny_Adj = salePo.Sale_Totals.Penny_Adj; // end salePo.Sale_Totals.Net = po.Gross; // - Sum_Taxes Nicolette commented out, // once for payout all taxes are included, don't subtract the taxes, // this will afect Sale_Amt in SaleHead, March 07, 2003 var saleTotals = salePo.Sale_Totals; _saleManager.SetGross(ref saleTotals, salePo.Sale_Totals.Net); salePo.Sale_Totals.Gross = saleTotals.Gross; salePo.Sale_Totals.TotalLabel = saleTotals.TotalLabel; salePo.Sale_Totals.SummaryLabel = saleTotals.SummaryLabel; salePo.Register = Convert.ToByte(registerNumber); salePo.Sale_Change = 0; salePo.TillNumber = Convert.ToByte(tillNumber); salePo.Sale_Date = DateTime.Now; salePo.Sale_Tender = 0; salePo.Sale_Totals.PayOut = po.Gross; salePo.Sale_Change = 0; salePo.Sale_Amount = 0; if (po.Sale_Num == 0) { salePo.Sale_Num = _saleManager.GetSaleNo(tillNumber, userCode, out error); } else { salePo.Sale_Num = po.Sale_Num; } po.Penny_Adj = salePo.Sale_Totals.Penny_Adj; // salePo.Sale_Type = "PAYOUT"; salePo.Vendor = po.Vendor.Code; var user = _userService.GetUser(userCode); var stream = _receiptManager.Print_Payout(po, userCode, user.Name, DateTime.Today, salePo.Sale_Date, registerNumber, till); stream.Copies = _policyManager.PayoutReceiptCopies; _saleManager.SaveSale(salePo, userCode, ref tendPo, null); _saleManager.Clear_Sale(salePo, po.Sale_Num, salePo.TillNumber, userCode, "", null, false, false, false, out error); return(stream); }