diff options
author | Lars Hjemli <hjemli@gmail.com> | 2008-05-03 08:54:39 +0000 |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-05-03 08:54:39 +0000 |
commit | c6078b8b006bcb0671a3c1bc21dd1a2c01035a2e (patch) | |
tree | 0ca48d3ac455a7aecd30590ed71703ba5b34c4f1 /ui-repolist.c | |
parent | 141f1c3eb657470e81bbf998f44f9723f9009def (diff) | |
download | cgit-c6078b8b006bcb0671a3c1bc21dd1a2c01035a2e.tar cgit-c6078b8b006bcb0671a3c1bc21dd1a2c01035a2e.tar.gz cgit-c6078b8b006bcb0671a3c1bc21dd1a2c01035a2e.zip |
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 (limited to 'ui-repolist.c')
-rw-r--r-- | ui-repolist.c | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/ui-repolist.c b/ui-repolist.c index 3f78e28..ee4facb 100644 --- a/ui-repolist.c +++ b/ui-repolist.c @@ -71,6 +71,17 @@ void print_header(int columns) html("</tr>\n"); } + +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() { int i, columns = 4, hits = 0, header = 0; @@ -92,9 +103,13 @@ void cgit_print_repolist() ctx.repo = &cgit_repolist.repos[i]; 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) || (last_group != NULL && ctx.repo->group != NULL && @@ -134,6 +149,8 @@ void cgit_print_repolist() html("</table>"); 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(); } |