FIX: make email recipients dropdowns unselectable in 3.0 API

This commit is contained in:
Will Rossiter 2012-09-11 20:50:29 +12:00
parent 90ba5031ab
commit e0a476ea15

View File

@ -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(" ");
}
} }
} }