mirror of
https://github.com/silverstripe/silverstripe-userforms.git
synced 2024-10-22 17:05:42 +02:00
Compare commits
No commits in common. "2714f8699b9c98b7ce9ec2e54895e36432340101" and "cd0deae9c0924879432792ae53341b0e453446ba" have entirely different histories.
2714f8699b
...
cd0deae9c0
@ -124,14 +124,14 @@ class UserDefinedFormController extends PageController
|
|||||||
{
|
{
|
||||||
$form = $this->Form();
|
$form = $this->Form();
|
||||||
if ($this->Content && $form && !$this->config()->disable_form_content_shortcode) {
|
if ($this->Content && $form && !$this->config()->disable_form_content_shortcode) {
|
||||||
$hasLocation = stristr($this->Content ?? '', '$UserDefinedForm');
|
$hasLocation = stristr($this->Content, '$UserDefinedForm');
|
||||||
if ($hasLocation) {
|
if ($hasLocation) {
|
||||||
/** @see Requirements_Backend::escapeReplacement */
|
/** @see Requirements_Backend::escapeReplacement */
|
||||||
$formEscapedForRegex = addcslashes($form->forTemplate() ?? '', '\\$');
|
$formEscapedForRegex = addcslashes($form->forTemplate(), '\\$');
|
||||||
$content = preg_replace(
|
$content = preg_replace(
|
||||||
'/(<p[^>]*>)?\\$UserDefinedForm(<\\/p>)?/i',
|
'/(<p[^>]*>)?\\$UserDefinedForm(<\\/p>)?/i',
|
||||||
$formEscapedForRegex ?? '',
|
$formEscapedForRegex,
|
||||||
$this->Content ?? ''
|
$this->Content
|
||||||
);
|
);
|
||||||
return [
|
return [
|
||||||
'Content' => DBField::create_field('HTMLText', $content),
|
'Content' => DBField::create_field('HTMLText', $content),
|
||||||
@ -260,7 +260,7 @@ JS
|
|||||||
$submittedField->Displayed = $field->isDisplayed($data);
|
$submittedField->Displayed = $field->isDisplayed($data);
|
||||||
|
|
||||||
if (!empty($data[$field->Name])) {
|
if (!empty($data[$field->Name])) {
|
||||||
if (in_array(EditableFileField::class, $field->getClassAncestry() ?? [])) {
|
if (in_array(EditableFileField::class, $field->getClassAncestry())) {
|
||||||
if (!empty($_FILES[$field->Name]['name'])) {
|
if (!empty($_FILES[$field->Name]['name'])) {
|
||||||
$foldername = $field->getFormField()->getFolderName();
|
$foldername = $field->getFormField()->getFolderName();
|
||||||
|
|
||||||
@ -371,15 +371,15 @@ JS
|
|||||||
$submittedFormField = $submittedFields->find('Name', $recipient->SendEmailFromField()->Name);
|
$submittedFormField = $submittedFields->find('Name', $recipient->SendEmailFromField()->Name);
|
||||||
|
|
||||||
if ($submittedFormField && $submittedFormField->Value && is_string($submittedFormField->Value)) {
|
if ($submittedFormField && $submittedFormField->Value && is_string($submittedFormField->Value)) {
|
||||||
$email->setReplyTo(explode(',', $submittedFormField->Value ?? ''));
|
$email->setReplyTo(explode(',', $submittedFormField->Value));
|
||||||
}
|
}
|
||||||
} elseif ($recipient->EmailReplyTo) {
|
} elseif ($recipient->EmailReplyTo) {
|
||||||
$email->setReplyTo(explode(',', $recipient->EmailReplyTo ?? ''));
|
$email->setReplyTo(explode(',', $recipient->EmailReplyTo));
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for a specified from; otherwise fall back to server defaults
|
// check for a specified from; otherwise fall back to server defaults
|
||||||
if ($recipient->EmailFrom) {
|
if ($recipient->EmailFrom) {
|
||||||
$email->setFrom(explode(',', $recipient->EmailFrom ?? ''));
|
$email->setFrom(explode(',', $recipient->EmailFrom));
|
||||||
}
|
}
|
||||||
|
|
||||||
// check to see if they are a dynamic reciever eg based on a dropdown field a user selected
|
// check to see if they are a dynamic reciever eg based on a dropdown field a user selected
|
||||||
@ -390,12 +390,12 @@ JS
|
|||||||
$submittedFormField = $submittedFields->find('Name', $recipient->SendEmailToField()->Name);
|
$submittedFormField = $submittedFields->find('Name', $recipient->SendEmailToField()->Name);
|
||||||
|
|
||||||
if ($submittedFormField && is_string($submittedFormField->Value)) {
|
if ($submittedFormField && is_string($submittedFormField->Value)) {
|
||||||
$email->setTo(explode(',', $submittedFormField->Value ?? ''));
|
$email->setTo(explode(',', $submittedFormField->Value));
|
||||||
} else {
|
} else {
|
||||||
$email->setTo(explode(',', $recipient->EmailAddress ?? ''));
|
$email->setTo(explode(',', $recipient->EmailAddress));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$email->setTo(explode(',', $recipient->EmailAddress ?? ''));
|
$email->setTo(explode(',', $recipient->EmailAddress));
|
||||||
}
|
}
|
||||||
} catch (Swift_RfcComplianceException $e) {
|
} catch (Swift_RfcComplianceException $e) {
|
||||||
// The sending address is empty and/or invalid. Log and skip sending.
|
// The sending address is empty and/or invalid. Log and skip sending.
|
||||||
@ -415,7 +415,7 @@ JS
|
|||||||
if ($emailSubject && $emailSubject->exists()) {
|
if ($emailSubject && $emailSubject->exists()) {
|
||||||
$submittedFormField = $submittedFields->find('Name', $recipient->SendEmailSubjectField()->Name);
|
$submittedFormField = $submittedFields->find('Name', $recipient->SendEmailSubjectField()->Name);
|
||||||
|
|
||||||
if ($submittedFormField && trim($submittedFormField->Value ?? '')) {
|
if ($submittedFormField && trim($submittedFormField->Value)) {
|
||||||
$email->setSubject($submittedFormField->Value);
|
$email->setSubject($submittedFormField->Value);
|
||||||
} else {
|
} else {
|
||||||
$email->setSubject(SSViewer::execute_string($recipient->EmailSubject, $mergeFields));
|
$email->setSubject(SSViewer::execute_string($recipient->EmailSubject, $mergeFields));
|
||||||
@ -428,7 +428,7 @@ JS
|
|||||||
|
|
||||||
if ((bool)$recipient->SendPlain) {
|
if ((bool)$recipient->SendPlain) {
|
||||||
// decode previously encoded html tags because the email is being sent as text/plain
|
// decode previously encoded html tags because the email is being sent as text/plain
|
||||||
$body = html_entity_decode($emailData['Body'] ?? '') . "\n";
|
$body = html_entity_decode($emailData['Body']) . "\n";
|
||||||
if (isset($emailData['Fields']) && !$emailData['HideFormData']) {
|
if (isset($emailData['Fields']) && !$emailData['HideFormData']) {
|
||||||
foreach ($emailData['Fields'] as $field) {
|
foreach ($emailData['Fields'] as $field) {
|
||||||
if ($field instanceof SubmittedFileField) {
|
if ($field instanceof SubmittedFileField) {
|
||||||
@ -474,7 +474,7 @@ JS
|
|||||||
// to allow us to get through the finshed method
|
// to allow us to get through the finshed method
|
||||||
if (!$this->Form()->getSecurityToken()->isEnabled()) {
|
if (!$this->Form()->getSecurityToken()->isEnabled()) {
|
||||||
$randNum = rand(1, 1000);
|
$randNum = rand(1, 1000);
|
||||||
$randHash = md5($randNum ?? '');
|
$randHash = md5($randNum);
|
||||||
$session->set('FormProcessed', $randHash);
|
$session->set('FormProcessed', $randHash);
|
||||||
$session->set('FormProcessedNum', $randNum);
|
$session->set('FormProcessedNum', $randNum);
|
||||||
}
|
}
|
||||||
@ -531,7 +531,7 @@ JS
|
|||||||
// make sure the session matches the SecurityID and is not left over from another form
|
// make sure the session matches the SecurityID and is not left over from another form
|
||||||
if ($formProcessed != $securityID) {
|
if ($formProcessed != $securityID) {
|
||||||
// they may have disabled tokens on the form
|
// they may have disabled tokens on the form
|
||||||
$securityID = md5($this->getRequest()->getSession()->get('FormProcessedNum') ?? '');
|
$securityID = md5($this->getRequest()->getSession()->get('FormProcessedNum'));
|
||||||
if ($formProcessed != $securityID) {
|
if ($formProcessed != $securityID) {
|
||||||
return $this->redirect($this->Link() . $referrer);
|
return $this->redirect($this->Link() . $referrer);
|
||||||
}
|
}
|
||||||
@ -571,7 +571,7 @@ JS
|
|||||||
$operations = implode(" {$conjunction} ", $rule['operations']);
|
$operations = implode(" {$conjunction} ", $rule['operations']);
|
||||||
$target = $rule['targetFieldID'];
|
$target = $rule['targetFieldID'];
|
||||||
$holder = $rule['holder'];
|
$holder = $rule['holder'];
|
||||||
$isFormStep = strpos($target ?? '', 'EditableFormStep') !== false;
|
$isFormStep = strpos($target, 'EditableFormStep') !== false;
|
||||||
|
|
||||||
$result .= <<<EOS
|
$result .= <<<EOS
|
||||||
\n
|
\n
|
||||||
@ -592,7 +592,7 @@ EOS;
|
|||||||
// This is particularly important beacause the next/prev page buttons logic is controlled by
|
// This is particularly important beacause the next/prev page buttons logic is controlled by
|
||||||
// the visibility of the FormStep buttons
|
// the visibility of the FormStep buttons
|
||||||
// The HTML for the FormStep buttons is defined in UserFormProgress.ss
|
// The HTML for the FormStep buttons is defined in UserFormProgress.ss
|
||||||
$id = str_replace('#', '', $target ?? '');
|
$id = str_replace('#', '', $target);
|
||||||
$result .= <<<EOS
|
$result .= <<<EOS
|
||||||
$('.step-button-wrapper[data-for="{$id}"]').addClass('hide');
|
$('.step-button-wrapper[data-for="{$id}"]').addClass('hide');
|
||||||
EOS;
|
EOS;
|
||||||
|
@ -67,7 +67,7 @@ class UpgradePolymorphicExtension extends DataExtension
|
|||||||
// If the defined data class doesn't have the UserForm trait applied, it's probably wrong. Re-map
|
// If the defined data class doesn't have the UserForm trait applied, it's probably wrong. Re-map
|
||||||
// it to a default value that does
|
// it to a default value that does
|
||||||
$classTraits = class_uses($relationshipObject);
|
$classTraits = class_uses($relationshipObject);
|
||||||
if (in_array(UserForm::class, $classTraits ?? [])) {
|
if (in_array(UserForm::class, $classTraits)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ class UserFormValidator extends RequiredFields
|
|||||||
foreach ($fields as $field) {
|
foreach ($fields as $field) {
|
||||||
if ($field instanceof EditableFormStep) {
|
if ($field instanceof EditableFormStep) {
|
||||||
// Page at top level, or after another page is ok
|
// Page at top level, or after another page is ok
|
||||||
if (empty($stack) || (count($stack ?? []) === 1 && $stack[0] instanceof EditableFormStep)) {
|
if (empty($stack) || (count($stack) === 1 && $stack[0] instanceof EditableFormStep)) {
|
||||||
$stack = array($field);
|
$stack = array($field);
|
||||||
$conditionalStep = $field->DisplayRules()->count() > 0;
|
$conditionalStep = $field->DisplayRules()->count() > 0;
|
||||||
continue;
|
continue;
|
||||||
|
@ -145,7 +145,7 @@ class GridFieldAddClassesButton implements GridField_HTMLProvider, GridField_Act
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Filter out classes without permission
|
// Filter out classes without permission
|
||||||
return array_filter($classes ?? [], function ($class) {
|
return array_filter($classes, function ($class) {
|
||||||
return singleton($class)->canCreate();
|
return singleton($class)->canCreate();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -219,7 +219,7 @@ class GridFieldAddClassesButton implements GridField_HTMLProvider, GridField_Act
|
|||||||
|
|
||||||
public function handleAction(GridField $gridField, $actionName, $arguments, $data)
|
public function handleAction(GridField $gridField, $actionName, $arguments, $data)
|
||||||
{
|
{
|
||||||
switch (strtolower($actionName ?? '')) {
|
switch (strtolower($actionName)) {
|
||||||
case $this->getAction():
|
case $this->getAction():
|
||||||
return $this->handleAdd($gridField);
|
return $this->handleAdd($gridField);
|
||||||
default:
|
default:
|
||||||
|
@ -122,7 +122,7 @@ class UserFormsGridFieldFilterHeader extends GridFieldFilterHeader
|
|||||||
$actions->addExtraClass('no-change-track');
|
$actions->addExtraClass('no-change-track');
|
||||||
|
|
||||||
$colSpan = 2 + count($gridField->getConfig()->getComponentByType(GridFieldDataColumns::class)
|
$colSpan = 2 + count($gridField->getConfig()->getComponentByType(GridFieldDataColumns::class)
|
||||||
->getDisplayFields($gridField) ?? []);
|
->getDisplayFields($gridField));
|
||||||
|
|
||||||
$forTemplate = ArrayData::create(array(
|
$forTemplate = ArrayData::create(array(
|
||||||
'Fields' => $fields,
|
'Fields' => $fields,
|
||||||
|
@ -113,11 +113,11 @@ class UserFormsRequiredFields extends RequiredFields
|
|||||||
if ($field instanceof FileField && isset($value['error']) && $value['error']) {
|
if ($field instanceof FileField && isset($value['error']) && $value['error']) {
|
||||||
$error = true;
|
$error = true;
|
||||||
} else {
|
} else {
|
||||||
$error = (count($value ?? [])) ? false : true;
|
$error = (count($value)) ? false : true;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// assume a string or integer
|
// assume a string or integer
|
||||||
$error = (strlen($value ?? '')) ? false : true;
|
$error = (strlen($value)) ? false : true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $error;
|
return $error;
|
||||||
|
@ -24,7 +24,7 @@ class UserFormsCheckboxSetField extends CheckboxSetField
|
|||||||
*/
|
*/
|
||||||
public function getValidationAttributesHTML()
|
public function getValidationAttributesHTML()
|
||||||
{
|
{
|
||||||
$attrs = array_filter(array_keys($this->getAttributes() ?? []), function ($attr) {
|
$attrs = array_filter(array_keys($this->getAttributes()), function ($attr) {
|
||||||
return !in_array($attr, ['data-rule-required', 'data-msg-required']);
|
return !in_array($attr, ['data-rule-required', 'data-msg-required']);
|
||||||
});
|
});
|
||||||
return $this->getAttributesHTML(...$attrs);
|
return $this->getAttributesHTML(...$attrs);
|
||||||
@ -60,8 +60,8 @@ class UserFormsCheckboxSetField extends CheckboxSetField
|
|||||||
|
|
||||||
$previous = $value = $this->Value();
|
$previous = $value = $this->Value();
|
||||||
|
|
||||||
if (is_string($value) && strstr($value ?? '', ",")) {
|
if (is_string($value) && strstr($value, ",")) {
|
||||||
$value = explode(",", $value ?? '');
|
$value = explode(",", $value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// set the value as an array for parent validation
|
// set the value as an array for parent validation
|
||||||
|
@ -43,7 +43,7 @@ class UserFormsFieldList extends FieldList implements UserFormsFieldContainer
|
|||||||
public function clearEmptySteps()
|
public function clearEmptySteps()
|
||||||
{
|
{
|
||||||
foreach ($this as $field) {
|
foreach ($this as $field) {
|
||||||
if ($field instanceof UserFormsStepField && count($field->getChildren() ?? []) === 0) {
|
if ($field instanceof UserFormsStepField && count($field->getChildren()) === 0) {
|
||||||
$this->remove($field);
|
$this->remove($field);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,7 @@ class UserFormsOptionSetField extends OptionsetField
|
|||||||
*/
|
*/
|
||||||
public function getValidationAttributesHTML()
|
public function getValidationAttributesHTML()
|
||||||
{
|
{
|
||||||
$attrs = array_filter(array_keys($this->getAttributes() ?? []), function ($attr) {
|
$attrs = array_filter(array_keys($this->getAttributes()), function ($attr) {
|
||||||
return !in_array($attr, ['data-rule-required', 'data-msg-required']);
|
return !in_array($attr, ['data-rule-required', 'data-msg-required']);
|
||||||
});
|
});
|
||||||
return $this->getAttributesHTML(...$attrs);
|
return $this->getAttributesHTML(...$attrs);
|
||||||
|
@ -299,7 +299,7 @@ class EditableCustomRule extends DataObject
|
|||||||
*/
|
*/
|
||||||
public function toggleDisplayText($initialState, $invert = false)
|
public function toggleDisplayText($initialState, $invert = false)
|
||||||
{
|
{
|
||||||
$action = strtolower($initialState ?? '') === 'hide' ? 'removeClass' : 'addClass';
|
$action = strtolower($initialState) === 'hide' ? 'removeClass' : 'addClass';
|
||||||
if ($invert) {
|
if ($invert) {
|
||||||
$action = $action === 'removeClass' ? 'addClass' : 'removeClass';
|
$action = $action === 'removeClass' ? 'addClass' : 'removeClass';
|
||||||
}
|
}
|
||||||
@ -316,7 +316,7 @@ class EditableCustomRule extends DataObject
|
|||||||
*/
|
*/
|
||||||
public function toggleDisplayEvent($initialState, $invert = false)
|
public function toggleDisplayEvent($initialState, $invert = false)
|
||||||
{
|
{
|
||||||
$action = strtolower($initialState ?? '') === 'hide' ? 'show' : 'hide';
|
$action = strtolower($initialState) === 'hide' ? 'show' : 'hide';
|
||||||
if ($invert) {
|
if ($invert) {
|
||||||
$action = $action === 'hide' ? 'show' : 'hide';
|
$action = $action === 'hide' ? 'show' : 'hide';
|
||||||
}
|
}
|
||||||
|
@ -358,7 +358,7 @@ class EditableFormField extends DataObject
|
|||||||
*/
|
*/
|
||||||
protected function getDisplayRuleFields()
|
protected function getDisplayRuleFields()
|
||||||
{
|
{
|
||||||
$allowedClasses = array_keys($this->getEditableFieldClasses(false) ?? []);
|
$allowedClasses = array_keys($this->getEditableFieldClasses(false));
|
||||||
$editableColumns = new GridFieldEditableColumns();
|
$editableColumns = new GridFieldEditableColumns();
|
||||||
$editableColumns->setDisplayFields([
|
$editableColumns->setDisplayFields([
|
||||||
'ConditionFieldID' => function ($record, $column, $grid) use ($allowedClasses) {
|
'ConditionFieldID' => function ($record, $column, $grid) use ($allowedClasses) {
|
||||||
@ -584,7 +584,7 @@ class EditableFormField extends DataObject
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return stripos($this->ID ?? '', 'new') === 0;
|
return stripos($this->ID, 'new') === 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -612,7 +612,7 @@ class EditableFormField extends DataObject
|
|||||||
$shortClass = end($classNamespaces);
|
$shortClass = end($classNamespaces);
|
||||||
|
|
||||||
$resource = ModuleLoader::getModule('silverstripe/userforms')
|
$resource = ModuleLoader::getModule('silverstripe/userforms')
|
||||||
->getResource('images/' . strtolower($shortClass ?? '') . '.png');
|
->getResource('images/' . strtolower($shortClass) . '.png');
|
||||||
|
|
||||||
if (!$resource->exists()) {
|
if (!$resource->exists()) {
|
||||||
return '';
|
return '';
|
||||||
@ -782,7 +782,7 @@ class EditableFormField extends DataObject
|
|||||||
}
|
}
|
||||||
|
|
||||||
// if this field has a placeholder
|
// if this field has a placeholder
|
||||||
if (strlen($this->Placeholder ?? '') >= 0) {
|
if (strlen($this->Placeholder) >= 0) {
|
||||||
$field->setAttribute('placeholder', $this->Placeholder);
|
$field->setAttribute('placeholder', $this->Placeholder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -983,10 +983,10 @@ class EditableFormField extends DataObject
|
|||||||
$fieldToWatch = $formFieldWatch->getSelectorFieldOnly();
|
$fieldToWatch = $formFieldWatch->getSelectorFieldOnly();
|
||||||
|
|
||||||
$expression = $rule->buildExpression();
|
$expression = $rule->buildExpression();
|
||||||
if (!in_array($fieldToWatch, $result['selectors'] ?? [])) {
|
if (!in_array($fieldToWatch, $result['selectors'])) {
|
||||||
$result['selectors'][] = $fieldToWatch;
|
$result['selectors'][] = $fieldToWatch;
|
||||||
}
|
}
|
||||||
if (!in_array($expression['event'], $result['events'] ?? [])) {
|
if (!in_array($expression['event'], $result['events'])) {
|
||||||
$result['events'][] = $expression['event'];
|
$result['events'][] = $expression['event'];
|
||||||
}
|
}
|
||||||
$result['operations'][] = $expression['operation'];
|
$result['operations'][] = $expression['operation'];
|
||||||
@ -999,7 +999,7 @@ class EditableFormField extends DataObject
|
|||||||
$result['holder_event_opposite'] = $rule->toggleDisplayEvent($result['initialState'], true);
|
$result['holder_event_opposite'] = $rule->toggleDisplayEvent($result['initialState'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (count($result['selectors'] ?? [])) ? $result : null;
|
return (count($result['selectors'])) ? $result : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1050,7 +1050,7 @@ class EditableFormField extends DataObject
|
|||||||
*/
|
*/
|
||||||
public function DisplayRulesConjunctionNice()
|
public function DisplayRulesConjunctionNice()
|
||||||
{
|
{
|
||||||
return (strtolower($this->DisplayRulesConjunction ?? '') === 'or') ? '||' : '&&';
|
return (strtolower($this->DisplayRulesConjunction) === 'or') ? '||' : '&&';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -209,7 +209,7 @@ class EditableFileField extends EditableFormField
|
|||||||
$field->getValidator()->setAllowedExtensions(
|
$field->getValidator()->setAllowedExtensions(
|
||||||
array_diff(
|
array_diff(
|
||||||
// filter out '' since this would be a regex problem on JS end
|
// filter out '' since this would be a regex problem on JS end
|
||||||
array_filter(Config::inst()->get(File::class, 'allowed_extensions') ?? []),
|
array_filter(Config::inst()->get(File::class, 'allowed_extensions')),
|
||||||
$this->config()->get('allowed_extensions_blacklist')
|
$this->config()->get('allowed_extensions_blacklist')
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@ -223,7 +223,7 @@ class EditableFileField extends EditableFormField
|
|||||||
$folder = $this->Folder();
|
$folder = $this->Folder();
|
||||||
if ($folder && $folder->exists()) {
|
if ($folder && $folder->exists()) {
|
||||||
$field->setFolderName(
|
$field->setFolderName(
|
||||||
preg_replace("/^assets\//", "", $folder->Filename ?? '')
|
preg_replace("/^assets\//", "", $folder->Filename)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -143,9 +143,9 @@ class EmailRecipient extends DataObject
|
|||||||
|
|
||||||
// email addresses have trim() applied to them during validation for a slightly nicer UX
|
// email addresses have trim() applied to them during validation for a slightly nicer UX
|
||||||
// apply trim() here too before saving to the database
|
// apply trim() here too before saving to the database
|
||||||
$this->EmailAddress = trim($this->EmailAddress ?? '');
|
$this->EmailAddress = trim($this->EmailAddress);
|
||||||
$this->EmailFrom = trim($this->EmailFrom ?? '');
|
$this->EmailFrom = trim($this->EmailFrom);
|
||||||
$this->EmailReplyTo = trim($this->EmailReplyTo ?? '');
|
$this->EmailReplyTo = trim($this->EmailReplyTo);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function summaryFields()
|
public function summaryFields()
|
||||||
@ -272,9 +272,9 @@ class EmailRecipient extends DataObject
|
|||||||
// an AJAX request, e.g. saving a GridFieldDetailForm
|
// an AJAX request, e.g. saving a GridFieldDetailForm
|
||||||
$remove = ['/edit', '/ItemEditForm'];
|
$remove = ['/edit', '/ItemEditForm'];
|
||||||
foreach ($remove as $badSuffix) {
|
foreach ($remove as $badSuffix) {
|
||||||
$badSuffixLength = strlen($badSuffix ?? '');
|
$badSuffixLength = strlen($badSuffix);
|
||||||
if (substr($currentUrl ?? '', -$badSuffixLength) === $badSuffix) {
|
if (substr($currentUrl, -$badSuffixLength) === $badSuffix) {
|
||||||
$currentUrl = substr($currentUrl ?? '', 0, -$badSuffixLength);
|
$currentUrl = substr($currentUrl, 0, -$badSuffixLength);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$previewUrl = Controller::join_links($currentUrl, 'preview');
|
$previewUrl = Controller::join_links($currentUrl, 'preview');
|
||||||
@ -534,7 +534,7 @@ class EmailRecipient extends DataObject
|
|||||||
$found = $finder->find(BASE_PATH . DIRECTORY_SEPARATOR . $templateDirectory);
|
$found = $finder->find(BASE_PATH . DIRECTORY_SEPARATOR . $templateDirectory);
|
||||||
|
|
||||||
foreach ($found as $key => $value) {
|
foreach ($found as $key => $value) {
|
||||||
$template = pathinfo($value ?? '');
|
$template = pathinfo($value);
|
||||||
$absoluteFilename = $template['dirname'] . DIRECTORY_SEPARATOR . $template['filename'];
|
$absoluteFilename = $template['dirname'] . DIRECTORY_SEPARATOR . $template['filename'];
|
||||||
|
|
||||||
// Optionally remove vendor/ path prefixes
|
// Optionally remove vendor/ path prefixes
|
||||||
@ -544,10 +544,10 @@ class EmailRecipient extends DataObject
|
|||||||
} else {
|
} else {
|
||||||
$prefixToStrip = BASE_PATH;
|
$prefixToStrip = BASE_PATH;
|
||||||
}
|
}
|
||||||
$templatePath = substr($absoluteFilename ?? '', strlen($prefixToStrip ?? '') + 1);
|
$templatePath = substr($absoluteFilename, strlen($prefixToStrip) + 1);
|
||||||
|
|
||||||
// Optionally remove "templates/" ("templates\" on Windows respectively) prefixes
|
// Optionally remove "templates/" ("templates\" on Windows respectively) prefixes
|
||||||
if (preg_match('#(?<=templates' . preg_quote(DIRECTORY_SEPARATOR, '#') . ').*$#', $templatePath ?? '', $matches)) {
|
if (preg_match('#(?<=templates' . preg_quote(DIRECTORY_SEPARATOR, '#') . ').*$#', $templatePath, $matches)) {
|
||||||
$templatePath = $matches[0];
|
$templatePath = $matches[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -573,9 +573,9 @@ class EmailRecipient extends DataObject
|
|||||||
foreach ($checkEmail as $check => $translation) {
|
foreach ($checkEmail as $check => $translation) {
|
||||||
if ($this->$check) {
|
if ($this->$check) {
|
||||||
//may be a comma separated list of emails
|
//may be a comma separated list of emails
|
||||||
$addresses = explode(',', $this->$check ?? '');
|
$addresses = explode(',', $this->$check);
|
||||||
foreach ($addresses as $address) {
|
foreach ($addresses as $address) {
|
||||||
$trimAddress = trim($address ?? '');
|
$trimAddress = trim($address);
|
||||||
if ($trimAddress && !Email::is_valid_address($trimAddress)) {
|
if ($trimAddress && !Email::is_valid_address($trimAddress)) {
|
||||||
$error = _t(
|
$error = _t(
|
||||||
__CLASS__.".$translation",
|
__CLASS__.".$translation",
|
||||||
|
@ -8,11 +8,11 @@ class UnderscoreSegmentFieldModifier extends SlugSegmentFieldModifier
|
|||||||
{
|
{
|
||||||
public function getPreview($value)
|
public function getPreview($value)
|
||||||
{
|
{
|
||||||
return str_replace('-', '_', parent::getPreview($value) ?? '');
|
return str_replace('-', '_', parent::getPreview($value));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getSuggestion($value)
|
public function getSuggestion($value)
|
||||||
{
|
{
|
||||||
return str_replace('-', '_', parent::getSuggestion($value) ?? '');
|
return str_replace('-', '_', parent::getSuggestion($value));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,7 @@ class UserFormsColumnCleanTask extends MigrationTask
|
|||||||
DB::query($query);
|
DB::query($query);
|
||||||
$backedUp = 1;
|
$backedUp = 1;
|
||||||
}
|
}
|
||||||
if (!isset($columns[$column]) && !in_array($column, $this->keepColumns ?? [])) {
|
if (!isset($columns[$column]) && !in_array($column, $this->keepColumns)) {
|
||||||
echo "Dropping $column from $db <br />";
|
echo "Dropping $column from $db <br />";
|
||||||
$query = "ALTER TABLE $db DROP COLUMN $column";
|
$query = "ALTER TABLE $db DROP COLUMN $column";
|
||||||
DB::query($query);
|
DB::query($query);
|
||||||
|
@ -255,7 +255,7 @@ SQL;
|
|||||||
$columns = array();
|
$columns = array();
|
||||||
|
|
||||||
foreach (DB::query($columnSQL)->map() as $name => $title) {
|
foreach (DB::query($columnSQL)->map() as $name => $title) {
|
||||||
$columns[$name] = trim(strtr($title ?? '', '.', ' '));
|
$columns[$name] = trim(strtr($title, '.', ' '));
|
||||||
}
|
}
|
||||||
|
|
||||||
$config = GridFieldConfig::create();
|
$config = GridFieldConfig::create();
|
||||||
|
@ -106,7 +106,7 @@ class UserDefinedFormAdminTest extends FunctionalTest
|
|||||||
null,
|
null,
|
||||||
['X-FormSchema-Request' => 'auto,schema,state,errors']
|
['X-FormSchema-Request' => 'auto,schema,state,errors']
|
||||||
);
|
);
|
||||||
$schemaData = json_decode($response->getBody() ?? '', true);
|
$schemaData = json_decode($response->getBody(), true);
|
||||||
|
|
||||||
$this->assertEquals('ConfirmFolderForm', $schemaData['schema']['name']);
|
$this->assertEquals('ConfirmFolderForm', $schemaData['schema']['name']);
|
||||||
$this->assertField($schemaData, 'FolderOptions', ['component' => 'OptionsetField']);
|
$this->assertField($schemaData, 'FolderOptions', ['component' => 'OptionsetField']);
|
||||||
@ -128,7 +128,7 @@ class UserDefinedFormAdminTest extends FunctionalTest
|
|||||||
null,
|
null,
|
||||||
['X-FormSchema-Request' => 'auto,schema,state,errors']
|
['X-FormSchema-Request' => 'auto,schema,state,errors']
|
||||||
);
|
);
|
||||||
$schemaData = json_decode($response->getBody() ?? '', true);
|
$schemaData = json_decode($response->getBody(), true);
|
||||||
|
|
||||||
$this->assertEquals('ConfirmFolderForm', $schemaData['schema']['name']);
|
$this->assertEquals('ConfirmFolderForm', $schemaData['schema']['name']);
|
||||||
$this->assertField($schemaData, 'FolderOptions', ['component' => 'OptionsetField']);
|
$this->assertField($schemaData, 'FolderOptions', ['component' => 'OptionsetField']);
|
||||||
|
@ -96,7 +96,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
|
|
||||||
// submitted html tags are escaped for the html value
|
// submitted html tags are escaped for the html value
|
||||||
$value = 'class="readonly">My body html Basic Value <b>HTML</b></span>';
|
$value = 'class="readonly">My body html Basic Value <b>HTML</b></span>';
|
||||||
$this->assertTrue(strpos($email['Content'] ?? '', $value ?? '') !== false, 'Email contains the merge field value');
|
$this->assertTrue(strpos($email['Content'], $value) !== false, 'Email contains the merge field value');
|
||||||
|
|
||||||
$value = $parser->getBySelector('dd');
|
$value = $parser->getBySelector('dd');
|
||||||
$this->assertEquals('Basic Value <b>HTML</b>', (string) $value[0], 'Email contains the value');
|
$this->assertEquals('Basic Value <b>HTML</b>', (string) $value[0], 'Email contains the value');
|
||||||
@ -198,14 +198,14 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
$this->assertEquals($controller->Form()->getName(), 'Form_' . $form->ID, 'The form is referenced as Form');
|
$this->assertEquals($controller->Form()->getName(), 'Form_' . $form->ID, 'The form is referenced as Form');
|
||||||
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
||||||
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
||||||
$this->assertEquals(count($controller->Form()->getValidator()->getRequired() ?? []), 0);
|
$this->assertEquals(count($controller->Form()->getValidator()->getRequired()), 0);
|
||||||
|
|
||||||
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
$requiredForm = $this->objFromFixture(UserDefinedForm::class, 'validation-form');
|
||||||
$controller = new UserDefinedFormController($requiredForm);
|
$controller = new UserDefinedFormController($requiredForm);
|
||||||
|
|
||||||
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
$this->assertEquals($controller->Form()->Fields()->Count(), 1); // disabled SecurityID token fields
|
||||||
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
$this->assertEquals($controller->Form()->Actions()->Count(), 1);
|
||||||
$this->assertEquals(count($controller->Form()->getValidator()->getRequired() ?? []), 1);
|
$this->assertEquals(count($controller->Form()->getValidator()->getRequired()), 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testGetFormFields()
|
public function testGetFormFields()
|
||||||
@ -413,7 +413,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
'type' => 'image/jpeg',
|
'type' => 'image/jpeg',
|
||||||
'tmp_name' => $path,
|
'tmp_name' => $path,
|
||||||
'error' => 0,
|
'error' => 0,
|
||||||
'size' => filesize($path ?? ''),
|
'size' => filesize($path),
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
$_FILES[$field->Name] = $data[$field->Name];
|
$_FILES[$field->Name] = $data[$field->Name];
|
||||||
@ -449,7 +449,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
|
|||||||
'type' => 'image/jpeg',
|
'type' => 'image/jpeg',
|
||||||
'tmp_name' => $path,
|
'tmp_name' => $path,
|
||||||
'error' => 0,
|
'error' => 0,
|
||||||
'size' => filesize($path ?? ''),
|
'size' => filesize($path),
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
$_FILES[$field->Name] = $data[$field->Name];
|
$_FILES[$field->Name] = $data[$field->Name];
|
||||||
|
@ -46,6 +46,6 @@ class UserFormsCheckboxSetFieldTest extends SapphireTest
|
|||||||
$userFormsCheckboxSetField = $editableCheckboxGroupField->getFormField();
|
$userFormsCheckboxSetField = $editableCheckboxGroupField->getFormField();
|
||||||
$html = $userFormsCheckboxSetField->renderWith(UserFormsCheckboxSetField::class)->getValue();
|
$html = $userFormsCheckboxSetField->renderWith(UserFormsCheckboxSetField::class)->getValue();
|
||||||
$attributesHTML = 'data-rule-required="true" data-msg-required="My custom error message with &#039;single&#039; and &quot;double&quot; quotes"';
|
$attributesHTML = 'data-rule-required="true" data-msg-required="My custom error message with &#039;single&#039; and &quot;double&quot; quotes"';
|
||||||
$this->assertTrue(strpos($html ?? '', $attributesHTML ?? '') > 0);
|
$this->assertTrue(strpos($html, $attributesHTML) > 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,6 @@ class UserFormsOptionSetFieldTest extends SapphireTest
|
|||||||
$userFormsOptionSetField = $radio->getFormField();
|
$userFormsOptionSetField = $radio->getFormField();
|
||||||
$html = $userFormsOptionSetField->renderWith(UserFormsOptionSetField::class)->getValue();
|
$html = $userFormsOptionSetField->renderWith(UserFormsOptionSetField::class)->getValue();
|
||||||
$attributesHTML = 'data-rule-required="true" data-msg-required="My custom error message with &#039;single&#039; and &quot;double&quot; quotes"';
|
$attributesHTML = 'data-rule-required="true" data-msg-required="My custom error message with &#039;single&#039; and &quot;double&quot; quotes"';
|
||||||
$this->assertTrue(strpos($html ?? '', $attributesHTML ?? '') > 0);
|
$this->assertTrue(strpos($html, $attributesHTML) > 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -100,8 +100,8 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
|
|
||||||
$summaryFields = $gridFieldDataColumns->getDisplayFields($submissionsgrid);
|
$summaryFields = $gridFieldDataColumns->getDisplayFields($submissionsgrid);
|
||||||
|
|
||||||
$this->assertContains('SummaryShow', array_keys($summaryFields ?? []), 'Summary field not showing displayed field');
|
$this->assertContains('SummaryShow', array_keys($summaryFields), 'Summary field not showing displayed field');
|
||||||
$this->assertNotContains('SummaryHide', array_keys($summaryFields ?? []), 'Summary field showing displayed field');
|
$this->assertNotContains('SummaryHide', array_keys($summaryFields), 'Summary field showing displayed field');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testEmailRecipientPopup()
|
public function testEmailRecipientPopup()
|
||||||
@ -177,13 +177,13 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
|
|
||||||
// Installation path can be as a project when testing in Travis, so check partial match
|
// Installation path can be as a project when testing in Travis, so check partial match
|
||||||
$foundKey = false;
|
$foundKey = false;
|
||||||
foreach (array_keys($result ?? []) as $key) {
|
foreach (array_keys($result) as $key) {
|
||||||
if (strpos($key ?? '', 'email' . DIRECTORY_SEPARATOR . 'SubmittedFormEmail') !== false) {
|
if (strpos($key, 'email' . DIRECTORY_SEPARATOR . 'SubmittedFormEmail') !== false) {
|
||||||
$foundKey = true;
|
$foundKey = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$this->assertTrue($foundKey);
|
$this->assertTrue($foundKey);
|
||||||
$this->assertTrue(in_array('SubmittedFormEmail', array_values($result ?? [])));
|
$this->assertTrue(in_array('SubmittedFormEmail', array_values($result)));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testEmailTemplateExists()
|
public function testEmailTemplateExists()
|
||||||
@ -195,7 +195,7 @@ class UserDefinedFormTest extends FunctionalTest
|
|||||||
$recipient->EmailAddress = 'test@example.com';
|
$recipient->EmailAddress = 'test@example.com';
|
||||||
|
|
||||||
// Set the default template
|
// Set the default template
|
||||||
$recipient->EmailTemplate = current(array_keys($recipient->getEmailTemplateDropdownValues() ?? []));
|
$recipient->EmailTemplate = current(array_keys($recipient->getEmailTemplateDropdownValues()));
|
||||||
$recipient->write();
|
$recipient->write();
|
||||||
|
|
||||||
// The default template exists
|
// The default template exists
|
||||||
|
Loading…
Reference in New Issue
Block a user