summaryrefslogtreecommitdiffabout
path: root/ui-shared.c
authorLars Hjemli <hjemli@gmail.com>2008-04-28 23:13:08 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-04-28 23:13:08 (UTC)
commit905dbaef5aa33ea11d385b82de0188fee73dd655 (patch) (unidiff)
tree34712da2eef917be04b2acc5585612b65c1e49cc /ui-shared.c
parentd188ed4f2905e6d10abd26c45572a0d48eb53969 (diff)
parent71adba1f1678914063fc109cf3805afde2c68f75 (diff)
downloadcgit-905dbaef5aa33ea11d385b82de0188fee73dd655.zip
cgit-905dbaef5aa33ea11d385b82de0188fee73dd655.tar.gz
cgit-905dbaef5aa33ea11d385b82de0188fee73dd655.tar.bz2
Merge branch 'lh/about'
* lh/about: Add 'about site' and 'about repo' pages Prepare for 'about site' page / add 'root-readme' option to cgitrc Make it possible for a single cmd to work both with and without a repo Re-enable 'index-info' and add support for 'root-desc' in cgitrc Move included header-file out of repolist table Prepare for 'about repo' page
Diffstat (limited to 'ui-shared.c') (more/less context) (ignore whitespace changes)
-rw-r--r--ui-shared.c58
1 files changed, 54 insertions, 4 deletions
diff --git a/ui-shared.c b/ui-shared.c
index 8a804c2..d08ede9 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -109,16 +109,59 @@ char *cgit_currurl()
109 else if (ctx.qry.page) 109 else if (ctx.qry.page)
110 return fmt("%s/%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo, ctx.qry.page); 110 return fmt("%s/%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo, ctx.qry.page);
111 else if (ctx.qry.repo) 111 else if (ctx.qry.repo)
112 return fmt("%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo); 112 return fmt("%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo);
113 else 113 else
114 return fmt("%s/", ctx.cfg.virtual_root); 114 return fmt("%s/", ctx.cfg.virtual_root);
115} 115}
116 116
117static void site_url(char *page, char *search)
118{
119 char *delim = "?";
120
121 if (ctx.cfg.virtual_root) {
122 html_attr(ctx.cfg.virtual_root);
123 if (ctx.cfg.virtual_root[strlen(ctx.cfg.virtual_root) - 1] != '/')
124 html("/");
125 } else
126 html(ctx.cfg.script_name);
127
128 if (page) {
129 htmlf("?p=%s", page);
130 delim = "&";
131 }
132 if (search) {
133 html(delim);
134 html("q=");
135 html_attr(search);
136 }
137}
138
139static void site_link(char *page, char *name, char *title, char *class,
140 char *search)
141{
142 html("<a");
143 if (title) {
144 html(" title='");
145 html_attr(title);
146 html("'");
147 }
148 if (class) {
149 html(" class='");
150 html_attr(class);
151 html("'");
152 }
153 html(" href='");
154 site_url(page, search);
155 html("'>");
156 html_txt(name);
157 html("</a>");
158}
159
117static char *repolink(char *title, char *class, char *page, char *head, 160static char *repolink(char *title, char *class, char *page, char *head,
118 char *path) 161 char *path)
119{ 162{
120 char *delim = "?"; 163 char *delim = "?";
121 164
122 html("<a"); 165 html("<a");
123 if (title) { 166 if (title) {
124 html(" title='"); 167 html(" title='");
@@ -505,17 +548,20 @@ void cgit_print_pageheader(struct cgit_context *ctx)
505 html("</td></tr>\n"); 548 html("</td></tr>\n");
506 549
507 html("<tr><td class='sub'"); 550 html("<tr><td class='sub'");
508 if (ctx->repo) { 551 if (ctx->repo) {
509 html(" colspan='2'>"); 552 html(" colspan='2'>");
510 html_txt(ctx->repo->desc); 553 html_txt(ctx->repo->desc);
511 } else { 554 } else {
512 html(">"); 555 html(">");
513 html_txt("a fast webinterface for the git dscm"); 556 if (ctx->cfg.root_desc)
557 html_txt(ctx->cfg.root_desc);
558 else if (ctx->cfg.index_info)
559 html_include(ctx->cfg.index_info);
514 } 560 }
515 html("</td></tr></table>\n"); 561 html("</td></tr></table>\n");
516 562
517 html("<table class='tabs'><tr><td>\n"); 563 html("<table class='tabs'><tr><td>\n");
518 if (ctx->repo) { 564 if (ctx->repo) {
519 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"), 565 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"),
520 ctx->qry.head, NULL, NULL); 566 ctx->qry.head, NULL, NULL);
521 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, 567 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head,
@@ -523,16 +569,20 @@ void cgit_print_pageheader(struct cgit_context *ctx)
523 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, 569 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head,
524 NULL, NULL, 0, NULL, NULL); 570 NULL, NULL, 0, NULL, NULL);
525 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, 571 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head,
526 ctx->qry.sha1, NULL); 572 ctx->qry.sha1, NULL);
527 cgit_commit_link("commit", NULL, hc(cmd, "commit"), 573 cgit_commit_link("commit", NULL, hc(cmd, "commit"),
528 ctx->qry.head, ctx->qry.sha1); 574 ctx->qry.head, ctx->qry.sha1);
529 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, 575 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head,
530 ctx->qry.sha1, ctx->qry.sha2, NULL); 576 ctx->qry.sha1, ctx->qry.sha2, NULL);
577 if (ctx->repo->readme)
578 reporevlink("about", "about", NULL,
579 hc(cmd, "about"), ctx->qry.head, NULL,
580 NULL);
531 html("</td><td class='form'>"); 581 html("</td><td class='form'>");
532 html("<form class='right' method='get' action='"); 582 html("<form class='right' method='get' action='");
533 if (ctx->cfg.virtual_root) 583 if (ctx->cfg.virtual_root)
534 html_attr(cgit_fileurl(ctx->qry.repo, "log", 584 html_attr(cgit_fileurl(ctx->qry.repo, "log",
535 ctx->qry.path, NULL)); 585 ctx->qry.path, NULL));
536 html("'>\n"); 586 html("'>\n");
537 add_hidden_formfields(1, 0, "log"); 587 add_hidden_formfields(1, 0, "log");
538 html("<select name='qt'>\n"); 588 html("<select name='qt'>\n");
@@ -541,19 +591,19 @@ void cgit_print_pageheader(struct cgit_context *ctx)
541 html_option("committer", "committer", ctx->qry.grep); 591 html_option("committer", "committer", ctx->qry.grep);
542 html("</select>\n"); 592 html("</select>\n");
543 html("<input class='txt' type='text' size='10' name='q' value='"); 593 html("<input class='txt' type='text' size='10' name='q' value='");
544 html_attr(ctx->qry.search); 594 html_attr(ctx->qry.search);
545 html("'/>\n"); 595 html("'/>\n");
546 html("<input type='submit' value='search'/>\n"); 596 html("<input type='submit' value='search'/>\n");
547 html("</form>\n"); 597 html("</form>\n");
548 } else { 598 } else {
549 html("<a class='active' href='"); 599 site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL);
550 html_attr(cgit_rooturl()); 600 if (ctx->cfg.root_readme)
551 html("'>index</a>\n"); 601 site_link("about", "about", NULL, hc(cmd, "about"), NULL);
552 html("</td><td class='form'>"); 602 html("</td><td class='form'>");
553 html("<form method='get' action='"); 603 html("<form method='get' action='");
554 html_attr(cgit_rooturl()); 604 html_attr(cgit_rooturl());
555 html("'>\n"); 605 html("'>\n");
556 html("<input type='text' name='q' size='10' value='"); 606 html("<input type='text' name='q' size='10' value='");
557 html_attr(ctx->qry.search); 607 html_attr(ctx->qry.search);
558 html("'/>\n"); 608 html("'/>\n");
559 html("<input type='submit' value='search'/>\n"); 609 html("<input type='submit' value='search'/>\n");