mirror of https://git.jolheiser.com/ugit.git
permalink
parent
68992f0807
commit
51f11a9897
|
@ -127,6 +127,21 @@ func (r Repo) Dir(ref, path string) ([]FileInfo, error) {
|
||||||
return fis, nil
|
return fis, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetCommitFromRef returns the commit object for a given ref
|
||||||
|
func (r Repo) GetCommitFromRef(ref string) (*object.Commit, error) {
|
||||||
|
g, err := r.Git()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
hash, err := g.ResolveRevision(plumbing.Revision(ref))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return g.CommitObject(*hash)
|
||||||
|
}
|
||||||
|
|
||||||
// FileContent returns the content of a file in the git tree at a given ref/rev
|
// FileContent returns the content of a file in the git tree at a given ref/rev
|
||||||
func (r Repo) FileContent(ref, file string) (string, error) {
|
func (r Repo) FileContent(ref, file string) (string, error) {
|
||||||
t, err := r.Tree(ref)
|
t, err := r.Tree(ref)
|
||||||
|
|
|
@ -2,6 +2,7 @@ package html
|
||||||
|
|
||||||
import (
|
import (
|
||||||
_ "embed"
|
_ "embed"
|
||||||
|
"fmt"
|
||||||
|
|
||||||
. "maragu.dev/gomponents"
|
. "maragu.dev/gomponents"
|
||||||
. "maragu.dev/gomponents/html"
|
. "maragu.dev/gomponents/html"
|
||||||
|
@ -12,6 +13,8 @@ type RepoFileContext struct {
|
||||||
RepoHeaderComponentContext
|
RepoHeaderComponentContext
|
||||||
RepoBreadcrumbComponentContext
|
RepoBreadcrumbComponentContext
|
||||||
Code string
|
Code string
|
||||||
|
Commit string
|
||||||
|
Path string
|
||||||
}
|
}
|
||||||
|
|
||||||
//go:embed repo_file.js
|
//go:embed repo_file.js
|
||||||
|
@ -24,6 +27,8 @@ func RepoFileTemplate(rfc RepoFileContext) Node {
|
||||||
repoBreadcrumbComponent(rfc.RepoBreadcrumbComponentContext),
|
repoBreadcrumbComponent(rfc.RepoBreadcrumbComponentContext),
|
||||||
Text(" - "),
|
Text(" - "),
|
||||||
A(Class("text-text underline decoration-text/50 decoration-dashed hover:decoration-solid"), Href("?raw"), Text("raw")),
|
A(Class("text-text underline decoration-text/50 decoration-dashed hover:decoration-solid"), Href("?raw"), Text("raw")),
|
||||||
|
Text(" - "),
|
||||||
|
A(Class("text-text underline decoration-text/50 decoration-dashed hover:decoration-solid"), ID("permalink"), Href(fmt.Sprintf("/%s/tree/%s/%s", rfc.RepoBreadcrumbComponentContext.Repo, rfc.Commit, rfc.Path)), Text("permalink")),
|
||||||
Div(Class("code relative"),
|
Div(Class("code relative"),
|
||||||
Raw(rfc.Code),
|
Raw(rfc.Code),
|
||||||
Button(ID("copy"), Class("absolute top-0 right-0 rounded bg-base hover:bg-surface0")),
|
Button(ID("copy"), Class("absolute top-0 right-0 rounded bg-base hover:bg-surface0")),
|
||||||
|
|
|
@ -2,6 +2,7 @@ const lineRe = /#L(\d+)(?:-L(\d+))?/g
|
||||||
const $lineLines = document.querySelectorAll(".chroma .lntable .lnt");
|
const $lineLines = document.querySelectorAll(".chroma .lntable .lnt");
|
||||||
const $codeLines = document.querySelectorAll(".chroma .lntable .line");
|
const $codeLines = document.querySelectorAll(".chroma .lntable .line");
|
||||||
const $copyButton = document.getElementById('copy');
|
const $copyButton = document.getElementById('copy');
|
||||||
|
const $permalinkButton = document.getElementById('permalink');
|
||||||
const $copyIcon = "📋";
|
const $copyIcon = "📋";
|
||||||
const $copiedIcon = "✅";
|
const $copiedIcon = "✅";
|
||||||
let $code = ""
|
let $code = ""
|
||||||
|
@ -48,6 +49,18 @@ $copyButton.addEventListener("click", () => {
|
||||||
}, 1000);
|
}, 1000);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$permalinkButton.addEventListener("click", (event) => {
|
||||||
|
event.preventDefault();
|
||||||
|
const url = $permalinkButton.getAttribute("href");
|
||||||
|
navigator.clipboard.writeText(window.location.origin + url + location.hash);
|
||||||
|
|
||||||
|
const originalText = $permalinkButton.innerText;
|
||||||
|
$permalinkButton.innerText = "copied!";
|
||||||
|
setTimeout(() => {
|
||||||
|
$permalinkButton.innerText = originalText;
|
||||||
|
}, 1000);
|
||||||
|
});
|
||||||
|
|
||||||
function activateLines(start, end) {
|
function activateLines(start, end) {
|
||||||
if (end < start) end = start;
|
if (end < start) end = start;
|
||||||
for (let idx = start - 1; idx < end; idx++) {
|
for (let idx = start - 1; idx < end; idx++) {
|
||||||
|
|
|
@ -92,11 +92,21 @@ func (rh repoHandler) repoFile(w http.ResponseWriter, r *http.Request, repo *git
|
||||||
return httperr.Error(err)
|
return httperr.Error(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
commit := ref
|
||||||
|
if len(ref) < 40 {
|
||||||
|
commitObj, err := repo.GetCommitFromRef(ref)
|
||||||
|
if err == nil {
|
||||||
|
commit = commitObj.Hash.String()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if err := html.RepoFileTemplate(html.RepoFileContext{
|
if err := html.RepoFileTemplate(html.RepoFileContext{
|
||||||
BaseContext: rh.baseContext(),
|
BaseContext: rh.baseContext(),
|
||||||
RepoHeaderComponentContext: rh.repoHeaderContext(repo, r),
|
RepoHeaderComponentContext: rh.repoHeaderContext(repo, r),
|
||||||
RepoBreadcrumbComponentContext: rh.repoBreadcrumbContext(repo, r, path),
|
RepoBreadcrumbComponentContext: rh.repoBreadcrumbContext(repo, r, path),
|
||||||
Code: buf.String(),
|
Code: buf.String(),
|
||||||
|
Commit: commit,
|
||||||
|
Path: path,
|
||||||
}).Render(w); err != nil {
|
}).Render(w); err != nil {
|
||||||
return httperr.Error(err)
|
return httperr.Error(err)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue