1
0
Fork 0
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:
vrana 2012-01-24 00:37:50 -08:00
parent 28a5f9f44d
commit 79218b6e47
2 changed files with 35 additions and 36 deletions

View file

@ -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(

View file

@ -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));
}
} }