113 lines
3.3 KiB
PHP
Raw Normal View History

2016-10-14 14:30:05 +13:00
<?php
namespace SilverStripe\Forms\Tests\FormTest;
use SilverStripe\Control\Controller;
use SilverStripe\Dev\TestOnly;
use SilverStripe\Forms\CheckboxSetField;
use SilverStripe\Forms\EmailField;
use SilverStripe\Forms\FieldList;
use SilverStripe\Forms\Form;
use SilverStripe\Forms\FormAction;
use SilverStripe\Forms\NumericField;
use SilverStripe\Forms\RequiredFields;
use SilverStripe\Forms\TextField;
use SilverStripe\ORM\ValidationException;
use SilverStripe\ORM\ValidationResult;
2016-10-14 14:30:05 +13:00
use SilverStripe\View\SSViewer;
/**
* @skipUpgrade
*/
class TestController extends Controller implements TestOnly
{
2017-06-19 12:49:45 +12:00
public function __construct()
{
parent::__construct();
if (Controller::has_curr()) {
$this->setRequest(Controller::curr()->getRequest());
}
}
2016-10-14 14:30:05 +13:00
private static $allowed_actions = array('Form');
2016-10-14 14:30:05 +13:00
private static $url_handlers = array(
'$Action//$ID/$OtherID' => "handleAction",
);
2016-10-14 14:30:05 +13:00
protected $template = 'BlankPage';
2016-10-14 14:30:05 +13:00
public function Link($action = null)
{
return Controller::join_links(
'FormTest_Controller',
$this->getRequest()->latestParam('Action'),
$this->getRequest()->latestParam('ID'),
$action
);
}
2016-10-14 14:30:05 +13:00
public function Form()
{
$form = new Form(
$this,
'Form',
new FieldList(
new EmailField('Email'),
new TextField('SomeRequiredField'),
new CheckboxSetField('Boxes', null, array('1' => 'one', '2' => 'two')),
new NumericField('Number'),
TextField::create('ReadonlyField')
->setReadonly(true)
->setValue('This value is readonly')
),
new FieldList(
FormAction::create('doSubmit'),
FormAction::create('doTriggerException'),
FormAction::create('doSubmitValidationExempt'),
FormAction::create('doSubmitActionExempt')
->setValidationExempt(true)
),
new RequiredFields(
'Email',
'SomeRequiredField'
)
);
$form->setValidationExemptActions(array('doSubmitValidationExempt'));
$form->disableSecurityToken(); // Disable CSRF protection for easier form submission handling
2016-10-14 14:30:05 +13:00
return $form;
}
2016-10-14 14:30:05 +13:00
public function doSubmit($data, $form, $request)
{
$form->sessionMessage('Test save was successful', 'good');
return $this->redirectBack();
}
2016-10-14 14:30:05 +13:00
public function doTriggerException($data, $form, $request)
{
$result = new ValidationResult();
$result->addFieldError('Email', 'Error on Email field');
$result->addError('Error at top of form');
throw new ValidationException($result);
}
public function doSubmitValidationExempt($data, $form, $request)
{
$form->sessionMessage('Validation skipped', 'good');
return $this->redirectBack();
}
2016-10-14 14:30:05 +13:00
public function doSubmitActionExempt($data, $form, $request)
{
$form->sessionMessage('Validation bypassed!', 'good');
return $this->redirectBack();
}
2016-10-14 14:30:05 +13:00
public function getViewer($action = null)
{
return new SSViewer('BlankPage');
}
2016-10-14 14:30:05 +13:00
}