From ce97e51b638e5d2aa94ba2aecb10c7dd24385466 Mon Sep 17 00:00:00 2001 From: David Taylor Date: Fri, 10 Jan 2025 11:49:36 +0000 Subject: [PATCH] UX: Improve git blob oneboxes (#30694) Rearranges the info at the top of github/gitlab 'blob' oneboxes to make them easier to read --- .../stylesheets/common/base/onebox.scss | 12 ++++++++-- lib/onebox/engine/github_blob_onebox.rb | 10 ++++---- lib/onebox/engine/gitlab_blob_onebox.rb | 10 ++++---- lib/onebox/mixins/git_blob_onebox.rb | 23 ++++++++++++++++++- lib/onebox/templates/githubblob.mustache | 4 ++++ lib/onebox/templates/gitlabblob.mustache | 20 ++++++++-------- 6 files changed, 59 insertions(+), 20 deletions(-) diff --git a/app/assets/stylesheets/common/base/onebox.scss b/app/assets/stylesheets/common/base/onebox.scss index 1daee32eb3e..5fd8bb79a48 100644 --- a/app/assets/stylesheets/common/base/onebox.scss +++ b/app/assets/stylesheets/common/base/onebox.scss @@ -368,8 +368,16 @@ pre.onebox code ol.lines li:before { counter-increment: li-counter; } -.onebox.githubblob h4 { - word-break: break-all; +.onebox.githubblob, +.onebox.gitlabblob { + .onebox-body h4 { + word-break: break-all; + margin-bottom: 5px; + font-size: 1rem; + } + .git-blob-info { + font-size: var(--font-down-1); + } } pre.onebox code ol { diff --git a/lib/onebox/engine/github_blob_onebox.rb b/lib/onebox/engine/github_blob_onebox.rb index b396f1998d9..9ae691aa13a 100644 --- a/lib/onebox/engine/github_blob_onebox.rb +++ b/lib/onebox/engine/github_blob_onebox.rb @@ -35,13 +35,15 @@ module Onebox "https://raw.githubusercontent.com/#{match[:org]}/#{match[:repo]}/#{match[:sha1]}/#{match[:file]}" end - def title - Sanitize.fragment(Onebox::Helpers.uri_unencode(link).sub(%r{^https?\://github\.com/}, "")) - end - def auth_headers(match) github_auth_header(match[:org]) end + + private + + def data + super.merge({ domain: "github.com/#{match[:org]}/#{match[:repo]}" }) + end end end end diff --git a/lib/onebox/engine/gitlab_blob_onebox.rb b/lib/onebox/engine/gitlab_blob_onebox.rb index 51cf05858e3..8d4e1e77040 100644 --- a/lib/onebox/engine/gitlab_blob_onebox.rb +++ b/lib/onebox/engine/gitlab_blob_onebox.rb @@ -30,13 +30,15 @@ module Onebox "https://gitlab.com/#{m[:user]}/#{m[:repo]}/raw/#{m[:sha1]}/#{m[:file]}" end - def title - Sanitize.fragment(Onebox::Helpers.uri_unencode(link).sub(%r{^https?\://gitlab\.com/}, "")) - end - def auth_headers(_match) {} end + + private + + def data + super.merge({ domain: "gitlab.com/#{match[:user]}/#{match[:repo]}" }) + end end end end diff --git a/lib/onebox/mixins/git_blob_onebox.rb b/lib/onebox/mixins/git_blob_onebox.rb index a6685bcf9cc..e010e3ff5df 100644 --- a/lib/onebox/mixins/git_blob_onebox.rb +++ b/lib/onebox/mixins/git_blob_onebox.rb @@ -154,10 +154,30 @@ module Onebox { output: output_builder.join(), array: hash_builder } end + def match + @match ||= @url.match(self.raw_regexp) + end + + def sha1 + full = match[:sha1] + + # We don't actually know if this is an sha1, or a branch/tag name + # So we only truncate if it's exactly 40 characters long, which is fairly unlikely to be a branch/tag name. + if full.length == 40 + full[0..8] + else + full + end + end + + def title + Sanitize.fragment(match[:file]) + end + def raw return @raw if defined?(@raw) - m = @url.match(self.raw_regexp) + m = match if m from = /\d+/.match(m[:from]) #get numeric should only match a positive interger @@ -239,6 +259,7 @@ module Onebox model_file: @model_file, width: 480, height: 360, + sha1: sha1, } end end diff --git a/lib/onebox/templates/githubblob.mustache b/lib/onebox/templates/githubblob.mustache index 573fb5e651f..8ad8651bdde 100644 --- a/lib/onebox/templates/githubblob.mustache +++ b/lib/onebox/templates/githubblob.mustache @@ -1,5 +1,9 @@

{{title}}

+
+ {{sha1}} +
+ {{^binary}} {{^has_lines}} {{#model_file}} diff --git a/lib/onebox/templates/gitlabblob.mustache b/lib/onebox/templates/gitlabblob.mustache index 9e3390b4a4f..eeb2b79dde1 100644 --- a/lib/onebox/templates/gitlabblob.mustache +++ b/lib/onebox/templates/gitlabblob.mustache @@ -1,19 +1,21 @@

{{title}}

+
+ {{sha1}} +
+ {{^has_lines}}
{{content}}
{{/has_lines}} {{#has_lines}} -
-    
-      
    - {{#lines}} - {{data}} - {{/lines}} -
-
-
+

+    
    + {{#lines}} + {{data}} + {{/lines}} +
+
{{/has_lines}} {{#truncated}}