From 10a6d6d6dc668fc51a10ff87436225a25eb817e9 Mon Sep 17 00:00:00 2001 From: Etienne Gutbub Date: Tue, 20 Aug 2024 11:56:27 +0200 Subject: [PATCH] feat(Meta): add meta tags and open-graph properties to blog articles --- src/Entity/Article.php | 30 +++++++++++++++ src/Entity/ArticleInterface.php | 12 ++++++ src/Entity/ArticleTranslation.php | 36 ++++++++++++++++++ src/Entity/ArticleTranslationInterface.php | 12 ++++++ src/Form/Type/ArticleTranslationType.php | 11 ++++++ src/Migrations/Version20240820090632.php | 38 +++++++++++++++++++ .../doctrine/ArticleTranslation.orm.xml | 4 ++ src/Resources/config/images.yaml | 1 + src/Resources/translations/messages.en.yaml | 6 +++ src/Resources/translations/messages.fr.yaml | 6 +++ .../Shop/Article/Metatags/_image.html.twig | 3 ++ .../views/Shop/Article/_metadata.html.twig | 13 +++++++ .../views/Shop/Article/show.html.twig | 1 + 13 files changed, 173 insertions(+) create mode 100644 src/Migrations/Version20240820090632.php create mode 100644 src/Resources/views/Shop/Article/Metatags/_image.html.twig create mode 100644 src/Resources/views/Shop/Article/_metadata.html.twig diff --git a/src/Entity/Article.php b/src/Entity/Article.php index cd17b3e..42729c5 100644 --- a/src/Entity/Article.php +++ b/src/Entity/Article.php @@ -209,6 +209,36 @@ public function getAuthors(): Collection return $this->authors; } + public function getMetaTitle(): ?string + { + return $this->getTranslation()->getMetaTitle(); + } + + public function setMetaTitle(?string $metaTitle): void + { + $this->getTranslation()->setMetaTitle($metaTitle); + } + + public function getMetaDescription(): ?string + { + return $this->getTranslation()->getMetaDescription(); + } + + public function setMetaDescription(?string $metaDescription): void + { + $this->getTranslation()->setMetaDescription($metaDescription); + } + + public function getMetaKeywords(): ?string + { + return $this->getTranslation()->getMetaKeywords(); + } + + public function setMetaKeywords(?string $metaKeywords): void + { + $this->getTranslation()->setMetaKeywords($metaKeywords); + } + public function publish(): void { $this->publishedAt = new DateTime(); diff --git a/src/Entity/ArticleInterface.php b/src/Entity/ArticleInterface.php index 3ae3ccf..999373f 100644 --- a/src/Entity/ArticleInterface.php +++ b/src/Entity/ArticleInterface.php @@ -77,4 +77,16 @@ public function hasAuthor(AuthorInterface $author): bool; public function getAuthors(): Collection; public function publish(): void; + + public function getMetaTitle(): ?string; + + public function setMetaTitle(?string $metaTitle): void; + + public function getMetaDescription(): ?string; + + public function setMetaDescription(?string $metaDescription): void; + + public function getMetaKeywords(): ?string; + + public function setMetaKeywords(?string $metaKeywords): void; } diff --git a/src/Entity/ArticleTranslation.php b/src/Entity/ArticleTranslation.php index 4d51dad..4c86a0c 100644 --- a/src/Entity/ArticleTranslation.php +++ b/src/Entity/ArticleTranslation.php @@ -28,6 +28,12 @@ class ArticleTranslation extends AbstractTranslation implements ArticleTranslati protected ?string $content; + protected ?string $metaTitle = null; + + protected ?string $metaDescription = null; + + protected ?string $metaKeywords = null; + public function getId(): ?int { return $this->id; @@ -72,4 +78,34 @@ public function setContent(?string $content): void { $this->content = $content; } + + public function getMetaTitle(): ?string + { + return $this->metaTitle; + } + + public function setMetaTitle(?string $metaTitle): void + { + $this->metaTitle = $metaTitle; + } + + public function getMetaDescription(): ?string + { + return $this->metaDescription; + } + + public function setMetaDescription(?string $metaDescription): void + { + $this->metaDescription = $metaDescription; + } + + public function getMetaKeywords(): ?string + { + return $this->metaKeywords; + } + + public function setMetaKeywords(?string $metaKeywords): void + { + $this->metaKeywords = $metaKeywords; + } } diff --git a/src/Entity/ArticleTranslationInterface.php b/src/Entity/ArticleTranslationInterface.php index f274148..372e831 100644 --- a/src/Entity/ArticleTranslationInterface.php +++ b/src/Entity/ArticleTranslationInterface.php @@ -29,4 +29,16 @@ public function setDescription(?string $description): void; public function getContent(): ?string; public function setContent(string $content): void; + + public function getMetaTitle(): ?string; + + public function setMetaTitle(?string $metaTitle): void; + + public function getMetaDescription(): ?string; + + public function setMetaDescription(?string $metaDescription): void; + + public function getMetaKeywords(): ?string; + + public function setMetaKeywords(?string $metaKeywords): void; } diff --git a/src/Form/Type/ArticleTranslationType.php b/src/Form/Type/ArticleTranslationType.php index 24fde17..bf883c1 100644 --- a/src/Form/Type/ArticleTranslationType.php +++ b/src/Form/Type/ArticleTranslationType.php @@ -39,6 +39,17 @@ public function buildForm(FormBuilderInterface $builder, array $options): void ->add('content', RichEditorType::class, [ 'label' => 'monsieurbiz_blog.form.article.content', ]) + ->add('metaTitle', TextType::class, [ + 'label' => 'monsieurbiz_blog.form.article.meta_title', + 'help' => 'monsieurbiz_blog.form.article.help.meta_title', + ]) + ->add('metaDescription', TextType::class, [ + 'label' => 'monsieurbiz_blog.form.article.meta_description', + 'help' => 'monsieurbiz_blog.form.article.help.meta_description', + ]) + ->add('metaKeywords', TextType::class, [ + 'label' => 'monsieurbiz_blog.form.article.meta_keywords', + ]) ; } } diff --git a/src/Migrations/Version20240820090632.php b/src/Migrations/Version20240820090632.php new file mode 100644 index 0000000..a0211b9 --- /dev/null +++ b/src/Migrations/Version20240820090632.php @@ -0,0 +1,38 @@ + + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +declare(strict_types=1); + +namespace MonsieurBiz\SyliusBlogPlugin\Migrations; + +use Doctrine\DBAL\Schema\Schema; +use Doctrine\Migrations\AbstractMigration; + +/** + * Auto-generated Migration: Please modify to your needs! + */ +final class Version20240820090632 extends AbstractMigration +{ + public function getDescription(): string + { + return ''; + } + + public function up(Schema $schema): void + { + // this up() migration is auto-generated, please modify it to your needs + $this->addSql('ALTER TABLE monsieurbiz_blog_article_translation ADD metaTitle VARCHAR(255) DEFAULT NULL, ADD metaDescription LONGTEXT DEFAULT NULL, ADD metaKeywords VARCHAR(255) DEFAULT NULL'); + } + + public function down(Schema $schema): void + { + // this down() migration is auto-generated, please modify it to your needs + $this->addSql('ALTER TABLE monsieurbiz_blog_article_translation DROP metaTitle, DROP metaDescription, DROP metaKeywords'); + } +} diff --git a/src/Resources/config/doctrine/ArticleTranslation.orm.xml b/src/Resources/config/doctrine/ArticleTranslation.orm.xml index 4d0c4a3..6ef4714 100644 --- a/src/Resources/config/doctrine/ArticleTranslation.orm.xml +++ b/src/Resources/config/doctrine/ArticleTranslation.orm.xml @@ -15,6 +15,10 @@ + + + + diff --git a/src/Resources/config/images.yaml b/src/Resources/config/images.yaml index e6ba989..0ad636a 100644 --- a/src/Resources/config/images.yaml +++ b/src/Resources/config/images.yaml @@ -6,3 +6,4 @@ liip_imagine: monsieurbiz_blog_image_thumbnail: filters: thumbnail: { size: [260, 260], mode: outbound } + monsieurbiz_blog_image_og_image: ~ diff --git a/src/Resources/translations/messages.en.yaml b/src/Resources/translations/messages.en.yaml index db7a095..3b7676b 100644 --- a/src/Resources/translations/messages.en.yaml +++ b/src/Resources/translations/messages.en.yaml @@ -11,6 +11,12 @@ monsieurbiz_blog: image: Image description: Description authors: Authors + meta_title: Meta title + meta_description: Meta description + meta_keywords: Meta keywords + help: + meta_title: If empty, the title will be used. + meta_description: If empty, the description will be used. author: name: Name ui: diff --git a/src/Resources/translations/messages.fr.yaml b/src/Resources/translations/messages.fr.yaml index 4e17a3e..83c2266 100644 --- a/src/Resources/translations/messages.fr.yaml +++ b/src/Resources/translations/messages.fr.yaml @@ -11,6 +11,12 @@ monsieurbiz_blog: image: Image description: Description authors: Auteurs + meta_title: Meta title + meta_description: Meta description + meta_keywords: Meta keywords + help: + meta_title: Si vide, le titre sera utilisé. + meta_description: Si vide, la description sera utilisée. author: name: Nom ui: diff --git a/src/Resources/views/Shop/Article/Metatags/_image.html.twig b/src/Resources/views/Shop/Article/Metatags/_image.html.twig new file mode 100644 index 0000000..afd1f3d --- /dev/null +++ b/src/Resources/views/Shop/Article/Metatags/_image.html.twig @@ -0,0 +1,3 @@ +{% if article.image is not empty %} + +{% endif %} diff --git a/src/Resources/views/Shop/Article/_metadata.html.twig b/src/Resources/views/Shop/Article/_metadata.html.twig new file mode 100644 index 0000000..de3831c --- /dev/null +++ b/src/Resources/views/Shop/Article/_metadata.html.twig @@ -0,0 +1,13 @@ +{% set metaTitle = article.metaTitle|default(article.title) %} +{% set metaDescription = article.metaDescription|default(article.title) %} + + + + + + +{% include '@MonsieurBizSyliusBlogPlugin/Shop/Article/Metatags/_image.html.twig' %} + +{% if article.metaKeywords|default('') is not empty %} + +{% endif %} diff --git a/src/Resources/views/Shop/Article/show.html.twig b/src/Resources/views/Shop/Article/show.html.twig index c20fa54..9a870e0 100644 --- a/src/Resources/views/Shop/Article/show.html.twig +++ b/src/Resources/views/Shop/Article/show.html.twig @@ -5,6 +5,7 @@ {% endblock %} {% block metatags %} + {% include '@MonsieurBizSyliusBlogPlugin/Shop/Article/_metadata.html.twig' %} {% include '@MonsieurBizSyliusBlogPlugin/Shop/Article/_structured_data.html.twig' %} {% endblock %}