2016-10-26 04:02:58 -04:00
|
|
|
/* eslint-disable */
|
2016-07-24 16:45:11 -04:00
|
|
|
(function() {
|
|
|
|
this.Diff = (function() {
|
|
|
|
var UNFOLD_COUNT;
|
|
|
|
|
|
|
|
UNFOLD_COUNT = 20;
|
|
|
|
|
|
|
|
function Diff() {
|
|
|
|
$('.files .diff-file').singleFileDiff();
|
|
|
|
this.filesCommentButton = $('.files .diff-file').filesCommentButton();
|
2016-09-19 19:02:52 -04:00
|
|
|
if (this.diffViewType() === 'parallel') {
|
|
|
|
$('.content-wrapper .container-fluid').removeClass('container-limited');
|
|
|
|
}
|
2016-07-24 16:45:11 -04:00
|
|
|
$(document).off('click', '.js-unfold');
|
|
|
|
$(document).on('click', '.js-unfold', (function(_this) {
|
|
|
|
return function(event) {
|
2016-07-21 14:44:12 -04:00
|
|
|
var line_number, link, file, offset, old_line, params, prev_new_line, prev_old_line, ref, ref1, since, target, to, unfold, unfoldBottom;
|
2016-07-24 16:45:11 -04:00
|
|
|
target = $(event.target);
|
|
|
|
unfoldBottom = target.hasClass('js-unfold-bottom');
|
|
|
|
unfold = true;
|
|
|
|
ref = _this.lineNumbers(target.parent()), old_line = ref[0], line_number = ref[1];
|
|
|
|
offset = line_number - old_line;
|
|
|
|
if (unfoldBottom) {
|
|
|
|
line_number += 1;
|
|
|
|
since = line_number;
|
|
|
|
to = line_number + UNFOLD_COUNT;
|
|
|
|
} else {
|
|
|
|
ref1 = _this.lineNumbers(target.parent().prev()), prev_old_line = ref1[0], prev_new_line = ref1[1];
|
|
|
|
line_number -= 1;
|
|
|
|
to = line_number;
|
|
|
|
if (line_number - UNFOLD_COUNT > prev_new_line + 1) {
|
|
|
|
since = line_number - UNFOLD_COUNT;
|
|
|
|
} else {
|
|
|
|
since = prev_new_line + 1;
|
|
|
|
unfold = false;
|
|
|
|
}
|
|
|
|
}
|
2016-07-21 14:44:12 -04:00
|
|
|
file = target.parents('.diff-file');
|
|
|
|
link = file.data('blob-diff-path');
|
2016-07-24 16:45:11 -04:00
|
|
|
params = {
|
|
|
|
since: since,
|
|
|
|
to: to,
|
|
|
|
bottom: unfoldBottom,
|
|
|
|
offset: offset,
|
|
|
|
unfold: unfold,
|
2016-07-26 23:32:10 -04:00
|
|
|
// indent is used to compensate for single space indent to fit
|
|
|
|
// '+' and '-' prepended to diff lines,
|
|
|
|
// see https://gitlab.com/gitlab-org/gitlab-ce/issues/707
|
2016-07-21 14:44:12 -04:00
|
|
|
indent: 1,
|
|
|
|
view: file.data('view')
|
2016-07-24 16:45:11 -04:00
|
|
|
};
|
|
|
|
return $.get(link, params, function(response) {
|
|
|
|
return target.parent().replaceWith(response);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
})(this));
|
|
|
|
}
|
|
|
|
|
2016-09-19 19:02:52 -04:00
|
|
|
Diff.prototype.diffViewType = function() {
|
|
|
|
return $('.inline-parallel-buttons a.active').data('view-type');
|
|
|
|
}
|
|
|
|
|
2016-07-24 16:45:11 -04:00
|
|
|
Diff.prototype.lineNumbers = function(line) {
|
|
|
|
if (!line.children().length) {
|
|
|
|
return [0, 0];
|
|
|
|
}
|
2016-07-21 14:44:12 -04:00
|
|
|
|
|
|
|
return line.find('.diff-line-num').map(function() {
|
|
|
|
return parseInt($(this).data('linenumber'));
|
|
|
|
});
|
2016-07-24 16:45:11 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
return Diff;
|
|
|
|
|
|
|
|
})();
|
|
|
|
|
|
|
|
}).call(this);
|