| Code Coverage | ||||||||||
| Lines | Functions and Methods | Classes and Traits | ||||||||
| Total |  | 100.00% | 8 / 8 |  | 100.00% | 3 / 3 | CRAP |  | 100.00% | 1 / 1 | 
| HasAuthor |  | 100.00% | 8 / 8 |  | 100.00% | 3 / 3 | 6 |  | 100.00% | 1 / 1 | 
| constructAuthor |  | 100.00% | 5 / 5 |  | 100.00% | 1 / 1 | 4 | |||
| findAuthor |  | 100.00% | 1 / 1 |  | 100.00% | 1 / 1 | 1 | |||
| createAuthor |  | 100.00% | 2 / 2 |  | 100.00% | 1 / 1 | 1 | |||
| 1 | <?php | 
| 2 | |
| 3 | namespace Hyde\Framework\Concerns; | 
| 4 | |
| 5 | use Hyde\Framework\Helpers\Author as AuthorHelper; | 
| 6 | use Hyde\Framework\Models\Author; | 
| 7 | |
| 8 | /** | 
| 9 | * Handle logic for Page models that have an Author. | 
| 10 | * | 
| 11 | * @see \Hyde\Framework\Models\Author | 
| 12 | * @see \Tests\Unit\HasAuthorTest | 
| 13 | */ | 
| 14 | trait HasAuthor | 
| 15 | { | 
| 16 | public Author $author; | 
| 17 | |
| 18 | public function constructAuthor(): void | 
| 19 | { | 
| 20 | if (isset($this->matter['author'])) { | 
| 21 | if (is_string($this->matter['author'])) { | 
| 22 | // If the author is a string, we assume it's a username | 
| 23 | // and we'll try to find the author in the config | 
| 24 | $this->author = $this->findAuthor($this->matter['author']); | 
| 25 | } | 
| 26 | if (is_array($this->matter['author'])) { | 
| 27 | // If the author is an array, we'll assume it's a user | 
| 28 | // with one-off custom data, so we create a new author. | 
| 29 | // In the future we may want to merge config data with custom data | 
| 30 | $this->author = $this->createAuthor($this->matter['author']); | 
| 31 | } | 
| 32 | } | 
| 33 | } | 
| 34 | |
| 35 | protected function findAuthor(string $author): Author | 
| 36 | { | 
| 37 | return AuthorHelper::get($author); | 
| 38 | } | 
| 39 | |
| 40 | protected function createAuthor(array $data): Author | 
| 41 | { | 
| 42 | $username = $data['username'] ?? $data['name'] ?? 'Guest'; | 
| 43 | |
| 44 | return new Author($username, $data); | 
| 45 | } | 
| 46 | } |