Browse Source

js fix R1-L1 highlight

for-closed-social
Alexey Makhov 9 years ago
parent
commit
3efe3f42e8
1 changed files with 17 additions and 16 deletions
  1. +17
    -16
      public/ng/js/gogs.js

+ 17
- 16
public/ng/js/gogs.js View File

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

Loading…
Cancel
Save