ENH Avoid use of 'new' keyword on injectable classes from this module.

It's not uncommon to want to override or enhance some functionality in vendor code that doesn't have extension points, so we should avoid the `new` keyword when instantiating injectable classes from the module.
This commit is contained in:
GuySartorelli 2021-05-31 13:00:31 +12:00 committed by GitHub
parent 4d9e78a841
commit 3fbccea2ea
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -118,7 +118,7 @@ class UserForm extends Form
*/ */
public function getFormFields() public function getFormFields()
{ {
$fields = new UserFormsFieldList(); $fields = UserFormsFieldList::create();
$target = $fields; $target = $fields;
foreach ($this->controller->data()->Fields() as $field) { foreach ($this->controller->data()->Fields() as $field) {
@ -174,7 +174,7 @@ class UserForm extends Form
->filter('Required', true) ->filter('Required', true)
->column('Name'); ->column('Name');
$requiredNames = array_merge($requiredNames, $this->getEmailRecipientRequiredFields()); $requiredNames = array_merge($requiredNames, $this->getEmailRecipientRequiredFields());
$required = new UserFormsRequiredFields($requiredNames); $required = UserFormsRequiredFields::create($requiredNames);
$this->extend('updateRequiredFields', $required); $this->extend('updateRequiredFields', $required);
$required->setForm($this); $required->setForm($this);
return $required; return $required;