summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2008-05-03 08:54:39 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-05-03 08:54:39 (UTC)
commitc6078b8b006bcb0671a3c1bc21dd1a2c01035a2e (patch) (side-by-side diff)
tree0ca48d3ac455a7aecd30590ed71703ba5b34c4f1
parent141f1c3eb657470e81bbf998f44f9723f9009def (diff)
downloadcgit-c6078b8b006bcb0671a3c1bc21dd1a2c01035a2e.zip
cgit-c6078b8b006bcb0671a3c1bc21dd1a2c01035a2e.tar.gz
cgit-c6078b8b006bcb0671a3c1bc21dd1a2c01035a2e.tar.bz2
Add a pager on the repolist
This enables a pager on the repolist which restricts the number of entries displayed per page, controlled by the new option `max-repo-count` (default value 50). Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--cgit.c3
-rw-r--r--cgit.css10
-rw-r--r--cgit.h1
-rw-r--r--ui-repolist.c19
4 files changed, 32 insertions, 1 deletions
diff --git a/cgit.c b/cgit.c
index ccd61f4..2036ceb 100644
--- a/cgit.c
+++ b/cgit.c
@@ -66,4 +66,6 @@ void config_cb(const char *name, const char *value)
else if (!strcmp(name, "max-repodesc-length"))
ctx.cfg.max_repodesc_len = atoi(value);
+ else if (!strcmp(name, "max-repo-count"))
+ ctx.cfg.max_repo_count = atoi(value);
else if (!strcmp(name, "max-commit-count"))
ctx.cfg.max_commit_count = atoi(value);
@@ -160,4 +162,5 @@ static void prepare_context(struct cgit_context *ctx)
ctx->cfg.css = "/cgit.css";
ctx->cfg.logo = "/git-logo.png";
+ ctx->cfg.max_repo_count = 50;
ctx->cfg.max_commit_count = 50;
ctx->cfg.max_lock_attempts = 5;
diff --git a/cgit.css b/cgit.css
index 30cb8e6..d57722c 100644
--- a/cgit.css
+++ b/cgit.css
@@ -414,4 +414,14 @@ table.list td.sublevel-repo {
}
+div.pager {
+ text-align: center;
+ margin: 1em 0em 0em 0em;
+}
+
+div.pager a {
+ color: #777;
+ margin: 0em 0.5em;
+}
+
span.age-mins {
font-weight: bold;
diff --git a/cgit.h b/cgit.h
index bbb404e..4fa5cf2 100644
--- a/cgit.h
+++ b/cgit.h
@@ -146,4 +146,5 @@ struct cgit_config {
int enable_log_filecount;
int enable_log_linecount;
+ int max_repo_count;
int max_commit_count;
int max_lock_attempts;
diff --git a/ui-repolist.c b/ui-repolist.c
index 3f78e28..ee4facb 100644
--- a/ui-repolist.c
+++ b/ui-repolist.c
@@ -72,4 +72,15 @@ void print_header(int columns)
}
+
+void print_pager(int items, int pagelen, char *search)
+{
+ int i;
+ html("<div class='pager'>");
+ for(i = 0; i * pagelen < items; i++)
+ cgit_index_link(fmt("[%d]", i+1), fmt("Page %d", i+1), NULL,
+ search, i * pagelen);
+ html("</div>");
+}
+
void cgit_print_repolist()
{
@@ -93,7 +104,11 @@ void cgit_print_repolist()
if (!is_match(ctx.repo))
continue;
+ hits++;
+ if (hits <= ctx.qry.ofs)
+ continue;
+ if (hits > ctx.qry.ofs + ctx.cfg.max_repo_count)
+ continue;
if (!header++)
print_header(columns);
- hits++;
if ((last_group == NULL && ctx.repo->group != NULL) ||
(last_group != NULL && ctx.repo->group == NULL) ||
@@ -135,4 +150,6 @@ void cgit_print_repolist()
if (!hits)
cgit_print_error("No repositories found");
+ else if (hits > ctx.cfg.max_repo_count)
+ print_pager(hits, ctx.cfg.max_repo_count, ctx.qry.search);
cgit_print_docend();
}