Добавлена функция поиска и улучшена команда вывода списка. #41
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,2 +1,3 @@
|
|||||||
todo/target/
|
todo/target/
|
||||||
.vscode/
|
.vscode/
|
||||||
|
.lingma/
|
||||||
@ -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());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
30
todo/src/main/java/ru/kamask/pet/todo/cli/SearchCommand.java
Normal file
30
todo/src/main/java/ru/kamask/pet/todo/cli/SearchCommand.java
Normal 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);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user