2020-06-21
only show relevant versions in issue editor
--- a/src/main/java/de/uapcore/lightpit/entities/VersionStatus.java Sun Jun 21 11:43:08 2020 +0200 +++ b/src/main/java/de/uapcore/lightpit/entities/VersionStatus.java Sun Jun 21 11:56:36 2020 +0200 @@ -33,5 +33,9 @@ Unreleased, Released, LTS, - Deprecated + Deprecated; + + public boolean isReleased() { + return ordinal() >= VersionStatus.Released.ordinal(); + } }
--- a/src/main/java/de/uapcore/lightpit/viewmodel/IssueEditView.java Sun Jun 21 11:43:08 2020 +0200 +++ b/src/main/java/de/uapcore/lightpit/viewmodel/IssueEditView.java Sun Jun 21 11:56:36 2020 +0200 @@ -2,6 +2,7 @@ import de.uapcore.lightpit.entities.*; +import java.util.ArrayList; import java.util.Collections; import java.util.List; @@ -9,7 +10,8 @@ private final Issue issue; private List<Project> projects = Collections.emptyList(); - private List<Version> versions = Collections.emptyList(); + private List<Version> versionsUpcoming = new ArrayList<>(); + private List<Version> versionsRecent = new ArrayList<>(); private List<User> users; public IssueEditView(Issue issue) { @@ -28,12 +30,24 @@ this.projects = projects; } - public List<Version> getVersions() { - return versions; + public List<Version> getVersionsUpcoming() { + return versionsUpcoming; + } + + public List<Version> getVersionsRecent() { + return versionsRecent; } public void setVersions(List<Version> versions) { - this.versions = versions; + versionsRecent.clear(); + versionsUpcoming.clear(); + for (var v : versions) { + if (v.getStatus().isReleased()) { + versionsRecent.add(v); + } else { + versionsUpcoming.add(v); + } + } } public List<User> getUsers() {
--- a/src/main/java/de/uapcore/lightpit/viewmodel/ProjectInfo.java Sun Jun 21 11:43:08 2020 +0200 +++ b/src/main/java/de/uapcore/lightpit/viewmodel/ProjectInfo.java Sun Jun 21 11:56:36 2020 +0200 @@ -3,7 +3,6 @@ import de.uapcore.lightpit.entities.IssueSummary; import de.uapcore.lightpit.entities.Project; import de.uapcore.lightpit.entities.Version; -import de.uapcore.lightpit.entities.VersionStatus; import java.util.Collections; import java.util.List; @@ -31,17 +30,19 @@ } public Version getLatestVersion() { + // expects versions to be sorted by status descending for (var v : versions) { - if (v.getStatus().ordinal() >= VersionStatus.Released.ordinal()) + if (v.getStatus().isReleased()) return v; } return null; } public Version getNextVersion() { + // expects versions to be sorted by status descending Version next = null; for (var v : versions) { - if (v.getStatus().ordinal() >= VersionStatus.Released.ordinal()) + if (v.getStatus().isReleased()) break; next = v; }
--- a/src/main/webapp/WEB-INF/jsp/issue-form.jsp Sun Jun 21 11:43:08 2020 +0200 +++ b/src/main/webapp/WEB-INF/jsp/issue-form.jsp Sun Jun 21 11:56:36 2020 +0200 @@ -30,7 +30,6 @@ <jsp:useBean id="viewmodel" type="de.uapcore.lightpit.viewmodel.IssueEditView" scope="request"/> <c:set var="issue" scope="page" value="${viewmodel.issue}" /> -<c:set var="versions" value="${viewmodel.versions}" /> <form action="./projects/issues/commit" method="post"> <table class="formtable"> @@ -115,6 +114,7 @@ <th class="vtop"><fmt:message key="issue.affected-versions"/></th> <td> <c:set var="fieldname" value="affected"/> + <c:set var="selectionList" value="${viewmodel.versionsRecent}"/> <c:set var="data" value="${issue.affectedVersions}" /> <%@include file="../jspf/version-list.jsp"%> </td> @@ -123,6 +123,7 @@ <th class="vtop"><fmt:message key="issue.resolved-versions"/></th> <td> <c:set var="fieldname" value="resolved"/> + <c:set var="selectionList" value="${viewmodel.versionsUpcoming}"/> <c:set var="data" value="${issue.resolvedVersions}" /> <%@include file="../jspf/version-list.jsp"%> </td>
--- a/src/main/webapp/WEB-INF/jspf/version-list.jsp Sun Jun 21 11:43:08 2020 +0200 +++ b/src/main/webapp/WEB-INF/jspf/version-list.jsp Sun Jun 21 11:56:36 2020 +0200 @@ -1,13 +1,13 @@ <%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %> <select name="${fieldname}" multiple> - <c:forEach var="version" items="${versions}"> - <option value="${version.id}" + <c:forEach var="vselitem" items="${selectionList}"> + <option value="${vselitem.id}" <c:forEach var="v" items="${data}"> - <c:if test="${v eq version}">selected</c:if> + <c:if test="${v eq vselitem}">selected</c:if> </c:forEach> > - <c:out value="${version.name}" /> + <c:out value="${vselitem.name}" /> </option> </c:forEach> </select>