Allow ApplicationEditor forms to be reconfigured
Summary:
Ref T9132. This diff doesn't do anything interesting, it just lays the groundwork for more interesting future diffs.
Broadly, the idea here is to let you create multiple views of each edit form. For example, we might create several different "Create Task" forms, like:
- "New Bug Report"
- "New Feature Request"
These would be views of the "Create Task" form, but with various adjustments:
- A form might have additional instructions ("how to file a good bug report").
- A form might have prefilled values for some fields (like particular projects, subscribers, or policies).
- A form might have some fields locked (so they can not be edited) or hidden.
- A form might have a different field order.
- A form might have a limited visibility policy, so only some users can access it.
This diff adds a new storage object (`EditEngineConfiguration`) to keep track of all those customizations and represent "a form which has been configured to look and work a certain way".
This doesn't let these configurations do anything useful/interesting, and you can't access them directly yet, it's just all the boring plumbing to enable more interesting behavior in the future.
Test Plan:
ApplicationEditor forms now let you manage available forms and edit the current form:
{F959025}
There's a new (bare bones) list of all available engines:
{F959030}
And if you jump into an engine, you can see all the forms for it:
{F959038}
The actual form configurations have standard detail/edit pages. The edit pages are themselves driven by ApplicationEditor, of course, so you can edit the form for editing forms.
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T9132
Differential Revision: https://secure.phabricator.com/D14453
2015-11-04 21:52:52 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PhabricatorEditEngineConfiguration
|
|
|
|
extends PhabricatorSearchDAO
|
|
|
|
implements
|
|
|
|
PhabricatorApplicationTransactionInterface,
|
|
|
|
PhabricatorPolicyInterface {
|
|
|
|
|
|
|
|
protected $engineKey;
|
|
|
|
protected $builtinKey;
|
|
|
|
protected $name;
|
|
|
|
protected $viewPolicy;
|
|
|
|
protected $editPolicy;
|
|
|
|
protected $properties = array();
|
|
|
|
protected $isDisabled = 0;
|
|
|
|
protected $isDefault = 0;
|
|
|
|
|
|
|
|
private $engine = self::ATTACHABLE;
|
|
|
|
|
|
|
|
public function getTableName() {
|
|
|
|
return 'search_editengineconfiguration';
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function initializeNewConfiguration(
|
|
|
|
PhabricatorUser $actor,
|
|
|
|
PhabricatorEditEngine $engine) {
|
|
|
|
|
|
|
|
// TODO: This should probably be controlled by a new defualt capability.
|
|
|
|
$edit_policy = PhabricatorPolicies::POLICY_ADMIN;
|
|
|
|
|
|
|
|
return id(new PhabricatorEditEngineConfiguration())
|
|
|
|
->setEngineKey($engine->getEngineKey())
|
|
|
|
->attachEngine($engine)
|
|
|
|
->setViewPolicy(PhabricatorPolicies::getMostOpenPolicy())
|
|
|
|
->setEditPolicy($edit_policy);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function generatePHID() {
|
|
|
|
return PhabricatorPHID::generateNewPHID(
|
|
|
|
PhabricatorEditEngineConfigurationPHIDType::TYPECONST);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getConfiguration() {
|
|
|
|
return array(
|
|
|
|
self::CONFIG_AUX_PHID => true,
|
|
|
|
self::CONFIG_SERIALIZATION => array(
|
|
|
|
'properties' => self::SERIALIZATION_JSON,
|
|
|
|
),
|
|
|
|
self::CONFIG_COLUMN_SCHEMA => array(
|
|
|
|
'engineKey' => 'text64',
|
|
|
|
'builtinKey' => 'text64?',
|
|
|
|
'name' => 'text255',
|
|
|
|
'isDisabled' => 'bool',
|
|
|
|
'isDefault' => 'bool',
|
|
|
|
),
|
|
|
|
self::CONFIG_KEY_SCHEMA => array(
|
|
|
|
'key_engine' => array(
|
|
|
|
'columns' => array('engineKey', 'builtinKey'),
|
|
|
|
'unique' => true,
|
|
|
|
),
|
|
|
|
'key_default' => array(
|
|
|
|
'columns' => array('engineKey', 'isDefault', 'isDisabled'),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
) + parent::getConfiguration();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getProperty($key, $default = null) {
|
|
|
|
return idx($this->properties, $key, $default);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setProperty($key, $value) {
|
|
|
|
$this->properties[$key] = $value;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function attachEngine(PhabricatorEditEngine $engine) {
|
|
|
|
$this->engine = $engine;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getEngine() {
|
|
|
|
return $this->assertAttached($this->engine);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function applyConfigurationToFields(
|
|
|
|
PhabricatorEditEngine $engine,
|
|
|
|
array $fields) {
|
|
|
|
$fields = mpull($fields, null, 'getKey');
|
|
|
|
|
|
|
|
$values = $this->getProperty('defaults', array());
|
|
|
|
foreach ($fields as $key => $field) {
|
|
|
|
if ($engine->getIsCreate()) {
|
|
|
|
if (array_key_exists($key, $values)) {
|
|
|
|
$field->readDefaultValueFromConfiguration($values[$key]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$fields = $this->reorderFields($fields);
|
|
|
|
|
2015-11-17 18:33:06 +01:00
|
|
|
$preamble = $this->getPreamble();
|
|
|
|
if (strlen($preamble)) {
|
Allow ApplicationEditor forms to be reconfigured
Summary:
Ref T9132. This diff doesn't do anything interesting, it just lays the groundwork for more interesting future diffs.
Broadly, the idea here is to let you create multiple views of each edit form. For example, we might create several different "Create Task" forms, like:
- "New Bug Report"
- "New Feature Request"
These would be views of the "Create Task" form, but with various adjustments:
- A form might have additional instructions ("how to file a good bug report").
- A form might have prefilled values for some fields (like particular projects, subscribers, or policies).
- A form might have some fields locked (so they can not be edited) or hidden.
- A form might have a different field order.
- A form might have a limited visibility policy, so only some users can access it.
This diff adds a new storage object (`EditEngineConfiguration`) to keep track of all those customizations and represent "a form which has been configured to look and work a certain way".
This doesn't let these configurations do anything useful/interesting, and you can't access them directly yet, it's just all the boring plumbing to enable more interesting behavior in the future.
Test Plan:
ApplicationEditor forms now let you manage available forms and edit the current form:
{F959025}
There's a new (bare bones) list of all available engines:
{F959030}
And if you jump into an engine, you can see all the forms for it:
{F959038}
The actual form configurations have standard detail/edit pages. The edit pages are themselves driven by ApplicationEditor, of course, so you can edit the form for editing forms.
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T9132
Differential Revision: https://secure.phabricator.com/D14453
2015-11-04 21:52:52 +01:00
|
|
|
$fields = array(
|
2015-11-17 18:33:06 +01:00
|
|
|
'config.preamble' => id(new PhabricatorInstructionsEditField())
|
|
|
|
->setKey('config.preamble')
|
|
|
|
->setIsReorderable(false)
|
2015-11-18 19:38:12 +01:00
|
|
|
->setIsDefaultable(false)
|
2015-11-17 18:33:06 +01:00
|
|
|
->setValue($preamble),
|
Allow ApplicationEditor forms to be reconfigured
Summary:
Ref T9132. This diff doesn't do anything interesting, it just lays the groundwork for more interesting future diffs.
Broadly, the idea here is to let you create multiple views of each edit form. For example, we might create several different "Create Task" forms, like:
- "New Bug Report"
- "New Feature Request"
These would be views of the "Create Task" form, but with various adjustments:
- A form might have additional instructions ("how to file a good bug report").
- A form might have prefilled values for some fields (like particular projects, subscribers, or policies).
- A form might have some fields locked (so they can not be edited) or hidden.
- A form might have a different field order.
- A form might have a limited visibility policy, so only some users can access it.
This diff adds a new storage object (`EditEngineConfiguration`) to keep track of all those customizations and represent "a form which has been configured to look and work a certain way".
This doesn't let these configurations do anything useful/interesting, and you can't access them directly yet, it's just all the boring plumbing to enable more interesting behavior in the future.
Test Plan:
ApplicationEditor forms now let you manage available forms and edit the current form:
{F959025}
There's a new (bare bones) list of all available engines:
{F959030}
And if you jump into an engine, you can see all the forms for it:
{F959038}
The actual form configurations have standard detail/edit pages. The edit pages are themselves driven by ApplicationEditor, of course, so you can edit the form for editing forms.
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T9132
Differential Revision: https://secure.phabricator.com/D14453
2015-11-04 21:52:52 +01:00
|
|
|
) + $fields;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $fields;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function reorderFields(array $fields) {
|
2015-11-17 18:33:06 +01:00
|
|
|
$keys = $this->getFieldOrder();
|
Allow ApplicationEditor forms to be reconfigured
Summary:
Ref T9132. This diff doesn't do anything interesting, it just lays the groundwork for more interesting future diffs.
Broadly, the idea here is to let you create multiple views of each edit form. For example, we might create several different "Create Task" forms, like:
- "New Bug Report"
- "New Feature Request"
These would be views of the "Create Task" form, but with various adjustments:
- A form might have additional instructions ("how to file a good bug report").
- A form might have prefilled values for some fields (like particular projects, subscribers, or policies).
- A form might have some fields locked (so they can not be edited) or hidden.
- A form might have a different field order.
- A form might have a limited visibility policy, so only some users can access it.
This diff adds a new storage object (`EditEngineConfiguration`) to keep track of all those customizations and represent "a form which has been configured to look and work a certain way".
This doesn't let these configurations do anything useful/interesting, and you can't access them directly yet, it's just all the boring plumbing to enable more interesting behavior in the future.
Test Plan:
ApplicationEditor forms now let you manage available forms and edit the current form:
{F959025}
There's a new (bare bones) list of all available engines:
{F959030}
And if you jump into an engine, you can see all the forms for it:
{F959038}
The actual form configurations have standard detail/edit pages. The edit pages are themselves driven by ApplicationEditor, of course, so you can edit the form for editing forms.
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T9132
Differential Revision: https://secure.phabricator.com/D14453
2015-11-04 21:52:52 +01:00
|
|
|
$fields = array_select_keys($fields, $keys) + $fields;
|
|
|
|
|
|
|
|
// Now, move locked fields to the bottom.
|
|
|
|
$head = array();
|
|
|
|
$tail = array();
|
|
|
|
foreach ($fields as $key => $field) {
|
|
|
|
if (!$field->getIsLocked()) {
|
|
|
|
$head[$key] = $field;
|
|
|
|
} else {
|
|
|
|
$tail[$key] = $field;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $head + $tail;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getURI() {
|
|
|
|
$engine_key = $this->getEngineKey();
|
|
|
|
$key = $this->getIdentifier();
|
|
|
|
|
|
|
|
return "/transactions/editengine/{$engine_key}/view/{$key}/";
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getIdentifier() {
|
|
|
|
$key = $this->getID();
|
|
|
|
if (!$key) {
|
|
|
|
$key = $this->getBuiltinKey();
|
|
|
|
}
|
|
|
|
return $key;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getDisplayName() {
|
|
|
|
$name = $this->getName();
|
|
|
|
if (strlen($name)) {
|
|
|
|
return $name;
|
|
|
|
}
|
|
|
|
|
|
|
|
$builtin = $this->getBuiltinKey();
|
|
|
|
if ($builtin !== null) {
|
|
|
|
return pht('Builtin Form "%s"', $builtin);
|
|
|
|
}
|
|
|
|
|
|
|
|
return pht('Untitled Form');
|
|
|
|
}
|
|
|
|
|
2015-11-17 18:33:06 +01:00
|
|
|
public function getPreamble() {
|
|
|
|
return $this->getProperty('preamble');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setPreamble($preamble) {
|
|
|
|
return $this->setProperty('preamble', $preamble);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setFieldOrder(array $field_order) {
|
|
|
|
return $this->setProperty('order', $field_order);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getFieldOrder() {
|
|
|
|
return $this->getProperty('order', array());
|
|
|
|
}
|
|
|
|
|
2015-11-18 19:38:12 +01:00
|
|
|
public function getFieldDefault($key) {
|
|
|
|
$defaults = $this->getProperty('defaults', array());
|
|
|
|
return idx($defaults, $key);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setFieldDefault($key, $value) {
|
|
|
|
$defaults = $this->getProperty('defaults', array());
|
|
|
|
$defaults[$key] = $value;
|
|
|
|
return $this->setProperty('defaults', $defaults);
|
|
|
|
}
|
|
|
|
|
Allow ApplicationEditor forms to be reconfigured
Summary:
Ref T9132. This diff doesn't do anything interesting, it just lays the groundwork for more interesting future diffs.
Broadly, the idea here is to let you create multiple views of each edit form. For example, we might create several different "Create Task" forms, like:
- "New Bug Report"
- "New Feature Request"
These would be views of the "Create Task" form, but with various adjustments:
- A form might have additional instructions ("how to file a good bug report").
- A form might have prefilled values for some fields (like particular projects, subscribers, or policies).
- A form might have some fields locked (so they can not be edited) or hidden.
- A form might have a different field order.
- A form might have a limited visibility policy, so only some users can access it.
This diff adds a new storage object (`EditEngineConfiguration`) to keep track of all those customizations and represent "a form which has been configured to look and work a certain way".
This doesn't let these configurations do anything useful/interesting, and you can't access them directly yet, it's just all the boring plumbing to enable more interesting behavior in the future.
Test Plan:
ApplicationEditor forms now let you manage available forms and edit the current form:
{F959025}
There's a new (bare bones) list of all available engines:
{F959030}
And if you jump into an engine, you can see all the forms for it:
{F959038}
The actual form configurations have standard detail/edit pages. The edit pages are themselves driven by ApplicationEditor, of course, so you can edit the form for editing forms.
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T9132
Differential Revision: https://secure.phabricator.com/D14453
2015-11-04 21:52:52 +01:00
|
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
public function getCapabilities() {
|
|
|
|
return array(
|
|
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPolicy($capability) {
|
|
|
|
switch ($capability) {
|
|
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
|
|
return $this->getViewPolicy();
|
|
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
|
|
return $this->getEditPolicy();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function describeAutomaticCapability($capability) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* -( PhabricatorApplicationTransactionInterface )------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
public function getApplicationTransactionEditor() {
|
|
|
|
return new PhabricatorEditEngineConfigurationEditor();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getApplicationTransactionObject() {
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getApplicationTransactionTemplate() {
|
|
|
|
return new PhabricatorEditEngineConfigurationTransaction();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function willRenderTimeline(
|
|
|
|
PhabricatorApplicationTransactionView $timeline,
|
|
|
|
AphrontRequest $request) {
|
|
|
|
return $timeline;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|