/// <summary>
 /// SaveSalerInfo:
 /// 【1】AddSalesList销售主表:以发票的形式记录消费的客户的小票数据,放在SalesList表里面记录客户的买的东西
 /// 【2】AddSalesListDetail商品销售统计表:就是顾客买的东西记录一下,放在AddSalesListDetail表里面记录收银员的给客户卖东西是的账本
 /// 【3】RefreshMemberPoint修改会员积分:如果有会员则修改会员积分
 /// </summary>
 /// <param name="sales"></param>
 /// <param name="members"></param>
 /// <returns></returns>
 public bool SaveSalerInfo(SalesListModel1 sales, SMMembersModel10 members)
 {
     return(server.SaveSalerInfo(sales, members));
 }
Esempio n. 2
0
        //【1.1】到【1.5】先搭建构架;还没有实现存储过程
        //【1.1】到【1.4】取消结算
        //【1.5】到【1.20】正式开始结算([包含了客户卖东西的数据库中的表]和[收银员记录客户消费具体的信息表在数据库中显示]和[VIP会员的积分记录])
        private void Balance()
        {
            //【1.1】
            //显示结算窗口,考虑支付被取消或修改,并传递txtPay应付多少钱文本框
            FrmBalance frm = new FrmBalance(txtPay.Text);

            //【1.2】
            //如果打开FrmBalance不成功进入
            if (frm.ShowDialog() != DialogResult.OK)
            {
                //客户放弃购买(忘记带钱等);在购买界面时键盘上按了Escape按钮,给Tag传了一个Tag数据,则frm.Tag.ToString() == "Esc"现在相等,进入if语句
                //【1.3】
                if (frm.Tag.ToString() == "Esc")
                {
                    //【1.4】
                    //支付完成重置界面:就是把原有的界面里面的商品清空,从新开始
                    RestForm();//【二】弄完后进入【三.1】FrmBalance窗口里
                }
            }
            //【1.5】
            else//正式进入结算环节
            {
                //【1.6】
                //实例化会员类
                SMMembersModel10 members = null;
                //Contains("&")表示&这个字符是否出现在此字符串中
                //【1.7】
                //获取含有&tag值
                if (frm.Tag.ToString().Contains("&"))//输入了会员卡号
                {
                    //【1.8】
                    //把含有&的Tag值,分割两部分,用string数组记录
                    //这两部分分别是【客户实际付的钱数】和【VIP的编号】
                    string[] info = frm.Tag.ToString().Split('&');
                    //【1.9】【客户实际付的钱数】
                    txtAmount.Text = info[0];
                    //【1.10】
                    members = new SMMembersModel10()
                    {
                        //【1.11】【VIP的编号】
                        MemberId = info[1],
                        //【1.12】给具体购买的商品的总金额/10
                        Points = (int)(Convert.ToDouble(txtPay.Text) / 10.0)
                    };
                }
                else
                {
                    //【1.13】没有会员,直接获取【客户实际付的钱数】
                    txtAmount.Text = frm.Tag.ToString();
                }
                //【1.14】
                //找零
                //【客户实际付的钱数】-【具体购买的商品的总金额】
                txtChange.Text = (Convert.ToDecimal(txtAmount.Text) - Convert.ToDecimal(txtPay.Text)).ToString();
                /*txtChange.Text = (Convert.ToDecimal(txtPay.Text) - Convert.ToDecimal(txtAmount.Text)).ToString();*/
                //【1.15】上面弄完后,saleObj的每个数据就会附上具体的数据
                //创建消费对象
                SalesListModel1 saleObj = new SalesListModel1()
                {
                    SerialNum     = txtSerialNum.Text,
                    TotalMoney    = Convert.ToDecimal(txtPay.Text.Trim()),
                    RealReceive   = Convert.ToDecimal(txtAmount.Text.Trim()),
                    ReturnMoney   = Convert.ToDecimal(txtChange.Text.Trim()),
                    SalesPersonId = Program.Seles.SalesPersonId
                };
                //【1.16】
                //封装消费明细列表
                //productList放商品的具体数据盒子
                foreach (ProdutsModel item in productList)
                {
                    //【1.17】
                    //给saleObj里面的ListDetail属性里面添加方法
                    //ListDetail就是SalesListDetailModel的接收容器
                    //给 saleObj.ListDetail.Add里面添加new SalesListDetailModel(){}的原因是saleObj.ListDetail这个方法接收的是SalesListDetailModel类型的泛型所以用new SalesListDetailModel(){}添加
                    saleObj.ListDetail.Add(
                        //【1.18】
                        new SalesListDetailModel()
                    {
                        //把商品列表中的所有信息给了SalesListDetailModel类里面
                        SerialNum     = txtSerialNum.Text,
                        ProductId     = item.ProductId,
                        ProductName   = item.ProductName,
                        Quantity      = item.Quantity,
                        UnitPrice     = item.UnitPrice,
                        Discount      = item.Discount,
                        SubTotalMoney = item.SubTotal
                    }
                        );
                }
                try
                {
                    //【1.19】
                    /// <summary>
                    /// SaveSalerInfo:
                    /// 【1】AddSalesList销售主表:以发票的形式记录消费的客户的小票数据,放在SalesList表里面记录客户的买的东西
                    /// 【2】AddSalesListDetail商品销售统计表:就是顾客买的东西记录一下,放在AddSalesListDetail表里面记录收银员的给客户卖东西是的账本
                    /// 【3】RefreshMemberPoint修改会员积分:如果有会员则修改会员积分
                    /// </summary>
                    //把结算的内容相互通过数据库事务相互牵连
                    //saleObj(包含了在主窗口中文本框中的所有数据,还获取了ListDetail里面添加的所有数据)获取所有的商品表并数据传递到数据库里
                    //members把会员所需要的数据传递到数据库里
                    manager2.SaveSalerInfo(saleObj, members);
                }
                //【1.20】
                catch (Exception ex)
                {
                    MessageBox.Show($"保存销售数据的时候发生异常!{ex.Message}", "异常提示");
                    return;
                }
                //小票打印
                //【1】在工具箱里获取打印工具printDocument(printDocument打印工具的名字)
                //【3】Print开始文档的打印进程
                printDocument.Print();
                //【4】小票打印预览
                PrintPriview();

                //重置主界面
                RestForm();
            }
        }
        /// <summary>
        /// 【1】AddSalesList销售主表:以发票的形式记录消费的客户的小票数据,放在SalesList表里面记录客户的买的东西
        /// 【2】AddSalesListDetail商品销售统计表:就是顾客买的东西记录一下,放在AddSalesListDetail表里面记录收银员的给客户卖东西是的账本
        /// 【3】RefreshMemberPoint修改会员积分:如果有会员则修改会员积分
        /// </summary>
        /// <param name="sales">sales(包含了在主窗口中文本框中的所有数据,还获取了ListDetail里面添加的所有数据)获取所有的商品表并数据传递到数据库里</param>
        /// <param name="members"></param>
        /// <returns></returns>
        public bool SaveSalerInfo(SalesListModel1 sales, SMMembersModel10 members)
        {
            //【4月8日】
            List <string>         procList = new List <string>();
            List <SqlParameter[]> psList   = new List <SqlParameter[]>();

            //给消费主表中添加数据
            procList.Add("AddSalesList");
            //【1】
            SqlParameter[] saleSp = new SqlParameter[] {
                new SqlParameter("@SerialNum", SqlDbType.NVarChar, 50),
                new SqlParameter("@TotalMoney", SqlDbType.Decimal),
                new SqlParameter("@RealReceive", SqlDbType.Decimal),
                new SqlParameter("@ReturnMoney", SqlDbType.Decimal),
                new SqlParameter("@SalesPersonId", SqlDbType.Int)
            };
            saleSp[0].Value = sales.SerialNum;
            saleSp[1].Value = sales.TotalMoney;
            saleSp[2].Value = sales.RealReceive;
            saleSp[3].Value = sales.ReturnMoney;
            saleSp[4].Value = sales.SalesPersonId;
            // 把参数对应的值放在psList里面
            psList.Add(saleSp);
            //【2】
            //通过SalesListModel1也可以知道SalesListDetailModel里面对应的值
            //给消费明细表中添加每次购物的详细数据
            foreach (SalesListDetailModel detail in sales.ListDetail)
            {
                procList.Add("AddSalesListDetail");
                SqlParameter[] detailList = new SqlParameter[] {
                    new SqlParameter("@SerialNum", SqlDbType.NVarChar, 50),
                    new SqlParameter("@ProductId", SqlDbType.NVarChar, 50),
                    new SqlParameter("@ProductName", SqlDbType.NVarChar, 50),
                    new SqlParameter("@UnitPrice", SqlDbType.Decimal),
                    new SqlParameter("@Discount", SqlDbType.Float),
                    new SqlParameter("@Quantity", SqlDbType.Int),
                    new SqlParameter("@SubTotalMoney", SqlDbType.Decimal)
                };
                detailList[0].Value = detail.SerialNum;
                detailList[1].Value = detail.ProductId;
                detailList[2].Value = detail.ProductName;
                detailList[3].Value = detail.UnitPrice;
                detailList[4].Value = detail.Discount;
                detailList[5].Value = detail.Quantity;
                detailList[6].Value = detail.SubTotalMoney;
                psList.Add(detailList);

                //【4月9日】
                //更新库存数据:就是对商品数量的改变
                procList.Add("InventoryOut");
                SqlParameter[] inventorySp = new SqlParameter[]
                {
                    new SqlParameter("@ProductId", SqlDbType.NVarChar, 50),
                    new SqlParameter("@TotalCount", SqlDbType.Int)
                };
                inventorySp[0].Value = detail.ProductId;
                inventorySp[1].Value = detail.Quantity;
                psList.Add(inventorySp);
            }

            //【4月8日】
            //【3】
            //更新会员的积分
            if (members != null)
            {
                procList.Add("RefreshMemberPoint");
                SqlParameter[] memberSp = new SqlParameter[]
                {
                    new SqlParameter("@point", SqlDbType.Int),
                    new SqlParameter("@memberId", SqlDbType.Int)
                };
                memberSp[0].Value = members.Points;
                memberSp[1].Value = members.MemberId;
                psList.Add(memberSp);
            }
            return(SQLHelper.UpdateByTran(procList, psList));
        }