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; } } }
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; } } }