2012-02-29 14:47:37 +01:00
|
|
|
<?php
|
|
|
|
|
2016-07-01 04:37:50 +02:00
|
|
|
namespace SilverStripe\FrameworkTest\Model;
|
|
|
|
|
|
|
|
|
|
|
|
use NumericField;
|
|
|
|
use TextField;
|
|
|
|
|
|
|
|
use SilverStripe\ORM\DataObject;
|
|
|
|
use SilverStripe\ORM\DB;
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-02-29 14:47:37 +01:00
|
|
|
/**
|
|
|
|
* Description of Employees
|
|
|
|
*
|
|
|
|
*/
|
2015-12-17 21:20:49 +01:00
|
|
|
class Employee extends DataObject
|
|
|
|
{
|
2016-07-01 04:37:50 +02:00
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
private static $db = array(
|
|
|
|
'Name' => 'Varchar',
|
|
|
|
'Biography' => 'HTMLText'
|
|
|
|
);
|
2016-07-01 04:37:50 +02:00
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
private static $has_one = array(
|
2016-07-01 04:37:50 +02:00
|
|
|
'Company' => 'SilverStripe\\FrameworkTest\\Model\\Company',
|
2015-12-17 21:20:49 +01:00
|
|
|
'ProfileImage' => 'Image'
|
|
|
|
);
|
2013-01-15 00:43:43 +01:00
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
private static $belongs_many_many = array(
|
2016-07-01 04:37:50 +02:00
|
|
|
'PastCompanies' => 'SilverStripe\\FrameworkTest\\Model\\Company'
|
2015-12-17 21:20:49 +01:00
|
|
|
);
|
2013-01-15 00:43:43 +01:00
|
|
|
|
2016-07-20 00:35:01 +02:00
|
|
|
private static $table_name = 'Employee';
|
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
public function getCMSFields()
|
|
|
|
{
|
2016-08-03 04:12:53 +02:00
|
|
|
// Use basic scaffolder (no tabs)
|
|
|
|
$fields = $this->scaffoldFormFields();
|
|
|
|
$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)'));
|
2015-12-17 21:20:49 +01:00
|
|
|
return $fields;
|
|
|
|
}
|
2016-07-01 04:37:50 +02:00
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
public function requireDefaultRecords()
|
|
|
|
{
|
|
|
|
parent::requireDefaultRecords();
|
2016-07-01 04:37:50 +02:00
|
|
|
$employeeSet = DataObject::get('SilverStripe\\FrameworkTest\\Model\\Employee');
|
2015-12-17 21:20:49 +01:00
|
|
|
foreach ($employeeSet as $employee) {
|
|
|
|
$employee->delete();
|
|
|
|
}
|
2016-07-01 04:37:50 +02:00
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
foreach ($this->data() as $employeeName) {
|
|
|
|
$employee = new Employee();
|
|
|
|
$employee->Name = $employeeName;
|
|
|
|
$employee->write();
|
|
|
|
}
|
|
|
|
DB::alteration_message("Added default records to Employee table", "created");
|
|
|
|
}
|
2013-05-29 17:26:11 +02:00
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
public function validate()
|
|
|
|
{
|
|
|
|
$result = parent::validate();
|
|
|
|
if (!$this->Name) {
|
|
|
|
$result->error('"Name" can\'t be blank');
|
|
|
|
}
|
|
|
|
return $result;
|
|
|
|
}
|
2016-07-01 04:37:50 +02:00
|
|
|
|
2015-12-17 21:20:49 +01:00
|
|
|
/**
|
|
|
|
* Contains test data
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function data()
|
|
|
|
{
|
|
|
|
return array(
|
|
|
|
'Hayley', 'Octavius', 'Walker', 'Gary','Elton','Janna','Ursa','Lars','Moses','Lareina',
|
|
|
|
'Elmo','Cara','Shea','Duncan','Velma','Acton','Galena','Heidi','Troy','Elliott','Cara',
|
|
|
|
'Whitney','Summer','Olga','Tatum','Zeph','Jared','Hilda','Quinlan','Chaim','Xenos',
|
|
|
|
'Cara','Tatiana','Tyrone','Juliet','Chester','Hannah','Imani','Quinn','Ariel','Abel',
|
|
|
|
'Aretha','Courtney ','Shellie','Garrett','Camilla','Simon','Mohammad','Kirby','Rae',
|
|
|
|
'Xena','Noel','Omar','Shannon','Iola','Maia','Serina','Taylor','Alice','Lucy','Austin',
|
|
|
|
'Abel','Quinn','Yetta','Ulysses','Donovan','Castor','Emmanuel','Nero','Virginia',
|
|
|
|
'Gregory','Neville','Abel','Len','Knox','Gavin','Pascale','Hyatt','Alden','Emerald',
|
|
|
|
'Cherokee','Zeph','Adam','Uma','Serena','Isabelle','Kieran','Moses','Gay','Lavinia',
|
|
|
|
'Elvis','Illana','Lee','Ariana','Hilel','Juliet','Gage','Larissa','Richard','Allen'
|
|
|
|
);
|
|
|
|
}
|
2012-02-29 14:47:37 +01:00
|
|
|
}
|