mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-25 15:00:58 +01:00
3003b293d8
Summary: Fixes T7382, specifically we were drawing double navs, removed those from each page and added the correct CSS rule. Test Plan: Test a number of people and profile pages with a footer set. Reviewers: btrahan, epriestley Reviewed By: epriestley Subscribers: Korvin, epriestley Maniphest Tasks: T7382 Differential Revision: https://secure.phabricator.com/D11895
91 lines
2.3 KiB
PHP
91 lines
2.3 KiB
PHP
<?php
|
|
|
|
final class PhabricatorPeopleProfileEditController
|
|
extends PhabricatorPeopleController {
|
|
|
|
private $id;
|
|
|
|
public function shouldRequireAdmin() {
|
|
return false;
|
|
}
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = $data['id'];
|
|
}
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$viewer = $request->getUser();
|
|
|
|
$user = id(new PhabricatorPeopleQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($this->id))
|
|
->needProfileImage(true)
|
|
->requireCapabilities(
|
|
array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
))
|
|
->executeOne();
|
|
if (!$user) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$profile_uri = '/p/'.$user->getUsername().'/';
|
|
|
|
$field_list = PhabricatorCustomField::getObjectFields(
|
|
$user,
|
|
PhabricatorCustomField::ROLE_EDIT);
|
|
$field_list
|
|
->setViewer($viewer)
|
|
->readFieldsFromStorage($user);
|
|
|
|
$validation_exception = null;
|
|
if ($request->isFormPost()) {
|
|
$xactions = $field_list->buildFieldTransactionsFromRequest(
|
|
new PhabricatorUserTransaction(),
|
|
$request);
|
|
|
|
$editor = id(new PhabricatorUserProfileEditor())
|
|
->setActor($viewer)
|
|
->setContentSource(
|
|
PhabricatorContentSource::newFromRequest($request))
|
|
->setContinueOnNoEffect(true);
|
|
|
|
try {
|
|
$editor->applyTransactions($user, $xactions);
|
|
return id(new AphrontRedirectResponse())->setURI($profile_uri);
|
|
} catch (PhabricatorApplicationTransactionValidationException $ex) {
|
|
$validation_exception = $ex;
|
|
}
|
|
}
|
|
|
|
$title = pht('Edit Profile');
|
|
|
|
$form = id(new AphrontFormView())
|
|
->setUser($viewer);
|
|
|
|
$field_list->appendFieldsToForm($form);
|
|
|
|
$form
|
|
->appendChild(
|
|
id(new AphrontFormSubmitControl())
|
|
->addCancelButton($profile_uri)
|
|
->setValue(pht('Save Profile')));
|
|
|
|
$form_box = id(new PHUIObjectBoxView())
|
|
->setHeaderText(pht('Edit Profile'))
|
|
->setValidationException($validation_exception)
|
|
->setForm($form);
|
|
|
|
$nav = $this->buildIconNavView($user);
|
|
$nav->selectFilter('/');
|
|
$nav->appendChild($form_box);
|
|
|
|
return $this->buildApplicationPage(
|
|
$nav,
|
|
array(
|
|
'title' => $title,
|
|
));
|
|
}
|
|
}
|