A simple reusable app for django that makes it easy to deal with faving
Project description
# django-favit
A simple reusable app for django that makes it easy to deal with faving
and unfaving any object from any application.
## Installation
* Install django-favit in your vilrtual env:
```
pip install django-favit
```
* Add the app to your settings.py
```python
INSTALLED_APPS = [
...
"favit",
...
]
```
* Add favit urls to your project's `urls.py` file:
```python
urlpatterns = patterns('',
...
(r'^favit/', include('favit.urls')),
...
)
```
* Sync your database:
```
python manage.py syncdb
```
* Make sure you have jQuery ajax CSRF configuration right
See https://docs.djangoproject.com/en/1.7/ref/contrib/csrf/#ajax
## Usage:
### Template tags:
* Get the favorited objects for a given user:
```python
{% with user_favorites <user> "app_label.model" as favorite_list %}
{% for fav_obj in favorite_list %}
{# do something with fav_obj #}
{% endfor %}
{% endwith %}
```
* Given an object `obj` you may show it fav count like this:
```python
<p>Favorite Count {{ obj|favorites_count }}</p>
```
* Get Favorite instance for an object (obj) and a user (user)
```python
{% with obj|get_favorite_for:user as fav_object %}
...
{% endwith %}
```
* Favorite Button for an object `my_obj`:
```python
{% favorite_button my_obj %}
```
### Favorites Manager
* Create a Favorite instance for a user and object:
```python
>>> from django.contrib.auth.models import User
>>> from music.models import Song
>>> user = User.objects.get(username='jdoe')
>>> song = Song.objects.get(pk=1)
>>> fav = Favorite.objects.create(user, song)
```
or:
```python
>>> fav = Favorite.objects.create(user, 1, Song)
```
or:
```python
>>> fav = Favorite.objects.create(user, 1, "music.Song")
```
* Get the objects favorited by a given user:
```python
>>> from django.contrib.auth.models import User
>>> user = User.objects.get(username='jdoe')
>>> Favorite.objects.for_user(user)
>>> [<Favorite: Favorite object 1>, <Favorite: Favorite object 2>, <Favorite: Favorite object 3>]
```
* Now, get user favorited objects belonging to a given model:
```python
>>> from django.contrib.auth.models import User
>>> from music.models import Song
>>> user = User.objects.get(username='jdoe')
>>> Favorite.objects.for_user(user, model=Song)
>>> [<Favorite: Favorite object 1>, <Favorite: Favorite object 2>, <Favorite: Favorite object 3>]
```
* Get the favorited object instances of a given model favorited by any user:
```python
>>> from music.models import Song
>>> Favorite.objects.for_model(Song)
>>> [<Favorite: Favorite object 1>, <Favorite: Favorite object 2>, <Favorite: Favorite object 3>]
```
* Get a Favorite instance for a given object and user:
```python
>>> from django.contrib.auth.models import User
>>> from music.models import Song
>>> user = User.objects.get(username='jdoe')
>>> song = Song.objects.get(pk=1)
>>> fav = Favorite.objects.get_favorite(user, song)
```
* Get all Favorite instances for a given object
```python
>>> from music.models import Song
>>> song = Song.objects.get(pk=1)
>>> fav = Favorite.objects.for_object(song)
```
A simple reusable app for django that makes it easy to deal with faving
and unfaving any object from any application.
## Installation
* Install django-favit in your vilrtual env:
```
pip install django-favit
```
* Add the app to your settings.py
```python
INSTALLED_APPS = [
...
"favit",
...
]
```
* Add favit urls to your project's `urls.py` file:
```python
urlpatterns = patterns('',
...
(r'^favit/', include('favit.urls')),
...
)
```
* Sync your database:
```
python manage.py syncdb
```
* Make sure you have jQuery ajax CSRF configuration right
See https://docs.djangoproject.com/en/1.7/ref/contrib/csrf/#ajax
## Usage:
### Template tags:
* Get the favorited objects for a given user:
```python
{% with user_favorites <user> "app_label.model" as favorite_list %}
{% for fav_obj in favorite_list %}
{# do something with fav_obj #}
{% endfor %}
{% endwith %}
```
* Given an object `obj` you may show it fav count like this:
```python
<p>Favorite Count {{ obj|favorites_count }}</p>
```
* Get Favorite instance for an object (obj) and a user (user)
```python
{% with obj|get_favorite_for:user as fav_object %}
...
{% endwith %}
```
* Favorite Button for an object `my_obj`:
```python
{% favorite_button my_obj %}
```
### Favorites Manager
* Create a Favorite instance for a user and object:
```python
>>> from django.contrib.auth.models import User
>>> from music.models import Song
>>> user = User.objects.get(username='jdoe')
>>> song = Song.objects.get(pk=1)
>>> fav = Favorite.objects.create(user, song)
```
or:
```python
>>> fav = Favorite.objects.create(user, 1, Song)
```
or:
```python
>>> fav = Favorite.objects.create(user, 1, "music.Song")
```
* Get the objects favorited by a given user:
```python
>>> from django.contrib.auth.models import User
>>> user = User.objects.get(username='jdoe')
>>> Favorite.objects.for_user(user)
>>> [<Favorite: Favorite object 1>, <Favorite: Favorite object 2>, <Favorite: Favorite object 3>]
```
* Now, get user favorited objects belonging to a given model:
```python
>>> from django.contrib.auth.models import User
>>> from music.models import Song
>>> user = User.objects.get(username='jdoe')
>>> Favorite.objects.for_user(user, model=Song)
>>> [<Favorite: Favorite object 1>, <Favorite: Favorite object 2>, <Favorite: Favorite object 3>]
```
* Get the favorited object instances of a given model favorited by any user:
```python
>>> from music.models import Song
>>> Favorite.objects.for_model(Song)
>>> [<Favorite: Favorite object 1>, <Favorite: Favorite object 2>, <Favorite: Favorite object 3>]
```
* Get a Favorite instance for a given object and user:
```python
>>> from django.contrib.auth.models import User
>>> from music.models import Song
>>> user = User.objects.get(username='jdoe')
>>> song = Song.objects.get(pk=1)
>>> fav = Favorite.objects.get_favorite(user, song)
```
* Get all Favorite instances for a given object
```python
>>> from music.models import Song
>>> song = Song.objects.get(pk=1)
>>> fav = Favorite.objects.for_object(song)
```
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
django-favs-sc-0.2.4.tar.gz
(7.6 kB
view details)
Built Distribution
File details
Details for the file django-favs-sc-0.2.4.tar.gz
.
File metadata
- Download URL: django-favs-sc-0.2.4.tar.gz
- Upload date:
- Size: 7.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eb106eb69aaf8b53f3b522b4779bb7396628435bfea45c320e678d3e3e88bfb2 |
|
MD5 | b2aeb5599ded6179e995415bc684dba8 |
|
BLAKE2b-256 | 368abaeda7d7d82660fe2799dc35b7ab864f672cdd3e5bffc4352e4aae5a6fc2 |
File details
Details for the file django_favs_sc-0.2.4-py2-none-any.whl
.
File metadata
- Download URL: django_favs_sc-0.2.4-py2-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 082936e2103911c96e6dc0529f8571403a949e81b37f3ff4c68438b41b9da7e4 |
|
MD5 | fa9f4400dd6f9b905dde7d26419a9c49 |
|
BLAKE2b-256 | 749ce56e6d0669820122607b662aced3d55910cecfc245e3a8aa36e8be5a62df |