mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 07:11:04 +01:00
Remove ReleephUserView
Summary: Fixes T3738. Facebook uses this to provide a couple of integrations (push karma, is user an intern?), but the mechanism is both very complex and not very general. Instead, these features are better implemented in Hovercards or via CustomField. We'll help Facebook integrate things when the time comes, but per discussion in T3738 none of this is critical or especially complicated. Test Plan: - Grepped for all callsites. - Viewed a request and verified that author/requestor populated and rendered correctly. Reviewers: btrahan, chad Reviewed By: chad Subscribers: epriestley Maniphest Tasks: T3738 Differential Revision: https://secure.phabricator.com/D8631
This commit is contained in:
parent
ce5714526a
commit
6c8cef3bee
6 changed files with 10 additions and 119 deletions
|
@ -2501,7 +2501,6 @@ phutil_register_library_map(array(
|
||||||
'ReleephController' => 'applications/releeph/controller/ReleephController.php',
|
'ReleephController' => 'applications/releeph/controller/ReleephController.php',
|
||||||
'ReleephDAO' => 'applications/releeph/storage/ReleephDAO.php',
|
'ReleephDAO' => 'applications/releeph/storage/ReleephDAO.php',
|
||||||
'ReleephDefaultFieldSelector' => 'applications/releeph/field/selector/ReleephDefaultFieldSelector.php',
|
'ReleephDefaultFieldSelector' => 'applications/releeph/field/selector/ReleephDefaultFieldSelector.php',
|
||||||
'ReleephDefaultUserView' => 'applications/releeph/view/user/ReleephDefaultUserView.php',
|
|
||||||
'ReleephDependsOnFieldSpecification' => 'applications/releeph/field/specification/ReleephDependsOnFieldSpecification.php',
|
'ReleephDependsOnFieldSpecification' => 'applications/releeph/field/specification/ReleephDependsOnFieldSpecification.php',
|
||||||
'ReleephDiffChurnFieldSpecification' => 'applications/releeph/field/specification/ReleephDiffChurnFieldSpecification.php',
|
'ReleephDiffChurnFieldSpecification' => 'applications/releeph/field/specification/ReleephDiffChurnFieldSpecification.php',
|
||||||
'ReleephDiffMessageFieldSpecification' => 'applications/releeph/field/specification/ReleephDiffMessageFieldSpecification.php',
|
'ReleephDiffMessageFieldSpecification' => 'applications/releeph/field/specification/ReleephDiffMessageFieldSpecification.php',
|
||||||
|
@ -2554,7 +2553,6 @@ phutil_register_library_map(array(
|
||||||
'ReleephSeverityFieldSpecification' => 'applications/releeph/field/specification/ReleephSeverityFieldSpecification.php',
|
'ReleephSeverityFieldSpecification' => 'applications/releeph/field/specification/ReleephSeverityFieldSpecification.php',
|
||||||
'ReleephStatusFieldSpecification' => 'applications/releeph/field/specification/ReleephStatusFieldSpecification.php',
|
'ReleephStatusFieldSpecification' => 'applications/releeph/field/specification/ReleephStatusFieldSpecification.php',
|
||||||
'ReleephSummaryFieldSpecification' => 'applications/releeph/field/specification/ReleephSummaryFieldSpecification.php',
|
'ReleephSummaryFieldSpecification' => 'applications/releeph/field/specification/ReleephSummaryFieldSpecification.php',
|
||||||
'ReleephUserView' => 'applications/releeph/view/user/ReleephUserView.php',
|
|
||||||
'ShellLogView' => 'applications/harbormaster/view/ShellLogView.php',
|
'ShellLogView' => 'applications/harbormaster/view/ShellLogView.php',
|
||||||
'SlowvoteEmbedView' => 'applications/slowvote/view/SlowvoteEmbedView.php',
|
'SlowvoteEmbedView' => 'applications/slowvote/view/SlowvoteEmbedView.php',
|
||||||
'SlowvoteRemarkupRule' => 'applications/slowvote/remarkup/SlowvoteRemarkupRule.php',
|
'SlowvoteRemarkupRule' => 'applications/slowvote/remarkup/SlowvoteRemarkupRule.php',
|
||||||
|
@ -5473,7 +5471,6 @@ phutil_register_library_map(array(
|
||||||
'ReleephController' => 'PhabricatorController',
|
'ReleephController' => 'PhabricatorController',
|
||||||
'ReleephDAO' => 'PhabricatorLiskDAO',
|
'ReleephDAO' => 'PhabricatorLiskDAO',
|
||||||
'ReleephDefaultFieldSelector' => 'ReleephFieldSelector',
|
'ReleephDefaultFieldSelector' => 'ReleephFieldSelector',
|
||||||
'ReleephDefaultUserView' => 'ReleephUserView',
|
|
||||||
'ReleephDependsOnFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephDependsOnFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
'ReleephDiffChurnFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephDiffChurnFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
'ReleephDiffMessageFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephDiffMessageFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
|
@ -5545,7 +5542,6 @@ phutil_register_library_map(array(
|
||||||
'ReleephSeverityFieldSpecification' => 'ReleephLevelFieldSpecification',
|
'ReleephSeverityFieldSpecification' => 'ReleephLevelFieldSpecification',
|
||||||
'ReleephStatusFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephStatusFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
'ReleephSummaryFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephSummaryFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
'ReleephUserView' => 'AphrontView',
|
|
||||||
'ShellLogView' => 'AphrontView',
|
'ShellLogView' => 'AphrontView',
|
||||||
'SlowvoteEmbedView' => 'AphrontView',
|
'SlowvoteEmbedView' => 'AphrontView',
|
||||||
'SlowvoteRemarkupRule' => 'PhabricatorRemarkupRuleObject',
|
'SlowvoteRemarkupRule' => 'PhabricatorRemarkupRuleObject',
|
||||||
|
|
|
@ -59,18 +59,6 @@ final class PhabricatorApplicationReleephConfigOptions
|
||||||
"stable.")),
|
"stable.")),
|
||||||
$this->newOption('releeph.fields', $custom_field_type, $default)
|
$this->newOption('releeph.fields', $custom_field_type, $default)
|
||||||
->setCustomData('ReleephFieldSpecification'),
|
->setCustomData('ReleephFieldSpecification'),
|
||||||
$this->newOption(
|
|
||||||
'releeph.user-view',
|
|
||||||
'class',
|
|
||||||
'ReleephDefaultUserView')
|
|
||||||
->setBaseClass('ReleephUserView')
|
|
||||||
->setSummary(pht('Extra markup when rendering usernames'))
|
|
||||||
->setDescription(
|
|
||||||
pht(
|
|
||||||
"A wrapper to render Phabricator users in Releeph, with custom ".
|
|
||||||
"markup. For example, Facebook extends this to render additional ".
|
|
||||||
"information about requestors, to each Releeph project's ".
|
|
||||||
"pushers.")),
|
|
||||||
$this->newOption(
|
$this->newOption(
|
||||||
'releeph.default-branch-template',
|
'releeph.default-branch-template',
|
||||||
'string',
|
'string',
|
||||||
|
|
|
@ -17,11 +17,6 @@ final class ReleephAuthorFieldSpecification
|
||||||
self::$authorMap[$releeph_request->getPHID()] = $author_phid;
|
self::$authorMap[$releeph_request->getPHID()] = $author_phid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ReleephUserView::getNewInstance()
|
|
||||||
->setUser($this->getUser())
|
|
||||||
->setReleephProject($this->getReleephProject())
|
|
||||||
->load(self::$authorMap);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getName() {
|
public function getName() {
|
||||||
|
@ -32,9 +27,11 @@ final class ReleephAuthorFieldSpecification
|
||||||
$rr = $this->getReleephRequest();
|
$rr = $this->getReleephRequest();
|
||||||
$author_phid = idx(self::$authorMap, $rr->getPHID());
|
$author_phid = idx(self::$authorMap, $rr->getPHID());
|
||||||
if ($author_phid) {
|
if ($author_phid) {
|
||||||
return ReleephUserView::getNewInstance()
|
$handle = id(new PhabricatorHandleQuery())
|
||||||
->setRenderUserPHID($author_phid)
|
->setViewer($this->getUser())
|
||||||
->render();
|
->withPHIDs(array($author_phid))
|
||||||
|
->executeOne();
|
||||||
|
return $handle->renderLink();
|
||||||
} else {
|
} else {
|
||||||
return 'Unknown Author';
|
return 'Unknown Author';
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,23 +7,17 @@ final class ReleephRequestorFieldSpecification
|
||||||
return 'requestor';
|
return 'requestor';
|
||||||
}
|
}
|
||||||
|
|
||||||
public function bulkLoad(array $releeph_requests) {
|
|
||||||
$phids = mpull($releeph_requests, 'getRequestUserPHID');
|
|
||||||
ReleephUserView::getNewInstance()
|
|
||||||
->setUser($this->getUser())
|
|
||||||
->setReleephProject($this->getReleephProject())
|
|
||||||
->load($phids);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getName() {
|
public function getName() {
|
||||||
return 'Requestor';
|
return 'Requestor';
|
||||||
}
|
}
|
||||||
|
|
||||||
public function renderValueForHeaderView() {
|
public function renderValueForHeaderView() {
|
||||||
$phid = $this->getReleephRequest()->getRequestUserPHID();
|
$phid = $this->getReleephRequest()->getRequestUserPHID();
|
||||||
return ReleephUserView::getNewInstance()
|
$handle = id(new PhabricatorHandleQuery())
|
||||||
->setRenderUserPHID($phid)
|
->setViewer($this->getUser())
|
||||||
->render();
|
->withPHIDs(array($phid))
|
||||||
|
->executeOne();
|
||||||
|
return $handle->renderLink();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function shouldAppearOnCommitMessage() {
|
public function shouldAppearOnCommitMessage() {
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
final class ReleephDefaultUserView extends ReleephUserView {
|
|
||||||
|
|
||||||
public function render() {
|
|
||||||
return $this->getHandle()->renderLink();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,75 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
abstract class ReleephUserView extends AphrontView {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This function should bulk load everything you need to render all the given
|
|
||||||
* user phids.
|
|
||||||
*
|
|
||||||
* Many parts of Releeph load users for rendering. Accordingly, this
|
|
||||||
* function will be called multiple times for each part of the UI that
|
|
||||||
* renders users, so you should accumulate your results on each call.
|
|
||||||
*
|
|
||||||
* You should also implement render() (from AphrontView) to render each
|
|
||||||
* user's PHID.
|
|
||||||
*/
|
|
||||||
protected function loadInner(array $phids) {
|
|
||||||
// This is a hook!
|
|
||||||
}
|
|
||||||
|
|
||||||
final public static function getNewInstance() {
|
|
||||||
$key = 'releeph.user-view';
|
|
||||||
$class = PhabricatorEnv::getEnvConfig($key);
|
|
||||||
return newv($class, array());
|
|
||||||
}
|
|
||||||
|
|
||||||
private static $handles = array();
|
|
||||||
private static $seen = array();
|
|
||||||
|
|
||||||
final public function load(array $phids) {
|
|
||||||
$todo = array();
|
|
||||||
|
|
||||||
foreach ($phids as $key => $phid) {
|
|
||||||
if (!idx(self::$seen, $phid)) {
|
|
||||||
$todo[$key] = $phid;
|
|
||||||
self::$seen[$phid] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($todo) {
|
|
||||||
self::$handles = array_merge(
|
|
||||||
self::$handles,
|
|
||||||
id(new PhabricatorHandleQuery())
|
|
||||||
->setViewer($this->getUser())
|
|
||||||
->withPHIDs($todo)
|
|
||||||
->execute());
|
|
||||||
$this->loadInner($todo);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private $phid;
|
|
||||||
private $releephProject;
|
|
||||||
|
|
||||||
final public function setRenderUserPHID($phid) {
|
|
||||||
$this->phid = $phid;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
final public function setReleephProject(ReleephProject $project) {
|
|
||||||
$this->releephProject = $project;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
final protected function getRenderUserPHID() {
|
|
||||||
return $this->phid;
|
|
||||||
}
|
|
||||||
|
|
||||||
final protected function getReleephProject() {
|
|
||||||
return $this->releephProject;
|
|
||||||
}
|
|
||||||
|
|
||||||
final protected function getHandle() {
|
|
||||||
return self::$handles[$this->phid];
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in a new issue