1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-05 12:21:02 +01:00

Separate reading object values out of didSetObject() in CustomField

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
This commit is contained in:
epriestley 2014-02-21 14:44:01 -08:00
parent ce5eafe7f1
commit b62420e6e4
9 changed files with 34 additions and 21 deletions

View file

@ -79,7 +79,7 @@ abstract class DifferentialCoreCustomField
return true; return true;
} }
protected function didSetObject(PhabricatorCustomFieldInterface $object) { public function readValueFromObject(PhabricatorCustomFieldInterface $object) {
if ($this->isCoreFieldRequired()) { if ($this->isCoreFieldRequired()) {
$this->setFieldError(true); $this->setFieldError(true);
} }

View file

@ -47,15 +47,9 @@ final class ManiphestTaskDetailController extends ManiphestController {
$field_list = PhabricatorCustomField::getObjectFields( $field_list = PhabricatorCustomField::getObjectFields(
$task, $task,
PhabricatorCustomField::ROLE_VIEW); PhabricatorCustomField::ROLE_VIEW);
$field_list
foreach ($field_list->getFields() as $field) { ->setViewer($user)
$field->setObject($task); ->readFieldsFromStorage($task);
$field->setViewer($user);
}
$field_list->readFieldsFromStorage($task);
$aux_fields = $field_list->getFields();
$e_commit = PhabricatorEdgeConfig::TYPE_TASK_HAS_COMMIT; $e_commit = PhabricatorEdgeConfig::TYPE_TASK_HAS_COMMIT;
$e_dep_on = PhabricatorEdgeConfig::TYPE_TASK_DEPENDS_ON_TASK; $e_dep_on = PhabricatorEdgeConfig::TYPE_TASK_DEPENDS_ON_TASK;

View file

@ -158,11 +158,6 @@ final class ManiphestTaskEditController extends ManiphestController {
$task, $task,
PhabricatorCustomField::ROLE_EDIT); PhabricatorCustomField::ROLE_EDIT);
$field_list->setViewer($user); $field_list->setViewer($user);
foreach ($field_list->getFields() as $field) {
$field->setObject($task);
}
$field_list->readFieldsFromStorage($task); $field_list->readFieldsFromStorage($task);
$aux_fields = $field_list->getFields(); $aux_fields = $field_list->getFields();
@ -389,6 +384,7 @@ final class ManiphestTaskEditController extends ManiphestController {
if ($fields) { if ($fields) {
id(new PhabricatorCustomFieldList($fields)) id(new PhabricatorCustomFieldList($fields))
->setViewer($user)
->readFieldsFromStorage($template_task); ->readFieldsFromStorage($template_task);
foreach ($fields as $key => $field) { foreach ($fields as $key => $field) {

View file

@ -29,7 +29,7 @@ final class PhabricatorUserBlurbField
return true; return true;
} }
protected function didSetObject(PhabricatorCustomFieldInterface $object) { public function readValueFromObject(PhabricatorCustomFieldInterface $object) {
$this->value = $object->loadUserProfile()->getBlurb(); $this->value = $object->loadUserProfile()->getBlurb();
} }

View file

@ -29,7 +29,7 @@ final class PhabricatorUserRealNameField
return true; return true;
} }
protected function didSetObject(PhabricatorCustomFieldInterface $object) { public function readValueFromObject(PhabricatorCustomFieldInterface $object) {
$this->value = $object->getRealName(); $this->value = $object->getRealName();
} }

View file

@ -29,7 +29,7 @@ final class PhabricatorUserTitleField
return true; return true;
} }
protected function didSetObject(PhabricatorCustomFieldInterface $object) { public function readValueFromObject(PhabricatorCustomFieldInterface $object) {
$this->value = $object->loadUserProfile()->getTitle(); $this->value = $object->loadUserProfile()->getTitle();
} }

View file

@ -347,6 +347,7 @@ abstract class PhabricatorCustomField {
* Sets the object this field belongs to. * Sets the object this field belongs to.
* *
* @param PhabricatorCustomFieldInterface The object this field belongs to. * @param PhabricatorCustomFieldInterface The object this field belongs to.
* @return this
* @task context * @task context
*/ */
final public function setObject(PhabricatorCustomFieldInterface $object) { final public function setObject(PhabricatorCustomFieldInterface $object) {
@ -361,6 +362,21 @@ abstract class PhabricatorCustomField {
} }
/**
* Read object data into local field storage, if applicable.
*
* @param PhabricatorCustomFieldInterface The object this field belongs to.
* @return this
* @task context
*/
public function readValueFromObject(PhabricatorCustomFieldInterface $object) {
if ($this->proxy) {
$this->proxy->readValueFromObject($object);
}
return $this;
}
/** /**
* Get the object this field belongs to. * Get the object this field belongs to.
* *

View file

@ -39,6 +39,11 @@ final class PhabricatorCustomFieldList extends Phobject {
public function readFieldsFromStorage( public function readFieldsFromStorage(
PhabricatorCustomFieldInterface $object) { PhabricatorCustomFieldInterface $object) {
foreach ($this->fields as $field) {
$field->setObject($object);
$field->readValueFromObject($object);
}
$keys = array(); $keys = array();
foreach ($this->fields as $field) { foreach ($this->fields as $field) {
if ($field->shouldEnableForRole(PhabricatorCustomField::ROLE_STORAGE)) { if ($field->shouldEnableForRole(PhabricatorCustomField::ROLE_STORAGE)) {

View file

@ -180,7 +180,9 @@ final class AphrontFormPolicyControl extends AphrontFormControl {
'customPlaceholder' => $this->getCustomPolicyPlaceholder(), 'customPlaceholder' => $this->getCustomPolicyPlaceholder(),
)); ));
$selected = $flat_options[$this->getValue()]; $selected = idx($flat_options, $this->getValue(), array());
$selected_icon = idx($selected, 'icon');
$selected_name = idx($selected, 'name');
return phutil_tag( return phutil_tag(
'div', 'div',
@ -205,8 +207,8 @@ final class AphrontFormPolicyControl extends AphrontFormControl {
'class' => 'phui-button-text', 'class' => 'phui-button-text',
), ),
array( array(
$icons[$selected['icon']], idx($icons, $selected_icon),
$selected['name'], $selected_name,
)), )),
)), )),
$input, $input,