Skip to main content

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)
```

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-favs-sc-0.2.4.tar.gz (7.6 kB view details)

Uploaded Source

Built Distribution

django_favs_sc-0.2.4-py2-none-any.whl (10.5 kB view details)

Uploaded Python 2

File details

Details for the file django-favs-sc-0.2.4.tar.gz.

File metadata

File hashes

Hashes for django-favs-sc-0.2.4.tar.gz
Algorithm Hash digest
SHA256 eb106eb69aaf8b53f3b522b4779bb7396628435bfea45c320e678d3e3e88bfb2
MD5 b2aeb5599ded6179e995415bc684dba8
BLAKE2b-256 368abaeda7d7d82660fe2799dc35b7ab864f672cdd3e5bffc4352e4aae5a6fc2

See more details on using hashes here.

File details

Details for the file django_favs_sc-0.2.4-py2-none-any.whl.

File metadata

File hashes

Hashes for django_favs_sc-0.2.4-py2-none-any.whl
Algorithm Hash digest
SHA256 082936e2103911c96e6dc0529f8571403a949e81b37f3ff4c68438b41b9da7e4
MD5 fa9f4400dd6f9b905dde7d26419a9c49
BLAKE2b-256 749ce56e6d0669820122607b662aced3d55910cecfc245e3a8aa36e8be5a62df

See more details on using hashes here.

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