simplifies version overviews by removing "scheduled issues"

2020-06-21

author
Mike Becker <universe@uap-core.de>
date
Sun, 21 Jun 2020 11:38:16 +0200 (2020-06-21)
changeset 88
1438e5a22c55
parent 87
501addad452b
child 89
c69d5cb11d6c

simplifies version overviews by removing "scheduled issues"

setup/postgres/psql_create_tables.sql file | annotate | diff | comparison | revisions
src/main/java/de/uapcore/lightpit/dao/postgres/PGIssueDao.java file | annotate | diff | comparison | revisions
src/main/java/de/uapcore/lightpit/entities/Issue.java file | annotate | diff | comparison | revisions
src/main/java/de/uapcore/lightpit/modules/ProjectsModule.java file | annotate | diff | comparison | revisions
src/main/java/de/uapcore/lightpit/viewmodel/ProjectView.java file | annotate | diff | comparison | revisions
src/main/java/de/uapcore/lightpit/viewmodel/VersionInfo.java file | annotate | diff | comparison | revisions
src/main/resources/localization/projects.properties file | annotate | diff | comparison | revisions
src/main/resources/localization/projects_de.properties file | annotate | diff | comparison | revisions
src/main/webapp/WEB-INF/jsp/issue-form.jsp file | annotate | diff | comparison | revisions
src/main/webapp/WEB-INF/jsp/project-details.jsp file | annotate | diff | comparison | revisions
src/main/webapp/WEB-INF/jsp/version.jsp file | annotate | diff | comparison | revisions
--- a/setup/postgres/psql_create_tables.sql	Sun Jun 21 11:10:30 2020 +0200
+++ b/setup/postgres/psql_create_tables.sql	Sun Jun 21 11:38:16 2020 +0200
@@ -77,12 +77,6 @@
     primary key (issueid, versionid)
 );
 
-create table lpit_issue_scheduled_version (
-    issueid         integer         references lpit_issue(issueid),
-    versionid       integer         references lpit_version(versionid),
-    primary key (issueid, versionid)
-);
-
 create table lpit_issue_resolved_version (
     issueid         integer         references lpit_issue(issueid),
     versionid       integer         references lpit_version(versionid),
--- a/src/main/java/de/uapcore/lightpit/dao/postgres/PGIssueDao.java	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/java/de/uapcore/lightpit/dao/postgres/PGIssueDao.java	Sun Jun 21 11:38:16 2020 +0200
@@ -44,9 +44,9 @@
 public final class PGIssueDao implements IssueDao {
 
     private final PreparedStatement insert, update, list, listForVersion, find;
-    private final PreparedStatement affectedVersions, scheduledVersions, resolvedVersions;
-    private final PreparedStatement clearAffected, clearScheduled, clearResolved;
-    private final PreparedStatement insertAffected, insertScheduled, insertResolved;
+    private final PreparedStatement affectedVersions, resolvedVersions;
+    private final PreparedStatement clearAffected, clearResolved;
+    private final PreparedStatement insertAffected, insertResolved;
 
     public PGIssueDao(Connection connection) throws SQLException {
         list = connection.prepareStatement(
@@ -62,7 +62,6 @@
         listForVersion = connection.prepareStatement(
                 "with issue_version as ( "+
                         "select issueid, versionid from lpit_issue_affected_version union "+
-                        "select issueid, versionid from lpit_issue_scheduled_version union "+
                         "select issueid, versionid from lpit_issue_resolved_version) "+
                         "select issueid, project, p.name as projectname, status, category, subject, i.description, " +
                         "userid, username, givenname, lastname, mail, " +
@@ -102,15 +101,6 @@
         clearAffected = connection.prepareStatement("delete from lpit_issue_affected_version where issueid = ?");
         insertAffected = connection.prepareStatement("insert into lpit_issue_affected_version (issueid, versionid) values (?,?)");
 
-        scheduledVersions = connection.prepareStatement(
-                "select versionid, name, status, ordinal " +
-                        "from lpit_version join lpit_issue_scheduled_version using (versionid) " +
-                        "where issueid = ? " +
-                        "order by ordinal, name"
-        );
-        clearScheduled = connection.prepareStatement("delete from lpit_issue_scheduled_version where issueid = ?");
-        insertScheduled = connection.prepareStatement("insert into lpit_issue_scheduled_version (issueid, versionid) values (?,?)");
-
         resolvedVersions = connection.prepareStatement(
                 "select versionid, name, status, ordinal " +
                         "from lpit_version v join lpit_issue_resolved_version using (versionid) " +
@@ -161,22 +151,15 @@
 
     private void updateVersionLists(Issue instance) throws SQLException {
         clearAffected.setInt(1, instance.getId());
-        clearScheduled.setInt(1, instance.getId());
         clearResolved.setInt(1, instance.getId());
         insertAffected.setInt(1, instance.getId());
-        insertScheduled.setInt(1, instance.getId());
         insertResolved.setInt(1, instance.getId());
         clearAffected.executeUpdate();
-        clearScheduled.executeUpdate();
         clearResolved.executeUpdate();
         for (Version v : instance.getAffectedVersions()) {
             insertAffected.setInt(2, v.getId());
             insertAffected.executeUpdate();
         }
-        for (Version v : instance.getScheduledVersions()) {
-            insertScheduled.setInt(2, v.getId());
-            insertScheduled.executeUpdate();
-        }
         for (Version v : instance.getResolvedVersions()) {
             insertResolved.setInt(2, v.getId());
             insertResolved.executeUpdate();
@@ -269,7 +252,6 @@
     public void joinVersionInformation(Issue issue) throws SQLException {
         Objects.requireNonNull(issue.getProject());
         issue.setAffectedVersions(listVersions(affectedVersions, issue));
-        issue.setScheduledVersions(listVersions(scheduledVersions, issue));
         issue.setResolvedVersions(listVersions(resolvedVersions, issue));
     }
 }
--- a/src/main/java/de/uapcore/lightpit/entities/Issue.java	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/java/de/uapcore/lightpit/entities/Issue.java	Sun Jun 21 11:38:16 2020 +0200
@@ -48,7 +48,6 @@
     private User assignee;
 
     private List<Version> affectedVersions = Collections.emptyList();
-    private List<Version> scheduledVersions = Collections.emptyList();
     private List<Version> resolvedVersions = Collections.emptyList();
 
     private Timestamp created = Timestamp.from(Instant.now());
@@ -131,14 +130,6 @@
         this.affectedVersions = affectedVersions;
     }
 
-    public List<Version> getScheduledVersions() {
-        return scheduledVersions;
-    }
-
-    public void setScheduledVersions(List<Version> scheduledVersions) {
-        this.scheduledVersions = scheduledVersions;
-    }
-
     public List<Version> getResolvedVersions() {
         return resolvedVersions;
     }
--- a/src/main/java/de/uapcore/lightpit/modules/ProjectsModule.java	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/java/de/uapcore/lightpit/modules/ProjectsModule.java	Sun Jun 21 11:38:16 2020 +0200
@@ -127,7 +127,7 @@
             }
             // our object contains more details
             issue.setProject(project);
-            if (!issue.getResolvedVersions().contains(version) && !issue.getScheduledVersions().contains(version)
+            if (!issue.getResolvedVersions().contains(version)
                     && !issue.getAffectedVersions().contains(version)) {
                 version = null;
             }
@@ -536,11 +536,6 @@
                     .map(stream ->
                         stream.map(Version::new).collect(Collectors.toList())
                     ).ifPresent(issue::setAffectedVersions);
-            getParameter(req, Integer[].class, "scheduled")
-                    .map(Stream::of)
-                    .map(stream ->
-                            stream.map(Version::new).collect(Collectors.toList())
-                    ).ifPresent(issue::setScheduledVersions);
             getParameter(req, Integer[].class, "resolved")
                     .map(Stream::of)
                     .map(stream ->
--- a/src/main/java/de/uapcore/lightpit/viewmodel/ProjectView.java	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/java/de/uapcore/lightpit/viewmodel/ProjectView.java	Sun Jun 21 11:38:16 2020 +0200
@@ -39,7 +39,8 @@
         issuesWithoutVersionTotal = new IssueSummary();
         for (Issue issue : issues) {
             issuesTotal.add(issue);
-            if (issue.getResolvedVersions().isEmpty() && issue.getScheduledVersions().isEmpty() && issue.getResolvedVersions().isEmpty()) {
+            // we want to list all issues that do not have a target version
+            if (issue.getResolvedVersions().isEmpty()) {
                 issuesWithoutVersion.add(issue);
                 issuesWithoutVersionTotal.add(issue);
             }
--- a/src/main/java/de/uapcore/lightpit/viewmodel/VersionInfo.java	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/java/de/uapcore/lightpit/viewmodel/VersionInfo.java	Sun Jun 21 11:38:16 2020 +0200
@@ -12,11 +12,9 @@
     private final Version version;
 
     private final IssueSummary reportedTotal = new IssueSummary();
-    private final IssueSummary scheduledTotal = new IssueSummary();
     private final IssueSummary resolvedTotal = new IssueSummary();
 
     private final List<Issue> reported = new ArrayList<>();
-    private final List<Issue> scheduled = new ArrayList<>();
     private final List<Issue> resolved = new ArrayList<>();
 
     public VersionInfo(Version version) {
@@ -32,11 +30,6 @@
         reported.add(issue);
     }
 
-    public void addScheduled(Issue issue) {
-        scheduledTotal.add(issue);
-        scheduled.add(issue);
-    }
-
     public void addResolved(Issue issue) {
         resolvedTotal.add(issue);
         resolved.add(issue);
@@ -46,10 +39,6 @@
         return reportedTotal;
     }
 
-    public IssueSummary getScheduledTotal() {
-        return scheduledTotal;
-    }
-
     public IssueSummary getResolvedTotal() {
         return resolvedTotal;
     }
@@ -58,10 +47,6 @@
         return reported;
     }
 
-    public List<Issue> getScheduled() {
-        return scheduled;
-    }
-
     public List<Issue> getResolved() {
         return resolved;
     }
@@ -71,9 +56,6 @@
             if (issue.getAffectedVersions().contains(version)) {
                 addReported(issue);
             }
-            if (issue.getScheduledVersions().contains(version)) {
-                addScheduled(issue);
-            }
             if (issue.getResolvedVersions().contains(version)) {
                 addResolved(issue);
             }
--- a/src/main/resources/localization/projects.properties	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/resources/localization/projects.properties	Sun Jun 21 11:38:16 2020 +0200
@@ -28,9 +28,6 @@
 button.issue.create=New Issue
 button.issue.all=All Issues
 
-button.stats.hidezeros=Reduced View
-button.stats.showzeros=Full View
-
 no-projects=Welcome to LightPIT. Start off by creating a new project!
 
 menu.issues=Issues
@@ -49,8 +46,7 @@
 issues.done=Done
 issues.total=Total
 issues.reported=Reported Issues
-issues.scheduled=Scheduled Issues
-issues.resolved=Resolved Issues
+issues.resolved=Issues
 
 version.project=Project
 version.name=Version
@@ -61,6 +57,7 @@
 placeholder.null-owner=Unassigned
 placeholder.null-assignee=Unassigned
 
+version.open=open
 version.label=Version
 version.status.Future=Future
 version.status.Unreleased=Unreleased
@@ -75,8 +72,7 @@
 issue.description=Description
 issue.assignee=Assignee
 issue.affected-versions=Affected Versions
-issue.scheduled-versions=Scheduled for Versions
-issue.resolved-versions=Resolved in Versions
+issue.resolved-versions=Target Versions
 issue.category=Category
 issue.status=Status
 issue.created=Created
--- a/src/main/resources/localization/projects_de.properties	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/resources/localization/projects_de.properties	Sun Jun 21 11:38:16 2020 +0200
@@ -28,9 +28,6 @@
 button.issue.create=Neuer Vorgang
 button.issue.all=Alle Vorg\u00e4nge
 
-button.stats.hidezeros=Reduzierte Ansicht
-button.stats.showzeros=Komplettansicht
-
 no-projects=Wilkommen bei LightPIT. Beginnen Sie mit der Erstellung eines Projektes!
 
 menu.issues=Vorg\u00e4nge
@@ -48,8 +45,7 @@
 issues.active=In Arbeit
 issues.done=Erledigt
 issues.reported=Er\u00f6ffnete Vorg\u00e4nge
-issues.scheduled=Geplante Vorg\u00e4nge 
-issues.resolved=Gel\u00f6ste Vorg\u00e4nge
+issues.resolved=Vorg\u00e4nge
 issues.total=Summe
 
 version.project=Projekt
@@ -61,6 +57,7 @@
 placeholder.null-owner=Nicht Zugewiesen
 placeholder.null-assignee=Niemandem
 
+version.open=ansehen
 version.label=Version
 version.status.Future=Geplant
 version.status.Unreleased=Unver\u00f6ffentlicht
@@ -74,8 +71,7 @@
 issue.description=Beschreibung
 issue.assignee=Zugewiesen
 issue.affected-versions=Betroffene Versionen
-issue.scheduled-versions=Zielversionen
-issue.resolved-versions=Gel\u00f6st in Versionen
+issue.resolved-versions=Zielversionen
 issue.category=Kategorie
 issue.status=Status
 issue.created=Erstellt
--- a/src/main/webapp/WEB-INF/jsp/issue-form.jsp	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/webapp/WEB-INF/jsp/issue-form.jsp	Sun Jun 21 11:38:16 2020 +0200
@@ -120,14 +120,6 @@
             </td>
         </tr>
         <tr>
-            <th class="vtop"><fmt:message key="issue.scheduled-versions"/></th>
-            <td>
-                <c:set var="fieldname" value="scheduled"/>
-                <c:set var="data" value="${issue.scheduledVersions}" />
-                <%@include file="../jspf/version-list.jsp"%>
-            </td>
-        </tr>
-        <tr>
             <th class="vtop"><fmt:message key="issue.resolved-versions"/></th>
             <td>
                 <c:set var="fieldname" value="resolved"/>
--- a/src/main/webapp/WEB-INF/jsp/project-details.jsp	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/webapp/WEB-INF/jsp/project-details.jsp	Sun Jun 21 11:38:16 2020 +0200
@@ -53,21 +53,14 @@
 <c:forEach var="versionInfo" items="${viewmodel.versionInfos}">
     <h2>
         <fmt:message key="version.label" /> <c:out value="${versionInfo.version.name}" /> - <fmt:message key="version.status.${versionInfo.version.status}"/>
-        (<a href="./projects/versions/view?vid=${versionInfo.version.id}">open</a>)
+        (<a href="./projects/versions/view?vid=${versionInfo.version.id}"><fmt:message key="version.open" /></a>)
     </h2>
 
-    <h3><fmt:message key="issues.reported"/> </h3>
-    <c:set var="summary" value="${versionInfo.reportedTotal}"/>
-    <c:set var="issues" value="${versionInfo.reported}"/>
-    <%@include file="../jspf/issue-summary.jsp"%>
-
-    <h3><fmt:message key="issues.scheduled"/> </h3>
-    <c:set var="summary" value="${versionInfo.scheduledTotal}"/>
-    <c:set var="issues" value="${versionInfo.scheduled}"/>
-    <%@include file="../jspf/issue-summary.jsp"%>
-
     <h3><fmt:message key="issues.resolved"/> </h3>
     <c:set var="summary" value="${versionInfo.resolvedTotal}"/>
     <c:set var="issues" value="${versionInfo.resolved}"/>
     <%@include file="../jspf/issue-summary.jsp"%>
+    <c:if test="${not empty issues}">
+    <%@include file="../jspf/issue-list.jsp"%>
+    </c:if>
 </c:forEach>
\ No newline at end of file
--- a/src/main/webapp/WEB-INF/jsp/version.jsp	Sun Jun 21 11:10:30 2020 +0200
+++ b/src/main/webapp/WEB-INF/jsp/version.jsp	Sun Jun 21 11:38:16 2020 +0200
@@ -44,22 +44,19 @@
 <a href="./projects/versions/edit?vid=${version.id}">&#x270e;</a>
 </h2>
 
-<h3><fmt:message key="issues.reported"/> </h3>
-
-<c:set var="summary" value="${viewmodel.versionInfo.reportedTotal}"/>
-<c:set var="issues" value="${viewmodel.versionInfo.reported}"/>
-<%@include file="../jspf/issue-summary.jsp"%>
-<%@include file="../jspf/issue-list.jsp"%>
+<c:if test="${not empty viewmodel.versionInfo.resolved}">
+    <h3><fmt:message key="issues.resolved"/> </h3>
+    <c:set var="summary" value="${viewmodel.versionInfo.resolvedTotal}"/>
+    <c:set var="issues" value="${viewmodel.versionInfo.resolved}"/>
+    <%@include file="../jspf/issue-summary.jsp"%>
+    <%@include file="../jspf/issue-list.jsp"%>
+</c:if>
 
-<h3><fmt:message key="issues.scheduled"/> </h3>
-<c:set var="summary" value="${viewmodel.versionInfo.scheduledTotal}"/>
-<c:set var="issues" value="${viewmodel.versionInfo.scheduled}"/>
-<%@include file="../jspf/issue-summary.jsp"%>
-<%@include file="../jspf/issue-list.jsp"%>
+<c:if test="${not empty viewmodel.versionInfo.reported}">
+    <h3><fmt:message key="issues.reported"/> </h3>
+    <c:set var="summary" value="${viewmodel.versionInfo.reportedTotal}"/>
+    <c:set var="issues" value="${viewmodel.versionInfo.reported}"/>
+    <%@include file="../jspf/issue-summary.jsp"%>
+    <%@include file="../jspf/issue-list.jsp"%>
+</c:if>
 
-<h3><fmt:message key="issues.resolved"/> </h3>
-<c:set var="summary" value="${viewmodel.versionInfo.resolvedTotal}"/>
-<c:set var="issues" value="${viewmodel.versionInfo.resolved}"/>
-<%@include file="../jspf/issue-summary.jsp"%>
-<%@include file="../jspf/issue-list.jsp"%>
-

mercurial