1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-13 16:21:07 +01:00
phorge-phorge/src/applications/diffusion/controller/DiffusionChangeController.php

74 lines
2.1 KiB
PHP
Raw Normal View History

2011-03-14 06:03:30 +01:00
<?php
final class DiffusionChangeController extends DiffusionController {
2011-03-14 06:03:30 +01:00
public function processRequest() {
$drequest = $this->diffusionRequest;
$content = array();
2011-03-31 02:36:16 +02:00
$diff_query = DiffusionDiffQuery::newFromDiffusionRequest($drequest);
$changeset = $diff_query->loadChangeset();
2011-03-14 06:03:30 +01:00
if (!$changeset) {
// TODO: Refine this.
return new Aphront404Response();
}
$repository = $drequest->getRepository();
$callsign = $repository->getCallsign();
$commit = $drequest->getRawCommit();
$changesets = array(
0 => $changeset,
);
2011-03-31 02:36:16 +02:00
$changeset_view = new DifferentialChangesetListView();
$changeset_view->setTitle(DiffusionView::nameCommit($repository, $commit));
$changeset_view->setChangesets($changesets);
$changeset_view->setVisibleChangesets($changesets);
$changeset_view->setRenderingReferences(
array(
0 => $diff_query->getRenderingReference(),
));
$raw_params = array(
'action' => 'browse',
'params' => array(
'view' => 'raw',
),
);
$right_uri = $drequest->generateURI($raw_params);
$raw_params['params']['before'] = $drequest->getRawCommit();
$left_uri = $drequest->generateURI($raw_params);
$changeset_view->setRawFileURIs($left_uri, $right_uri);
2011-03-31 02:36:16 +02:00
$changeset_view->setRenderURI(
'/diffusion/'.$callsign.'/diff/');
$changeset_view->setWhitespace(
DifferentialChangesetParser::WHITESPACE_SHOW_ALL);
$changeset_view->setUser($this->getRequest()->getUser());
2011-03-14 06:03:30 +01:00
2011-03-31 02:36:16 +02:00
// TODO: This is pretty awkward, unify the CSS between Diffusion and
// Differential better.
require_celerity_resource('differential-core-view-css');
$content[] = $changeset_view->render();
2011-03-14 06:03:30 +01:00
$nav = $this->buildSideNav('change', true);
$nav->appendChild($content);
$crumbs = $this->buildCrumbs(
array(
'branch' => true,
'path' => true,
'view' => 'change',
));
$nav->setCrumbs($crumbs);
2011-03-14 06:03:30 +01:00
return $this->buildApplicationPage(
2011-03-14 06:03:30 +01:00
$nav,
array(
'title' => 'Change',
));
}
}