public static void findInTableByText(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Для поиска по тексту введите текст\n" + "[Назад - esc]"); string text = ""; ConsoleKeyInfo cki = IO.getKeyFromUser(); while (cki.Key != ConsoleKey.Enter) { if (cki.Key == ConsoleKey.Escape) { throw new ProcessToShowTable(); } text += cki.KeyChar; cki = IO.getKeyFromUser(); } IO.print("Поиск по тексту - " + text); tm.findTasksByText(text); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ProcessToShowTable(); }
public static void deleteTasksFromTableById(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Список " + DB.MainTable); tm = DB.getAllTasks(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Выберите № задачи для удаления:\n[Назад - esc]"); int countTasks = tm.getTasks().Count; ConsoleKeyInfo cki; int id = -1; do { string int_ans = ""; cki = IO.getKeyFromUser(); while (cki.Key != ConsoleKey.Enter) { if (cki.Key == ConsoleKey.Escape) { throw new ReturnToTableMenu(); } int_ans += cki.KeyChar; cki = IO.getKeyFromUser(); } bool v = int.TryParse(int_ans, out id); if (!v || id < 0) { id = -1; IO.clear(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Ошибка! Неверное значение.\n"); IO.print("Выберите № задачи для удаления:\n[Назад - esc]"); } tm.findTaskById(id); if (tm.getTasks().Count == 0) { tm = DB.getAllTasks(); id = -1; IO.clear(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Ошибка! Такого номера задания не существует.\n"); IO.print("Выберите № задачи для удаления:\n[Назад - esc]"); } } while (id < 0); IO.clear(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Удаление задачи. Для подтверждения нажмите Enter"); if (IO.getKeyFromUser().Key == ConsoleKey.Enter) { DB.deleteTasks(tm); IO.print("Удаление выполнено успешно. Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); } throw new ReturnToTableMenu(); }
public static void editTasksAtTableByStatus(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); string menu = "Редактировать:\n" + "1)Выполненные\n" + "2)Не выполненные\n" + "[Назад - esc]"; IO.print(menu); ConsoleKeyInfo cki; int answer = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out answer); if (!v || answer < 1 || answer > 2) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + menu); } } while (answer < 1 || answer > 2); IO.clear(); switch (answer) { case 1: tm = DB.getAllTasks(); tm.findTasksByCompletion(true); tm.getTasks().ForEach(e => editSingleTask(e, tm, IO)); DB.updateTasks(tm); IO.clear(); IO.print("Редактирование выполнено успешно. Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ReturnToTableMenu(); break; case 2: tm = DB.getAllTasks(); tm.findTasksByCompletion(false); tm.getTasks().ForEach(e => editSingleTask(e, tm, IO)); DB.updateTasks(tm); IO.clear(); IO.print("Редактирование выполнено успешно. Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ReturnToTableMenu(); break; default: throw new ReturnToTableMenu(); break; } }
internal bool deleteTasks(Task_manager_impl tm) { List <string> query = new List <string>(); for (int i = 0; i < tm.getTasks().Count; i++) { query.Add("DELETE FROM " + mainTable + " WHERE task_id = " + tm.getTasks()[i].Task_id + ";"); } query.ForEach(e => DB.executeQuery(e, false)); return(true); }
public static void findInTable(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); string menu = "Выберите действие:\n" + "1)Найти по тексту\n" + "2)Найти по дате\n" + "3)Найти по статусу\n" + "[Назад - esc]"; IO.print(menu); ConsoleKeyInfo cki; int answer = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out answer); if (!v || answer < 1 || answer > 3) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + menu); } } while (answer < 1 || answer > 3); IO.clear(); try { switch (answer) { case 1: findInTableByText(DB, tm, IO); break; case 2: findInTableByDate(DB, tm, IO); break; case 3: findInTableByCompletion(DB, tm, IO); break; default: throw new ProcessToShowTable(); break; } } catch (ProcessToShowTable) { throw new ProcessToShowTable(); } }
public Task_manager_impl getAllTasks() { if (mainTable.Equals("")) { throw new Exception(); } Task_manager_impl tm = new Task_manager_impl(); DB.executeQuery("SELECT * FROM " + mainTable, true) .ForEach(e => tm.addTask(int.Parse(e[0]), e[1], DateTime.Parse(e[2]), bool.Parse(e[3]))); return(tm); }
public static void findInTableByCompletion(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); string menu = "Найти:\n" + "1)Выполненные\n" + "2)Не выполненные\n" + "[Назад - esc]"; IO.print(menu); ConsoleKeyInfo cki; int answer = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out answer); if (!v || answer < 1 || answer > 2) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + menu); } } while (answer < 1 || answer > 2); IO.clear(); switch (answer) { case 1: IO.print("Поиск выполненных задач"); tm.findTasksByCompletion(true); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ProcessToShowTable(); break; case 2: IO.print("Поиск не выполненных задач"); tm.findTasksByCompletion(false); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ProcessToShowTable(); break; default: throw new ProcessToShowTable(); break; } }
public static void findInTableByDate(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Для поиска по дате введите дату\n" + "[Назад - esc]"); string date_string; ConsoleKeyInfo cki; DateTime date = DateTime.Now; while (true) { date_string = ""; cki = IO.getKeyFromUser(); while (cki.Key != ConsoleKey.Enter) { if (cki.Key == ConsoleKey.Escape) { throw new ProcessToShowTable(); } date_string += cki.KeyChar; cki = IO.getKeyFromUser(); } date_string = date_string.Replace(".", "/").Replace(",", "/") .Replace(":", "/").Replace(";", "/").Replace("-", "/"); if (new Regex(@"\d{2,2}/\d{2,2}/\d{4,4}").IsMatch(date_string)) { date_string = date_string.Substring(6) + "/" + date_string.Substring(3, 2) + "/" + date_string.Substring(0, 2); } date = new DateTime(); if (!(new Regex(@"\d{4,4}/\d{2,2}/\d{2,2}").IsMatch(date_string)) || !DateTime.TryParse(date_string, out date)) { IO.clear(); IO.print("Ошибка! Неверный формат даты\nДля поиска по дате введите дату\n" + "[Назад - esc]"); } else { break; } } IO.print("Поиск по дате - " + date.ToString().Substring(0, 10)); tm.findTasksByDate(date); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ProcessToShowTable(); }
public static void deleteTasksFromTableByText(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Список " + DB.MainTable); tm = DB.getAllTasks(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Для удаления по тексту введите текст\n" + "[Назад - esc]"); string text; ConsoleKeyInfo cki; while (true) { text = ""; cki = IO.getKeyFromUser(); while (cki.Key != ConsoleKey.Enter) { if (cki.Key == ConsoleKey.Escape) { throw new ProcessToShowTable(); } text += cki.KeyChar; cki = IO.getKeyFromUser(); } tm.findTasksByText(text); if (tm.getTasks().Count == 0) { tm = DB.getAllTasks(); IO.clear(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Не найдено совпадений! Введите текст еще раз!"); } else { break; } } IO.clear(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Удаление задач. Для подтверждения нажмите Enter"); if (IO.getKeyFromUser().Key == ConsoleKey.Enter) { DB.deleteTasks(tm); IO.print("Удаление выполнено успешно. Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); } throw new ReturnToTableMenu(); }
public static void showTable(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Список " + DB.MainTable); tm = DB.getAllTasks(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); string menu = "Выберите действие:\n" + "1)Отсортировать\n" + "2)Найти\n" + "[Назад - esc]"; IO.print(menu); ConsoleKeyInfo cki; int answer = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out answer); if (!v || answer < 1 || answer > 2) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + menu); } } while (answer < 1 || answer > 2); switch (answer) { case 1: throw new ProcessToSortTable(); break; case 2: throw new ProcessToFindInTable(); break; default: throw new ReturnToTableMenu(); break; } }
public bool updateTasks(Task_manager_impl tm) { List <string> query = new List <string>(); for (int i = 0; i < tm.getTasks().Count; i++) { if (tm.getTasks()[i].Task_id == -1) { query.Add("INSERT INTO " + mainTable + " VALUES('" + tm.getTasks()[i].Task_text + "','" + tm.getTasks()[i].Task_date.ToString() + "'," + (tm.getTasks()[i].Task_completion?1:0) + ")"); } else { query.Add("UPDATE " + mainTable + " SET task_text = '" + tm.getTasks()[i].Task_text + "', task_date = '" + tm.getTasks()[i].Task_date.ToString() + "', task_completion = " + (tm.getTasks()[i].Task_completion ? 1 : 0) + " WHERE task_id = " + tm.getTasks()[i].Task_id + ";"); } } query.ForEach(e => DB.executeQuery(e, false)); return(true); }
public static void editSingleTask(Task_impl task, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Задание: " + task.Task_text); IO.print("Введите новое: "); string text = IO.getStringFromUser(); IO.print("Дата задания: " + task.Task_date.ToString().Substring(0, 10)); IO.print("Введите новую дату: "); DateTime time = IO.getDateFromUser(); IO.print("Статус задания: " + (task.Task_completion ? "[X]" : "[ ]")); string phrase = "Введите новый статус:\n" + "1)Выполнено\n" + "2)Не выполнено"; IO.print(phrase); ConsoleKeyInfo cki; int status = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out status); if (!v || status < 1 || status > 2) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + phrase); } } while (status < 1 || status > 2); tm.changeTask(task, text, time, status == 1 ? true : false); }
public static void deleteTasksFromTableByStatus(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); string menu = "Удалить:\n" + "1)Выполненные\n" + "2)Не выполненные\n" + "[Назад - esc]"; IO.print(menu); ConsoleKeyInfo cki; int answer = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out answer); if (!v || answer < 1 || answer > 2) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + menu); } } while (answer < 1 || answer > 2); IO.clear(); switch (answer) { case 1: tm = DB.getAllTasks(); tm.findTasksByCompletion(true); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Удаление выполненных задач. Для подтверждения нажмите Enter"); if (IO.getKeyFromUser().Key == ConsoleKey.Enter) { DB.deleteTasks(tm); IO.print("Удаление выполнено успешно. Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); } throw new ReturnToTableMenu(); break; case 2: tm = DB.getAllTasks(); tm.findTasksByCompletion(false); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Удаление не выполненных задач. Для подтверждения нажмите Enter"); if (IO.getKeyFromUser().Key == ConsoleKey.Enter) { DB.deleteTasks(tm); IO.print("Удаление выполнено успешно. Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); } throw new ReturnToTableMenu(); break; default: throw new ReturnToTableMenu(); break; } }
public static void addTaskToTable(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Добавление новой задачи\n[Назад - esc]\nВведите задание:"); string text = ""; ConsoleKeyInfo cki = IO.getKeyFromUser(); while (cki.Key != ConsoleKey.Enter) { if (cki.Key == ConsoleKey.Escape) { throw new ProcessToShowTable(); } text += cki.KeyChar; cki = IO.getKeyFromUser(); } IO.print(text + "\nВведите дату:"); string date_string; DateTime date = DateTime.Now; while (true) { date_string = ""; cki = IO.getKeyFromUser(); while (cki.Key != ConsoleKey.Enter) { if (cki.Key == ConsoleKey.Escape) { throw new ProcessToShowTable(); } date_string += cki.KeyChar; cki = IO.getKeyFromUser(); } date_string = date_string.Replace(".", "/").Replace(",", "/") .Replace(":", "/").Replace(";", "/").Replace("-", "/"); if (new Regex(@"\d{2,2}/\d{2,2}/\d{4,4}").IsMatch(date_string)) { date_string = date_string.Substring(6) + "/" + date_string.Substring(3, 2) + "/" + date_string.Substring(0, 2); } date = new DateTime(); if (!(new Regex(@"\d{4,4}/\d{2,2}/\d{2,2}").IsMatch(date_string)) || !DateTime.TryParse(date_string, out date)) { IO.clear(); IO.print("Ошибка! Неверный формат даты\nВведите дату"); } else { break; } } tm = new Task_manager_impl(); tm.addTask(text, date); IO.getKeyFromUser(); DB.updateTasks(tm); IO.clear(); IO.print("Успешно добавлено"); IO.getKeyFromUser(); throw new ProcessToAddTaskToTable(); }
public static void editTasksAtTableByDate(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); IO.print("Список " + DB.MainTable); tm = DB.getAllTasks(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Для редактирования по дате введите дату\n" + "[Назад - esc]"); string date_string; ConsoleKeyInfo cki; DateTime date = DateTime.Now; while (true) { while (true) { date_string = ""; cki = IO.getKeyFromUser(); while (cki.Key != ConsoleKey.Enter) { if (cki.Key == ConsoleKey.Escape) { throw new ProcessToShowTable(); } date_string += cki.KeyChar; cki = IO.getKeyFromUser(); } date_string = date_string.Replace(".", "/").Replace(",", "/") .Replace(":", "/").Replace(";", "/").Replace("-", "/"); if (new Regex(@"\d{2,2}/\d{2,2}/\d{4,4}").IsMatch(date_string)) { date_string = date_string.Substring(6) + "/" + date_string.Substring(3, 2) + "/" + date_string.Substring(0, 2); } date = new DateTime(); if (!(new Regex(@"\d{4,4}/\d{2,2}/\d{2,2}").IsMatch(date_string)) || !DateTime.TryParse(date_string, out date)) { IO.clear(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Ошибка! Неверный формат даты\nДля редактирования по дате введите дату\n" + "[Назад - esc]"); } else { break; } } tm.findTasksByDate(date); if (tm.getTasks().Count == 0) { tm = DB.getAllTasks(); IO.clear(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Не найдено совпадений! Введите дату еще раз!"); } else { break; } } IO.clear(); tm.getTasks().ForEach(e => editSingleTask(e, tm, IO)); DB.updateTasks(tm); IO.print("Редактирование выполнено успешно. Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ReturnToTableMenu(); }
public static void editTasksAtTable(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); string menu = "Выберите действие:\n" + "1)Редактировать по номеру\n" + "2)Редактировать по тексту\n" + "3)Редактировать по дате\n" + "4)Редактировать по статусу\n" + "[Назад - esc]"; IO.print(menu); ConsoleKeyInfo cki; int answer = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out answer); if (!v || answer < 1 || answer > 4) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + menu); } } while (answer < 1 || answer > 4); IO.clear(); switch (answer) { case 1: try { editTasksAtTableById(DB, tm, IO); } catch (ProcessToShowTable) { throw new ProcessToShowTable(); } catch (ReturnToTableMenu) { throw new ReturnToTableMenu(); } break; case 2: try { editTasksAtTableByText(DB, tm, IO); } catch (ProcessToShowTable) { throw new ProcessToShowTable(); } catch (ReturnToTableMenu) { throw new ReturnToTableMenu(); } break; case 3: try { editTasksAtTableByDate(DB, tm, IO); } catch (ProcessToShowTable) { throw new ProcessToShowTable(); } catch (ReturnToTableMenu) { throw new ReturnToTableMenu(); } break; case 4: try { editTasksAtTableByStatus(DB, tm, IO); } catch (ProcessToShowTable) { throw new ProcessToShowTable(); } catch (ReturnToTableMenu) { throw new ReturnToTableMenu(); } break; default: throw new ProcessToEditTable(); break; } }
public static void sortTable(DB_impl DB, Task_manager_impl tm, ConsoleIO_impl IO) { IO.clear(); string menu = "Выберите действие:\n" + "1)Отсортировать по тексту\n" + "2)Отсортировать по дате\n" + "3)Отсортировать по статусу\n" + "[Назад - esc]"; IO.print(menu); ConsoleKeyInfo cki; int answer = -1; do { cki = IO.getKeyFromUser(); if (cki.Key == ConsoleKey.Escape) { break; } bool v = int.TryParse(cki.Key.ToString().Substring(1), out answer); if (!v || answer < 1 || answer > 3) { IO.clear(); IO.print("Ошибка! Неверное значение.\n" + menu); } } while (answer < 1 || answer > 3); IO.clear(); switch (answer) { case 1: IO.print("Сортировка по тексту"); tm.sortByText(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ProcessToShowTable(); break; case 2: IO.print("Сортировка по дате"); tm.sortByDate(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ProcessToShowTable(); break; case 3: IO.print("Сортировка по статусу"); tm.sortByCompletion(); IO.printTable(new string[] { "id", "[X]/[ ]", "Дата", "Задание" }, tm.getTaskManagerDataGrid()); IO.print("Нажмите любую клавишу для возврата."); IO.getKeyFromUser(); throw new ProcessToShowTable(); break; default: throw new ProcessToShowTable(); break; } }
public UI_impl(DB_impl dB, Task_manager_impl tm, ConsoleIO_impl iO) { DB = dB ?? throw new ArgumentNullException(nameof(dB)); this.tm = tm ?? throw new ArgumentNullException(nameof(tm)); IO = iO ?? throw new ArgumentNullException(nameof(iO)); }