From adeaa0bafc90edf82b7027270e73ed55eaa7e0d1 Mon Sep 17 00:00:00 2001 From: Pluiexo Date: Thu, 15 Feb 2024 12:47:01 +0800 Subject: [PATCH] Change index system for query functions --- src/main/java/duke/task/TaskManager.java | 25 ++++++++++++++++-------- 1 file changed, 17 insertions(+), 8 deletions(-) diff --git a/src/main/java/duke/task/TaskManager.java b/src/main/java/duke/task/TaskManager.java index 418020c1cc..ae1b6065d0 100644 --- a/src/main/java/duke/task/TaskManager.java +++ b/src/main/java/duke/task/TaskManager.java @@ -9,6 +9,7 @@ import java.util.regex.Matcher; import java.util.regex.Pattern; import java.util.stream.Collectors; +import java.util.stream.IntStream; import duke.DukeException; import duke.parser.DateHandler; @@ -276,12 +277,13 @@ public String[] queryTasks(Query act, String instruction) throws DukeException { * @return A list of items containing the search results. */ public String[] findTask(String search) { - List foundTask = items.stream().filter(item -> item.toString().contains(search)) - .map(item -> items.indexOf(item) + 1 + ". " + item).collect(Collectors.toList()); + List foundTask = items.stream().map(Task::toString).filter(string -> string.contains(search)) + .collect(Collectors.toList()); if (!foundTask.isEmpty()) { - foundTask.add(0, RESPONSE_FIND); - return foundTask.toArray(String[]::new); + List print = iterateWithIndex(foundTask); + print.add(0, RESPONSE_FIND); + return print.toArray(String[]::new); } else { return new String[]{RESPONSE_EMPTY_SEARCH}; @@ -299,12 +301,14 @@ public String[] findTask(String search) { public String[] viewByDate(String date) throws DukeException { LocalDate inputDate = DateHandler.checkDate(date).orElseThrow(() -> new DukeException("dateError")); System.out.println(inputDate); - List foundDates = items.stream().filter(item -> isMatchDate(item.getType(), item, inputDate)) - .map(item -> items.indexOf(item) + 1 + ". " + item).collect(Collectors.toList()); + List foundDates = + items.stream().filter(item -> isMatchDate(item.getType(), item, inputDate)).map(Task::toString) + .collect(Collectors.toList()); if (!foundDates.isEmpty()) { - foundDates.add(0, RESPONSE_VIEW_DATES); - return foundDates.toArray(String[]::new); + List print = iterateWithIndex(foundDates); + print.add(0, RESPONSE_VIEW_DATES); + return print.toArray(String[]::new); } else { return new String[]{RESPONSE_EMPTY_SEARCH}; @@ -312,6 +316,11 @@ public String[] viewByDate(String date) throws DukeException { } } + private static List iterateWithIndex(List toReturn) { + return IntStream.range(0, toReturn.size()).mapToObj(i -> (i + 1) + ". " + toReturn.get(i)) + .collect(Collectors.toList()); + } + private boolean isMatchDate(SaveType type, Task first, LocalDate second) { if (type.equals(SaveType.DEADLINE)) { Deadline test = (Deadline) first;