mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-21 04:01:30 +01:00
64dddc76c5
Summary: Ref T7689. Modernize all callsites of these methods. Test Plan: - Poked at dashboards. - Pretty sure this code is technically unreachable right now. - Viewed commit; viewed "Audit Status". - Viewed a fund; viewed "Payable to"; viewed "Owner". - Viewed herald rules; viewed "Author"; viewed "Applies To". - Viewed a Legalpad document; viewed "Contributors". - Viewed Phame post list; viewed blog; viewed post (viewed "Blog", viewed "Blogger"). - Viewed a macro; viewed "Audio". - Viewed a Phriction page; viewed "Last Author". - Viewed a Ponder question; viewed "Author". - Viewed a Ponder answer; viewed header. - Behavior changed very slightly here; whatevs. - Viewed a Countdown; viewed "Author". Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T7689 Differential Revision: https://secure.phabricator.com/D12210
181 lines
5 KiB
PHP
181 lines
5 KiB
PHP
<?php
|
|
|
|
final class PhabricatorMacroViewController
|
|
extends PhabricatorMacroController {
|
|
|
|
private $id;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = $data['id'];
|
|
}
|
|
|
|
public function shouldAllowPublic() {
|
|
return true;
|
|
}
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$user = $request->getUser();
|
|
|
|
$macro = id(new PhabricatorMacroQuery())
|
|
->setViewer($user)
|
|
->withIDs(array($this->id))
|
|
->needFiles(true)
|
|
->executeOne();
|
|
if (!$macro) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$file = $macro->getFile();
|
|
|
|
$title_short = pht('Macro "%s"', $macro->getName());
|
|
$title_long = pht('Image Macro "%s"', $macro->getName());
|
|
|
|
$actions = $this->buildActionView($macro);
|
|
|
|
$crumbs = $this->buildApplicationCrumbs();
|
|
$crumbs->addTextCrumb(
|
|
$title_short,
|
|
$this->getApplicationURI('/view/'.$macro->getID().'/'));
|
|
|
|
$properties = $this->buildPropertyView($macro, $actions);
|
|
if ($file) {
|
|
$file_view = new PHUIPropertyListView();
|
|
$file_view->addImageContent(
|
|
phutil_tag(
|
|
'img',
|
|
array(
|
|
'src' => $file->getViewURI(),
|
|
'class' => 'phabricator-image-macro-hero',
|
|
)));
|
|
}
|
|
|
|
$timeline = $this->buildTransactionTimeline(
|
|
$macro,
|
|
new PhabricatorMacroTransactionQuery());
|
|
|
|
$header = id(new PHUIHeaderView())
|
|
->setUser($user)
|
|
->setPolicyObject($macro)
|
|
->setHeader($title_long);
|
|
|
|
if (!$macro->getIsDisabled()) {
|
|
$header->setStatus('fa-check', 'bluegrey', pht('Active'));
|
|
} else {
|
|
$header->setStatus('fa-ban', 'red', pht('Archived'));
|
|
}
|
|
|
|
$is_serious = PhabricatorEnv::getEnvConfig('phabricator.serious-business');
|
|
|
|
$comment_header = $is_serious
|
|
? pht('Add Comment')
|
|
: pht('Grovel in Awe');
|
|
|
|
$draft = PhabricatorDraft::newFromUserAndKey($user, $macro->getPHID());
|
|
|
|
$add_comment_form = id(new PhabricatorApplicationTransactionCommentView())
|
|
->setUser($user)
|
|
->setObjectPHID($macro->getPHID())
|
|
->setDraft($draft)
|
|
->setHeaderText($comment_header)
|
|
->setAction($this->getApplicationURI('/comment/'.$macro->getID().'/'))
|
|
->setSubmitButtonName(pht('Add Comment'));
|
|
|
|
$object_box = id(new PHUIObjectBoxView())
|
|
->setHeader($header)
|
|
->addPropertyList($properties);
|
|
|
|
if ($file_view) {
|
|
$object_box->addPropertyList($file_view);
|
|
}
|
|
|
|
return $this->buildApplicationPage(
|
|
array(
|
|
$crumbs,
|
|
$object_box,
|
|
$timeline,
|
|
$add_comment_form,
|
|
),
|
|
array(
|
|
'title' => $title_short,
|
|
));
|
|
}
|
|
|
|
private function buildActionView(PhabricatorFileImageMacro $macro) {
|
|
$can_manage = $this->hasApplicationCapability(
|
|
PhabricatorMacroManageCapability::CAPABILITY);
|
|
|
|
$request = $this->getRequest();
|
|
$view = id(new PhabricatorActionListView())
|
|
->setUser($request->getUser())
|
|
->setObject($macro)
|
|
->setObjectURI($request->getRequestURI())
|
|
->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Edit Macro'))
|
|
->setHref($this->getApplicationURI('/edit/'.$macro->getID().'/'))
|
|
->setDisabled(!$can_manage)
|
|
->setWorkflow(!$can_manage)
|
|
->setIcon('fa-pencil'));
|
|
|
|
$view->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Edit Audio'))
|
|
->setHref($this->getApplicationURI('/audio/'.$macro->getID().'/'))
|
|
->setDisabled(!$can_manage)
|
|
->setWorkflow(!$can_manage)
|
|
->setIcon('fa-music'));
|
|
|
|
if ($macro->getIsDisabled()) {
|
|
$view->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Activate Macro'))
|
|
->setHref($this->getApplicationURI('/disable/'.$macro->getID().'/'))
|
|
->setWorkflow(true)
|
|
->setDisabled(!$can_manage)
|
|
->setIcon('fa-check'));
|
|
} else {
|
|
$view->addAction(
|
|
id(new PhabricatorActionView())
|
|
->setName(pht('Archive Macro'))
|
|
->setHref($this->getApplicationURI('/disable/'.$macro->getID().'/'))
|
|
->setWorkflow(true)
|
|
->setDisabled(!$can_manage)
|
|
->setIcon('fa-ban'));
|
|
}
|
|
|
|
return $view;
|
|
}
|
|
|
|
private function buildPropertyView(
|
|
PhabricatorFileImageMacro $macro,
|
|
PhabricatorActionListView $actions) {
|
|
$viewer = $this->getViewer();
|
|
|
|
$view = id(new PHUIPropertyListView())
|
|
->setUser($this->getRequest()->getUser())
|
|
->setObject($macro)
|
|
->setActionList($actions);
|
|
|
|
switch ($macro->getAudioBehavior()) {
|
|
case PhabricatorFileImageMacro::AUDIO_BEHAVIOR_ONCE:
|
|
$view->addProperty(pht('Audio Behavior'), pht('Play Once'));
|
|
break;
|
|
case PhabricatorFileImageMacro::AUDIO_BEHAVIOR_LOOP:
|
|
$view->addProperty(pht('Audio Behavior'), pht('Loop'));
|
|
break;
|
|
}
|
|
|
|
$audio_phid = $macro->getAudioPHID();
|
|
if ($audio_phid) {
|
|
$view->addProperty(
|
|
pht('Audio'),
|
|
$viewer->renderHandle($audio_phid));
|
|
}
|
|
|
|
$view->invokeWillRenderEvent();
|
|
|
|
return $view;
|
|
}
|
|
|
|
}
|