From 06ae63123c94038b90153f4847de2c57c0193db8 Mon Sep 17 00:00:00 2001 From: Rafael Cavazin <rafaelcavazin@gmail.com> Date: Sun, 27 Jan 2013 09:46:50 -0500 Subject: [PATCH] updating current development --- src/com/gitblit/wicket/panels/RepositoriesPanel.java | 53 ++++++++++++++++++++++++++++++++++------------------- 1 files changed, 34 insertions(+), 19 deletions(-) diff --git a/src/com/gitblit/wicket/panels/RepositoriesPanel.java b/src/com/gitblit/wicket/panels/RepositoriesPanel.java index d3b8ddb..726af61 100644 --- a/src/com/gitblit/wicket/panels/RepositoriesPanel.java +++ b/src/com/gitblit/wicket/panels/RepositoriesPanel.java @@ -49,6 +49,7 @@ import com.gitblit.models.ProjectModel; import com.gitblit.models.RepositoryModel; import com.gitblit.models.UserModel; +import com.gitblit.utils.ArrayUtils; import com.gitblit.utils.StringUtils; import com.gitblit.wicket.GitBlitWebSession; import com.gitblit.wicket.WicketUtils; @@ -123,22 +124,18 @@ if (rootRepositories.size() > 0) { // inject the root repositories at the top of the page - String rootPath = GitBlit.getString(Keys.web.repositoryRootGroupName, " "); - roots.add(0, rootPath); - groups.put(rootPath, rootRepositories); + roots.add(0, ""); + groups.put("", rootRepositories); } - Map<String, ProjectModel> projects = new HashMap<String, ProjectModel>(); - for (ProjectModel project : GitBlit.self().getProjectModels(user, true)) { - projects.put(project.name, project); - } List<RepositoryModel> groupedModels = new ArrayList<RepositoryModel>(); for (String root : roots) { List<RepositoryModel> subModels = groups.get(root); - GroupRepositoryModel group = new GroupRepositoryModel(root, subModels.size()); - if (projects.containsKey(root)) { - group.title = projects.get(root).title; - group.description = projects.get(root).description; + ProjectModel project = GitBlit.self().getProjectModel(root); + GroupRepositoryModel group = new GroupRepositoryModel(project.name, subModels.size()); + if (project != null) { + group.title = project.title; + group.description = project.description; } groupedModels.add(group); Collections.sort(subModels); @@ -237,6 +234,13 @@ .setEscapeModelStrings(false)); } + if (entry.isSparkleshared()) { + row.add(WicketUtils.newImage("sparkleshareIcon", "star_16x16.png", + getString("gb.isSparkleshared"))); + } else { + row.add(WicketUtils.newClearPixel("sparkleshareIcon").setVisible(false)); + } + if (entry.isFork()) { row.add(WicketUtils.newImage("forkIcon", "commit_divide_16x16.png", getString("gb.isFork"))); @@ -291,14 +295,23 @@ row.add(WicketUtils.newBlankImage("accessRestrictionIcon")); } - String owner = entry.owner; - if (!StringUtils.isEmpty(owner)) { - UserModel ownerModel = GitBlit.self().getUserModel(owner); - if (ownerModel != null) { - owner = ownerModel.getDisplayName(); + String owner = ""; + if (!ArrayUtils.isEmpty(entry.owners)) { + // display first owner + for (String username : entry.owners) { + UserModel ownerModel = GitBlit.self().getUserModel(username); + if (ownerModel != null) { + owner = ownerModel.getDisplayName(); + break; + } + } + if (entry.owners.size() > 1) { + owner += ", ..."; } } - row.add(new Label("repositoryOwner", owner)); + Label ownerLabel = new Label("repositoryOwner", owner); + WicketUtils.setHtmlTooltip(ownerLabel, ArrayUtils.toString(entry.owners)); + row.add(ownerLabel); String lastChange; if (entry.lastChange.getTime() == 0) { @@ -519,10 +532,12 @@ Collections.sort(list, new Comparator<RepositoryModel>() { @Override public int compare(RepositoryModel o1, RepositoryModel o2) { + String own1 = ArrayUtils.toString(o1.owners); + String own2 = ArrayUtils.toString(o2.owners); if (asc) { - return o1.owner.compareTo(o2.owner); + return own1.compareTo(own2); } - return o2.owner.compareTo(o1.owner); + return own2.compareTo(own1); } }); } else if (prop.equals(SortBy.description.name())) { -- Gitblit v1.9.1