示例#1
0
 //Выбор записи
 private void SelectAppointment(object sender, EventArgs e)
 {
     if (dgvClient.CurrentRow.Index != -1)
     {
         appointment.id              = Convert.ToInt32(dgvAppointment.CurrentRow.Cells["idDataGridViewTextBoxColumn4"].Value);
         txtClientID.Enabled         = false;
         cmbDoctorName.Enabled       = false;
         dtDateAppointment.Enabled   = false;
         cbTime.Enabled              = false;
         cbAppointmentStatus.Enabled = true;
         btnClearAppointment.Enabled = true;
         btnClearAppointment.Enabled = true;
         using (DANTDBEntities db = new DANTDBEntities())
         {
             appointment = db.Appointment.Where(x => x.id == appointment.id).FirstOrDefault();
             if (appointment == null)
             {
                 MessageBox.Show("Ошибка закрузки данных пользователя", "Ошибка");
                 return;
             }
             cbAppointmentStatus.SelectedValue = appointment.status_id;
             txtClientID.Text            = appointment.client_id.ToString();
             cmbDoctorName.SelectedValue = appointment.employee_id;
             dtDateAppointment.Value     = appointment.date;
             cbTime.SelectedValue        = appointment.time_id;
         }
         btnAppointment.Text = "Обновить запись";
     }
 }
示例#2
0
 private int getServicePrice(string operation)
 {
     if (operation == "add")
     {
         using (DANTDBEntities db = new DANTDBEntities())
         {
             Service model = (from u in db.Service
                              where u.name == cbNameService.Text
                              select u).FirstOrDefault();
             return((int)model.price);
         }
     }
     if (operation == "delete")
     {
         using (DANTDBEntities db = new DANTDBEntities())
         {
             Service model = (from u in db.Service
                              where u.name == listService.SelectedItem.ToString()
                              select u).FirstOrDefault();
             return((int)model.price);
         }
     }
     else
     {
         MessageBox.Show("Операция не определена");
         return(0);
     }
 }
示例#3
0
        private void addCheck(object sender, EventArgs e)
        {
            check.appointment_id  = Convert.ToInt32(cbAppointment.SelectedValue.ToString());
            check.check_status_id = 1;
            check.service_cost    = Convert.ToInt32(txtServiceCost.Text.Trim());

            if (String.IsNullOrEmpty(cbAppointment.SelectedItem.ToString()) || String.IsNullOrEmpty(check.service_cost.ToString()))
            {
                MessageBox.Show("Все поля должны быть заполненны"); return;
            }

            var regexNumberID = @"^[1-9]\d{0,7}$";

            if (!Regex.IsMatch(txtServiceCost.Text, regexNumberID))
            {
                MessageBox.Show("Стоимсоть должна состоять из цифр и иметь длинну не более 7 символов", "Ошибка"); return;
            }


            using (DANTDBEntities db = new DANTDBEntities())
            {
                Check model = (from u in db.Check
                               orderby u.number_check descending
                               select u).FirstOrDefault();
                check.number_check = model.number_check + 1;
                if (model == null)
                {
                    MessageBox.Show("Ошибка закрузки данных", "Ошибка");
                    return;
                }
            }

            if (MessageBox.Show("Создать чек? Детали чека изменить нельзя", "Создать чек", MessageBoxButtons.YesNo) == DialogResult.Yes)
            {
                using (DANTDBEntities db = new DANTDBEntities())
                {
                    db.Check.Add(check);
                    db.SaveChanges();
                }
                using (DANTDBEntities db = new DANTDBEntities())
                {
                    appointment                 = db.Appointment.Where(x => x.id == check.appointment_id).FirstOrDefault();
                    appointment.status_id       = 4;
                    db.Entry(appointment).State = EntityState.Modified;
                    db.SaveChanges();
                }
                txtServiceCost.Text = "";
                appointment.id      = 0;
                updateTable();
                MessageBox.Show("Данные успешно добавлены");
            }
            else
            {
                return;
            }
        }
示例#4
0
 private void ChangeCheck(object sender, EventArgs e)
 {
     check.check_status_id = 2;
     using (DANTDBEntities db = new DANTDBEntities())
     {
         db.Entry(check).State = EntityState.Modified;
         db.SaveChanges();
     }
     btnChangeCheck.Enabled = false;
     UpdateTable();
 }
示例#5
0
        //Функция проверки введенных данных
        private bool VerificationForm(DateTime dateAppointment)
        {
            DateTime dt = DateTime.Today;
            DateTime datePosibleAppointment = dt.AddDays(30);

            using (DANTDBEntities db = new DANTDBEntities())
            {
                Client model = (from u in db.Client
                                orderby u.id descending
                                select u).FirstOrDefault();
                if (model.id < Convert.ToInt32(txtClientID.Text))
                {
                    MessageBox.Show("Клиента с ID " + Convert.ToInt32(txtClientID.Text) + " не существует в информационной системе", "Ошибка");
                    return(false);
                }
            }


            if (dateAppointment <= dt)
            {
                MessageBox.Show("Записать пациента возможно только на следующие дни от текущей даты", "Ошибка"); return(false);
            }
            if (dateAppointment > datePosibleAppointment)
            {
                MessageBox.Show("Записать пациента возможно только не более чем на месяц вперед", "Ошибка"); return(false);
            }

            using (DANTDBEntities db = new DANTDBEntities())
            {
                Appointment model = (from u in db.Appointment
                                     where u.date == appointment.date && u.time_id == appointment.time_id && u.employee_id == appointment.employee_id
                                     select u).FirstOrDefault();
                if (model != null && appointment.status_id != 6)
                {
                    MessageBox.Show("Нельзя записать пациента на одну дату, время и врача более одно раза", "Ошибка");
                    return(false);
                }
            }

            using (DANTDBEntities db = new DANTDBEntities())
            {
                Appointment model = (from u in db.Appointment
                                     where u.date == appointment.date && u.time_id == appointment.time_id
                                     select u).FirstOrDefault();
                if (model != null && appointment.status_id != 6)
                {
                    MessageBox.Show("Нельзя записать пациента на одну дату и время более одно раза", "Ошибка");
                    return(false);
                }
            }
            return(true);
        }
示例#6
0
 //Удаление записи
 private void DeleteAppointment(object sender, EventArgs e)
 {
     if (MessageBox.Show("Удалить эту запись?", "Удаление", MessageBoxButtons.YesNo) == DialogResult.Yes)
     {
         using (DANTDBEntities db = new DANTDBEntities())
         {
             appointment.status_id       = 6;
             db.Entry(appointment).State = EntityState.Modified;
             db.SaveChanges();
         }
     }
     ClearAppointment();
     btnClearAppointment.Enabled = false;
     MessageBox.Show("Удаление прошло успешно");
 }
示例#7
0
        private void loginUser(object sender, EventArgs e)
        {
            string login    = txtLogin.Text;
            string password = txtPassword.Text;

            if (String.IsNullOrEmpty(login) || login.Equals("Логин"))
            {
                MessageBox.Show("Не введен логин", "Информация"); return;
            }
            else if (String.IsNullOrEmpty(password) || password.Equals("Пароль"))
            {
                MessageBox.Show("Не введен пароль", "Информация"); return;
            }

            password = getHash(getHash(password));

            Employee employee;
            bool     userAuth = false;

            using (DANTDBEntities db = new DANTDBEntities())
            {
                employee = db.Employee.FirstOrDefault(u => u.login == login && u.password == password);
                if (employee != null)
                {
                    userAuth = true;
                }
            }
            if (!userAuth)
            {
                MessageBox.Show("Неправильный логин или пароль"); return;
            }
            else
            {
                if (employee.position_id == 1)
                {
                    this.Visible = false;
                    AdminForm userForm = new AdminForm(login);
                    userForm.Show();
                }
                else
                {
                    this.Visible = false;
                    EmployeeForm employeeForm = new EmployeeForm(login);
                    employeeForm.Show();
                }
            }
        }
示例#8
0
 private void SelectCheck(object sender, EventArgs e)
 {
     if (dgvCheckList.CurrentRow.Index != -1)
     {
         check.id = Convert.ToInt32(dgvCheckList.CurrentRow.Cells["idDataGridViewTextBoxColumn3"].Value);
         using (DANTDBEntities db = new DANTDBEntities())
         {
             check = db.Check.Where(x => x.id == check.id).FirstOrDefault();
             if (check == null)
             {
                 MessageBox.Show("Ошибка закрузки данных пользователя", "Ошибка");
                 return;
             }
         }
         btnChangeCheck.Enabled = true;
     }
 }
示例#9
0
 //Загрузка данных панели сотрудника сотрудника
 private void loadUserInfo()
 {
     //lbDate.Text = Convert.ToString(DateTime.Now.Day + "." + DateTime.Now.Month + "." + DateTime.Now.Year);
     using (DANTDBEntities db = new DANTDBEntities())
     {
         Employee model = (from u in db.Employee
                           join q in db.Position on u.position_id equals q.id
                           where u.login == loginName
                           select u).FirstOrDefault();
         lbEmployeeName.Text = model.surname + " " + model.name.Remove(model.name.Length - (model.name.Length - 1)) + "." + model.surname.Remove(model.name.Length - (model.name.Length - 1)) + ".";
         //lbPosition.Text = model.Position.position1;
         if (model == null)
         {
             MessageBox.Show("Ошибка закрузки данных пользователя", "Ошибка");
             return;
         }
     }
 }
示例#10
0
 //Выбор клиента (двойное нажатие на ячейку)
 private void selectClient(object sender, EventArgs e)
 {
     btnClearClient.Enabled = true;
     if (dgvClient.CurrentRow.Index != -1)
     {
         client.id = Convert.ToInt32(dgvClient.CurrentRow.Cells["idDataGridViewTextBoxColumn"].Value);
         using (DANTDBEntities db = new DANTDBEntities())
         {
             client = db.Client.Where(x => x.id == client.id).FirstOrDefault();
             if (client == null)
             {
                 MessageBox.Show("Ошибка запроса", "Ошибка");
                 return;
             }
             txtClientName.Text       = client.name;
             txtClientSurname.Text    = client.surname;
             txtClientPatronymic.Text = client.patronymic;
             txtClientPhone.Text      = client.phone;
             txtNumberCard.Text       = client.card_number.ToString();
         }
         btnClient.Text = "Обновить запись";
     }
 }
示例#11
0
        //Функция добавления и обновления данных клиентов (вызывается нажатием на кнопку).
        private void AddClient(object sender, EventArgs e)
        {
            //Присвоение полям класса Client данных из TextBox
            client.surname    = txtClientSurname.Text.Trim();
            client.name       = txtClientName.Text.Trim();
            client.patronymic = txtClientPatronymic.Text.Trim();
            client.phone      = txtClientPhone.Text.Trim();

            //Проверка на заполненные поля
            if (String.IsNullOrEmpty(client.surname) || String.IsNullOrEmpty(client.name) || String.IsNullOrEmpty(client.patronymic) || String.IsNullOrEmpty(client.phone))
            {
                MessageBox.Show("Все поля должны быть заполненны");
                return;
            }

            //Проверки на введенную в TextBox информацию
            var regexName        = @"^([А-Я]{1}[а-яё]{1,23}|[A-Z]{1}[a-z]{1,23})$";
            var regexNumberPhone = @"^((8|\+7)[\- ]?)?(\(?\d{3}\)?[\- ]?)?[\d\- ]{7,10}$";

            if (!Regex.IsMatch(txtClientName.Text, regexName) || !Regex.IsMatch(txtClientSurname.Text, regexName) || !Regex.IsMatch(txtClientPatronymic.Text, regexName))
            {
                MessageBox.Show("Имя должно быть соответсвовать следующим требованиям:\n- Имя может состоять только из букв одного языка;\n- В имени обязательна должна присутствовать заглавная буква;\n" +
                                "- Имя должно состоять как минимум из 2 букв и максимум из 24;\n- Имя недолжно содержать никаких других символов, кроме букв.", "Ошибка"); return;
            }

            if (!Regex.IsMatch(txtClientPhone.Text, regexNumberPhone))
            {
                MessageBox.Show("Номер телефона не соотвествует стандартам", "Ошибка"); return;
            }

            //Следующий блок отвечает за заполнение поля card_number. Так как после добавления нового клиента этот номер должен увеличиваться на 1
            //Если поле id == 0, это означает то, что происходит ДОБАВЛЕНИЕ новых данных, а не ОБНОВЛЕНИЕ
            if (client.id == 0)
            {
                //Открываем соединение с бд с помощью оператора using
                using (DANTDBEntities db = new DANTDBEntities())
                {
                    //LINQ запрос берет таблицу Client, сортирует ее по убыванию столбца card_number и берет первую строку (в этом случае номер карты будет последнем добавленным)
                    Client model = (from u in db.Client
                                    orderby u.card_number descending
                                    select u).FirstOrDefault();
                    if (model != null)
                    {
                        client.card_number = model.card_number + 1;
                    }
                    else
                    {
                        //В случае если в результате запроса не было выбранно строки это значит что таблица пуста и card_number будет иметь исходне значение 100000
                        client.card_number = 100000;
                    }
                }
            }
            //Если поле id != 0 то происходит обновление данных и данные карты будут браться из TextBox
            else
            {
                client.card_number = Convert.ToInt32(txtNumberCard.Text.Trim());
            }

            //Следующий блок отвечает за добавление или обновление данных
            using (DANTDBEntities db = new DANTDBEntities())
            {
                //Добавление
                if (client.id == 0)
                {
                    db.Client.Add(client);
                }
                //Обновление
                else
                {
                    db.Entry(client).State = EntityState.Modified;
                }
                //Сохранение данных
                db.SaveChanges();
            }

            //Очищаем TextBox
            txtClientName.Text     = txtClientSurname.Text = txtClientPatronymic.Text = txtClientPhone.Text = txtNumberCard.Text = "";
            btnClearClient.Enabled = false;
            //Добавляем значение 0 полю id
            client.id = 0;
            //Заполняем таблицу клиентов новыми данными
            this.clientTableAdapter.Fill(this.clientData.Client);
            MessageBox.Show("Данные успешно добавлены");
        }
示例#12
0
        //Добавление добавления и обновления данных записей (вызывается нажатием на кнопку)
        private void AddAppointment(object sender, EventArgs e)
        {
            DateTime dateAppointment = new DateTime(dtDateAppointment.Value.Year, dtDateAppointment.Value.Month, dtDateAppointment.Value.Day);

            appointment.client_id   = Convert.ToInt32(txtClientID.Text.Trim());
            appointment.employee_id = Convert.ToInt32(cmbDoctorName.SelectedValue.ToString());
            appointment.date        = dtDateAppointment.Value.Date;
            appointment.time_id     = Convert.ToInt32(cbTime.SelectedValue);

            if (String.IsNullOrEmpty(appointment.client_id.ToString()) || String.IsNullOrEmpty(appointment.employee_id.ToString()) || String.IsNullOrEmpty(appointment.date.ToString()) || String.IsNullOrEmpty(appointment.time_id.ToString()))
            {
                MessageBox.Show("Все поля должны быть заполненны"); return;
            }

            var regexNumberID = @"^[1-9]\d{0,7}$";

            if (!Regex.IsMatch(txtClientID.Text, regexNumberID))
            {
                MessageBox.Show("ID должно состоять из цифр и иметь длинну не более 7 символов", "Ошибка"); return;
            }

            using (DANTDBEntities db = new DANTDBEntities())
            {
                Appointment model = (from u in db.Appointment
                                     orderby u.number_appointment descending
                                     select u).FirstOrDefault();
                if (model != null)
                {
                    appointment.number_appointment = model.number_appointment + 1;
                }
                else
                {
                    appointment.number_appointment = 510000;
                }
            }

            if (appointment.id == 0)
            {
                if (!VerificationForm(dateAppointment))
                {
                    return;
                }
            }


            using (DANTDBEntities db = new DANTDBEntities())
            {
                if (appointment.id == 0)
                {
                    appointment.status_id = 1;
                    db.Appointment.Add(appointment);
                }
                else
                {
                    appointment.status_id = Convert.ToInt32(cbAppointmentStatus.SelectedValue);
                    if (appointment.status_id == 1)
                    {
                        MessageBox.Show("Нельзя поменять статус записи на 'Записан'", "Ошибка"); return;
                    }
                    else if (DateTime.Today < dateAppointment && appointment.status_id == 2)
                    {
                        MessageBox.Show("Нельзя поменять статус записи на 'Явился на прием' до такого как наступит дата приема ", "Ошибка"); return;
                    }
                    else if (DateTime.Today < dateAppointment && appointment.status_id == 3)
                    {
                        MessageBox.Show("Нельзя поменять статус записи на 'Не явился на прием' до такого как наступит дата приема ", "Ошибка"); return;
                    }
                    db.Entry(appointment).State = EntityState.Modified;
                }
                db.SaveChanges();
            }
            txtClientID.Text = cmbDoctorName.Text = dtDateAppointment.Text = cbTime.Text = "";
            appointment.id   = 0;
            this.dataTable1TableAdapter3.Fill(this.appointmentData1.DataTable1);
            MessageBox.Show("Данные успешно добавлены");
            ClearAppointment();
        }