BigW Consortium Gitlab

Commit 0ec6ff5a by Fatih Acet Committed by kushalpandya

Merge branch '32125-fix-link-to-note-in-diff' into 'master'

Fix linking to resolved note in diff Closes #32125 See merge request !11327
parent accdca5f
...@@ -120,7 +120,7 @@ const DiffNoteAvatars = Vue.extend({ ...@@ -120,7 +120,7 @@ const DiffNoteAvatars = Vue.extend({
}, },
methods: { methods: {
clickedAvatar(e) { clickedAvatar(e) {
notes.addDiffNote(e); notes.onAddDiffNote(e);
// Toggle the active state of the toggle all button // Toggle the active state of the toggle all button
this.toggleDiscussionsToggleState(); this.toggleDiscussionsToggleState();
......
/* eslint-disable no-new, class-methods-use-this */ /* eslint-disable no-new, class-methods-use-this */
/* global Breakpoints */ /* global Breakpoints */
/* global Flash */ /* global Flash */
/* global notes */
import Cookies from 'js-cookie'; import Cookies from 'js-cookie';
import './breakpoints'; import './breakpoints';
...@@ -251,7 +252,8 @@ import BlobForkSuggestion from './blob/blob_fork_suggestion'; ...@@ -251,7 +252,8 @@ import BlobForkSuggestion from './blob/blob_fork_suggestion';
this.ajaxGet({ this.ajaxGet({
url: `${urlPathname}.json${location.search}`, url: `${urlPathname}.json${location.search}`,
success: (data) => { success: (data) => {
$('#diffs').html(data.html); const $container = $('#diffs');
$container.html(data.html);
if (typeof gl.diffNotesCompileComponents !== 'undefined') { if (typeof gl.diffNotesCompileComponents !== 'undefined') {
gl.diffNotesCompileComponents(); gl.diffNotesCompileComponents();
...@@ -278,6 +280,20 @@ import BlobForkSuggestion from './blob/blob_fork_suggestion'; ...@@ -278,6 +280,20 @@ import BlobForkSuggestion from './blob/blob_fork_suggestion';
}) })
.init(); .init();
}); });
// Scroll any linked note into view
// Similar to `toggler_behavior` in the discussion tab
const hash = window.gl.utils.getLocationHash();
const anchor = hash && $container.find(`[id="${hash}"]`);
if (anchor) {
const notesContent = anchor.closest('.notes_content');
const lineType = notesContent.hasClass('new') ? 'new' : 'old';
notes.addDiffNote(anchor, lineType, false);
anchor[0].scrollIntoView();
// We have multiple elements on the page with `#note_xxx`
// (discussion and diff tabs) and `:target` only applies to the first
anchor.addClass('target');
}
}, },
}); });
} }
......
...@@ -31,24 +31,25 @@ const normalizeNewlines = function(str) { ...@@ -31,24 +31,25 @@ const normalizeNewlines = function(str) {
Notes.interval = null; Notes.interval = null;
function Notes(notes_url, note_ids, last_fetched_at, view) { function Notes(notes_url, note_ids, last_fetched_at, view) {
this.updateTargetButtons = bind(this.updateTargetButtons, this); this.updateTargetButtons = this.updateTargetButtons.bind(this);
this.updateComment = bind(this.updateComment, this); this.updateComment = this.updateComment.bind(this);
this.visibilityChange = bind(this.visibilityChange, this); this.visibilityChange = this.visibilityChange.bind(this);
this.cancelDiscussionForm = bind(this.cancelDiscussionForm, this); this.cancelDiscussionForm = this.cancelDiscussionForm.bind(this);
this.addDiffNote = bind(this.addDiffNote, this); this.onAddDiffNote = this.onAddDiffNote.bind(this);
this.setupDiscussionNoteForm = bind(this.setupDiscussionNoteForm, this); this.setupDiscussionNoteForm = this.setupDiscussionNoteForm.bind(this);
this.replyToDiscussionNote = bind(this.replyToDiscussionNote, this); this.onReplyToDiscussionNote = this.onReplyToDiscussionNote.bind(this);
this.removeNote = bind(this.removeNote, this); this.removeNote = this.removeNote.bind(this);
this.cancelEdit = bind(this.cancelEdit, this); this.cancelEdit = this.cancelEdit.bind(this);
this.updateNote = bind(this.updateNote, this); this.updateNote = this.updateNote.bind(this);
this.addDiscussionNote = bind(this.addDiscussionNote, this); this.addDiscussionNote = this.addDiscussionNote.bind(this);
this.addNoteError = bind(this.addNoteError, this); this.addNoteError = this.addNoteError.bind(this);
this.addNote = bind(this.addNote, this); this.addNote = this.addNote.bind(this);
this.resetMainTargetForm = bind(this.resetMainTargetForm, this); this.resetMainTargetForm = this.resetMainTargetForm.bind(this);
this.refresh = bind(this.refresh, this); this.refresh = this.refresh.bind(this);
this.keydownNoteText = bind(this.keydownNoteText, this); this.keydownNoteText = this.keydownNoteText.bind(this);
this.toggleCommitList = bind(this.toggleCommitList, this); this.toggleCommitList = this.toggleCommitList.bind(this);
this.postComment = bind(this.postComment, this); this.postComment = this.postComment.bind(this);
this.clearFlashWrapper = this.clearFlash.bind(this);
this.notes_url = notes_url; this.notes_url = notes_url;
this.note_ids = note_ids; this.note_ids = note_ids;
...@@ -102,9 +103,9 @@ const normalizeNewlines = function(str) { ...@@ -102,9 +103,9 @@ const normalizeNewlines = function(str) {
// update the file name when an attachment is selected // update the file name when an attachment is selected
$(document).on("change", ".js-note-attachment-input", this.updateFormAttachment); $(document).on("change", ".js-note-attachment-input", this.updateFormAttachment);
// reply to diff/discussion notes // reply to diff/discussion notes
$(document).on("click", ".js-discussion-reply-button", this.replyToDiscussionNote); $(document).on("click", ".js-discussion-reply-button", this.onReplyToDiscussionNote);
// add diff note // add diff note
$(document).on("click", ".js-add-diff-note-button", this.addDiffNote); $(document).on("click", ".js-add-diff-note-button", this.onAddDiffNote);
// hide diff note form // hide diff note form
$(document).on("click", ".js-close-discussion-note-form", this.cancelDiscussionForm); $(document).on("click", ".js-close-discussion-note-form", this.cancelDiscussionForm);
// toggle commit list // toggle commit list
...@@ -796,10 +797,14 @@ const normalizeNewlines = function(str) { ...@@ -796,10 +797,14 @@ const normalizeNewlines = function(str) {
Shows the note form below the notes. Shows the note form below the notes.
*/ */
Notes.prototype.replyToDiscussionNote = function(e) { Notes.prototype.onReplyToDiscussionNote = function(e) {
this.replyToDiscussionNote(e.target);
};
Notes.prototype.replyToDiscussionNote = function(target) {
var form, replyLink; var form, replyLink;
form = this.cleanForm(this.formClone.clone()); form = this.cleanForm(this.formClone.clone());
replyLink = $(e.target).closest(".js-discussion-reply-button"); replyLink = $(target).closest(".js-discussion-reply-button");
// insert the form after the button // insert the form after the button
replyLink replyLink
.closest('.discussion-reply-holder') .closest('.discussion-reply-holder')
...@@ -869,35 +874,43 @@ const normalizeNewlines = function(str) { ...@@ -869,35 +874,43 @@ const normalizeNewlines = function(str) {
Sets up the form and shows it. Sets up the form and shows it.
*/ */
Notes.prototype.addDiffNote = function(e) { Notes.prototype.onAddDiffNote = function(e) {
var $link, addForm, hasNotes, lineType, newForm, nextRow, noteForm, notesContent, notesContentSelector, replyButton, row, rowCssToAdd, targetContent, isDiffCommentAvatar;
e.preventDefault(); e.preventDefault();
$link = $(e.currentTarget || e.target); const $link = $(e.currentTarget || e.target);
const showReplyInput = !$link.hasClass('js-diff-comment-avatar');
this.addDiffNote($link, $link.data('lineType'), showReplyInput);
};
Notes.prototype.addDiffNote = function(target, lineType, showReplyInput) {
var $link, addForm, hasNotes, newForm, noteForm, replyButton, row, rowCssToAdd, targetContent, isDiffCommentAvatar;
$link = $(target);
row = $link.closest("tr"); row = $link.closest("tr");
nextRow = row.next(); const nextRow = row.next();
hasNotes = nextRow.is(".notes_holder"); let targetRow = row;
if (nextRow.is('.notes_holder')) {
targetRow = nextRow;
}
hasNotes = targetRow.is(".notes_holder");
addForm = false; addForm = false;
notesContentSelector = ".notes_content"; let lineTypeSelector = '';
rowCssToAdd = "<tr class=\"notes_holder js-temp-notes-holder\"><td class=\"notes_line\" colspan=\"2\"></td><td class=\"notes_content\"><div class=\"content\"></div></td></tr>"; rowCssToAdd = "<tr class=\"notes_holder js-temp-notes-holder\"><td class=\"notes_line\" colspan=\"2\"></td><td class=\"notes_content\"><div class=\"content\"></div></td></tr>";
isDiffCommentAvatar = $link.hasClass('js-diff-comment-avatar');
// In parallel view, look inside the correct left/right pane // In parallel view, look inside the correct left/right pane
if (this.isParallelView()) { if (this.isParallelView()) {
lineType = $link.data("lineType"); lineTypeSelector = `.${lineType}`;
notesContentSelector += "." + lineType;
rowCssToAdd = "<tr class=\"notes_holder js-temp-notes-holder\"><td class=\"notes_line old\"></td><td class=\"notes_content parallel old\"><div class=\"content\"></div></td><td class=\"notes_line new\"></td><td class=\"notes_content parallel new\"><div class=\"content\"></div></td></tr>"; rowCssToAdd = "<tr class=\"notes_holder js-temp-notes-holder\"><td class=\"notes_line old\"></td><td class=\"notes_content parallel old\"><div class=\"content\"></div></td><td class=\"notes_line new\"></td><td class=\"notes_content parallel new\"><div class=\"content\"></div></td></tr>";
} }
notesContentSelector += " .content"; const notesContentSelector = `.notes_content${lineTypeSelector} .content`;
notesContent = nextRow.find(notesContentSelector); let notesContent = targetRow.find(notesContentSelector);
if (hasNotes && !isDiffCommentAvatar) { if (hasNotes && showReplyInput) {
nextRow.show(); targetRow.show();
notesContent = nextRow.find(notesContentSelector); notesContent = targetRow.find(notesContentSelector);
if (notesContent.length) { if (notesContent.length) {
notesContent.show(); notesContent.show();
replyButton = notesContent.find(".js-discussion-reply-button:visible"); replyButton = notesContent.find(".js-discussion-reply-button:visible");
if (replyButton.length) { if (replyButton.length) {
e.target = replyButton[0]; this.replyToDiscussionNote(replyButton[0]);
$.proxy(this.replyToDiscussionNote, replyButton[0], e).call();
} else { } else {
// In parallel view, the form may not be present in one of the panes // In parallel view, the form may not be present in one of the panes
noteForm = notesContent.find(".js-discussion-note-form"); noteForm = notesContent.find(".js-discussion-note-form");
...@@ -906,18 +919,18 @@ const normalizeNewlines = function(str) { ...@@ -906,18 +919,18 @@ const normalizeNewlines = function(str) {
} }
} }
} }
} else if (!isDiffCommentAvatar) { } else if (showReplyInput) {
// add a notes row and insert the form // add a notes row and insert the form
row.after(rowCssToAdd); row.after(rowCssToAdd);
nextRow = row.next(); targetRow = row.next();
notesContent = nextRow.find(notesContentSelector); notesContent = targetRow.find(notesContentSelector);
addForm = true; addForm = true;
} else { } else {
nextRow.show(); targetRow.show();
notesContent.toggle(!notesContent.is(':visible')); notesContent.toggle(!notesContent.is(':visible'));
if (!nextRow.find('.content:not(:empty)').is(':visible')) { if (!targetRow.find('.content:not(:empty)').is(':visible')) {
nextRow.hide(); targetRow.hide();
} }
} }
...@@ -1323,7 +1336,7 @@ const normalizeNewlines = function(str) { ...@@ -1323,7 +1336,7 @@ const normalizeNewlines = function(str) {
// Show form again on UI on failure // Show form again on UI on failure
if (isDiscussionForm && $notesContainer.length) { if (isDiscussionForm && $notesContainer.length) {
const replyButton = $notesContainer.parent().find('.js-discussion-reply-button'); const replyButton = $notesContainer.parent().find('.js-discussion-reply-button');
$.proxy(this.replyToDiscussionNote, replyButton[0], { target: replyButton[0] }).call(); this.replyToDiscussionNote(replyButton[0]);
$form = $notesContainer.parent().find('form'); $form = $notesContainer.parent().find('form');
} }
......
...@@ -3,7 +3,26 @@ ...@@ -3,7 +3,26 @@
margin: 0; margin: 0;
padding: 0; padding: 0;
.timeline-entry { .note-text {
p:last-child {
margin-bottom: 0;
}
}
.system-note {
.note-text {
color: $gl-text-color !important;
}
}
.diff-file {
border: 1px solid $border-color;
border-bottom: none;
margin: 0;
}
}
.timeline-entry {
padding: $gl-padding $gl-btn-padding 0; padding: $gl-padding $gl-btn-padding 0;
border-color: $white-normal; border-color: $white-normal;
color: $gl-text-color; color: $gl-text-color;
...@@ -13,7 +32,8 @@ ...@@ -13,7 +32,8 @@
position: relative; position: relative;
} }
&:target { &:target,
&.target {
background: $line-target-blue; background: $line-target-blue;
} }
...@@ -25,25 +45,6 @@ ...@@ -25,25 +45,6 @@
padding-top: 10px; padding-top: 10px;
float: right; float: right;
} }
}
.note-text {
p:last-child {
margin-bottom: 0;
}
}
.system-note {
.note-text {
color: $gl-text-color !important;
}
}
.diff-file {
border: 1px solid $border-color;
border-bottom: none;
margin: 0;
}
} }
@media (max-width: $screen-xs-max) { @media (max-width: $screen-xs-max) {
...@@ -51,6 +52,7 @@ ...@@ -51,6 +52,7 @@
&::before { &::before {
background: none; background: none;
} }
}
.timeline-entry .timeline-entry-inner { .timeline-entry .timeline-entry-inner {
.timeline-icon { .timeline-icon {
...@@ -61,7 +63,6 @@ ...@@ -61,7 +63,6 @@
margin-left: 0; margin-left: 0;
} }
} }
}
} }
.discussion .timeline-entry { .discussion .timeline-entry {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment