A Django app to add star ratings to models.
Project description
Python 3 compatible ratings for Django.
Add ratings to any Django model with a template tag.
Installation
Install from PyPI:
pip install django-star-ratings
add star_ratings to INSTALLED_APPS:
INSTALLED_APPS = ( ... 'star_ratings' )
sync your database:
python manage.py migrate
add the following to your urls.py:
url(r'^ratings/', include('star_ratings.urls', namespace='ratings', app_name='ratings')),
Make sure 'django.core.context_processors.request', is in TEMPLATE_CONTEXT_PROCESSORS.
Usage
Add the following javascript and stylesheet to your template
{% load static %} <html> ... <link rel="stylesheet" href="{% static 'star-ratings/css/star-ratings.css' %}"> <script type="text/javascript" src="{% static 'star-ratings/js/dist/star-ratings.min.js' %}"></script> ... </html>
To enable ratings for a model add the following tag in your template
{% load ratings %} <html> ... {% ratings object %} ... </html>
Settings
To prohibit users from altering their ratings set STAR_RATINGS_RERATE = False in settings.py
To change the number of rating stars, set STAR_RATINGS_RANGE (defaults to 5)
To enable anonymous rating set STAR_RATINGS_ANONYMOUS = True.
Anonymous Rating
- If anonymous rating is enabled only the ip address for the rater will be stored (even if the user is logged in). When
a user rates an object a preexisting object will not be searched for, instead a new rating object will be created
If this value is changed your lookups will return different results!
To control the default size of stars in pixels set the values of STAR_RATINGS_STAR_HEIGHT and STAR_RATINGS_STAR_WIDTH. By default STAR_RATINGS_STAR_WIDTH is the same as STAR_RATINGS_STAR_HEIGHT and STAR_RATINGS_STAR_HEIGHT defaults to 32.
Changing the star graphics
To change the star graphic, add a sprite sheet to /static/star-ratings/images/stars.png with the states aligned horizontally. The stars should be laid out in three states: full, empty and active.
Customize widget template
You can customize ratings widget by creating star_ratings/widget.html. For example :
{% extends "star_ratings/widget_base.html" %} {% block rating_detail %} Whatever you want {% endblock %}
See star_ratings/widget_base.html for other blocks to be extended.
Ordering by ratings
The easiest way to order by ratings is to add a GenericRelation to the Rating model from your model:
from django.contrib.contenttypes.fields import GenericRelation from star_ratings.models import Rating class Foo(models.Model): bar = models.CharField(max_length=100) ratings = GenericRelation(Rating, related_query_name='foos') Foo.objects.filter(ratings__isnull=False).order_by('ratings__average')
Running tests
To run the test use:
$> ./runtests.py
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for django-star-ratings-0.5.3.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0532a48669dacb4a0b72db6a4a7b4402f9c4bd69b287430f0bd48473087c82e7 |
|
MD5 | d34f165284f7ea1fa9baaad00504df40 |
|
BLAKE2b-256 | 73c06c7ce724ab8ccc8662298b2a0ce6a38df9177df4f17e5ac8cd4e09e18565 |
Hashes for django_star_ratings-0.5.3-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e96d439943261f07a59d451bfcce989c7a7db63d144c9e7c4afa998d03be1376 |
|
MD5 | d643a86471239146d96b98b6f9c664a4 |
|
BLAKE2b-256 | 0e5aa5a99aa6a5c54ddb69e3013359edfbdc2bf054fdfd61efe68417f0fa897c |