package scrum.client.project; import scrum.client.common.TooltipBuilder; public class CloseRequirementAction extends GCloseRequirementAction { public CloseRequirementAction(scrum.client.project.Requirement requirement) { super(requirement); } @Override public String getLabel() { return "Accept"; } @Override public String getTooltip() { TooltipBuilder tb = new TooltipBuilder("Accept this Story as done."); if (!getCurrentProject().isProductOwner(getCurrentUser())) { tb.addRemark(TooltipBuilder.NOT_PRODUCT_OWNER); } else { if (requirement.isClosed()) tb.addRemark("Story is already closed."); if (!requirement.getTasks().isEmpty() && !requirement.isTasksClosed()) tb.addRemark("Requirement contains unclosed tasks."); } return tb.getTooltip(); } @Override public boolean isPermitted() { if (!getCurrentProject().isProductOwner(getCurrentUser())) return false; if (!requirement.isTasksClosed()) return false; return true; } @Override public boolean isExecutable() { if (requirement.isClosed()) return false; if (!requirement.isInCurrentSprint()) return false; return true; } @Override protected void onExecute() { requirement.setClosed(true); addUndo(new Undo()); } class Undo extends ALocalUndo { @Override public String getLabel() { return "Undo Close " + requirement.getReferenceAndLabel(); } @Override protected void onUndo() { requirement.setClosed(false); } } }