e24f651c86
So I found this [linter](https://github.com/Riverside-Healthcare/djlint) which features a mode for go templates, so I gave it a try and it did find a number of valid issue, like unbalanced tags etc. It also has a number of bugs, I had to disable/workaround many issues. Given that this linter is written in python, this does add a dependency on `python` >= 3.8 and `poetry` to the development environment to be able to run this linter locally. - `e.g.` prefixes on placeholders are removed because the linter had a false-positive on `placeholder="e.g. cn=Search"` for the `attr=value` syntax and it's not ideal anyways to write `e.g.` into a placeholder because a placeholder is meant to hold a sample value. - In `templates/repo/settings/options.tmpl` I simplified the logic to not conditionally create opening tags without closing tags because this stuff confuses the linter (and possibly the reader as well).
126 lines
5.2 KiB
Handlebars
126 lines
5.2 KiB
Handlebars
<div role="main" aria-label="{{.Title}}" class="page-content user notification" id="notification_div" data-params="{{.Page.GetParams}}" data-sequence-number="{{.SequenceNumber}}">
|
|
<div class="ui container">
|
|
{{$notificationUnreadCount := call .NotificationUnreadCount}}
|
|
<div class="gt-df gt-ac gt-sb gt-mb-4">
|
|
<div class="small-menu-items ui compact tiny menu">
|
|
<a class="{{if eq .Status 1}}active {{end}}item" href="{{AppSubUrl}}/notifications?q=unread">
|
|
{{.locale.Tr "notification.unread"}}
|
|
<div class="notifications-unread-count ui label {{if not $notificationUnreadCount}}gt-hidden{{end}}">{{$notificationUnreadCount}}</div>
|
|
</a>
|
|
<a class="{{if eq .Status 2}}active {{end}}item" href="{{AppSubUrl}}/notifications?q=read">
|
|
{{.locale.Tr "notification.read"}}
|
|
</a>
|
|
</div>
|
|
{{if and (eq .Status 1)}}
|
|
<form action="{{AppSubUrl}}/notifications/purge" method="post">
|
|
{{$.CsrfTokenHtml}}
|
|
<div class="{{if not $notificationUnreadCount}}gt-hidden{{end}}">
|
|
<button class="ui mini button primary gt-mr-0" title='{{$.locale.Tr "notification.mark_all_as_read"}}'>
|
|
{{svg "octicon-checklist"}}
|
|
</button>
|
|
</div>
|
|
</form>
|
|
{{end}}
|
|
</div>
|
|
<div class="gt-p-0">
|
|
<div id="notification_table">
|
|
{{if eq (len .Notifications) 0}}
|
|
<div class="gt-df gt-ac gt-fc gt-p-4">
|
|
{{svg "octicon-inbox" 56 "gt-mb-4"}}
|
|
{{if eq .Status 1}}
|
|
{{.locale.Tr "notification.no_unread"}}
|
|
{{else}}
|
|
{{.locale.Tr "notification.no_read"}}
|
|
{{end}}
|
|
</div>
|
|
{{else}}
|
|
{{$locale := .locale}}
|
|
{{range $notification := .Notifications}}
|
|
<div class="notifications-item gt-df gt-ac gt-fw gt-gap-3 gt-p-3" id="notification_{{.ID}}" data-status="{{.Status}}">
|
|
<div class="notifications-icon gt-ml-3 gt-mr-2 gt-self-start gt-mt-2">
|
|
{{if .Issue}}
|
|
{{template "shared/issueicon" .Issue}}
|
|
{{else}}
|
|
{{svg "octicon-repo" 16 "text grey"}}
|
|
{{end}}
|
|
</div>
|
|
<a class="notifications-link gt-df gt-f1 gt-fc silenced" href="{{.Link}}">
|
|
<div class="notifications-top-row gt-font-13">
|
|
{{.Repository.FullName}} {{if .Issue}}<span class="text light-3">#{{.Issue.Index}}</span>{{end}}
|
|
{{if eq .Status 3}}
|
|
{{svg "octicon-pin" 13 "text blue gt-mt-1 gt-ml-2"}}
|
|
{{end}}
|
|
</div>
|
|
<div class="notifications-bottom-row gt-font-16 gt-py-1">
|
|
<span class="issue-title">
|
|
{{if .Issue}}
|
|
{{.Issue.Title | RenderEmoji $.Context | RenderCodeBlock}}
|
|
{{else}}
|
|
{{.Repository.FullName}}
|
|
{{end}}
|
|
</span>
|
|
</div>
|
|
</a>
|
|
<div class="notifications-updated gt-ac gt-mr-3">
|
|
{{if .Issue}}
|
|
{{TimeSinceUnix .Issue.UpdatedUnix $locale}}
|
|
{{else}}
|
|
{{TimeSinceUnix .UpdatedUnix $locale}}
|
|
{{end}}
|
|
</div>
|
|
<div class="notifications-buttons gt-ac gt-je gt-gap-2 gt-px-2">
|
|
{{if ne .Status 3}}
|
|
<form action="{{AppSubUrl}}/notifications/status" method="post">
|
|
{{$.CsrfTokenHtml}}
|
|
<input type="hidden" name="notification_id" value="{{.ID}}">
|
|
<input type="hidden" name="status" value="pinned">
|
|
<button class="btn interact-bg gt-p-3" title='{{$.locale.Tr "notification.pin"}}'
|
|
data-url="{{AppSubUrl}}/notifications/status"
|
|
data-status="pinned"
|
|
data-page="{{$.Page.Paginater.Current}}"
|
|
data-notification-id="{{.ID}}"
|
|
data-q="{{$.Keyword}}">
|
|
{{svg "octicon-pin"}}
|
|
</button>
|
|
</form>
|
|
{{end}}
|
|
{{if or (eq .Status 1) (eq .Status 3)}}
|
|
<form action="{{AppSubUrl}}/notifications/status" method="post">
|
|
{{$.CsrfTokenHtml}}
|
|
<input type="hidden" name="notification_id" value="{{.ID}}">
|
|
<input type="hidden" name="status" value="read">
|
|
<input type="hidden" name="page" value="{{$.Page.Paginater.Current}}">
|
|
<button class="btn interact-bg gt-p-3" title='{{$.locale.Tr "notification.mark_as_read"}}'
|
|
data-url="{{AppSubUrl}}/notifications/status"
|
|
data-status="read"
|
|
data-page="{{$.Page.Paginater.Current}}"
|
|
data-notification-id="{{.ID}}"
|
|
data-q="{{$.Keyword}}">
|
|
{{svg "octicon-check"}}
|
|
</button>
|
|
</form>
|
|
{{else if eq .Status 2}}
|
|
<form action="{{AppSubUrl}}/notifications/status" method="post">
|
|
{{$.CsrfTokenHtml}}
|
|
<input type="hidden" name="notification_id" value="{{.ID}}">
|
|
<input type="hidden" name="status" value="unread">
|
|
<input type="hidden" name="page" value="{{$.Page.Paginater.Current}}">
|
|
<button class="btn interact-bg gt-p-3" title='{{$.locale.Tr "notification.mark_as_unread"}}'
|
|
data-url="{{AppSubUrl}}/notifications/status"
|
|
data-status="unread"
|
|
data-page="{{$.Page.Paginater.Current}}"
|
|
data-notification-id="{{.ID}}"
|
|
data-q="{{$.Keyword}}">
|
|
{{svg "octicon-bell"}}
|
|
</button>
|
|
</form>
|
|
{{end}}
|
|
</div>
|
|
</div>
|
|
{{end}}
|
|
{{end}}
|
|
</div>
|
|
</div>
|
|
{{template "base/paginate" .}}
|
|
</div>
|
|
</div>
|