summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.css10
-rw-r--r--ui-shared.c7
2 files changed, 17 insertions, 0 deletions
diff --git a/cgit.css b/cgit.css
index 67cf48e..80680c9 100644
--- a/cgit.css
+++ b/cgit.css
@@ -1,194 +1,204 @@
1body, table { 1body, table {
2 padding: 0em; 2 padding: 0em;
3 margin: 0em; 3 margin: 0em;
4} 4}
5 5
6body { 6body {
7 font-family: sans; 7 font-family: sans;
8 font-size: 10pt; 8 font-size: 10pt;
9 color: #333; 9 color: #333;
10 background: white; 10 background: white;
11 padding: 4px; 11 padding: 4px;
12} 12}
13 13
14a { 14a {
15 color: blue; 15 color: blue;
16 text-decoration: none; 16 text-decoration: none;
17} 17}
18 18
19a:hover { 19a:hover {
20 text-decoration: underline; 20 text-decoration: underline;
21} 21}
22 22
23table { 23table {
24 border-collapse: collapse; 24 border-collapse: collapse;
25} 25}
26 26
27table#header { 27table#header {
28 width: 100%; 28 width: 100%;
29 margin-bottom: 1em; 29 margin-bottom: 1em;
30} 30}
31 31
32table#header td.logo { 32table#header td.logo {
33 width: 96px; 33 width: 96px;
34} 34}
35 35
36table#header td.main { 36table#header td.main {
37 font-size: 200%; 37 font-size: 200%;
38} 38}
39 39
40table#header td.sub { 40table#header td.sub {
41 color: #777; 41 color: #777;
42 border-top: solid 1px #ccc; 42 border-top: solid 1px #ccc;
43} 43}
44 44
45table.tabs { 45table.tabs {
46 border-bottom: solid 2px #ccc; 46 border-bottom: solid 2px #ccc;
47 border-collapse: collapse; 47 border-collapse: collapse;
48 margin-top: 2em; 48 margin-top: 2em;
49 margin-bottom: 1em; 49 margin-bottom: 1em;
50 width: 100%; 50 width: 100%;
51} 51}
52 52
53table.tabs td { 53table.tabs td {
54 padding: 0px 0.5em; 54 padding: 0px 0.5em;
55 vertical-align: bottom;
55} 56}
56 57
57table.tabs td a { 58table.tabs td a {
58 padding: 2px 1em; 59 padding: 2px 1em;
59 color: #007; 60 color: #007;
60} 61}
61 62
62table.tabs td a.active { 63table.tabs td a.active {
63 color: #000; 64 color: #000;
64 background-color: #ccc; 65 background-color: #ccc;
65} 66}
66 67
68table.tabs td.branch {
69 text-align: right;
70}
71
72table.tabs td.branch form {
73 padding-bottom: 2px;
74 font-size: 90%;
75}
76
67div.content { 77div.content {
68 margin: 0px; 78 margin: 0px;
69 padding: 1em; 79 padding: 1em;
70} 80}
71 81
72 82
73table.list { 83table.list {
74 width: 100%; 84 width: 100%;
75 border: none; 85 border: none;
76 border-collapse: collapse; 86 border-collapse: collapse;
77} 87}
78 88
79table.list tr { 89table.list tr {
80 background: white; 90 background: white;
81} 91}
82 92
83table.list tr:hover { 93table.list tr:hover {
84 background: #eee; 94 background: #eee;
85} 95}
86 96
87table.list tr.nohover:hover { 97table.list tr.nohover:hover {
88 background: white; 98 background: white;
89} 99}
90 100
91table.list th { 101table.list th {
92 font-weight: normal; 102 font-weight: normal;
93 border-bottom: solid 1px #ccc; 103 border-bottom: solid 1px #ccc;
94 padding: 0.1em 0.5em 0.1em 0.5em; 104 padding: 0.1em 0.5em 0.1em 0.5em;
95 vertical-align: baseline; 105 vertical-align: baseline;
96} 106}
97 107
98table.list td { 108table.list td {
99 border: none; 109 border: none;
100 padding: 0.1em 0.5em 0.1em 0.5em; 110 padding: 0.1em 0.5em 0.1em 0.5em;
101} 111}
102 112
103table.list td a { 113table.list td a {
104 color: black; 114 color: black;
105} 115}
106 116
107img { 117img {
108 border: none; 118 border: none;
109} 119}
110 120
111input#switch-btn { 121input#switch-btn {
112 margin: 2px 0px 0px 0px; 122 margin: 2px 0px 0px 0px;
113} 123}
114 124
115td#sidebar input.txt { 125td#sidebar input.txt {
116 width: 100%; 126 width: 100%;
117 margin: 2px 0px 0px 0px; 127 margin: 2px 0px 0px 0px;
118} 128}
119 129
120table#grid { 130table#grid {
121 margin: 0px; 131 margin: 0px;
122} 132}
123 133
124td#content { 134td#content {
125 vertical-align: top; 135 vertical-align: top;
126 padding: 1em 2em 1em 1em; 136 padding: 1em 2em 1em 1em;
127 border: none; 137 border: none;
128} 138}
129 139
130div#summary { 140div#summary {
131 vertical-align: top; 141 vertical-align: top;
132 margin-bottom: 1em; 142 margin-bottom: 1em;
133} 143}
134 144
135table#downloads { 145table#downloads {
136 float: right; 146 float: right;
137 border-collapse: collapse; 147 border-collapse: collapse;
138 border: solid 1px #777; 148 border: solid 1px #777;
139 margin-left: 0.5em; 149 margin-left: 0.5em;
140 margin-bottom: 0.5em; 150 margin-bottom: 0.5em;
141} 151}
142 152
143table#downloads th { 153table#downloads th {
144 background-color: #ccc; 154 background-color: #ccc;
145} 155}
146 156
147div#blob { 157div#blob {
148 border: solid 1px black; 158 border: solid 1px black;
149} 159}
150 160
151div.error { 161div.error {
152 color: red; 162 color: red;
153 font-weight: bold; 163 font-weight: bold;
154 margin: 1em 2em; 164 margin: 1em 2em;
155} 165}
156 166
157a.ls-blob, a.ls-dir, a.ls-mod { 167a.ls-blob, a.ls-dir, a.ls-mod {
158 font-family: monospace; 168 font-family: monospace;
159} 169}
160 170
161td.ls-size { 171td.ls-size {
162 text-align: right; 172 text-align: right;
163} 173}
164 174
165td.ls-size { 175td.ls-size {
166 font-family: monospace; 176 font-family: monospace;
167} 177}
168 178
169td.ls-mode { 179td.ls-mode {
170 font-family: monospace; 180 font-family: monospace;
171} 181}
172 182
173table.blob { 183table.blob {
174 margin-top: 0.5em; 184 margin-top: 0.5em;
175 border-top: solid 1px black; 185 border-top: solid 1px black;
176} 186}
177 187
178table.blob td.no { 188table.blob td.no {
179 border-right: solid 1px black; 189 border-right: solid 1px black;
180 color: black; 190 color: black;
181 background-color: #eee; 191 background-color: #eee;
182 text-align: right; 192 text-align: right;
183} 193}
184 194
185table.blob td.no a { 195table.blob td.no a {
186 color: black; 196 color: black;
187} 197}
188 198
189table.blob td.no a:hover { 199table.blob td.no a:hover {
190 color: black; 200 color: black;
191 text-decoration: none; 201 text-decoration: none;
192} 202}
193 203
194table.blob td.txt { 204table.blob td.txt {
diff --git a/ui-shared.c b/ui-shared.c
index 03d147f..73e3d4c 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -393,168 +393,175 @@ void cgit_print_docend()
393} 393}
394 394
395int print_branch_option(const char *refname, const unsigned char *sha1, 395int print_branch_option(const char *refname, const unsigned char *sha1,
396 int flags, void *cb_data) 396 int flags, void *cb_data)
397{ 397{
398 char *name = (char *)refname; 398 char *name = (char *)refname;
399 html_option(name, name, ctx.qry.head); 399 html_option(name, name, ctx.qry.head);
400 return 0; 400 return 0;
401} 401}
402 402
403int print_archive_ref(const char *refname, const unsigned char *sha1, 403int print_archive_ref(const char *refname, const unsigned char *sha1,
404 int flags, void *cb_data) 404 int flags, void *cb_data)
405{ 405{
406 struct tag *tag; 406 struct tag *tag;
407 struct taginfo *info; 407 struct taginfo *info;
408 struct object *obj; 408 struct object *obj;
409 char buf[256], *url; 409 char buf[256], *url;
410 unsigned char fileid[20]; 410 unsigned char fileid[20];
411 int *header = (int *)cb_data; 411 int *header = (int *)cb_data;
412 412
413 if (prefixcmp(refname, "refs/archives")) 413 if (prefixcmp(refname, "refs/archives"))
414 return 0; 414 return 0;
415 strncpy(buf, refname+14, sizeof(buf)); 415 strncpy(buf, refname+14, sizeof(buf));
416 obj = parse_object(sha1); 416 obj = parse_object(sha1);
417 if (!obj) 417 if (!obj)
418 return 1; 418 return 1;
419 if (obj->type == OBJ_TAG) { 419 if (obj->type == OBJ_TAG) {
420 tag = lookup_tag(sha1); 420 tag = lookup_tag(sha1);
421 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 421 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
422 return 0; 422 return 0;
423 hashcpy(fileid, tag->tagged->sha1); 423 hashcpy(fileid, tag->tagged->sha1);
424 } else if (obj->type != OBJ_BLOB) { 424 } else if (obj->type != OBJ_BLOB) {
425 return 0; 425 return 0;
426 } else { 426 } else {
427 hashcpy(fileid, sha1); 427 hashcpy(fileid, sha1);
428 } 428 }
429 if (!*header) { 429 if (!*header) {
430 html("<h1>download</h1>\n"); 430 html("<h1>download</h1>\n");
431 *header = 1; 431 *header = 1;
432 } 432 }
433 url = cgit_pageurl(ctx.qry.repo, "blob", 433 url = cgit_pageurl(ctx.qry.repo, "blob",
434 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid), 434 fmt("id=%s&amp;path=%s", sha1_to_hex(fileid),
435 buf)); 435 buf));
436 html_link_open(url, NULL, "menu"); 436 html_link_open(url, NULL, "menu");
437 html_txt(strlpart(buf, 20)); 437 html_txt(strlpart(buf, 20));
438 html_link_close(); 438 html_link_close();
439 return 0; 439 return 0;
440} 440}
441 441
442void add_hidden_formfields(int incl_head, int incl_search, char *page) 442void add_hidden_formfields(int incl_head, int incl_search, char *page)
443{ 443{
444 char *url; 444 char *url;
445 445
446 if (!ctx.cfg.virtual_root) { 446 if (!ctx.cfg.virtual_root) {
447 url = fmt("%s/%s", ctx.qry.repo, page); 447 url = fmt("%s/%s", ctx.qry.repo, page);
448 if (ctx.qry.path) 448 if (ctx.qry.path)
449 url = fmt("%s/%s", url, ctx.qry.path); 449 url = fmt("%s/%s", url, ctx.qry.path);
450 html_hidden("url", url); 450 html_hidden("url", url);
451 } 451 }
452 452
453 if (incl_head && strcmp(ctx.qry.head, ctx.repo->defbranch)) 453 if (incl_head && strcmp(ctx.qry.head, ctx.repo->defbranch))
454 html_hidden("h", ctx.qry.head); 454 html_hidden("h", ctx.qry.head);
455 455
456 if (ctx.qry.sha1) 456 if (ctx.qry.sha1)
457 html_hidden("id", ctx.qry.sha1); 457 html_hidden("id", ctx.qry.sha1);
458 if (ctx.qry.sha2) 458 if (ctx.qry.sha2)
459 html_hidden("id2", ctx.qry.sha2); 459 html_hidden("id2", ctx.qry.sha2);
460 460
461 if (incl_search) { 461 if (incl_search) {
462 if (ctx.qry.grep) 462 if (ctx.qry.grep)
463 html_hidden("qt", ctx.qry.grep); 463 html_hidden("qt", ctx.qry.grep);
464 if (ctx.qry.search) 464 if (ctx.qry.search)
465 html_hidden("q", ctx.qry.search); 465 html_hidden("q", ctx.qry.search);
466 } 466 }
467} 467}
468 468
469char *hc(struct cgit_cmd *cmd, const char *page) 469char *hc(struct cgit_cmd *cmd, const char *page)
470{ 470{
471 return (strcmp(cmd->name, page) ? NULL : "active"); 471 return (strcmp(cmd->name, page) ? NULL : "active");
472} 472}
473 473
474void cgit_print_pageheader(struct cgit_context *ctx) 474void cgit_print_pageheader(struct cgit_context *ctx)
475{ 475{
476 struct cgit_cmd *cmd = cgit_get_cmd(ctx); 476 struct cgit_cmd *cmd = cgit_get_cmd(ctx);
477 477
478 html("<table id='header'>\n"); 478 html("<table id='header'>\n");
479 html("<tr>\n"); 479 html("<tr>\n");
480 html("<td class='logo' rowspan='2'><a href='"); 480 html("<td class='logo' rowspan='2'><a href='");
481 if (ctx->cfg.logo_link) 481 if (ctx->cfg.logo_link)
482 html_attr(ctx->cfg.logo_link); 482 html_attr(ctx->cfg.logo_link);
483 else 483 else
484 html_attr(cgit_rooturl()); 484 html_attr(cgit_rooturl());
485 html("'><img src='"); 485 html("'><img src='");
486 html_attr(ctx->cfg.logo); 486 html_attr(ctx->cfg.logo);
487 html("'/></a></td>\n"); 487 html("'/></a></td>\n");
488 html("<td class='main'>"); 488 html("<td class='main'>");
489 if (ctx->repo) { 489 if (ctx->repo) {
490 html("<a href='"); 490 html("<a href='");
491 html_attr(cgit_rooturl()); 491 html_attr(cgit_rooturl());
492 html("'>index</a> / "); 492 html("'>index</a> / ");
493 html_txt(ctx->repo->name); 493 html_txt(ctx->repo->name);
494 } else 494 } else
495 html_txt(ctx->cfg.root_title); 495 html_txt(ctx->cfg.root_title);
496 html("</td></tr>\n"); 496 html("</td></tr>\n");
497 html("<tr><td class='sub'>"); 497 html("<tr><td class='sub'>");
498 if (ctx->repo) 498 if (ctx->repo)
499 html_txt(ctx->repo->desc); 499 html_txt(ctx->repo->desc);
500 else 500 else
501 html_txt(ctx->cfg.index_info); 501 html_txt(ctx->cfg.index_info);
502 html("</td></tr>\n"); 502 html("</td></tr>\n");
503 html("</table>\n"); 503 html("</table>\n");
504 504
505 html("<table class='tabs'><tr><td>\n"); 505 html("<table class='tabs'><tr><td>\n");
506 if (ctx->repo) { 506 if (ctx->repo) {
507 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"), 507 reporevlink(NULL, "summary", NULL, hc(cmd, "summary"),
508 ctx->qry.head, NULL, NULL); 508 ctx->qry.head, NULL, NULL);
509 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head, 509 cgit_refs_link("refs", NULL, hc(cmd, "refs"), ctx->qry.head,
510 ctx->qry.sha1, NULL); 510 ctx->qry.sha1, NULL);
511 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, 511 cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head,
512 NULL, NULL, 0, NULL, NULL); 512 NULL, NULL, 0, NULL, NULL);
513 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, 513 cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head,
514 ctx->qry.sha1, NULL); 514 ctx->qry.sha1, NULL);
515 cgit_commit_link("commit", NULL, hc(cmd, "commit"), 515 cgit_commit_link("commit", NULL, hc(cmd, "commit"),
516 ctx->qry.head, ctx->qry.sha1); 516 ctx->qry.head, ctx->qry.sha1);
517 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, 517 cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head,
518 ctx->qry.sha1, ctx->qry.sha2, NULL); 518 ctx->qry.sha1, ctx->qry.sha2, NULL);
519 cgit_patch_link("patch", NULL, hc(cmd, "patch"), ctx->qry.head, 519 cgit_patch_link("patch", NULL, hc(cmd, "patch"), ctx->qry.head,
520 ctx->qry.sha1); 520 ctx->qry.sha1);
521 html("</td><td class='branch'>");
522 html("<form method='get' action=''>\n");
523 add_hidden_formfields(0, 1, ctx->qry.page);
524 html("<select name='h' onchange='this.form.submit();'>\n");
525 for_each_branch_ref(print_branch_option, ctx->qry.head);
526 html("</select> ");
527 html("<input type='submit' name='' value='switch'/>");
521 } else { 528 } else {
522 html("<a class='active' href='"); 529 html("<a class='active' href='");
523 html_attr(cgit_rooturl()); 530 html_attr(cgit_rooturl());
524 html("'>index</a>\n"); 531 html("'>index</a>\n");
525 } 532 }
526 html("</td></tr></table>\n"); 533 html("</td></tr></table>\n");
527 html("<div class='content'>"); 534 html("<div class='content'>");
528} 535}
529 536
530void cgit_print_filemode(unsigned short mode) 537void cgit_print_filemode(unsigned short mode)
531{ 538{
532 if (S_ISDIR(mode)) 539 if (S_ISDIR(mode))
533 html("d"); 540 html("d");
534 else if (S_ISLNK(mode)) 541 else if (S_ISLNK(mode))
535 html("l"); 542 html("l");
536 else if (S_ISGITLINK(mode)) 543 else if (S_ISGITLINK(mode))
537 html("m"); 544 html("m");
538 else 545 else
539 html("-"); 546 html("-");
540 html_fileperm(mode >> 6); 547 html_fileperm(mode >> 6);
541 html_fileperm(mode >> 3); 548 html_fileperm(mode >> 3);
542 html_fileperm(mode); 549 html_fileperm(mode);
543} 550}
544 551
545void cgit_print_snapshot_links(const char *repo, const char *head, 552void cgit_print_snapshot_links(const char *repo, const char *head,
546 const char *hex, int snapshots) 553 const char *hex, int snapshots)
547{ 554{
548 const struct cgit_snapshot_format* f; 555 const struct cgit_snapshot_format* f;
549 char *filename; 556 char *filename;
550 557
551 for (f = cgit_snapshot_formats; f->suffix; f++) { 558 for (f = cgit_snapshot_formats; f->suffix; f++) {
552 if (!(snapshots & f->bit)) 559 if (!(snapshots & f->bit))
553 continue; 560 continue;
554 filename = fmt("%s-%s%s", cgit_repobasename(repo), hex, 561 filename = fmt("%s-%s%s", cgit_repobasename(repo), hex,
555 f->suffix); 562 f->suffix);
556 cgit_snapshot_link(filename, NULL, NULL, (char *)head, 563 cgit_snapshot_link(filename, NULL, NULL, (char *)head,
557 (char *)hex, filename); 564 (char *)hex, filename);
558 html("<br/>"); 565 html("<br/>");
559 } 566 }
560} 567}