the repository which powers this website
Implement themed summary page
| -rw-r--r-- | cgit.mk | 13 | ||||
| -rw-r--r-- | themed/summary.html | 98 | ||||
| -rw-r--r-- | themed/themed.in.css | 12 | ||||
| -rw-r--r-- | ui-summary.c | 2 |
4 files changed, 121 insertions, 4 deletions
@@ -98,6 +98,13 @@ CGIT_OBJ_NAMES += ui-tree.o CGIT_OBJ_NAMES += themed/themed.o CGIT_OBJ_NAMES += themed/mincrypt_sha256.o +CGIT_THEMED_INPUTS += $(CGIT_PREFIX)themed/base.html +CGIT_THEMED_INPUTS += $(CGIT_PREFIX)themed/index.html +CGIT_THEMED_INPUTS += $(CGIT_PREFIX)themed/commit.html +CGIT_THEMED_INPUTS += $(CGIT_PREFIX)themed/log.html +CGIT_THEMED_INPUTS += $(CGIT_PREFIX)themed/refs.html +CGIT_THEMED_INPUTS += $(CGIT_PREFIX)themed/summary.html + CGIT_OBJS := $(addprefix $(CGIT_PREFIX),$(CGIT_OBJ_NAMES)) # Only cgit.c reference CGIT_VERSION so we only rebuild its objects when the @@ -129,11 +136,11 @@ $(CGIT_PREFIX).depend: $(CGIT_PREFIX)themed/.depend: @mkdir -p $@ -$(CGIT_PREFIX)themed/themed.c: $(CGIT_PREFIX)themed/base.html $(CGIT_PREFIX)themed/index.html $(CGIT_PREFIX)themed/commit.html $(CGIT_PREFIX)themed/log.html $(CGIT_PREFIX)themed/refs.html +$(CGIT_PREFIX)themed/themed.c: $(CGIT_THEMED_INPUTS) cd $(CGIT_PREFIX)themed; python -m htmlcc $^ > $@ -$(CGIT_PREFIX)themed/themed.css: $(CGIT_PREFIX)themed/themed.in.css - cd $(CGIT_PREFIX)themed; tailwindcss -i $^ -o $@ +$(CGIT_PREFIX)themed/themed.css: $(CGIT_PREFIX)themed/themed.in.css $(CGIT_THEMED_INPUTS) + cd $(CGIT_PREFIX)themed; tailwindcss -i $< -o $@ $(CGIT_PREFIX)CGIT-CFLAGS: FORCE @FLAGS='$(subst ','\'',$(CGIT_CFLAGS))'; \ diff --git a/themed/summary.html b/themed/summary.html new file mode 100644 index 00000000..9bd3004c --- /dev/null +++ b/themed/summary.html @@ -0,0 +1,98 @@ +{! #include "../ui-blob.h" !} + +{% block ls_item_impl(const struct object_id *oid, struct strbuf *base, const char *pathname, unsigned mode, void *cbdata) %} + {! + unsigned long size = 0; + if (!S_ISGITLINK(mode)) { + oid_object_info(the_repository, oid, &size); + } + !} + <div class="pl-3 pr-1 py-2 border-t border-gray-300"> + {% if S_ISDIR(mode) %} + {# Heroicons solid folder #} + <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" class="size-5 text-blue-400 mt-[0.1rem]"><path d="M19.5 21a3 3 0 0 0 3-3v-4.5a3 3 0 0 0-3-3h-15a3 3 0 0 0-3 3V18a3 3 0 0 0 3 3h15ZM1.5 10.146V6a3 3 0 0 1 3-3h5.379a2.25 2.25 0 0 1 1.59.659l2.122 2.121c.14.141.331.22.53.22H19.5a3 3 0 0 1 3 3v1.146A4.483 4.483 0 0 0 19.5 9h-15a4.483 4.483 0 0 0-3 1.146Z" /></svg> + {% else %} + {# Heroicons outline document #} + <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="size-5 text-gray-500 mt-[0.1rem]"><path stroke-linecap="round" stroke-linejoin="round" d="M19.5 14.25v-2.625a3.375 3.375 0 0 0-3.375-3.375h-1.5A1.125 1.125 0 0 1 13.5 7.125v-1.5a3.375 3.375 0 0 0-3.375-3.375H8.25m2.25 0H5.625c-.621 0-1.125.504-1.125 1.125v17.25c0 .621.504 1.125 1.125 1.125h12.75c.621 0 1.125-.504 1.125-1.125V11.25a9 9 0 0 0-9-9Z" /></svg> + {% endif %} + </div> + <div class="pr-3 py-2 border-t border-gray-300"><a href="{! cgit_shared_repolink_url("tree", ctx.qry.head, pathname); !}" class="hover:text-blue-600 hover:underline">{{ pathname }}</a></div> + <div class="pr-3 py-2 border-t border-gray-300 text-gray-500 font-mono">{! cgit_print_filemode(mode); !}</div> + <div class="pr-3 py-2 border-t border-gray-300 text-gray-500 text-end">{% if !S_ISDIR(mode) %}{{ size|%ld }}{% endif %}</div> +{% endblock %} +{! + int ls_item(const struct object_id *oid, struct strbuf *base, const char *pathname, unsigned mode, void *cbdata) { + ls_item_impl(oid, base, pathname, mode, cbdata); + return 0; + } +!} + +{% page cgit_print_summary %} +{! page_start(); !} +{! repo_header(); !} + <main class="max-w-[1280px] mx-auto py-4">{# Main content #} +{! repo_description_panel(); !} +{! repo_summary_bar(); !} + <div class="grid grid-cols-[auto_1fr_auto_auto] border border-gray-300 rounded-md mb-4"> + {# Latest commit panel (specify rounded-t-md so background does not cover border) #} + {! + // Get latest commit + struct object_id oid; + if (repo_get_oid(the_repository, ctx.qry.head, &oid)) { + die("Bad object id"); + } + struct commit *commit = lookup_commit_reference(the_repository, &oid); + if (!commit) { + die("Bad commit reference"); + } + struct commitinfo *info = cgit_parse_commit(commit); + !} + <div class="col-span-4 rounded-t-md bg-gray-50 px-3 py-2 flex gap-x-1"> + <img src="{! gravatar_url(info->author_email); !}?s=24"> + <span class="font-semibold">{{ info->author }}</span> + <a href="{! cgit_shared_repolink_url_with_delimiter("commit", ctx.qry.head, ctx.qry.vpath); !}id={{ oid_to_hex(&commit->object.oid) }}" class="ml-2 text-gray-500 hover:text-blue-600 hover:underline">{{ info->subject }}</a> + <div class="flex-1"></div> + {! char short_commit_id[8]; !} + {! memcpy(short_commit_id, oid_to_hex(&commit->object.oid), 7); !} + {! short_commit_id[7] = '\0'; !} + <span class="text-gray-500"><a href="{! cgit_shared_repolink_url_with_delimiter("commit", ctx.qry.head, ctx.qry.vpath); !}id={{ oid_to_hex(&commit->object.oid) }}" class="font-mono hover:text-blue-600 hover:underline">{{ short_commit_id }}</a> · {! cgit_print_age(info->committer_date, info->committer_tz, TM_WEEK * 2); !} ago</span> + </div> + {# Files #} + {! + const struct object_id *tree_oid = get_commit_tree_oid(commit); + struct tree *tree = parse_tree_indirect(tree_oid); + struct pathspec paths = { + .nr = 0 + }; + read_tree(the_repository, tree, &paths, ls_item, NULL); + !} + </div> + {% if ctx.repo->readme.nr > 0 %} + {! + char *filename = ctx.repo->readme.items[0].string; + char *ref = ctx.repo->readme.items[0].util; + !} + <div class="flex flex-col border border-gray-300 rounded-md"> + {# Readme panel #} + <div class="rounded-t-md bg-gray-50 px-3 py-2 flex gap-x-1 items-center"> + {# Heroicons micro book-open #} + <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" fill="currentColor" class="size-4"><path d="M7.25 3.688a8.035 8.035 0 0 0-4.872-.523A.48.48 0 0 0 2 3.64v7.994c0 .345.342.588.679.512a6.02 6.02 0 0 1 4.571.81V3.688ZM8.75 12.956a6.02 6.02 0 0 1 4.571-.81c.337.075.679-.167.679-.512V3.64a.48.48 0 0 0-.378-.475 8.034 8.034 0 0 0-4.872.523v9.268Z" /></svg> + <span class="font-semibold text-sm">{{ filename }}</span> + </div> + {# Readme content #} + <div class="rendered-file p-7 border-t border-gray-300"> + {! + cgit_open_filter(ctx.repo->about_filter, filename); + if (ref) { + cgit_print_file(filename, ref, 1); + } else { + html_include(filename); + } + cgit_close_filter(ctx.repo->about_filter); + !} + </div> + </div> + {% endif %} + </main> +{! page_end(); !} +{% endpage %} diff --git a/themed/themed.in.css b/themed/themed.in.css index 9ab4c729..336859db 100644 --- a/themed/themed.in.css +++ b/themed/themed.in.css @@ -8,6 +8,18 @@ font-size: 11pt; } +.rendered-file { + a { + @apply hover:underline; + } + :not(h1, h2, h3, h4, h5, h6) > a { + @apply text-blue-500 hover:text-blue-600; + } + ul { + @apply list-disc; + } +} + .diff-panel { a { @apply text-blue-500 hover:text-blue-600 hover:underline; diff --git a/ui-summary.c b/ui-summary.c index b8552673..1752e202 100644 --- a/ui-summary.c +++ b/ui-summary.c @@ -40,7 +40,7 @@ static void print_url(const char *url) html("</a></td></tr>\n"); } -void cgit_print_summary(void) +void _orig_cgit_print_summary(void) { int columns = 3; |