summaryrefslogtreecommitdiffstats
path: root/templates/repo/diff/conversation.tmpl
blob: c80d999f47455991d4c8e75e5bd47793db26dc60 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
{{$resolved := (index .comments 0).IsResolved}}
{{$invalid := (index .comments 0).Invalidated}}
{{$resolveDoer := (index .comments 0).ResolveDoer}}
{{$isNotPending := (not (eq (index .comments 0).Review.Type 0))}}
{{$referenceUrl := printf "%s#%s" $.Issue.Link (index .comments 0).HashTag}}
<div class="conversation-holder" data-path="{{(index .comments 0).TreePath}}" data-side="{{if lt (index .comments 0).Line 0}}left{{else}}right{{end}}" data-idx="{{(index .comments 0).UnsignedLine}}">
	{{if $resolved}}
		<div class="ui attached header resolved-placeholder tw-flex tw-items-center tw-justify-between">
			<div class="ui grey text tw-flex tw-items-center tw-flex-wrap tw-gap-1">
				{{svg "octicon-check" 16 "icon tw-mr-1"}}
				<b>{{$resolveDoer.Name}}</b> {{ctx.Locale.Tr "repo.issues.review.resolved_by"}}
				{{if $invalid}}
					<!--
					We only handle the case $resolved=true and $invalid=true in this template because if the comment is not resolved it has the outdated label in the comments area (not the header above).
					The case $resolved=false and $invalid=true is handled in repo/diff/comments.tmpl
					-->
					<a href="{{AppSubUrl}}{{$referenceUrl}}" class="ui label basic small tw-ml-2" data-tooltip-content="{{ctx.Locale.Tr "repo.issues.review.outdated_description"}}">
						{{ctx.Locale.Tr "repo.issues.review.outdated"}}
					</a>
				{{end}}
			</div>
			<div class="tw-flex tw-items-center tw-gap-2">
				<button id="show-outdated-{{(index .comments 0).ID}}" data-comment="{{(index .comments 0).ID}}" class="ui tiny labeled button show-outdated tw-flex tw-items-center">
					{{svg "octicon-unfold" 16 "tw-mr-2"}}
					{{ctx.Locale.Tr "repo.issues.review.show_resolved"}}
				</button>
				<button id="hide-outdated-{{(index .comments 0).ID}}" data-comment="{{(index .comments 0).ID}}" class="ui tiny labeled button hide-outdated tw-flex tw-items-center tw-hidden">
					{{svg "octicon-fold" 16 "tw-mr-2"}}
					{{ctx.Locale.Tr "repo.issues.review.hide_resolved"}}
				</button>
			</div>
		</div>
	{{end}}
	<div id="code-comments-{{(index  .comments 0).ID}}" class="field comment-code-cloud {{if $resolved}}tw-hidden{{end}}">
		<div class="comment-list">
			<ui class="ui comments">
				{{template "repo/diff/comments" dict "root" $ "comments" .comments}}
			</ui>
		</div>
		<div class="button-row tw-flex tw-justify-end tw-items-center tw-flex-wrap tw-mt-2">
			<div class="ui buttons">
				<button class="ui icon tiny basic button previous-conversation">
					{{svg "octicon-arrow-up" 12 "icon"}} {{ctx.Locale.Tr "repo.issues.previous"}}
				</button>
				<button class="ui icon tiny basic button next-conversation">
					{{svg "octicon-arrow-down" 12 "icon"}} {{ctx.Locale.Tr "repo.issues.next"}}
				</button>
			</div>
			{{if and $.CanMarkConversation $isNotPending}}
				<button class="ui icon tiny basic button resolve-conversation" data-origin="diff" data-action="{{if not $resolved}}Resolve{{else}}UnResolve{{end}}" data-comment-id="{{(index .comments 0).ID}}" data-update-url="{{$.RepoLink}}/issues/resolve_conversation">
					{{if $resolved}}
						{{ctx.Locale.Tr "repo.issues.review.un_resolve_conversation"}}
					{{else}}
						{{ctx.Locale.Tr "repo.issues.review.resolve_conversation"}}
					{{end}}
				</button>
			{{end}}
			{{if and $.SignedUserID (not $.Repository.IsArchived)}}
				<button class="comment-form-reply ui primary tiny labeled icon button">
					{{svg "octicon-reply" 16 "reply icon tw-mr-1"}}{{ctx.Locale.Tr "repo.diff.comment.reply"}}
				</button>
			{{end}}
		</div>
		{{template "repo/diff/comment_form_datahandler" dict "hidden" true "reply" (index .comments 0).ReviewID "root" $ "comment" (index .comments 0)}}
	</div>
</div>