Merge pull request #267 from MaevaBrunelles/support-seo-plugin

Add support for SEO Pelican plugin
This commit is contained in:
Alexandre Vicenzi 2021-06-17 01:23:43 +02:00 committed by GitHub
commit 21dd3f677b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 79 additions and 69 deletions

View file

@ -44,6 +44,7 @@ The minimalist [Pelican](http://blog.getpelican.com/) theme.
- [Representative image](https://github.com/getpelican/pelican-plugins/tree/master/representative_image) - [Representative image](https://github.com/getpelican/pelican-plugins/tree/master/representative_image)
- [Neighbors](https://github.com/getpelican/pelican-plugins/tree/master/neighbors) - [Neighbors](https://github.com/getpelican/pelican-plugins/tree/master/neighbors)
- [Tipue Search](https://github.com/getpelican/pelican-plugins/blob/master/tipue_search/) - [Tipue Search](https://github.com/getpelican/pelican-plugins/blob/master/tipue_search/)
- [SEO](https://github.com/pelican-plugins/seo)
## Install ## Install

View file

@ -114,19 +114,22 @@
<meta name="msapplication-TileColor" content="{{ BROWSER_COLOR }}"> <meta name="msapplication-TileColor" content="{{ BROWSER_COLOR }}">
{% endif %} {% endif %}
{% if not PLUGINS or 'seo' not in PLUGINS %}
{% if REL_CANONICAL %} {% if REL_CANONICAL %}
{% if page %} {% if page %}
<link rel="canonical" href="{{ SITEURL }}/{{ page.url }}"> <link rel="canonical" href="{{ SITEURL }}/{{ page.url }}">
{% elif article %} {% elif article %}
<link rel="canonical" href="{{ SITEURL }}/{{ article.url }}"> <link rel="canonical" href="{{ SITEURL }}/{{ article.url }}">
{% elif page_name == 'index' and not articles_previous_page %} {% elif page_name == 'index' and not articles_previous_page %}
<link rel="canonical" href="{{ SITEURL }}/"> <link rel="canonical" href="{{ SITEURL }}">
{% elif author or category or tag or page_name == 'index' %} {% elif author or category or tag or page_name == 'index' %}
<link rel="canonical" href="{{ SITEURL }}/{{ articles_page.url }}"> <link rel="canonical" href="{{ SITEURL }}/{{ articles_page.url }}">
{% else %} {% else %}
<link rel="canonical" href="{{ SITEURL }}/{{ output_file }}"> <link rel="canonical" href="{{ SITEURL }}/{{ output_file }}">
{% endif %} {% endif %}
{% endif %} {% endif %}
{% endif %}
{% block meta %} {% block meta %}
<meta name="author" content="{{ AUTHOR }}" /> <meta name="author" content="{{ AUTHOR }}" />
<meta name="description" content="{{ SITEDESCRIPTION }}" /> <meta name="description" content="{{ SITEDESCRIPTION }}" />

View file

@ -1,10 +1,11 @@
{% if SITELOGO %} {% if not PLUGINS or 'seo' not in PLUGINS %}
{% if SITELOGO %}
{% set default_cover = SITELOGO %} {% set default_cover = SITELOGO %}
{% else %} {% else %}
{% set default_cover = '{{ SITEURL }}/{{ THEME_STATIC_DIR }}/img/profile.png' %} {% set default_cover = '{{ SITEURL }}/{{ THEME_STATIC_DIR }}/img/profile.png' %}
{% endif %} {% endif %}
<script type="application/ld+json"> <script type="application/ld+json">
{ {
"@context": "http://schema.org", "@context": "http://schema.org",
"@type": "BlogPosting", "@type": "BlogPosting",
"name": "{{ article.title|striptags }}", "name": "{{ article.title|striptags }}",
@ -19,5 +20,6 @@
"image": "{{ article.metadata.get('cover', default_cover) }}", "image": "{{ article.metadata.get('cover', default_cover) }}",
"url": "{{ SITEURL }}/{{ article.url }}", "url": "{{ SITEURL }}/{{ article.url }}",
"description": "{{ article.summary|striptags }}" "description": "{{ article.summary|striptags }}"
} }
</script> </script>
{% endif %}

View file

@ -1,14 +1,16 @@
{% if OG_LOCALE %} {% if not PLUGINS or 'seo' not in PLUGINS %}
{% if OG_LOCALE %}
{% set default_locale = OG_LOCALE %} {% set default_locale = OG_LOCALE %}
{% else %} {% else %}
{% set default_locale = 'en_US' %} {% set default_locale = 'en_US' %}
{% endif %} {% endif %}
<meta property="og:site_name" content="{{ SITENAME }}"/> <meta property="og:site_name" content="{{ SITENAME }}"/>
<meta property="og:type" content="blog"/> <meta property="og:type" content="blog"/>
<meta property="og:title" content="{{ SITENAME }}"/> <meta property="og:title" content="{{ SITENAME }}"/>
<meta property="og:description" content="{{ SITEDESCRIPTION }}"/> <meta property="og:description" content="{{ SITEDESCRIPTION }}"/>
<meta property="og:locale" content="{{ default_locale }}"/> <meta property="og:locale" content="{{ default_locale }}"/>
<meta property="og:url" content="{{ SITEURL }}"/> <meta property="og:url" content="{{ SITEURL }}"/>
{% if SITELOGO %} {% if SITELOGO %}
<meta property="og:image" content="{{ SITELOGO }}"> <meta property="og:image" content="{{ SITELOGO }}">
{% endif %}
{% endif %} {% endif %}

View file

@ -1,23 +1,25 @@
{% if OG_LOCALE %} {% if not PLUGINS or 'seo' not in PLUGINS %}
{% if OG_LOCALE %}
{% set default_locale = OG_LOCALE %} {% set default_locale = OG_LOCALE %}
{% else %} {% else %}
{% set default_locale = 'en_US' %} {% set default_locale = 'en_US' %}
{% endif %} {% endif %}
<meta property="og:site_name" content="{{ SITENAME }}"/> <meta property="og:site_name" content="{{ SITENAME }}"/>
<meta property="og:title" content="{{ article.title|striptags|escape }}"/> <meta property="og:title" content="{{ article.title|striptags|escape }}"/>
<meta property="og:description" content="{{ article.summary|striptags|escape }}"/> <meta property="og:description" content="{{ article.summary|striptags|escape }}"/>
<meta property="og:locale" content="{{ article.metadata.get('og_locale', default_locale) }}"/> <meta property="og:locale" content="{{ article.metadata.get('og_locale', default_locale) }}"/>
<meta property="og:url" content="{{ SITEURL }}/{{ article.url }}"/> <meta property="og:url" content="{{ SITEURL }}/{{ article.url }}"/>
<meta property="og:type" content="article"/> <meta property="og:type" content="article"/>
<meta property="article:published_time" content="{{ article.date }}"/> <meta property="article:published_time" content="{{ article.date }}"/>
<meta property="article:modified_time" content="{{ article.modified }}"/> <meta property="article:modified_time" content="{{ article.modified }}"/>
<meta property="article:author" content="{{ SITEURL }}/{{ article.author.url }}"> <meta property="article:author" content="{{ SITEURL }}/{{ article.author.url }}">
<meta property="article:section" content="{{ article.category.name }}"/> <meta property="article:section" content="{{ article.category.name }}"/>
{% for tag in article.tags %} {% for tag in article.tags %}
<meta property="article:tag" content="{{ tag.name|escape }}"/> <meta property="article:tag" content="{{ tag.name|escape }}"/>
{% endfor %} {% endfor %}
{% if 'cover' in article.metadata %} {% if 'cover' in article.metadata %}
<meta property="og:image" content="{{ SITEURL }}/{{ article.metadata['cover'] }}"> <meta property="og:image" content="{{ SITEURL }}/{{ article.metadata['cover'] }}">
{% else %} {% else %}
<meta property="og:image" content="{{ SITELOGO }}"> <meta property="og:image" content="{{ SITELOGO }}">
{% endif %}
{% endif %} {% endif %}