# HG changeset patch # User Mike Becker # Date 1602763309 -7200 # Node ID a09d5c59351a11d4035352f4b6dc95350ff443b8 # Parent 947d0f6a6a838526a2cdb304109f44667556eb56 add components to navmenu diff -r 947d0f6a6a83 -r a09d5c59351a src/main/java/de/uapcore/lightpit/modules/ProjectsModule.java --- a/src/main/java/de/uapcore/lightpit/modules/ProjectsModule.java Thu Oct 15 13:31:52 2020 +0200 +++ b/src/main/java/de/uapcore/lightpit/modules/ProjectsModule.java Thu Oct 15 14:01:49 2020 +0200 @@ -60,8 +60,10 @@ private static final String SESSION_ATTR_SELECTED_PROJECT = fqn(ProjectsModule.class, "selected_project"); private static final String SESSION_ATTR_SELECTED_VERSION = fqn(ProjectsModule.class, "selected_version"); + private static final String SESSION_ATTR_SELECTED_COMPONENT = fqn(ProjectsModule.class, "selected_component"); private static final String PARAMETER_SELECTED_PROJECT = "pid"; private static final String PARAMETER_SELECTED_VERSION = "vid"; + private static final String PARAMETER_SELECTED_COMPONENT = "cid"; @Override protected String getResourceBundleName() { @@ -84,6 +86,7 @@ private void populate(ProjectView viewModel, HttpServletRequest req, DataAccessObjects dao) throws SQLException { final var projectDao = dao.getProjectDao(); final var versionDao = dao.getVersionDao(); + final var componentDao = dao.getComponentDao(); projectDao.list().stream().map(ProjectInfo::new).forEach(viewModel.getProjectList()::add); @@ -96,6 +99,7 @@ } else { final var info = new ProjectInfo(project); info.setVersions(versionDao.list(project)); + info.setComponents(componentDao.list(project)); info.setIssueSummary(projectDao.getIssueSummary(project)); viewModel.setProjectInfo(info); } @@ -103,8 +107,20 @@ // Select Version final int vid = syncParamWithSession(req, PARAMETER_SELECTED_VERSION, SESSION_ATTR_SELECTED_VERSION); - if (vid >= 0) { + if (vid > 0) { viewModel.setVersionFilter(versionDao.find(vid)); + } else { + // NULL for version means: show all unassigned + viewModel.setVersionFilter(null); + } + + // Select Component + final int cid = syncParamWithSession(req, PARAMETER_SELECTED_COMPONENT, SESSION_ATTR_SELECTED_COMPONENT); + if (cid > 0) { + viewModel.setComponentFilter(componentDao.find(cid)); + } else if (cid <= 0) { + // -1 means: filter for unassigned, null means: show all + viewModel.setComponentFilter(new Component(-1)); } } diff -r 947d0f6a6a83 -r a09d5c59351a src/main/java/de/uapcore/lightpit/viewmodel/ProjectInfo.java --- a/src/main/java/de/uapcore/lightpit/viewmodel/ProjectInfo.java Thu Oct 15 13:31:52 2020 +0200 +++ b/src/main/java/de/uapcore/lightpit/viewmodel/ProjectInfo.java Thu Oct 15 14:01:49 2020 +0200 @@ -1,5 +1,6 @@ package de.uapcore.lightpit.viewmodel; +import de.uapcore.lightpit.entities.Component; import de.uapcore.lightpit.entities.IssueSummary; import de.uapcore.lightpit.entities.Project; import de.uapcore.lightpit.entities.Version; @@ -11,6 +12,7 @@ private final Project project; private List versions = Collections.emptyList(); + private List components = Collections.emptyList(); private IssueSummary issueSummary = new IssueSummary(); public ProjectInfo(Project project) { @@ -29,6 +31,14 @@ this.versions = versions; } + public List getComponents() { + return components; + } + + public void setComponents(List components) { + this.components = components; + } + public Version getLatestVersion() { // expects versions to be sorted by status descending for (var v : versions) { diff -r 947d0f6a6a83 -r a09d5c59351a src/main/java/de/uapcore/lightpit/viewmodel/ProjectView.java --- a/src/main/java/de/uapcore/lightpit/viewmodel/ProjectView.java Thu Oct 15 13:31:52 2020 +0200 +++ b/src/main/java/de/uapcore/lightpit/viewmodel/ProjectView.java Thu Oct 15 14:01:49 2020 +0200 @@ -1,5 +1,6 @@ package de.uapcore.lightpit.viewmodel; +import de.uapcore.lightpit.entities.Component; import de.uapcore.lightpit.entities.Version; import java.util.ArrayList; @@ -10,6 +11,7 @@ private final List projectList = new ArrayList<>(); private ProjectInfo projectInfo; private Version versionFilter; + private Component componentFilter; public List getProjectList() { return projectList; @@ -30,4 +32,12 @@ public void setVersionFilter(Version versionFilter) { this.versionFilter = versionFilter; } + + public Component getComponentFilter() { + return componentFilter; + } + + public void setComponentFilter(Component componentFilter) { + this.componentFilter = componentFilter; + } } diff -r 947d0f6a6a83 -r a09d5c59351a src/main/resources/localization/projects.properties --- a/src/main/resources/localization/projects.properties Thu Oct 15 13:31:52 2020 +0200 +++ b/src/main/resources/localization/projects.properties Thu Oct 15 14:01:49 2020 +0200 @@ -32,9 +32,10 @@ no-projects=Welcome to LightPIT. Start off by creating a new project! -menu.versions=Versions -menu.versions.unassigned=unassigned -menu.issues=Issues +navmenu.versions=Versions +navmenu.components=Components +navmenu.unassigned=unassigned +navmenu.all=all name=Name description=Description diff -r 947d0f6a6a83 -r a09d5c59351a src/main/resources/localization/projects_de.properties --- a/src/main/resources/localization/projects_de.properties Thu Oct 15 13:31:52 2020 +0200 +++ b/src/main/resources/localization/projects_de.properties Thu Oct 15 14:01:49 2020 +0200 @@ -32,9 +32,10 @@ no-projects=Wilkommen bei LightPIT. Beginnen Sie mit der Erstellung eines Projektes! -menu.versions=Versionen -menu.versions.unassigned=Nicht Zugewiesen -menu.issues=Vorg\u00e4nge +navmenu.versions=Versionen +navmenu.components=Komponenten +navmenu.unassigned=Nicht Zugewiesen +navmenu.all=Alle name=Name description=Beschreibung diff -r 947d0f6a6a83 -r a09d5c59351a src/main/webapp/WEB-INF/jsp/project-navmenu.jsp --- a/src/main/webapp/WEB-INF/jsp/project-navmenu.jsp Thu Oct 15 13:31:52 2020 +0200 +++ b/src/main/webapp/WEB-INF/jsp/project-navmenu.jsp Thu Oct 15 14:01:49 2020 +0200 @@ -38,26 +38,54 @@ + + + + + + + + + diff -r 947d0f6a6a83 -r a09d5c59351a src/main/webapp/projects.css --- a/src/main/webapp/projects.css Thu Oct 15 13:31:52 2020 +0200 +++ b/src/main/webapp/projects.css Thu Oct 15 14:01:49 2020 +0200 @@ -109,7 +109,7 @@ background: green; } -div.version-icon { +div.navmenu-icon { display: inline-block; width: .5em; height: .5em;