'Varchar', 'ClearButtonText' => 'Varchar', 'OnCompleteMessage' => 'HTMLText', 'ShowClearButton' => 'Boolean', 'DisableSaveSubmissions' => 'Boolean', 'EnableLiveValidation' => 'Boolean', 'DisplayErrorMessagesAtTop' => 'Boolean', 'DisableAuthenicatedFinishAction' => 'Boolean', 'DisableCsrfSecurityToken' => 'Boolean' ]; /** * @var array Default values of variables when this page is created */ private static $defaults = [ 'Content' => '$UserDefinedForm', 'DisableSaveSubmissions' => 0, ]; /** * @var array */ private static $has_many = [ 'Submissions' => SubmittedForm::class, 'EmailRecipients' => EmailRecipient::class ]; private static $cascade_deletes = [ 'EmailRecipients', ]; private static $cascade_duplicates = false; /** * @var array * @config */ private static $casting = [ 'ErrorContainerID' => 'Text' ]; /** * Error container selector which matches the element for grouped messages * * @var string * @config */ private static $error_container_id = 'error-container'; /** * The configuration used to determine whether a confirmation message is to * appear when navigating away from a partially completed form. * * @var boolean * @config */ private static $enable_are_you_sure = true; /** * @var bool * @config */ private static $recipients_warning_enabled = false; private static $non_live_permissions = ['SITETREE_VIEW_ALL']; /** * Temporary storage of field ids when the form is duplicated. * Example layout: array('EditableCheckbox3' => 'EditableCheckbox14') * @var array */ protected $fieldsFromTo = []; /** * @var array */ public function populateDefaults() { parent::populateDefaults(); $this->OnCompleteMessage = '
' . _t('SilverStripe\\UserForms\\Model\\UserDefinedForm.ONCOMPLETEMESSAGE', 'Thanks, we\'ve received your submission.') . '
'; } /** * @return FieldList */ public function getCMSFields() { Requirements::css('silverstripe/userforms:client/dist/styles/userforms-cms.css'); $this->beforeUpdateCMSFields(function ($fields) { // remove $fields->removeByName('OnCompleteMessageLabel'); $fields->removeByName('OnCompleteMessage'); $fields->removeByName('Fields'); $fields->removeByName('EmailRecipients'); // define tabs $fields->findOrMakeTab('Root.FormOptions', _t(__CLASS__.'.CONFIGURATION', 'Configuration')); $fields->findOrMakeTab('Root.Recipients', _t(__CLASS__.'.RECIPIENTS', 'Recipients')); $fields->findOrMakeTab('Root.Submissions', _t(__CLASS__.'.SUBMISSIONS', 'Submissions')); // text to show on complete $onCompleteFieldSet = CompositeField::create( $label = LabelField::create( 'OnCompleteMessageLabel', _t(__CLASS__.'.ONCOMPLETELABEL', 'Show on completion') ), $editor = HTMLEditorField::create( 'OnCompleteMessage', '', $this->OnCompleteMessage ) ); $onCompleteFieldSet->addExtraClass('field'); $editor->setRows(3); $label->addExtraClass('left'); // Define config for email recipients $emailRecipientsConfig = GridFieldConfig_RecordEditor::create(10); $emailRecipientsConfig->getComponentByType(GridFieldAddNewButton::class) ->setButtonName( _t(__CLASS__.'.ADDEMAILRECIPIENT', 'Add Email Recipient') ); // who do we email on submission $emailRecipients = GridField::create( 'EmailRecipients', '', $this->EmailRecipients(), $emailRecipientsConfig ); $emailRecipients ->getConfig() ->getComponentByType(GridFieldDetailForm::class) ->setItemRequestClass(UserFormRecipientItemRequest::class); $fields->addFieldsToTab('Root.FormOptions', $onCompleteFieldSet); $fields->addFieldToTab('Root.Recipients', $emailRecipients); $fields->addFieldsToTab('Root.FormOptions', $this->getFormOptions()); // view the submissions // make sure a numeric not a empty string is checked against this int column for SQL server $parentID = (!empty($this->ID)) ? (int) $this->ID : 0; // get a list of all field names and values used for print and export CSV views of the GridField below. $columnSQL = <<' . _t( __CLASS__.'.NORECIPIENTS', 'Warning: You have not configured any recipients. Form submissions may be missed.' ) . '
' ), 'Title'); } return $fields; } /** * Allow overriding the EmailRecipients on a {@link DataExtension} * so you can customise who receives an email. * Converts the RelationList to an ArrayList so that manipulation * of the original source data isn't possible. * * @return ArrayList */ public function FilteredEmailRecipients($data = null, $form = null) { $recipients = ArrayList::create($this->EmailRecipients()->toArray()); // Filter by rules $recipients = $recipients->filterByCallback(function ($recipient) use ($data, $form) { /** @var EmailRecipient $recipient */ return $recipient->canSend($data, $form); }); $this->extend('updateFilteredEmailRecipients', $recipients, $data, $form); return $recipients; } /** * Custom options for the form. You can extend the built in options by * using {@link updateFormOptions()} * * @return FieldList */ public function getFormOptions() { $submit = ($this->SubmitButtonText) ? $this->SubmitButtonText : _t(__CLASS__.'.SUBMITBUTTON', 'Submit'); $clear = ($this->ClearButtonText) ? $this->ClearButtonText : _t(__CLASS__.'.CLEARBUTTON', 'Clear'); $options = FieldList::create( TextField::create('SubmitButtonText', _t(__CLASS__.'.TEXTONSUBMIT', 'Text on submit button:'), $submit), TextField::create('ClearButtonText', _t(__CLASS__.'.TEXTONCLEAR', 'Text on clear button:'), $clear), CheckboxField::create('ShowClearButton', _t(__CLASS__.'.SHOWCLEARFORM', 'Show Clear Form Button'), $this->ShowClearButton), CheckboxField::create('EnableLiveValidation', _t(__CLASS__.'.ENABLELIVEVALIDATION', 'Enable live validation')), CheckboxField::create('DisplayErrorMessagesAtTop', _t(__CLASS__.'.DISPLAYERRORMESSAGESATTOP', 'Display error messages above the form?')), CheckboxField::create('DisableCsrfSecurityToken', _t(__CLASS__.'.DISABLECSRFSECURITYTOKEN', 'Disable CSRF Token')), CheckboxField::create('DisableAuthenicatedFinishAction', _t(__CLASS__.'.DISABLEAUTHENICATEDFINISHACTION', 'Disable Authentication on finish action')) ); $this->extend('updateFormOptions', $options); return $options; } /** * Get the HTML id of the error container displayed above the form. * * @return string */ public function getErrorContainerID() { return $this->config()->get('error_container_id'); } /** * Validate formfields */ public function getCMSValidator() { return UserFormValidator::create(); } }