From 13a3f5bc3e2d25fc76850f86070dc34efe60d77a Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Fri, 07 Sep 2012 22:06:15 -0400
Subject: [PATCH] Draft project pages, project metadata, and RSS feeds

---
 src/com/gitblit/wicket/panels/RepositoriesPanel.java |   20 +++++++++++++++++---
 1 files changed, 17 insertions(+), 3 deletions(-)

diff --git a/src/com/gitblit/wicket/panels/RepositoriesPanel.java b/src/com/gitblit/wicket/panels/RepositoriesPanel.java
index 8c8e1e5..a113e00 100644
--- a/src/com/gitblit/wicket/panels/RepositoriesPanel.java
+++ b/src/com/gitblit/wicket/panels/RepositoriesPanel.java
@@ -46,6 +46,7 @@
 import com.gitblit.GitBlit;
 import com.gitblit.Keys;
 import com.gitblit.SyndicationServlet;
+import com.gitblit.models.ProjectModel;
 import com.gitblit.models.RepositoryModel;
 import com.gitblit.models.UserModel;
 import com.gitblit.utils.StringUtils;
@@ -54,6 +55,7 @@
 import com.gitblit.wicket.pages.BasePage;
 import com.gitblit.wicket.pages.EditRepositoryPage;
 import com.gitblit.wicket.pages.EmptyRepositoryPage;
+import com.gitblit.wicket.pages.ProjectPage;
 import com.gitblit.wicket.pages.RepositoriesPage;
 import com.gitblit.wicket.pages.SummaryPage;
 
@@ -112,10 +114,20 @@
 				roots.add(0, rootPath);
 				groups.put(rootPath, rootRepositories);
 			}
+						
+			Map<String, ProjectModel> projects = new HashMap<String, ProjectModel>();
+			for (ProjectModel project : GitBlit.self().getProjectModels(user)) {
+				projects.put(project.name, project);
+			}
 			List<RepositoryModel> groupedModels = new ArrayList<RepositoryModel>();
 			for (String root : roots) {
 				List<RepositoryModel> subModels = groups.get(root);
-				groupedModels.add(new GroupRepositoryModel(root, subModels.size()));
+				GroupRepositoryModel group = new GroupRepositoryModel(root, subModels.size());
+				if (projects.containsKey(root)) {
+					group.title = projects.get(root).title;
+					group.description = projects.get(root).description;
+				}
+				groupedModels.add(group);
 				Collections.sort(subModels);
 				groupedModels.addAll(subModels);
 			}
@@ -144,7 +156,8 @@
 					currGroupName = entry.name;
 					Fragment row = new Fragment("rowContent", "groupRepositoryRow", this);
 					item.add(row);
-					row.add(new Label("groupName", entry.toString()));
+					row.add(new LinkPanel("groupName", null, entry.toString(), ProjectPage.class, WicketUtils.newProjectParameter(entry.name)));
+					row.add(new Label("groupDescription", entry.description == null ? "":entry.description));
 					WicketUtils.setCssClass(item, "group");
 					// reset counter so that first row is light background
 					counter = 0;
@@ -326,6 +339,7 @@
 		private static final long serialVersionUID = 1L;
 
 		int count;
+		String title;
 
 		GroupRepositoryModel(String name, int count) {
 			super(name, "", "", new Date(0));
@@ -334,7 +348,7 @@
 
 		@Override
 		public String toString() {
-			return name + " (" + count + ")";
+			return StringUtils.isEmpty(title) ? name  : title + " (" + count + ")";
 		}
 	}
 

--
Gitblit v1.9.1