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:
parent
6404fa5c0e
commit
222b25f3a2
1 changed files with 18 additions and 0 deletions
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue