forked from AY2324S1-CS2103T-F12-4/tp
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request AY2324S1-CS2103T-F12-4#105 from jason-raiin/mark-c…
…ommand Mark command
- Loading branch information
Showing
57 changed files
with
815 additions
and
231 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
105 changes: 105 additions & 0 deletions
105
src/main/java/seedu/address/logic/commands/MarkMeetingCommand.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
package seedu.address.logic.commands; | ||
|
||
import static java.util.Objects.requireNonNull; | ||
|
||
import java.time.LocalDateTime; | ||
import java.util.Iterator; | ||
import java.util.List; | ||
|
||
import seedu.address.commons.core.index.Index; | ||
import seedu.address.commons.util.ToStringBuilder; | ||
import seedu.address.logic.Messages; | ||
import seedu.address.logic.commands.exceptions.CommandException; | ||
import seedu.address.model.Model; | ||
import seedu.address.model.meeting.Attendee; | ||
import seedu.address.model.meeting.Meeting; | ||
import seedu.address.model.meeting.MeetingStatus; | ||
import seedu.address.model.person.Person; | ||
|
||
/** | ||
* Marks a meeting as complete. | ||
*/ | ||
public class MarkMeetingCommand extends Command { | ||
|
||
public static final String COMMAND_WORD = "mark"; | ||
|
||
public static final String MESSAGE_MARK_MEETING_SUCCESS = "Meeting marked as complete: %1$s"; | ||
|
||
public static final String MESSAGE_MEETING_ALREADY_COMPLETE = "Meeting has already been marked as complete."; | ||
|
||
public static final String MESSAGE_USAGE = COMMAND_WORD | ||
+ ": Marks the meeting identified by the index number used in the displayed meetings list as complete.\n" | ||
+ "Parameters: INDEX (must be a positive integer)\n" + "Example: " + COMMAND_WORD + "1"; | ||
|
||
private final Index targetIndex; | ||
|
||
public MarkMeetingCommand(Index targetIndex) { | ||
this.targetIndex = targetIndex; | ||
} | ||
|
||
@Override | ||
public CommandResult execute(Model model) throws CommandException { | ||
requireNonNull(model); | ||
List<Meeting> lastShownList = model.getFilteredMeetingList(); | ||
|
||
if (targetIndex.getZeroBased() >= lastShownList.size()) { | ||
throw new CommandException(Messages.MESSAGE_INVALID_MEETING_DISPLAYED_INDEX); | ||
} | ||
|
||
Meeting meetingToMark = lastShownList.get(targetIndex.getZeroBased()); | ||
Meeting updatedMeeting = markMeeting(meetingToMark); | ||
model.setMeeting(meetingToMark, updatedMeeting); | ||
|
||
Iterator<Attendee> attendeeIterator = meetingToMark.getAttendees().iterator(); | ||
while (attendeeIterator.hasNext()) { | ||
Attendee attendee = attendeeIterator.next(); | ||
Person person = model.getPerson(attendee.getAttendeeName()); | ||
Person updatedPerson = updateLastContactedTime(person, meetingToMark.getEnd()); | ||
model.setPerson(person, updatedPerson); | ||
} | ||
|
||
return new CommandResult(String.format(MESSAGE_MARK_MEETING_SUCCESS, Messages.format(updatedMeeting))); | ||
} | ||
|
||
static Meeting markMeeting(Meeting meeting) throws CommandException { | ||
if (meeting.getStatus().isComplete) { | ||
throw new CommandException(MESSAGE_MEETING_ALREADY_COMPLETE); | ||
} | ||
|
||
Meeting markedMeeting = new Meeting(meeting.getTitle(), meeting.getLocation(), meeting.getStart(), | ||
meeting.getEnd(), meeting.getAttendees(), meeting.getTags(), new MeetingStatus(true)); | ||
|
||
return markedMeeting; | ||
} | ||
|
||
static Person updateLastContactedTime(Person person, LocalDateTime lastContactedTime) { | ||
if (lastContactedTime.isBefore(person.getLastContactedTime())) { | ||
return person; | ||
} | ||
|
||
Person updatedPerson = new Person(person.getName(), person.getPhone(), person.getEmail(), lastContactedTime, | ||
person.getStatus(), person.getRemark(), person.getTags()); | ||
|
||
return updatedPerson; | ||
} | ||
|
||
@Override | ||
public boolean equals(Object other) { | ||
if (other == this) { | ||
return true; | ||
} | ||
|
||
// instanceof handles nulls | ||
if (!(other instanceof MarkMeetingCommand)) { | ||
return false; | ||
} | ||
|
||
MarkMeetingCommand otherMarkMeetingCommand = (MarkMeetingCommand) other; | ||
return targetIndex.equals(otherMarkMeetingCommand.targetIndex); | ||
} | ||
|
||
@Override | ||
public String toString() { | ||
return new ToStringBuilder(this).add("targetIndex", targetIndex).toString(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
29 changes: 29 additions & 0 deletions
29
src/main/java/seedu/address/logic/parser/MarkMeetingCommandParser.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
package seedu.address.logic.parser; | ||
|
||
import static seedu.address.logic.Messages.MESSAGE_INVALID_COMMAND_FORMAT; | ||
|
||
import seedu.address.commons.core.index.Index; | ||
import seedu.address.logic.commands.MarkMeetingCommand; | ||
import seedu.address.logic.parser.exceptions.ParseException; | ||
|
||
/** | ||
* Parses input arguments and creates a new MarkMeetingCommand object | ||
*/ | ||
public class MarkMeetingCommandParser implements Parser<MarkMeetingCommand> { | ||
|
||
/** | ||
* Parses the given {@code String} of arguments in the context of the MarkMeetingCommand | ||
* and returns a MarkMeetingCommand object for execution. | ||
* @throws ParseException if the user input does not conform the expected format | ||
*/ | ||
public MarkMeetingCommand parse(String args) throws ParseException { | ||
try { | ||
Index index = ParserUtil.parseIndex(args); | ||
return new MarkMeetingCommand(index); | ||
} catch (ParseException pe) { | ||
throw new ParseException( | ||
String.format(MESSAGE_INVALID_COMMAND_FORMAT, MarkMeetingCommand.MESSAGE_USAGE), pe); | ||
} | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.