1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-11-22 23:02:42 +01:00

Diffusion: turn branches/refs properties into links

Summary: They just beg to be clicked.

Test Plan: clicked furiously with my mouse until i got tired - went expected places.

Reviewers: epriestley

Reviewed By: epriestley

CC: aran, Korvin

Differential Revision: https://secure.phabricator.com/D2889
This commit is contained in:
David Reuss 2012-06-29 14:14:02 -07:00 committed by epriestley
parent aa95ef2463
commit 30b06c1ad0

View file

@ -361,17 +361,11 @@ final class DiffusionCommitController extends DiffusionController {
$request = $this->getDiffusionRequest(); $request = $this->getDiffusionRequest();
$contains = DiffusionContainsQuery::newFromDiffusionRequest($request); $branches = $this->buildBranches($request);
$branches = $contains->loadContainingBranches();
if ($branches) { if ($branches) {
// TODO: Separate these into 'tracked' and other; link tracked branches.
$branches = implode(', ', array_keys($branches));
$branches = phutil_escape_html($branches);
$props['Branches'] = $branches; $props['Branches'] = $branches;
} }
$tags = $this->buildTags($request); $tags = $this->buildTags($request);
if ($tags) { if ($tags) {
$props['Tags'] = $tags; $props['Tags'] = $tags;
@ -379,7 +373,7 @@ final class DiffusionCommitController extends DiffusionController {
$refs = $this->buildRefs($request); $refs = $this->buildRefs($request);
if ($refs) { if ($refs) {
$props['Refs'] = $refs; $props['References'] = $refs;
} }
if ($task_phids) { if ($task_phids) {
@ -761,6 +755,32 @@ final class DiffusionCommitController extends DiffusionController {
return $action_list; return $action_list;
} }
private function buildBranches(DiffusionRequest $request) {
$branch_query = DiffusionContainsQuery::newFromDiffusionRequest($request);
$branches = $branch_query->loadContainingBranches();
if (!$branches) {
return null;
}
$branch_links = array();
foreach ($branches as $branch => $commit) {
$branch_links[] = phutil_render_tag(
'a',
array(
'href' => $request->generateURI(
array(
'action' => 'browse',
'branch' => $branch,
)),
),
phutil_escape_html($branch));
}
$branch_links = implode(', ', $branch_links);
return $branch_links;
}
private function buildTags(DiffusionRequest $request) { private function buildTags(DiffusionRequest $request) {
$tag_limit = 10; $tag_limit = 10;
@ -822,7 +842,27 @@ final class DiffusionCommitController extends DiffusionController {
'%d', '%d',
$request->getCommit()); $request->getCommit());
return trim($stdout, "() \n"); // %d, gives a weird output format
// similar to (remote/one, remote/two, remote/three)
$refs = trim($stdout, "() \n");
$refs = explode(',', $refs);
$refs = array_map('trim', $refs);
$ref_links = array();
foreach ($refs as $ref) {
$ref_links[] = phutil_render_tag(
'a',
array(
'href' => $request->generateURI(
array(
'action' => 'browse',
'branch' => $ref,
)),
),
phutil_escape_html($ref));
}
$ref_links = implode(', ', $ref_links);
return $ref_links;
} }
private function buildRawDiffResponse(DiffusionRequest $drequest) { private function buildRawDiffResponse(DiffusionRequest $drequest) {