public void CreateOrderDiscount(OrderDiscount orderDiscount) { try { _daoManager.OpenConnection(); _orderDiscountDao.CreateOrderDiscount(orderDiscount); } catch (Exception exception) { LogHelper.GetInstance().Error(string.Format("[CreateOrderDiscount]参数:orderDiscount_{0}", JsonConvert.SerializeObject(orderDiscount)), exception); } finally { _daoManager.CloseConnection(); } }
public bool UpdateOrderDiscount(OrderDiscount orderDiscount) { bool result = false; try { _daoManager.OpenConnection(); result = _orderDiscountDao.UpdateOrderDiscount(orderDiscount); } catch (Exception exception) { LogHelper.GetInstance().Error(string.Format("[UpdateOrderDiscount]参数:orderDiscount_{0}", JsonConvert.SerializeObject(orderDiscount)), exception); } finally { _daoManager.CloseConnection(); } return result; }
/// <summary> /// 0:提交失败 1:成功 2:没有可提交的数据 3:沽清失败 /// </summary> private Int32 SubmitSalesOrder(string deskName, EatWayType eatType) { int result = 0; Guid orderId; if (_salesOrder == null) //新增的菜单 { orderId = Guid.NewGuid(); } else { orderId = _salesOrder.order.OrderID; } IList<GoodsCheckStock> temp = new List<GoodsCheckStock>(); IList<OrderDetails> newOrderDetailsList = new List<OrderDetails>(); IList<OrderDiscount> newOrderDiscountList = new List<OrderDiscount>(); foreach (DataGridViewRow dr in dgvGoodsOrder.Rows) { if (dr.Cells["OrderDetailsID"].Value == null) { Guid orderDetailsId = Guid.NewGuid(); int itemType = Convert.ToInt32(dr.Cells["ItemType"].Value); string goodsName = dr.Cells["GoodsName"].Value.ToString(); //填充OrderDetails OrderDetails orderDetails = new OrderDetails(); orderDetails.OrderDetailsID = orderDetailsId; orderDetails.OrderID = orderId; orderDetails.DeviceNo = ConstantValuePool.BizSettingConfig.DeviceNo; orderDetails.TotalSellPrice = Convert.ToDecimal(dr.Cells["GoodsPrice"].Value); orderDetails.TotalDiscount = Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value); orderDetails.ItemQty = Convert.ToDecimal(dr.Cells["GoodsNum"].Value); orderDetails.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; if (dr.Cells["Wait"].Value != null) { orderDetails.Wait = Convert.ToInt32(dr.Cells["Wait"].Value); } if (itemType == (int)OrderItemType.Goods) { orderDetails.ItemType = (int)OrderItemType.Goods; Goods goods = dr.Cells["ItemID"].Tag as Goods; if (goods != null) { orderDetails.GoodsID = goods.GoodsID; orderDetails.GoodsNo = goods.GoodsNo; orderDetails.GoodsName = goods.GoodsName; orderDetails.Unit = goods.Unit; orderDetails.CanDiscount = goods.CanDiscount; orderDetails.SellPrice = goods.SellPrice; orderDetails.PrintSolutionName = goods.PrintSolutionName; orderDetails.DepartID = goods.DepartID; if (goods.IsCheckStock) { GoodsCheckStock goodsCheckStock = new GoodsCheckStock(); goodsCheckStock.GoodsID = goods.GoodsID; goodsCheckStock.GoodsName = goods.GoodsName; goodsCheckStock.ReducedQuantity = orderDetails.ItemQty; temp.Add(goodsCheckStock); } } } else if (itemType == (int)OrderItemType.Details) { orderDetails.ItemType = (int)OrderItemType.Details; Details details = dr.Cells["ItemID"].Tag as Details; if (details != null) { orderDetails.GoodsID = details.DetailsID; orderDetails.GoodsNo = details.DetailsNo; orderDetails.GoodsName = details.DetailsName; orderDetails.CanDiscount = details.CanDiscount; orderDetails.Unit = ""; // orderDetails.SellPrice = details.SellPrice; orderDetails.PrintSolutionName = details.PrintSolutionName; orderDetails.DepartID = details.DepartID; } int index = goodsName.LastIndexOf('-'); string itemPrefix = goodsName.Substring(0, index + 1); orderDetails.ItemLevel = itemPrefix.Length / 2; } else if (itemType == (int)OrderItemType.SetMeal) { orderDetails.ItemType = (int)OrderItemType.SetMeal; int index = goodsName.LastIndexOf('-'); string itemPrefix = goodsName.Substring(0, index + 1); orderDetails.ItemLevel = itemPrefix.Length / 2; object item = dr.Cells["ItemID"].Tag; if (item is Goods) { Goods goods = item as Goods; orderDetails.GoodsID = goods.GoodsID; orderDetails.GoodsNo = goods.GoodsNo; orderDetails.GoodsName = goods.GoodsName; orderDetails.CanDiscount = goods.CanDiscount; orderDetails.Unit = goods.Unit; orderDetails.SellPrice = goods.SellPrice; orderDetails.PrintSolutionName = goods.PrintSolutionName; orderDetails.DepartID = goods.DepartID; } else if (item is Details) { Details details = item as Details; orderDetails.GoodsID = details.DetailsID; orderDetails.GoodsNo = details.DetailsNo; orderDetails.GoodsName = details.DetailsName; orderDetails.CanDiscount = details.CanDiscount; orderDetails.Unit = ""; // orderDetails.SellPrice = details.SellPrice; orderDetails.PrintSolutionName = details.PrintSolutionName; orderDetails.DepartID = details.DepartID; } } newOrderDetailsList.Add(orderDetails); //填充OrderDiscount Discount discount = dr.Cells["GoodsDiscount"].Tag as Discount; if (discount != null) { decimal offPay = Math.Abs(Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value)); if (offPay > 0) { OrderDiscount orderDiscount = new OrderDiscount(); orderDiscount.OrderDiscountID = Guid.NewGuid(); orderDiscount.OrderID = orderId; orderDiscount.OrderDetailsID = orderDetailsId; orderDiscount.DiscountID = discount.DiscountID; orderDiscount.DiscountName = discount.DiscountName; orderDiscount.DiscountType = discount.DiscountType; orderDiscount.DiscountRate = discount.DiscountRate; orderDiscount.OffFixPay = discount.OffFixPay; orderDiscount.OffPay = offPay; orderDiscount.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; newOrderDiscountList.Add(orderDiscount); } } } else { //修改过折扣的账单 Discount discount = dr.Cells["GoodsDiscount"].Tag as Discount; if (discount != null) { Guid orderDetailsId = new Guid(dr.Cells["OrderDetailsID"].Value.ToString()); //填充OrderDetails OrderDetails orderDetails = new OrderDetails(); orderDetails.OrderDetailsID = orderDetailsId; orderDetails.OrderID = orderId; orderDetails.DeviceNo = ConstantValuePool.BizSettingConfig.DeviceNo; orderDetails.ItemQty = Convert.ToDecimal(dr.Cells["GoodsNum"].Value); orderDetails.ItemType = Convert.ToInt32(dr.Cells["ItemType"].Value); orderDetails.GoodsName = dr.Cells["GoodsName"].Value.ToString(); orderDetails.TotalSellPrice = Convert.ToDecimal(dr.Cells["GoodsPrice"].Value); orderDetails.TotalDiscount = Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value); orderDetails.Unit = dr.Cells["ItemUnit"].Value.ToString(); orderDetails.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; if (dr.Cells["Wait"].Value != null) { orderDetails.Wait = Convert.ToInt32(dr.Cells["Wait"].Value); } newOrderDetailsList.Add(orderDetails); //填充OrderDiscount decimal offPay = Math.Abs(Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value)); if (offPay > 0) { OrderDiscount orderDiscount = new OrderDiscount(); orderDiscount.OrderDiscountID = Guid.NewGuid(); orderDiscount.OrderID = orderId; orderDiscount.OrderDetailsID = orderDetailsId; orderDiscount.DiscountID = discount.DiscountID; orderDiscount.DiscountName = discount.DiscountName; orderDiscount.DiscountType = discount.DiscountType; orderDiscount.DiscountRate = discount.DiscountRate; orderDiscount.OffFixPay = discount.OffFixPay; orderDiscount.OffPay = offPay; orderDiscount.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; newOrderDiscountList.Add(orderDiscount); } } } } //品项沽清 IList<GoodsCheckStock> tempGoodsStockList = GoodsService.GetInstance().GetGoodsCheckStock(); if (tempGoodsStockList != null && tempGoodsStockList.Count > 0 && temp.Count > 0) { IList<GoodsCheckStock> goodsCheckStockList = new List<GoodsCheckStock>(); foreach (GoodsCheckStock item in temp) { bool isContains = tempGoodsStockList.Any(tempGoodsStock => item.GoodsID.Equals(tempGoodsStock.GoodsID)); if (isContains) { goodsCheckStockList.Add(item); } } if (goodsCheckStockList.Count > 0) { string goodsName = GoodsService.GetInstance().UpdateReducedGoodsQty(goodsCheckStockList); if (!string.IsNullOrEmpty(goodsName)) { MessageBox.Show(string.Format("<{0}> 的剩余数量不足!", goodsName), "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); return 3; } } } if (_salesOrder == null) //新增的菜单 { Order order = new Order(); order.OrderID = orderId; order.TotalSellPrice = _totalPrice; order.ActualSellPrice = _actualPayMoney; order.DiscountPrice = _discount; order.CutOffPrice = _cutOff; order.ServiceFee = 0; order.DeviceNo = ConstantValuePool.BizSettingConfig.DeviceNo; order.DeskName = deskName; order.EatType = (int)eatType; order.Status = 0; order.PeopleNum = 1; order.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; order.EmployeeNo = ConstantValuePool.CurrentEmployee.EmployeeNo; SalesOrder salesOrder = new SalesOrder(); salesOrder.order = order; salesOrder.orderDetailsList = newOrderDetailsList; salesOrder.orderDiscountList = newOrderDiscountList; int tranSequence = SalesOrderService.GetInstance().CreateSalesOrder(salesOrder); if (tranSequence > 0) { //重新加载 _salesOrder = SalesOrderService.GetInstance().GetSalesOrder(orderId); BindGoodsOrderInfo(); //绑定订单信息 BindOrderInfoSum(); result = 1; } } else { if (newOrderDetailsList.Count > 0) { Order order = new Order(); order.OrderID = orderId; order.TotalSellPrice = _totalPrice; order.ActualSellPrice = _actualPayMoney; order.DiscountPrice = _discount; order.CutOffPrice = _cutOff; order.ServiceFee = 0; order.DeviceNo = ConstantValuePool.BizSettingConfig.DeviceNo; order.DeskName = deskName; order.PeopleNum = 1; order.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; order.EmployeeNo = ConstantValuePool.CurrentEmployee.EmployeeNo; SalesOrder salesOrder = new SalesOrder(); salesOrder.order = order; salesOrder.orderDetailsList = newOrderDetailsList; salesOrder.orderDiscountList = newOrderDiscountList; if (SalesOrderService.GetInstance().UpdateSalesOrder(salesOrder) == 1) { //重新加载 _salesOrder = SalesOrderService.GetInstance().GetSalesOrder(orderId); BindGoodsOrderInfo(); //绑定订单信息 BindOrderInfoSum(); result = 1; } } else { result = 2; } } if (eatType == EatWayType.OutsideOrder) { if (result == 1 || result == 2) { //添加外送信息 CustomerOrder customerOrder = new CustomerOrder { OrderID = orderId, Telephone = txtTelephone.Text.Trim(), CustomerName = txtName.Text.Trim(), Address = txtAddress.Text.Trim() }; if (!string.IsNullOrEmpty(customerOrder.Telephone) && !string.IsNullOrEmpty(customerOrder.CustomerName)) { if (CustomersService.GetInstance().CreateOrUpdateCustomerOrder(customerOrder)) { result = 1; } else { MessageBox.Show("添加外送信息失败!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Error); } } } } if (eatType == EatWayType.Takeout) { if (result == 1) { if (ConstantValuePool.BizSettingConfig.TakeoutPrint && ConstantValuePool.BizSettingConfig.printConfig.Enabled) { //打印 PrintData printData = new PrintData(); printData.ShopName = ConstantValuePool.CurrentShop.ShopName; printData.DeskName = deskName; printData.PersonNum = "1"; printData.PrintTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm"); printData.EmployeeNo = ConstantValuePool.CurrentEmployee.EmployeeNo; printData.TranSequence = _salesOrder.order.TranSequence.ToString(); printData.ShopAddress = ConstantValuePool.CurrentShop.RunAddress; printData.Telephone = ConstantValuePool.CurrentShop.Telephone; printData.GoodsOrderList = new List<GoodsOrder>(); foreach (OrderDetails item in newOrderDetailsList) { string strLevelFlag = string.Empty; if (item.ItemLevel > 0) { int levelCount = item.ItemLevel * 2; for (int i = 0; i < levelCount; i++) { strLevelFlag += "-"; } } GoodsOrder goodsOrder = new GoodsOrder(); goodsOrder.GoodsName = strLevelFlag + item.GoodsName; goodsOrder.GoodsNum = item.ItemQty.ToString("f1"); goodsOrder.SellPrice = (item.TotalSellPrice / item.ItemQty).ToString("f2"); goodsOrder.TotalSellPrice = item.TotalSellPrice.ToString("f2"); goodsOrder.TotalDiscount = item.TotalDiscount.ToString("f2"); goodsOrder.Unit = item.Unit; printData.GoodsOrderList.Add(goodsOrder); } int copies = ConstantValuePool.BizSettingConfig.printConfig.Copies; string paperWidth = ConstantValuePool.BizSettingConfig.printConfig.PaperWidth; if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.DRIVER) { string printerName = ConstantValuePool.BizSettingConfig.printConfig.Name; string paperName = ConstantValuePool.BizSettingConfig.printConfig.PaperName; DriverOrderPrint printer = DriverOrderPrint.GetInstance(printerName, paperName, paperWidth); for (int i = 0; i < copies; i++) { printer.DoPrintOrder(printData); } } if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.COM) { string port = ConstantValuePool.BizSettingConfig.printConfig.Name; if (port.Length > 3) { if (port.Substring(0, 3).ToUpper() == "COM") { string portName = port.Substring(0, 4).ToUpper(); InstructionOrderPrint printer = new InstructionOrderPrint(portName, 9600, Parity.None, 8, StopBits.One, paperWidth); for (int i = 0; i < copies; i++) { printer.DoPrintOrder(printData); } } } } if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.ETHERNET) { string ipAddress = ConstantValuePool.BizSettingConfig.printConfig.Name; InstructionOrderPrint printer = new InstructionOrderPrint(ipAddress, 9100, paperWidth); for (int i = 0; i < copies; i++) { printer.DoPrintOrder(printData); } } if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.USB) { string vid = ConstantValuePool.BizSettingConfig.printConfig.VID; string pid = ConstantValuePool.BizSettingConfig.printConfig.PID; string endpointId = ConstantValuePool.BizSettingConfig.printConfig.EndpointID; InstructionOrderPrint printer = new InstructionOrderPrint(vid, pid, endpointId, paperWidth); for (int i = 0; i < copies; i++) { printer.DoPrintOrder(printData); } } } } } return result; }
private bool ModifyForOrder(List<OrderPayoff> orderPayoffList, decimal paymentMoney, decimal needChangePay) { //填充Order Order order = new Order(); order.OrderID = m_SalesOrder.order.OrderID; order.TotalSellPrice = m_TotalPrice; order.ActualSellPrice = m_ActualPayMoney; order.DiscountPrice = m_Discount; order.CutOffPrice = m_CutOff; order.ServiceFee = m_ServiceFee; order.PaymentMoney = paymentMoney; order.NeedChangePay = needChangePay; order.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; //填充OrderDetails\OrderDiscount List<OrderDetails> orderDetailsList = new List<OrderDetails>(); List<OrderDiscount> orderDiscountList = new List<OrderDiscount>(); for (int i = 0; i < dgvGoodsOrder.RowCount; i++) { Discount itemDiscount = dgvGoodsOrder.Rows[i].Cells["GoodsDiscount"].Tag as Discount; if (itemDiscount != null) { decimal itemDiscountPrice = Convert.ToDecimal(dgvGoodsOrder.Rows[i].Cells["GoodsDiscount"].Value); OrderDetails orderDetails = CopyExtension.Clone<OrderDetails>(m_SalesOrder.orderDetailsList[i]); orderDetails.TotalDiscount = itemDiscountPrice; orderDetailsList.Add(orderDetails); //OrderDiscount OrderDiscount orderDiscount = new OrderDiscount(); orderDiscount.OrderDiscountID = Guid.NewGuid(); orderDiscount.OrderID = m_SalesOrder.order.OrderID; orderDiscount.OrderDetailsID = orderDetails.OrderDetailsID; orderDiscount.DiscountID = itemDiscount.DiscountID; orderDiscount.DiscountName = itemDiscount.DiscountName; orderDiscount.DiscountType = itemDiscount.DiscountType; orderDiscount.DiscountRate = itemDiscount.DiscountRate; orderDiscount.OffFixPay = itemDiscount.OffFixPay; orderDiscount.OffPay = Math.Abs(itemDiscountPrice); orderDiscount.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; orderDiscountList.Add(orderDiscount); } } ModifiedPaidOrder modifiedPaidOrder = new ModifiedPaidOrder(); modifiedPaidOrder.order = order; modifiedPaidOrder.orderDetailsList = orderDetailsList; modifiedPaidOrder.orderDiscountList = orderDiscountList; modifiedPaidOrder.orderPayoffList = orderPayoffList; return ModifyOrderService.GetInstance().ModifyForOrder(modifiedPaidOrder); }
private void btnPreCheck_Click(object sender, EventArgs e) { CrystalButton btn = sender as CrystalButton; Order order = m_SalesOrder.order; if (order.Status == 0) { //存在整单折扣则先提交 //填充Order Order submitOrder = new Order(); submitOrder.OrderID = order.OrderID; submitOrder.TotalSellPrice = m_TotalPrice; submitOrder.ActualSellPrice = m_ActualPayMoney; submitOrder.DiscountPrice = m_Discount; submitOrder.CutOffPrice = m_CutOff; submitOrder.ServiceFee = m_ServiceFee; submitOrder.MembershipCard = m_MembershipCard; submitOrder.MemberDiscount = m_MemberDiscountRate; //填充OrderDetails\OrderDiscount List<OrderDetails> orderDetailsList = new List<OrderDetails>(); List<OrderDiscount> newOrderDiscountList = new List<OrderDiscount>(); foreach (DataGridViewRow dr in dgvGoodsOrder.Rows) { OrderDetails orderDetails = dr.Cells["OrderDetailsID"].Tag as OrderDetails; if (orderDetails != null) { Discount itemDiscount = dr.Cells["GoodsDiscount"].Tag as Discount; decimal itemDiscountPrice = Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value); if (orderDetails.CanDiscount && itemDiscount != null && Math.Abs(itemDiscountPrice) > 0) { orderDetailsList.Add(orderDetails); //OrderDiscount OrderDiscount orderDiscount = new OrderDiscount(); orderDiscount.OrderDiscountID = Guid.NewGuid(); orderDiscount.OrderID = order.OrderID; orderDiscount.OrderDetailsID = orderDetails.OrderDetailsID; orderDiscount.DiscountID = itemDiscount.DiscountID; orderDiscount.DiscountName = itemDiscount.DiscountName; orderDiscount.DiscountType = itemDiscount.DiscountType; orderDiscount.DiscountRate = itemDiscount.DiscountRate; orderDiscount.OffFixPay = itemDiscount.OffFixPay; orderDiscount.OffPay = Math.Abs(Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value)); orderDiscount.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; newOrderDiscountList.Add(orderDiscount); } } } if (orderDetailsList.Count > 0 && newOrderDiscountList.Count > 0) { PayingOrder payingOrder = new PayingOrder(); payingOrder.order = submitOrder; payingOrder.orderDetailsList = orderDetailsList; payingOrder.orderDiscountList = newOrderDiscountList; bool result = PayingOrderService.GetInstance().CreatePrePayOrder(payingOrder); if (result) { btn.Text = "解锁"; order.Status = 3; //预结 m_IsPreCheckOut = true; } else { MessageBox.Show("预结账单失败,请重新操作!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } } else { int status = 3; //预结 if (OrderService.GetInstance().UpdateOrderStatus(order.OrderID, status)) { btn.Text = "解锁"; order.Status = status; m_IsPreCheckOut = true; } else { MessageBox.Show("预结账单失败,请重新操作!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } } //打印预结小票 PrintData printData = new PrintData(); printData.ShopName = ConstantValuePool.CurrentShop.ShopName; printData.DeskName = m_CurrentDeskName; printData.PersonNum = m_SalesOrder.order.PeopleNum.ToString(); printData.PrintTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm"); printData.EmployeeNo = ConstantValuePool.CurrentEmployee.EmployeeNo; printData.TranSequence = m_SalesOrder.order.TranSequence.ToString(); printData.ShopAddress = ConstantValuePool.CurrentShop.RunAddress; printData.Telephone = ConstantValuePool.CurrentShop.Telephone; printData.ReceivableMoney = this.lbReceMoney.Text; printData.ServiceFee = m_ServiceFee.ToString("f2"); printData.TotalAmount = (m_ActualPayMoney + m_ServiceFee).ToString("f2"); printData.GoodsOrderList = new List<GoodsOrder>(); foreach (OrderDetails item in m_SalesOrder.orderDetailsList) { string strLevelFlag = string.Empty; int levelCount = item.ItemLevel * 2; for (int i = 0; i < levelCount; i++) { strLevelFlag += "-"; } GoodsOrder goodsOrder = new GoodsOrder(); goodsOrder.GoodsName = strLevelFlag + item.GoodsName; goodsOrder.GoodsNum = item.ItemQty.ToString("f1"); goodsOrder.SellPrice = item.SellPrice.ToString("f2"); goodsOrder.TotalSellPrice = item.TotalSellPrice.ToString("f2"); goodsOrder.TotalDiscount = item.TotalDiscount.ToString("f2"); goodsOrder.Unit = item.Unit; printData.GoodsOrderList.Add(goodsOrder); } string paperWidth = ConstantValuePool.BizSettingConfig.printConfig.PaperWidth; if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.DRIVER) { string printerName = ConstantValuePool.BizSettingConfig.printConfig.Name; string paperName = ConstantValuePool.BizSettingConfig.printConfig.PaperName; DriverOrderPrint printer = DriverOrderPrint.GetInstance(printerName, paperName, paperWidth); printer.DoPrintPrePayOrder(printData); } if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.COM) { string port = ConstantValuePool.BizSettingConfig.printConfig.Name; if (port.Length > 3) { if (port.Substring(0, 3).ToUpper() == "COM") { string portName = port.Substring(0, 4).ToUpper(); InstructionOrderPrint printer = new InstructionOrderPrint(portName, 9600, Parity.None, 8, StopBits.One, paperWidth); printer.DoPrintPrePayOrder(printData); } } } if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.ETHERNET) { string ipAddress = ConstantValuePool.BizSettingConfig.printConfig.Name; InstructionOrderPrint printer = new InstructionOrderPrint(ipAddress, 9100, paperWidth); printer.DoPrintPrePayOrder(printData); } if (ConstantValuePool.BizSettingConfig.printConfig.PrinterPort == PortType.USB) { string vid = ConstantValuePool.BizSettingConfig.printConfig.VID; string pid = ConstantValuePool.BizSettingConfig.printConfig.PID; string endpointId = ConstantValuePool.BizSettingConfig.printConfig.EndpointID; InstructionOrderPrint printer = new InstructionOrderPrint(vid, pid, endpointId, paperWidth); printer.DoPrintPrePayOrder(printData); } } else if (order.Status == 3) { //权限验证 bool hasRights = false; if (RightsItemCode.FindRights(RightsItemCode.PRECHECKOUT)) { hasRights = true; } else { FormRightsCode form = new FormRightsCode(); form.ShowDialog(); if (form.ReturnValue) { IList<string> rightsCodeList = form.RightsCodeList; if (RightsItemCode.FindRights(rightsCodeList, RightsItemCode.PRECHECKOUT)) { hasRights = true; } } } if (!hasRights) { return; } int status = 0; if (OrderService.GetInstance().UpdateOrderStatus(order.OrderID, status)) { btn.Text = "预结"; order.Status = status; m_IsPreCheckOut = false; } else { MessageBox.Show("预结状态解锁失败,请重新操作!", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } } }
private bool PayForOrder(List<OrderPayoff> orderPayoffList, decimal paymentMoney, decimal needChangePay, string tradePayNo) { //填充Order Order order = new Order(); order.OrderID = m_SalesOrder.order.OrderID; order.TotalSellPrice = m_TotalPrice; order.ActualSellPrice = m_ActualPayMoney; order.DiscountPrice = m_Discount; order.CutOffPrice = m_CutOff; order.ServiceFee = m_ServiceFee; order.PaymentMoney = paymentMoney; order.NeedChangePay = needChangePay; order.MembershipCard = m_MembershipCard; order.MemberDiscount = m_MemberDiscountRate; order.PayEmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; order.PayEmployeeNo = ConstantValuePool.CurrentEmployee.EmployeeNo; order.CheckoutDeviceNo = ConstantValuePool.BizSettingConfig.DeviceNo; order.TradePayNo = tradePayNo; //填充OrderDetails\OrderDiscount List<OrderDetails> orderDetailsList = new List<OrderDetails>(); List<OrderDiscount> newOrderDiscountList = new List<OrderDiscount>(); foreach (DataGridViewRow dr in dgvGoodsOrder.Rows) { OrderDetails orderDetails = dr.Cells["OrderDetailsID"].Tag as OrderDetails; if (orderDetails != null) { Discount itemDiscount = dr.Cells["GoodsDiscount"].Tag as Discount; decimal itemDiscountPrice = Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value); if (orderDetails.CanDiscount && itemDiscount != null && Math.Abs(itemDiscountPrice) > 0) { orderDetailsList.Add(orderDetails); //OrderDiscount OrderDiscount orderDiscount = new OrderDiscount(); orderDiscount.OrderDiscountID = Guid.NewGuid(); orderDiscount.OrderID = m_SalesOrder.order.OrderID; orderDiscount.OrderDetailsID = orderDetails.OrderDetailsID; orderDiscount.DiscountID = itemDiscount.DiscountID; orderDiscount.DiscountName = itemDiscount.DiscountName; orderDiscount.DiscountType = itemDiscount.DiscountType; orderDiscount.DiscountRate = itemDiscount.DiscountRate; orderDiscount.OffFixPay = itemDiscount.OffFixPay; orderDiscount.OffPay = Math.Abs(Convert.ToDecimal(dr.Cells["GoodsDiscount"].Value)); orderDiscount.EmployeeID = ConstantValuePool.CurrentEmployee.EmployeeID; newOrderDiscountList.Add(orderDiscount); } } } PayingOrder payingOrder = new PayingOrder(); payingOrder.order = order; payingOrder.orderDetailsList = orderDetailsList; payingOrder.orderDiscountList = newOrderDiscountList; payingOrder.orderPayoffList = orderPayoffList; return PayingOrderService.GetInstance().PayForOrder(payingOrder); }
public bool UpdateOrderDiscount(OrderDiscount orderDiscount) { int result = 0; result = ExecuteUpdate("UpdateOrderDiscount", orderDiscount); return result > 0; }
public void CreateOrderDiscount(OrderDiscount orderDiscount) { ExecuteInsert("InsertOrderDiscount", orderDiscount); }