mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-22 12:41:19 +01:00
Highlighting blame is broken if there is an unavailable commit
Test Plan: .../PhotoSnowlift.js?view=blame Reviewers: jungejason Reviewed By: jungejason CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D2165
This commit is contained in:
parent
7451c1f6c9
commit
aa0d0396a6
2 changed files with 17 additions and 15 deletions
|
@ -250,7 +250,7 @@ final class DiffusionBrowseFileController extends DiffusionController {
|
||||||
$selected) {
|
$selected) {
|
||||||
|
|
||||||
if ($blame_dict) {
|
if ($blame_dict) {
|
||||||
$epoch_list = ipull($blame_dict, 'epoch');
|
$epoch_list = ipull(ifilter($blame_dict, 'epoch'), 'epoch');
|
||||||
$epoch_min = min($epoch_list);
|
$epoch_min = min($epoch_list);
|
||||||
$epoch_max = max($epoch_list);
|
$epoch_max = max($epoch_list);
|
||||||
$epoch_range = ($epoch_max - $epoch_min) + 1;
|
$epoch_range = ($epoch_max - $epoch_min) + 1;
|
||||||
|
@ -298,27 +298,30 @@ final class DiffusionBrowseFileController extends DiffusionController {
|
||||||
} else {
|
} else {
|
||||||
$blame = $blame_dict[$rev];
|
$blame = $blame_dict[$rev];
|
||||||
|
|
||||||
$color_ratio = ($blame['epoch'] - $epoch_min) / $epoch_range;
|
if (!isset($blame['epoch'])) {
|
||||||
|
$color = '#ffd'; // Render as warning.
|
||||||
|
} else {
|
||||||
|
$color_ratio = ($blame['epoch'] - $epoch_min) / $epoch_range;
|
||||||
|
$color_value = 0xF6 * (1.0 - $color_ratio);
|
||||||
|
$color = sprintf(
|
||||||
|
'#%02x%02x%02x',
|
||||||
|
$color_value,
|
||||||
|
0xF6,
|
||||||
|
$color_value);
|
||||||
|
}
|
||||||
|
|
||||||
$color_value = 0xF6 * (1.0 - $color_ratio);
|
$display_line['epoch'] = idx($blame, 'epoch');
|
||||||
$color = sprintf(
|
|
||||||
'#%02x%02x%02x',
|
|
||||||
$color_value,
|
|
||||||
0xF6,
|
|
||||||
$color_value);
|
|
||||||
|
|
||||||
$display_line['epoch'] = $blame['epoch'];
|
|
||||||
$display_line['color'] = $color;
|
$display_line['color'] = $color;
|
||||||
$display_line['commit'] = $rev;
|
$display_line['commit'] = $rev;
|
||||||
|
|
||||||
if (isset($blame_dict[$rev]['handle'])) {
|
if (isset($blame['handle'])) {
|
||||||
$author_link = $blame_dict[$rev]['handle']->renderLink();
|
$author_link = $blame['handle']->renderLink();
|
||||||
} else {
|
} else {
|
||||||
$author_link = phutil_render_tag(
|
$author_link = phutil_render_tag(
|
||||||
'span',
|
'span',
|
||||||
array(
|
array(
|
||||||
),
|
),
|
||||||
phutil_escape_html($blame_dict[$rev]['author']));
|
phutil_escape_html($blame['author']));
|
||||||
}
|
}
|
||||||
$display_line['author'] = $author_link;
|
$display_line['author'] = $author_link;
|
||||||
|
|
||||||
|
|
|
@ -59,8 +59,7 @@ abstract class DiffusionFileContentQuery extends DiffusionQuery {
|
||||||
list($rev_id, $author, $text) = $line;
|
list($rev_id, $author, $text) = $line;
|
||||||
$rev_id = $rev_list[$k];
|
$rev_id = $rev_list[$k];
|
||||||
|
|
||||||
if (!isset($blame_dict[$rev_id]) &&
|
if (!isset($blame_dict[$rev_id])) {
|
||||||
!isset($blame_dict[$rev_id]['author'] )) {
|
|
||||||
$blame_dict[$rev_id]['author'] = $author;
|
$blame_dict[$rev_id]['author'] = $author;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue