MNT Make employee validatable

Fix broken validation that's already there
Add email field for testing field validation
This commit is contained in:
Guy Sartorelli 2023-08-08 13:04:08 +12:00
parent 806254d77b
commit 39b85c9365
No known key found for this signature in database
GPG Key ID: F313E3B9504D496A

View File

@ -3,6 +3,7 @@
namespace SilverStripe\FrameworkTest\Model; namespace SilverStripe\FrameworkTest\Model;
use SilverStripe\Assets\Image; use SilverStripe\Assets\Image;
use SilverStripe\Forms\EmailField;
use SilverStripe\Forms\NumericField; use SilverStripe\Forms\NumericField;
use SilverStripe\Forms\TextField; use SilverStripe\Forms\TextField;
use SilverStripe\ORM\Connect\MySQLSchemaManager; use SilverStripe\ORM\Connect\MySQLSchemaManager;
@ -27,6 +28,7 @@ class Employee extends DataObject
private static $db = array( private static $db = array(
'Name' => 'Varchar', 'Name' => 'Varchar',
'Email' => 'Varchar',
'Biography' => 'HTMLText', 'Biography' => 'HTMLText',
'DateOfBirth' => 'Date', 'DateOfBirth' => 'Date',
'Category' => 'Enum("marketing,management,rnd,hr")' 'Category' => 'Enum("marketing,management,rnd,hr")'
@ -90,6 +92,7 @@ class Employee extends DataObject
{ {
// Use basic scaffolder (no tabs) // Use basic scaffolder (no tabs)
$fields = $this->scaffoldFormFields(); $fields = $this->scaffoldFormFields();
$fields->replaceField('Email', EmailField::create('Email'));
$fields->push(new NumericField('ManyMany[YearStart]', 'Year started (3.1, many-many only)')); $fields->push(new NumericField('ManyMany[YearStart]', 'Year started (3.1, many-many only)'));
$fields->push(new TextField('ManyMany[Role]', 'Role (3.1, many-many only)')); $fields->push(new TextField('ManyMany[Role]', 'Role (3.1, many-many only)'));
return $fields; return $fields;
@ -142,7 +145,7 @@ class Employee extends DataObject
{ {
$result = parent::validate(); $result = parent::validate();
if (!$this->Name) { if (!$this->Name) {
$result->error('"Name" can\'t be blank'); $result->addFieldError('Name', '"Name" can\'t be blank');
} }
return $result; return $result;
} }