mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-17 18:21:11 +01:00
37893ba2e6
Summary: Ref T9132. Let configurations be enabled/disabled. This doesn't do much right now. Let configurations be marked as default entries in the application "Create" menu. This makes them show up in the application in a dropdown, so you can replace the default form and/or provide several forms. In Maniphest, we'll do this to provide a menu something like this: - New Bug Report - New Feature Request - ADVANCED TASK CREATION!!11~ (only available for Community members) Test Plan: {F1005679} Reviewers: chad Reviewed By: chad Maniphest Tasks: T9132 Differential Revision: https://secure.phabricator.com/D14584
263 lines
6.7 KiB
PHP
263 lines
6.7 KiB
PHP
<?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;
|
|
|
|
const LOCK_VISIBLE = 'visible';
|
|
const LOCK_LOCKED = 'locked';
|
|
const LOCK_HIDDEN = 'hidden';
|
|
|
|
public function getTableName() {
|
|
return 'search_editengineconfiguration';
|
|
}
|
|
|
|
public static function initializeNewConfiguration(
|
|
PhabricatorUser $actor,
|
|
PhabricatorEditEngine $engine) {
|
|
|
|
// TODO: This should probably be controlled by a new default 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]);
|
|
}
|
|
}
|
|
}
|
|
|
|
$locks = $this->getFieldLocks();
|
|
foreach ($fields as $field) {
|
|
$key = $field->getKey();
|
|
switch (idx($locks, $key)) {
|
|
case self::LOCK_LOCKED:
|
|
$field->setIsHidden(false);
|
|
$field->setIsLocked(true);
|
|
break;
|
|
case self::LOCK_HIDDEN:
|
|
$field->setIsHidden(true);
|
|
$field->setIsLocked(false);
|
|
break;
|
|
case self::LOCK_VISIBLE:
|
|
$field->setIsHidden(false);
|
|
$field->setIsLocked(false);
|
|
break;
|
|
default:
|
|
// If we don't have an explicit value, don't make any adjustments.
|
|
break;
|
|
}
|
|
}
|
|
|
|
$fields = $this->reorderFields($fields);
|
|
|
|
$preamble = $this->getPreamble();
|
|
if (strlen($preamble)) {
|
|
$fields = array(
|
|
'config.preamble' => id(new PhabricatorInstructionsEditField())
|
|
->setKey('config.preamble')
|
|
->setIsReorderable(false)
|
|
->setIsDefaultable(false)
|
|
->setIsLockable(false)
|
|
->setValue($preamble),
|
|
) + $fields;
|
|
}
|
|
|
|
return $fields;
|
|
}
|
|
|
|
private function reorderFields(array $fields) {
|
|
$keys = $this->getFieldOrder();
|
|
$fields = array_select_keys($fields, $keys) + $fields;
|
|
return $fields;
|
|
}
|
|
|
|
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');
|
|
}
|
|
|
|
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());
|
|
}
|
|
|
|
public function setFieldLocks(array $field_locks) {
|
|
return $this->setProperty('locks', $field_locks);
|
|
}
|
|
|
|
public function getFieldLocks() {
|
|
return $this->getProperty('locks', array());
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
|
|
/* -( 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;
|
|
}
|
|
|
|
}
|