Skip to main content

Social meta tags mixin for django-meta

Project description

https://badge.fury.io/py/django-meta-mixin.png https://travis-ci.org/nephila/django-meta-mixin.png?branch=master https://coveralls.io/repos/nephila/django-meta-mixin/badge.png?branch=master

Concepts

django-meta-mixin provides a mixin to handle metadata in your models.

Actual data are evaluated at runtime pulling values from model attributes and methods.

To use it, defines a _metadata attribute as a dictionary of tag/value pairs;

  • tag is the name of the metatag as used by meta.html template

  • value is a string that is evaluated in the following order:

    • model method name (which is called without argument at runtime)

    • model attribute name (evaluated at runtime)

    • string literal (if any of the above exists)

If value is False or it is evaluated as False at runtime the tag is skipped.

To use this mixin you must invoke as_meta() on the model instance for example in the get_context_data().

Installation

From PyPi:

pip install django-meta-mixin

From github:

pip install -e git+https://github.com/nephila/django-meta-mixin#egg=django-meta-mixin

Usage

  1. Add to installed apps along with django-meta:

    INSTALLED_APPS = [
        ...
        'meta',
        'meta_mixin',
    ]
  2. Configure django-meta according to documentation (https://bitbucket.org/monwara/django-meta#rst-header-installation)

  3. Add meta information to your model:

    from django.db import models
    from meta_mixin.models import ModelMeta
    
    class MyModel(ModelMeta, models.Model):
        name = models.CharField(max_length=20)
        abstract = models.TextField()
        ...
    
        _metadata = {
            'title': 'name',
            'description': 'abstract',
            ...
        }
  4. Push metadata in the context using as_meta method:

    class MyView(DetailView):
    
        ...
    
        def get_context_data(self, **kwargs):
            context = super(MyView, self).get_context_data(self, **kwargs)
            context['meta'] = self.get_object().as_meta()
            return context
  5. Include meta_mixin/meta.html template in your templates:

    {% load sekizai_tags %}
    
    <html {% render_block 'html_extra' %}>
    <head>
        {% include "meta_mixin/meta.html" %}
    </head>
    <body>
    </body>
    </html>

Note

For Google+ support you must add {% render_block ‘html_extra’ %} in your template to add object type definition. See relevant Google+ snippets documentation (https://developers.google.com/+/web/snippet/)

Example

Look at the example folder for a sample implementation.

Available properties

django-meta-mixin currently supports the following properties:

Generic properties

  • title: object title,

  • description: generic object description, used for SEO and as default for specific description,

  • keywords: generic keywords for SEO

  • locale: advertised object locale (if any)

  • image: image to display for object

  • object_type: default object type

  • published_time: date-time of publishing

  • modified_time: date-time of modification

  • expiration_time: date-time of expiration

  • url: canonical object url

Open Graph properties

  • og_description: object description in Open Graph

  • og_type: object type in Open Graph

  • og_app_id: Facebook App ID

  • og_profile_id: Author’s Facebook profileID

  • og_publisher: Facebook URL to publisher’s profile

  • og_author_url: Facebook URL to author’s profile

  • tag: object tags

Twitter Cards properties

  • twitter_description: object description on Twitter card (currently 200 chars max)

  • twitter_type: twitter card type

  • twitter_site: Website twitter account

  • twitter_author: Author twitter account

Google+ Snippet properties

  • gplus_description: object description

  • gplus_type: object type according to schema.org types

  • gplus_author: Author Google+ account

Settings

Some of the above properties can be set either in the model or via settings paramaters

  • image: META_DEFAULT_IMAGE (must be an absolute URL)

  • object_type: META_SITE_TYPE

  • og_type: META_FB_TYPE

  • og_app_id: META_FB_APPID

  • og_profile_id: META_FB_PROFILE_ID

  • og_publisher: META_FB_PUBLISHER

  • og_author_url: META_FB_AUTHOR_URL

  • twitter_type: META_TWITTER_TYPE

  • twitter_site: META_TWITTER_SITE

  • twitter_author: META_TWITTER_AUTHOR

  • gplus_type: META_GPLUS_TYPE

  • gplus_author: META_GPLUS_AUTHOR

History

0.1.1 (2014-06-20)

  • Add make_full_url method to retrieve complete object URL.

0.1.0 (2014-04-19)

  • First release on PyPI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-meta-mixin-0.1.1.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

django_meta_mixin-0.1.1-py2.py3-none-any.whl (9.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-meta-mixin-0.1.1.tar.gz.

File metadata

File hashes

Hashes for django-meta-mixin-0.1.1.tar.gz
Algorithm Hash digest
SHA256 093293d8903166a62379f3ed112f943a582a9bd63dd48709c3c7649af93b3cc8
MD5 ac6b406ff043fbe765c372003ab42a69
BLAKE2b-256 443c9ec01fc6b7d4ba9d3f5b683872a17f0d63c38161db41e44fd67a33096a27

See more details on using hashes here.

Provenance

File details

Details for the file django_meta_mixin-0.1.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_meta_mixin-0.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 09af739fbcf3c753d7fc0957c4469f3b550b3f75b0efe9170f66f6fc5fffbb8a
MD5 a3d8b0bd09aa7878d42af41db8965d7b
BLAKE2b-256 4e9865ea947bef173609e50e3b9625d7c0ebfebd72ef8d596bf4e30230609626

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page