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>
Šī revīzija ir iekļauta:
vecāks
141f1c3eb6
revīzija
c6078b8b00
3
cgit.c
3
cgit.c
@ -65,6 +65,8 @@ void config_cb(const char *name, const char *value)
|
|||||||
ctx.cfg.max_msg_len = atoi(value);
|
ctx.cfg.max_msg_len = atoi(value);
|
||||||
else if (!strcmp(name, "max-repodesc-length"))
|
else if (!strcmp(name, "max-repodesc-length"))
|
||||||
ctx.cfg.max_repodesc_len = atoi(value);
|
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"))
|
else if (!strcmp(name, "max-commit-count"))
|
||||||
ctx.cfg.max_commit_count = atoi(value);
|
ctx.cfg.max_commit_count = atoi(value);
|
||||||
else if (!strcmp(name, "summary-log"))
|
else if (!strcmp(name, "summary-log"))
|
||||||
@ -159,6 +161,7 @@ static void prepare_context(struct cgit_context *ctx)
|
|||||||
ctx->cfg.cache_static_ttl = -1;
|
ctx->cfg.cache_static_ttl = -1;
|
||||||
ctx->cfg.css = "/cgit.css";
|
ctx->cfg.css = "/cgit.css";
|
||||||
ctx->cfg.logo = "/git-logo.png";
|
ctx->cfg.logo = "/git-logo.png";
|
||||||
|
ctx->cfg.max_repo_count = 50;
|
||||||
ctx->cfg.max_commit_count = 50;
|
ctx->cfg.max_commit_count = 50;
|
||||||
ctx->cfg.max_lock_attempts = 5;
|
ctx->cfg.max_lock_attempts = 5;
|
||||||
ctx->cfg.max_msg_len = 60;
|
ctx->cfg.max_msg_len = 60;
|
||||||
|
10
cgit.css
10
cgit.css
@ -413,6 +413,16 @@ table.list td.sublevel-repo {
|
|||||||
padding-left: 1.5em;
|
padding-left: 1.5em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
div.pager {
|
||||||
|
text-align: center;
|
||||||
|
margin: 1em 0em 0em 0em;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.pager a {
|
||||||
|
color: #777;
|
||||||
|
margin: 0em 0.5em;
|
||||||
|
}
|
||||||
|
|
||||||
span.age-mins {
|
span.age-mins {
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
color: #080;
|
color: #080;
|
||||||
|
1
cgit.h
1
cgit.h
@ -145,6 +145,7 @@ struct cgit_config {
|
|||||||
int enable_index_links;
|
int enable_index_links;
|
||||||
int enable_log_filecount;
|
int enable_log_filecount;
|
||||||
int enable_log_linecount;
|
int enable_log_linecount;
|
||||||
|
int max_repo_count;
|
||||||
int max_commit_count;
|
int max_commit_count;
|
||||||
int max_lock_attempts;
|
int max_lock_attempts;
|
||||||
int max_msg_len;
|
int max_msg_len;
|
||||||
|
@ -71,6 +71,17 @@ void print_header(int columns)
|
|||||||
html("</tr>\n");
|
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()
|
void cgit_print_repolist()
|
||||||
{
|
{
|
||||||
int i, columns = 4, hits = 0, header = 0;
|
int i, columns = 4, hits = 0, header = 0;
|
||||||
@ -92,9 +103,13 @@ void cgit_print_repolist()
|
|||||||
ctx.repo = &cgit_repolist.repos[i];
|
ctx.repo = &cgit_repolist.repos[i];
|
||||||
if (!is_match(ctx.repo))
|
if (!is_match(ctx.repo))
|
||||||
continue;
|
continue;
|
||||||
|
hits++;
|
||||||
|
if (hits <= ctx.qry.ofs)
|
||||||
|
continue;
|
||||||
|
if (hits > ctx.qry.ofs + ctx.cfg.max_repo_count)
|
||||||
|
continue;
|
||||||
if (!header++)
|
if (!header++)
|
||||||
print_header(columns);
|
print_header(columns);
|
||||||
hits++;
|
|
||||||
if ((last_group == NULL && ctx.repo->group != NULL) ||
|
if ((last_group == NULL && ctx.repo->group != NULL) ||
|
||||||
(last_group != NULL && ctx.repo->group == NULL) ||
|
(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>");
|
html("</table>");
|
||||||
if (!hits)
|
if (!hits)
|
||||||
cgit_print_error("No repositories found");
|
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();
|
cgit_print_docend();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Notiek ielāde…
Atsaukties uz šo jaunā problēmā
Block a user