diff options
| author | 2007-10-30 18:47:38 (JST) | |
|---|---|---|
| committer | 2007-10-30 21:38:34 (JST) | |
| commit | 0c8e184e9cbf4d3a1e907de9125f6d8210c169d6 (patch) | |
| tree | 2e82baf582b7ba0b34f498e1e7494800070067f9 /ui-shared.c | |
| parent | 10ac7ad1f30f914dc5ff36ba3651ef6dca11aaf7 (diff) | |
| download | cgit-0c8e184e9cbf4d3a1e907de9125f6d8210c169d6.zip cgit-0c8e184e9cbf4d3a1e907de9125f6d8210c169d6.tar.gz | |
Change the cgit layout
This modifies and hopefully improves the layout of all cgit pages:
* Remove the header from all pages and replace it with a sidebar;
most pages have sufficient width but many needs more height.
* Add a dropdown-box to switch between branches, using a one-liner
javascript to reload the current page in context of the selected branch.
* Include refs found below refs/archives in the sidebar, appearing as a
set of menuitems below a 'download' heading.
* Include the brand new cgit logo
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'ui-shared.c')
| -rw-r--r-- | ui-shared.c | 172 |
1 files changed, 122 insertions, 50 deletions
diff --git a/ui-shared.c b/ui-shared.c index 1418010..1d66940 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
| @@ -362,77 +362,149 @@ void cgit_print_docstart(char *title, struct cacheitem *item) | |||
| 362 | 362 | ||
| 363 | void cgit_print_docend() | 363 | void cgit_print_docend() |
| 364 | { | 364 | { |
| 365 | html("</td></tr></table>"); | 365 | html("</td>\n</tr>\n<table>\n</body>\n</html>\n"); |
| 366 | html("</body>\n</html>\n"); | 366 | } |
| 367 | |||
| 368 | int print_branch_option(const char *refname, const unsigned char *sha1, | ||
| 369 | int flags, void *cb_data) | ||
| 370 | { | ||
| 371 | char *name = (char *)refname; | ||
| 372 | html_option(name, name, cgit_query_head); | ||
| 373 | return 0; | ||
| 374 | } | ||
| 375 | |||
| 376 | int print_archive_ref(const char *refname, const unsigned char *sha1, | ||
| 377 | int flags, void *cb_data) | ||
| 378 | { | ||
| 379 | struct tag *tag; | ||
| 380 | struct taginfo *info; | ||
| 381 | struct object *obj; | ||
| 382 | char buf[256], *url; | ||
| 383 | unsigned char fileid[20]; | ||
| 384 | int *header = (int *)cb_data; | ||
| 385 | |||
| 386 | if (prefixcmp(refname, "refs/archives")) | ||
| 387 | return 0; | ||
| 388 | strncpy(buf, refname+14, sizeof(buf)); | ||
| 389 | obj = parse_object(sha1); | ||
| 390 | if (!obj) | ||
| 391 | return 1; | ||
| 392 | if (obj->type == OBJ_TAG) { | ||
| 393 | tag = lookup_tag(sha1); | ||
| 394 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) | ||
| 395 | return 0; | ||
| 396 | hashcpy(fileid, tag->tagged->sha1); | ||
| 397 | } else if (obj->type != OBJ_BLOB) { | ||
| 398 | return 0; | ||
| 399 | } else { | ||
| 400 | hashcpy(fileid, sha1); | ||
| 401 | } | ||
| 402 | if (!*header) { | ||
| 403 | html("<p><h1>download</h1>"); | ||
| 404 | *header = 1; | ||
| 405 | } | ||
| 406 | url = cgit_pageurl(cgit_query_repo, "blob", | ||
| 407 | fmt("id=%s&path=%s", sha1_to_hex(fileid), | ||
| 408 | buf)); | ||
| 409 | html_link_open(url, NULL, "menu"); | ||
| 410 | html_txt(strlpart(buf, 20)); | ||
| 411 | html_link_close(); | ||
| 412 | return 0; | ||
| 413 | } | ||
| 414 | |||
| 415 | void add_hidden_formfields(int incl_head, int incl_search) | ||
| 416 | { | ||
| 417 | if (!cgit_virtual_root) { | ||
| 418 | if (cgit_query_repo) | ||
| 419 | html_hidden("r", cgit_query_repo); | ||
| 420 | if (cgit_query_page) | ||
| 421 | html_hidden("p", cgit_query_page); | ||
| 422 | } | ||
| 423 | |||
| 424 | if (incl_head && strcmp(cgit_query_head, cgit_repo->defbranch)) | ||
| 425 | html_hidden("h", cgit_query_head); | ||
| 426 | |||
| 427 | if (cgit_query_sha1) | ||
| 428 | html_hidden("id", cgit_query_sha1); | ||
| 429 | if (cgit_query_sha2) | ||
| 430 | html_hidden("id2", cgit_query_sha2); | ||
| 431 | |||
| 432 | if (incl_search) { | ||
| 433 | if (cgit_query_grep) | ||
| 434 | html_hidden("qt", cgit_query_grep); | ||
| 435 | if (cgit_query_search) | ||
| 436 | html_hidden("q", cgit_query_search); | ||
| 437 | } | ||
| 367 | } | 438 | } |
| 368 | 439 | ||
| 369 | void cgit_print_pageheader(char *title, int show_search) | 440 | void cgit_print_pageheader(char *title, int show_search) |
| 370 | { | 441 | { |
| 371 | html("<table id='layout'>"); | 442 | static const char *default_info = "This is cgit, a fast webinterface for git repositories"; |
| 372 | html("<tr><td id='header'><a href='"); | 443 | int header = 0; |
| 373 | html_attr(cgit_rooturl()); | 444 | |
| 374 | html("'>"); | 445 | html("<div id='sidebar'>\n"); |
| 375 | html_txt(cgit_root_title); | ||
| 376 | html("</a></td><td id='logo'>"); | ||
| 377 | html("<a href='"); | 446 | html("<a href='"); |
| 378 | html_attr(cgit_logo_link); | 447 | html_attr(cgit_rooturl()); |
| 379 | htmlf("'><img src='%s' alt='logo'/></a>", cgit_logo); | 448 | htmlf("'><div id='logo'><img src='%s' alt='cgit'/></div></a>\n", |
| 380 | html("</td></tr>"); | 449 | cgit_logo); |
| 381 | html("<tr><td id='crumb'>"); | 450 | html("<div class='infobox'>"); |
| 382 | if (cgit_query_repo) { | 451 | if (cgit_query_repo) { |
| 383 | html_txt(cgit_repo->name); | 452 | html("<h1>"); |
| 384 | html(" ("); | 453 | html_txt(strrpart(cgit_repo->name, 20)); |
| 385 | html_txt(cgit_query_head); | 454 | html("</h1>\n"); |
| 386 | html(") : "); | 455 | html_txt(cgit_repo->desc); |
| 387 | reporevlink(NULL, "summary", NULL, NULL, cgit_query_head, | 456 | if (cgit_repo->owner) { |
| 457 | html("<p>\n<h1>owner</h1>\n"); | ||
| 458 | html_txt(cgit_repo->owner); | ||
| 459 | } | ||
| 460 | html("<p>\n<h1>navigate</h1>\n"); | ||
| 461 | reporevlink(NULL, "summary", NULL, "menu", cgit_query_head, | ||
| 388 | NULL, NULL); | 462 | NULL, NULL); |
| 389 | html(" "); | 463 | cgit_log_link("log", NULL, "menu", cgit_query_head, |
| 390 | cgit_log_link("log", NULL, NULL, cgit_query_head, | ||
| 391 | cgit_query_sha1, cgit_query_path, 0); | 464 | cgit_query_sha1, cgit_query_path, 0); |
| 392 | html(" "); | 465 | cgit_tree_link("tree", NULL, "menu", cgit_query_head, |
| 393 | cgit_tree_link("tree", NULL, NULL, cgit_query_head, | ||
| 394 | cgit_query_sha1, NULL); | 466 | cgit_query_sha1, NULL); |
| 395 | html(" "); | 467 | cgit_commit_link("commit", NULL, "menu", cgit_query_head, |
| 396 | cgit_commit_link("commit", NULL, NULL, cgit_query_head, | ||
| 397 | cgit_query_sha1); | 468 | cgit_query_sha1); |
| 398 | html(" "); | 469 | cgit_diff_link("diff", NULL, "menu", cgit_query_head, |
| 399 | cgit_diff_link("diff", NULL, NULL, cgit_query_head, | ||
| 400 | cgit_query_sha1, cgit_query_sha2, | 470 | cgit_query_sha1, cgit_query_sha2, |
| 401 | cgit_query_path); | 471 | cgit_query_path); |
| 402 | } else { | 472 | |
| 403 | html_txt("Index of repositories"); | 473 | for_each_ref(print_archive_ref, &header); |
| 404 | } | 474 | |
| 405 | html("</td>"); | 475 | html("<p>\n<h1>branch</h1>\n"); |
| 406 | html("<td id='search'>"); | 476 | html("<form method='get' action=''>\n"); |
| 407 | if (show_search) { | 477 | add_hidden_formfields(0, 1); |
| 478 | html("<select name='h' onchange='this.form.submit();'>\n"); | ||
| 479 | for_each_branch_ref(print_branch_option, cgit_query_head); | ||
| 480 | html("</select>\n"); | ||
| 481 | html("</form>\n"); | ||
| 482 | |||
| 483 | html("<p>\n<h1>search</h1>\n"); | ||
| 408 | html("<form method='get' action='"); | 484 | html("<form method='get' action='"); |
| 409 | html_attr(cgit_currurl()); | 485 | html_attr(cgit_pageurl(cgit_query_repo, "log", NULL)); |
| 410 | html("'>"); | 486 | html("'>\n"); |
| 411 | if (!cgit_virtual_root) { | 487 | add_hidden_formfields(1, 0); |
| 412 | if (cgit_query_repo) | 488 | html("<select name='qt'>\n"); |
| 413 | html_hidden("r", cgit_query_repo); | ||
| 414 | if (cgit_query_page) | ||
| 415 | html_hidden("p", cgit_query_page); | ||
| 416 | } | ||
| 417 | if (cgit_query_head) | ||
| 418 | html_hidden("h", cgit_query_head); | ||
| 419 | if (cgit_query_sha1) | ||
| 420 | html_hidden("id", cgit_query_sha1); | ||
| 421 | if (cgit_query_sha2) | ||
| 422 | html_hidden("id2", cgit_query_sha2); | ||
| 423 | html("<select name='qt'>"); | ||
| 424 | html_option("grep", "log msg", cgit_query_grep); | 489 | html_option("grep", "log msg", cgit_query_grep); |
| 425 | html_option("author", "author", cgit_query_grep); | 490 | html_option("author", "author", cgit_query_grep); |
| 426 | html_option("committer", "committer", cgit_query_grep); | 491 | html_option("committer", "committer", cgit_query_grep); |
| 427 | html("</select>"); | 492 | html("</select>\n"); |
| 428 | html("<input class='txt' type='text' name='q' value='"); | 493 | html("<input class='txt' type='text' name='q' value='"); |
| 429 | html_attr(cgit_query_search); | 494 | html_attr(cgit_query_search); |
| 430 | html("'/><input class='btn' type='submit' value='...'/></form>"); | 495 | html("'/>\n"); |
| 496 | html("</form>\n"); | ||
| 497 | } else { | ||
| 498 | if (!cgit_index_info || html_include(cgit_index_info)) | ||
| 499 | html(default_info); | ||
| 431 | } | 500 | } |
| 432 | html("</td></tr>"); | 501 | |
| 433 | html("<tr><td id='content' colspan='2'>"); | 502 | html("</div>\n"); |
| 503 | |||
| 504 | html("</div>\n<table class='grid'><tr><td id='content'>\n"); | ||
| 434 | } | 505 | } |
| 435 | 506 | ||
| 507 | |||
| 436 | void cgit_print_snapshot_start(const char *mimetype, const char *filename, | 508 | void cgit_print_snapshot_start(const char *mimetype, const char *filename, |
| 437 | struct cacheitem *item) | 509 | struct cacheitem *item) |
| 438 | { | 510 | { |
