A reusable Django app that provides threaded conversations between users.
Project description
A reusable Django app that provides threaded conversations between users.
Installation
To get the latest stable release from PyPi
$ pip install django-conversation
To get the latest commit from GitHub
$ pip install -e git+git://github.com/bitmazk/django-conversation.git#egg=conversation
TODO: Describe further installation steps (edit / remove the examples below):
Add conversation to your INSTALLED_APPS
INSTALLED_APPS = (
...,
'conversation',
'django_libs',
)
Add the conversation URLs to your urls.py
urlpatterns = patterns('',
...
url(r'^conversation/', include('conversation.urls')),
)
Don’t forget to migrate your database
./manage.py migrate conversation
Usage
Please add the following files to your base.html
<link rel="stylesheet" href="{% static "conversation/css/conversation.css" %}">
<script src="{% static "conversation/js/conversation.js" %}"></script>
The conversations in this app are threaded, that means a conversation is related to one object. In this case the object is a user. So if user1 starts a conversation with user2 all messages between those users are stored in one conversation (you know it, if your are e.g. a Facebook user).
This app allows another relation, so you can also add a content object to a conversation between two users. Let’s say you built a sports app. user1 wants to talk with user2 about a fight called Klitschko vs. Tyson. They can now start a conversation, which is also related to that fight. But, they can also start a new conversation about other fights or talk to each other without another relation, for sure.
If you have executed the tasks written above, the app is ready to work. Note: The templates are based on Twitter Bootstrap (http://getbootstrap.com/). If you don’t use it, simply overwrite them.
In almost every case you want to customize stuff, add jQuery/JavaScript, add CSS, your own templates and so on, so this app is kept very simple.
Settings
CONVERSATION_MESSAGE_FORM
Default: None
If you want to use your own message form, you can define it here.
CONVERSATION_MESSAGE_FORM = 'my_app.forms.MyMessageForm'
CONVERSATION_ENABLE_DIGEST
Default: True
You can enable digests of unread messages by running ./manage.py send_message_digest.
If you want to disable the digest you can set the setting to False.
CONVERSATION_ENABLE_DIGEST = False
CONVERSATION_ENABLE_NOTIFICATIONS
Default: True
You can enable instant email notification, which are sent each time a new message has arrived.
If you want to disable notifications you can set the setting to False.
CONVERSATION_ENABLE_NOTIFICATIONS = False
User specific notification settings
You can also disable notifications for single users by adding an attribute to your user model. Name it disable_conversation_notifications.
Contribute
If you want to contribute to this project, please perform the following steps
# Fork this repository
# Clone your fork
mkvirtualenv -p python2.7 django-conversation
make develop
git co -b feature_branch master
# Implement your feature and tests
git add . && git commit
git push -u origin feature_branch
# Send us a pull request for your feature branch
In order to run the tests, simply execute tox. This will install two new environments (for Django 1.8 and Django 1.9) and run the tests against both environments.
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
File details
Details for the file django-conversation-1.4.10.tar.gz
.
File metadata
- Download URL: django-conversation-1.4.10.tar.gz
- Upload date:
- Size: 37.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/2.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9d8f767ea56f0208c9f1130733b18b92e8f3651186bacd7a59e8668d3b6b8af6 |
|
MD5 | 544b181df988e8a6eea3c6ea02b06d71 |
|
BLAKE2b-256 | 21a4a198e5215858c09935a10f12e8d8b6d746ecbc36dde227238781ac2e63a5 |