public void LuuThanhToan() { using (var scope = new TransactionScope()) { try { double?SoTienThu = double.Parse(speSoTienTT.Number.ToString()); if (SoTienThu == 0) { throw new Exception("Chưa nhập số tiền thanh toán"); } double?SoNoHienTai = double.Parse(txtCongNoHienTai.Text); if (SoTienThu > SoNoHienTai) { throw new Exception("Số tiền thu không được vượt qua số nợ hiện tại"); } int IDKhachHang = Convert.ToInt32(ccbKhachHang.Value.ToString()); string SoHoaDon = txtHoaDon.Text; string NoiDung = memoNoiDungTT.Text; DateTime NgayThu = Formats.ConvertToDateTime(dateNgayTT.Text); int HinhThucThu = rdlHinhThuc.SelectedIndex == 0 ? 1 : 2; double CongNoCu = double.Parse(txtCongNoHienTai.Text); ghPhieuDaiLyThanhToan thanhtoan = new ghPhieuDaiLyThanhToan(); thanhtoan.STTPhieuThu = DBDataProvider.STTPhieuThanhToan_DaiLy(IDKhachHang); thanhtoan.SoHoaDon = SoHoaDon; thanhtoan.KhachHangID = IDKhachHang; thanhtoan.SoTienThu = SoTienThu; thanhtoan.NoiDung = NoiDung; thanhtoan.NgayThu = NgayThu; thanhtoan.NgayLap = DateTime.Now; thanhtoan.NhanVienThuID = Formats.IDUser(); thanhtoan.HinhThucTTID = HinhThucThu; thanhtoan.CongNoCu = CongNoCu; DBDataProvider.DB.ghPhieuDaiLyThanhToans.InsertOnSubmit(thanhtoan); DBDataProvider.DB.SubmitChanges(); int IDPhieuThu = thanhtoan.IDPhieuThu; khKhachHang KH = DBDataProvider.DB.khKhachHangs.Where(x => x.IDKhachHang == IDKhachHang).FirstOrDefault(); KH.LanCuoiMuaHang = DateTime.Now; if (rdlHinhThuc.SelectedIndex == 0) { //Cap nhat thanh toan phieu giao hang List <ghPhieuGiaoHang> ListPhieuGiaoHang = DBDataProvider.ListPhieuGiaoHang_ASC(IDKhachHang);// phiếu đã được duyệt & chưa thanh toán int i = 0; if (SoTienThu > 0 && ListPhieuGiaoHang.Count > 0) { while (SoTienThu > 0 && i < ListPhieuGiaoHang.Count) { double?TienNoDonHang = ListPhieuGiaoHang[i].ConLai; if (SoTienThu >= TienNoDonHang) //Thanh toán hết đơn hàng { ListPhieuGiaoHang[i].ThanhToan = ListPhieuGiaoHang[i].TongTien; //cập nhật lại thanh toán = tổng tiền ListPhieuGiaoHang[i].ConLai = 0; // cập nhật còn lại = 0; ListPhieuGiaoHang[i].TTThanhToan = 1; // đã thanh toán if (KH != null) { #region ghi nhật ký nhập kho để xem báo cáo khNhatKyCongNo nhatky = new khNhatKyCongNo(); nhatky.NgayNhap = DateTime.Now; nhatky.DienGiai = "Thanh toán"; nhatky.NoDau = KH.CongNo; nhatky.NhapHang = 0; nhatky.GiamGia = 0; nhatky.TraHang = 0; nhatky.MaPhieu = DBDataProvider.STTPhieuThanhToan_DaiLy(IDKhachHang); nhatky.ThanhToan = TienNoDonHang; nhatky.NoCuoi = KH.CongNo - TienNoDonHang; nhatky.NhanVienID = Formats.IDUser(); nhatky.SoPhieu = ListPhieuGiaoHang[i].MaPhieu; nhatky.IDKhachHang = IDKhachHang; DBDataProvider.DB.khNhatKyCongNos.InsertOnSubmit(nhatky); DBDataProvider.DB.SubmitChanges(); #endregion KH.CongNo -= TienNoDonHang; // - công nợ KH.ThanhToan += TienNoDonHang; } SoTienThu -= TienNoDonHang; } else // Thanh toán 1 phần đơn hàng { ListPhieuGiaoHang[i].ThanhToan += SoTienThu; // cộng phần còn lại vào thanh toán. ListPhieuGiaoHang[i].ConLai = ListPhieuGiaoHang[i].TongTien - ListPhieuGiaoHang[i].ThanhToan; // cập nhật phần còn lại //ListPhieuGiaoHang[i].TTThanhToan = 1;// đã thanh toán if (KH != null) { #region ghi nhật ký nhập kho để xem báo cáo khNhatKyCongNo nhatky = new khNhatKyCongNo(); nhatky.NgayNhap = DateTime.Now; nhatky.DienGiai = "Thanh toán"; nhatky.NoDau = KH.CongNo; nhatky.NhapHang = 0; nhatky.TraHang = 0; nhatky.ThanhToan = SoTienThu; nhatky.GiamGia = 0; nhatky.NoCuoi = KH.CongNo - SoTienThu; nhatky.NhanVienID = Formats.IDUser(); nhatky.MaPhieu = DBDataProvider.STTPhieuThanhToan_DaiLy(IDKhachHang); nhatky.SoPhieu = ListPhieuGiaoHang[i].MaPhieu; nhatky.IDKhachHang = IDKhachHang; DBDataProvider.DB.khNhatKyCongNos.InsertOnSubmit(nhatky); DBDataProvider.DB.SubmitChanges(); #endregion KH.CongNo -= SoTienThu; // - công nợ KH.ThanhToan += SoTienThu; } SoTienThu -= SoTienThu; } i++; } } else { // trừ công nợ thẳng. if (KH != null) { #region ghi nhật ký nhập kho để xem báo cáo khNhatKyCongNo nhatky = new khNhatKyCongNo(); nhatky.NgayNhap = DateTime.Now; nhatky.DienGiai = "Thanh toán"; nhatky.NoDau = KH.CongNo; nhatky.NhapHang = 0; nhatky.TraHang = 0; nhatky.GiamGia = 0; nhatky.ThanhToan = SoTienThu; nhatky.NoCuoi = KH.CongNo - SoTienThu; nhatky.NhanVienID = Formats.IDUser(); nhatky.SoPhieu = ""; nhatky.MaPhieu = DBDataProvider.STTPhieuThanhToan_DaiLy(IDKhachHang); nhatky.IDKhachHang = IDKhachHang; DBDataProvider.DB.khNhatKyCongNos.InsertOnSubmit(nhatky); DBDataProvider.DB.SubmitChanges(); #endregion KH.CongNo -= SoTienThu; // - công nợ KH.ThanhToan += SoTienThu; } } } else { // trừ theo phiếu int IDPhieuGiaoHang = int.Parse(ccbPhieuThanhToan.Value.ToString()); ghPhieuGiaoHang PhieuGH = DBDataProvider.DB.ghPhieuGiaoHangs.Single(x => x.IDPhieuGiaoHang == IDPhieuGiaoHang); if (KH != null) { #region ghi nhật ký nhập kho để xem báo cáo khNhatKyCongNo nhatky = new khNhatKyCongNo(); nhatky.NgayNhap = DateTime.Now; nhatky.DienGiai = "Thanh toán"; nhatky.NoDau = KH.CongNo; nhatky.NhapHang = 0; nhatky.TraHang = 0; nhatky.GiamGia = 0; nhatky.MaPhieu = DBDataProvider.STTPhieuThanhToan_DaiLy(IDKhachHang); nhatky.ThanhToan = PhieuGH.ConLai; nhatky.NoCuoi = KH.CongNo - PhieuGH.ConLai; nhatky.NhanVienID = Formats.IDUser(); nhatky.SoPhieu = PhieuGH.MaPhieu; nhatky.IDKhachHang = IDKhachHang; DBDataProvider.DB.khNhatKyCongNos.InsertOnSubmit(nhatky); DBDataProvider.DB.SubmitChanges(); #endregion KH.CongNo -= PhieuGH.ConLai;// - công nợ KH.ThanhToan += PhieuGH.TongTien; } PhieuGH.ThanhToan = PhieuGH.TongTien; PhieuGH.ConLai = 0; PhieuGH.TTThanhToan = 1; } DBDataProvider.DB.SubmitChanges(); scope.Complete(); // Reset(); cbpThanhToan.JSProperties["cp_Reset"] = true; } catch (Exception ex) { throw ex; } } }