API Add 'validation' to form schema

This commit is contained in:
Damian Mooyman 2016-10-28 16:22:58 +13:00 committed by Christopher Joe
parent 019e99dd4d
commit 1142757c21
7 changed files with 222 additions and 2 deletions

View File

@ -62,4 +62,10 @@ class CurrencyField extends TextField {
} }
return true; return true;
} }
public function getSchemaValidation() {
$rules = parent::getSchemaValidation();
$rules['currency'] = true;
return $rules;
}
} }

View File

@ -474,4 +474,10 @@ class DateField extends TextField {
return $this->config; return $this->config;
} }
} }
public function getSchemaValidation() {
$rules = parent::getSchemaValidation();
$rules['date'] = true;
return $rules;
}
} }

View File

@ -55,4 +55,10 @@ class EmailField extends TextField {
return true; return true;
} }
public function getSchemaValidation() {
$rules = parent::getSchemaValidation();
$rules['email'] = true;
return $rules;
}
} }

View File

@ -1459,6 +1459,7 @@ class FormField extends RequestHandler {
'readOnly' => $this->isReadonly(), 'readOnly' => $this->isReadonly(),
'disabled' => $this->isDisabled(), 'disabled' => $this->isDisabled(),
'customValidationMessage' => $this->getCustomValidationMessage(), 'customValidationMessage' => $this->getCustomValidationMessage(),
'validation' => $this->getSchemaValidation(),
'attributes' => [], 'attributes' => [],
'data' => [], 'data' => [],
]; ];
@ -1520,4 +1521,18 @@ class FormField extends RequestHandler {
return $state; return $state;
} }
/**
* Return list of validation rules. Each rule is a key value pair.
* The key is the rule name. The value is any information the frontend
* validation handler can understand, or just `true` to enable.
*
* @return array
*/
public function getSchemaValidation() {
if ($this->Required()) {
return [ 'required' => true ];
}
return [];
}
} }

View File

@ -118,6 +118,12 @@ class NumericField extends TextField {
return false; return false;
} }
public function getSchemaValidation() {
$rules = parent::getSchemaValidation();
$rules['numeric'] = true;
return $rules;
}
/** /**
* Extracts the number value from the localised string value. * Extracts the number value from the localised string value.
* *

View File

@ -108,4 +108,12 @@ class TextField extends FormField {
return true; return true;
} }
public function getSchemaValidation() {
$rules = parent::getSchemaValidation();
if ($this->getMaxLength()) {
$rules['max'] = $this->getMaxLength();
}
return $rules;
}
} }

View File

@ -1,5 +1,8 @@
<?php <?php
use SilverStripe\Forms\CurrencyField;
use SilverStripe\Forms\DateField;
use SilverStripe\Forms\NumericField;
use SilverStripe\Forms\Schema\FormSchema; use SilverStripe\Forms\Schema\FormSchema;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
@ -46,7 +49,8 @@ class FormSchemaTest extends SapphireTest {
'disabled' => false, 'disabled' => false,
'customValidationMessage' => '', 'customValidationMessage' => '',
'attributes' => [], 'attributes' => [],
'data' => [] 'data' => [],
'validation' => [],
], ],
], ],
'actions' => [] 'actions' => []
@ -199,6 +203,7 @@ class FormSchemaTest extends SapphireTest {
'customValidationMessage' => '', 'customValidationMessage' => '',
'attributes' => [], 'attributes' => [],
'data' => [], 'data' => [],
'validation' => [],
], ],
[ [
'id' => 'Form_TestForm_SecurityID', 'id' => 'Form_TestForm_SecurityID',
@ -216,7 +221,8 @@ class FormSchemaTest extends SapphireTest {
'disabled' => false, 'disabled' => false,
'customValidationMessage' => '', 'customValidationMessage' => '',
'attributes' => [], 'attributes' => [],
'data' => [] 'data' => [],
'validation' => [],
], ],
], ],
'actions' => [ 'actions' => [
@ -241,6 +247,7 @@ class FormSchemaTest extends SapphireTest {
'data' => [ 'data' => [
'icon' => 'save', 'icon' => 'save',
], ],
'validation' => [],
], ],
[ [
'id' => 'Form_TestForm_action_cancel', 'id' => 'Form_TestForm_action_cancel',
@ -263,6 +270,7 @@ class FormSchemaTest extends SapphireTest {
'data' => [ 'data' => [
'icon' => null 'icon' => null
], ],
'validation' => [],
], ],
[ [
'id' => 'Form_TestForm_Moreoptions', 'id' => 'Form_TestForm_Moreoptions',
@ -286,6 +294,7 @@ class FormSchemaTest extends SapphireTest {
'tag' => 'div', 'tag' => 'div',
'legend' => null, 'legend' => null,
], ],
'validation' => [],
'children' => [ 'children' => [
[ [
'id' => 'Form_TestForm_action_publish', 'id' => 'Form_TestForm_action_publish',
@ -308,6 +317,7 @@ class FormSchemaTest extends SapphireTest {
'data' => [ 'data' => [
'icon' => null, 'icon' => null,
], ],
'validation' => [],
], ],
[ [
'id' => 'Form_TestForm_action_archive', 'id' => 'Form_TestForm_action_archive',
@ -330,6 +340,7 @@ class FormSchemaTest extends SapphireTest {
'data' => [ 'data' => [
'icon' => null, 'icon' => null,
], ],
'validation' => [],
], ],
] ]
] ]
@ -359,4 +370,166 @@ class FormSchemaTest extends SapphireTest {
); );
} }
public function testSchemaValidation() {
$form = new Form(
new Controller(),
'TestForm',
new FieldList(
TextField::create("Name")
->setMaxLength(40),
new DateField("Date"),
new NumericField("Number"),
new CurrencyField("Money")
),
new FieldList(),
new RequiredFields('Name')
);
$formSchema = new FormSchema();
$schema = $formSchema->getSchema($form);
$expected = [
'name' => 'TestForm',
'id' => 'Form_TestForm',
'action' => 'Controller/TestForm',
'method' => 'POST',
'attributes' =>
[
'id' => 'Form_TestForm',
'action' => 'Controller/TestForm',
'method' => 'POST',
'enctype' => 'application/x-www-form-urlencoded',
'target' => null,
'class' => '',
],
'data' =>
[],
'fields' =>
[
[
'name' => 'Name',
'id' => 'Form_TestForm_Name',
'type' => 'Text',
'component' => null,
'holderId' => 'Form_TestForm_Name_Holder',
'title' => 'Name',
'source' => null,
'extraClass' => 'text',
'description' => null,
'rightTitle' => null,
'leftTitle' => null,
'readOnly' => false,
'disabled' => false,
'customValidationMessage' => '',
'validation' =>
[
'required' => true,
'max' => 40,
],
'attributes' =>
[],
'data' =>
[],
],
[
'name' => 'Date',
'id' => 'Form_TestForm_Date',
'type' => 'Date',
'component' => null,
'holderId' => 'Form_TestForm_Date_Holder',
'title' => 'Date',
'source' => null,
'extraClass' => 'date text',
'description' => null,
'rightTitle' => null,
'leftTitle' => null,
'readOnly' => false,
'disabled' => false,
'customValidationMessage' => '',
'validation' =>
[
'date' => true,
],
'attributes' =>
[],
'data' =>
[],
],
[
'name' => 'Number',
'id' => 'Form_TestForm_Number',
'type' => 'Decimal',
'component' => null,
'holderId' => 'Form_TestForm_Number_Holder',
'title' => 'Number',
'source' => null,
'extraClass' => 'numeric text',
'description' => null,
'rightTitle' => null,
'leftTitle' => null,
'readOnly' => false,
'disabled' => false,
'customValidationMessage' => '',
'validation' =>
[
'numeric' => true,
],
'attributes' =>
[],
'data' =>
[],
],
[
'name' => 'Money',
'id' => 'Form_TestForm_Money',
'type' => 'Text',
'component' => null,
'holderId' => 'Form_TestForm_Money_Holder',
'title' => 'Money',
'source' => null,
'extraClass' => 'currency text',
'description' => null,
'rightTitle' => null,
'leftTitle' => null,
'readOnly' => false,
'disabled' => false,
'customValidationMessage' => '',
'validation' =>
[
'currency' => true,
],
'attributes' =>
[],
'data' =>
[],
],
[
'name' => 'SecurityID',
'id' => 'Form_TestForm_SecurityID',
'type' => 'Hidden',
'component' => null,
'holderId' => 'Form_TestForm_SecurityID_Holder',
'title' => 'Security ID',
'source' => null,
'extraClass' => 'hidden',
'description' => null,
'rightTitle' => null,
'leftTitle' => null,
'readOnly' => false,
'disabled' => false,
'customValidationMessage' => '',
'validation' =>
[],
'attributes' =>
[],
'data' =>
[],
],
],
'actions' =>
[],
];
$this->assertInternalType('array', $schema);
$this->assertJsonStringEqualsJsonString(json_encode($expected), json_encode($schema));
}
} }