mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-23 21:18:19 +01:00
572567b85d
Summary: Ref T4122. - For Diffusion, we need "allow null" (permits selection of "No Credential") for anonymous HTTP repositories. - For Diffusion, we can make things a little easier to configure by prefilling the username. Test Plan: Used UIExample form. These featuers are used in a future revision. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T4122 Differential Revision: https://secure.phabricator.com/D7624
97 lines
2.3 KiB
PHP
97 lines
2.3 KiB
PHP
<?php
|
|
|
|
final class PassphraseCredentialControl extends AphrontFormControl {
|
|
|
|
private $options;
|
|
private $credentialType;
|
|
private $defaultUsername;
|
|
private $allowNull;
|
|
|
|
public function setAllowNull($allow_null) {
|
|
$this->allowNull = $allow_null;
|
|
return $this;
|
|
}
|
|
|
|
public function setDefaultUsername($default_username) {
|
|
$this->defaultUsername = $default_username;
|
|
return $this;
|
|
}
|
|
|
|
public function setCredentialType($credential_type) {
|
|
$this->credentialType = $credential_type;
|
|
return $this;
|
|
}
|
|
|
|
public function getCredentialType() {
|
|
return $this->credentialType;
|
|
}
|
|
|
|
public function setOptions(array $options) {
|
|
assert_instances_of($options, 'PassphraseCredential');
|
|
$this->options = $options;
|
|
return $this;
|
|
}
|
|
|
|
protected function getCustomControlClass() {
|
|
return 'passphrase-credential-control';
|
|
}
|
|
|
|
protected function renderInput() {
|
|
|
|
$options_map = array();
|
|
foreach ($this->options as $option) {
|
|
$options_map[$option->getPHID()] = pht(
|
|
"%s %s",
|
|
'K'.$option->getID(),
|
|
$option->getName());
|
|
}
|
|
|
|
$disabled = $this->getDisabled();
|
|
if ($this->allowNull) {
|
|
$options_map = array('' => pht('(No Credentials)')) + $options_map;
|
|
} else {
|
|
if (!$options_map) {
|
|
$options_map[''] = pht('(No Existing Credentials)');
|
|
$disabled = true;
|
|
}
|
|
}
|
|
|
|
Javelin::initBehavior('passphrase-credential-control');
|
|
|
|
$options = AphrontFormSelectControl::renderSelectTag(
|
|
$this->getValue(),
|
|
$options_map,
|
|
array(
|
|
'id' => $this->getControlID(),
|
|
'name' => $this->getName(),
|
|
'disabled' => $disabled ? 'disabled' : null,
|
|
'sigil' => 'passphrase-credential-select',
|
|
));
|
|
|
|
$button = javelin_tag(
|
|
'a',
|
|
array(
|
|
'href' => '#',
|
|
'class' => 'button grey',
|
|
'sigil' => 'passphrase-credential-add',
|
|
'mustcapture' => true,
|
|
),
|
|
pht('Add Credential'));
|
|
|
|
return javelin_tag(
|
|
'div',
|
|
array(
|
|
'sigil' => 'passphrase-credential-control',
|
|
'meta' => array(
|
|
'type' => $this->getCredentialType(),
|
|
'username' => $this->defaultUsername,
|
|
'allowNull' => $this->allowNull,
|
|
),
|
|
),
|
|
array(
|
|
$options,
|
|
$button,
|
|
));
|
|
}
|
|
|
|
}
|