예제 #1
0
 private void button_TraSach_Click(object sender, EventArgs e)
 {
     if (maMuonTra == null || maMuonTra == "")
     {
         MessageBox.Show("Vui lòng chọn phiếu mượn");
     }
     else
     {
         MUONTRA mt          = Ham.tv.MUONTRAs.Where(x => x.MaMuonTra == maMuonTra).SingleOrDefault();
         string  memberName  = Ham.tv.DOCGIAs.Where(x => x.MaDocGia == mt.MaDocGia).SingleOrDefault().HoVaTen;
         string  bookName    = Ham.tv.SACHes.Where(x => x.MaSach == mt.MaSach).SingleOrDefault().TieuDe;
         var     coc         = Ham.tv.SACHes.Where(x => x.MaSach == mt.MaSach).SingleOrDefault().Gia * 0.8;
         var     costRent    = Ham.getCostRent(maMuonTra);
         var     costFine    = Ham.getFine(maMuonTra);
         var     action      = (double)(coc - costRent - costFine) > 0 ? "Hoàn trả độc giả: " : "Thu thêm độc giả: ";
         string  backConfirm = "Độc giả: " + memberName + "\n"
                               + "Sách: " + bookName + "\n"
                               + "Trả đặt cọc: " + coc.ToString() + "\n"
                               + "Phí mượn: " + costRent.ToString() + "\n"
                               + "Phí trễ: " + costFine.ToString() + "\n"
                               + action + (Math.Abs((double)(-coc + costRent + costFine))).ToString() + "\n"
                               + "Xác nhận trả?";
         if (MessageBox.Show(backConfirm, "Thêm trả", MessageBoxButtons.OKCancel) == System.Windows.Forms.DialogResult.OK)
         {
             mt.NgayTra      = DateTime.Now;
             mt.NguoiNhanTra = Ham.currentUser;
             mt.Phi          = costRent;
             mt.Phat         = (int)costFine;
             Ham.tv.SaveChanges();
             MessageBox.Show("Trả sách thành công");
             dataGridView_MuonTra.DataSource = Ham.getData("MT", textBox_TimKiemMuonTra.Text);
         }
     }
 }
예제 #2
0
        private void button_Luu_Click(object sender, EventArgs e)
        {
            if (textBox_HoVaTen.Text == "" ||
                textBox_SoCMT.Text == "" ||
                textBox_DiaChi.Text == "" ||
                textBox_SoDienThoai.Text == "" ||
                textBox_Email.Text == "")
            {
                MessageBox.Show("Vui lòng nhập thông tin cần thiết.");
            }
            else
            {
                NHANVIEN nv = new NHANVIEN();
                nv.MaNhanVien  = Ham.generateID("NV");
                nv.HoVaTen     = textBox_HoVaTen.Text;
                nv.SoCMT       = textBox_SoCMT.Text;
                nv.NgaySinh    = dateTimePicker_NgaySinh.Value;
                nv.DiaChi      = textBox_DiaChi.Text;
                nv.SoDienThoai = textBox_SoDienThoai.Text;
                nv.Email       = textBox_Email.Text;
                nv.MatKhau     = textBox_MatKhau.Text == "" ? Ham.getMD5(Ham.defaultPassword) : Ham.getMD5(textBox_MatKhau.Text);
                nv.NguoiLap    = Ham.currentUser;
                nv.Anh         = textBox_Anh.Text;
                nv.NgayLap     = DateTime.Now;
                Ham.tv.NHANVIENs.Add(nv);
                Ham.tv.SaveChanges();

                maNhanVien = null;
                clearNVInput();
                dataGridView_NhanVien.DataSource = Ham.getData("NV", textBox_TimKiem.Text);
                MessageBox.Show("Thêm đối tượng thành công.");
            }
        }
예제 #3
0
        private void button_Luu_Click(object sender, EventArgs e)
        {
            if (textBox_TieuDe.Text == "" ||
                textBox_Gia.Text == "")
            {
                MessageBox.Show("Vui lòng nhập thông tin cần thiết.");
            }
            else
            {
                SACH s = new SACH();
                s.MaSach     = Ham.generateID("S");
                s.TieuDe     = textBox_TieuDe.Text;
                s.NhaXuatBan = textBox_NhaXuatBan.Text;
                s.NgonNgu    = textBox_NgonNgu.Text;
                s.Mota       = textBox_MoTa.Text;
                s.Gia        = Int32.TryParse(textBox_Gia.Text, out int y) ? Int32.Parse(textBox_Gia.Text) : 0;
                s.NguoiLap   = Ham.currentUser;
                s.Anh        = textBox_Anh.Text;
                s.NgayLap    = DateTime.Now;
                Ham.tv.SACHes.Add(s);
                Ham.tv.SaveChanges();

                maSach = null;
                clearSInput();
                dataGridView_Sach.DataSource = Ham.getData("S", textBox_TimKiem.Text);
                MessageBox.Show("Thêm đối tượng thành công.");
            }
        }
예제 #4
0
 private void button_Them_Click(object sender, EventArgs e)
 {
     if (textBox_MaDocGia.Text == "" || textBox_MaSach.Text == "")
     {
         MessageBox.Show("Vui lòng chọn độc giả và sách.");
     }
     else
     {
         string memberName  = Ham.tv.DOCGIAs.Where(x => x.MaDocGia == textBox_MaDocGia.Text).SingleOrDefault().HoVaTen;
         string bookName    = Ham.tv.SACHes.Where(x => x.MaSach == textBox_MaSach.Text).SingleOrDefault().TieuDe;
         double costRent    = Ham.percentPricePerRent * Ham.tv.SACHes.Where(x => x.MaSach == textBox_MaSach.Text).SingleOrDefault().Gia;
         string rentConfirm = "Độc giả: " + memberName + "\n"
                              + "Sách: " + bookName + "\n"
                              + "Giá đặt cọc: " + costRent.ToString() + "\n"
                              + "Xác nhận mượn?";
         if (MessageBox.Show(rentConfirm, "Thêm mượn", MessageBoxButtons.OKCancel) == System.Windows.Forms.DialogResult.OK)
         {
             MUONTRA mt = new MUONTRA();
             mt.MaMuonTra    = Ham.generateID("MT");
             mt.MaDocGia     = textBox_MaDocGia.Text;
             mt.MaSach       = textBox_MaSach.Text;
             mt.NguoiChoMuon = Ham.currentUser;
             mt.NgayMuon     = DateTime.Now;
             mt.NgayHenTra   = dateTimePicker_NgayHenTra.Value;
             Ham.tv.MUONTRAs.Add(mt);
             Ham.tv.SaveChanges();
             MessageBox.Show("Thêm lượt mượn thành công");
         }
     }
 }
예제 #5
0
        private void button_CapNhat_Click(object sender, EventArgs e)
        {
            if (maDocGia == null || maDocGia == "")
            {
                MessageBox.Show("Vui lòng chọn đối tượng cần chỉnh sửa.");
            }
            else
            {
                if (textBox_HoVaTen.Text == "" ||
                    textBox_SoCMT.Text == "" ||
                    textBox_DiaChi.Text == "" ||
                    textBox_SoDienThoai.Text == "" ||
                    textBox_Email.Text == "")
                {
                    MessageBox.Show("Vui lòng điền những thông tin cần thiết.");
                }
                else
                {
                    DOCGIA dg = Ham.tv.DOCGIAs.Where(x => x.MaDocGia == maDocGia).SingleOrDefault();
                    dg.HoVaTen     = textBox_HoVaTen.Text;
                    dg.SoCMT       = textBox_SoCMT.Text;
                    dg.NgaySinh    = dateTimePicker_NgaySinh.Value;
                    dg.DiaChi      = textBox_DiaChi.Text;
                    dg.SoDienThoai = textBox_SoDienThoai.Text;
                    dg.Email       = textBox_Email.Text;
                    Ham.tv.SaveChanges();

                    maDocGia = null;
                    clearDGInput();
                    dataGridView_Docgia.DataSource = Ham.getData("DG", textBox_TimKiem.Text);
                    MessageBox.Show("Chỉnh sửa đối tượng thành công.");
                }
            }
        }
예제 #6
0
        private void button_DangNhap_Click(object sender, EventArgs e)
        {
            NHANVIEN nv = Ham.tv.NHANVIENs
                          .Where(x => x.MaNhanVien == textBox_MaNhanVien.Text)
                          .SingleOrDefault();

            if (nv == null)
            {
                MessageBox.Show("Đăng nhập thất bại. Thông tin đăng nhập không đúng.");
            }
            else
            {
                if (Ham.getMD5(textBox_MatKhau.Text) != nv.MatKhau)
                {
                    MessageBox.Show("Đăng nhập thất bại. Thông tin đăng nhập không đúng.");
                }
                else
                {
                    Ham.currentUser = nv.MaNhanVien;
                    MessageBox.Show("Đăng nhập thành công.");
                    this.Hide();
                    Menu m = new Menu();
                    m.ShowDialog();
                }
            }
        }
예제 #7
0
        private void button_CapNhat_Click(object sender, EventArgs e)
        {
            if (maNhanVien == null || maNhanVien == "")
            {
                MessageBox.Show("Vui lòng chọn đối tượng cần chỉnh sửa.");
            }
            else
            {
                if (textBox_HoVaTen.Text == "" ||
                    textBox_SoCMT.Text == "" ||
                    textBox_DiaChi.Text == "" ||
                    textBox_SoDienThoai.Text == "" ||
                    textBox_Email.Text == "")
                {
                    MessageBox.Show("Vui lòng điền những thông tin cần thiết.");
                }
                else
                {
                    NHANVIEN nv = Ham.tv.NHANVIENs.Where(x => x.MaNhanVien == maNhanVien).SingleOrDefault();
                    nv.HoVaTen     = textBox_HoVaTen.Text;
                    nv.SoCMT       = textBox_SoCMT.Text;
                    nv.NgaySinh    = dateTimePicker_NgaySinh.Value;
                    nv.DiaChi      = textBox_DiaChi.Text;
                    nv.SoDienThoai = textBox_SoDienThoai.Text;
                    nv.Email       = textBox_Email.Text;
                    nv.MatKhau     = textBox_MatKhau.Text == "" ? nv.MatKhau : Ham.getMD5(textBox_MatKhau.Text);
                    Ham.tv.SaveChanges();

                    maNhanVien = null;
                    clearNVInput();
                    dataGridView_NhanVien.DataSource = Ham.getData("NV", textBox_TimKiem.Text);
                    MessageBox.Show("Chỉnh sửa đối tượng thành công.");
                }
            }
        }
예제 #8
0
        private void button_CapNhat_Click(object sender, EventArgs e)
        {
            if (maSach == null || maSach == "")
            {
                MessageBox.Show("Vui lòng chọn đối tượng cần chỉnh sửa.");
            }
            else
            {
                if (textBox_TieuDe.Text == "" ||
                    textBox_Gia.Text == "")
                {
                    MessageBox.Show("Vui lòng điền những thông tin cần thiết.");
                }
                else
                {
                    SACH s = Ham.tv.SACHes.Where(x => x.MaSach == maSach).SingleOrDefault();
                    s.TieuDe     = textBox_TieuDe.Text;
                    s.NhaXuatBan = textBox_NhaXuatBan.Text;
                    s.NgonNgu    = textBox_NgonNgu.Text;
                    s.Mota       = textBox_MoTa.Text;
                    s.Gia        = Int32.TryParse(textBox_Gia.Text, out int y) ? Int32.Parse(textBox_Gia.Text) : 0;
                    Ham.tv.SaveChanges();

                    maSach = null;
                    clearSInput();
                    dataGridView_Sach.DataSource = Ham.getData("S", textBox_TimKiem.Text);
                    MessageBox.Show("Chỉnh sửa đối tượng thành công.");
                }
            }
        }
예제 #9
0
 private void button_DoiMatKhau_Click(object sender, EventArgs e)
 {
     if (textBox_MaNhanVien.Text == "" ||
         textBox_SoCMT.Text == "" ||
         textBox_Email.Text == "" ||
         textBox_MatKhauMoi.Text == "" ||
         textBox_NhapLaiMatKhau.Text == "")
     {
         MessageBox.Show("Vui lòng điền các thông tin cần thiết.");
     }
     else
     {
         NHANVIEN nv = Ham.tv.NHANVIENs
                       .Where(x => x.MaNhanVien == textBox_MaNhanVien.Text && x.SoCMT == textBox_SoCMT.Text && x.Email == textBox_Email.Text).SingleOrDefault();
         if (nv == null)
         {
             MessageBox.Show("Thông tin sai. Vui lòng kiểm tra lại.");
         }
         else
         {
             if (textBox_MatKhauMoi.Text != textBox_NhapLaiMatKhau.Text)
             {
                 MessageBox.Show("Thất bại. Kiểm tra dữ liệu mật khẩu mới.");
             }
             else
             {
                 nv.MatKhau = Ham.getMD5(textBox_MatKhauMoi.Text);
                 Ham.tv.SaveChanges();
                 MessageBox.Show("Đổi mật khẩu thành công");
             }
         }
     }
 }
예제 #10
0
        private void button_Xoa_Click(object sender, EventArgs e)
        {
            Ham.deleteData("S", maSach);

            maSach = null;
            clearSInput();
            dataGridView_Sach.DataSource = Ham.getData("S", textBox_TimKiem.Text);
        }
예제 #11
0
        private void button_Xoa_Click(object sender, EventArgs e)
        {
            Ham.deleteData("DG", maDocGia);

            maDocGia = null;
            clearDGInput();
            dataGridView_Docgia.DataSource = Ham.getData("DG", textBox_TimKiem.Text);
        }
예제 #12
0
        private void button_Xoa_Click(object sender, EventArgs e)
        {
            Ham.deleteData("NV", maNhanVien);

            maNhanVien = null;
            clearNVInput();
            dataGridView_NhanVien.DataSource = Ham.getData("NV", textBox_TimKiem.Text);
        }
예제 #13
0
 private void Muon_Load(object sender, EventArgs e)
 {
     dataGridView_Sach.DataSource = Ham.tv.GETAVAILABLEBOOKS()
                                    .Select(x => new { x.MaSach, x.TieuDe })
                                    .ToList();
     dataGridView_DocGia.DataSource = Ham.tv.GETAVALIDMEMBER(Ham.maxBookHold)
                                      .Select(x => new { x.MaDocGia, x.HoVaTen })
                                      .ToList();
     dataGridView_MuonTra.DataSource = Ham.getData("MT", textBox_TimKiemMuonTra.Text);
     dateTimePicker_NgayHenTra.Value = DateTime.Now.AddDays(1);
 }
예제 #14
0
 private void button_LeftSubMenu3_Click(object sender, EventArgs e)
 {
     if (button_LeftSubMenu3.Text == "Thống kê độc giả")
     {
         Ham.openFormInPanel(new DocGiaBCTK(), panel_Content);
     }
     if (button_LeftSubMenu3.Text == "Thống kê sách")
     {
         Ham.openFormInPanel(new SachBCTK(), panel_Content);
     }
     if (button_LeftSubMenu3.Text == "Đăng ký trả")
     {
         Ham.openFormInPanel(new MuonTra(), panel_Content);
     }
     hideSubMenu();
 }
예제 #15
0
        private void Menu_Load(object sender, EventArgs e)
        {
            hideSubMenu();
            NHANVIEN nv = Ham.tv.NHANVIENs.Where(x => x.MaNhanVien == Ham.currentUser).SingleOrDefault();

            if (nv == null)
            {
                label_MaNhanVien.Text = "Khách";
                label_HoVaTen.Text    = "Khách";
            }
            else
            {
                label_MaNhanVien.Text        = nv.MaNhanVien;
                label_HoVaTen.Text           = nv.HoVaTen;
                pictureBox_Anh.ImageLocation = nv.Anh == null? Ham.defaultNVImage : nv.Anh;
            }
            Ham.openFormInPanel(new TrangChu(), panel_Content);


            if (DateTime.Now.Day == Ham.lastDaySendReminder.Day && DateTime.Now.Month == Ham.lastDaySendReminder.Month)
            {
            }
            else
            {
                IEnumerable <MUONTRA> allMuon = Ham.tv.MUONTRAs.ToList();
                foreach (var item in allMuon)
                {
                    if ((int)(DateTime.Now - (DateTime)item.NgayHenTra).TotalDays == 7 || (int)(DateTime.Now - (DateTime)item.NgayHenTra).TotalDays == 3 || (int)(DateTime.Now - (DateTime)item.NgayHenTra).TotalDays == 1)
                    {
                        Ham.sendEmailRemindMuon(item.MaMuonTra);
                    }
                }
                var allLastestTDG = Ham.tv.THEDOCGIAs
                                    .GroupBy(x => x.MaDocGia)
                                    .Select(g => new { MaDocGia = g.Key, HanMoi = g.Max(x => x.HanMoi) })
                                    .ToList();
                foreach (var item in allLastestTDG)
                {
                    if ((int)(DateTime.Now - (DateTime)item.HanMoi).TotalDays == 7 || (int)(DateTime.Now - (DateTime)item.HanMoi).TotalDays == 3 || (int)(DateTime.Now - (DateTime)item.HanMoi).TotalDays == 1)
                    {
                        Ham.sendEmailRemindTheDocGia(item.MaDocGia);
                    }
                }
                Ham.lastDaySendReminder = DateTime.Now;
            }
        }
예제 #16
0
 private void button_LeftSubMenu1_Click(object sender, EventArgs e)
 {
     if (button_LeftSubMenu1.Text == "Tra cứu nhân viên")
     {
         Ham.openFormInPanel(new NhanVien(), panel_Content);
     }
     if (button_LeftSubMenu1.Text == "Tra cứu độc giả")
     {
         Ham.openFormInPanel(new DocGia(), panel_Content);
     }
     if (button_LeftSubMenu1.Text == "Tra cứu sách")
     {
         Ham.openFormInPanel(new Sach(), panel_Content);
     }
     if (button_LeftSubMenu1.Text == "Tra cứu mượn/trả")
     {
         Ham.openFormInPanel(new MuonTra(), panel_Content);
     }
     hideSubMenu();
 }
예제 #17
0
 private void button_LeftSubMenu2_Click(object sender, EventArgs e)
 {
     if (button_LeftSubMenu2.Text == "Quản lý nhân viên")
     {
         Ham.openFormInPanel(new NhanVien(), panel_Content);
     }
     if (button_LeftSubMenu2.Text == "Quản lý độc giả")
     {
         Ham.openFormInPanel(new DocGia(), panel_Content);
     }
     if (button_LeftSubMenu2.Text == "Quản lý sách")
     {
         Ham.openFormInPanel(new Sach(), panel_Content);
     }
     if (button_LeftSubMenu2.Text == "Đăng ký mượn")
     {
         Ham.openFormInPanel(new MuonTra(), panel_Content);
     }
     hideSubMenu();
 }
예제 #18
0
        private void button_Luu_Click(object sender, EventArgs e)
        {
            if (textBox_HoVaTen.Text == "" ||
                textBox_SoCMT.Text == "" ||
                textBox_DiaChi.Text == "" ||
                textBox_SoDienThoai.Text == "" ||
                textBox_Email.Text == "")
            {
                MessageBox.Show("Vui lòng nhập thông tin cần thiết.");
            }
            else
            {
                DOCGIA dg = new DOCGIA();
                dg.MaDocGia    = Ham.generateID("DG");
                dg.HoVaTen     = textBox_HoVaTen.Text;
                dg.SoCMT       = textBox_SoCMT.Text;
                dg.NgaySinh    = dateTimePicker_NgaySinh.Value;
                dg.DiaChi      = textBox_DiaChi.Text;
                dg.SoDienThoai = textBox_SoDienThoai.Text;
                dg.Email       = textBox_Email.Text;
                dg.NguoiLap    = Ham.currentUser;
                dg.Anh         = textBox_Anh.Text;
                dg.NgayLap     = DateTime.Now;
                Ham.tv.DOCGIAs.Add(dg);

                THEDOCGIA tdg = new THEDOCGIA();
                tdg.MaDocGia   = dg.MaDocGia;
                tdg.NgayGiaHan = DateTime.Now;
                tdg.HanCu      = null;
                tdg.HanMoi     = DateTime.Now.AddYears(1);
                tdg.NguoiLap   = Ham.currentUser;
                Ham.tv.THEDOCGIAs.Add(tdg);

                Ham.tv.SaveChanges();

                maDocGia = null;
                clearDGInput();
                dataGridView_Docgia.DataSource = Ham.getData("DG", textBox_TimKiem.Text);
                MessageBox.Show("Thêm đối tượng thành công.");
            }
        }
예제 #19
0
 private void textBox_TimKiem_TextChanged(object sender, EventArgs e)
 {
     dataGridView_NhanVien.DataSource = Ham.getData("NV", textBox_TimKiem.Text);
 }
예제 #20
0
 private void button_TrangChu_Click(object sender, EventArgs e)
 {
     Ham.openFormInPanel(new TrangChu(), panel_Content);
 }
예제 #21
0
 private void DangNhap_Load(object sender, EventArgs e)
 {
     Ham.sendEmailRemindTheDocGia("DG1");
 }
예제 #22
0
 private void textBox_TimKiemMuonTra_TextChanged(object sender, EventArgs e)
 {
     dataGridView_MuonTra.DataSource = Ham.getData("MT", textBox_TimKiemMuonTra.Text);
 }
예제 #23
0
 private void DocGia_Load(object sender, EventArgs e)
 {
     dataGridView_Docgia.DataSource = Ham.getData("DG", textBox_TimKiem.Text);
 }
예제 #24
0
 private void Sach_Load(object sender, EventArgs e)
 {
     dataGridView_Sach.DataSource = Ham.getData("S", textBox_TimKiem.Text);
 }
예제 #25
0
 private void button_Xoa_Click(object sender, EventArgs e)
 {
     Ham.deleteData("MT", maMuonTra);
     dataGridView_MuonTra.DataSource = Ham.getData("MT", textBox_TimKiemMuonTra.Text);
     maMuonTra = null;
 }