diff2html/website/templates/pages/demo/demo.js

234 lines
8 KiB
JavaScript
Raw Normal View History

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 searchParam = 'diff';
2016-10-12 21:52:59 +00:00
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');
2017-10-16 21:00:03 +00:00
var $wordsThreshold = $('#diff-url-options-match-words-threshold');
2016-10-12 22:55:31 +00:00
var $matchingMaxComparisons = $('#diff-url-options-matching-max-comparisons');
2016-10-12 21:52:59 +00:00
if (window.location.search) {
var url = getUrlFromSearch(window.location.search);
$url.val(url);
smartDraw(url);
2016-10-12 21:52:59 +00:00
}
bind();
2016-10-12 21:52:59 +00:00
$outputFormat
.add($showFiles)
.add($matching)
2017-10-16 21:00:03 +00:00
.add($wordsThreshold)
2016-10-12 21:52:59 +00:00
.add($matchingMaxComparisons)
2017-10-16 21:00:03 +00:00
.change(function(e) {
console.log('');
console.log(e);
console.log('');
smartDraw(null, true);
2016-10-12 21:52:59 +00:00
});
function getUrlFromSearch(search) {
try {
return search
.split('?')[1]
.split(searchParam + '=')[1]
.split('&')[0];
} catch (_ignore) {
}
return null;
}
2017-10-16 21:00:03 +00:00
function getParamsFromSearch(search) {
var map = {};
try {
search
.split('?')[1]
.split('&')
.map(function(e) {
var values = e.split('=');
map[values[0]] = values[1];
});
} catch (_ignore) {
}
return map;
}
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();
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) {
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) {
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\/(.*?)(?:\/.*)?$/;
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;
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))) {
fetchUrl = gitHubUrlGen(values[1], values[2], 'pulls', values[3]);
2016-10-12 21:52:59 +00:00
} else if ((values = gitlabCommitUrl.exec(url))) {
fetchUrl = gitLabUrlGen(values[1], values[2], 'commit', values[3]);
2016-10-12 21:52:59 +00:00
} else if ((values = gitlabPrUrl.exec(url))) {
fetchUrl = gitLabUrlGen(values[1], values[2], 'merge_requests', values[3]);
2016-10-12 21:52:59 +00:00
} else if ((values = bitbucketCommitUrl.exec(url))) {
fetchUrl = bitbucketUrlGen(values[1], values[2], 'commit', values[3]);
2016-10-12 21:52:59 +00:00
} else if ((values = bitbucketPrUrl.exec(url))) {
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
}
return {
2016-10-15 11:41:15 +00:00
originalUrl: url,
url: fetchUrl,
headers: headers
};
2016-10-12 21:52:59 +00:00
}
2017-10-16 21:00:03 +00:00
function smartDraw(urlOpt, forced) {
2016-10-15 11:41:15 +00:00
var url = urlOpt || $url.val();
var req = prepareUrl(url);
2017-10-16 21:00:03 +00:00
draw(req, forced);
2016-10-15 11:41:15 +00:00
}
2017-10-16 21:00:03 +00:00
function draw(req, forced) {
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();
2017-10-16 21:00:03 +00:00
var wordsThreshold = $wordsThreshold.val();
2016-10-12 21:52:59 +00:00
var matchingMaxComparisons = $matchingMaxComparisons.val();
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 21:18:16 +00:00
$container.css({'width': '100%'});
2016-10-12 21:52:59 +00:00
} else {
2016-10-15 21:18:16 +00:00
$container.css({'width': ''});
2016-10-12 21:52:59 +00:00
}
2017-10-16 21:00:03 +00:00
var params = getParamsFromSearch(window.location.search);
delete params[searchParam];
if (forced) {
params['outputFormat'] = outputFormat;
params['showFiles'] = showFiles;
params['matching'] = matching;
params['wordsThreshold'] = wordsThreshold;
params['matchingMaxComparisons'] = matchingMaxComparisons;
} else {
params['outputFormat'] = params['outputFormat'] || outputFormat;
params['showFiles'] = String(params['showFiles']) !== 'false' || (params['showFiles'] === null && showFiles);
params['matching'] = params['matching'] || matching;
params['wordsThreshold'] = params['wordsThreshold'] || wordsThreshold;
params['matchingMaxComparisons'] = params['matchingMaxComparisons'] || matchingMaxComparisons;
$outputFormat.val(params['outputFormat']);
$showFiles.prop('checked', params['showFiles']);
$matching.val(params['matching']);
$wordsThreshold.val(params['wordsThreshold']);
$matchingMaxComparisons.val(params['matchingMaxComparisons']);
}
params['synchronisedScroll'] = params['synchronisedScroll'] || true;
diff2htmlUi.draw(container, params);
diff2htmlUi.fileListCloseable(container, params['fileListCloseable'] || false);
2018-11-14 23:03:32 +00:00
if (params['highlight'] === undefined || params['highlight']) {
diff2htmlUi.highlightCode(container);
}
2016-10-12 21:52:59 +00:00
});
}
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) {
2017-10-16 21:00:03 +00:00
var params = getParamsFromSearch(window.location.search);
if (params[searchParam] === url) return;
params[searchParam] = url;
2017-10-16 21:00:03 +00:00
var paramString = Object.keys(params).map(function(k) { return k + '=' + params[k]; }).join('&');
2017-10-16 21:00:03 +00:00
window.location = 'demo.html?' + paramString;
2016-10-15 11:41:15 +00:00
}
2016-10-12 21:52:59 +00:00
});