Reply button is not removed when deleting a code review comment (#13774)
Co-authored-by: mrsdizzie <info@mrsdizzie.com>
This commit is contained in:
		
							parent
							
								
									4353cf96c0
								
							
						
					
					
						commit
						47e4d1a4e2
					
				
					 4 changed files with 43 additions and 97 deletions
				
			
		|  | @ -150,80 +150,19 @@ | ||||||
| 															{{end}} | 															{{end}} | ||||||
| 														</tr> | 														</tr> | ||||||
| 														{{if gt (len $line.Comments) 0}} | 														{{if gt (len $line.Comments) 0}} | ||||||
| 															{{$resolved := (index $line.Comments 0).IsResolved}} |  | ||||||
| 															{{$resolveDoer := (index $line.Comments 0).ResolveDoer}} |  | ||||||
| 															{{$isNotPending := (not (eq (index $line.Comments 0).Review.Type 0))}} |  | ||||||
| 															<tr class="add-code-comment"> | 															<tr class="add-code-comment"> | ||||||
| 																<td class="lines-num"></td> | 																<td class="lines-num"></td> | ||||||
| 																<td class="lines-type-marker"></td> | 																<td class="lines-type-marker"></td> | ||||||
| 																<td class="add-comment-left"> | 																<td class="add-comment-left"> | ||||||
| 																	{{if and $resolved  (eq $line.GetCommentSide "previous")}} |  | ||||||
| 																		<div class="ui top attached header resolved-placeholder"> |  | ||||||
| 																			<span class="ui grey text left"><b>{{$resolveDoer.Name}}</b> {{$.i18n.Tr "repo.issues.review.resolved_by"}}</span> |  | ||||||
| 																			<button id="show-outdated-{{(index $line.Comments 0).ID}}" data-comment="{{(index $line.Comments 0).ID}}" class="ui tiny right labeled button show-outdated"> |  | ||||||
| 																				{{svg "octicon-unfold"}} |  | ||||||
| 																				{{$.i18n.Tr "repo.issues.review.show_resolved"}} |  | ||||||
| 																			</button> |  | ||||||
| 																			<button id="hide-outdated-{{(index $line.Comments 0).ID}}" data-comment="{{(index $line.Comments 0).ID}}" class="hide ui tiny right labeled button hide-outdated"> |  | ||||||
| 																				{{svg "octicon-fold"}} |  | ||||||
| 																				{{$.i18n.Tr "repo.issues.review.hide_resolved"}} |  | ||||||
| 																			</button> |  | ||||||
| 																		</div> |  | ||||||
| 																	{{end}} |  | ||||||
| 																	{{if eq $line.GetCommentSide "previous"}} | 																	{{if eq $line.GetCommentSide "previous"}} | ||||||
| 																		<div id="code-comments-{{(index  $line.Comments 0).ID}}" class="field comment-code-cloud {{if $resolved}}hide{{end}}"> | 																		{{template "repo/diff/conversation" mergeinto $ "comments" $line.Comments}} | ||||||
| 																			<div class="comment-list"> |  | ||||||
| 																				<ui class="ui comments"> |  | ||||||
| 																				{{ template "repo/diff/comments" dict "root" $ "comments" $line.Comments}} |  | ||||||
| 																				</ui> |  | ||||||
| 																			</div> |  | ||||||
| 																		{{template "repo/diff/comment_form_datahandler" dict "reply" (index $line.Comments 0).ReviewID "hidden" true "root" $ "comment" (index $line.Comments 0)}} |  | ||||||
| 																			{{if and $.CanMarkConversation $isNotPending}} |  | ||||||
| 																				<button class="ui icon tiny button resolve-conversation" data-action="{{if not $resolved}}Resolve{{else}}UnResolve{{end}}" data-comment-id="{{(index $line.Comments 0).ID}}" data-update-url="{{$.RepoLink}}/issues/resolve_conversation" > |  | ||||||
| 																					{{if $resolved}} |  | ||||||
| 																						{{$.i18n.Tr "repo.issues.review.un_resolve_conversation"}} |  | ||||||
| 																					{{else}} |  | ||||||
| 																						{{$.i18n.Tr "repo.issues.review.resolve_conversation"}} |  | ||||||
| 																					{{end}} |  | ||||||
| 																				</button> |  | ||||||
| 																			{{end}} |  | ||||||
| 																		</div> |  | ||||||
| 																	{{end}} | 																	{{end}} | ||||||
| 																</td> | 																</td> | ||||||
| 																<td class="lines-num"></td> | 																<td class="lines-num"></td> | ||||||
| 																<td class="lines-type-marker"></td> | 																<td class="lines-type-marker"></td> | ||||||
| 																<td class="add-comment-right resolved-placeholder"> | 																<td class="add-comment-right"> | ||||||
| 																	{{if and $resolved (eq $line.GetCommentSide "proposed")}} |  | ||||||
| 																		<div class="ui top attached header"> |  | ||||||
| 																			<span class="ui grey text left"><b>{{$resolveDoer.Name}}</b> {{$.i18n.Tr "repo.issues.review.resolved_by"}}</span> |  | ||||||
| 																			<button id="show-outdated-{{(index $line.Comments 0).ID}}" data-comment="{{(index $line.Comments 0).ID}}" class="ui tiny right labeled button show-outdated"> |  | ||||||
| 																				{{svg "octicon-unfold"}} |  | ||||||
| 																				{{$.i18n.Tr "repo.issues.review.show_resolved"}} |  | ||||||
| 																			</button> |  | ||||||
| 																			<button id="hide-outdated-{{(index $line.Comments 0).ID}}" data-comment="{{(index $line.Comments 0).ID}}" class="hide ui tiny right labeled button hide-outdated"> |  | ||||||
| 																				{{svg "octicon-fold"}} |  | ||||||
| 																				{{$.i18n.Tr "repo.issues.review.hide_resolved"}} |  | ||||||
| 																			</button> |  | ||||||
| 																		</div> |  | ||||||
| 																	{{end}} |  | ||||||
| 																	{{if eq $line.GetCommentSide "proposed"}} | 																	{{if eq $line.GetCommentSide "proposed"}} | ||||||
| 																		<div id="code-comments-{{(index  $line.Comments 0).ID}}" class="field comment-code-cloud {{if $resolved}}hide{{end}}"> | 																		{{template "repo/diff/conversation" mergeinto $ "comments" $line.Comments}} | ||||||
| 																			<div class="comment-list"> |  | ||||||
| 																				<ui class="ui comments"> |  | ||||||
| 																				{{ template "repo/diff/comments" dict "root" $ "comments" $line.Comments}} |  | ||||||
| 																				</ui> |  | ||||||
| 																			</div> |  | ||||||
| 																			{{template "repo/diff/comment_form_datahandler" dict "reply" (index $line.Comments 0).ReviewID "hidden" true "root" $ "comment" (index $line.Comments 0)}} |  | ||||||
| 																			{{if and $.CanMarkConversation $isNotPending}} |  | ||||||
| 																				<button class="ui icon tiny button resolve-conversation" data-action="{{if not $resolved}}Resolve{{else}}UnResolve{{end}}" data-comment-id="{{(index $line.Comments 0).ID}}" data-update-url="{{$.RepoLink}}/issues/resolve_conversation" > |  | ||||||
| 																					{{if $resolved}} |  | ||||||
| 																						{{$.i18n.Tr "repo.issues.review.un_resolve_conversation"}} |  | ||||||
| 																					{{else}} |  | ||||||
| 																						{{$.i18n.Tr "repo.issues.review.resolve_conversation"}} |  | ||||||
| 																					{{end}} |  | ||||||
| 																				</button> |  | ||||||
| 																			{{end}} |  | ||||||
| 																		</div> |  | ||||||
| 																	{{end}} | 																	{{end}} | ||||||
| 																</td> | 																</td> | ||||||
| 															</tr> | 															</tr> | ||||||
|  |  | ||||||
							
								
								
									
										35
									
								
								templates/repo/diff/conversation.tmpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								templates/repo/diff/conversation.tmpl
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | ||||||
|  | {{$resolved := (index .comments 0).IsResolved}} | ||||||
|  | {{$resolveDoer := (index .comments 0).ResolveDoer}} | ||||||
|  | {{$isNotPending := (not (eq (index .comments 0).Review.Type 0))}} | ||||||
|  | <div class="conversation-holder"> | ||||||
|  | 	{{if $resolved}} | ||||||
|  | 		<div class="ui attached header resolved-placeholder"> | ||||||
|  | 			<span class="ui grey text left"><b>{{$resolveDoer.Name}}</b> {{$.i18n.Tr "repo.issues.review.resolved_by"}}</span> | ||||||
|  | 			<button id="show-outdated-{{(index .comments 0).ID}}" data-comment="{{(index .comments 0).ID}}" class="ui tiny right labeled button show-outdated"> | ||||||
|  | 				{{svg "octicon-unfold"}} | ||||||
|  | 				{{$.i18n.Tr "repo.issues.review.show_resolved"}} | ||||||
|  | 			</button> | ||||||
|  | 			<button id="hide-outdated-{{(index .comments 0).ID}}" data-comment="{{(index .comments 0).ID}}" class="hide ui tiny right labeled button hide-outdated"> | ||||||
|  | 				{{svg "octicon-fold"}} | ||||||
|  | 				{{$.i18n.Tr "repo.issues.review.hide_resolved"}} | ||||||
|  | 			</button> | ||||||
|  | 		</div> | ||||||
|  | 	{{end}} | ||||||
|  | 	<div id="code-comments-{{(index  .comments 0).ID}}" class="field comment-code-cloud {{if $resolved}}hide{{end}}"> | ||||||
|  | 		<div class="comment-list"> | ||||||
|  | 			<ui class="ui comments"> | ||||||
|  | 				{{template "repo/diff/comments" dict "root" $ "comments" .comments}} | ||||||
|  | 			</ui> | ||||||
|  | 		</div> | ||||||
|  | 		{{template "repo/diff/comment_form_datahandler" dict "hidden" true "reply" (index .comments 0).ReviewID "root" $ "comment" (index .comments 0)}} | ||||||
|  | 		{{if and $.CanMarkConversation $isNotPending}} | ||||||
|  | 			<button class="ui icon tiny button resolve-conversation" 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}} | ||||||
|  | 					{{$.i18n.Tr "repo.issues.review.un_resolve_conversation"}} | ||||||
|  | 				{{else}} | ||||||
|  | 					{{$.i18n.Tr "repo.issues.review.resolve_conversation"}} | ||||||
|  | 				{{end}} | ||||||
|  | 			</button> | ||||||
|  | 		{{end}} | ||||||
|  | 	</div> | ||||||
|  | </div> | ||||||
|  | @ -33,42 +33,10 @@ | ||||||
| 				{{end}} | 				{{end}} | ||||||
| 			</tr> | 			</tr> | ||||||
| 			{{if gt (len $line.Comments) 0}} | 			{{if gt (len $line.Comments) 0}} | ||||||
| 				{{$resolved := (index $line.Comments 0).IsResolved}} |  | ||||||
| 				{{$resolveDoer := (index $line.Comments 0).ResolveDoer}} |  | ||||||
| 				{{$isNotPending := (not (eq (index $line.Comments 0).Review.Type 0))}} |  | ||||||
| 				<tr> | 				<tr> | ||||||
| 					<td colspan="2" class="lines-num"></td> | 					<td colspan="2" class="lines-num"></td> | ||||||
| 					<td class="add-comment-left add-comment-right" colspan="2"> | 					<td class="add-comment-left add-comment-right" colspan="2"> | ||||||
| 						{{if $resolved}} | 						{{template "repo/diff/conversation" mergeinto $.root "comments" $line.Comments}} | ||||||
| 							<div class="ui attached header resolved-placeholder"> |  | ||||||
| 								<span class="ui grey text left"><b>{{$resolveDoer.Name}}</b> {{$.root.i18n.Tr "repo.issues.review.resolved_by"}}</span> |  | ||||||
| 								<button id="show-outdated-{{(index $line.Comments 0).ID}}" data-comment="{{(index $line.Comments 0).ID}}" class="ui tiny right labeled button show-outdated"> |  | ||||||
| 									{{svg "octicon-unfold"}} |  | ||||||
| 									{{$.root.i18n.Tr "repo.issues.review.show_resolved"}} |  | ||||||
| 								</button> |  | ||||||
| 								<button id="hide-outdated-{{(index $line.Comments 0).ID}}" data-comment="{{(index $line.Comments 0).ID}}" class="hide ui tiny right labeled button hide-outdated"> |  | ||||||
| 									{{svg "octicon-fold"}} |  | ||||||
| 									{{$.root.i18n.Tr "repo.issues.review.hide_resolved"}} |  | ||||||
| 								</button> |  | ||||||
| 							</div> |  | ||||||
| 						{{end}} |  | ||||||
| 						<div id="code-comments-{{(index  $line.Comments 0).ID}}" class="field comment-code-cloud {{if $resolved}}hide{{end}}"> |  | ||||||
| 							<div class="comment-list"> |  | ||||||
| 								<ui class="ui comments"> |  | ||||||
| 									{{ template "repo/diff/comments" dict "root" $.root "comments" $line.Comments}} |  | ||||||
| 								</ui> |  | ||||||
| 							</div> |  | ||||||
| 							{{template "repo/diff/comment_form_datahandler" dict "hidden" true "reply" (index $line.Comments 0).ReviewID "root" $.root "comment" (index $line.Comments 0)}} |  | ||||||
| 							{{if and $.root.CanMarkConversation $isNotPending}} |  | ||||||
| 								<button class="ui icon tiny button resolve-conversation" data-action="{{if not $resolved}}Resolve{{else}}UnResolve{{end}}" data-comment-id="{{(index $line.Comments 0).ID}}" data-update-url="{{$.root.RepoLink}}/issues/resolve_conversation" > |  | ||||||
| 									{{if $resolved}} |  | ||||||
| 										{{$.root.i18n.Tr "repo.issues.review.un_resolve_conversation"}} |  | ||||||
| 									{{else}} |  | ||||||
| 										{{$.root.i18n.Tr "repo.issues.review.resolve_conversation"}} |  | ||||||
| 									{{end}} |  | ||||||
| 								</button> |  | ||||||
| 							{{end}} |  | ||||||
| 						</div> |  | ||||||
| 					</td> | 					</td> | ||||||
| 				</tr> | 				</tr> | ||||||
| 			{{end}} | 			{{end}} | ||||||
|  |  | ||||||
|  | @ -1094,7 +1094,11 @@ async function initRepository() { | ||||||
|         $.post($this.data('url'), { |         $.post($this.data('url'), { | ||||||
|           _csrf: csrf |           _csrf: csrf | ||||||
|         }).done(() => { |         }).done(() => { | ||||||
|  |           const $conversationHolder = $this.closest('.conversation-holder'); | ||||||
|           $(`#${$this.data('comment-id')}`).remove(); |           $(`#${$this.data('comment-id')}`).remove(); | ||||||
|  |           if ($conversationHolder.length && !$conversationHolder.find('.comment').length) { | ||||||
|  |             $conversationHolder.remove(); | ||||||
|  |           } | ||||||
|         }); |         }); | ||||||
|       } |       } | ||||||
|       return false; |       return false; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue