2016-10-12 22:55:31 +00:00
|
|
|
/* global Diff2HtmlUI */
|
|
|
|
|
|
2016-10-12 21:52:59 +00:00
|
|
|
/*
|
|
|
|
|
* Example URLs:
|
|
|
|
|
*
|
|
|
|
|
* https://github.com/rtfpessoa/diff2html/commit/7d02e67f3b3386ac5d804f974d025cd7a1165839
|
|
|
|
|
* https://github.com/rtfpessoa/diff2html/pull/106
|
|
|
|
|
*
|
|
|
|
|
* https://gitlab.com/gitlab-org/gitlab-ce/commit/4e963fed42ad518caa7353d361a38a1250c99c41
|
|
|
|
|
* https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/6763
|
|
|
|
|
*
|
|
|
|
|
* https://bitbucket.org/atlassian/amps/commits/52c38116f12475f75af4a147b7a7685478b83eca
|
|
|
|
|
* https://bitbucket.org/atlassian/amps/pull-requests/236
|
|
|
|
|
*/
|
|
|
|
|
|
2016-10-12 22:55:31 +00:00
|
|
|
$(document).ready(function() {
|
2016-10-12 21:52:59 +00:00
|
|
|
// Improves browser compatibility
|
|
|
|
|
require('whatwg-fetch');
|
|
|
|
|
|
|
|
|
|
var $container = $('.container');
|
2016-10-12 22:55:31 +00:00
|
|
|
var $url = $('#url');
|
|
|
|
|
var $outputFormat = $('#diff-url-options-output-format');
|
|
|
|
|
var $showFiles = $('#diff-url-options-show-files');
|
|
|
|
|
var $matching = $('#diff-url-options-matching');
|
|
|
|
|
var $wordThreshold = $('#diff-url-options-match-words-threshold');
|
|
|
|
|
var $matchingMaxComparisons = $('#diff-url-options-matching-max-comparisons');
|
2016-10-12 21:52:59 +00:00
|
|
|
|
|
|
|
|
var hash = window.location.hash
|
2016-10-12 22:55:31 +00:00
|
|
|
.replace(/^(#!?\/?)/, '');
|
2016-10-12 21:52:59 +00:00
|
|
|
|
|
|
|
|
var search = window.location.search;
|
|
|
|
|
|
|
|
|
|
if (hash) {
|
|
|
|
|
$url.val(hash);
|
2016-10-15 11:13:09 +00:00
|
|
|
smartDraw(hash);
|
2016-10-12 21:52:59 +00:00
|
|
|
} else if (search) {
|
|
|
|
|
try {
|
|
|
|
|
var url = search
|
2016-10-12 22:55:31 +00:00
|
|
|
.split('?')[1]
|
|
|
|
|
.split('diff=')[1]
|
|
|
|
|
.split('&')[0];
|
2016-10-12 21:52:59 +00:00
|
|
|
$url.val(url);
|
2016-10-15 11:13:09 +00:00
|
|
|
smartDraw(url);
|
2016-10-12 21:52:59 +00:00
|
|
|
} catch (_ignore) {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-15 11:13:09 +00:00
|
|
|
bind();
|
2016-10-12 21:52:59 +00:00
|
|
|
|
|
|
|
|
$outputFormat
|
|
|
|
|
.add($showFiles)
|
|
|
|
|
.add($matching)
|
|
|
|
|
.add($wordThreshold)
|
|
|
|
|
.add($matchingMaxComparisons)
|
2016-10-12 22:55:31 +00:00
|
|
|
.change(function() {
|
2016-10-15 11:13:09 +00:00
|
|
|
smartDraw();
|
2016-10-12 21:52:59 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
function bind() {
|
2016-10-12 22:55:31 +00:00
|
|
|
$('#url-btn').click(function(e) {
|
2016-10-12 21:52:59 +00:00
|
|
|
e.preventDefault();
|
2016-10-15 11:13:09 +00:00
|
|
|
var url = $url.val();
|
|
|
|
|
smartDraw(url);
|
2016-10-12 21:52:59 +00:00
|
|
|
});
|
2016-10-12 22:17:39 +00:00
|
|
|
|
2016-10-12 22:55:31 +00:00
|
|
|
$url.on('paste', function(e) {
|
2016-10-15 11:13:09 +00:00
|
|
|
var url = e.originalEvent.clipboardData.getData('Text');
|
|
|
|
|
smartDraw(url);
|
2016-10-12 22:17:39 +00:00
|
|
|
});
|
2016-10-12 21:52:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function prepareUrl(url) {
|
2016-10-15 11:13:09 +00:00
|
|
|
var fetchUrl;
|
|
|
|
|
var headers = new Headers();
|
|
|
|
|
|
2016-10-12 21:52:59 +00:00
|
|
|
var githubCommitUrl = /^https?:\/\/(?:www\.)?github\.com\/(.*?)\/(.*?)\/commit\/(.*?)(?:\.diff)?(?:\.patch)?(?:\/.*)?$/;
|
|
|
|
|
var githubPrUrl = /^https?:\/\/(?:www\.)?github\.com\/(.*?)\/(.*?)\/pull\/(.*?)(?:\.diff)?(?:\.patch)?(?:\/.*)?$/;
|
|
|
|
|
|
|
|
|
|
var gitlabCommitUrl = /^https?:\/\/(?:www\.)?gitlab\.com\/(.*?)\/(.*?)\/commit\/(.*?)(?:\.diff)?(?:\.patch)?(?:\/.*)?$/;
|
|
|
|
|
var gitlabPrUrl = /^https?:\/\/(?:www\.)?gitlab\.com\/(.*?)\/(.*?)\/merge_requests\/(.*?)(?:\.diff)?(?:\.patch)?(?:\/.*)?$/;
|
|
|
|
|
|
|
|
|
|
var bitbucketCommitUrl = /^https?:\/\/(?:www\.)?bitbucket\.org\/(.*?)\/(.*?)\/commits\/(.*?)(?:\/raw)?(?:\/.*)?$/;
|
|
|
|
|
var bitbucketPrUrl = /^https?:\/\/(?:www\.)?bitbucket\.org\/(.*?)\/(.*?)\/pull-requests\/(.*?)(?:\/.*)?$/;
|
|
|
|
|
|
2016-10-15 11:13:09 +00:00
|
|
|
function gitLabUrlGen(userName, projectName, type, value) {
|
|
|
|
|
return 'https://crossorigin.me/https://gitlab.com/' + userName + '/' + projectName + '/' + type + '/' + value + '.diff';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function gitHubUrlGen(userName, projectName, type, value) {
|
|
|
|
|
headers.append('Accept', 'application/vnd.github.v3.diff');
|
|
|
|
|
return 'https://api.github.com/repos/' + userName + '/' + projectName + '/' + type + '/' + value;
|
2016-10-12 21:52:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function bitbucketUrlGen(userName, projectName, type, value) {
|
2016-10-12 22:55:31 +00:00
|
|
|
var baseUrl = 'https://bitbucket.org/api/2.0/repositories/';
|
|
|
|
|
if (type === 'pullrequests') {
|
|
|
|
|
return baseUrl + userName + '/' + projectName + '/pullrequests/' + value + '/diff';
|
2016-10-12 21:52:59 +00:00
|
|
|
}
|
2016-10-12 22:55:31 +00:00
|
|
|
return baseUrl + userName + '/' + projectName + '/diff/' + value;
|
2016-10-12 21:52:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var values;
|
2016-10-15 11:13:09 +00:00
|
|
|
if ((values = githubCommitUrl.exec(url))) {
|
|
|
|
|
fetchUrl = gitHubUrlGen(values[1], values[2], 'commits', values[3]);
|
2016-10-12 21:52:59 +00:00
|
|
|
} else if ((values = githubPrUrl.exec(url))) {
|
2016-10-15 11:13:09 +00:00
|
|
|
fetchUrl = gitHubUrlGen(values[1], values[2], 'pulls', values[3]);
|
2016-10-12 21:52:59 +00:00
|
|
|
} else if ((values = gitlabCommitUrl.exec(url))) {
|
2016-10-15 11:13:09 +00:00
|
|
|
fetchUrl = gitLabUrlGen(values[1], values[2], 'commit', values[3]);
|
2016-10-12 21:52:59 +00:00
|
|
|
} else if ((values = gitlabPrUrl.exec(url))) {
|
2016-10-15 11:13:09 +00:00
|
|
|
fetchUrl = gitLabUrlGen(values[1], values[2], 'merge_requests', values[3]);
|
2016-10-12 21:52:59 +00:00
|
|
|
} else if ((values = bitbucketCommitUrl.exec(url))) {
|
2016-10-15 11:13:09 +00:00
|
|
|
fetchUrl = bitbucketUrlGen(values[1], values[2], 'commit', values[3]);
|
2016-10-12 21:52:59 +00:00
|
|
|
} else if ((values = bitbucketPrUrl.exec(url))) {
|
2016-10-15 11:13:09 +00:00
|
|
|
fetchUrl = bitbucketUrlGen(values[1], values[2], 'pullrequests', values[3]);
|
2016-10-12 21:52:59 +00:00
|
|
|
} else {
|
2016-10-12 22:55:31 +00:00
|
|
|
console.info('Could not parse url, using the provided url.');
|
2016-10-15 11:52:16 +00:00
|
|
|
fetchUrl = 'https://crossorigin.me/' + url;
|
2016-10-12 21:52:59 +00:00
|
|
|
}
|
|
|
|
|
|
2016-10-15 11:13:09 +00:00
|
|
|
return {
|
2016-10-15 11:41:15 +00:00
|
|
|
originalUrl: url,
|
2016-10-15 11:13:09 +00:00
|
|
|
url: fetchUrl,
|
|
|
|
|
headers: headers
|
|
|
|
|
};
|
2016-10-12 21:52:59 +00:00
|
|
|
}
|
|
|
|
|
|
2016-10-15 11:41:15 +00:00
|
|
|
function smartDraw(urlOpt) {
|
|
|
|
|
var url = urlOpt || $url.val();
|
|
|
|
|
var req = prepareUrl(url);
|
|
|
|
|
draw(req);
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-15 11:13:09 +00:00
|
|
|
function draw(req) {
|
2016-10-15 11:41:15 +00:00
|
|
|
if (!validateUrl(req.url)) {
|
2016-10-15 11:56:55 +00:00
|
|
|
console.error('Invalid url provided!');
|
2016-10-15 11:41:15 +00:00
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-15 11:56:55 +00:00
|
|
|
if (validateUrl(req.originalUrl)) updateUrl(req.originalUrl);
|
2016-10-15 11:41:15 +00:00
|
|
|
|
2016-10-12 21:52:59 +00:00
|
|
|
var outputFormat = $outputFormat.val();
|
2016-10-12 22:55:31 +00:00
|
|
|
var showFiles = $showFiles.is(':checked');
|
2016-10-12 21:52:59 +00:00
|
|
|
var matching = $matching.val();
|
|
|
|
|
var wordThreshold = $wordThreshold.val();
|
|
|
|
|
var matchingMaxComparisons = $matchingMaxComparisons.val();
|
|
|
|
|
|
2016-10-15 11:13:09 +00:00
|
|
|
fetch(req.url, {
|
|
|
|
|
method: 'GET',
|
|
|
|
|
headers: req.headers,
|
|
|
|
|
mode: 'cors',
|
|
|
|
|
cache: 'default'
|
|
|
|
|
})
|
2016-10-12 22:55:31 +00:00
|
|
|
.then(function(res) {
|
|
|
|
|
return res.text();
|
2016-10-12 21:52:59 +00:00
|
|
|
})
|
2016-10-12 22:55:31 +00:00
|
|
|
.then(function(data) {
|
2016-10-12 21:52:59 +00:00
|
|
|
var container = '#url-diff-container';
|
|
|
|
|
var diff2htmlUi = new Diff2HtmlUI({diff: data});
|
|
|
|
|
|
2016-10-12 22:55:31 +00:00
|
|
|
if (outputFormat === 'side-by-side') {
|
2016-10-15 20:47:32 +00:00
|
|
|
$container.css({'min-width': '1280px'});
|
2016-10-12 21:52:59 +00:00
|
|
|
} else {
|
2016-10-15 20:47:32 +00:00
|
|
|
$container.css({'width': '980px'});
|
2016-10-12 21:52:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
diff2htmlUi.draw(container, {
|
|
|
|
|
outputFormat: outputFormat,
|
|
|
|
|
showFiles: showFiles,
|
|
|
|
|
matching: matching,
|
|
|
|
|
matchWordsThreshold: wordThreshold,
|
2016-10-12 22:17:39 +00:00
|
|
|
matchingMaxComparisons: matchingMaxComparisons,
|
|
|
|
|
synchronisedScroll: true
|
2016-10-12 21:52:59 +00:00
|
|
|
});
|
|
|
|
|
diff2htmlUi.fileListCloseable(container, false);
|
|
|
|
|
diff2htmlUi.highlightCode(container);
|
|
|
|
|
});
|
|
|
|
|
}
|
2016-10-15 11:41:15 +00:00
|
|
|
|
|
|
|
|
function validateUrl(url) {
|
|
|
|
|
return /^(?:(?:(?:https?|ftp):)?\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})).?)(?::\d{2,5})?(?:[/?#]\S*)?$/i.test(url);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function updateUrl(url) {
|
|
|
|
|
if (window.history.pushState) {
|
|
|
|
|
window.history.pushState('', '/', 'url.html?diff=' + url);
|
|
|
|
|
} else {
|
|
|
|
|
window.location.hash = '';
|
|
|
|
|
window.location.search = '?diff=' + url;
|
|
|
|
|
}
|
|
|
|
|
}
|
2016-10-12 21:52:59 +00:00
|
|
|
});
|