mirror of
https://github.com/go-gitea/gitea.git
synced 2024-12-19 08:46:29 +08:00
Fix repo home file list (#32788)
1. use grid instead of table, completely drop "ui table" from that list 2. move some "commit sign" related styles into a new file by the way (no change) because I need to figure out where `#repo-files-table` is used. 3. move legacy "branch/tag selector" related code into repo-legacy.ts, now there are 13 `import $` files left.
This commit is contained in:
parent
18061af490
commit
4814f43af7
|
@ -102,8 +102,7 @@
|
||||||
{{end}}
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{{/* by default, the row-right flex grows, but on non-root tree path, it should not because the row-left might contain a long path */}}
|
<div class="repo-button-row-right">
|
||||||
<div class="repo-button-row-right {{if not $isTreePathRoot}}tw-flex-grow-0{{end}}">
|
|
||||||
<!-- Only show clone panel in repository home page -->
|
<!-- Only show clone panel in repository home page -->
|
||||||
{{if $isTreePathRoot}}
|
{{if $isTreePathRoot}}
|
||||||
{{template "repo/clone_panel" .}}
|
{{template "repo/clone_panel" .}}
|
||||||
|
@ -124,6 +123,9 @@
|
||||||
{{template "repo/code/upstream_diverging_info" .}}
|
{{template "repo/code/upstream_diverging_info" .}}
|
||||||
{{end}}
|
{{end}}
|
||||||
{{template "repo/view_list" .}}
|
{{template "repo/view_list" .}}
|
||||||
|
{{if and .ReadmeExist (or .IsMarkup .IsPlainText)}}
|
||||||
|
{{template "repo/view_file" .}}
|
||||||
|
{{end}}
|
||||||
{{end}}
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
{{if not .LatestCommit}}
|
{{if not .LatestCommit}}
|
||||||
<div class="ui active tiny slow centered inline">…</div>
|
…
|
||||||
{{else}}
|
{{else}}
|
||||||
{{if .LatestCommitUser}}
|
{{if .LatestCommitUser}}
|
||||||
{{ctx.AvatarUtils.Avatar .LatestCommitUser 24 "tw-mr-1"}}
|
{{ctx.AvatarUtils.Avatar .LatestCommitUser 24 "tw-mr-1"}}
|
||||||
|
|
|
@ -1,73 +1,57 @@
|
||||||
<table id="repo-files-table" class="ui single line fixed table tw-mt-0" {{if .HasFilesWithoutLatestCommit}}hx-indicator="tr.notready td.message span" hx-trigger="load" hx-swap="morph" hx-post="{{.LastCommitLoaderURL}}"{{end}}>
|
{{/* use grid layout, still use the old ID because there are many other CSS styles depending on this ID */}}
|
||||||
<thead>
|
<div id="repo-files-table" {{if .HasFilesWithoutLatestCommit}}hx-indicator="#repo-files-table .repo-file-cell.message" hx-trigger="load" hx-swap="morph" hx-post="{{.LastCommitLoaderURL}}"{{end}}>
|
||||||
<tr class="commit-list">
|
<div class="repo-file-line">
|
||||||
<th class="tw-overflow-hidden" colspan="2">
|
<div class="latest-commit">{{template "repo/latest_commit" .}}</div>
|
||||||
<div class="tw-flex">
|
<div>{{if and .LatestCommit .LatestCommit.Committer}}{{DateUtils.TimeSince .LatestCommit.Committer.When}}{{end}}</div>
|
||||||
<div class="latest-commit">
|
</div>
|
||||||
{{template "repo/latest_commit" .}}
|
{{if .HasParentPath}}
|
||||||
</div>
|
<div class="repo-file-line">
|
||||||
</div>
|
{{svg "octicon-reply"}} <a class="muted" href="{{.BranchLink}}{{if .ParentPath}}{{PathEscapeSegments .ParentPath}}{{end}}">..</a>
|
||||||
</th>
|
</div>
|
||||||
<th class="text grey right age">{{if .LatestCommit}}{{if .LatestCommit.Committer}}{{DateUtils.TimeSince .LatestCommit.Committer.When}}{{end}}{{end}}</th>
|
{{end}}
|
||||||
</tr>
|
{{range $item := .Files}}
|
||||||
</thead>
|
<div class="repo-file-item">
|
||||||
<tbody>
|
|
||||||
{{if .HasParentPath}}
|
|
||||||
<tr class="has-parent">
|
|
||||||
<td colspan="3">{{svg "octicon-reply"}}<a class="muted" href="{{.BranchLink}}{{if .ParentPath}}{{PathEscapeSegments .ParentPath}}{{end}}">..</a></td>
|
|
||||||
</tr>
|
|
||||||
{{end}}
|
|
||||||
{{range $item := .Files}}
|
|
||||||
{{$entry := $item.Entry}}
|
{{$entry := $item.Entry}}
|
||||||
{{$commit := $item.Commit}}
|
{{$commit := $item.Commit}}
|
||||||
{{$subModuleFile := $item.SubModuleFile}}
|
{{$subModuleFile := $item.SubModuleFile}}
|
||||||
<tr data-entryname="{{$entry.Name}}" data-ready="{{if $commit}}true{{else}}false{{end}}" class="{{if not $commit}}not{{end}}ready entry">
|
<div class="repo-file-cell name {{if not $commit}}notready{{end}}">
|
||||||
<td class="name four wide">
|
{{if $entry.IsSubModule}}
|
||||||
<span class="truncate">
|
{{svg "octicon-file-submodule"}}
|
||||||
{{if $entry.IsSubModule}}
|
{{$refURL := $subModuleFile.RefURL AppUrl $.Repository.FullName $.SSHDomain}} {{/* FIXME: the usage of AppUrl seems incorrect, it would be fixed in the future, use AppSubUrl instead */}}
|
||||||
{{svg "octicon-file-submodule"}}
|
{{if $refURL}}
|
||||||
{{$refURL := $subModuleFile.RefURL AppUrl $.Repository.FullName $.SSHDomain}} {{/* FIXME: the usage of AppUrl seems incorrect, it would be fixed in the future, use AppSubUrl instead */}}
|
<a class="muted" href="{{$refURL}}">{{$entry.Name}}</a><span class="at">@</span><a href="{{$refURL}}/commit/{{PathEscape $subModuleFile.RefID}}">{{ShortSha $subModuleFile.RefID}}</a>
|
||||||
{{if $refURL}}
|
{{else}}
|
||||||
<a class="muted" href="{{$refURL}}">{{$entry.Name}}</a><span class="at">@</span><a href="{{$refURL}}/commit/{{PathEscape $subModuleFile.RefID}}">{{ShortSha $subModuleFile.RefID}}</a>
|
{{$entry.Name}}<span class="at">@</span>{{ShortSha $subModuleFile.RefID}}
|
||||||
|
{{end}}
|
||||||
|
{{else}}
|
||||||
|
{{if $entry.IsDir}}
|
||||||
|
{{$subJumpablePathName := $entry.GetSubJumpablePathName}}
|
||||||
|
{{svg "octicon-file-directory-fill"}}
|
||||||
|
<a class="muted" href="{{$.TreeLink}}/{{PathEscapeSegments $subJumpablePathName}}" title="{{$subJumpablePathName}}">
|
||||||
|
{{$subJumpablePathFields := StringUtils.Split $subJumpablePathName "/"}}
|
||||||
|
{{$subJumpablePathFieldLast := (Eval (len $subJumpablePathFields) "-" 1)}}
|
||||||
|
{{if eq $subJumpablePathFieldLast 0}}
|
||||||
|
{{$subJumpablePathName}}
|
||||||
{{else}}
|
{{else}}
|
||||||
{{$entry.Name}}<span class="at">@</span>{{ShortSha $subModuleFile.RefID}}
|
{{$subJumpablePathPrefixes := slice $subJumpablePathFields 0 $subJumpablePathFieldLast}}
|
||||||
|
<span class="text light-2">{{StringUtils.Join $subJumpablePathPrefixes "/"}}</span>/{{index $subJumpablePathFields $subJumpablePathFieldLast}}
|
||||||
{{end}}
|
{{end}}
|
||||||
{{else}}
|
</a>
|
||||||
{{if $entry.IsDir}}
|
{{else}}
|
||||||
{{$subJumpablePathName := $entry.GetSubJumpablePathName}}
|
{{svg (printf "octicon-%s" (EntryIcon $entry))}}
|
||||||
{{svg "octicon-file-directory-fill"}}
|
<a class="muted" href="{{$.TreeLink}}/{{PathEscapeSegments $entry.Name}}" title="{{$entry.Name}}">{{$entry.Name}}</a>
|
||||||
<a class="muted" href="{{$.TreeLink}}/{{PathEscapeSegments $subJumpablePathName}}" title="{{$subJumpablePathName}}">
|
{{end}}
|
||||||
{{$subJumpablePathFields := StringUtils.Split $subJumpablePathName "/"}}
|
{{end}}
|
||||||
{{$subJumpablePathFieldLast := (Eval (len $subJumpablePathFields) "-" 1)}}
|
</div>
|
||||||
{{if eq $subJumpablePathFieldLast 0}}
|
<div class="repo-file-cell message loading-icon-2px">
|
||||||
{{$subJumpablePathName}}
|
{{if $commit}}
|
||||||
{{else}}
|
{{$commitLink := printf "%s/commit/%s" $.RepoLink (PathEscape $commit.ID.String)}}
|
||||||
{{$subJumpablePathPrefixes := slice $subJumpablePathFields 0 $subJumpablePathFieldLast}}
|
{{ctx.RenderUtils.RenderCommitMessageLinkSubject $commit.Message $commitLink ($.Repository.ComposeMetas ctx)}}
|
||||||
<span class="text light-2">{{StringUtils.Join $subJumpablePathPrefixes "/"}}</span>/{{index $subJumpablePathFields $subJumpablePathFieldLast}}
|
{{else}}
|
||||||
{{end}}
|
… {{/* will be loaded again by LastCommitLoaderURL */}}
|
||||||
</a>
|
{{end}}
|
||||||
{{else}}
|
</div>
|
||||||
{{svg (printf "octicon-%s" (EntryIcon $entry))}}
|
<div class="repo-file-cell age">{{if $commit}}{{DateUtils.TimeSince $commit.Committer.When}}{{end}}</div>
|
||||||
<a class="muted" href="{{$.TreeLink}}/{{PathEscapeSegments $entry.Name}}" title="{{$entry.Name}}">{{$entry.Name}}</a>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
{{end}}
|
</div>
|
||||||
</span>
|
|
||||||
</td>
|
|
||||||
<td class="message nine wide">
|
|
||||||
<span class="truncate">
|
|
||||||
{{if $commit}}
|
|
||||||
{{$commitLink := printf "%s/commit/%s" $.RepoLink (PathEscape $commit.ID.String)}}
|
|
||||||
{{ctx.RenderUtils.RenderCommitMessageLinkSubject $commit.Message $commitLink ($.Repository.ComposeMetas ctx)}}
|
|
||||||
{{else}}
|
|
||||||
<div class="ui active tiny slow centered inline"></div>
|
|
||||||
{{end}}
|
|
||||||
</span>
|
|
||||||
</td>
|
|
||||||
<td class="text right age three wide">{{if $commit}}{{DateUtils.TimeSince $commit.Committer.When}}{{end}}</td>
|
|
||||||
</tr>
|
|
||||||
{{end}}
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
{{if and .ReadmeExist (or .IsMarkup .IsPlainText)}}
|
|
||||||
{{template "repo/view_file" .}}
|
|
||||||
{{end}}
|
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
{{$title := .title}}
|
{{$title := .title}}
|
||||||
<div class="ui container">
|
<div class="ui container">
|
||||||
<div class="repo-button-row">
|
<div class="repo-button-row">
|
||||||
<div class="tw-flex tw-items-center">
|
<div class="flex-text-block tw-flex-1">
|
||||||
<div class="ui floating filter dropdown" data-no-results="{{ctx.Locale.Tr "no_results_found"}}">
|
<div class="ui floating filter dropdown" data-no-results="{{ctx.Locale.Tr "no_results_found"}}">
|
||||||
<div class="ui basic small button">
|
<div class="ui basic small button">
|
||||||
<span class="text">
|
<span class="text">
|
||||||
|
@ -42,7 +42,7 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex-text-block tw-flex-wrap tw-justify-end">
|
<div class="repo-button-row">
|
||||||
{{if .EscapeStatus.Escaped}}
|
{{if .EscapeStatus.Escaped}}
|
||||||
<a class="ui small button unescape-button tw-m-0 tw-hidden">{{ctx.Locale.Tr "repo.unescape_control_characters"}}</a>
|
<a class="ui small button unescape-button tw-m-0 tw-hidden">{{ctx.Locale.Tr "repo.unescape_control_characters"}}</a>
|
||||||
<a class="ui small button escape-button tw-m-0">{{ctx.Locale.Tr "repo.escape_control_characters"}}</a>
|
<a class="ui small button escape-button tw-m-0">{{ctx.Locale.Tr "repo.escape_control_characters"}}</a>
|
||||||
|
|
|
@ -49,7 +49,7 @@ func testViewRepo(t *testing.T) {
|
||||||
resp := session.MakeRequest(t, req, http.StatusOK)
|
resp := session.MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
htmlDoc := NewHTMLParser(t, resp.Body)
|
htmlDoc := NewHTMLParser(t, resp.Body)
|
||||||
files := htmlDoc.doc.Find("#repo-files-table > TBODY > TR")
|
files := htmlDoc.doc.Find("#repo-files-table .repo-file-item")
|
||||||
|
|
||||||
type file struct {
|
type file struct {
|
||||||
fileName string
|
fileName string
|
||||||
|
@ -61,7 +61,7 @@ func testViewRepo(t *testing.T) {
|
||||||
var items []file
|
var items []file
|
||||||
|
|
||||||
files.Each(func(i int, s *goquery.Selection) {
|
files.Each(func(i int, s *goquery.Selection) {
|
||||||
tds := s.Find("td")
|
tds := s.Find(".repo-file-cell")
|
||||||
var f file
|
var f file
|
||||||
tds.Each(func(i int, s *goquery.Selection) {
|
tds.Each(func(i int, s *goquery.Selection) {
|
||||||
if i == 0 {
|
if i == 0 {
|
||||||
|
@ -161,7 +161,7 @@ func TestViewRepoWithSymlinks(t *testing.T) {
|
||||||
resp := session.MakeRequest(t, req, http.StatusOK)
|
resp := session.MakeRequest(t, req, http.StatusOK)
|
||||||
|
|
||||||
htmlDoc := NewHTMLParser(t, resp.Body)
|
htmlDoc := NewHTMLParser(t, resp.Body)
|
||||||
files := htmlDoc.doc.Find("#repo-files-table > TBODY > TR > TD.name > SPAN.truncate")
|
files := htmlDoc.doc.Find("#repo-files-table .repo-file-cell.name")
|
||||||
items := files.Map(func(i int, s *goquery.Selection) string {
|
items := files.Map(func(i int, s *goquery.Selection) string {
|
||||||
cls, _ := s.Find("SVG").Attr("class")
|
cls, _ := s.Find("SVG").Attr("class")
|
||||||
file := strings.Trim(s.Find("A").Text(), " \t\n")
|
file := strings.Trim(s.Find("A").Text(), " \t\n")
|
||||||
|
|
|
@ -66,8 +66,10 @@
|
||||||
@import "./repo/wiki.css";
|
@import "./repo/wiki.css";
|
||||||
@import "./repo/header.css";
|
@import "./repo/header.css";
|
||||||
@import "./repo/home.css";
|
@import "./repo/home.css";
|
||||||
|
@import "./repo/home-file-list.css";
|
||||||
@import "./repo/reactions.css";
|
@import "./repo/reactions.css";
|
||||||
@import "./repo/clone.css";
|
@import "./repo/clone.css";
|
||||||
|
@import "./repo/commit-sign.css";
|
||||||
|
|
||||||
@import "./editor/fileeditor.css";
|
@import "./editor/fileeditor.css";
|
||||||
@import "./editor/combomarkdowneditor.css";
|
@import "./editor/combomarkdowneditor.css";
|
||||||
|
|
|
@ -141,138 +141,6 @@ td .commit-summary {
|
||||||
overflow-wrap: anywhere;
|
overflow-wrap: anywhere;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* this is what limits the commit table width to a value that works on all viewport sizes */
|
|
||||||
#repo-files-table th:first-of-type {
|
|
||||||
max-width: calc(calc(min(100vw, 1280px)) - 145px - calc(2 * var(--page-margin-x)));
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table thead th {
|
|
||||||
font-weight: var(--font-weight-normal);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tbody .svg {
|
|
||||||
margin-left: 3px;
|
|
||||||
margin-right: 5px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tbody .svg.octicon-reply {
|
|
||||||
margin-right: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tbody .svg.octicon-file-directory-fill,
|
|
||||||
.repository.file.list #repo-files-table tbody .svg.octicon-file-submodule {
|
|
||||||
color: var(--color-primary);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tbody .svg.octicon-file,
|
|
||||||
.repository.file.list #repo-files-table tbody .svg.octicon-file-symlink-file,
|
|
||||||
.repository.file.list #repo-files-table tbody .svg.octicon-file-directory-symlink {
|
|
||||||
color: var(--color-secondary-dark-7);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td {
|
|
||||||
padding-top: 0;
|
|
||||||
padding-bottom: 0;
|
|
||||||
overflow: initial;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td.name {
|
|
||||||
width: 33%;
|
|
||||||
max-width: calc(100vw - 140px);
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 1201px) {
|
|
||||||
.repository.file.list #repo-files-table td.name {
|
|
||||||
max-width: 150px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 992px) and (max-width: 1200px) {
|
|
||||||
.repository.file.list #repo-files-table td.name {
|
|
||||||
max-width: 200px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 768px) and (max-width: 991.98px) {
|
|
||||||
.repository.file.list #repo-files-table td.name {
|
|
||||||
max-width: 300px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td.message {
|
|
||||||
color: var(--color-text-light-1);
|
|
||||||
width: 66%;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 1201px) {
|
|
||||||
.repository.file.list #repo-files-table td.message {
|
|
||||||
max-width: 400px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 992px) and (max-width: 1200px) {
|
|
||||||
.repository.file.list #repo-files-table td.message {
|
|
||||||
max-width: 350px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 768px) and (max-width: 991.98px) {
|
|
||||||
.repository.file.list #repo-files-table td.message {
|
|
||||||
max-width: 250px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td.age {
|
|
||||||
color: var(--color-text-light-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td .truncate {
|
|
||||||
display: inline-block;
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
width: 100%;
|
|
||||||
padding-top: 8px;
|
|
||||||
padding-bottom: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td a {
|
|
||||||
padding-top: 8px;
|
|
||||||
padding-bottom: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td .at {
|
|
||||||
margin-left: 3px;
|
|
||||||
margin-right: 3px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td > * {
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table td.message .isSigned {
|
|
||||||
cursor: default;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tr:last-of-type td:first-child {
|
|
||||||
border-bottom-left-radius: var(--border-radius);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tr:last-of-type td:last-child {
|
|
||||||
border-bottom-right-radius: var(--border-radius);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tr:hover {
|
|
||||||
background-color: var(--color-hover);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list #repo-files-table tr.has-parent a {
|
|
||||||
display: inline-block;
|
|
||||||
padding-top: 8px;
|
|
||||||
padding-bottom: 8px;
|
|
||||||
width: calc(100% - 1.25rem);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.file.list .non-diff-file-content .header .icon {
|
.repository.file.list .non-diff-file-content .header .icon {
|
||||||
font-size: 1em;
|
font-size: 1em;
|
||||||
}
|
}
|
||||||
|
@ -751,47 +619,6 @@ td .commit-summary {
|
||||||
height: 30px !important;
|
height: 30px !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label {
|
|
||||||
margin: 0;
|
|
||||||
border: 1px solid var(--color-light-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isWarning {
|
|
||||||
border: 1px solid var(--color-red-badge);
|
|
||||||
background: var(--color-red-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isWarning:hover {
|
|
||||||
background: var(--color-red-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isVerified {
|
|
||||||
border: 1px solid var(--color-green-badge);
|
|
||||||
background: var(--color-green-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isVerified:hover {
|
|
||||||
background: var(--color-green-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isVerifiedUntrusted {
|
|
||||||
border: 1px solid var(--color-yellow-badge);
|
|
||||||
background: var(--color-yellow-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isVerifiedUntrusted:hover {
|
|
||||||
background: var(--color-yellow-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isVerifiedUnmatched {
|
|
||||||
border: 1px solid var(--color-orange-badge);
|
|
||||||
background: var(--color-orange-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.singular-commit .shabox .sha.label.isSigned.isVerifiedUnmatched:hover {
|
|
||||||
background: var(--color-orange-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository.view.issue .comment-list .timeline-item.event > .commit-status-link {
|
.repository.view.issue .comment-list .timeline-item.event > .commit-status-link {
|
||||||
float: right;
|
float: right;
|
||||||
margin-right: 8px;
|
margin-right: 8px;
|
||||||
|
@ -1126,151 +953,6 @@ td .commit-summary {
|
||||||
background-color: var(--color-light) !important;
|
background-color: var(--color-light) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label,
|
|
||||||
.repository #repo-files-table .sha.label,
|
|
||||||
.repository #repo-file-commit-box .sha.label,
|
|
||||||
.repository #rev-list .sha.label,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label {
|
|
||||||
border: 1px solid var(--color-light-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label .detail.icon,
|
|
||||||
.repository #repo-files-table .sha.label .detail.icon,
|
|
||||||
.repository #repo-file-commit-box .sha.label .detail.icon,
|
|
||||||
.repository #rev-list .sha.label .detail.icon,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label .detail.icon {
|
|
||||||
background: var(--color-light);
|
|
||||||
margin: -6px -10px -4px 0;
|
|
||||||
padding: 5px 4px 5px 6px;
|
|
||||||
border-left: 1px solid var(--color-light-border);
|
|
||||||
border-top: 0;
|
|
||||||
border-right: 0;
|
|
||||||
border-bottom: 0;
|
|
||||||
border-top-left-radius: 0;
|
|
||||||
border-bottom-left-radius: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label .detail.icon .svg,
|
|
||||||
.repository #repo-files-table .sha.label .detail.icon .svg,
|
|
||||||
.repository #repo-file-commit-box .sha.label .detail.icon .svg,
|
|
||||||
.repository #rev-list .sha.label .detail.icon .svg,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label .detail.icon .svg {
|
|
||||||
margin: 0 0.25em 0 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label .detail.icon > div,
|
|
||||||
.repository #repo-files-table .sha.label .detail.icon > div,
|
|
||||||
.repository #repo-file-commit-box .sha.label .detail.icon > div,
|
|
||||||
.repository #rev-list .sha.label .detail.icon > div,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label .detail.icon > div {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isWarning,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isWarning,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isWarning,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isWarning,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isWarning {
|
|
||||||
border: 1px solid var(--color-red-badge);
|
|
||||||
background: var(--color-red-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isWarning .detail.icon,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isWarning .detail.icon,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isWarning .detail.icon,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isWarning .detail.icon,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isWarning .detail.icon {
|
|
||||||
border-left: 1px solid var(--color-red-badge);
|
|
||||||
color: var(--color-red-badge);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isWarning:hover,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isWarning:hover,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isWarning:hover,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isWarning:hover,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isWarning:hover {
|
|
||||||
background: var(--color-red-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerified,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerified,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerified,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerified,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerified {
|
|
||||||
border: 1px solid var(--color-green-badge);
|
|
||||||
background: var(--color-green-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerified .detail.icon,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerified .detail.icon,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerified .detail.icon,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerified .detail.icon,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerified .detail.icon {
|
|
||||||
border-left: 1px solid var(--color-green-badge);
|
|
||||||
color: var(--color-green-badge);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerified:hover,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerified:hover,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerified:hover,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerified:hover,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerified:hover {
|
|
||||||
background: var(--color-green-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUntrusted,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerifiedUntrusted,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUntrusted,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerifiedUntrusted,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUntrusted {
|
|
||||||
border: 1px solid var(--color-yellow-badge);
|
|
||||||
background: var(--color-yellow-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUntrusted .detail.icon {
|
|
||||||
border-left: 1px solid var(--color-yellow-badge);
|
|
||||||
color: var(--color-yellow-badge);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUntrusted:hover,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerifiedUntrusted:hover,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUntrusted:hover,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerifiedUntrusted:hover,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUntrusted:hover {
|
|
||||||
background: var(--color-yellow-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUnmatched,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerifiedUnmatched,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUnmatched,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerifiedUnmatched,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUnmatched {
|
|
||||||
border: 1px solid var(--color-orange-badge);
|
|
||||||
background: var(--color-orange-badge-bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUnmatched .detail.icon {
|
|
||||||
border-left: 1px solid var(--color-orange-badge);
|
|
||||||
color: var(--color-orange-badge);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUnmatched:hover,
|
|
||||||
.repository #repo-files-table .sha.label.isSigned.isVerifiedUnmatched:hover,
|
|
||||||
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUnmatched:hover,
|
|
||||||
.repository #rev-list .sha.label.isSigned.isVerifiedUnmatched:hover,
|
|
||||||
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUnmatched:hover {
|
|
||||||
background: var(--color-orange-badge-hover-bg) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .data-table {
|
.repository .data-table {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
@ -1634,92 +1316,6 @@ td .commit-summary {
|
||||||
padding-top: 0;
|
padding-top: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isWarning {
|
|
||||||
border-left: 1px solid var(--color-error-border);
|
|
||||||
border-right: 1px solid var(--color-error-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isWarning.top,
|
|
||||||
.repository .ui.attached.isSigned.isWarning.message {
|
|
||||||
border-top: 1px solid var(--color-error-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isWarning.message {
|
|
||||||
box-shadow: none;
|
|
||||||
background-color: var(--color-error-bg);
|
|
||||||
color: var(--color-error-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isWarning.message .ui.text {
|
|
||||||
color: var(--color-error-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isWarning:last-child,
|
|
||||||
.repository .ui.attached.isSigned.isWarning.bottom {
|
|
||||||
border-bottom: 1px solid var(--color-error-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerified {
|
|
||||||
border-left: 1px solid var(--color-success-border);
|
|
||||||
border-right: 1px solid var(--color-success-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerified.top,
|
|
||||||
.repository .ui.attached.isSigned.isVerified.message {
|
|
||||||
border-top: 1px solid var(--color-success-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerified.message {
|
|
||||||
box-shadow: none;
|
|
||||||
background-color: var(--color-success-bg);
|
|
||||||
color: var(--color-success-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerified.message .pull-right {
|
|
||||||
color: var(--color-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerified.message .ui.text {
|
|
||||||
color: var(--color-success-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerified:last-child,
|
|
||||||
.repository .ui.attached.isSigned.isVerified.bottom {
|
|
||||||
border-bottom: 1px solid var(--color-success-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUntrusted,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUnmatched {
|
|
||||||
border-left: 1px solid var(--color-warning-border);
|
|
||||||
border-right: 1px solid var(--color-warning-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUntrusted.top,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUnmatched.top,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUntrusted.message,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUnmatched.message {
|
|
||||||
border-top: 1px solid var(--color-warning-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUntrusted.message,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUnmatched.message {
|
|
||||||
box-shadow: none;
|
|
||||||
background-color: var(--color-warning-bg);
|
|
||||||
color: var(--color-warning-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUntrusted.message .ui.text,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUnmatched.message .ui.text {
|
|
||||||
color: var(--color-warning-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUntrusted:last-child,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUnmatched:last-child,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUntrusted.bottom,
|
|
||||||
.repository .ui.attached.isSigned.isVerifiedUnmatched.bottom {
|
|
||||||
border-bottom: 1px solid var(--color-warning-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
.repository .ui.fluid.action.input .ui.search.action.input {
|
.repository .ui.fluid.action.input .ui.search.action.input {
|
||||||
flex: auto;
|
flex: auto;
|
||||||
}
|
}
|
||||||
|
@ -1738,7 +1334,7 @@ td .commit-summary {
|
||||||
|
|
||||||
.repository .repository-summary .sub-menu .item {
|
.repository .repository-summary .sub-menu .item {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
height: 30px;
|
height: 33px; /* match search bar height, need to be improved in the future to use some consistent methods */
|
||||||
line-height: var(--line-height-default);
|
line-height: var(--line-height-default);
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
@ -2066,26 +1662,18 @@ td .commit-summary {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
gap: 8px;
|
gap: 8px;
|
||||||
justify-content: space-between;
|
flex-wrap: wrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
.repo-button-row-left,
|
.repo-button-row-left,
|
||||||
.repo-button-row-right {
|
.repo-button-row-right {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex: 1;
|
|
||||||
align-items: center;
|
align-items: center;
|
||||||
gap: 0.5rem;
|
gap: 0.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.repo-button-row-right {
|
.repo-button-row-left {
|
||||||
justify-content: flex-end;
|
flex: 1;
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 1200px) {
|
|
||||||
.repository:not(.wiki) .repo-button-row {
|
|
||||||
flex-direction: column;
|
|
||||||
align-items: stretch;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.repo-button-row .button {
|
.repo-button-row .button {
|
||||||
|
@ -2099,16 +1687,6 @@ td .commit-summary {
|
||||||
padding-right: 22px !important; /* normal buttons have !important paddings, so we need to override it for dropdown (Add File) icons */
|
padding-right: 22px !important; /* normal buttons have !important paddings, so we need to override it for dropdown (Add File) icons */
|
||||||
}
|
}
|
||||||
|
|
||||||
.repo-button-row input {
|
|
||||||
height: 30px;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 600px) {
|
|
||||||
.repo-button-row-left {
|
|
||||||
flex-wrap: wrap;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody.commit-list {
|
tbody.commit-list {
|
||||||
vertical-align: baseline;
|
vertical-align: baseline;
|
||||||
}
|
}
|
||||||
|
@ -2134,11 +1712,6 @@ tbody.commit-list {
|
||||||
overflow-wrap: anywhere;
|
overflow-wrap: anywhere;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* but in the repo-files-table we cannot */
|
|
||||||
#repo-files-table .commit-list .message-wrapper {
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 767.98px) {
|
@media (max-width: 767.98px) {
|
||||||
tr.commit-list {
|
tr.commit-list {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
@ -2534,25 +2107,6 @@ tbody.commit-list {
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-width: 767.98px) {
|
@media (max-width: 767.98px) {
|
||||||
.repository.file.list #repo-files-table .entry,
|
|
||||||
.repository.file.list #repo-files-table .commit-list {
|
|
||||||
align-items: center;
|
|
||||||
display: flex !important;
|
|
||||||
padding-top: 4px;
|
|
||||||
padding-bottom: 4px;
|
|
||||||
}
|
|
||||||
.repository.file.list #repo-files-table .entry td.age,
|
|
||||||
.repository.file.list #repo-files-table .commit-list td.age,
|
|
||||||
.repository.file.list #repo-files-table .entry th.age,
|
|
||||||
.repository.file.list #repo-files-table .commit-list th.age {
|
|
||||||
margin-left: auto;
|
|
||||||
}
|
|
||||||
.repository.file.list #repo-files-table .entry td.message,
|
|
||||||
.repository.file.list #repo-files-table .commit-list td.message,
|
|
||||||
.repository.file.list #repo-files-table .entry span.commit-summary,
|
|
||||||
.repository.file.list #repo-files-table .commit-list tr span.commit-summary {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
.repository.view.issue .comment-list .timeline,
|
.repository.view.issue .comment-list .timeline,
|
||||||
.repository.view.issue .comment-list .timeline-item {
|
.repository.view.issue .comment-list .timeline-item {
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
|
|
272
web_src/css/repo/commit-sign.css
Normal file
272
web_src/css/repo/commit-sign.css
Normal file
|
@ -0,0 +1,272 @@
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isWarning {
|
||||||
|
border-left: 1px solid var(--color-error-border);
|
||||||
|
border-right: 1px solid var(--color-error-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isWarning.top,
|
||||||
|
.repository .ui.attached.isSigned.isWarning.message {
|
||||||
|
border-top: 1px solid var(--color-error-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isWarning.message {
|
||||||
|
box-shadow: none;
|
||||||
|
background-color: var(--color-error-bg);
|
||||||
|
color: var(--color-error-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isWarning.message .ui.text {
|
||||||
|
color: var(--color-error-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isWarning:last-child,
|
||||||
|
.repository .ui.attached.isSigned.isWarning.bottom {
|
||||||
|
border-bottom: 1px solid var(--color-error-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerified {
|
||||||
|
border-left: 1px solid var(--color-success-border);
|
||||||
|
border-right: 1px solid var(--color-success-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerified.top,
|
||||||
|
.repository .ui.attached.isSigned.isVerified.message {
|
||||||
|
border-top: 1px solid var(--color-success-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerified.message {
|
||||||
|
box-shadow: none;
|
||||||
|
background-color: var(--color-success-bg);
|
||||||
|
color: var(--color-success-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerified.message .pull-right {
|
||||||
|
color: var(--color-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerified.message .ui.text {
|
||||||
|
color: var(--color-success-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerified:last-child,
|
||||||
|
.repository .ui.attached.isSigned.isVerified.bottom {
|
||||||
|
border-bottom: 1px solid var(--color-success-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUntrusted,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUnmatched {
|
||||||
|
border-left: 1px solid var(--color-warning-border);
|
||||||
|
border-right: 1px solid var(--color-warning-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUntrusted.top,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUnmatched.top,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUntrusted.message,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUnmatched.message {
|
||||||
|
border-top: 1px solid var(--color-warning-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUntrusted.message,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUnmatched.message {
|
||||||
|
box-shadow: none;
|
||||||
|
background-color: var(--color-warning-bg);
|
||||||
|
color: var(--color-warning-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUntrusted.message .ui.text,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUnmatched.message .ui.text {
|
||||||
|
color: var(--color-warning-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUntrusted:last-child,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUnmatched:last-child,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUntrusted.bottom,
|
||||||
|
.repository .ui.attached.isSigned.isVerifiedUnmatched.bottom {
|
||||||
|
border-bottom: 1px solid var(--color-warning-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label,
|
||||||
|
.repository #repo-files-table .sha.label,
|
||||||
|
.repository #repo-file-commit-box .sha.label,
|
||||||
|
.repository #rev-list .sha.label,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label {
|
||||||
|
border: 1px solid var(--color-light-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label .detail.icon,
|
||||||
|
.repository #repo-files-table .sha.label .detail.icon,
|
||||||
|
.repository #repo-file-commit-box .sha.label .detail.icon,
|
||||||
|
.repository #rev-list .sha.label .detail.icon,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label .detail.icon {
|
||||||
|
background: var(--color-light);
|
||||||
|
margin: -6px -10px -4px 0;
|
||||||
|
padding: 5px 4px 5px 6px;
|
||||||
|
border-left: 1px solid var(--color-light-border);
|
||||||
|
border-top: 0;
|
||||||
|
border-right: 0;
|
||||||
|
border-bottom: 0;
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label .detail.icon .svg,
|
||||||
|
.repository #repo-files-table .sha.label .detail.icon .svg,
|
||||||
|
.repository #repo-file-commit-box .sha.label .detail.icon .svg,
|
||||||
|
.repository #rev-list .sha.label .detail.icon .svg,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label .detail.icon .svg {
|
||||||
|
margin: 0 0.25em 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label .detail.icon > div,
|
||||||
|
.repository #repo-files-table .sha.label .detail.icon > div,
|
||||||
|
.repository #repo-file-commit-box .sha.label .detail.icon > div,
|
||||||
|
.repository #rev-list .sha.label .detail.icon > div,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label .detail.icon > div {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isWarning,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isWarning,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isWarning,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isWarning,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isWarning {
|
||||||
|
border: 1px solid var(--color-red-badge);
|
||||||
|
background: var(--color-red-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isWarning .detail.icon,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isWarning .detail.icon,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isWarning .detail.icon,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isWarning .detail.icon,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isWarning .detail.icon {
|
||||||
|
border-left: 1px solid var(--color-red-badge);
|
||||||
|
color: var(--color-red-badge);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isWarning:hover,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isWarning:hover,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isWarning:hover,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isWarning:hover,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isWarning:hover {
|
||||||
|
background: var(--color-red-badge-hover-bg) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerified,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerified,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerified,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerified,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerified {
|
||||||
|
border: 1px solid var(--color-green-badge);
|
||||||
|
background: var(--color-green-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerified .detail.icon,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerified .detail.icon,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerified .detail.icon,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerified .detail.icon,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerified .detail.icon {
|
||||||
|
border-left: 1px solid var(--color-green-badge);
|
||||||
|
color: var(--color-green-badge);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerified:hover,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerified:hover,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerified:hover,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerified:hover,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerified:hover {
|
||||||
|
background: var(--color-green-badge-hover-bg) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUntrusted,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerifiedUntrusted,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUntrusted,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerifiedUntrusted,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUntrusted {
|
||||||
|
border: 1px solid var(--color-yellow-badge);
|
||||||
|
background: var(--color-yellow-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerifiedUntrusted .detail.icon,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUntrusted .detail.icon {
|
||||||
|
border-left: 1px solid var(--color-yellow-badge);
|
||||||
|
color: var(--color-yellow-badge);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUntrusted:hover,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerifiedUntrusted:hover,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUntrusted:hover,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerifiedUntrusted:hover,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUntrusted:hover {
|
||||||
|
background: var(--color-yellow-badge-hover-bg) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUnmatched,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerifiedUnmatched,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUnmatched,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerifiedUnmatched,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUnmatched {
|
||||||
|
border: 1px solid var(--color-orange-badge);
|
||||||
|
background: var(--color-orange-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerifiedUnmatched .detail.icon,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUnmatched .detail.icon {
|
||||||
|
border-left: 1px solid var(--color-orange-badge);
|
||||||
|
color: var(--color-orange-badge);
|
||||||
|
}
|
||||||
|
|
||||||
|
.repository #commits-table td.sha .sha.label.isSigned.isVerifiedUnmatched:hover,
|
||||||
|
.repository #repo-files-table .sha.label.isSigned.isVerifiedUnmatched:hover,
|
||||||
|
.repository #repo-file-commit-box .sha.label.isSigned.isVerifiedUnmatched:hover,
|
||||||
|
.repository #rev-list .sha.label.isSigned.isVerifiedUnmatched:hover,
|
||||||
|
.repository .timeline-item.commits-list .singular-commit .sha.label.isSigned.isVerifiedUnmatched:hover {
|
||||||
|
background: var(--color-orange-badge-hover-bg) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label {
|
||||||
|
margin: 0;
|
||||||
|
border: 1px solid var(--color-light-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isWarning {
|
||||||
|
border: 1px solid var(--color-red-badge);
|
||||||
|
background: var(--color-red-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isWarning:hover {
|
||||||
|
background: var(--color-red-badge-hover-bg) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isVerified {
|
||||||
|
border: 1px solid var(--color-green-badge);
|
||||||
|
background: var(--color-green-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isVerified:hover {
|
||||||
|
background: var(--color-green-badge-hover-bg) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isVerifiedUntrusted {
|
||||||
|
border: 1px solid var(--color-yellow-badge);
|
||||||
|
background: var(--color-yellow-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isVerifiedUntrusted:hover {
|
||||||
|
background: var(--color-yellow-badge-hover-bg) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isVerifiedUnmatched {
|
||||||
|
border: 1px solid var(--color-orange-badge);
|
||||||
|
background: var(--color-orange-badge-bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.singular-commit .shabox .sha.label.isSigned.isVerifiedUnmatched:hover {
|
||||||
|
background: var(--color-orange-badge-hover-bg) !important;
|
||||||
|
}
|
70
web_src/css/repo/home-file-list.css
Normal file
70
web_src/css/repo/home-file-list.css
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
#repo-files-table {
|
||||||
|
width: 100%;
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: auto 1fr auto;
|
||||||
|
border: 1px solid var(--color-light-border);
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
margin: 10px 0; /* match the "clone-panel-popup" margin to avoid "visual double-border" */
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .svg.octicon-file-directory-fill,
|
||||||
|
#repo-files-table .svg.octicon-file-submodule {
|
||||||
|
color: var(--color-primary);
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .svg.octicon-file,
|
||||||
|
#repo-files-table .svg.octicon-file-symlink-file,
|
||||||
|
#repo-files-table .svg.octicon-file-directory-symlink {
|
||||||
|
color: var(--color-secondary-dark-7);
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-item {
|
||||||
|
display: contents;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-item:hover > .repo-file-cell {
|
||||||
|
background: var(--color-hover);
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-line,
|
||||||
|
#repo-files-table .repo-file-cell {
|
||||||
|
border-top: 1px solid var(--color-light-border);
|
||||||
|
padding: 6px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-line:first-child {
|
||||||
|
border-top: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-line {
|
||||||
|
grid-column: 1 / span 3;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
gap: 0.5em;
|
||||||
|
padding: 6px 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-cell.name {
|
||||||
|
max-width: 300px;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-cell.message {
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
color: var(--color-text-light-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
#repo-files-table .repo-file-cell.age {
|
||||||
|
white-space: nowrap;
|
||||||
|
color: var(--color-text-light-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 767.98px) {
|
||||||
|
#repo-files-table .repo-file-cell.name {
|
||||||
|
max-width: 150px;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,5 +1,4 @@
|
||||||
import $ from 'jquery';
|
import {queryElems} from '../utils/dom.ts';
|
||||||
import {hideElem, queryElems, showElem} from '../utils/dom.ts';
|
|
||||||
import {POST} from '../modules/fetch.ts';
|
import {POST} from '../modules/fetch.ts';
|
||||||
import {showErrorToast} from '../modules/toast.ts';
|
import {showErrorToast} from '../modules/toast.ts';
|
||||||
import {sleep} from '../utils.ts';
|
import {sleep} from '../utils.ts';
|
||||||
|
@ -92,6 +91,8 @@ function initCloneSchemeUrlSelection(parent: Element) {
|
||||||
|
|
||||||
function initClonePanelButton(btn: HTMLButtonElement) {
|
function initClonePanelButton(btn: HTMLButtonElement) {
|
||||||
const elPanel = btn.nextElementSibling;
|
const elPanel = btn.nextElementSibling;
|
||||||
|
// "init" must be before the "createTippy" otherwise the "tippy-target" will be removed from the document
|
||||||
|
initCloneSchemeUrlSelection(elPanel);
|
||||||
createTippy(btn, {
|
createTippy(btn, {
|
||||||
content: elPanel,
|
content: elPanel,
|
||||||
trigger: 'click',
|
trigger: 'click',
|
||||||
|
@ -99,7 +100,6 @@ function initClonePanelButton(btn: HTMLButtonElement) {
|
||||||
interactive: true,
|
interactive: true,
|
||||||
hideOnClick: true,
|
hideOnClick: true,
|
||||||
});
|
});
|
||||||
initCloneSchemeUrlSelection(elPanel);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function initRepoCloneButtons() {
|
export function initRepoCloneButtons() {
|
||||||
|
@ -107,33 +107,6 @@ export function initRepoCloneButtons() {
|
||||||
queryElems(document, '.clone-buttons-combo', initCloneSchemeUrlSelection);
|
queryElems(document, '.clone-buttons-combo', initCloneSchemeUrlSelection);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function initRepoCommonBranchOrTagDropdown(selector: string) {
|
|
||||||
$(selector).each(function () {
|
|
||||||
const $dropdown = $(this);
|
|
||||||
$dropdown.find('.reference.column').on('click', function () {
|
|
||||||
hideElem($dropdown.find('.scrolling.reference-list-menu'));
|
|
||||||
showElem($($(this).data('target')));
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
export function initRepoCommonFilterSearchDropdown(selector: string) {
|
|
||||||
const $dropdown = $(selector);
|
|
||||||
if (!$dropdown.length) return;
|
|
||||||
|
|
||||||
$dropdown.dropdown({
|
|
||||||
fullTextSearch: 'exact',
|
|
||||||
selectOnKeydown: false,
|
|
||||||
onChange(_text, _value, $choice) {
|
|
||||||
if ($choice[0].getAttribute('data-url')) {
|
|
||||||
window.location.href = $choice[0].getAttribute('data-url');
|
|
||||||
}
|
|
||||||
},
|
|
||||||
message: {noResults: $dropdown[0].getAttribute('data-no-results')},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
export async function updateIssuesMeta(url, action, issue_ids, id) {
|
export async function updateIssuesMeta(url, action, issue_ids, id) {
|
||||||
try {
|
try {
|
||||||
const response = await POST(url, {data: new URLSearchParams({action, issue_ids, id})});
|
const response = await POST(url, {data: new URLSearchParams({action, issue_ids, id})});
|
||||||
|
|
|
@ -8,9 +8,7 @@ import {
|
||||||
} from './repo-issue.ts';
|
} from './repo-issue.ts';
|
||||||
import {initUnicodeEscapeButton} from './repo-unicode-escape.ts';
|
import {initUnicodeEscapeButton} from './repo-unicode-escape.ts';
|
||||||
import {initRepoBranchTagSelector} from '../components/RepoBranchTagSelector.vue';
|
import {initRepoBranchTagSelector} from '../components/RepoBranchTagSelector.vue';
|
||||||
import {
|
import {initRepoCloneButtons} from './repo-common.ts';
|
||||||
initRepoCloneButtons, initRepoCommonBranchOrTagDropdown, initRepoCommonFilterSearchDropdown,
|
|
||||||
} from './repo-common.ts';
|
|
||||||
import {initCitationFileCopyContent} from './citation.ts';
|
import {initCitationFileCopyContent} from './citation.ts';
|
||||||
import {initCompLabelEdit} from './comp/LabelEdit.ts';
|
import {initCompLabelEdit} from './comp/LabelEdit.ts';
|
||||||
import {initRepoDiffConversationNav} from './repo-diff.ts';
|
import {initRepoDiffConversationNav} from './repo-diff.ts';
|
||||||
|
@ -36,6 +34,33 @@ export function initBranchSelectorTabs() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function initRepoCommonBranchOrTagDropdown(selector: string) {
|
||||||
|
$(selector).each(function () {
|
||||||
|
const $dropdown = $(this);
|
||||||
|
$dropdown.find('.reference.column').on('click', function () {
|
||||||
|
hideElem($dropdown.find('.scrolling.reference-list-menu'));
|
||||||
|
showElem($($(this).data('target')));
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function initRepoCommonFilterSearchDropdown(selector: string) {
|
||||||
|
const $dropdown = $(selector);
|
||||||
|
if (!$dropdown.length) return;
|
||||||
|
|
||||||
|
$dropdown.dropdown({
|
||||||
|
fullTextSearch: 'exact',
|
||||||
|
selectOnKeydown: false,
|
||||||
|
onChange(_text, _value, $choice) {
|
||||||
|
if ($choice[0].getAttribute('data-url')) {
|
||||||
|
window.location.href = $choice[0].getAttribute('data-url');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
message: {noResults: $dropdown[0].getAttribute('data-no-results')},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
export function initRepository() {
|
export function initRepository() {
|
||||||
if (!$('.page-content.repository').length) return;
|
if (!$('.page-content.repository').length) return;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user