コード例 #1
0
        protected void SaveTemp()
        {
            using (var scope = new TransactionScope())
            {
                try
                {
                    double TongTien    = 0;
                    int    TongSoLuong = 0;
                    foreach (var prod in listReceiptProducts)
                    {
                        TongTien    += prod.ThanhTien;
                        TongSoLuong += prod.SoLuong;
                    }

                    string MaPhieu = null;

                    string strMaPhieu = "PT";
                    string MAX        = (DBDataProvider.DB.kNhapKhos.Where(r => r.TrangThaiPhieu == 1).Count() + 1).ToString();
                    for (int i = 1; i < (6 - MAX.Length); i++)
                    {
                        strMaPhieu += "0";
                    }


                    double ThanhToan = Convert.ToDouble(spThanhToan.Number);
                    double ConLai    = TongTien - ThanhToan;

                    MaPhieu = strMaPhieu + MAX;
                    int IDNCC = Int32.Parse(ccbNhaCungCap.Value.ToString());
                    //Insert vào bảng nhập kho
                    kNhapKho nhapKho = new kNhapKho();
                    nhapKho.NCCID       = IDNCC;
                    nhapKho.MaPhieu     = MaPhieu;
                    nhapKho.SoHoaDon    = txtSoHoaDon.Text;;
                    nhapKho.NgayNhap    = Formats.ConvertToDateTime(dateNgayNhap.Text);
                    nhapKho.NguoiNhapID = Formats.IDUser();
                    nhapKho.TongTien    = TongTien;
                    nhapKho.TongSoLuong = TongSoLuong;
                    nhapKho.GhiChu      = memoGhiChu.Text;
                    nhapKho.ThanhToan   = ThanhToan;

                    nhapKho.TrangThaiPhieu = 1;// 1 phiếu tạm, 2 phiếu xóa, 0 phiếu nhập
                    DBDataProvider.DB.kNhapKhos.InsertOnSubmit(nhapKho);
                    DBDataProvider.DB.SubmitChanges();
                    int IDNhap = nhapKho.IDNhapKho;
                    nhapKho.Url = "CapNhat.aspx?id=" + IDNhap;
                    foreach (var prod in listReceiptProducts)
                    {
                        //Insert vào chi tiết nhập kho
                        kNhapKhoChiTiet detailNhapKho = new kNhapKhoChiTiet();
                        detailNhapKho.NhapKhoID = IDNhap;
                        detailNhapKho.HangHoaID = prod.IDHangHoa;
                        detailNhapKho.GiaVon    = prod.GiaVon;
                        detailNhapKho.GiaBan    = prod.GiaBanMoi;
                        detailNhapKho.SoLuong   = prod.SoLuong;
                        detailNhapKho.ThanhTien = prod.ThanhTien;
                        detailNhapKho.TonKho    = prod.TonKho;
                        DBDataProvider.DB.kNhapKhoChiTiets.InsertOnSubmit(detailNhapKho);
                    }
                    //update công nợ
                    //khKhachHang Supplier = DBDataProvider.DB.khKhachHangs.Where(x => x.IDKhachHang == IDNCC).FirstOrDefault();
                    //if (Supplier != null)
                    //{
                    //    nhapKho.CongNoCu = Supplier.CongNo;
                    //    nhapKho.CongNoMoi = Supplier.CongNo + ConLai;
                    //}
                    DBDataProvider.DB.SubmitChanges();
                    scope.Complete();
                    Reset();
                    cbpInfoImport.JSProperties["cp_Reset"] = true;
                }
                catch (Exception ex)
                {
                    throw ex;
                }
            }
        }
コード例 #2
0
        protected void Save()
        {
            using (var scope = new TransactionScope())
            {
                try
                {
                    if (listReceiptProducts.Count > 0)
                    {
                        double TongTien    = 0;
                        int    TongSoLuong = 0;
                        foreach (var prod in listReceiptProducts)
                        {
                            TongTien    += prod.ThanhTien;
                            TongSoLuong += prod.SoLuong;
                        }

                        double ThanhToan = Convert.ToDouble(spThanhToan.Number);
                        double ConLai    = TongTien - ThanhToan;

                        string MaPhieu = null, strMaPhieu = "PN";
                        //string MAX = (DBDataProvider.DB.kNhapKhos.Where(r => r.TrangThaiPhieu == 0).Count() + 1).ToString();
                        string MAX = (DBDataProvider.DB.kNhapKhos.Count() + 1).ToString();
                        for (int i = 1; i < (7 - MAX.Length); i++)
                        {
                            strMaPhieu += "0";
                        }
                        MaPhieu = strMaPhieu + MAX;

                        int IDNCC = Int32.Parse(ccbNhaCungCap.Value.ToString());
                        //Insert vào bảng nhập kho
                        kNhapKho nhapKho = new kNhapKho();
                        nhapKho.NCCID          = IDNCC;
                        nhapKho.MaPhieu        = MaPhieu;
                        nhapKho.SoHoaDon       = txtSoHoaDon.Text;;
                        nhapKho.NgayNhap       = Formats.ConvertToDateTime(dateNgayNhap.Text);
                        nhapKho.NguoiNhapID    = Formats.IDUser();
                        nhapKho.TongTien       = TongTien;
                        nhapKho.TrangThaiPhieu = 0;// 1 phiếu tạm, 2 phiếu xóa, 0 phiếu nhập
                        nhapKho.TongSoLuong    = TongSoLuong;
                        nhapKho.GhiChu         = memoGhiChu.Text;
                        nhapKho.NgayTao        = DateTime.Now;
                        nhapKho.DaXoa          = 0;
                        nhapKho.ThanhToan      = ThanhToan;
                        nhapKho.CongNo         = ConLai;// nợ đơn hàng

                        if (ConLai == 0)
                        {
                            nhapKho.TTThanhToan = 1;
                        }
                        nhapKho.TTThanhToan = 0;
                        DBDataProvider.DB.kNhapKhos.InsertOnSubmit(nhapKho);
                        DBDataProvider.DB.SubmitChanges();
                        int IDNhap = nhapKho.IDNhapKho;
                        nhapKho.Url = "TraHang.aspx?id=" + IDNhap;
                        foreach (var prod in listReceiptProducts)
                        {
                            //Insert vào chi tiết nhập kho
                            kNhapKhoChiTiet detailNhapKho = new kNhapKhoChiTiet();
                            detailNhapKho.NhapKhoID = IDNhap;
                            detailNhapKho.HangHoaID = prod.IDHangHoa;
                            detailNhapKho.GiaVon    = prod.GiaVon;
                            detailNhapKho.SoLuong   = prod.SoLuong;
                            detailNhapKho.ThanhTien = prod.ThanhTien;
                            detailNhapKho.GiaBan    = prod.GiaBanMoi;
                            detailNhapKho.TonKho    = prod.TonKho;
                            DBDataProvider.DB.kNhapKhoChiTiets.InsertOnSubmit(detailNhapKho);
                            DBDataProvider.DB.SubmitChanges();

                            //Cập nhật || Thêm tồn kho
                            var TonKhoBanDau = DBDataProvider.DB.hhHangHoas.Where(x => x.IDHangHoa == prod.IDHangHoa).FirstOrDefault();
                            if (TonKhoBanDau != null)
                            {
                                TonKhoBanDau.TonKho += prod.SoLuong;
                                #region ghi thẻ kho
                                kTheKho thekho = new kTheKho();
                                thekho.NgayNhap    = DateTime.Now;
                                thekho.DienGiai    = "Nhập hàng #" + MaPhieu;
                                thekho.Nhap        = prod.SoLuong;
                                thekho.Xuat        = 0;
                                thekho.GiaThoiDiem = prod.GiaVon;
                                thekho.Ton         = prod.SoLuong + prod.TonKho;
                                thekho.HangHoaID   = TonKhoBanDau.IDHangHoa;
                                thekho.NhanVienID  = Formats.IDUser();
                                DBDataProvider.DB.kTheKhos.InsertOnSubmit(thekho);
                                #endregion
                            }
                            hhHangHoa hang = DBDataProvider.DB.hhHangHoas.Where(x => x.IDHangHoa == prod.IDHangHoa).FirstOrDefault();

                            // cập nhật giá nhập trung bình cho hàng hóa

                            var GiaVonTB = DBDataProvider.DB.spAVG_IDHangHoa(Convert.ToInt32(hang.IDHangHoa)).FirstOrDefault();
                            hang.GiaVon = Convert.ToDouble(GiaVonTB.GiaNhapTrungBinh);
                            // thay đổi giá bán nếu khác giá bán cũ
                            if (prod.GiaBanMoi != prod.GiaBanCu)
                            {
                                hang.GiaBan = prod.GiaBanMoi;
                            }
                        }
                        //update công nợ
                        khKhachHang Supplier = DBDataProvider.DB.khKhachHangs.Where(x => x.IDKhachHang == IDNCC).FirstOrDefault();
                        if (Supplier != null)
                        {
                            #region ghi nhật ký nhập kho để xem báo cáo
                            khNhatKyCongNo nhatky = new khNhatKyCongNo();
                            nhatky.NgayNhap    = DateTime.Now;
                            nhatky.DienGiai    = "Nhập kho";
                            nhatky.NoDau       = Supplier.CongNo;
                            nhatky.NhapHang    = TongTien;
                            nhatky.TraHang     = 0;
                            nhatky.NoCuoi      = Supplier.CongNo + ConLai;
                            nhatky.ThanhToan   = ThanhToan;
                            nhatky.NhanVienID  = Formats.IDUser();
                            nhatky.GiamGia     = 0;
                            nhatky.SoPhieu     = MaPhieu;
                            nhatky.IDKhachHang = IDNCC;
                            DBDataProvider.DB.khNhatKyCongNos.InsertOnSubmit(nhatky);
                            DBDataProvider.DB.SubmitChanges();
                            #endregion

                            nhapKho.CongNoCu        = Supplier.CongNo;
                            nhapKho.CongNoMoi       = Supplier.CongNo + ConLai;
                            Supplier.TongTienHang  += TongTien;
                            Supplier.CongNo        += ConLai;
                            Supplier.LanCuoiMuaHang = DateTime.Now;
                        }

                        DBDataProvider.DB.SubmitChanges();
                        scope.Complete();
                        cbpInfoImport.JSProperties["cp_Reset"] = true;
                    }
                    else
                    {
                        throw new Exception("Danh sách nhập kho trống !!");
                        ccbBarcode.Text  = "";
                        ccbBarcode.Value = "";
                        ccbBarcode.Focus();
                    }
                }
                catch (Exception ex)
                {
                    throw ex;
                }
            }
        }