mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-20 19:51:08 +01:00
Factor out DifferentialDiffTableOfContentsView::renderChangesetLink()
Summary: Links from lint errors for large diffs don't work. This diff adds TODO for it because I am not sure how to do it. Move of changeset links rendering to a separate method would be still useful. Test Plan: Display ToC of large diff, verify link. Repeat for small diff. Reviewers: tuomaspelkonen, epriestley Reviewed By: epriestley CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1476
This commit is contained in:
parent
28a5f9f44d
commit
79218b6e47
2 changed files with 35 additions and 36 deletions
|
@ -56,6 +56,8 @@ final class DifferentialLintFieldSpecification
|
||||||
|
|
||||||
$line_link = phutil_escape_html($line);
|
$line_link = phutil_escape_html($line);
|
||||||
if (isset($path_changesets[$path])) {
|
if (isset($path_changesets[$path])) {
|
||||||
|
// TODO: Create standalone links for large diffs. Logic is in
|
||||||
|
// DifferentialDiffTableOfContentsView::renderChangesetLink().
|
||||||
$line_link = phutil_render_tag(
|
$line_link = phutil_render_tag(
|
||||||
'a',
|
'a',
|
||||||
array(
|
array(
|
||||||
|
|
|
@ -58,44 +58,9 @@ final class DifferentialDiffTableOfContentsView extends AphrontView {
|
||||||
|
|
||||||
$changesets = $this->changesets;
|
$changesets = $this->changesets;
|
||||||
foreach ($changesets as $changeset) {
|
foreach ($changesets as $changeset) {
|
||||||
$file = $changeset->getFilename();
|
|
||||||
$display_file = $changeset->getDisplayFilename();
|
|
||||||
|
|
||||||
$type = $changeset->getChangeType();
|
$type = $changeset->getChangeType();
|
||||||
$ftype = $changeset->getFileType();
|
$ftype = $changeset->getFileType();
|
||||||
|
$link = $this->renderChangesetLink($changeset);
|
||||||
if ($this->standaloneViewLink) {
|
|
||||||
$id = $changeset->getID();
|
|
||||||
if ($id) {
|
|
||||||
$vs_id = idx($this->vsMap, $id);
|
|
||||||
} else {
|
|
||||||
$vs_id = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
$ref = $vs_id ? $id.'/'.$vs_id : $id;
|
|
||||||
$detail_uri = new PhutilURI($this->renderURI);
|
|
||||||
$detail_uri->setQueryParams(
|
|
||||||
array(
|
|
||||||
'ref' => $ref,
|
|
||||||
'whitespace' => $this->whitespace,
|
|
||||||
'revision_id' => $this->revisionID,
|
|
||||||
));
|
|
||||||
|
|
||||||
$link = phutil_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => $detail_uri,
|
|
||||||
'target' => '_blank',
|
|
||||||
),
|
|
||||||
phutil_escape_html($display_file));
|
|
||||||
} else {
|
|
||||||
$link = phutil_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => '#'.$changeset->getAnchorName(),
|
|
||||||
),
|
|
||||||
phutil_escape_html($display_file));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (DifferentialChangeType::isOldLocationChangeType($type)) {
|
if (DifferentialChangeType::isOldLocationChangeType($type)) {
|
||||||
$away = $changeset->getAwayPaths();
|
$away = $changeset->getAwayPaths();
|
||||||
|
@ -170,4 +135,36 @@ final class DifferentialDiffTableOfContentsView extends AphrontView {
|
||||||
'</table>'.
|
'</table>'.
|
||||||
'</div>';
|
'</div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function renderChangesetLink(DifferentialChangeset $changeset) {
|
||||||
|
$display_file = $changeset->getDisplayFilename();
|
||||||
|
|
||||||
|
if ($this->standaloneViewLink) {
|
||||||
|
$id = $changeset->getID();
|
||||||
|
$vs_id = idx($this->vsMap, $id);
|
||||||
|
|
||||||
|
$ref = $vs_id ? $id.'/'.$vs_id : $id;
|
||||||
|
$detail_uri = new PhutilURI($this->renderURI);
|
||||||
|
$detail_uri->setQueryParams(
|
||||||
|
array(
|
||||||
|
'ref' => $ref,
|
||||||
|
'whitespace' => $this->whitespace,
|
||||||
|
'revision_id' => $this->revisionID,
|
||||||
|
));
|
||||||
|
|
||||||
|
return phutil_render_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => $detail_uri,
|
||||||
|
'target' => '_blank',
|
||||||
|
),
|
||||||
|
phutil_escape_html($display_file));
|
||||||
|
}
|
||||||
|
return phutil_render_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => '#'.$changeset->getAnchorName(),
|
||||||
|
),
|
||||||
|
phutil_escape_html($display_file));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue