Compare commits

..

6 Commits

Author SHA1 Message Date
0f8f4037c9 Merge pull request 'dev' (#43) from dev into main
Reviewed-on: #43
2025-06-04 15:14:11 +03:00
65b3ddcc24 Merge branch 'main' into dev 2025-06-04 15:13:17 +03:00
20f9f7e8df Merge pull request 'Release v2.1.0' (#42) from release/2.1.0 into dev
Reviewed-on: #42
2025-06-04 15:08:40 +03:00
0f838ae4a0 Release v2.1.0 2025-06-04 15:02:31 +03:00
1f609abcb7 Merge pull request 'Добавлена функция поиска и улучшена команда вывода списка.' (#41) from feature/search into dev
Reviewed-on: #41
2025-06-04 14:06:02 +03:00
99e60947a6 Добавлена функция поиска и улучшена команда вывода списка.
- Добавлен класс SearchCommand в CliEngine
- Улучшен класс ListCommand, реализован новый метод formatWithTable
- Реализован метод поиска в сервисе задач (TaskService)
2025-06-04 13:25:39 +03:00
8 changed files with 77 additions and 20 deletions

1
.gitignore vendored
View File

@ -1,2 +1,3 @@
todo/target/ todo/target/
.vscode/ .vscode/
.lingma/

View File

@ -1,9 +1,19 @@
# Журнал изменений
Все заметные изменения проекта будут документироваться в этом файле. Все заметные изменения проекта будут документироваться в этом файле.
Формат основан на [Keep a Changelog](https://keepachangelog.com/ru/1.0.0/), Формат основан на [Keep a Changelog](https://keepachangelog.com/ru/1.0.0/),
и этот проект придерживается [Semantic Versioning](https://semver.org/spec/v2.0.0.html). и этот проект придерживается [Semantic Versioning](https://semver.org/spec/v2.0.0.html)
## [2.1.0] - 2025-06-01
### Добавлено
- Команда `search <текст>` для поиска задач по тексту (реализован класс `SearchCommand`)
- Метод `search(String query)` в `TaskService` для поддержки поиска задач
- Рефакторинг: вынесение общего функционала отображения задач в отдельный метод `formatWithTable()` в классе `ListCommand`
### Изменено
- Обновлены внутренние зависимости между компонентами CLI (`SearchCommand`, `ListCommand`) и моделью данных (`Task`, `SimpleTask`)
- Добавлена обработка минимальной длины поискового запроса (3 символа) в `SearchCommand`# Журнал изменений
## [2.0.0] - 2025-05-29 ## [2.0.0] - 2025-05-29
@ -11,4 +21,4 @@
- Базовая функциональность для управления задачами - Базовая функциональность для управления задачами
- Команды: create, list, delete - Команды: create, list, delete
- Консольный интерфейс для взаимодействия с приложением - Консольный интерфейс для взаимодействия с приложением
- In-memory хранилище задач - In-memory хранилище задач

View File

@ -19,6 +19,7 @@ java -jar ./target/todo.jar
- `list` - Показать список всех задач - `list` - Показать список всех задач
- `complete <id>` - Отметить задачу как выполненную - `complete <id>` - Отметить задачу как выполненную
- `delete <id>` - Удалить задачу - `delete <id>` - Удалить задачу
- `search <текст>` - Найти задачи по тексту
- `exit` - Выйти из приложения - `exit` - Выйти из приложения
## Структура проекта ## Структура проекта
@ -28,7 +29,7 @@ java -jar ./target/todo.jar
- `cli` - Компоненты интерфейса командной строки - `cli` - Компоненты интерфейса командной строки
## Версии ## Версии
Актуальная версия: 2.0 Актуальная версия: 2.1
## Лицензия ## Лицензия
[MIT](LICENSE) [MIT](LICENSE)

View File

@ -6,7 +6,7 @@
<groupId>ru.kamask.pet</groupId> <groupId>ru.kamask.pet</groupId>
<artifactId>todo</artifactId> <artifactId>todo</artifactId>
<version>2.0-SNAPSHOT</version> <version>2.1</version>
<properties> <properties>
<maven.compiler.release>24</maven.compiler.release> <maven.compiler.release>24</maven.compiler.release>

View File

@ -21,7 +21,7 @@ public class CliEngine {
} }
public void start() throws IOException { public void start() throws IOException {
System.out.println("\обро пожаловать в Список задач 2.0!"); System.out.println("\обро пожаловать в Список задач 2.1!");
System.out.println("Введите help для просмтора доступных команд или exit для выхода."); System.out.println("Введите help для просмтора доступных команд или exit для выхода.");
while (true) { while (true) {
System.out.print("\ntodo> "); System.out.print("\ntodo> ");
@ -46,6 +46,7 @@ public class CliEngine {
registerCommand(new CreateCommand()); registerCommand(new CreateCommand());
registerCommand(new ListCommand()); registerCommand(new ListCommand());
registerCommand(new CompleteCommand()); registerCommand(new CompleteCommand());
registerCommand(new SearchCommand());
registerCommand(new DeleteCommand()); registerCommand(new DeleteCommand());
} }

View File

@ -1,5 +1,6 @@
package ru.kamask.pet.todo.cli; package ru.kamask.pet.todo.cli;
import java.util.List;
import java.util.Optional; import java.util.Optional;
import ru.kamask.pet.todo.model.SimpleTask; import ru.kamask.pet.todo.model.SimpleTask;
@ -17,18 +18,8 @@ public class ListCommand implements Command {
if (args.length > 0) if (args.length > 0)
return Optional.of(Command.errorMessage); return Optional.of(Command.errorMessage);
String template = "%-2s | %-30s | %s\n"; var res = formatWithTable(service.list(), "Список задач пуст.");
String res = "";
res += String.format(template, "ID", "Название задачи", "Статус");
res += "-".repeat(50) + "\n";
if (service.list().size() == 0)
return Optional.of(res + "\nСписок задач пуст.");
for (Task task : service.list()) {
SimpleTask.Data data = ((SimpleTask) task).data();
res += String.format(template, data.id(), data.title(), data.done() ? "выполнено" : "не выполнено");
}
return Optional.of(res); return Optional.of(res);
} }
@ -36,4 +27,21 @@ public class ListCommand implements Command {
public String usage() { public String usage() {
return String.format(templateUsage, name(), "Список всех задач."); return String.format(templateUsage, name(), "Список всех задач.");
} }
String formatWithTable(List<Task> tasks, String msgIfEmpty){
String template = "%-2s | %-30s | %s\n";
String res = "";
res += String.format(template, "ID", "Название задачи", "Статус");
res += "-".repeat(50) + "\n";
if (tasks.size() == 0)
return res + "\n" + msgIfEmpty;
for (Task task : tasks) {
SimpleTask.Data data = ((SimpleTask) task).data();
res += String.format(template, data.id(), data.title(), data.done() ? "выполнено" : "не выполнено");
}
return res;
}
} }

View File

@ -0,0 +1,30 @@
package ru.kamask.pet.todo.cli;
import java.util.Optional;
import ru.kamask.pet.todo.service.TaskService;
public class SearchCommand implements Command {
@Override
public String name() {
return "search";
}
@Override
public String usage() {
return String.format(templateUsage, name() + " <текст>", "Поиск задач по тексту (минимум 3 символа)");
}
@Override
public Optional<String> handle(String[] args, TaskService service) {
if (args.length != 1)
return Optional.of(Command.errorMessage);
if (args[0].length() < 3)
return Optional.of("Длина запроса должна быть не менее 3 символов.");
var matchTask = service.search(args[0]);
var res = new ListCommand().formatWithTable(matchTask, "Не найдено задач, соответствующих запросу.");
return Optional.of(res);
}
}

View File

@ -42,4 +42,10 @@ public class TaskService {
public boolean has(int id) { public boolean has(int id) {
return repo.has(id); return repo.has(id);
} }
public List<Task> search(String query) {
return repo.findAll().stream()
.filter(task -> ((SimpleTask) task).data().title().contains(query))
.toList();
}
} }