Skip to main content

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


Download files

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

Source Distribution

django-conversation-1.4.10.tar.gz (37.1 kB view details)

Uploaded Source

File details

Details for the file django-conversation-1.4.10.tar.gz.

File metadata

File hashes

Hashes for django-conversation-1.4.10.tar.gz
Algorithm Hash digest
SHA256 9d8f767ea56f0208c9f1130733b18b92e8f3651186bacd7a59e8668d3b6b8af6
MD5 544b181df988e8a6eea3c6ea02b06d71
BLAKE2b-256 21a4a198e5215858c09935a10f12e8d8b6d746ecbc36dde227238781ac2e63a5

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