mirror of
https://git.freesoftwareextremist.com/bloat
synced 2024-11-09 16:14:11 +00:00
1d61f1aa27
This uses better color contrast and component spacing to improve legibility. The updated HTML also has better compatibility with browsers with limited/no CSS support.
237 lines
10 KiB
Cheetah
237 lines
10 KiB
Cheetah
{{with .Data}}
|
|
<article id="status-{{.ID}}" class="status-container-container">
|
|
{{if .Reblog}}
|
|
<div class="retweet-info">
|
|
<a class="img-link" href="/user/{{.Account.ID}}">
|
|
<img class="status-profile-img" src="{{.Account.Avatar}}" title="@{{.Account.Acct}}" alt="@{{.Account.Acct}}" height="24">
|
|
</a>
|
|
<bdi class="status-dname">{{EmojiFilter (HTML .Account.DisplayName) .Account.Emojis | Raw}}</bdi>
|
|
<a href="/user/{{.Account.ID}}">
|
|
<span class="status-uname">@{{.Account.Acct}}</span>
|
|
</a>
|
|
<span>retweeted</span>
|
|
</div>
|
|
{{template "status" (WithContext .Reblog $.Ctx)}}
|
|
{{else}}
|
|
{{block "status" (WithContext . $.Ctx)}}
|
|
{{with $s := .Data}}
|
|
<div class="status-container status-{{.ID}}" data-id="{{.ID}}">
|
|
<div class="status-profile-img-container">
|
|
<a class="img-link" href="/user/{{.Account.ID}}">
|
|
<img class="status-profile-img" src="{{.Account.Avatar}}" title="@{{.Account.Acct}}" alt="@{{.Account.Acct}}" height="48">
|
|
</a>
|
|
</div>
|
|
<div class="status">
|
|
<div class="status-name">
|
|
<bdi class="status-dname">{{EmojiFilter (HTML .Account.DisplayName) .Account.Emojis | Raw}}</bdi>
|
|
<a href="/user/{{.Account.ID}}"><span class="status-uname">@{{.Account.Acct}}</span></a>
|
|
<div class="more-container">
|
|
<div class="remote-link">
|
|
{{if .IDNumbers}}#{{index .IDNumbers .ID}}{{end}} {{.Visibility}}
|
|
</div>
|
|
<div class="more-content">
|
|
<a class="more-link" href="{{.URL}}" target="_blank">source</a>
|
|
<a class="more-link" href="/quickreply/{{.ID}}#status-{{.ID}}">quickreply</a>
|
|
{{if .Muted}}
|
|
<form action="/unmuteconv/{{.ID}}" method="post" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="submit" value="unmute" class="btn-link more-link">
|
|
</form>
|
|
{{else}}
|
|
<form action="/muteconv/{{.ID}}" method="post" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="submit" value="mute" class="btn-link more-link">
|
|
</form>
|
|
{{end}}
|
|
{{if .Bookmarked}}
|
|
<form action="/unbookmark/{{.ID}}" method="post" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="hidden" name="retweeted_by_id" value="{{.RetweetedByID}}">
|
|
<input type="submit" value="unbookmark" class="btn-link more-link">
|
|
</form>
|
|
{{else}}
|
|
<form action="/bookmark/{{.ID}}" method="post" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="hidden" name="retweeted_by_id" value="{{.RetweetedByID}}">
|
|
<input type="submit" value="bookmark" class="btn-link more-link">
|
|
</form>
|
|
{{end}}
|
|
{{if eq $.Ctx.UserID .Account.ID}}
|
|
<form action="/delete/{{.ID}}" method="post" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="submit" value="delete" class="btn-link more-link">
|
|
</form>
|
|
{{end}}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{{if (or .InReplyToID .ShowReplies)}}
|
|
<div class="status-reply-container">
|
|
{{if .InReplyToID}}
|
|
<a class="status-reply-to-link" href="{{if not .ShowReplies}}/thread/{{.InReplyToID}}{{end}}#status-{{.InReplyToID}}">
|
|
in reply to {{if .IDNumbers}}#{{index .IDNumbers .InReplyToID}}{{end}} {{if .Pleroma.InReplyToAccountAcct}}@{{.Pleroma.InReplyToAccountAcct}}{{else if not .IDNumbers}}{{.InReplyToID}}{{end}}
|
|
</a>
|
|
{{if index .IDReplies .ID}} <span class="status-reply-info-divider"> - </span> {{end}}
|
|
{{end}}
|
|
{{if .ShowReplies}}
|
|
{{if index .IDReplies .ID}} <span class="status-reply-text"> replies: </span> {{end}}
|
|
{{range index .IDReplies .ID}}
|
|
<a class="status-reply-link" href="#status-{{.ID}}">#{{.Number}}</a>
|
|
{{end}}
|
|
{{end}}
|
|
</div>
|
|
{{end}}
|
|
{{if (or .Content .SpoilerText)}}
|
|
<div class="status-content">
|
|
{{- if .SpoilerText}}{{EmojiFilter (HTML .SpoilerText) .Emojis | Raw}}<br>{{end -}}
|
|
{{- StatusContentFilter .Content .Emojis .Mentions | Raw -}}
|
|
</div>
|
|
{{end}}
|
|
{{if .MediaAttachments}}
|
|
<div class="status-media-container">
|
|
{{range .MediaAttachments}}
|
|
|
|
{{- if eq .Type "image" -}}
|
|
{{if $.Ctx.HideAttachments}}
|
|
<a href="{{.URL}}" target="_blank">[image{{if $s.Sensitive}}/nsfw{{end}}{{if .Description}}: {{.Description}}{{end}}]</a>
|
|
{{- else -}}
|
|
<a class="img-link status-image-container" href="{{.URL}}" target="_blank" title="{{.Description}}">
|
|
<img class="status-image" src="{{.PreviewURL}}" alt="{{.Description}}" height="240">
|
|
{{if (and $.Ctx.MaskNSFW $s.Sensitive)}}
|
|
<div class="status-nsfw-overlay"></div>
|
|
{{end}}
|
|
</a>
|
|
{{- end -}}
|
|
|
|
{{else if eq .Type "audio"}}
|
|
{{if $.Ctx.HideAttachments}}
|
|
<a href="{{.URL}}" target="_blank">[audio{{if $s.Sensitive}}/nsfw{{end}}{{if .Description}}: {{.Description}}{{end}}]</a>
|
|
{{else}}
|
|
<audio class="status-audio" controls title="{{.Description}}">
|
|
<source src="{{.URL}}">
|
|
<a href="{{.URL}}" target="_blank">[audio]</a>
|
|
</audio>
|
|
{{end}}
|
|
|
|
{{else if eq .Type "video"}}
|
|
{{if $.Ctx.HideAttachments}}
|
|
<a href="{{.URL}}" target="_blank">[video{{if $s.Sensitive}}/nsfw{{end}}{{if .Description}}: {{.Description}}{{end}}]</a>
|
|
{{else}}
|
|
<div class="status-video-container" title="{{.Description}}">
|
|
<video class="status-video" controls height="240">
|
|
<source src="{{.URL}}">
|
|
<a href="{{.URL}}" target="_blank">[video]</a>
|
|
</video>
|
|
{{if (and $.Ctx.MaskNSFW $s.Sensitive)}}
|
|
<div class="status-nsfw-overlay"></div>
|
|
{{end}}
|
|
</div>
|
|
{{end}}
|
|
|
|
{{else}}
|
|
<a href="{{.URL}}" target="_blank">[attachment{{if $s.Sensitive}}/nsfw{{end}}{{if .Description}}: {{.Description}}{{end}}]</a>
|
|
{{end}}
|
|
{{- end -}}
|
|
</div>
|
|
{{end}}
|
|
{{if .Poll}}
|
|
<form class="status-poll" action="/vote/{{.Poll.ID}}" method="POST" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="hidden" name="status_id" value="{{$s.ID}}">
|
|
{{range $i, $o := .Poll.Options}}
|
|
<div class="form-field-s">
|
|
{{if (or $s.Poll.Expired $s.Poll.Voted)}}
|
|
<div> {{EmojiFilter (HTML $o.Title) $s.Emojis | Raw}} - {{$o.VotesCount}} votes </div>
|
|
{{else}}
|
|
<input type="{{if $s.Poll.Multiple}}checkbox{{else}}radio{{end}}" name="choices"
|
|
id="poll-{{$s.ID}}-{{$i}}" value="{{$i}}">
|
|
<label for="poll-{{$s.ID}}-{{$i}}">
|
|
{{EmojiFilter (HTML $o.Title) $s.Emojis | Raw}}
|
|
</label>
|
|
{{end}}
|
|
</div>
|
|
{{end}}
|
|
{{if not (or .Poll.Expired .Poll.Voted)}}
|
|
<div class="form-field-s">
|
|
<button type="submit"> Vote </button>
|
|
</div>
|
|
{{end}}
|
|
<div>
|
|
<span>{{.Poll.VotesCount}} votes</span>
|
|
{{if .Poll.Expired}}
|
|
<span> - poll expired </span>
|
|
{{else if .Poll.ExpiresAt}}
|
|
<span>
|
|
- poll ends in
|
|
<time datetime="{{FormatTimeRFC3339 .Poll.ExpiresAt}}" title="{{FormatTimeRFC822 .Poll.ExpiresAt}}">
|
|
{{TimeUntil .Poll.ExpiresAt}}
|
|
</time>
|
|
</span>
|
|
{{end}}
|
|
</div>
|
|
</form>
|
|
{{end}}
|
|
<div class="status-action-container">
|
|
<div class="status-action">
|
|
<a href="/thread/{{.ID}}?reply=true#status-{{.ID}}">reply</a>
|
|
<a class="status-reply-count {{if or $.Ctx.AntiDopamineMode (not .RepliesCount)}}hidden{{end}}"
|
|
href="/thread/{{.ID}}#status-{{.ID}}" {{if $.Ctx.ThreadInNewTab}}target="_blank"{{end}} title="replies">
|
|
{{if and (not $.Ctx.AntiDopamineMode) .RepliesCount}}
|
|
({{DisplayInteractionCount .RepliesCount}})
|
|
{{end}}
|
|
</a>
|
|
</div>
|
|
<div class="status-action">
|
|
{{$rt := "retweet"}} {{if .Reblogged}} {{$rt = "unretweet"}} {{end}}
|
|
<form class="status-retweet" data-action="{{$rt}}" action="/{{$rt}}/{{.ID}}" method="post" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="hidden" name="retweeted_by_id" value="{{.RetweetedByID}}">
|
|
<input type="submit" value="{{$rt}}" class="btn-link"
|
|
{{if or (eq .Visibility "private") (eq .Visibility "direct")}}title="this status cannot be retweeted" disabled{{end}}>
|
|
<a class="status-retweet-count {{if or $.Ctx.AntiDopamineMode (not .ReblogsCount)}}hidden{{end}}"
|
|
href="/retweetedby/{{.ID}}" title="click to see the the list">
|
|
{{if and (not $.Ctx.AntiDopamineMode) .ReblogsCount}}
|
|
({{DisplayInteractionCount .ReblogsCount}})
|
|
{{end}}
|
|
</a>
|
|
</form>
|
|
</div>
|
|
<div class="status-action">
|
|
{{$like := "like"}} {{if .Favourited}} {{$like = "unlike"}} {{end}}
|
|
<form class="status-like" data-action="{{$like}}" action="/{{$like}}/{{.ID}}" method="post" target="_self">
|
|
<input type="hidden" name="csrf_token" value="{{$.Ctx.CSRFToken}}">
|
|
<input type="hidden" name="referrer" value="{{$.Ctx.Referrer}}">
|
|
<input type="hidden" name="retweeted_by_id" value="{{.RetweetedByID}}">
|
|
<input type="submit" value="{{$like}}" class="btn-link">
|
|
<a class="status-like-count {{if or $.Ctx.AntiDopamineMode (not .FavouritesCount)}}hidden{{end}}"
|
|
href="/likedby/{{.ID}}" title="click to see the the list">
|
|
{{if and (not $.Ctx.AntiDopamineMode) .FavouritesCount}}
|
|
({{DisplayInteractionCount .FavouritesCount}})
|
|
{{end}}
|
|
</a>
|
|
</form>
|
|
</div>
|
|
<div class="status-action status-action-last">
|
|
<a class="status-time" href="{{if not .ShowReplies}}/thread/{{.ID}}{{end}}#status-{{.ID}}"
|
|
{{if $.Ctx.ThreadInNewTab}}target="_blank"{{end}}>
|
|
<time datetime="{{FormatTimeRFC3339 .CreatedAt.Time}}" title="{{FormatTimeRFC822 .CreatedAt.Time}}">
|
|
{{TimeSince .CreatedAt.Time}}
|
|
</time>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<br class="hidden">
|
|
{{end}}
|
|
{{end}}
|
|
{{end}}
|
|
</article>
|
|
{{end}}
|