Browse Source

js fix R1-L1 highlight

pull/972/head
Alexey Makhov 10 years ago
parent
commit
3efe3f42e8
  1. 33
      public/ng/js/gogs.js

33
public/ng/js/gogs.js

@ -209,27 +209,28 @@ var Gogs = {};
$list.parents('tr').removeClass('end-selected-line'); $list.parents('tr').removeClass('end-selected-line');
$list.parents('tr').find('td').removeClass('selected-line'); $list.parents('tr').find('td').removeClass('selected-line');
if ($from) { if ($from) {
var expr = new RegExp(/diff-(\w+)([LR])(\d+)/); var expr = new RegExp(/diff-(\w+)([LR]\d+)/);
var selectMatches = $select.attr('rel').match(expr) var selectMatches = $select.attr('rel').match(expr)
var fromMatches = $from.attr('rel').match(expr) var fromMatches = $from.attr('rel').match(expr)
var a = parseInt(selectMatches[3]); var selectTop = $select.offset().top;
var b = parseInt(fromMatches[3]); var fromTop = $from.offset().top;
var linesIntToStr = {}; var hash;
linesIntToStr[a] = selectMatches[3];
linesIntToStr[b] = fromMatches[3]; if (selectMatches[2] != fromMatches[2]) {
if ((selectTop > fromTop)) {
var c; $startElem = $from;
if (a != b) { $endElem = $select;
if (a > b) { hash = fromMatches[1]+fromMatches[2] + '-' + selectMatches[2];
c = a; } else {
a = b; $startElem = $select;
b = c; $endElem = $from;
hash = selectMatches[1]+selectMatches[2] + '-' + fromMatches[2];
} }
$('[rel=diff-'+fromMatches[1] + fromMatches[2] + linesIntToStr[b] + ']').parents('tr').next().addClass('end-selected-line'); $endElem.parents('tr').next().addClass('end-selected-line');
var $selectedLines = $('[rel=diff-'+fromMatches[1]+selectMatches[2] + linesIntToStr[a] + ']').parents('tr').nextUntil('.end-selected-line').andSelf(); var $selectedLines = $startElem.parents('tr').nextUntil('.end-selected-line').andSelf();
$selectedLines.find('td.lines-num > span').addClass('active') $selectedLines.find('td.lines-num > span').addClass('active')
$selectedLines.find('td').addClass('selected-line'); $selectedLines.find('td').addClass('selected-line');
$.changeHash('#diff-'+fromMatches[1]+fromMatches[2] + linesIntToStr[a] + '-' + selectMatches[2] + + linesIntToStr[b]); $.changeHash('#diff-'+hash);
return return
} }
} }

Loading…
Cancel
Save