From 8e47c9ff0b2a5e714938f38895735010372f1b40 Mon Sep 17 00:00:00 2001 From: github-actions Date: Sat, 6 Jul 2024 18:44:06 +0000 Subject: [PATCH 1/2] Merge pull request #1794 from hydephp/prepare-post-author-changes [1.x] Update the post author class to prepare for the v2 overhaul https://github.com/hydephp/develop/commit/cc57e00e84a03953ed5fb881307aadfbab14b284 --- .../Features/Blogging/Models/PostAuthor.php | 13 +++++++++---- tests/Feature/MarkdownPostTest.php | 2 +- tests/Unit/PostAuthorTest.php | 7 +++++++ 3 files changed, 17 insertions(+), 5 deletions(-) diff --git a/src/Framework/Features/Blogging/Models/PostAuthor.php b/src/Framework/Features/Blogging/Models/PostAuthor.php index ac6b850b..35236438 100644 --- a/src/Framework/Features/Blogging/Models/PostAuthor.php +++ b/src/Framework/Features/Blogging/Models/PostAuthor.php @@ -8,6 +8,7 @@ use Hyde\Facades\Author; use Hyde\Facades\Config; use Illuminate\Support\Collection; +use JetBrains\PhpStorm\Deprecated; use function strtolower; use function is_string; @@ -26,7 +27,7 @@ class PostAuthor implements Stringable /** * The display name of the author. */ - public readonly ?string $name; + public readonly string $name; /** * The author's website URL. @@ -48,7 +49,7 @@ class PostAuthor implements Stringable public function __construct(string $username, ?string $name = null, ?string $website = null) { $this->username = $username; - $this->name = $name; + $this->name = $name ?? $this->username; $this->website = $website; } @@ -82,12 +83,16 @@ public static function all(): Collection public function __toString(): string { - return $this->getName(); + return $this->name; } + /** + * @deprecated This is not needed as the name property can be accessed directly. + */ + #[Deprecated(reason: 'Use the name property instead.', replacement: '%class%->name')] public function getName(): string { - return $this->name ?? $this->username; + return $this->name; } /** @param array{username?: string, name?: string, website?: string} $data */ diff --git a/tests/Feature/MarkdownPostTest.php b/tests/Feature/MarkdownPostTest.php index ef8c319d..f3f3b315 100644 --- a/tests/Feature/MarkdownPostTest.php +++ b/tests/Feature/MarkdownPostTest.php @@ -29,7 +29,7 @@ public function testConstructorCanCreateANewAuthorInstanceFromUsernameString() $this->assertInstanceOf(PostAuthor::class, $post->author); $this->assertSame('John Doe', $post->author->username); - $this->assertNull($post->author->name); + $this->assertSame('John Doe', $post->author->name); $this->assertNull($post->author->website); } diff --git a/tests/Unit/PostAuthorTest.php b/tests/Unit/PostAuthorTest.php index c6c98a9c..503c59f5 100644 --- a/tests/Unit/PostAuthorTest.php +++ b/tests/Unit/PostAuthorTest.php @@ -134,6 +134,13 @@ public function testGetNameHelperReturnsUsernameIfNameIsNotSet() $this->assertEquals('username', $author->getName()); } + public function testNameIsSetToUsernameIfNameIsNotSet() + { + $author = new PostAuthor('username'); + + $this->assertEquals('username', $author->name); + } + public function testToStringHelperReturnsTheName() { $author = new PostAuthor('username', 'John Doe'); From 3946c113e9e8d28560577f85c226c06d3f098d45 Mon Sep 17 00:00:00 2001 From: github-actions Date: Sat, 6 Jul 2024 18:48:35 +0000 Subject: [PATCH 2/2] Merge pull request #1795 from hydephp/prepare-post-author-changes Internal: Replace deprecated method usage https://github.com/hydephp/develop/commit/00fef196328658f2349a82961222f4ff24bb94ca --- src/Framework/Features/XmlGenerators/RssFeedGenerator.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Framework/Features/XmlGenerators/RssFeedGenerator.php b/src/Framework/Features/XmlGenerators/RssFeedGenerator.php index 09ebc3db..b3abfab4 100644 --- a/src/Framework/Features/XmlGenerators/RssFeedGenerator.php +++ b/src/Framework/Features/XmlGenerators/RssFeedGenerator.php @@ -69,7 +69,7 @@ protected function addDynamicItemData(SimpleXMLElement $item, MarkdownPost $post } if (isset($post->author)) { - $item->addChild('dc:creator', $post->author->getName(), 'http://purl.org/dc/elements/1.1/'); + $item->addChild('dc:creator', $post->author->name, 'http://purl.org/dc/elements/1.1/'); } if (isset($post->category)) {