Compare commits
No commits in common. "0f8f4037c9981277bcb97ce8ee390e7c87d46347" and "f380e12f67b11e172bcd5e3d12b3e4cf5bd72f37" have entirely different histories.
0f8f4037c9
...
f380e12f67
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,3 +1,2 @@
|
|||||||
todo/target/
|
todo/target/
|
||||||
.vscode/
|
.vscode/
|
||||||
.lingma/
|
|
||||||
18
CHANGELOG.md
18
CHANGELOG.md
@ -1,19 +1,9 @@
|
|||||||
|
# Журнал изменений
|
||||||
|
|
||||||
Все заметные изменения проекта будут документироваться в этом файле.
|
Все заметные изменения проекта будут документироваться в этом файле.
|
||||||
|
|
||||||
Формат основан на [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
|
||||||
|
|
||||||
@ -21,4 +11,4 @@
|
|||||||
- Базовая функциональность для управления задачами
|
- Базовая функциональность для управления задачами
|
||||||
- Команды: create, list, delete
|
- Команды: create, list, delete
|
||||||
- Консольный интерфейс для взаимодействия с приложением
|
- Консольный интерфейс для взаимодействия с приложением
|
||||||
- In-memory хранилище задач
|
- In-memory хранилище задач
|
||||||
@ -19,7 +19,6 @@ java -jar ./target/todo.jar
|
|||||||
- `list` - Показать список всех задач
|
- `list` - Показать список всех задач
|
||||||
- `complete <id>` - Отметить задачу как выполненную
|
- `complete <id>` - Отметить задачу как выполненную
|
||||||
- `delete <id>` - Удалить задачу
|
- `delete <id>` - Удалить задачу
|
||||||
- `search <текст>` - Найти задачи по тексту
|
|
||||||
- `exit` - Выйти из приложения
|
- `exit` - Выйти из приложения
|
||||||
|
|
||||||
## Структура проекта
|
## Структура проекта
|
||||||
@ -29,7 +28,7 @@ java -jar ./target/todo.jar
|
|||||||
- `cli` - Компоненты интерфейса командной строки
|
- `cli` - Компоненты интерфейса командной строки
|
||||||
|
|
||||||
## Версии
|
## Версии
|
||||||
Актуальная версия: 2.1
|
Актуальная версия: 2.0
|
||||||
|
|
||||||
## Лицензия
|
## Лицензия
|
||||||
[MIT](LICENSE)
|
[MIT](LICENSE)
|
||||||
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
<groupId>ru.kamask.pet</groupId>
|
<groupId>ru.kamask.pet</groupId>
|
||||||
<artifactId>todo</artifactId>
|
<artifactId>todo</artifactId>
|
||||||
<version>2.1</version>
|
<version>2.0-SNAPSHOT</version>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<maven.compiler.release>24</maven.compiler.release>
|
<maven.compiler.release>24</maven.compiler.release>
|
||||||
|
|||||||
@ -21,7 +21,7 @@ public class CliEngine {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void start() throws IOException {
|
public void start() throws IOException {
|
||||||
System.out.println("\nДобро пожаловать в Список задач 2.1!");
|
System.out.println("\nДобро пожаловать в Список задач 2.0!");
|
||||||
System.out.println("Введите help для просмтора доступных команд или exit для выхода.");
|
System.out.println("Введите help для просмтора доступных команд или exit для выхода.");
|
||||||
while (true) {
|
while (true) {
|
||||||
System.out.print("\ntodo> ");
|
System.out.print("\ntodo> ");
|
||||||
@ -46,7 +46,6 @@ 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());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -1,6 +1,5 @@
|
|||||||
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;
|
||||||
@ -18,8 +17,18 @@ public class ListCommand implements Command {
|
|||||||
if (args.length > 0)
|
if (args.length > 0)
|
||||||
return Optional.of(Command.errorMessage);
|
return Optional.of(Command.errorMessage);
|
||||||
|
|
||||||
var res = formatWithTable(service.list(), "Список задач пуст.");
|
String template = "%-2s | %-30s | %s\n";
|
||||||
|
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);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -27,21 +36,4 @@ 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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,30 +0,0 @@
|
|||||||
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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -42,10 +42,4 @@ 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();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user