1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-25 14:08:19 +01:00

In Herald transcript rendering, don't store display labels in keys

Summary:
Ref T13480. Currently, when Herald renders a transcript, it puts display labels into array keys. This is a bad pattern for several reasons, notably that the values must be scalar (so you can't add icons or other markup later) and the values must be unique (which is easily violated because many values are translated).

Instead, keep values as list items.

Test Plan: Viewed Herald transcripts, saw no (meaningful) change in rendering output.

Maniphest Tasks: T13480

Differential Revision: https://secure.phabricator.com/D20949
This commit is contained in:
epriestley 2020-01-23 11:47:31 -08:00
parent a5a9a5e002
commit 19662e33bc

View file

@ -453,31 +453,47 @@ final class HeraldTranscriptController extends HeraldController {
$object_xscript = $xscript->getObjectTranscript(); $object_xscript = $xscript->getObjectTranscript();
$data = array(); $rows = array();
if ($object_xscript) { if ($object_xscript) {
$phid = $object_xscript->getPHID(); $phid = $object_xscript->getPHID();
$handles = $this->handles; $handles = $this->handles;
$data += array( $rows[] = array(
pht('Object Name') => $object_xscript->getName(), pht('Object Name'),
pht('Object Type') => $object_xscript->getType(), $object_xscript->getName(),
pht('Object PHID') => $phid, );
pht('Object Link') => $handles[$phid]->renderLink(),
$rows[] = array(
pht('Object Type'),
$object_xscript->getType(),
);
$rows[] = array(
pht('Object PHID'),
$phid,
);
$rows[] = array(
pht('Object Link'),
$handles[$phid]->renderLink(),
); );
} }
$data += $xscript->getMetadataMap(); foreach ($xscript->getMetadataMap() as $key => $value) {
$rows[] = array(
$key,
$value,
);
}
if ($object_xscript) { if ($object_xscript) {
foreach ($object_xscript->getFields() as $field => $value) { foreach ($object_xscript->getFields() as $field => $value) {
$field = idx($field_names, $field, '['.$field.'?]'); if (isset($field_names[$field])) {
$data['Field: '.$field] = $value; $field_name = pht('Field: %s', $field_names[$field]);
} } else {
} $field_name = pht('Unknown Field ("%s")', $field_name);
}
$rows = array();
foreach ($data as $name => $value) {
if (!($value instanceof PhutilSafeHTML)) {
if (!is_scalar($value) && !is_null($value)) { if (!is_scalar($value) && !is_null($value)) {
$value = implode("\n", $value); $value = implode("\n", $value);
} }
@ -490,9 +506,12 @@ final class HeraldTranscriptController extends HeraldController {
), ),
$value); $value);
} }
}
$rows[] = array($name, $value); $rows[] = array(
$field_name,
$value,
);
}
} }
$property_list = new PHUIPropertyListView(); $property_list = new PHUIPropertyListView();