diff options
| author | Asko Nõmm <asko@repl.ee> | 2023-09-25 17:29:52 +0300 |
|---|---|---|
| committer | Asko Nõmm <asko@repl.ee> | 2023-09-25 17:29:52 +0300 |
| commit | 57518b03cbf19b8a714d6fcb573f71cb921005e3 (patch) | |
| tree | 240509fd84f023f289a83577a735fa82fac879f4 /src/Hird.php | |
| parent | 8ebb9ca9fbce0982e27296d5016d17d8b20962d6 (diff) | |
Implement `$fieldNames`, a way to overwrite field names to be more human friendly in error messages.
Diffstat (limited to 'src/Hird.php')
| -rw-r--r-- | src/Hird.php | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/src/Hird.php b/src/Hird.php index d1b85cc..f60eca8 100644 --- a/src/Hird.php +++ b/src/Hird.php @@ -47,11 +47,14 @@ class Hird { private array $errors = []; private array $validators = []; + private array $fieldNames = []; public function __construct( private array $fields, private array $rules, + array $fieldNames = [] ) { + $this->composeFieldNames($fieldNames); $this->registerDefaultValidators(); } @@ -69,6 +72,23 @@ class Hird } /** + * Composes the field names array. + * + * @param array $fieldNames + * @return void + */ + private function composeFieldNames(array $fieldNames): void + { + $updatedFieldNames = []; + + foreach ($this->fields as $field => $value) { + $updatedFieldNames[$field] = $fieldNames[$field] ?? $field; + } + + $this->fieldNames = $updatedFieldNames; + } + + /** * Registers a validator to a `$ruleName`. * * @param string $ruleName @@ -81,7 +101,7 @@ class Hird $instance = null; if ($class->getConstructor() !== null) { - $instance = $class->newInstanceArgs([$this->fields]); + $instance = $class->newInstanceArgs([$this->fields, $this->fieldNames]); } else { $instance = $class->newInstance(); } |
