Based on Leah Culver's django-elsewhere, formerly Django-PSN (Portable Social Networks).
This version of django-elsewhere allows any object to be linked to external network by using a generic foreign key.
-
[Leah Culver] (http://leahculver.com)
-
[Chris Drackett] (http://chrisdrackett.com/)
-
[Guillaume Libersat] (http://spreadband.com)
-
[Aziz M. Bookwala] (https://github.com/azizmb)
-
Please send feedback to [email protected]
-
You can get the source directly from GitHub either by downloading the project or checking out the repository: 'git clone git://github.com/SpreadBand/django-elsewhere.git'
-
After checking the project out, add the 'elsewhere' directory to your Python path.
-
Once the project is on your python path, add 'elsewhere' to your INSTALLED_APPS in settings.py.
-
Run python manage.py syncdb from within your project to add the elsewhere database tables and initial data.
-
If not using django-staticfiles, copy the media folder to your project media folder
Django-elsewhere any objects of a website te be linked with information about their related online social networks. The project was created to let Pownce users show their friends what other online social networks they participate in. The hyperlinks to other profiles make use of the XFN rel="me" standard [http://www.gmpg.org/xfn/] (http://www.gmpg.org/xfn/), which enables auto-discovery of social network profiles which the user has chosen to consolidate into a single identity.
- Django 1.0
- Django Contrib Auth, place 'django.contrib.auth' in INSTALLED_APPS setting
Add the following to your urlconf:
(r'^elsewhere/', include('elsewhere.urls'))
For sample templates add the path to elsewhere/templates to your TEMPLATE_DIRS setting.
Load elsewhere templatetags:
{% load elsewhere_tags %}
There are three tags available:
- For social networks : socialnetworks_for_object
- For instant messengers : instantmessengers_for_object
- For websites : websites_for_object
Example:
<ul>
{% socialnetworks_for_object band as socialnetworks %}
{% for socialnetwork in socialnetworks %}
<li>
<img src="{{ socialnetwork.network.icon_url }}">
<a href="{{ socialnetwork.url }}">{{ socialnetwork.username }}</a>
</li>
{% endfor %}
</ul>
Each network object has an icon_url property that will render the icon Just use:
{{ profile.network.icon_url }}
To enable the icons in production, you'll need to point your webserver to the icon directory (or run build_static if using django-staticmedia).
You can also use an icon pack. To do so, just set ELSEWHERE_ICON_PACK in your settings file and copy the icons to the elsewhere media folder. Make sure the icons are the same name as specified in the settings or in the default list.
This is controlled by the ELSEWHERE_MEDIA_DIR environement variable, which defaults to "/images/elsewhere/". The default path to an icon is like: /elsewhere/img/vox.png
For Django-elsewhere, the online profiles have been divided into three categories:
- Social Networks (online social site profiles)
- Instant Messengers (screennames)
- Websites (can be used for other types of online profiles such as weblogs or OpenID providers)
You can create and edit these either in the Django admin or using Django forms.
You can define your own list of available social networks and instant messengers by adding SOCIAL_NETWORKS and/or INSTANT_MESSENGERS lists to your settings:
SOCIAL_NETWORKS = [
{
'id': 'facebook',
'name': 'Facebook',
'url': 'http://www.facebook.com/profile.php?id=%s',
'identifier': 'User ID',
'icon': 'facebook.png',
},
{
'id': 'myspace',
'name': 'MySpace',
'url': 'http://www.myspace.com/%s',
'identifier': 'Username',
'icon': 'myspace.png',
},
]
INSTANT_MESSENGERS = [
{
'id': 'aim',
'name': 'AIM',
'url': 'aim:goim?screenname=%s',
'icon': 'aim.png',
},
{
'id': 'yahoo',
'name': 'Y!',
'url': 'ymsgr:sendim?%s',
'icon': 'yahoo.png',
},
]
If no SOCIAL_NETWORKS or INSTANT_MESSENGERS are defined in your project settings, django-elsewhere will default to using the lists in default_lists.py.
- [Portable Social Networks for Django] (http://leahculver.com/2007/09/03/portable-social-networks-for-django/) - Leah Culver
- [Thoughts on the Social Graph] (http://bradfitz.com/social-graph-problem/) - Brad Fitzpatrick and David Recordon
- [Microformats Social Network Portability] (http://microformats.org/wiki/social-network-portability) - from the Microformats wiki
- [XHTML Friends Network] (http://www.gmpg.org/xfn/)
- [Building Blocks for Portable Social Networks] (http://www.brianoberkirch.com/2007/08/08/building-blocks-for-portable-social-networks/) - Brian Oberkirch
- [Following Friends Across Walled Gardens] (http://www.personalinfocloud.com/2006/11/following_frien.html) - Thomas Vander Wal
- [Open Social Graph @ Plaxo] (http://www.plaxo.com/info/opensocialgraph) - identity consolidation tools