mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-23 21:18:19 +01:00
b62420e6e4
Summary: Ref T3886. Broadly, fields break down into two types right now: fields which store data on the object (like `DifferentialTitleField`) and fields which store data in custom field storage. The former type generally reads data from the object into local storage prior to editing, then writes it back afterward. Currently, this happens in `didSetObject()`. However, now that we load and set objects from ApplicationTransactionQuery, we'll do this extra read-field-values on view interfaces too. There, it's unnecessary and sometimes throws data-attached exceptions. Instead, separate these concepts, and do all the read-from-object / read-from-storage in one logical chunk, separate from `didSetObject()`. Test Plan: - Edited Differential revision. - Edited Maniphest task. - Edited Project. - Edited user profile. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T3886 Differential Revision: https://secure.phabricator.com/D8299
68 lines
1.6 KiB
PHP
68 lines
1.6 KiB
PHP
<?php
|
|
|
|
final class PhabricatorUserRealNameField
|
|
extends PhabricatorUserCustomField {
|
|
|
|
private $value;
|
|
|
|
public function getFieldKey() {
|
|
return 'user:realname';
|
|
}
|
|
|
|
public function getFieldName() {
|
|
return pht('Real Name');
|
|
}
|
|
|
|
public function getFieldDescription() {
|
|
return pht('Stores the real name of the user, like "Abraham Lincoln".');
|
|
}
|
|
|
|
public function canDisableField() {
|
|
return false;
|
|
}
|
|
|
|
public function shouldAppearInApplicationTransactions() {
|
|
return true;
|
|
}
|
|
|
|
public function shouldAppearInEditView() {
|
|
return true;
|
|
}
|
|
|
|
public function readValueFromObject(PhabricatorCustomFieldInterface $object) {
|
|
$this->value = $object->getRealName();
|
|
}
|
|
|
|
public function getOldValueForApplicationTransactions() {
|
|
return $this->getObject()->getRealName();
|
|
}
|
|
|
|
public function getNewValueForApplicationTransactions() {
|
|
if (!$this->isEditable()) {
|
|
return $this->getObject()->getRealName();
|
|
}
|
|
return $this->value;
|
|
}
|
|
|
|
public function applyApplicationTransactionInternalEffects(
|
|
PhabricatorApplicationTransaction $xaction) {
|
|
$this->getObject()->setRealName($xaction->getNewValue());
|
|
}
|
|
|
|
public function readValueFromRequest(AphrontRequest $request) {
|
|
$this->value = $request->getStr($this->getFieldKey());
|
|
}
|
|
|
|
public function renderEditControl(array $handles) {
|
|
return id(new AphrontFormTextControl())
|
|
->setName($this->getFieldKey())
|
|
->setValue($this->value)
|
|
->setLabel($this->getFieldName())
|
|
->setDisabled(!$this->isEditable());
|
|
}
|
|
|
|
private function isEditable() {
|
|
return PhabricatorEnv::getEnvConfig('account.editable');
|
|
}
|
|
|
|
}
|