diff options
Diffstat (limited to 'src/main/java/com/gitblit/wicket')
3 files changed, 60 insertions, 3 deletions
diff --git a/src/main/java/com/gitblit/wicket/pages/BasePage.html b/src/main/java/com/gitblit/wicket/pages/BasePage.html index 4dbc2e57..49810ddc 100644 --- a/src/main/java/com/gitblit/wicket/pages/BasePage.html +++ b/src/main/java/com/gitblit/wicket/pages/BasePage.html @@ -51,7 +51,8 @@ <!-- Include scripts at end for faster page loading -->
<script type="text/javascript" src="bootstrap/js/jquery.js"></script>
- <script type="text/javascript" src="bootstrap/js/bootstrap.js"></script>
+ <script type="text/javascript" src="bootstrap/js/bootstrap.js"></script>
+ <script type="text/javascript" src="gitblit/js/collapsible-table.js"></script>
<wicket:container wicket:id="bottomScripts"></wicket:container>
</body>
</html>
\ No newline at end of file diff --git a/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.html b/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.html index 2de52b09..7c3b3082 100644 --- a/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.html +++ b/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.html @@ -18,6 +18,9 @@ </tbody>
</table>
+ <wicket:fragment wicket:id="emptyFragment">
+ </wicket:fragment>
+
<wicket:fragment wicket:id="repoIconFragment">
<span class="octicon octicon-centered octicon-repo"></span>
</wicket:fragment>
@@ -72,9 +75,15 @@ </tr>
</wicket:fragment>
+ <wicket:fragment wicket:id="tableAllCollapsible">
+ <i title="Click to expand all" class="fa fa-plus-square-o table-openall-collapsible" aria-hidden="true" style="padding-right:3px;cursor:pointer;"></i>
+ <i title="Click to collapse all" class="fa fa-minus-square-o table-closeall-collapsible" aria-hidden="true" style="padding-right:3px;cursor:pointer;"></i>
+ </wicket:fragment>
+
<wicket:fragment wicket:id="groupRepositoryHeader">
<tr>
<th class="left">
+ <span wicket:id="allCollapsible"></span>
<img style="vertical-align: middle;" src="git-black-16x16.png"/>
<wicket:message key="gb.repository">Repository</wicket:message>
</th>
@@ -86,8 +95,16 @@ </tr>
</wicket:fragment>
+ <wicket:fragment wicket:id="tableGroupMinusCollapsible">
+ <i title="Click to expand/collapse" class="fa fa-minus-square-o table-group-collapsible" aria-hidden="true" style="padding-right:3px;cursor:pointer;"></i>
+ </wicket:fragment>
+
+ <wicket:fragment wicket:id="tableGroupPlusCollapsible">
+ <i title="Click to expand/collapse" class="fa fa-plus-square-o table-group-collapsible" aria-hidden="true" style="padding-right:3px;cursor:pointer;"></i>
+ </wicket:fragment>
+
<wicket:fragment wicket:id="groupRepositoryRow">
- <td colspan="1"><span wicket:id="groupName">[group name]</span></td>
+ <td colspan="1"><span wicket:id="groupCollapsible"></span><span wicket:id="groupName">[group name]</span></td>
<td colspan="6" style="padding: 2px;"><span class="hidden-phone" style="font-weight:normal;color:#666;" wicket:id="groupDescription">[description]</span></td>
</wicket:fragment>
diff --git a/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.java b/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.java index c3f07099..aab602e5 100644 --- a/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.java +++ b/src/main/java/com/gitblit/wicket/panels/RepositoriesPanel.java @@ -58,6 +58,25 @@ import com.gitblit.wicket.pages.UserPage; public class RepositoriesPanel extends BasePanel {
private static final long serialVersionUID = 1L;
+
+ private enum CollapsibleRepositorySetting {
+ DISABLED,
+
+ EXPANDED,
+
+ COLLAPSED;
+
+ public static CollapsibleRepositorySetting get(String name) {
+ CollapsibleRepositorySetting returnVal = CollapsibleRepositorySetting.DISABLED;
+ for (CollapsibleRepositorySetting setting : values()) {
+ if (setting.name().equalsIgnoreCase(name)) {
+ returnVal = setting;
+ break;
+ }
+ }
+ return returnVal;
+ }
+ }
public RepositoriesPanel(String wicketId, final boolean showAdmin, final boolean showManagement,
List<RepositoryModel> models, boolean enableLinks,
@@ -66,6 +85,8 @@ public class RepositoriesPanel extends BasePanel { final boolean linksActive = enableLinks;
final boolean showSize = app().settings().getBoolean(Keys.web.showRepositorySizes, true);
+ final String collapsibleRespositorySetting = app().settings().getString(Keys.web.collapsibleRepositoryGroups, null);
+ final CollapsibleRepositorySetting collapsibleRepoGroups = CollapsibleRepositorySetting.get(collapsibleRespositorySetting);
final UserModel user = GitBlitWebSession.get().getUser();
@@ -160,6 +181,16 @@ public class RepositoriesPanel extends BasePanel { GroupRepositoryModel groupRow = (GroupRepositoryModel) entry;
currGroupName = entry.name;
Fragment row = new Fragment("rowContent", "groupRepositoryRow", this);
+ if(collapsibleRepoGroups == CollapsibleRepositorySetting.EXPANDED) {
+ Fragment groupCollapsible = new Fragment("groupCollapsible", "tableGroupMinusCollapsible", this);
+ row.add(groupCollapsible);
+ } else if(collapsibleRepoGroups == CollapsibleRepositorySetting.COLLAPSED) {
+ Fragment groupCollapsible = new Fragment("groupCollapsible", "tableGroupPlusCollapsible", this);
+ row.add(groupCollapsible);
+ } else {
+ Fragment groupCollapsible = new Fragment("groupCollapsible", "emptyFragment", this);
+ row.add(groupCollapsible);
+ }
item.add(row);
String name = groupRow.name;
@@ -174,7 +205,7 @@ public class RepositoriesPanel extends BasePanel { row.add(new LinkPanel("groupName", null, groupRow.toString(), ProjectPage.class, WicketUtils.newProjectParameter(entry.name)));
row.add(new Label("groupDescription", entry.description == null ? "":entry.description));
}
- WicketUtils.setCssClass(item, "group");
+ WicketUtils.setCssClass(item, "group collapsible");
// reset counter so that first row is light background
counter = 0;
return;
@@ -319,6 +350,14 @@ public class RepositoriesPanel extends BasePanel { } else {
// not sortable
Fragment fragment = new Fragment("headerContent", "groupRepositoryHeader", this);
+ if(collapsibleRepoGroups == CollapsibleRepositorySetting.EXPANDED ||
+ collapsibleRepoGroups == CollapsibleRepositorySetting.COLLAPSED) {
+ Fragment allCollapsible = new Fragment("allCollapsible", "tableAllCollapsible", this);
+ fragment.add(allCollapsible);
+ } else {
+ Fragment allCollapsible = new Fragment("allCollapsible", "emptyFragment", this);
+ fragment.add(allCollapsible);
+ }
add(fragment);
}
}
|