mirror of
https://github.com/silverstripe/silverstripe-userforms.git
synced 2024-10-22 17:05:42 +02:00
FIX: make email recipients dropdowns unselectable in 3.0 API
This commit is contained in:
parent
90ba5031ab
commit
e0a476ea15
@ -905,13 +905,18 @@ class UserDefinedForm_EmailRecipient extends DataObject {
|
|||||||
);
|
);
|
||||||
|
|
||||||
if($this->Form()) {
|
if($this->Form()) {
|
||||||
|
$dropdowns = array();
|
||||||
|
|
||||||
$validEmailFields = DataObject::get("EditableEmailField", "\"ParentID\" = '" . (int)$this->FormID . "'");
|
$validEmailFields = DataObject::get("EditableEmailField", "\"ParentID\" = '" . (int)$this->FormID . "'");
|
||||||
$multiOptionFields = DataObject::get("EditableMultipleOptionField", "\"ParentID\" = '" . (int)$this->FormID . "'");
|
$multiOptionFields = DataObject::get("EditableMultipleOptionField", "\"ParentID\" = '" . (int)$this->FormID . "'");
|
||||||
|
|
||||||
// if they have email fields then we could send from it
|
// if they have email fields then we could send from it
|
||||||
if($validEmailFields) {
|
if($validEmailFields) {
|
||||||
$fields->insertAfter(new DropdownField('SendEmailFromFieldID', _t('UserDefinedForm.ORSELECTAFIELDTOUSEASFROM', '.. or Select a Form Field to use as the From Address'),
|
$fields->insertAfter($dropdowns[] = new DropdownField(
|
||||||
$validEmailFields->map('ID', 'Title'), '', null,""), 'EmailFrom');
|
'SendEmailFromFieldID',
|
||||||
|
_t('UserDefinedForm.ORSELECTAFIELDTOUSEASFROM', '.. or Select a Form Field to use as the From Address'),
|
||||||
|
$validEmailFields->map('ID', 'Title')
|
||||||
|
), 'EmailFrom');
|
||||||
}
|
}
|
||||||
|
|
||||||
// if they have multiple options
|
// if they have multiple options
|
||||||
@ -919,7 +924,11 @@ class UserDefinedForm_EmailRecipient extends DataObject {
|
|||||||
|
|
||||||
if($multiOptionFields && $validEmailFields) {
|
if($multiOptionFields && $validEmailFields) {
|
||||||
$multiOptionFields = $multiOptionFields->toArray();
|
$multiOptionFields = $multiOptionFields->toArray();
|
||||||
$multiOptionFields=array_merge($multiOptionFields, $validEmailFields->toArray());
|
$multiOptionFields = array_merge(
|
||||||
|
$multiOptionFields,
|
||||||
|
$validEmailFields->toArray()
|
||||||
|
);
|
||||||
|
|
||||||
$multiOptionFields = ArrayList::create($multiOptionFields);
|
$multiOptionFields = ArrayList::create($multiOptionFields);
|
||||||
}
|
}
|
||||||
else if(!$multiOptionFields) {
|
else if(!$multiOptionFields) {
|
||||||
@ -927,8 +936,18 @@ class UserDefinedForm_EmailRecipient extends DataObject {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$multiOptionFields = $multiOptionFields->map('ID', 'Title');
|
$multiOptionFields = $multiOptionFields->map('ID', 'Title');
|
||||||
$fields->insertAfter(new DropdownField('SendEmailToFieldID', _t('UserDefinedForm.ORSELECTAFIELDTOUSEASTO', '.. or Select a Field to use as the To Address'),
|
$fields->insertAfter($dropdowns[] = new DropdownField(
|
||||||
$multiOptionFields, '', null, ""), 'EmailAddress');
|
'SendEmailToFieldID',
|
||||||
|
_t('UserDefinedForm.ORSELECTAFIELDTOUSEASTO', '.. or Select a Field to use as the To Address'),
|
||||||
|
$multiOptionFields
|
||||||
|
), 'EmailAddress');
|
||||||
|
}
|
||||||
|
|
||||||
|
if($dropdowns) {
|
||||||
|
foreach($dropdowns as $dropdown) {
|
||||||
|
$dropdown->setHasEmptyDefault(true);
|
||||||
|
$dropdown->setEmptyString(" ");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user