1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-04 11:51:02 +01:00

Allow CCs to be specified and edited for mocks

Summary: Not sure if we're going to do reviewers or whatever, but let mock creators share mocks with lists or individuals.

Test Plan: Created a mock with "duck" and "dog" cc'd, verified they showed up on the email.

Reviewers: chad

Reviewed By: chad

CC: aran

Maniphest Tasks: T2568

Differential Revision: https://secure.phabricator.com/D5056
This commit is contained in:
epriestley 2013-02-22 05:44:46 -08:00
parent 6404fa5c0e
commit 222b25f3a2

View file

@ -51,6 +51,8 @@ final class PholioMockEditController extends PholioController {
$v_name = $mock->getName(); $v_name = $mock->getName();
$v_desc = $mock->getDescription(); $v_desc = $mock->getDescription();
$v_view = $mock->getViewPolicy(); $v_view = $mock->getViewPolicy();
$v_cc = PhabricatorSubscribersQuery::loadSubscribersForPHID(
$mock->getPHID());
if ($request->isFormPost()) { if ($request->isFormPost()) {
$xactions = array(); $xactions = array();
@ -58,14 +60,17 @@ final class PholioMockEditController extends PholioController {
$type_name = PholioTransactionType::TYPE_NAME; $type_name = PholioTransactionType::TYPE_NAME;
$type_desc = PholioTransactionType::TYPE_DESCRIPTION; $type_desc = PholioTransactionType::TYPE_DESCRIPTION;
$type_view = PhabricatorTransactions::TYPE_VIEW_POLICY; $type_view = PhabricatorTransactions::TYPE_VIEW_POLICY;
$type_cc = PhabricatorTransactions::TYPE_SUBSCRIBERS;
$v_name = $request->getStr('name'); $v_name = $request->getStr('name');
$v_desc = $request->getStr('description'); $v_desc = $request->getStr('description');
$v_view = $request->getStr('can_view'); $v_view = $request->getStr('can_view');
$v_cc = $request->getArr('cc');
$xactions[$type_name] = $v_name; $xactions[$type_name] = $v_name;
$xactions[$type_desc] = $v_desc; $xactions[$type_desc] = $v_desc;
$xactions[$type_view] = $v_view; $xactions[$type_view] = $v_view;
$xactions[$type_cc] = array('=' => $v_cc);
if (!strlen($request->getStr('name'))) { if (!strlen($request->getStr('name'))) {
$e_name = 'Required'; $e_name = 'Required';
@ -165,6 +170,12 @@ final class PholioMockEditController extends PholioController {
// NOTE: Make this show up correctly on the rendered form. // NOTE: Make this show up correctly on the rendered form.
$mock->setViewPolicy($v_view); $mock->setViewPolicy($v_view);
$handles = id(new PhabricatorObjectHandleData($v_cc))
->setViewer($user)
->loadHandles();
$cc_tokens = mpull($handles, 'getFullName', 'getPHID');
$form = id(new AphrontFormView()) $form = id(new AphrontFormView())
->setUser($user) ->setUser($user)
->setFlexible(true) ->setFlexible(true)
@ -185,6 +196,13 @@ final class PholioMockEditController extends PholioController {
->setName('file_phids') ->setName('file_phids')
->setLabel(pht('Images')) ->setLabel(pht('Images'))
->setError($e_images)) ->setError($e_images))
->appendChild(
id(new AphrontFormTokenizerControl())
->setLabel(pht('CC'))
->setName('cc')
->setValue($cc_tokens)
->setUser($user)
->setDatasource('/typeahead/common/mailable/'))
->appendChild( ->appendChild(
id(new AphrontFormPolicyControl()) id(new AphrontFormPolicyControl())
->setUser($user) ->setUser($user)