Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2022-08-24 21:12:18 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2022-08-24 21:12:18 +0300
commit06c57a837802f789b9276e23d7f505d95270f033 (patch)
treeb45a80632d84a459b11376e1b575928c911eb045 /app/assets/javascripts/blob
parent53ab147992c8e791582f625c80811fdda5ba4d5a (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'app/assets/javascripts/blob')
-rw-r--r--app/assets/javascripts/blob/blob_blame_link.js31
-rw-r--r--app/assets/javascripts/blob/blob_links_tracking.js9
2 files changed, 38 insertions, 2 deletions
diff --git a/app/assets/javascripts/blob/blob_blame_link.js b/app/assets/javascripts/blob/blob_blame_link.js
new file mode 100644
index 00000000000..41dfd7b82b8
--- /dev/null
+++ b/app/assets/javascripts/blob/blob_blame_link.js
@@ -0,0 +1,31 @@
+function addBlameLink(containerSelector, linkClass) {
+ const containerEl = document.querySelector(containerSelector);
+
+ if (!containerEl) {
+ return;
+ }
+
+ containerEl.addEventListener('mouseover', (e) => {
+ const isLineLink = e.target.classList.contains(linkClass);
+ if (isLineLink) {
+ const lineLink = e.target;
+ const lineLinkCopy = lineLink.cloneNode(true);
+ lineLinkCopy.classList.remove(linkClass, 'diff-line-num');
+
+ const { lineNumber } = lineLink.dataset;
+ const { blamePath } = document.querySelector('.line-numbers').dataset;
+ const blameLink = document.createElement('a');
+ blameLink.classList.add('file-line-blame');
+ blameLink.href = `${blamePath}#L${lineNumber}`;
+
+ const wrapper = document.createElement('div');
+ wrapper.classList.add('line-links', 'diff-line-num');
+
+ wrapper.appendChild(blameLink);
+ wrapper.appendChild(lineLinkCopy);
+ lineLink.replaceWith(wrapper);
+ }
+ });
+}
+
+export default addBlameLink;
diff --git a/app/assets/javascripts/blob/blob_links_tracking.js b/app/assets/javascripts/blob/blob_links_tracking.js
index 9a49aa8b0fc..713cc3fad05 100644
--- a/app/assets/javascripts/blob/blob_links_tracking.js
+++ b/app/assets/javascripts/blob/blob_links_tracking.js
@@ -1,7 +1,12 @@
import Tracking from '~/tracking';
-function addBlobLinksTracking(containerSelector, eventsToTrack) {
- const containerEl = document.querySelector(containerSelector);
+const eventsToTrack = [
+ { selector: '.file-line-blame', property: 'blame' },
+ { selector: '.file-line-num', property: 'link' },
+];
+
+function addBlobLinksTracking() {
+ const containerEl = document.querySelector('.file-holder');
if (!containerEl) {
return;